home *** CD-ROM | disk | FTP | other *** search
/ Cricao de Sites - 650 Layouts Prontos / WebMasters.iso / Plugins / tinymce-advanced / mce / style / jscripts / props.js
Encoding:
Text File  |  2008-02-20  |  29.0 KB  |  634 lines

  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. }
  634.