1 |
3 |
ahitrov@rambler.ru |
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); |