~quam-plures-core/quam-plures/bug-614012

« back to all changes in this revision

Viewing changes to qp_plugins/tinymce_plugin/tiny_mce/plugins/style/js/props.js

  • Committer: yabs
  • Author(s): EdB
  • Date: 2010-07-23 07:41:42 UTC
  • mfrom: (7507.5.4 upgrade_tinymce_core)
  • Revision ID: yabs@innervisions.org.uk-20100723074142-1xhibhdhaibhq33m
Upgrade TinyMCE

Show diffs side-by-side

added added

removed removed

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