Subversion Repositories Sites.tela-botanica.org

Rev

Details | Last modification | View Log | RSS feed

Rev Author Line No. Line
420 florian 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
}