/** * Micox Word Wrap 2.0 * elmicoxcodes.blogspot.com - www.ievolutionweb.com - micoxjcg@yahoo.com.br * Creative Commons License - creativecommons.org * * Description: * Wraps large words in Firefox and Opera. * Works just like the word-wrap: break-word; CSS property in Internet Explorer * * Usage: * 1) Include this JS file in your page. Example: * 2) Set 'word-wrap' as the classname of the elements that you want to word break. Example:
*
**/
function wrap(quem){
var larg_total,larg_carac,quant_quebra,pos_quebra, over_orig;
var elementos,quem, pai, caracs, texto, pai_texto, display_orig, wid_orig;
if(quem.nodeType==3){
//elemento tipo texto. tenho que verificar se o pai dele t quebrando
if(quem.nodeValue.replace('\n','').replace('\t','').trim()==''){
//se o textNode for vazio, no prossigo
return true;
}
pai = quem.parentNode;
texto = quem.nodeValue;
//pegando a largura setada oficial
display_orig = pai.style.display;
over_orig = pai.style.overflow;
wid_orig = pai.style.width;
pai.style.display="block";
pai.style.overflow="hidden";
larg_oficial = pai.offsetWidth;
//pegando a largura real total
pai.style.display="table";
pai.style.width = "auto"; //para o Opera
pai.style.overflow = "visible";
larg_total = pai.offsetWidth;
//alert("texto: " + texto + " \r\n larg_oficial:" + larg_oficial + " \r\n larg_total:" + larg_total)
pai.style.overflow = over_orig;
if(larg_total>larg_oficial){ //se o pai do text t extrapolando, quebro o text
pos_quebra = 0;
caracs = pai.textContent.length;
//recalculando a largura real tirando os espaos pra poder calcular
// direito a largura dos caracs e quando vou quebrar
quem.nodeValue = pai.textContent.replace(/ /g,"") + " ";
larg_total = pai.offsetWidth;
pai.style.display = display_orig;
larg_carac = larg_total / caracs ;
quant_quebra = parseInt(larg_oficial/larg_carac) - 2;
quant_quebra = quant_quebra>0 ? quant_quebra : 1 ;
quem.nodeValue = '';
while(pos_quebra<=caracs){
quem.nodeValue += texto.substring(pos_quebra,pos_quebra + quant_quebra) + " "
pos_quebra = pos_quebra + quant_quebra;
}
}
pai.style.display = display_orig;
pai.style.display = over_orig;
pai.style.width = wid_orig;
}else if(quem.childNodes.length==1 && quem.childNodes[0].nodeType==3){
// o ltimo do nvel e o nico filho texto
texto = String(quem.innerHTML); //salvando o original
/*quem.innerHTML = " "
display_orig = quem.style.display;
quem.style.display="block";
larg_oficial = quem.offsetWidth;
quem.style.display="table";
quem.innerHTML = texto;
larg_total = quem.offsetWidth;*/
//pegando a largura setada oficial
display_orig = quem.style.display;
over_orig = quem.style.overflow;
wid_orig = quem.style.width;
quem.style.display="block";
quem.style.overflow="hidden";
larg_oficial = quem.offsetWidth;
//pegando a largura real total
quem.style.display="table";
quem.style.width = "auto"; //para o Opera
quem.style.overflow = "visible";
larg_total = quem.offsetWidth;
//alert("texto: " + texto + " \r\n larg_oficial:" + larg_oficial + " \r\n larg_total:" + larg_total)
quem.style.overflow = over_orig;
if(larg_total>larg_oficial){ //quebrando quem extrapolou
pos_quebra = 0;
caracs = texto.length;
//recalculando a largura real tirando os espaos pra poder calcular
// direito a largura dos caracs e quando vou quebrar
quem.innerHTML = quem.innerHTML.replace(/ /g,"");
larg_total = quem.offsetWidth;
larg_carac = larg_total / caracs ;
quant_quebra = parseInt(larg_oficial/larg_carac) - 2;
quant_quebra = quant_quebra>0 ? quant_quebra : 1 ;
quem.innerHTML = ""
while(pos_quebra<=caracs){
quem.innerHTML += texto.substring(pos_quebra,pos_quebra + quant_quebra) + " "
pos_quebra = pos_quebra + quant_quebra;
}
}
quem.style.display = display_orig;
quem.style.display = over_orig;
quem.style.width = wid_orig;
}else if(quem.childNodes.length>0){
//se tiver mais que um filho, vou ter que executar de filho em filho nele
for(var i=0;i