Mercurial > hg > AnnotationManager
comparison WebContent/jscripts/tiny_mce/plugins/style/js/props.js @ 5:0be9d53a6967
editor for annotations
| author | dwinter |
|---|---|
| date | Tue, 13 Dec 2011 17:43:46 +0100 |
| parents | |
| children |
comparison
equal
deleted
inserted
replaced
| 4:c32080f364c6 | 5:0be9d53a6967 |
|---|---|
| 1 tinyMCEPopup.requireLangPack(); | |
| 2 | |
| 3 var 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 | |
| 12 var defaultSizes = "9;10;12;14;16;18;24;xx-small;x-small;small;medium;large;x-large;xx-large;smaller;larger"; | |
| 13 var defaultMeasurement = "+pixels=px;points=pt;inches=in;centimetres=cm;millimetres=mm;picas=pc;ems=em;exs=ex;%"; | |
| 14 var defaultSpacingMeasurement = "pixels=px;points=pt;inches=in;centimetres=cm;millimetres=mm;picas=pc;+ems=em;exs=ex;%"; | |
| 15 var defaultIndentMeasurement = "pixels=px;+points=pt;inches=in;centimetres=cm;millimetres=mm;picas=pc;ems=em;exs=ex;%"; | |
| 16 var defaultWeight = "normal;bold;bolder;lighter;100;200;300;400;500;600;700;800;900"; | |
| 17 var defaultTextStyle = "normal;italic;oblique"; | |
| 18 var defaultVariant = "normal;small-caps"; | |
| 19 var defaultLineHeight = "normal"; | |
| 20 var defaultAttachment = "fixed;scroll"; | |
| 21 var defaultRepeat = "no-repeat;repeat;repeat-x;repeat-y"; | |
| 22 var defaultPosH = "left;center;right"; | |
| 23 var defaultPosV = "top;center;bottom"; | |
| 24 var defaultVAlign = "baseline;sub;super;top;text-top;middle;bottom;text-bottom"; | |
| 25 var 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"; | |
| 26 var defaultBorderStyle = "none;solid;dashed;dotted;double;groove;ridge;inset;outset"; | |
| 27 var defaultBorderWidth = "thin;medium;thick"; | |
| 28 var defaultListType = "disc;circle;square;decimal;lower-roman;upper-roman;lower-alpha;upper-alpha;none"; | |
| 29 | |
| 30 function 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 | |
| 127 function 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 selectByValue(f, 'box_float', ce.style.cssFloat || ce.style.styleFloat, true, true); | |
| 181 | |
| 182 selectByValue(f, 'box_clear', ce.style.clear, true, true); | |
| 183 | |
| 184 setupBox(f, ce, 'box_padding', 'padding', ''); | |
| 185 setupBox(f, ce, 'box_margin', 'margin', ''); | |
| 186 | |
| 187 // Setup border fields | |
| 188 | |
| 189 setupBox(f, ce, 'border_style', 'border', 'Style'); | |
| 190 setupBox(f, ce, 'border_width', 'border', 'Width'); | |
| 191 setupBox(f, ce, 'border_color', 'border', 'Color'); | |
| 192 | |
| 193 updateColor('border_color_top_pick', 'border_color_top'); | |
| 194 updateColor('border_color_right_pick', 'border_color_right'); | |
| 195 updateColor('border_color_bottom_pick', 'border_color_bottom'); | |
| 196 updateColor('border_color_left_pick', 'border_color_left'); | |
| 197 | |
| 198 f.elements.border_color_top.value = tinyMCEPopup.editor.dom.toHex(f.elements.border_color_top.value); | |
| 199 f.elements.border_color_right.value = tinyMCEPopup.editor.dom.toHex(f.elements.border_color_right.value); | |
| 200 f.elements.border_color_bottom.value = tinyMCEPopup.editor.dom.toHex(f.elements.border_color_bottom.value); | |
| 201 f.elements.border_color_left.value = tinyMCEPopup.editor.dom.toHex(f.elements.border_color_left.value); | |
| 202 | |
| 203 // Setup list fields | |
| 204 | |
| 205 selectByValue(f, 'list_type', ce.style.listStyleType, true, true); | |
| 206 selectByValue(f, 'list_position', ce.style.listStylePosition, true, true); | |
| 207 f.list_bullet_image.value = ce.style.listStyleImage.replace(new RegExp("url\\('?([^']*)'?\\)", 'gi'), "$1"); | |
| 208 | |
| 209 // Setup box fields | |
| 210 | |
| 211 selectByValue(f, 'positioning_type', ce.style.position, true, true); | |
| 212 selectByValue(f, 'positioning_visibility', ce.style.visibility, true, true); | |
| 213 selectByValue(f, 'positioning_overflow', ce.style.overflow, true, true); | |
| 214 f.positioning_zindex.value = ce.style.zIndex ? ce.style.zIndex : ""; | |
| 215 | |
| 216 f.positioning_width.value = getNum(ce.style.width); | |
| 217 selectByValue(f, 'positioning_width_measurement', getMeasurement(ce.style.width)); | |
| 218 | |
| 219 f.positioning_height.value = getNum(ce.style.height); | |
| 220 selectByValue(f, 'positioning_height_measurement', getMeasurement(ce.style.height)); | |
| 221 | |
| 222 setupBox(f, ce, 'positioning_placement', '', '', ['top', 'right', 'bottom', 'left']); | |
| 223 | |
| 224 s = ce.style.clip.replace(new RegExp("rect\\('?([^']*)'?\\)", 'gi'), "$1"); | |
| 225 s = s.replace(/,/g, ' '); | |
| 226 | |
| 227 if (!hasEqualValues([getVal(s, 0), getVal(s, 1), getVal(s, 2), getVal(s, 3)])) { | |
| 228 f.positioning_clip_top.value = getNum(getVal(s, 0)); | |
| 229 selectByValue(f, 'positioning_clip_top_measurement', getMeasurement(getVal(s, 0))); | |
| 230 f.positioning_clip_right.value = getNum(getVal(s, 1)); | |
| 231 selectByValue(f, 'positioning_clip_right_measurement', getMeasurement(getVal(s, 1))); | |
| 232 f.positioning_clip_bottom.value = getNum(getVal(s, 2)); | |
| 233 selectByValue(f, 'positioning_clip_bottom_measurement', getMeasurement(getVal(s, 2))); | |
| 234 f.positioning_clip_left.value = getNum(getVal(s, 3)); | |
| 235 selectByValue(f, 'positioning_clip_left_measurement', getMeasurement(getVal(s, 3))); | |
| 236 } else { | |
| 237 f.positioning_clip_top.value = getNum(getVal(s, 0)); | |
| 238 selectByValue(f, 'positioning_clip_top_measurement', getMeasurement(getVal(s, 0))); | |
| 239 f.positioning_clip_right.value = f.positioning_clip_bottom.value = f.positioning_clip_left.value; | |
| 240 } | |
| 241 | |
| 242 // setupBox(f, ce, '', 'border', 'Color'); | |
| 243 } | |
| 244 | |
| 245 function getMeasurement(s) { | |
| 246 return s.replace(/^([0-9.]+)(.*)$/, "$2"); | |
| 247 } | |
| 248 | |
| 249 function getNum(s) { | |
| 250 if (new RegExp('^(?:[0-9.]+)(?:[a-z%]+)$', 'gi').test(s)) | |
| 251 return s.replace(/[^0-9.]/g, ''); | |
| 252 | |
| 253 return s; | |
| 254 } | |
| 255 | |
| 256 function inStr(s, n) { | |
| 257 return new RegExp(n, 'gi').test(s); | |
| 258 } | |
| 259 | |
| 260 function getVal(s, i) { | |
| 261 var a = s.split(' '); | |
| 262 | |
| 263 if (a.length > 1) | |
| 264 return a[i]; | |
| 265 | |
| 266 return ""; | |
| 267 } | |
| 268 | |
| 269 function setValue(f, n, v) { | |
| 270 if (f.elements[n].type == "text") | |
| 271 f.elements[n].value = v; | |
| 272 else | |
| 273 selectByValue(f, n, v, true, true); | |
| 274 } | |
| 275 | |
| 276 function setupBox(f, ce, fp, pr, sf, b) { | |
| 277 if (typeof(b) == "undefined") | |
| 278 b = ['Top', 'Right', 'Bottom', 'Left']; | |
| 279 | |
| 280 if (isSame(ce, pr, sf, b)) { | |
| 281 f.elements[fp + "_same"].checked = true; | |
| 282 | |
| 283 setValue(f, fp + "_top", getNum(ce.style[pr + b[0] + sf])); | |
| 284 f.elements[fp + "_top"].disabled = false; | |
| 285 | |
| 286 f.elements[fp + "_right"].value = ""; | |
| 287 f.elements[fp + "_right"].disabled = true; | |
| 288 f.elements[fp + "_bottom"].value = ""; | |
| 289 f.elements[fp + "_bottom"].disabled = true; | |
| 290 f.elements[fp + "_left"].value = ""; | |
| 291 f.elements[fp + "_left"].disabled = true; | |
| 292 | |
| 293 if (f.elements[fp + "_top_measurement"]) { | |
| 294 selectByValue(f, fp + '_top_measurement', getMeasurement(ce.style[pr + b[0] + sf])); | |
| 295 f.elements[fp + "_left_measurement"].disabled = true; | |
| 296 f.elements[fp + "_bottom_measurement"].disabled = true; | |
| 297 f.elements[fp + "_right_measurement"].disabled = true; | |
| 298 } | |
| 299 } else { | |
| 300 f.elements[fp + "_same"].checked = false; | |
| 301 | |
| 302 setValue(f, fp + "_top", getNum(ce.style[pr + b[0] + sf])); | |
| 303 f.elements[fp + "_top"].disabled = false; | |
| 304 | |
| 305 setValue(f, fp + "_right", getNum(ce.style[pr + b[1] + sf])); | |
| 306 f.elements[fp + "_right"].disabled = false; | |
| 307 | |
| 308 setValue(f, fp + "_bottom", getNum(ce.style[pr + b[2] + sf])); | |
| 309 f.elements[fp + "_bottom"].disabled = false; | |
| 310 | |
| 311 setValue(f, fp + "_left", getNum(ce.style[pr + b[3] + sf])); | |
| 312 f.elements[fp + "_left"].disabled = false; | |
| 313 | |
| 314 if (f.elements[fp + "_top_measurement"]) { | |
| 315 selectByValue(f, fp + '_top_measurement', getMeasurement(ce.style[pr + b[0] + sf])); | |
| 316 selectByValue(f, fp + '_right_measurement', getMeasurement(ce.style[pr + b[1] + sf])); | |
| 317 selectByValue(f, fp + '_bottom_measurement', getMeasurement(ce.style[pr + b[2] + sf])); | |
| 318 selectByValue(f, fp + '_left_measurement', getMeasurement(ce.style[pr + b[3] + sf])); | |
| 319 f.elements[fp + "_left_measurement"].disabled = false; | |
| 320 f.elements[fp + "_bottom_measurement"].disabled = false; | |
| 321 f.elements[fp + "_right_measurement"].disabled = false; | |
| 322 } | |
| 323 } | |
| 324 } | |
| 325 | |
| 326 function isSame(e, pr, sf, b) { | |
| 327 var a = [], i, x; | |
| 328 | |
| 329 if (typeof(b) == "undefined") | |
| 330 b = ['Top', 'Right', 'Bottom', 'Left']; | |
| 331 | |
| 332 if (typeof(sf) == "undefined" || sf == null) | |
| 333 sf = ""; | |
| 334 | |
| 335 a[0] = e.style[pr + b[0] + sf]; | |
| 336 a[1] = e.style[pr + b[1] + sf]; | |
| 337 a[2] = e.style[pr + b[2] + sf]; | |
| 338 a[3] = e.style[pr + b[3] + sf]; | |
| 339 | |
| 340 for (i=0; i<a.length; i++) { | |
| 341 if (a[i] == null) | |
| 342 return false; | |
| 343 | |
| 344 for (x=0; x<a.length; x++) { | |
| 345 if (a[x] != a[i]) | |
| 346 return false; | |
| 347 } | |
| 348 } | |
| 349 | |
| 350 return true; | |
| 351 }; | |
| 352 | |
| 353 function hasEqualValues(a) { | |
| 354 var i, x; | |
| 355 | |
| 356 for (i=0; i<a.length; i++) { | |
| 357 if (a[i] == null) | |
| 358 return false; | |
| 359 | |
| 360 for (x=0; x<a.length; x++) { | |
| 361 if (a[x] != a[i]) | |
| 362 return false; | |
| 363 } | |
| 364 } | |
| 365 | |
| 366 return true; | |
| 367 } | |
| 368 | |
| 369 function applyAction() { | |
| 370 var ce = document.getElementById('container'), ed = tinyMCEPopup.editor; | |
| 371 | |
| 372 generateCSS(); | |
| 373 | |
| 374 tinyMCEPopup.restoreSelection(); | |
| 375 ed.dom.setAttrib(ed.selection.getSelectedBlocks(), 'style', tinyMCEPopup.editor.dom.serializeStyle(tinyMCEPopup.editor.dom.parseStyle(ce.style.cssText))); | |
| 376 } | |
| 377 | |
| 378 function updateAction() { | |
| 379 applyAction(); | |
| 380 tinyMCEPopup.close(); | |
| 381 } | |
| 382 | |
| 383 function generateCSS() { | |
| 384 var ce = document.getElementById('container'), f = document.forms[0], num = new RegExp('[0-9]+', 'g'), s, t; | |
| 385 | |
| 386 ce.style.cssText = ""; | |
| 387 | |
| 388 // Build text styles | |
| 389 ce.style.fontFamily = f.text_font.value; | |
| 390 ce.style.fontSize = f.text_size.value + (isNum(f.text_size.value) ? (f.text_size_measurement.value || 'px') : ""); | |
| 391 ce.style.fontStyle = f.text_style.value; | |
| 392 ce.style.lineHeight = f.text_lineheight.value + (isNum(f.text_lineheight.value) ? f.text_lineheight_measurement.value : ""); | |
| 393 ce.style.textTransform = f.text_case.value; | |
| 394 ce.style.fontWeight = f.text_weight.value; | |
| 395 ce.style.fontVariant = f.text_variant.value; | |
| 396 ce.style.color = f.text_color.value; | |
| 397 | |
| 398 s = ""; | |
| 399 s += f.text_underline.checked ? " underline" : ""; | |
| 400 s += f.text_overline.checked ? " overline" : ""; | |
| 401 s += f.text_linethrough.checked ? " line-through" : ""; | |
| 402 s += f.text_blink.checked ? " blink" : ""; | |
| 403 s = s.length > 0 ? s.substring(1) : s; | |
| 404 | |
| 405 if (f.text_none.checked) | |
| 406 s = "none"; | |
| 407 | |
| 408 ce.style.textDecoration = s; | |
| 409 | |
| 410 // Build background styles | |
| 411 | |
| 412 ce.style.backgroundColor = f.background_color.value; | |
| 413 ce.style.backgroundImage = f.background_image.value != "" ? "url(" + f.background_image.value + ")" : ""; | |
| 414 ce.style.backgroundRepeat = f.background_repeat.value; | |
| 415 ce.style.backgroundAttachment = f.background_attachment.value; | |
| 416 | |
| 417 if (f.background_hpos.value != "") { | |
| 418 s = ""; | |
| 419 s += f.background_hpos.value + (isNum(f.background_hpos.value) ? f.background_hpos_measurement.value : "") + " "; | |
| 420 s += f.background_vpos.value + (isNum(f.background_vpos.value) ? f.background_vpos_measurement.value : ""); | |
| 421 ce.style.backgroundPosition = s; | |
| 422 } | |
| 423 | |
| 424 // Build block styles | |
| 425 | |
| 426 ce.style.wordSpacing = f.block_wordspacing.value + (isNum(f.block_wordspacing.value) ? f.block_wordspacing_measurement.value : ""); | |
| 427 ce.style.letterSpacing = f.block_letterspacing.value + (isNum(f.block_letterspacing.value) ? f.block_letterspacing_measurement.value : ""); | |
| 428 ce.style.verticalAlign = f.block_vertical_alignment.value; | |
| 429 ce.style.textAlign = f.block_text_align.value; | |
| 430 ce.style.textIndent = f.block_text_indent.value + (isNum(f.block_text_indent.value) ? f.block_text_indent_measurement.value : ""); | |
| 431 ce.style.whiteSpace = f.block_whitespace.value; | |
| 432 ce.style.display = f.block_display.value; | |
| 433 | |
| 434 // Build box styles | |
| 435 | |
| 436 ce.style.width = f.box_width.value + (isNum(f.box_width.value) ? f.box_width_measurement.value : ""); | |
| 437 ce.style.height = f.box_height.value + (isNum(f.box_height.value) ? f.box_height_measurement.value : ""); | |
| 438 ce.style.styleFloat = f.box_float.value; | |
| 439 ce.style.cssFloat = f.box_float.value; | |
| 440 | |
| 441 ce.style.clear = f.box_clear.value; | |
| 442 | |
| 443 if (!f.box_padding_same.checked) { | |
| 444 ce.style.paddingTop = f.box_padding_top.value + (isNum(f.box_padding_top.value) ? f.box_padding_top_measurement.value : ""); | |
| 445 ce.style.paddingRight = f.box_padding_right.value + (isNum(f.box_padding_right.value) ? f.box_padding_right_measurement.value : ""); | |
| 446 ce.style.paddingBottom = f.box_padding_bottom.value + (isNum(f.box_padding_bottom.value) ? f.box_padding_bottom_measurement.value : ""); | |
| 447 ce.style.paddingLeft = f.box_padding_left.value + (isNum(f.box_padding_left.value) ? f.box_padding_left_measurement.value : ""); | |
| 448 } else | |
| 449 ce.style.padding = f.box_padding_top.value + (isNum(f.box_padding_top.value) ? f.box_padding_top_measurement.value : ""); | |
| 450 | |
| 451 if (!f.box_margin_same.checked) { | |
| 452 ce.style.marginTop = f.box_margin_top.value + (isNum(f.box_margin_top.value) ? f.box_margin_top_measurement.value : ""); | |
| 453 ce.style.marginRight = f.box_margin_right.value + (isNum(f.box_margin_right.value) ? f.box_margin_right_measurement.value : ""); | |
| 454 ce.style.marginBottom = f.box_margin_bottom.value + (isNum(f.box_margin_bottom.value) ? f.box_margin_bottom_measurement.value : ""); | |
| 455 ce.style.marginLeft = f.box_margin_left.value + (isNum(f.box_margin_left.value) ? f.box_margin_left_measurement.value : ""); | |
| 456 } else | |
| 457 ce.style.margin = f.box_margin_top.value + (isNum(f.box_margin_top.value) ? f.box_margin_top_measurement.value : ""); | |
| 458 | |
| 459 // Build border styles | |
| 460 | |
| 461 if (!f.border_style_same.checked) { | |
| 462 ce.style.borderTopStyle = f.border_style_top.value; | |
| 463 ce.style.borderRightStyle = f.border_style_right.value; | |
| 464 ce.style.borderBottomStyle = f.border_style_bottom.value; | |
| 465 ce.style.borderLeftStyle = f.border_style_left.value; | |
| 466 } else | |
| 467 ce.style.borderStyle = f.border_style_top.value; | |
| 468 | |
| 469 if (!f.border_width_same.checked) { | |
| 470 ce.style.borderTopWidth = f.border_width_top.value + (isNum(f.border_width_top.value) ? f.border_width_top_measurement.value : ""); | |
| 471 ce.style.borderRightWidth = f.border_width_right.value + (isNum(f.border_width_right.value) ? f.border_width_right_measurement.value : ""); | |
| 472 ce.style.borderBottomWidth = f.border_width_bottom.value + (isNum(f.border_width_bottom.value) ? f.border_width_bottom_measurement.value : ""); | |
| 473 ce.style.borderLeftWidth = f.border_width_left.value + (isNum(f.border_width_left.value) ? f.border_width_left_measurement.value : ""); | |
| 474 } else | |
| 475 ce.style.borderWidth = f.border_width_top.value + (isNum(f.border_width_top.value) ? f.border_width_top_measurement.value : ""); | |
| 476 | |
| 477 if (!f.border_color_same.checked) { | |
| 478 ce.style.borderTopColor = f.border_color_top.value; | |
| 479 ce.style.borderRightColor = f.border_color_right.value; | |
| 480 ce.style.borderBottomColor = f.border_color_bottom.value; | |
| 481 ce.style.borderLeftColor = f.border_color_left.value; | |
| 482 } else | |
| 483 ce.style.borderColor = f.border_color_top.value; | |
| 484 | |
| 485 // Build list styles | |
| 486 | |
| 487 ce.style.listStyleType = f.list_type.value; | |
| 488 ce.style.listStylePosition = f.list_position.value; | |
| 489 ce.style.listStyleImage = f.list_bullet_image.value != "" ? "url(" + f.list_bullet_image.value + ")" : ""; | |
| 490 | |
| 491 // Build positioning styles | |
| 492 | |
| 493 ce.style.position = f.positioning_type.value; | |
| 494 ce.style.visibility = f.positioning_visibility.value; | |
| 495 | |
| 496 if (ce.style.width == "") | |
| 497 ce.style.width = f.positioning_width.value + (isNum(f.positioning_width.value) ? f.positioning_width_measurement.value : ""); | |
| 498 | |
| 499 if (ce.style.height == "") | |
| 500 ce.style.height = f.positioning_height.value + (isNum(f.positioning_height.value) ? f.positioning_height_measurement.value : ""); | |
| 501 | |
| 502 ce.style.zIndex = f.positioning_zindex.value; | |
| 503 ce.style.overflow = f.positioning_overflow.value; | |
| 504 | |
| 505 if (!f.positioning_placement_same.checked) { | |
| 506 ce.style.top = f.positioning_placement_top.value + (isNum(f.positioning_placement_top.value) ? f.positioning_placement_top_measurement.value : ""); | |
| 507 ce.style.right = f.positioning_placement_right.value + (isNum(f.positioning_placement_right.value) ? f.positioning_placement_right_measurement.value : ""); | |
| 508 ce.style.bottom = f.positioning_placement_bottom.value + (isNum(f.positioning_placement_bottom.value) ? f.positioning_placement_bottom_measurement.value : ""); | |
| 509 ce.style.left = f.positioning_placement_left.value + (isNum(f.positioning_placement_left.value) ? f.positioning_placement_left_measurement.value : ""); | |
| 510 } else { | |
| 511 s = f.positioning_placement_top.value + (isNum(f.positioning_placement_top.value) ? f.positioning_placement_top_measurement.value : ""); | |
| 512 ce.style.top = s; | |
| 513 ce.style.right = s; | |
| 514 ce.style.bottom = s; | |
| 515 ce.style.left = s; | |
| 516 } | |
| 517 | |
| 518 if (!f.positioning_clip_same.checked) { | |
| 519 s = "rect("; | |
| 520 s += (isNum(f.positioning_clip_top.value) ? f.positioning_clip_top.value + f.positioning_clip_top_measurement.value : "auto") + " "; | |
| 521 s += (isNum(f.positioning_clip_right.value) ? f.positioning_clip_right.value + f.positioning_clip_right_measurement.value : "auto") + " "; | |
| 522 s += (isNum(f.positioning_clip_bottom.value) ? f.positioning_clip_bottom.value + f.positioning_clip_bottom_measurement.value : "auto") + " "; | |
| 523 s += (isNum(f.positioning_clip_left.value) ? f.positioning_clip_left.value + f.positioning_clip_left_measurement.value : "auto"); | |
| 524 s += ")"; | |
| 525 | |
| 526 if (s != "rect(auto auto auto auto)") | |
| 527 ce.style.clip = s; | |
| 528 } else { | |
| 529 s = "rect("; | |
| 530 t = isNum(f.positioning_clip_top.value) ? f.positioning_clip_top.value + f.positioning_clip_top_measurement.value : "auto"; | |
| 531 s += t + " "; | |
| 532 s += t + " "; | |
| 533 s += t + " "; | |
| 534 s += t + ")"; | |
| 535 | |
| 536 if (s != "rect(auto auto auto auto)") | |
| 537 ce.style.clip = s; | |
| 538 } | |
| 539 | |
| 540 ce.style.cssText = ce.style.cssText; | |
| 541 } | |
| 542 | |
| 543 function isNum(s) { | |
| 544 return new RegExp('[0-9]+', 'g').test(s); | |
| 545 } | |
| 546 | |
| 547 function showDisabledControls() { | |
| 548 var f = document.forms, i, a; | |
| 549 | |
| 550 for (i=0; i<f.length; i++) { | |
| 551 for (a=0; a<f[i].elements.length; a++) { | |
| 552 if (f[i].elements[a].disabled) | |
| 553 tinyMCEPopup.editor.dom.addClass(f[i].elements[a], "disabled"); | |
| 554 else | |
| 555 tinyMCEPopup.editor.dom.removeClass(f[i].elements[a], "disabled"); | |
| 556 } | |
| 557 } | |
| 558 } | |
| 559 | |
| 560 function fillSelect(f, s, param, dval, sep, em) { | |
| 561 var i, ar, p, se; | |
| 562 | |
| 563 f = document.forms[f]; | |
| 564 sep = typeof(sep) == "undefined" ? ";" : sep; | |
| 565 | |
| 566 if (em) | |
| 567 addSelectValue(f, s, "", ""); | |
| 568 | |
| 569 ar = tinyMCEPopup.getParam(param, dval).split(sep); | |
| 570 for (i=0; i<ar.length; i++) { | |
| 571 se = false; | |
| 572 | |
| 573 if (ar[i].charAt(0) == '+') { | |
| 574 ar[i] = ar[i].substring(1); | |
| 575 se = true; | |
| 576 } | |
| 577 | |
| 578 p = ar[i].split('='); | |
| 579 | |
| 580 if (p.length > 1) { | |
| 581 addSelectValue(f, s, p[0], p[1]); | |
| 582 | |
| 583 if (se) | |
| 584 selectByValue(f, s, p[1]); | |
| 585 } else { | |
| 586 addSelectValue(f, s, p[0], p[0]); | |
| 587 | |
| 588 if (se) | |
| 589 selectByValue(f, s, p[0]); | |
| 590 } | |
| 591 } | |
| 592 } | |
| 593 | |
| 594 function toggleSame(ce, pre) { | |
| 595 var el = document.forms[0].elements, i; | |
| 596 | |
| 597 if (ce.checked) { | |
| 598 el[pre + "_top"].disabled = false; | |
| 599 el[pre + "_right"].disabled = true; | |
| 600 el[pre + "_bottom"].disabled = true; | |
| 601 el[pre + "_left"].disabled = true; | |
| 602 | |
| 603 if (el[pre + "_top_measurement"]) { | |
| 604 el[pre + "_top_measurement"].disabled = false; | |
| 605 el[pre + "_right_measurement"].disabled = true; | |
| 606 el[pre + "_bottom_measurement"].disabled = true; | |
| 607 el[pre + "_left_measurement"].disabled = true; | |
| 608 } | |
| 609 } else { | |
| 610 el[pre + "_top"].disabled = false; | |
| 611 el[pre + "_right"].disabled = false; | |
| 612 el[pre + "_bottom"].disabled = false; | |
| 613 el[pre + "_left"].disabled = false; | |
| 614 | |
| 615 if (el[pre + "_top_measurement"]) { | |
| 616 el[pre + "_top_measurement"].disabled = false; | |
| 617 el[pre + "_right_measurement"].disabled = false; | |
| 618 el[pre + "_bottom_measurement"].disabled = false; | |
| 619 el[pre + "_left_measurement"].disabled = false; | |
| 620 } | |
| 621 } | |
| 622 | |
| 623 showDisabledControls(); | |
| 624 } | |
| 625 | |
| 626 function synch(fr, to) { | |
| 627 var f = document.forms[0]; | |
| 628 | |
| 629 f.elements[to].value = f.elements[fr].value; | |
| 630 | |
| 631 if (f.elements[fr + "_measurement"]) | |
| 632 selectByValue(f, to + "_measurement", f.elements[fr + "_measurement"].value); | |
| 633 } | |
| 634 | |
| 635 tinyMCEPopup.onInit.add(init); |
