]> CyberLeo.Net >> Repos - Github/sugarcrm.git/blob - include/javascript/tiny_mce/plugins/style/js/props.js
Release 6.5.0
[Github/sugarcrm.git] / include / javascript / tiny_mce / plugins / style / js / props.js
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);