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