238 lines
		
	
	
		
			8.7 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			238 lines
		
	
	
		
			8.7 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| /**
 | |
|  * Created with JetBrains PhpStorm.
 | |
|  * User: xuheng
 | |
|  * Date: 12-12-19
 | |
|  * Time: 下午4:55
 | |
|  * To change this template use File | Settings | File Templates.
 | |
|  */
 | |
| (function () {
 | |
|     var title = $G("J_title"),
 | |
|         titleCol = $G("J_titleCol"),
 | |
|         caption = $G("J_caption"),
 | |
|         sorttable = $G("J_sorttable"),
 | |
|         autoSizeContent = $G("J_autoSizeContent"),
 | |
|         autoSizePage = $G("J_autoSizePage"),
 | |
|         tone = $G("J_tone"),
 | |
|         me,
 | |
|         preview = $G("J_preview");
 | |
| 
 | |
|     var editTable = function () {
 | |
|         me = this;
 | |
|         me.init();
 | |
|     };
 | |
|     editTable.prototype = {
 | |
|         init:function () {
 | |
|             var colorPiker = new UE.ui.ColorPicker({
 | |
|                     editor:editor
 | |
|                 }),
 | |
|                 colorPop = new UE.ui.Popup({
 | |
|                     editor:editor,
 | |
|                     content:colorPiker
 | |
|                 });
 | |
| 
 | |
|             title.checked = editor.queryCommandState("inserttitle") == -1;
 | |
|             titleCol.checked = editor.queryCommandState("inserttitlecol") == -1;
 | |
|             caption.checked = editor.queryCommandState("insertcaption") == -1;
 | |
|             sorttable.checked = editor.queryCommandState("enablesort") == 1;
 | |
| 
 | |
|             var enablesortState = editor.queryCommandState("enablesort"),
 | |
|                 disablesortState = editor.queryCommandState("disablesort");
 | |
| 
 | |
|             sorttable.checked = !!(enablesortState < 0 && disablesortState >=0);
 | |
|             sorttable.disabled = !!(enablesortState < 0 && disablesortState < 0);
 | |
|             sorttable.title = enablesortState < 0 && disablesortState < 0 ? lang.errorMsg:'';
 | |
| 
 | |
|             me.createTable(title.checked, titleCol.checked, caption.checked);
 | |
|             me.setAutoSize();
 | |
|             me.setColor(me.getColor());
 | |
| 
 | |
|             domUtils.on(title, "click", me.titleHanler);
 | |
|             domUtils.on(titleCol, "click", me.titleColHanler);
 | |
|             domUtils.on(caption, "click", me.captionHanler);
 | |
|             domUtils.on(sorttable, "click", me.sorttableHanler);
 | |
|             domUtils.on(autoSizeContent, "click", me.autoSizeContentHanler);
 | |
|             domUtils.on(autoSizePage, "click", me.autoSizePageHanler);
 | |
| 
 | |
|             domUtils.on(tone, "click", function () {
 | |
|                 colorPop.showAnchor(tone);
 | |
|             });
 | |
|             domUtils.on(document, 'mousedown', function () {
 | |
|                 colorPop.hide();
 | |
|             });
 | |
|             colorPiker.addListener("pickcolor", function () {
 | |
|                 me.setColor(arguments[1]);
 | |
|                 colorPop.hide();
 | |
|             });
 | |
|             colorPiker.addListener("picknocolor", function () {
 | |
|                 me.setColor("");
 | |
|                 colorPop.hide();
 | |
|             });
 | |
|         },
 | |
| 
 | |
|         createTable:function (hasTitle, hasTitleCol, hasCaption) {
 | |
|             var arr = [],
 | |
|                 sortSpan = '<span>^</span>';
 | |
|             arr.push("<table id='J_example'>");
 | |
|             if (hasCaption) {
 | |
|                 arr.push("<caption>" + lang.captionName + "</caption>")
 | |
|             }
 | |
|             if (hasTitle) {
 | |
|                 arr.push("<tr>");
 | |
|                 if(hasTitleCol) { arr.push("<th>" + lang.titleName + "</th>"); }
 | |
|                 for (var j = 0; j < 5; j++) {
 | |
|                     arr.push("<th>" + lang.titleName + "</th>");
 | |
|                 }
 | |
|                 arr.push("</tr>");
 | |
|             }
 | |
|             for (var i = 0; i < 6; i++) {
 | |
|                 arr.push("<tr>");
 | |
|                 if(hasTitleCol) { arr.push("<th>" + lang.titleName + "</th>") }
 | |
|                 for (var k = 0; k < 5; k++) {
 | |
|                     arr.push("<td>" + lang.cellsName + "</td>")
 | |
|                 }
 | |
|                 arr.push("</tr>");
 | |
|             }
 | |
|             arr.push("</table>");
 | |
|             preview.innerHTML = arr.join("");
 | |
|             this.updateSortSpan();
 | |
|         },
 | |
|         titleHanler:function () {
 | |
|             var example = $G("J_example"),
 | |
|                 frg=document.createDocumentFragment(),
 | |
|                 color = domUtils.getComputedStyle(domUtils.getElementsByTagName(example, "td")[0], "border-color"),
 | |
|                 colCount = example.rows[0].children.length;
 | |
| 
 | |
|             if (title.checked) {
 | |
|                 example.insertRow(0);
 | |
|                 for (var i = 0, node; i < colCount; i++) {
 | |
|                     node = document.createElement("th");
 | |
|                     node.innerHTML = lang.titleName;
 | |
|                     frg.appendChild(node);
 | |
|                 }
 | |
|                 example.rows[0].appendChild(frg);
 | |
| 
 | |
|             } else {
 | |
|                 domUtils.remove(example.rows[0]);
 | |
|             }
 | |
|             me.setColor(color);
 | |
|             me.updateSortSpan();
 | |
|         },
 | |
|         titleColHanler:function () {
 | |
|             var example = $G("J_example"),
 | |
|                 color = domUtils.getComputedStyle(domUtils.getElementsByTagName(example, "td")[0], "border-color"),
 | |
|                 colArr = example.rows,
 | |
|                 colCount = colArr.length;
 | |
| 
 | |
|             if (titleCol.checked) {
 | |
|                 for (var i = 0, node; i < colCount; i++) {
 | |
|                     node = document.createElement("th");
 | |
|                     node.innerHTML = lang.titleName;
 | |
|                     colArr[i].insertBefore(node, colArr[i].children[0]);
 | |
|                 }
 | |
|             } else {
 | |
|                 for (var i = 0; i < colCount; i++) {
 | |
|                     domUtils.remove(colArr[i].children[0]);
 | |
|                 }
 | |
|             }
 | |
|             me.setColor(color);
 | |
|             me.updateSortSpan();
 | |
|         },
 | |
|         captionHanler:function () {
 | |
|             var example = $G("J_example");
 | |
|             if (caption.checked) {
 | |
|                 var row = document.createElement('caption');
 | |
|                 row.innerHTML = lang.captionName;
 | |
|                 example.insertBefore(row, example.firstChild);
 | |
|             } else {
 | |
|                 domUtils.remove(domUtils.getElementsByTagName(example, 'caption')[0]);
 | |
|             }
 | |
|         },
 | |
|         sorttableHanler:function(){
 | |
|             me.updateSortSpan();
 | |
|         },
 | |
|         autoSizeContentHanler:function () {
 | |
|             var example = $G("J_example");
 | |
|             example.removeAttribute("width");
 | |
|         },
 | |
|         autoSizePageHanler:function () {
 | |
|             var example = $G("J_example");
 | |
|             var tds = example.getElementsByTagName(example, "td");
 | |
|             utils.each(tds, function (td) {
 | |
|                 td.removeAttribute("width");
 | |
|             });
 | |
|             example.setAttribute('width', '100%');
 | |
|         },
 | |
|         updateSortSpan: function(){
 | |
|             var example = $G("J_example"),
 | |
|                 row = example.rows[0];
 | |
| 
 | |
|             var spans = domUtils.getElementsByTagName(example,"span");
 | |
|             utils.each(spans,function(span){
 | |
|                 span.parentNode.removeChild(span);
 | |
|             });
 | |
|             if (sorttable.checked) {
 | |
|                 utils.each(row.cells, function(cell, i){
 | |
|                     var span = document.createElement("span");
 | |
|                     span.innerHTML = "^";
 | |
|                     cell.appendChild(span);
 | |
|                 });
 | |
|             }
 | |
|         },
 | |
|         getColor:function () {
 | |
|             var start = editor.selection.getStart(), color,
 | |
|                 cell = domUtils.findParentByTagName(start, ["td", "th", "caption"], true);
 | |
|             color = cell && domUtils.getComputedStyle(cell, "border-color");
 | |
|             if (!color)  color = "#DDDDDD";
 | |
|             return color;
 | |
|         },
 | |
|         setColor:function (color) {
 | |
|             var example = $G("J_example"),
 | |
|                 arr = domUtils.getElementsByTagName(example, "td").concat(
 | |
|                     domUtils.getElementsByTagName(example, "th"),
 | |
|                     domUtils.getElementsByTagName(example, "caption")
 | |
|                 );
 | |
| 
 | |
|             tone.value = color;
 | |
|             utils.each(arr, function (node) {
 | |
|                 node.style.borderColor = color;
 | |
|             });
 | |
| 
 | |
|         },
 | |
|         setAutoSize:function () {
 | |
|             var me = this;
 | |
|             autoSizePage.checked = true;
 | |
|             me.autoSizePageHanler();
 | |
|         }
 | |
|     };
 | |
| 
 | |
|     new editTable;
 | |
| 
 | |
|     dialog.onok = function () {
 | |
|         editor.__hasEnterExecCommand = true;
 | |
| 
 | |
|         var checks = {
 | |
|             title:"inserttitle deletetitle",
 | |
|             titleCol:"inserttitlecol deletetitlecol",
 | |
|             caption:"insertcaption deletecaption",
 | |
|             sorttable:"enablesort disablesort"
 | |
|         };
 | |
|         editor.fireEvent('saveScene');
 | |
|         for(var i in checks){
 | |
|             var cmds = checks[i].split(" "),
 | |
|                 input = $G("J_" + i);
 | |
|             if(input["checked"]){
 | |
|                 editor.queryCommandState(cmds[0])!=-1 &&editor.execCommand(cmds[0]);
 | |
|             }else{
 | |
|                 editor.queryCommandState(cmds[1])!=-1 &&editor.execCommand(cmds[1]);
 | |
|             }
 | |
|         }
 | |
| 
 | |
|         editor.execCommand("edittable", tone.value);
 | |
|         autoSizeContent.checked ?editor.execCommand('adaptbytext') : "";
 | |
|         autoSizePage.checked ? editor.execCommand("adaptbywindow") : "";
 | |
|         editor.fireEvent('saveScene');
 | |
| 
 | |
|         editor.__hasEnterExecCommand = false;
 | |
|     };
 | |
| })();
 | 
