/static/scripts/tiny_mce/plugins/style/js/props.js
JavaScript | 641 lines | 491 code | 135 blank | 15 comment | 72 complexity | 704cc52cc4973f3a6ae667b634aca2b9 MD5 | raw file
1tinyMCEPopup.requireLangPack(); 2 3var defaultFonts = "" + 4 "Arial, Helvetica, sans-serif=Arial, Helvetica, sans-serif;" + 5 "Times New Roman, Times, serif=Times New Roman, Times, serif;" + 6 "Courier New, Courier, mono=Courier New, Courier, mono;" + 7 "Times New Roman, Times, serif=Times New Roman, Times, serif;" + 8 "Georgia, Times New Roman, Times, serif=Georgia, Times New Roman, Times, serif;" + 9 "Verdana, Arial, Helvetica, sans-serif=Verdana, Arial, Helvetica, sans-serif;" + 10 "Geneva, Arial, Helvetica, sans-serif=Geneva, Arial, Helvetica, sans-serif"; 11 12var defaultSizes = "9;10;12;14;16;18;24;xx-small;x-small;small;medium;large;x-large;xx-large;smaller;larger"; 13var defaultMeasurement = "+pixels=px;points=pt;em;in;cm;mm;picas;ems;exs;%"; 14var defaultSpacingMeasurement = "pixels=px;points=pt;in;cm;mm;picas;+ems;exs;%"; 15var defaultIndentMeasurement = "pixels=px;+points=pt;in;cm;mm;picas;ems;exs;%"; 16var defaultWeight = "normal;bold;bolder;lighter;100;200;300;400;500;600;700;800;900"; 17var defaultTextStyle = "normal;italic;oblique"; 18var defaultVariant = "normal;small-caps"; 19var defaultLineHeight = "normal"; 20var defaultAttachment = "fixed;scroll"; 21var defaultRepeat = "no-repeat;repeat;repeat-x;repeat-y"; 22var defaultPosH = "left;center;right"; 23var defaultPosV = "top;center;bottom"; 24var defaultVAlign = "baseline;sub;super;top;text-top;middle;bottom;text-bottom"; 25var defaultDisplay = "inline;block;list-item;run-in;compact;marker;table;inline-table;table-row-group;table-header-group;table-footer-group;table-row;table-column-group;table-column;table-cell;table-caption;none"; 26var defaultBorderStyle = "none;solid;dashed;dotted;double;groove;ridge;inset;outset"; 27var defaultBorderWidth = "thin;medium;thick"; 28var defaultListType = "disc;circle;square;decimal;lower-roman;upper-roman;lower-alpha;upper-alpha;none"; 29 30function init() { 31 var ce = document.getElementById('container'), h; 32 33 ce.style.cssText = tinyMCEPopup.getWindowArg('style_text'); 34 35 h = getBrowserHTML('background_image_browser','background_image','image','advimage'); 36 document.getElementById("background_image_browser").innerHTML = h; 37 38 document.getElementById('text_color_pickcontainer').innerHTML = getColorPickerHTML('text_color_pick','text_color'); 39 document.getElementById('background_color_pickcontainer').innerHTML = getColorPickerHTML('background_color_pick','background_color'); 40 document.getElementById('border_color_top_pickcontainer').innerHTML = getColorPickerHTML('border_color_top_pick','border_color_top'); 41 document.getElementById('border_color_right_pickcontainer').innerHTML = getColorPickerHTML('border_color_right_pick','border_color_right'); 42 document.getElementById('border_color_bottom_pickcontainer').innerHTML = getColorPickerHTML('border_color_bottom_pick','border_color_bottom'); 43 document.getElementById('border_color_left_pickcontainer').innerHTML = getColorPickerHTML('border_color_left_pick','border_color_left'); 44 45 fillSelect(0, 'text_font', 'style_font', defaultFonts, ';', true); 46 fillSelect(0, 'text_size', 'style_font_size', defaultSizes, ';', true); 47 fillSelect(0, 'text_size_measurement', 'style_font_size_measurement', defaultMeasurement, ';', true); 48 fillSelect(0, 'text_case', 'style_text_case', "capitalize;uppercase;lowercase", ';', true); 49 fillSelect(0, 'text_weight', 'style_font_weight', defaultWeight, ';', true); 50 fillSelect(0, 'text_style', 'style_font_style', defaultTextStyle, ';', true); 51 fillSelect(0, 'text_variant', 'style_font_variant', defaultVariant, ';', true); 52 fillSelect(0, 'text_lineheight', 'style_font_line_height', defaultLineHeight, ';', true); 53 fillSelect(0, 'text_lineheight_measurement', 'style_font_line_height_measurement', defaultMeasurement, ';', true); 54 55 fillSelect(0, 'background_attachment', 'style_background_attachment', defaultAttachment, ';', true); 56 fillSelect(0, 'background_repeat', 'style_background_repeat', defaultRepeat, ';', true); 57 58 fillSelect(0, 'background_hpos_measurement', 'style_background_hpos_measurement', defaultMeasurement, ';', true); 59 fillSelect(0, 'background_vpos_measurement', 'style_background_vpos_measurement', defaultMeasurement, ';', true); 60 61 fillSelect(0, 'background_hpos', 'style_background_hpos', defaultPosH, ';', true); 62 fillSelect(0, 'background_vpos', 'style_background_vpos', defaultPosV, ';', true); 63 64 fillSelect(0, 'block_wordspacing', 'style_wordspacing', 'normal', ';', true); 65 fillSelect(0, 'block_wordspacing_measurement', 'style_wordspacing_measurement', defaultSpacingMeasurement, ';', true); 66 fillSelect(0, 'block_letterspacing', 'style_letterspacing', 'normal', ';', true); 67 fillSelect(0, 'block_letterspacing_measurement', 'style_letterspacing_measurement', defaultSpacingMeasurement, ';', true); 68 fillSelect(0, 'block_vertical_alignment', 'style_vertical_alignment', defaultVAlign, ';', true); 69 fillSelect(0, 'block_text_align', 'style_text_align', "left;right;center;justify", ';', true); 70 fillSelect(0, 'block_whitespace', 'style_whitespace', "normal;pre;nowrap", ';', true); 71 fillSelect(0, 'block_display', 'style_display', defaultDisplay, ';', true); 72 fillSelect(0, 'block_text_indent_measurement', 'style_text_indent_measurement', defaultIndentMeasurement, ';', true); 73 74 fillSelect(0, 'box_width_measurement', 'style_box_width_measurement', defaultMeasurement, ';', true); 75 fillSelect(0, 'box_height_measurement', 'style_box_height_measurement', defaultMeasurement, ';', true); 76 fillSelect(0, 'box_float', 'style_float', 'left;right;none', ';', true); 77 fillSelect(0, 'box_clear', 'style_clear', 'left;right;both;none', ';', true); 78 fillSelect(0, 'box_padding_left_measurement', 'style_padding_left_measurement', defaultMeasurement, ';', true); 79 fillSelect(0, 'box_padding_top_measurement', 'style_padding_top_measurement', defaultMeasurement, ';', true); 80 fillSelect(0, 'box_padding_bottom_measurement', 'style_padding_bottom_measurement', defaultMeasurement, ';', true); 81 fillSelect(0, 'box_padding_right_measurement', 'style_padding_right_measurement', defaultMeasurement, ';', true); 82 fillSelect(0, 'box_margin_left_measurement', 'style_margin_left_measurement', defaultMeasurement, ';', true); 83 fillSelect(0, 'box_margin_top_measurement', 'style_margin_top_measurement', defaultMeasurement, ';', true); 84 fillSelect(0, 'box_margin_bottom_measurement', 'style_margin_bottom_measurement', defaultMeasurement, ';', true); 85 fillSelect(0, 'box_margin_right_measurement', 'style_margin_right_measurement', defaultMeasurement, ';', true); 86 87 fillSelect(0, 'border_style_top', 'style_border_style_top', defaultBorderStyle, ';', true); 88 fillSelect(0, 'border_style_right', 'style_border_style_right', defaultBorderStyle, ';', true); 89 fillSelect(0, 'border_style_bottom', 'style_border_style_bottom', defaultBorderStyle, ';', true); 90 fillSelect(0, 'border_style_left', 'style_border_style_left', defaultBorderStyle, ';', true); 91 92 fillSelect(0, 'border_width_top', 'style_border_width_top', defaultBorderWidth, ';', true); 93 fillSelect(0, 'border_width_right', 'style_border_width_right', defaultBorderWidth, ';', true); 94 fillSelect(0, 'border_width_bottom', 'style_border_width_bottom', defaultBorderWidth, ';', true); 95 fillSelect(0, 'border_width_left', 'style_border_width_left', defaultBorderWidth, ';', true); 96 97 fillSelect(0, 'border_width_top_measurement', 'style_border_width_top_measurement', defaultMeasurement, ';', true); 98 fillSelect(0, 'border_width_right_measurement', 'style_border_width_right_measurement', defaultMeasurement, ';', true); 99 fillSelect(0, 'border_width_bottom_measurement', 'style_border_width_bottom_measurement', defaultMeasurement, ';', true); 100 fillSelect(0, 'border_width_left_measurement', 'style_border_width_left_measurement', defaultMeasurement, ';', true); 101 102 fillSelect(0, 'list_type', 'style_list_type', defaultListType, ';', true); 103 fillSelect(0, 'list_position', 'style_list_position', "inside;outside", ';', true); 104 105 fillSelect(0, 'positioning_type', 'style_positioning_type', "absolute;relative;static", ';', true); 106 fillSelect(0, 'positioning_visibility', 'style_positioning_visibility', "inherit;visible;hidden", ';', true); 107 108 fillSelect(0, 'positioning_width_measurement', 'style_positioning_width_measurement', defaultMeasurement, ';', true); 109 fillSelect(0, 'positioning_height_measurement', 'style_positioning_height_measurement', defaultMeasurement, ';', true); 110 fillSelect(0, 'positioning_overflow', 'style_positioning_overflow', "visible;hidden;scroll;auto", ';', true); 111 112 fillSelect(0, 'positioning_placement_top_measurement', 'style_positioning_placement_top_measurement', defaultMeasurement, ';', true); 113 fillSelect(0, 'positioning_placement_right_measurement', 'style_positioning_placement_right_measurement', defaultMeasurement, ';', true); 114 fillSelect(0, 'positioning_placement_bottom_measurement', 'style_positioning_placement_bottom_measurement', defaultMeasurement, ';', true); 115 fillSelect(0, 'positioning_placement_left_measurement', 'style_positioning_placement_left_measurement', defaultMeasurement, ';', true); 116 117 fillSelect(0, 'positioning_clip_top_measurement', 'style_positioning_clip_top_measurement', defaultMeasurement, ';', true); 118 fillSelect(0, 'positioning_clip_right_measurement', 'style_positioning_clip_right_measurement', defaultMeasurement, ';', true); 119 fillSelect(0, 'positioning_clip_bottom_measurement', 'style_positioning_clip_bottom_measurement', defaultMeasurement, ';', true); 120 fillSelect(0, 'positioning_clip_left_measurement', 'style_positioning_clip_left_measurement', defaultMeasurement, ';', true); 121 122 TinyMCE_EditableSelects.init(); 123 setupFormData(); 124 showDisabledControls(); 125} 126 127function setupFormData() { 128 var ce = document.getElementById('container'), f = document.forms[0], s, b, i; 129 130 // Setup text fields 131 132 selectByValue(f, 'text_font', ce.style.fontFamily, true, true); 133 selectByValue(f, 'text_size', getNum(ce.style.fontSize), true, true); 134 selectByValue(f, 'text_size_measurement', getMeasurement(ce.style.fontSize)); 135 selectByValue(f, 'text_weight', ce.style.fontWeight, true, true); 136 selectByValue(f, 'text_style', ce.style.fontStyle, true, true); 137 selectByValue(f, 'text_lineheight', getNum(ce.style.lineHeight), true, true); 138 selectByValue(f, 'text_lineheight_measurement', getMeasurement(ce.style.lineHeight)); 139 selectByValue(f, 'text_case', ce.style.textTransform, true, true); 140 selectByValue(f, 'text_variant', ce.style.fontVariant, true, true); 141 f.text_color.value = tinyMCEPopup.editor.dom.toHex(ce.style.color); 142 updateColor('text_color_pick', 'text_color'); 143 f.text_underline.checked = inStr(ce.style.textDecoration, 'underline'); 144 f.text_overline.checked = inStr(ce.style.textDecoration, 'overline'); 145 f.text_linethrough.checked = inStr(ce.style.textDecoration, 'line-through'); 146 f.text_blink.checked = inStr(ce.style.textDecoration, 'blink'); 147 148 // Setup background fields 149 150 f.background_color.value = tinyMCEPopup.editor.dom.toHex(ce.style.backgroundColor); 151 updateColor('background_color_pick', 'background_color'); 152 f.background_image.value = ce.style.backgroundImage.replace(new RegExp("url\\('?([^']*)'?\\)", 'gi'), "$1"); 153 selectByValue(f, 'background_repeat', ce.style.backgroundRepeat, true, true); 154 selectByValue(f, 'background_attachment', ce.style.backgroundAttachment, true, true); 155 selectByValue(f, 'background_hpos', getNum(getVal(ce.style.backgroundPosition, 0)), true, true); 156 selectByValue(f, 'background_hpos_measurement', getMeasurement(getVal(ce.style.backgroundPosition, 0))); 157 selectByValue(f, 'background_vpos', getNum(getVal(ce.style.backgroundPosition, 1)), true, true); 158 selectByValue(f, 'background_vpos_measurement', getMeasurement(getVal(ce.style.backgroundPosition, 1))); 159 160 // Setup block fields 161 162 selectByValue(f, 'block_wordspacing', getNum(ce.style.wordSpacing), true, true); 163 selectByValue(f, 'block_wordspacing_measurement', getMeasurement(ce.style.wordSpacing)); 164 selectByValue(f, 'block_letterspacing', getNum(ce.style.letterSpacing), true, true); 165 selectByValue(f, 'block_letterspacing_measurement', getMeasurement(ce.style.letterSpacing)); 166 selectByValue(f, 'block_vertical_alignment', ce.style.verticalAlign, true, true); 167 selectByValue(f, 'block_text_align', ce.style.textAlign, true, true); 168 f.block_text_indent.value = getNum(ce.style.textIndent); 169 selectByValue(f, 'block_text_indent_measurement', getMeasurement(ce.style.textIndent)); 170 selectByValue(f, 'block_whitespace', ce.style.whiteSpace, true, true); 171 selectByValue(f, 'block_display', ce.style.display, true, true); 172 173 // Setup box fields 174 175 f.box_width.value = getNum(ce.style.width); 176 selectByValue(f, 'box_width_measurement', getMeasurement(ce.style.width)); 177 178 f.box_height.value = getNum(ce.style.height); 179 selectByValue(f, 'box_height_measurement', getMeasurement(ce.style.height)); 180 181 if (tinymce.isGecko) 182 selectByValue(f, 'box_float', ce.style.cssFloat, true, true); 183 else 184 selectByValue(f, 'box_float', ce.style.styleFloat, true, true); 185 186 selectByValue(f, 'box_clear', ce.style.clear, true, true); 187 188 setupBox(f, ce, 'box_padding', 'padding', ''); 189 setupBox(f, ce, 'box_margin', 'margin', ''); 190 191 // Setup border fields 192 193 setupBox(f, ce, 'border_style', 'border', 'Style'); 194 setupBox(f, ce, 'border_width', 'border', 'Width'); 195 setupBox(f, ce, 'border_color', 'border', 'Color'); 196 197 updateColor('border_color_top_pick', 'border_color_top'); 198 updateColor('border_color_right_pick', 'border_color_right'); 199 updateColor('border_color_bottom_pick', 'border_color_bottom'); 200 updateColor('border_color_left_pick', 'border_color_left'); 201 202 f.elements.border_color_top.value = tinyMCEPopup.editor.dom.toHex(f.elements.border_color_top.value); 203 f.elements.border_color_right.value = tinyMCEPopup.editor.dom.toHex(f.elements.border_color_right.value); 204 f.elements.border_color_bottom.value = tinyMCEPopup.editor.dom.toHex(f.elements.border_color_bottom.value); 205 f.elements.border_color_left.value = tinyMCEPopup.editor.dom.toHex(f.elements.border_color_left.value); 206 207 // Setup list fields 208 209 selectByValue(f, 'list_type', ce.style.listStyleType, true, true); 210 selectByValue(f, 'list_position', ce.style.listStylePosition, true, true); 211 f.list_bullet_image.value = ce.style.listStyleImage.replace(new RegExp("url\\('?([^']*)'?\\)", 'gi'), "$1"); 212 213 // Setup box fields 214 215 selectByValue(f, 'positioning_type', ce.style.position, true, true); 216 selectByValue(f, 'positioning_visibility', ce.style.visibility, true, true); 217 selectByValue(f, 'positioning_overflow', ce.style.overflow, true, true); 218 f.positioning_zindex.value = ce.style.zIndex ? ce.style.zIndex : ""; 219 220 f.positioning_width.value = getNum(ce.style.width); 221 selectByValue(f, 'positioning_width_measurement', getMeasurement(ce.style.width)); 222 223 f.positioning_height.value = getNum(ce.style.height); 224 selectByValue(f, 'positioning_height_measurement', getMeasurement(ce.style.height)); 225 226 setupBox(f, ce, 'positioning_placement', '', '', ['top', 'right', 'bottom', 'left']); 227 228 s = ce.style.clip.replace(new RegExp("rect\\('?([^']*)'?\\)", 'gi'), "$1"); 229 s = s.replace(/,/g, ' '); 230 231 if (!hasEqualValues([getVal(s, 0), getVal(s, 1), getVal(s, 2), getVal(s, 3)])) { 232 f.positioning_clip_top.value = getNum(getVal(s, 0)); 233 selectByValue(f, 'positioning_clip_top_measurement', getMeasurement(getVal(s, 0))); 234 f.positioning_clip_right.value = getNum(getVal(s, 1)); 235 selectByValue(f, 'positioning_clip_right_measurement', getMeasurement(getVal(s, 1))); 236 f.positioning_clip_bottom.value = getNum(getVal(s, 2)); 237 selectByValue(f, 'positioning_clip_bottom_measurement', getMeasurement(getVal(s, 2))); 238 f.positioning_clip_left.value = getNum(getVal(s, 3)); 239 selectByValue(f, 'positioning_clip_left_measurement', getMeasurement(getVal(s, 3))); 240 } else { 241 f.positioning_clip_top.value = getNum(getVal(s, 0)); 242 selectByValue(f, 'positioning_clip_top_measurement', getMeasurement(getVal(s, 0))); 243 f.positioning_clip_right.value = f.positioning_clip_bottom.value = f.positioning_clip_left.value; 244 } 245 246// setupBox(f, ce, '', 'border', 'Color'); 247} 248 249function getMeasurement(s) { 250 return s.replace(/^([0-9]+)(.*)$/, "$2"); 251} 252 253function getNum(s) { 254 if (new RegExp('^[0-9]+[a-z%]+$', 'gi').test(s)) 255 return s.replace(/[^0-9]/g, ''); 256 257 return s; 258} 259 260function inStr(s, n) { 261 return new RegExp(n, 'gi').test(s); 262} 263 264function getVal(s, i) { 265 var a = s.split(' '); 266 267 if (a.length > 1) 268 return a[i]; 269 270 return ""; 271} 272 273function setValue(f, n, v) { 274 if (f.elements[n].type == "text") 275 f.elements[n].value = v; 276 else 277 selectByValue(f, n, v, true, true); 278} 279 280function setupBox(f, ce, fp, pr, sf, b) { 281 if (typeof(b) == "undefined") 282 b = ['Top', 'Right', 'Bottom', 'Left']; 283 284 if (isSame(ce, pr, sf, b)) { 285 f.elements[fp + "_same"].checked = true; 286 287 setValue(f, fp + "_top", getNum(ce.style[pr + b[0] + sf])); 288 f.elements[fp + "_top"].disabled = false; 289 290 f.elements[fp + "_right"].value = ""; 291 f.elements[fp + "_right"].disabled = true; 292 f.elements[fp + "_bottom"].value = ""; 293 f.elements[fp + "_bottom"].disabled = true; 294 f.elements[fp + "_left"].value = ""; 295 f.elements[fp + "_left"].disabled = true; 296 297 if (f.elements[fp + "_top_measurement"]) { 298 selectByValue(f, fp + '_top_measurement', getMeasurement(ce.style[pr + b[0] + sf])); 299 f.elements[fp + "_left_measurement"].disabled = true; 300 f.elements[fp + "_bottom_measurement"].disabled = true; 301 f.elements[fp + "_right_measurement"].disabled = true; 302 } 303 } else { 304 f.elements[fp + "_same"].checked = false; 305 306 setValue(f, fp + "_top", getNum(ce.style[pr + b[0] + sf])); 307 f.elements[fp + "_top"].disabled = false; 308 309 setValue(f, fp + "_right", getNum(ce.style[pr + b[1] + sf])); 310 f.elements[fp + "_right"].disabled = false; 311 312 setValue(f, fp + "_bottom", getNum(ce.style[pr + b[2] + sf])); 313 f.elements[fp + "_bottom"].disabled = false; 314 315 setValue(f, fp + "_left", getNum(ce.style[pr + b[3] + sf])); 316 f.elements[fp + "_left"].disabled = false; 317 318 if (f.elements[fp + "_top_measurement"]) { 319 selectByValue(f, fp + '_top_measurement', getMeasurement(ce.style[pr + b[0] + sf])); 320 selectByValue(f, fp + '_right_measurement', getMeasurement(ce.style[pr + b[1] + sf])); 321 selectByValue(f, fp + '_bottom_measurement', getMeasurement(ce.style[pr + b[2] + sf])); 322 selectByValue(f, fp + '_left_measurement', getMeasurement(ce.style[pr + b[3] + sf])); 323 f.elements[fp + "_left_measurement"].disabled = false; 324 f.elements[fp + "_bottom_measurement"].disabled = false; 325 f.elements[fp + "_right_measurement"].disabled = false; 326 } 327 } 328} 329 330function isSame(e, pr, sf, b) { 331 var a = [], i, x; 332 333 if (typeof(b) == "undefined") 334 b = ['Top', 'Right', 'Bottom', 'Left']; 335 336 if (typeof(sf) == "undefined" || sf == null) 337 sf = ""; 338 339 a[0] = e.style[pr + b[0] + sf]; 340 a[1] = e.style[pr + b[1] + sf]; 341 a[2] = e.style[pr + b[2] + sf]; 342 a[3] = e.style[pr + b[3] + sf]; 343 344 for (i=0; i<a.length; i++) { 345 if (a[i] == null) 346 return false; 347 348 for (x=0; x<a.length; x++) { 349 if (a[x] != a[i]) 350 return false; 351 } 352 } 353 354 return true; 355}; 356 357function hasEqualValues(a) { 358 var i, x; 359 360 for (i=0; i<a.length; i++) { 361 if (a[i] == null) 362 return false; 363 364 for (x=0; x<a.length; x++) { 365 if (a[x] != a[i]) 366 return false; 367 } 368 } 369 370 return true; 371} 372 373function applyAction() { 374 var ce = document.getElementById('container'), ed = tinyMCEPopup.editor; 375 376 generateCSS(); 377 378 tinyMCEPopup.restoreSelection(); 379 ed.dom.setAttrib(ed.selection.getNode(), 'style', tinyMCEPopup.editor.dom.serializeStyle(tinyMCEPopup.editor.dom.parseStyle(ce.style.cssText))); 380} 381 382function updateAction() { 383 applyAction(); 384 tinyMCEPopup.close(); 385} 386 387function generateCSS() { 388 var ce = document.getElementById('container'), f = document.forms[0], num = new RegExp('[0-9]+', 'g'), s, t; 389 390 ce.style.cssText = ""; 391 392 // Build text styles 393 ce.style.fontFamily = f.text_font.value; 394 ce.style.fontSize = f.text_size.value + (isNum(f.text_size.value) ? (f.text_size_measurement.value || 'px') : ""); 395 ce.style.fontStyle = f.text_style.value; 396 ce.style.lineHeight = f.text_lineheight.value + (isNum(f.text_lineheight.value) ? f.text_lineheight_measurement.value : ""); 397 ce.style.textTransform = f.text_case.value; 398 ce.style.fontWeight = f.text_weight.value; 399 ce.style.fontVariant = f.text_variant.value; 400 ce.style.color = f.text_color.value; 401 402 s = ""; 403 s += f.text_underline.checked ? " underline" : ""; 404 s += f.text_overline.checked ? " overline" : ""; 405 s += f.text_linethrough.checked ? " line-through" : ""; 406 s += f.text_blink.checked ? " blink" : ""; 407 s = s.length > 0 ? s.substring(1) : s; 408 409 if (f.text_none.checked) 410 s = "none"; 411 412 ce.style.textDecoration = s; 413 414 // Build background styles 415 416 ce.style.backgroundColor = f.background_color.value; 417 ce.style.backgroundImage = f.background_image.value != "" ? "url(" + f.background_image.value + ")" : ""; 418 ce.style.backgroundRepeat = f.background_repeat.value; 419 ce.style.backgroundAttachment = f.background_attachment.value; 420 421 if (f.background_hpos.value != "") { 422 s = ""; 423 s += f.background_hpos.value + (isNum(f.background_hpos.value) ? f.background_hpos_measurement.value : "") + " "; 424 s += f.background_vpos.value + (isNum(f.background_vpos.value) ? f.background_vpos_measurement.value : ""); 425 ce.style.backgroundPosition = s; 426 } 427 428 // Build block styles 429 430 ce.style.wordSpacing = f.block_wordspacing.value + (isNum(f.block_wordspacing.value) ? f.block_wordspacing_measurement.value : ""); 431 ce.style.letterSpacing = f.block_letterspacing.value + (isNum(f.block_letterspacing.value) ? f.block_letterspacing_measurement.value : ""); 432 ce.style.verticalAlign = f.block_vertical_alignment.value; 433 ce.style.textAlign = f.block_text_align.value; 434 ce.style.textIndent = f.block_text_indent.value + (isNum(f.block_text_indent.value) ? f.block_text_indent_measurement.value : ""); 435 ce.style.whiteSpace = f.block_whitespace.value; 436 ce.style.display = f.block_display.value; 437 438 // Build box styles 439 440 ce.style.width = f.box_width.value + (isNum(f.box_width.value) ? f.box_width_measurement.value : ""); 441 ce.style.height = f.box_height.value + (isNum(f.box_height.value) ? f.box_height_measurement.value : ""); 442 ce.style.styleFloat = f.box_float.value; 443 444 if (tinymce.isGecko) 445 ce.style.cssFloat = f.box_float.value; 446 447 ce.style.clear = f.box_clear.value; 448 449 if (!f.box_padding_same.checked) { 450 ce.style.paddingTop = f.box_padding_top.value + (isNum(f.box_padding_top.value) ? f.box_padding_top_measurement.value : ""); 451 ce.style.paddingRight = f.box_padding_right.value + (isNum(f.box_padding_right.value) ? f.box_padding_right_measurement.value : ""); 452 ce.style.paddingBottom = f.box_padding_bottom.value + (isNum(f.box_padding_bottom.value) ? f.box_padding_bottom_measurement.value : ""); 453 ce.style.paddingLeft = f.box_padding_left.value + (isNum(f.box_padding_left.value) ? f.box_padding_left_measurement.value : ""); 454 } else 455 ce.style.padding = f.box_padding_top.value + (isNum(f.box_padding_top.value) ? f.box_padding_top_measurement.value : ""); 456 457 if (!f.box_margin_same.checked) { 458 ce.style.marginTop = f.box_margin_top.value + (isNum(f.box_margin_top.value) ? f.box_margin_top_measurement.value : ""); 459 ce.style.marginRight = f.box_margin_right.value + (isNum(f.box_margin_right.value) ? f.box_margin_right_measurement.value : ""); 460 ce.style.marginBottom = f.box_margin_bottom.value + (isNum(f.box_margin_bottom.value) ? f.box_margin_bottom_measurement.value : ""); 461 ce.style.marginLeft = f.box_margin_left.value + (isNum(f.box_margin_left.value) ? f.box_margin_left_measurement.value : ""); 462 } else 463 ce.style.margin = f.box_margin_top.value + (isNum(f.box_margin_top.value) ? f.box_margin_top_measurement.value : ""); 464 465 // Build border styles 466 467 if (!f.border_style_same.checked) { 468 ce.style.borderTopStyle = f.border_style_top.value; 469 ce.style.borderRightStyle = f.border_style_right.value; 470 ce.style.borderBottomStyle = f.border_style_bottom.value; 471 ce.style.borderLeftStyle = f.border_style_left.value; 472 } else 473 ce.style.borderStyle = f.border_style_top.value; 474 475 if (!f.border_width_same.checked) { 476 ce.style.borderTopWidth = f.border_width_top.value + (isNum(f.border_width_top.value) ? f.border_width_top_measurement.value : ""); 477 ce.style.borderRightWidth = f.border_width_right.value + (isNum(f.border_width_right.value) ? f.border_width_right_measurement.value : ""); 478 ce.style.borderBottomWidth = f.border_width_bottom.value + (isNum(f.border_width_bottom.value) ? f.border_width_bottom_measurement.value : ""); 479 ce.style.borderLeftWidth = f.border_width_left.value + (isNum(f.border_width_left.value) ? f.border_width_left_measurement.value : ""); 480 } else 481 ce.style.borderWidth = f.border_width_top.value; 482 483 if (!f.border_color_same.checked) { 484 ce.style.borderTopColor = f.border_color_top.value; 485 ce.style.borderRightColor = f.border_color_right.value; 486 ce.style.borderBottomColor = f.border_color_bottom.value; 487 ce.style.borderLeftColor = f.border_color_left.value; 488 } else 489 ce.style.borderColor = f.border_color_top.value; 490 491 // Build list styles 492 493 ce.style.listStyleType = f.list_type.value; 494 ce.style.listStylePosition = f.list_position.value; 495 ce.style.listStyleImage = f.list_bullet_image.value != "" ? "url(" + f.list_bullet_image.value + ")" : ""; 496 497 // Build positioning styles 498 499 ce.style.position = f.positioning_type.value; 500 ce.style.visibility = f.positioning_visibility.value; 501 502 if (ce.style.width == "") 503 ce.style.width = f.positioning_width.value + (isNum(f.positioning_width.value) ? f.positioning_width_measurement.value : ""); 504 505 if (ce.style.height == "") 506 ce.style.height = f.positioning_height.value + (isNum(f.positioning_height.value) ? f.positioning_height_measurement.value : ""); 507 508 ce.style.zIndex = f.positioning_zindex.value; 509 ce.style.overflow = f.positioning_overflow.value; 510 511 if (!f.positioning_placement_same.checked) { 512 ce.style.top = f.positioning_placement_top.value + (isNum(f.positioning_placement_top.value) ? f.positioning_placement_top_measurement.value : ""); 513 ce.style.right = f.positioning_placement_right.value + (isNum(f.positioning_placement_right.value) ? f.positioning_placement_right_measurement.value : ""); 514 ce.style.bottom = f.positioning_placement_bottom.value + (isNum(f.positioning_placement_bottom.value) ? f.positioning_placement_bottom_measurement.value : ""); 515 ce.style.left = f.positioning_placement_left.value + (isNum(f.positioning_placement_left.value) ? f.positioning_placement_left_measurement.value : ""); 516 } else { 517 s = f.positioning_placement_top.value + (isNum(f.positioning_placement_top.value) ? f.positioning_placement_top_measurement.value : ""); 518 ce.style.top = s; 519 ce.style.right = s; 520 ce.style.bottom = s; 521 ce.style.left = s; 522 } 523 524 if (!f.positioning_clip_same.checked) { 525 s = "rect("; 526 s += (isNum(f.positioning_clip_top.value) ? f.positioning_clip_top.value + f.positioning_clip_top_measurement.value : "auto") + " "; 527 s += (isNum(f.positioning_clip_right.value) ? f.positioning_clip_right.value + f.positioning_clip_right_measurement.value : "auto") + " "; 528 s += (isNum(f.positioning_clip_bottom.value) ? f.positioning_clip_bottom.value + f.positioning_clip_bottom_measurement.value : "auto") + " "; 529 s += (isNum(f.positioning_clip_left.value) ? f.positioning_clip_left.value + f.positioning_clip_left_measurement.value : "auto"); 530 s += ")"; 531 532 if (s != "rect(auto auto auto auto)") 533 ce.style.clip = s; 534 } else { 535 s = "rect("; 536 t = isNum(f.positioning_clip_top.value) ? f.positioning_clip_top.value + f.positioning_clip_top_measurement.value : "auto"; 537 s += t + " "; 538 s += t + " "; 539 s += t + " "; 540 s += t + ")"; 541 542 if (s != "rect(auto auto auto auto)") 543 ce.style.clip = s; 544 } 545 546 ce.style.cssText = ce.style.cssText; 547} 548 549function isNum(s) { 550 return new RegExp('[0-9]+', 'g').test(s); 551} 552 553function showDisabledControls() { 554 var f = document.forms, i, a; 555 556 for (i=0; i<f.length; i++) { 557 for (a=0; a<f[i].elements.length; a++) { 558 if (f[i].elements[a].disabled) 559 tinyMCEPopup.editor.dom.addClass(f[i].elements[a], "disabled"); 560 else 561 tinyMCEPopup.editor.dom.removeClass(f[i].elements[a], "disabled"); 562 } 563 } 564} 565 566function fillSelect(f, s, param, dval, sep, em) { 567 var i, ar, p, se; 568 569 f = document.forms[f]; 570 sep = typeof(sep) == "undefined" ? ";" : sep; 571 572 if (em) 573 addSelectValue(f, s, "", ""); 574 575 ar = tinyMCEPopup.getParam(param, dval).split(sep); 576 for (i=0; i<ar.length; i++) { 577 se = false; 578 579 if (ar[i].charAt(0) == '+') { 580 ar[i] = ar[i].substring(1); 581 se = true; 582 } 583 584 p = ar[i].split('='); 585 586 if (p.length > 1) { 587 addSelectValue(f, s, p[0], p[1]); 588 589 if (se) 590 selectByValue(f, s, p[1]); 591 } else { 592 addSelectValue(f, s, p[0], p[0]); 593 594 if (se) 595 selectByValue(f, s, p[0]); 596 } 597 } 598} 599 600function toggleSame(ce, pre) { 601 var el = document.forms[0].elements, i; 602 603 if (ce.checked) { 604 el[pre + "_top"].disabled = false; 605 el[pre + "_right"].disabled = true; 606 el[pre + "_bottom"].disabled = true; 607 el[pre + "_left"].disabled = true; 608 609 if (el[pre + "_top_measurement"]) { 610 el[pre + "_top_measurement"].disabled = false; 611 el[pre + "_right_measurement"].disabled = true; 612 el[pre + "_bottom_measurement"].disabled = true; 613 el[pre + "_left_measurement"].disabled = true; 614 } 615 } else { 616 el[pre + "_top"].disabled = false; 617 el[pre + "_right"].disabled = false; 618 el[pre + "_bottom"].disabled = false; 619 el[pre + "_left"].disabled = false; 620 621 if (el[pre + "_top_measurement"]) { 622 el[pre + "_top_measurement"].disabled = false; 623 el[pre + "_right_measurement"].disabled = false; 624 el[pre + "_bottom_measurement"].disabled = false; 625 el[pre + "_left_measurement"].disabled = false; 626 } 627 } 628 629 showDisabledControls(); 630} 631 632function synch(fr, to) { 633 var f = document.forms[0]; 634 635 f.elements[to].value = f.elements[fr].value; 636 637 if (f.elements[fr + "_measurement"]) 638 selectByValue(f, to + "_measurement", f.elements[fr + "_measurement"].value); 639} 640 641tinyMCEPopup.onInit.add(init);