You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
					
					
						
							237 lines
						
					
					
						
							8.7 KiB
						
					
					
				
			
		
		
		
			
			
			
				
					
				
				
					
				
			
		
		
	
	
							237 lines
						
					
					
						
							8.7 KiB
						
					
					
				| /** | |
|  * 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; | |
|     }; | |
| })();
 |