PageRenderTime 178ms CodeModel.GetById 25ms app.highlight 138ms RepoModel.GetById 7ms app.codeStats 1ms

/war/src/main/webapp/js/lib/tiny_mce/plugins/style/js/props.js

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