1
|
1 |
var defaultFonts = "" +
|
|
2 |
"Arial, Helvetica, sans-serif=Arial, Helvetica, sans-serif;" +
|
|
3 |
"Times New Roman, Times, serif=Times New Roman, Times, serif;" +
|
|
4 |
"Courier New, Courier, mono=Courier New, Courier, mono;" +
|
|
5 |
"Times New Roman, Times, serif=Times New Roman, Times, serif;" +
|
|
6 |
"Georgia, Times New Roman, Times, serif=Georgia, Times New Roman, Times, serif;" +
|
|
7 |
"Verdana, Arial, Helvetica, sans-serif=Verdana, Arial, Helvetica, sans-serif;" +
|
|
8 |
"Geneva, Arial, Helvetica, sans-serif=Geneva, Arial, Helvetica, sans-serif";
|
|
9 |
|
|
10 |
var defaultSizes = "9;10;12;14;16;18;24;xx-small;x-small;small;medium;large;x-large;xx-large;smaller;larger";
|
|
11 |
var defaultMeasurement = "+pixels=px;points=pt;in;cm;mm;picas;ems;exs;%";
|
|
12 |
var defaultSpacingMeasurement = "pixels=px;points=pt;in;cm;mm;picas;+ems;exs;%";
|
|
13 |
var defaultIndentMeasurement = "pixels=px;+points=pt;in;cm;mm;picas;ems;exs;%";
|
|
14 |
var defaultWeight = "normal;bold;bolder;lighter;100;200;300;400;500;600;700;800;900";
|
|
15 |
var defaultTextStyle = "normal;italic;oblique";
|
|
16 |
var defaultVariant = "normal;small-caps";
|
|
17 |
var defaultLineHeight = "normal";
|
|
18 |
var defaultAttachment = "fixed;scroll";
|
|
19 |
var defaultRepeat = "no-repeat;repeat;repeat-x;repeat-y";
|
|
20 |
var defaultPosH = "left;center;right";
|
|
21 |
var defaultPosV = "top;center;bottom";
|
|
22 |
var defaultVAlign = "baseline;sub;super;top;text-top;middle;bottom;text-bottom";
|
|
23 |
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";
|
|
24 |
var defaultBorderStyle = "none;solid;dashed;dotted;double;groove;ridge;inset;outset";
|
|
25 |
var defaultBorderWidth = "thin;medium;thick";
|
|
26 |
var defaultListType = "disc;circle;square;decimal;lower-roman;upper-roman;lower-alpha;upper-alpha;none";
|
|
27 |
|
|
28 |
function init() {
|
|
29 |
var ce = document.getElementById('container'), h;
|
|
30 |
|
|
31 |
ce.style.cssText = tinyMCEPopup.getWindowArg('style_text');
|
|
32 |
|
|
33 |
h = getBrowserHTML('background_image_browser','background_image','image','advimage');
|
|
34 |
document.getElementById("background_image_browser").innerHTML = h;
|
|
35 |
|
|
36 |
tinyMCEPopup.resizeToInnerSize();
|
|
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 = 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 = 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 |
// Setup list fields
|
|
203 |
|
|
204 |
selectByValue(f, 'list_type', ce.style.listStyleType, true, true);
|
|
205 |
selectByValue(f, 'list_position', ce.style.listStylePosition, true, true);
|
|
206 |
f.list_bullet_image.value = ce.style.listStyleImage.replace(new RegExp("url\\('?([^']*)'?\\)", 'gi'), "$1");
|
|
207 |
|
|
208 |
// Setup box fields
|
|
209 |
|
|
210 |
selectByValue(f, 'positioning_type', ce.style.position, true, true);
|
|
211 |
selectByValue(f, 'positioning_visibility', ce.style.visibility, true, true);
|
|
212 |
selectByValue(f, 'positioning_overflow', ce.style.overflow, true, true);
|
|
213 |
f.positioning_zindex.value = ce.style.zIndex ? ce.style.zIndex : "";
|
|
214 |
|
|
215 |
f.positioning_width.value = getNum(ce.style.width);
|
|
216 |
selectByValue(f, 'positioning_width_measurement', getMeasurement(ce.style.width));
|
|
217 |
|
|
218 |
f.positioning_height.value = getNum(ce.style.height);
|
|
219 |
selectByValue(f, 'positioning_height_measurement', getMeasurement(ce.style.height));
|
|
220 |
|
|
221 |
setupBox(f, ce, 'positioning_placement', '', '', new Array('top', 'right', 'bottom', 'left'));
|
|
222 |
|
|
223 |
s = ce.style.clip.replace(new RegExp("rect\\('?([^']*)'?\\)", 'gi'), "$1");
|
|
224 |
s = s.replace(/,/g, ' ');
|
|
225 |
|
|
226 |
if (!hasEqualValues(new Array(getVal(s, 0), getVal(s, 1), getVal(s, 2), getVal(s, 3)))) {
|
|
227 |
f.positioning_clip_top.value = getNum(getVal(s, 0));
|
|
228 |
selectByValue(f, 'positioning_clip_top_measurement', getMeasurement(getVal(s, 0)));
|
|
229 |
f.positioning_clip_right.value = getNum(getVal(s, 1));
|
|
230 |
selectByValue(f, 'positioning_clip_right_measurement', getMeasurement(getVal(s, 1)));
|
|
231 |
f.positioning_clip_bottom.value = getNum(getVal(s, 2));
|
|
232 |
selectByValue(f, 'positioning_clip_bottom_measurement', getMeasurement(getVal(s, 2)));
|
|
233 |
f.positioning_clip_left.value = getNum(getVal(s, 3));
|
|
234 |
selectByValue(f, 'positioning_clip_left_measurement', getMeasurement(getVal(s, 3)));
|
|
235 |
} else {
|
|
236 |
f.positioning_clip_top.value = getNum(getVal(s, 0));
|
|
237 |
selectByValue(f, 'positioning_clip_top_measurement', getMeasurement(getVal(s, 0)));
|
|
238 |
f.positioning_clip_right.value = f.positioning_clip_bottom.value = f.positioning_clip_left.value;
|
|
239 |
}
|
|
240 |
|
|
241 |
// setupBox(f, ce, '', 'border', 'Color');
|
|
242 |
}
|
|
243 |
|
|
244 |
function getMeasurement(s) {
|
|
245 |
return s.replace(/^([0-9]+)(.*)$/, "$2");
|
|
246 |
}
|
|
247 |
|
|
248 |
function getNum(s) {
|
|
249 |
if (new RegExp('^[0-9]+[a-z%]+$', 'gi').test(s))
|
|
250 |
return s.replace(/[^0-9]/g, '');
|
|
251 |
|
|
252 |
return s;
|
|
253 |
}
|
|
254 |
|
|
255 |
function inStr(s, n) {
|
|
256 |
return new RegExp(n, 'gi').test(s);
|
|
257 |
}
|
|
258 |
|
|
259 |
function getVal(s, i) {
|
|
260 |
var a = tinyMCE.explode(' ', s);
|
|
261 |
|
|
262 |
if (a.length > 1)
|
|
263 |
return a[i];
|
|
264 |
|
|
265 |
return "";
|
|
266 |
}
|
|
267 |
|
|
268 |
function setValue(f, n, v) {
|
|
269 |
if (f.elements[n].type == "text")
|
|
270 |
f.elements[n].value = v;
|
|
271 |
else
|
|
272 |
selectByValue(f, n, v, true, true);
|
|
273 |
}
|
|
274 |
|
|
275 |
function setupBox(f, ce, fp, pr, sf, b) {
|
|
276 |
if (typeof(b) == "undefined")
|
|
277 |
b = new Array('Top', 'Right', 'Bottom', 'Left');
|
|
278 |
|
|
279 |
if (isSame(ce, pr, sf, b)) {
|
|
280 |
f.elements[fp + "_same"].checked = true;
|
|
281 |
|
|
282 |
setValue(f, fp + "_top", getNum(ce.style[pr + b[0] + sf]));
|
|
283 |
f.elements[fp + "_top"].disabled = false;
|
|
284 |
|
|
285 |
f.elements[fp + "_right"].value = "";
|
|
286 |
f.elements[fp + "_right"].disabled = true;
|
|
287 |
f.elements[fp + "_bottom"].value = "";
|
|
288 |
f.elements[fp + "_bottom"].disabled = true;
|
|
289 |
f.elements[fp + "_left"].value = "";
|
|
290 |
f.elements[fp + "_left"].disabled = true;
|
|
291 |
|
|
292 |
if (f.elements[fp + "_top_measurement"]) {
|
|
293 |
selectByValue(f, fp + '_top_measurement', getMeasurement(ce.style[pr + b[0] + sf]));
|
|
294 |
f.elements[fp + "_left_measurement"].disabled = true;
|
|
295 |
f.elements[fp + "_bottom_measurement"].disabled = true;
|
|
296 |
f.elements[fp + "_right_measurement"].disabled = true;
|
|
297 |
}
|
|
298 |
} else {
|
|
299 |
f.elements[fp + "_same"].checked = false;
|
|
300 |
|
|
301 |
setValue(f, fp + "_top", getNum(ce.style[pr + b[0] + sf]));
|
|
302 |
f.elements[fp + "_top"].disabled = false;
|
|
303 |
|
|
304 |
setValue(f, fp + "_right", getNum(ce.style[pr + b[1] + sf]));
|
|
305 |
f.elements[fp + "_right"].disabled = false;
|
|
306 |
|
|
307 |
setValue(f, fp + "_bottom", getNum(ce.style[pr + b[2] + sf]));
|
|
308 |
f.elements[fp + "_bottom"].disabled = false;
|
|
309 |
|
|
310 |
setValue(f, fp + "_left", getNum(ce.style[pr + b[3] + sf]));
|
|
311 |
f.elements[fp + "_left"].disabled = false;
|
|
312 |
|
|
313 |
if (f.elements[fp + "_top_measurement"]) {
|
|
314 |
selectByValue(f, fp + '_top_measurement', getMeasurement(ce.style[pr + b[0] + sf]));
|
|
315 |
selectByValue(f, fp + '_right_measurement', getMeasurement(ce.style[pr + b[1] + sf]));
|
|
316 |
selectByValue(f, fp + '_bottom_measurement', getMeasurement(ce.style[pr + b[2] + sf]));
|
|
317 |
selectByValue(f, fp + '_left_measurement', getMeasurement(ce.style[pr + b[3] + sf]));
|
|
318 |
f.elements[fp + "_left_measurement"].disabled = false;
|
|
319 |
f.elements[fp + "_bottom_measurement"].disabled = false;
|
|
320 |
f.elements[fp + "_right_measurement"].disabled = false;
|
|
321 |
}
|
|
322 |
}
|
|
323 |
}
|
|
324 |
|
|
325 |
function isSame(e, pr, sf, b) {
|
|
326 |
var a = new Array(), i, x;
|
|
327 |
|
|
328 |
if (typeof(b) == "undefined")
|
|
329 |
b = new Array('Top', 'Right', 'Bottom', 'Left');
|
|
330 |
|
|
331 |
if (typeof(sf) == "undefined" || sf == null)
|
|
332 |
sf = "";
|
|
333 |
|
|
334 |
a[0] = e.style[pr + b[0] + sf];
|
|
335 |
a[1] = e.style[pr + b[1] + sf];
|
|
336 |
a[2] = e.style[pr + b[2] + sf];
|
|
337 |
a[3] = e.style[pr + b[3] + sf];
|
|
338 |
|
|
339 |
for (i=0; i<a.length; i++) {
|
|
340 |
if (a[i] == null)
|
|
341 |
return false;
|
|
342 |
|
|
343 |
for (x=0; x<a.length; x++) {
|
|
344 |
if (a[x] != a[i])
|
|
345 |
return false;
|
|
346 |
}
|
|
347 |
}
|
|
348 |
|
|
349 |
return true;
|
|
350 |
};
|
|
351 |
|
|
352 |
function hasEqualValues(a) {
|
|
353 |
var i, x;
|
|
354 |
|
|
355 |
for (i=0; i<a.length; i++) {
|
|
356 |
if (a[i] == null)
|
|
357 |
return false;
|
|
358 |
|
|
359 |
for (x=0; x<a.length; x++) {
|
|
360 |
if (a[x] != a[i])
|
|
361 |
return false;
|
|
362 |
}
|
|
363 |
}
|
|
364 |
|
|
365 |
return true;
|
|
366 |
}
|
|
367 |
|
|
368 |
function applyAction() {
|
|
369 |
var ce = document.getElementById('container');
|
|
370 |
|
|
371 |
generateCSS();
|
|
372 |
|
|
373 |
tinyMCEPopup.execCommand('mceSetElementStyle', false, tinyMCE.serializeStyle(tinyMCE.parseStyle(ce.style.cssText)));
|
|
374 |
}
|
|
375 |
|
|
376 |
function updateAction() {
|
|
377 |
applyAction();
|
|
378 |
tinyMCEPopup.close();
|
|
379 |
}
|
|
380 |
|
|
381 |
function generateCSS() {
|
|
382 |
var ce = document.getElementById('container'), f = document.forms[0], num = new RegExp('[0-9]+', 'g'), s, t;
|
|
383 |
|
|
384 |
ce.style.cssText = "";
|
|
385 |
|
|
386 |
// Build text styles
|
|
387 |
ce.style.fontFamily = f.text_font.value;
|
|
388 |
ce.style.fontSize = f.text_size.value + (isNum(f.text_size.value) ? f.text_size_measurement.value : "");
|
|
389 |
ce.style.fontStyle = f.text_style.value;
|
|
390 |
ce.style.lineHeight = f.text_lineheight.value + (isNum(f.text_lineheight.value) ? f.text_lineheight_measurement.value : "");
|
|
391 |
ce.style.textTransform = f.text_case.value;
|
|
392 |
ce.style.fontWeight = f.text_weight.value;
|
|
393 |
ce.style.fontVariant = f.text_variant.value;
|
|
394 |
ce.style.color = f.text_color.value;
|
|
395 |
|
|
396 |
s = "";
|
|
397 |
s += f.text_underline.checked ? " underline" : "";
|
|
398 |
s += f.text_overline.checked ? " overline" : "";
|
|
399 |
s += f.text_linethrough.checked ? " line-through" : "";
|
|
400 |
s += f.text_blink.checked ? " blink" : "";
|
|
401 |
s = s.length > 0 ? s.substring(1) : s;
|
|
402 |
|
|
403 |
if (f.text_none.checked)
|
|
404 |
s = "none";
|
|
405 |
|
|
406 |
ce.style.textDecoration = s;
|
|
407 |
|
|
408 |
// Build background styles
|
|
409 |
|
|
410 |
ce.style.backgroundColor = f.background_color.value;
|
|
411 |
ce.style.backgroundImage = f.background_image.value != "" ? "url(" + f.background_image.value + ")" : "";
|
|
412 |
ce.style.backgroundRepeat = f.background_repeat.value;
|
|
413 |
ce.style.backgroundAttachment = f.background_attachment.value;
|
|
414 |
|
|
415 |
if (f.background_hpos.value != "") {
|
|
416 |
s = "";
|
|
417 |
s += f.background_hpos.value + (isNum(f.background_hpos.value) ? f.background_hpos_measurement.value : "") + " ";
|
|
418 |
s += f.background_vpos.value + (isNum(f.background_vpos.value) ? f.background_vpos_measurement.value : "");
|
|
419 |
ce.style.backgroundPosition = s;
|
|
420 |
}
|
|
421 |
|
|
422 |
// Build block styles
|
|
423 |
|
|
424 |
ce.style.wordSpacing = f.block_wordspacing.value + (isNum(f.block_wordspacing.value) ? f.block_wordspacing_measurement.value : "");
|
|
425 |
ce.style.letterSpacing = f.block_letterspacing.value + (isNum(f.block_letterspacing.value) ? f.block_letterspacing_measurement.value : "");
|
|
426 |
ce.style.verticalAlign = f.block_vertical_alignment.value;
|
|
427 |
ce.style.textAlign = f.block_text_align.value;
|
|
428 |
ce.style.textIndent = f.block_text_indent.value + (isNum(f.block_text_indent.value) ? f.block_text_indent_measurement.value : "");
|
|
429 |
ce.style.whiteSpace = f.block_whitespace.value;
|
|
430 |
ce.style.display = f.block_display.value;
|
|
431 |
|
|
432 |
// Build box styles
|
|
433 |
|
|
434 |
ce.style.width = f.box_width.value + (isNum(f.box_width.value) ? f.box_width_measurement.value : "");
|
|
435 |
ce.style.height = f.box_height.value + (isNum(f.box_height.value) ? f.box_height_measurement.value : "");
|
|
436 |
ce.style.styleFloat = f.box_float.value;
|
|
437 |
|
|
438 |
if (tinyMCE.isGecko)
|
|
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;
|
|
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 = tinyMCE.serializeStyle(tinyMCE.parseStyle(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 |
tinyMCE.addCSSClass(f[i].elements[a], "disabled");
|
|
554 |
else
|
|
555 |
tinyMCE.removeCSSClass(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 = tinyMCE.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 |
}
|