📄 advanced-table-operations.js
字号:
style.borderColor = val;
break;
case "f_st_borderCollapse":
style.borderCollapse = val ? "collapse" : "";
break;
case "f_st_width":
if (/\S/.test(val)) {
style.width = val + params["f_st_widthUnit"];
} else {
style.width = "";
}
break;
case "f_st_height":
if (/\S/.test(val)) {
style.height = val + params["f_st_heightUnit"];
} else {
style.height = "";
}
break;
case "f_st_textAlign":
if (val == "char") {
var ch = params["f_st_textAlignChar"];
if (ch == '"') {
ch = '\\"';
}
style.textAlign = '"' + ch + '"';
} else if (val == "-") {
style.textAlign = "";
} else {
style.textAlign = val;
}
break;
case "f_st_verticalAlign":
element.vAlign = "";
if (val == "-") {
style.verticalAlign = "";
} else {
style.verticalAlign = val;
}
break;
case "f_st_float":
style.cssFloat = val;
break;
// case "f_st_margin":
// style.margin = val + "px";
// break;
// case "f_st_padding":
// style.padding = val + "px";
// break;
}
}
};
// Returns an HTML element for a widget that allows color selection. That is,
// a button that contains the given color, if any, and when pressed will popup
// the sooner-or-later-to-be-rewritten select_color.html dialog allowing user
// to select some color. If a color is selected, an input field with the name
// "f_st_"+name will be updated with the color value in #123456 format.
AdvancedTableOperations.createColorButton = function(doc, editor, color, name) {
if (!color) {
color = "";
} else if (!/#/.test(color)) {
color = HTMLArea._colorToRgb(color);
}
var df = doc.createElement("span");
var field = doc.createElement("input");
field.type = "hidden";
df.appendChild(field);
field.name = "f_st_" + name;
field.value = color;
var button = doc.createElement("span");
button.className = "buttonColor";
df.appendChild(button);
var span = doc.createElement("span");
span.className = "chooser";
// span.innerHTML = " ";
span.style.backgroundColor = color;
button.appendChild(span);
button.onmouseover = function() { if (!this.disabled) { this.className += " buttonColor-hilite"; }};
button.onmouseout = function() { if (!this.disabled) { this.className = "buttonColor"; }};
span.onclick = function() {
if (this.parentNode.disabled) {
return false;
}
editor._popupDialog("select_color.html", function(color) {
if (color) {
span.style.backgroundColor = "#" + color;
field.value = "#" + color;
}
}, color);
};
var span2 = doc.createElement("span");
span2.innerHTML = "×";
span2.className = "nocolor";
span2.title = HTMLArea._lc("Unset color", "AdvancedTableOperations");
button.appendChild(span2);
span2.onmouseover = function() { if (!this.parentNode.disabled) { this.className += " nocolor-hilite"; }};
span2.onmouseout = function() { if (!this.parentNode.disabled) { this.className = "nocolor"; }};
span2.onclick = function() {
span.style.backgroundColor = "";
field.value = "";
};
return df;
};
AdvancedTableOperations.createStyleLayoutFieldset = function(doc, editor, el) {
var fieldset = doc.createElement("fieldset");
var legend = doc.createElement("legend");
fieldset.appendChild(legend);
legend.innerHTML = HTMLArea._lc("Layout", "AdvancedTableOperations");
var table = doc.createElement("table");
fieldset.appendChild(table);
table.style.width = "100%";
var tbody = doc.createElement("tbody");
table.appendChild(tbody);
var tagname = el.tagName.toLowerCase();
var tr, td, input, select, option, options, i;
if (tagname != "td" && tagname != "tr" && tagname != "th") {
tr = doc.createElement("tr");
tbody.appendChild(tr);
td = doc.createElement("td");
td.className = "label";
tr.appendChild(td);
td.innerHTML = HTMLArea._lc("Float", "AdvancedTableOperations") + ":";
td = doc.createElement("td");
tr.appendChild(td);
select = doc.createElement("select");
td.appendChild(select);
select.name = "f_st_float";
options = ["None", "Left", "Right"];
for (var i = 0; i < options.length; ++i) {
var Val = options[i];
var val = options[i].toLowerCase();
option = doc.createElement("option");
option.innerHTML = HTMLArea._lc(Val, "AdvancedTableOperations");
option.value = val;
option.selected = (("" + el.style.cssFloat).toLowerCase() == val);
select.appendChild(option);
}
}
tr = doc.createElement("tr");
tbody.appendChild(tr);
td = doc.createElement("td");
td.className = "label";
tr.appendChild(td);
td.innerHTML = HTMLArea._lc("Width", "AdvancedTableOperations") + ":";
td = doc.createElement("td");
tr.appendChild(td);
input = doc.createElement("input");
input.type = "text";
input.value = AdvancedTableOperations.getLength(el.style.width);
input.size = "5";
input.name = "f_st_width";
input.style.marginRight = "0.5em";
td.appendChild(input);
select = doc.createElement("select");
select.name = "f_st_widthUnit";
option = doc.createElement("option");
option.innerHTML = HTMLArea._lc("percent", "AdvancedTableOperations");
option.value = "%";
option.selected = /%/.test(el.style.width);
select.appendChild(option);
option = doc.createElement("option");
option.innerHTML = HTMLArea._lc("pixels", "AdvancedTableOperations");
option.value = "px";
option.selected = /px/.test(el.style.width);
select.appendChild(option);
td.appendChild(select);
select.style.marginRight = "0.5em";
td.appendChild(doc.createTextNode(HTMLArea._lc("Text align", "AdvancedTableOperations") + ":"));
select = doc.createElement("select");
select.style.marginLeft = select.style.marginRight = "0.5em";
td.appendChild(select);
select.name = "f_st_textAlign";
options = ["Left", "Center", "Right", "Justify", "-"];
if (tagname == "td") {
options.push("Char");
}
input = doc.createElement("input");
input.name = "f_st_textAlignChar";
input.size = "1";
input.style.fontFamily = "monospace";
td.appendChild(input);
for (var i = 0; i < options.length; ++i) {
var Val = options[i];
var val = Val.toLowerCase();
option = doc.createElement("option");
option.value = val;
option.innerHTML = HTMLArea._lc(Val, "AdvancedTableOperations");
option.selected = ((el.style.textAlign.toLowerCase() == val) || (el.style.textAlign == "" && Val == "-"));
select.appendChild(option);
}
function setCharVisibility(value) {
input.style.visibility = value ? "visible" : "hidden";
if (value) {
input.focus();
input.select();
}
}
select.onchange = function() { setCharVisibility(this.value == "char"); };
setCharVisibility(select.value == "char");
tr = doc.createElement("tr");
tbody.appendChild(tr);
td = doc.createElement("td");
td.className = "label";
tr.appendChild(td);
td.innerHTML = HTMLArea._lc("Height", "AdvancedTableOperations") + ":";
td = doc.createElement("td");
tr.appendChild(td);
input = doc.createElement("input");
input.type = "text";
input.value = AdvancedTableOperations.getLength(el.style.height);
input.size = "5";
input.name = "f_st_height";
input.style.marginRight = "0.5em";
td.appendChild(input);
select = doc.createElement("select");
select.name = "f_st_heightUnit";
option = doc.createElement("option");
option.innerHTML = HTMLArea._lc("percent", "AdvancedTableOperations");
option.value = "%";
option.selected = /%/.test(el.style.height);
select.appendChild(option);
option = doc.createElement("option");
option.innerHTML = HTMLArea._lc("pixels", "AdvancedTableOperations");
option.value = "px";
option.selected = /px/.test(el.style.height);
select.appendChild(option);
td.appendChild(select);
select.style.marginRight = "0.5em";
td.appendChild(doc.createTextNode(HTMLArea._lc("Vertical align", "AdvancedTableOperations") + ":"));
select = doc.createElement("select");
select.name = "f_st_verticalAlign";
select.style.marginLeft = "0.5em";
td.appendChild(select);
options = ["Top", "Middle", "Bottom", "Baseline", "-"];
for (var i = 0; i < options.length; ++i) {
var Val = options[i];
var val = Val.toLowerCase();
option = doc.createElement("option");
option.value = val;
option.innerHTML = HTMLArea._lc(Val, "AdvancedTableOperations");
option.selected = ((el.style.verticalAlign.toLowerCase() == val) || (el.style.verticalAlign == "" && Val == "-"));
select.appendChild(option);
}
return fieldset;
};
AdvancedTableOperations.createFieldtype = function(doc, editor, el)
{
var fieldset = doc.createElement("fieldset");
var legend = doc.createElement("legend");
fieldset.appendChild(legend);
legend.innerHTML = HTMLArea._lc("Cell type", "AdvancedTableOperations");
var table = doc.createElement("table");
fieldset.appendChild(table);
table.style.width = "100%";
var tbody = doc.createElement("tbody");
table.appendChild(tbody);
var tagName = el.tagName.toLowerCase();
var tr = doc.createElement("tr");
tbody.appendChild(tr);
td = doc.createElement("td");
td.className = "label";
tr.appendChild(td);
td.innerHTML = HTMLArea._lc("Cell type", "AdvancedTableOperations") + ":";
td = doc.createElement("td");
tr.appendChild(td);
var select = doc.createElement("select");
td.appendChild(select);
select.name = "f_celltype";
options = ["th", "td"];
for (var i = 0; i < options.length; ++i) {
var Val = options[i];
var val = options[i].toLowerCase();
option = doc.createElement("option");
option.innerHTML = HTMLArea._lc(Val, "AdvancedTableOperations");
option.value = val;
option.selected = (tagName == val);
select.appendChild(option);
}
return fieldset;
};
// Returns an HTML element containing the style attributes for the given
// element. This can be easily embedded into any dialog; the functionality is
// also provided.
AdvancedTableOperations.createStyleFieldset = function(doc, editor, el) {
var fieldset = doc.createElement("fieldset");
var legend = doc.createElement("legend");
fieldset.appendChild(legend);
legend.innerHTML = HTMLArea._lc("CSS Style", "AdvancedTableOperations");
var table = doc.createElement("table");
fieldset.appendChild(table);
table.style.width = "100%";
var tbody = doc.createElement("tbody");
table.appendChild(tbody);
var tr, td, input, select, option, options, i;
tr = doc.createElement("tr");
tbody.appendChild(tr);
td = doc.createElement("td");
tr.appendChild(td);
td.className = "label";
td.innerHTML = HTMLArea._lc("Background", "AdvancedTableOperations") + ":";
td = doc.createElement("td");
tr.appendChild(td);
var df = AdvancedTableOperations.createColorButton(doc, editor, el.style.backgroundColor, "backgroundColor");
df.firstChild.nextSibling.style.marginRight = "0.5em";
td.appendChild(df);
td.appendChild(doc.createTextNode(HTMLArea._lc("Image URL", "AdvancedTableOperations") + ": "));
input = doc.createElement("input");
input.type = "text";
input.name = "f_st_backgroundImage";
if (el.style.backgroundImage.match(/url\(\s*(.*?)\s*\)/)) {
input.value = RegExp.$1;
}
// input.style.width = "100%";
td.appendChild(input);
tr = doc.createElement("tr");
tbody.appendChild(tr);
td = doc.createElement("td");
tr.appendChild(td);
td.className = "label";
td.innerHTML = HTMLArea._lc("FG Color", "AdvancedTableOperations") + ":";
td = doc.createElement("td");
tr.appendChild(td);
td.appendChild(AdvancedTableOperations.createColorButton(doc, editor, el.style.color, "color"));
// for better alignment we include an invisible field.
input = doc.createElement("input");
input.style.visibility = "hidden";
input.type = "text";
td.appendChild(input);
tr = doc.createElement("tr");
tbody.appendChild(tr);
td = doc.createElement("td");
tr.appendChild(td);
td.className = "label";
td.innerHTML = HTMLArea._lc("Border", "AdvancedTableOperations") + ":";
td = doc.createElement("td");
tr.appendChild(td);
var colorButton = AdvancedTableOperations.createColorButton(doc, editor, el.style.borderColor, "borderColor");
var btn = colorButton.firstChild.nextSibling;
td.appendChild(colorButton);
// borderFields.push(btn);
btn.style.marginRight = "0.5em";
select = doc.createElement("select");
var borderFields = [];
td.appendChild(select);
select.name = "f_st_borderStyle";
options = ["none", "dotted", "dashed", "solid", "double", "groove", "ridge", "inset", "outset"];
var currentBorderStyle = el.style.borderStyle;
// Gecko reports "solid solid solid solid" for "border-style: solid".
// That is, "top right bottom left" -- we only consider the first
// value.
(currentBorderStyle.match(/([^\s]*)\s/)) && (currentBorderStyle = RegExp.$1);
for (var i in options) {
if(typeof options[i] == 'function') continue;
var val = options[i];
option = doc.createElement("option");
option.value = val;
option.innerHTML = val;
(val == currentBorderStyle) && (option.selected = true);
select.appendChild(option);
}
select.style.marginRight = "0.5em";
function setBorderFieldsStatus(value) {
for (var i = 0; i < borderFields.length; ++i) {
var el = borderFields[i];
el.style.visibility = value ? "hidden" : "visible";
if (!value && (el.tagName.toLowerCase() == "input")) {
el.focus();
el.select();
}
}
}
select.onchange = function() { setBorderFieldsStatus(this.value == "none"); };
input = doc.createElement("input");
borderFields.push(input);
input.type = "text";
input.name = "f_st_borderWidth";
input.value = AdvancedTableOperations.getLength(el.style.borderWidth);
input.size = "5";
td.appendChild(input);
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -