[4829] | 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.getNode(), '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);
|
---|