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