diff options
| author | hukl <contact@smyck.org> | 2009-02-17 21:54:39 +0100 |
|---|---|---|
| committer | hukl <contact@smyck.org> | 2009-02-17 21:54:39 +0100 |
| commit | f61b5b0597e0c25f084ee67d402f12a43a7a9947 (patch) | |
| tree | 3b4c3f9f38637f1a7ecf703ece4fd3bc4c6e2934 /public/javascripts/tiny_mce/plugins/table | |
| parent | 3d3b786cc43266f6292f5edd25733dbb9bd6ed06 (diff) | |
added tinymce editor for body area of pages
Diffstat (limited to 'public/javascripts/tiny_mce/plugins/table')
14 files changed, 2765 insertions, 0 deletions
diff --git a/public/javascripts/tiny_mce/plugins/table/cell.htm b/public/javascripts/tiny_mce/plugins/table/cell.htm new file mode 100755 index 0000000..60264db --- /dev/null +++ b/public/javascripts/tiny_mce/plugins/table/cell.htm | |||
| @@ -0,0 +1,184 @@ | |||
| 1 | <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"> | ||
| 2 | <html xmlns="http://www.w3.org/1999/xhtml"> | ||
| 3 | <head> | ||
| 4 | <title>{#table_dlg.cell_title}</title> | ||
| 5 | <script type="text/javascript" src="../../tiny_mce_popup.js"></script> | ||
| 6 | <script type="text/javascript" src="../../utils/mctabs.js"></script> | ||
| 7 | <script type="text/javascript" src="../../utils/form_utils.js"></script> | ||
| 8 | <script type="text/javascript" src="../../utils/editable_selects.js"></script> | ||
| 9 | <script type="text/javascript" src="js/cell.js"></script> | ||
| 10 | <link href="css/cell.css" rel="stylesheet" type="text/css" /> | ||
| 11 | <base target="_self" /> | ||
| 12 | </head> | ||
| 13 | <body id="tablecell" style="display: none"> | ||
| 14 | <form onsubmit="updateAction();return false;" action="#"> | ||
| 15 | <div class="tabs"> | ||
| 16 | <ul> | ||
| 17 | <li id="general_tab" class="current"><span><a href="javascript:mcTabs.displayTab('general_tab','general_panel');" onmousedown="return false;">{#table_dlg.general_tab}</a></span></li> | ||
| 18 | <li id="advanced_tab"><span><a href="javascript:mcTabs.displayTab('advanced_tab','advanced_panel');" onmousedown="return false;">{#table_dlg.advanced_tab}</a></span></li> | ||
| 19 | </ul> | ||
| 20 | </div> | ||
| 21 | |||
| 22 | <div class="panel_wrapper"> | ||
| 23 | <div id="general_panel" class="panel current"> | ||
| 24 | <fieldset> | ||
| 25 | <legend>{#table_dlg.general_props}</legend> | ||
| 26 | |||
| 27 | <table border="0" cellpadding="4" cellspacing="0"> | ||
| 28 | <tr> | ||
| 29 | <td><label for="align">{#table_dlg.align}</label></td> | ||
| 30 | <td> | ||
| 31 | <select id="align" name="align" class="mceFocus"> | ||
| 32 | <option value="">{#not_set}</option> | ||
| 33 | <option value="center">{#table_dlg.align_middle}</option> | ||
| 34 | <option value="left">{#table_dlg.align_left}</option> | ||
| 35 | <option value="right">{#table_dlg.align_right}</option> | ||
| 36 | </select> | ||
| 37 | </td> | ||
| 38 | |||
| 39 | <td><label for="celltype">{#table_dlg.cell_type}</label></td> | ||
| 40 | <td> | ||
| 41 | <select id="celltype" name="celltype"> | ||
| 42 | <option value="td">{#table_dlg.td}</option> | ||
| 43 | <option value="th">{#table_dlg.th}</option> | ||
| 44 | </select> | ||
| 45 | </td> | ||
| 46 | </tr> | ||
| 47 | |||
| 48 | <tr> | ||
| 49 | <td><label for="valign">{#table_dlg.valign}</label></td> | ||
| 50 | <td> | ||
| 51 | <select id="valign" name="valign"> | ||
| 52 | <option value="">{#not_set}</option> | ||
| 53 | <option value="top">{#table_dlg.align_top}</option> | ||
| 54 | <option value="middle">{#table_dlg.align_middle}</option> | ||
| 55 | <option value="bottom">{#table_dlg.align_bottom}</option> | ||
| 56 | </select> | ||
| 57 | </td> | ||
| 58 | |||
| 59 | <td><label for="scope">{#table_dlg.scope}</label></td> | ||
| 60 | <td> | ||
| 61 | <select id="scope" name="scope"> | ||
| 62 | <option value="">{#not_set}</option> | ||
| 63 | <option value="col">{#table.col}</option> | ||
| 64 | <option value="row">{#table.row}</option> | ||
| 65 | <option value="rowgroup">{#table_dlg.rowgroup}</option> | ||
| 66 | <option value="colgroup">{#table_dlg.colgroup}</option> | ||
| 67 | </select> | ||
| 68 | </td> | ||
| 69 | |||
| 70 | </tr> | ||
| 71 | |||
| 72 | <tr> | ||
| 73 | <td><label for="width">{#table_dlg.width}</label></td> | ||
| 74 | <td><input id="width" name="width" type="text" value="" size="4" maxlength="4" onchange="changedSize();" /></td> | ||
| 75 | |||
| 76 | <td><label for="height">{#table_dlg.height}</label></td> | ||
| 77 | <td><input id="height" name="height" type="text" value="" size="4" maxlength="4" onchange="changedSize();" /></td> | ||
| 78 | </tr> | ||
| 79 | |||
| 80 | <tr id="styleSelectRow"> | ||
| 81 | <td><label for="class">{#class_name}</label></td> | ||
| 82 | <td colspan="3"> | ||
| 83 | <select id="class" name="class" class="mceEditableSelect"> | ||
| 84 | <option value="" selected="selected">{#not_set}</option> | ||
| 85 | </select> | ||
| 86 | </td> | ||
| 87 | </tr> | ||
| 88 | </table> | ||
| 89 | </fieldset> | ||
| 90 | </div> | ||
| 91 | |||
| 92 | <div id="advanced_panel" class="panel"> | ||
| 93 | <fieldset> | ||
| 94 | <legend>{#table_dlg.advanced_props}</legend> | ||
| 95 | |||
| 96 | <table border="0" cellpadding="0" cellspacing="4"> | ||
| 97 | <tr> | ||
| 98 | <td class="column1"><label for="id">{#table_dlg.id}</label></td> | ||
| 99 | <td><input id="id" name="id" type="text" value="" style="width: 200px" /></td> | ||
| 100 | </tr> | ||
| 101 | |||
| 102 | <tr> | ||
| 103 | <td><label for="style">{#table_dlg.style}</label></td> | ||
| 104 | <td><input type="text" id="style" name="style" value="" style="width: 200px;" onchange="changedStyle();" /></td> | ||
| 105 | </tr> | ||
| 106 | |||
| 107 | <tr> | ||
| 108 | <td class="column1"><label for="dir">{#table_dlg.langdir}</label></td> | ||
| 109 | <td> | ||
| 110 | <select id="dir" name="dir" style="width: 200px"> | ||
| 111 | <option value="">{#not_set}</option> | ||
| 112 | <option value="ltr">{#table_dlg.ltr}</option> | ||
| 113 | <option value="rtl">{#table_dlg.rtl}</option> | ||
| 114 | </select> | ||
| 115 | </td> | ||
| 116 | </tr> | ||
| 117 | |||
| 118 | <tr> | ||
| 119 | <td class="column1"><label for="lang">{#table_dlg.langcode}</label></td> | ||
| 120 | <td> | ||
| 121 | <input id="lang" name="lang" type="text" value="" style="width: 200px" /> | ||
| 122 | </td> | ||
| 123 | </tr> | ||
| 124 | |||
| 125 | <tr> | ||
| 126 | <td class="column1"><label for="backgroundimage">{#table_dlg.bgimage}</label></td> | ||
| 127 | <td> | ||
| 128 | <table border="0" cellpadding="0" cellspacing="0"> | ||
| 129 | <tr> | ||
| 130 | <td><input id="backgroundimage" name="backgroundimage" type="text" value="" style="width: 200px" onchange="changedBackgroundImage();" /></td> | ||
| 131 | <td id="backgroundimagebrowsercontainer"> </td> | ||
| 132 | </tr> | ||
| 133 | </table> | ||
| 134 | </td> | ||
| 135 | </tr> | ||
| 136 | |||
| 137 | <tr> | ||
| 138 | <td class="column1"><label for="bordercolor">{#table_dlg.bordercolor}</label></td> | ||
| 139 | <td> | ||
| 140 | <table border="0" cellpadding="0" cellspacing="0"> | ||
| 141 | <tr> | ||
| 142 | <td><input id="bordercolor" name="bordercolor" type="text" value="" size="9" onchange="updateColor('bordercolor_pick','bordercolor');changedColor();" /></td> | ||
| 143 | <td id="bordercolor_pickcontainer"> </td> | ||
| 144 | </tr> | ||
| 145 | </table> | ||
| 146 | </td> | ||
| 147 | </tr> | ||
| 148 | |||
| 149 | <tr> | ||
| 150 | <td class="column1"><label for="bgcolor">{#table_dlg.bgcolor}</label></td> | ||
| 151 | <td> | ||
| 152 | <table border="0" cellpadding="0" cellspacing="0"> | ||
| 153 | <tr> | ||
| 154 | <td><input id="bgcolor" name="bgcolor" type="text" value="" size="9" onchange="updateColor('bgcolor_pick','bgcolor');changedColor();" /></td> | ||
| 155 | <td id="bgcolor_pickcontainer"> </td> | ||
| 156 | </tr> | ||
| 157 | </table> | ||
| 158 | </td> | ||
| 159 | </tr> | ||
| 160 | </table> | ||
| 161 | </fieldset> | ||
| 162 | </div> | ||
| 163 | </div> | ||
| 164 | |||
| 165 | <div class="mceActionPanel"> | ||
| 166 | <div> | ||
| 167 | <select id="action" name="action"> | ||
| 168 | <option value="cell">{#table_dlg.cell_cell}</option> | ||
| 169 | <option value="row">{#table_dlg.cell_row}</option> | ||
| 170 | <option value="all">{#table_dlg.cell_all}</option> | ||
| 171 | </select> | ||
| 172 | </div> | ||
| 173 | |||
| 174 | <div style="float: left"> | ||
| 175 | <div><input type="submit" id="insert" name="insert" value="{#update}" /></div> | ||
| 176 | </div> | ||
| 177 | |||
| 178 | <div style="float: right"> | ||
| 179 | <input type="button" id="cancel" name="cancel" value="{#cancel}" onclick="tinyMCEPopup.close();" /> | ||
| 180 | </div> | ||
| 181 | </div> | ||
| 182 | </form> | ||
| 183 | </body> | ||
| 184 | </html> | ||
diff --git a/public/javascripts/tiny_mce/plugins/table/css/cell.css b/public/javascripts/tiny_mce/plugins/table/css/cell.css new file mode 100755 index 0000000..a067ecd --- /dev/null +++ b/public/javascripts/tiny_mce/plugins/table/css/cell.css | |||
| @@ -0,0 +1,17 @@ | |||
| 1 | /* CSS file for cell dialog in the table plugin */ | ||
| 2 | |||
| 3 | .panel_wrapper div.current { | ||
| 4 | height: 200px; | ||
| 5 | } | ||
| 6 | |||
| 7 | .advfield { | ||
| 8 | width: 200px; | ||
| 9 | } | ||
| 10 | |||
| 11 | #action { | ||
| 12 | margin-bottom: 3px; | ||
| 13 | } | ||
| 14 | |||
| 15 | #class { | ||
| 16 | width: 150px; | ||
| 17 | } \ No newline at end of file | ||
diff --git a/public/javascripts/tiny_mce/plugins/table/css/row.css b/public/javascripts/tiny_mce/plugins/table/css/row.css new file mode 100755 index 0000000..1f7755d --- /dev/null +++ b/public/javascripts/tiny_mce/plugins/table/css/row.css | |||
| @@ -0,0 +1,25 @@ | |||
| 1 | /* CSS file for row dialog in the table plugin */ | ||
| 2 | |||
| 3 | .panel_wrapper div.current { | ||
| 4 | height: 200px; | ||
| 5 | } | ||
| 6 | |||
| 7 | .advfield { | ||
| 8 | width: 200px; | ||
| 9 | } | ||
| 10 | |||
| 11 | #action { | ||
| 12 | margin-bottom: 3px; | ||
| 13 | } | ||
| 14 | |||
| 15 | #rowtype,#align,#valign,#class,#height { | ||
| 16 | width: 150px; | ||
| 17 | } | ||
| 18 | |||
| 19 | #height { | ||
| 20 | width: 50px; | ||
| 21 | } | ||
| 22 | |||
| 23 | .col2 { | ||
| 24 | padding-left: 20px; | ||
| 25 | } | ||
diff --git a/public/javascripts/tiny_mce/plugins/table/css/table.css b/public/javascripts/tiny_mce/plugins/table/css/table.css new file mode 100755 index 0000000..d11c3f6 --- /dev/null +++ b/public/javascripts/tiny_mce/plugins/table/css/table.css | |||
| @@ -0,0 +1,13 @@ | |||
| 1 | /* CSS file for table dialog in the table plugin */ | ||
| 2 | |||
| 3 | .panel_wrapper div.current { | ||
| 4 | height: 245px; | ||
| 5 | } | ||
| 6 | |||
| 7 | .advfield { | ||
| 8 | width: 200px; | ||
| 9 | } | ||
| 10 | |||
| 11 | #class { | ||
| 12 | width: 150px; | ||
| 13 | } | ||
diff --git a/public/javascripts/tiny_mce/plugins/table/editor_plugin.js b/public/javascripts/tiny_mce/plugins/table/editor_plugin.js new file mode 100755 index 0000000..97a9d25 --- /dev/null +++ b/public/javascripts/tiny_mce/plugins/table/editor_plugin.js | |||
| @@ -0,0 +1 @@ | |||
| (function(){var each=tinymce.each;tinymce.create('tinymce.plugins.TablePlugin',{init:function(ed,url){var t=this;t.editor=ed;t.url=url;each([['table','table.desc','mceInsertTable',true],['delete_table','table.del','mceTableDelete'],['delete_col','table.delete_col_desc','mceTableDeleteCol'],['delete_row','table.delete_row_desc','mceTableDeleteRow'],['col_after','table.col_after_desc','mceTableInsertColAfter'],['col_before','table.col_before_desc','mceTableInsertColBefore'],['row_after','table.row_after_desc','mceTableInsertRowAfter'],['row_before','table.row_before_desc','mceTableInsertRowBefore'],['row_props','table.row_desc','mceTableRowProps',true],['cell_props','table.cell_desc','mceTableCellProps',true],['split_cells','table.split_cells_desc','mceTableSplitCells',true],['merge_cells','table.merge_cells_desc','mceTableMergeCells',true]],function(c){ed.addButton(c[0],{title:c[1],cmd:c[2],ui:c[3]});});if(ed.getParam('inline_styles')){ed.onPreProcess.add(function(ed,o){var dom=ed.dom;each(dom.select('table',o.node),function(n){var v;if(v=dom.getAttrib(n,'width')){dom.setStyle(n,'width',v);dom.setAttrib(n,'width');}if(v=dom.getAttrib(n,'height')){dom.setStyle(n,'height',v);dom.setAttrib(n,'height');}});});}ed.onInit.add(function(){if(ed&&ed.plugins.contextmenu){ed.plugins.contextmenu.onContextMenu.add(function(th,m,e){var sm,se=ed.selection,el=se.getNode()||ed.getBody();if(ed.dom.getParent(e,'td')||ed.dom.getParent(e,'th')){m.removeAll();if(el.nodeName=='A'&&!ed.dom.getAttrib(el,'name')){m.add({title:'advanced.link_desc',icon:'link',cmd:ed.plugins.advlink?'mceAdvLink':'mceLink',ui:true});m.add({title:'advanced.unlink_desc',icon:'unlink',cmd:'UnLink'});m.addSeparator();}if(el.nodeName=='IMG'&&el.className.indexOf('mceItem')==-1){m.add({title:'advanced.image_desc',icon:'image',cmd:ed.plugins.advimage?'mceAdvImage':'mceImage',ui:true});m.addSeparator();}m.add({title:'table.desc',icon:'table',cmd:'mceInsertTable',ui:true,value:{action:'insert'}});m.add({title:'table.props_desc',icon:'table_props',cmd:'mceInsertTable',ui:true});m.add({title:'table.del',icon:'delete_table',cmd:'mceTableDelete',ui:true});m.addSeparator();sm=m.addMenu({title:'table.cell'});sm.add({title:'table.cell_desc',icon:'cell_props',cmd:'mceTableCellProps',ui:true});sm.add({title:'table.split_cells_desc',icon:'split_cells',cmd:'mceTableSplitCells',ui:true});sm.add({title:'table.merge_cells_desc',icon:'merge_cells',cmd:'mceTableMergeCells',ui:true});sm=m.addMenu({title:'table.row'});sm.add({title:'table.row_desc',icon:'row_props',cmd:'mceTableRowProps',ui:true});sm.add({title:'table.row_before_desc',icon:'row_before',cmd:'mceTableInsertRowBefore'});sm.add({title:'table.row_after_desc',icon:'row_after',cmd:'mceTableInsertRowAfter'});sm.add({title:'table.delete_row_desc',icon:'delete_row',cmd:'mceTableDeleteRow'});sm.addSeparator();sm.add({title:'table.cut_row_desc',icon:'cut',cmd:'mceTableCutRow'});sm.add({title:'table.copy_row_desc',icon:'copy',cmd:'mceTableCopyRow'});sm.add({title:'table.paste_row_before_desc',icon:'paste',cmd:'mceTablePasteRowBefore'});sm.add({title:'table.paste_row_after_desc',icon:'paste',cmd:'mceTablePasteRowAfter'});sm=m.addMenu({title:'table.col'});sm.add({title:'table.col_before_desc',icon:'col_before',cmd:'mceTableInsertColBefore'});sm.add({title:'table.col_after_desc',icon:'col_after',cmd:'mceTableInsertColAfter'});sm.add({title:'table.delete_col_desc',icon:'delete_col',cmd:'mceTableDeleteCol'});}else m.add({title:'table.desc',icon:'table',cmd:'mceInsertTable',ui:true});});}});ed.onKeyDown.add(function(ed,e){if(e.keyCode==9&&ed.dom.getParent(ed.selection.getNode(),'TABLE')){if(!tinymce.isGecko&&!tinymce.isOpera){tinyMCE.execInstanceCommand(ed.editorId,"mceTableMoveToNextRow",true);return tinymce.dom.Event.cancel(e);}ed.undoManager.add();}});if(!tinymce.isIE){if(ed.getParam('table_selection',true)){ed.onClick.add(function(ed,e){e=e.target;if(e.nodeName==='TABLE')ed.selection.select(e);});}}ed.onNodeChange.add(function(ed,cm,n){var p=ed.dom.getParent(n,'td,th,caption');cm.setActive('table',n.nodeName==='TABLE'||!!p);if(p&&p.nodeName==='CAPTION')p=null;cm.setDisabled('delete_table',!p);cm.setDisabled('delete_col',!p);cm.setDisabled('delete_table',!p);cm.setDisabled('delete_row',!p);cm.setDisabled('col_after',!p);cm.setDisabled('col_before',!p);cm.setDisabled('row_after',!p);cm.setDisabled('row_before',!p);cm.setDisabled('row_props',!p);cm.setDisabled('cell_props',!p);cm.setDisabled('split_cells',!p||(parseInt(ed.dom.getAttrib(p,'colspan','1'))<2&&parseInt(ed.dom.getAttrib(p,'rowspan','1'))<2));cm.setDisabled('merge_cells',!p);});if(!tinymce.isIE){ed.onBeforeSetContent.add(function(ed,o){if(o.initial)o.content=o.content.replace(/<(td|th)([^>]+|)>\s*<\/(td|th)>/g,tinymce.isOpera?'<$1$2> </$1>':'<$1$2><br mce_bogus="1" /></$1>');});}},execCommand:function(cmd,ui,val){var ed=this.editor,b;switch(cmd){case"mceTableMoveToNextRow":case"mceInsertTable":case"mceTableRowProps":case"mceTableCellProps":case"mceTableSplitCells":case"mceTableMergeCells":case"mceTableInsertRowBefore":case"mceTableInsertRowAfter":case"mceTableDeleteRow":case"mceTableInsertColBefore":case"mceTableInsertColAfter":case"mceTableDeleteCol":case"mceTableCutRow":case"mceTableCopyRow":case"mceTablePasteRowBefore":case"mceTablePasteRowAfter":case"mceTableDelete":ed.execCommand('mceBeginUndoLevel');this._doExecCommand(cmd,ui,val);ed.execCommand('mceEndUndoLevel');return true;}return false;},getInfo:function(){return{longname:'Tables',author:'Moxiecode Systems AB',authorurl:'http://tinymce.moxiecode.com',infourl:'http://wiki.moxiecode.com/index.php/TinyMCE:Plugins/table',version:tinymce.majorVersion+"."+tinymce.minorVersion};},_doExecCommand:function(command,user_interface,value){var inst=this.editor,ed=inst,url=this.url;var focusElm=inst.selection.getNode();var trElm=inst.dom.getParent(focusElm,"tr");var tdElm=inst.dom.getParent(focusElm,"td,th");var tableElm=inst.dom.getParent(focusElm,"table");var doc=inst.contentWindow.document;var tableBorder=tableElm?tableElm.getAttribute("border"):"";if(trElm&&tdElm==null)tdElm=trElm.cells[0];function inArray(ar,v){for(var i=0;i<ar.length;i++){if(ar[i].length>0&&inArray(ar[i],v))return true;if(ar[i]==v)return true;}return false;}function select(dx,dy){var td;grid=getTableGrid(tableElm);dx=dx||0;dy=dy||0;dx=Math.max(cpos.cellindex+dx,0);dy=Math.max(cpos.rowindex+dy,0);inst.execCommand('mceRepaint');td=getCell(grid,dy,dx);if(td){inst.selection.select(td.firstChild||td);inst.selection.collapse(1);}};function makeTD(){var newTD=doc.createElement("td");if(!tinymce.isIE)newTD.innerHTML='<br mce_bogus="1"/>';}function getColRowSpan(td){var colspan=inst.dom.getAttrib(td,"colspan");var rowspan=inst.dom.getAttrib(td,"rowspan");colspan=colspan==""?1:parseInt(colspan);rowspan=rowspan==""?1:parseInt(rowspan);return{colspan:colspan,rowspan:rowspan};}function getCellPos(grid,td){var x,y;for(y=0;y<grid.length;y++){for(x=0;x<grid[y].length;x++){if(grid[y][x]==td)return{cellindex:x,rowindex:y};}}return null;}function getCell(grid,row,col){if(grid[row]&&grid[row][col])return grid[row][col];return null;}function getNextCell(table,cell){var cells=[],x=0,i,j,cell,nextCell;for(i=0;i<table.rows.length;i++)for(j=0;j<table.rows[i].cells.length;j++,x++)cells[x]=table.rows[i].cells[j];for(i=0;i<cells.length;i++)if(cells[i]==cell)if(nextCell=cells[i+1])return nextCell;}function getTableGrid(table){var grid=[],rows=table.rows,x,y,td,sd,xstart,x2,y2;for(y=0;y<rows.length;y++){for(x=0;x<rows[y].cells.length;x++){td=rows[y].cells[x];sd=getColRowSpan(td);for(xstart=x;grid[y]&&grid[y][xstart];xstart++);for(y2=y;y2<y+sd['rowspan'];y2++){if(!grid[y2])grid[y2]=[];for(x2=xstart;x2<xstart+sd['colspan'];x2++)grid[y2][x2]=td;}}}return grid;}function trimRow(table,tr,td,new_tr){var grid=getTableGrid(table),cpos=getCellPos(grid,td);var cells,lastElm;if(new_tr.cells.length!=tr.childNodes.length){cells=tr.childNodes;lastElm=null;for(var x=0;td=getCell(grid,cpos.rowindex,x);x++){var remove=true;var sd=getColRowSpan(td);if(inArray(cells,td)){new_tr.childNodes[x]._delete=true;}else if((lastElm==null||td!=lastElm)&&sd.colspan>1){for(var i=x;i<x+td.colSpan;i++)new_tr.childNodes[i]._delete=true;}if((lastElm==null||td!=lastElm)&&sd.rowspan>1)td.rowSpan=sd.rowspan+1;lastElm=td;}deleteMarked(tableElm);}}function prevElm(node,name){while((node=node.previousSibling)!=null){if(node.nodeName==name)return node;}return null;}function nextElm(node,names){var namesAr=names.split(',');while((node=node.nextSibling)!=null){for(var i=0;i<namesAr.length;i++){if(node.nodeName.toLowerCase()==namesAr[i].toLowerCase())return node;}}return null;}function deleteMarked(tbl){if(tbl.rows==0)return;var tr=tbl.rows[0];do{var next=nextElm(tr,"TR");if(tr._delete){tr.parentNode.removeChild(tr);continue;}var td=tr.cells[0];if(td.cells>1){do{var nexttd=nextElm(td,"TD,TH");if(td._delete)td.parentNode.removeChild(td);}while((td=nexttd)!=null);}}while((tr=next)!=null);}function addRows(td_elm,tr_elm,rowspan){td_elm.rowSpan=1;var trNext=nextElm(tr_elm,"TR");for(var i=1;i<rowspan&&trNext;i++){var newTD=doc.createElement("td");if(!tinymce.isIE)newTD.innerHTML='<br mce_bogus="1"/>';if(tinymce.isIE)trNext.insertBefore(newTD,trNext.cells(td_elm.cellIndex));else trNext.insertBefore(newTD,trNext.cells[td_elm.cellIndex]);trNext=nextElm(trNext,"TR");}}function copyRow(doc,table,tr){var grid=getTableGrid(table);var newTR=tr.cloneNode(false);var cpos=getCellPos(grid,tr.cells[0]);var lastCell=null;var tableBorder=inst.dom.getAttrib(table,"border");var tdElm=null;for(var x=0;tdElm=getCell(grid,cpos.rowindex,x);x++){var newTD=null;if(lastCell!=tdElm){for(var i=0;i<tr.cells.length;i++){if(tdElm==tr.cells[i]){newTD=tdElm.cloneNode(true);break;}}}if(newTD==null){newTD=doc.createElement("td");if(!tinymce.isIE)newTD.innerHTML='<br mce_bogus="1"/>';}newTD.colSpan=1;newTD.rowSpan=1;newTR.appendChild(newTD);lastCell=tdElm;}return newTR;}switch(command){case"mceTableMoveToNextRow":var nextCell=getNextCell(tableElm,tdElm);if(!nextCell){inst.execCommand("mceTableInsertRowAfter",tdElm);nextCell=getNextCell(tableElm,tdElm);}inst.selection.select(nextCell);inst.selection.collapse(true);return true;case"mceTableRowProps":if(trElm==null)return true;if(user_interface){inst.windowManager.open({url:url+'/row.htm',width:400+parseInt(inst.getLang('table.rowprops_delta_width',0)),height:295+parseInt(inst.getLang('table.rowprops_delta_height',0)),inline:1},{plugin_url:url});}return true;case"mceTableCellProps":if(tdElm==null)return true;if(user_interface){inst.windowManager.open({url:url+'/cell.htm',width:400+parseInt(inst.getLang('table.cellprops_delta_width',0)),height:295+parseInt(inst.getLang('table.cellprops_delta_height',0)),inline:1},{plugin_url:url});}return true;case"mceInsertTable":if(user_interface){inst.windowManager.open({url:url+'/table.htm',width:400+parseInt(inst.getLang('table.table_delta_width',0)),height:320+parseInt(inst.getLang('table.table_delta_height',0)),inline:1},{plugin_url:url,action:value?value.action:0});}return true;case"mceTableDelete":var table=inst.dom.getParent(inst.selection.getNode(),"table");if(table){table.parentNode.removeChild(table);inst.execCommand('mceRepaint');}return true;case"mceTableSplitCells":case"mceTableMergeCells":case"mceTableInsertRowBefore":case"mceTableInsertRowAfter":case"mceTableDeleteRow":case"mceTableInsertColBefore":case"mceTableInsertColAfter":case"mceTableDeleteCol":case"mceTableCutRow":case"mceTableCopyRow":case"mceTablePasteRowBefore":case"mceTablePasteRowAfter":if(!tableElm)return true;if(trElm&&tableElm!=trElm.parentNode)tableElm=trElm.parentNode;if(tableElm&&trElm){switch(command){case"mceTableCutRow":if(!trElm||!tdElm)return true;inst.tableRowClipboard=copyRow(doc,tableElm,trElm);inst.execCommand("mceTableDeleteRow");break;case"mceTableCopyRow":if(!trElm||!tdElm)return true;inst.tableRowClipboard=copyRow(doc,tableElm,trElm);break;case"mceTablePasteRowBefore":if(!trElm||!tdElm)return true;var newTR=inst.tableRowClipboard.cloneNode(true);var prevTR=prevElm(trElm,"TR");if(prevTR!=null)trimRow(tableElm,prevTR,prevTR.cells[0],newTR);trElm.parentNode.insertBefore(newTR,trElm);break;case"mceTablePasteRowAfter":if(!trElm||!tdElm)return true;var nextTR=nextElm(trElm,"TR");var newTR=inst.tableRowClipboard.cloneNode(true);trimRow(tableElm,trElm,tdElm,newTR);if(nextTR==null)trElm.parentNode.appendChild(newTR);else nextTR.parentNode.insertBefore(newTR,nextTR);break;case"mceTableInsertRowBefore":if(!trElm||!tdElm)return true;var grid=getTableGrid(tableElm);var cpos=getCellPos(grid,tdElm);var newTR=doc.createElement("tr");var lastTDElm=null;cpos.rowindex--;if(cpos.rowindex<0)cpos.rowindex=0;for(var x=0;tdElm=getCell(grid,cpos.rowindex,x);x++){if(tdElm!=lastTDElm){var sd=getColRowSpan(tdElm);if(sd['rowspan']==1){var newTD=doc.createElement("td");if(!tinymce.isIE)newTD.innerHTML='<br mce_bogus="1"/>';newTD.colSpan=tdElm.colSpan;newTR.appendChild(newTD);}else tdElm.rowSpan=sd['rowspan']+1;lastTDElm=tdElm;}}trElm.parentNode.insertBefore(newTR,trElm);select(0,1);break;case"mceTableInsertRowAfter":if(!trElm||!tdElm)return true;var grid=getTableGrid(tableElm);var cpos=getCellPos(grid,tdElm);var newTR=doc.createElement("tr");var lastTDElm=null;for(var x=0;tdElm=getCell(grid,cpos.rowindex,x);x++){if(tdElm!=lastTDElm){var sd=getColRowSpan(tdElm);if(sd['rowspan']==1){var newTD=doc.createElement("td");if(!tinymce.isIE)newTD.innerHTML='<br mce_bogus="1"/>';newTD.colSpan=tdElm.colSpan;newTR.appendChild(newTD);}else tdElm.rowSpan=sd['rowspan']+1;lastTDElm=tdElm;}}if(newTR.hasChildNodes()){var nextTR=nextElm(trElm,"TR");if(nextTR)nextTR.parentNode.insertBefore(newTR,nextTR);else tableElm.appendChild(newTR);}select(0,1);break;case"mceTableDeleteRow":if(!trElm||!tdElm)return true;var grid=getTableGrid(tableElm);var cpos=getCellPos(grid,tdElm);if(grid.length==1&&tableElm.nodeName=='TBODY'){inst.dom.remove(inst.dom.getParent(tableElm,"table"));return true;}var cells=trElm.cells;var nextTR=nextElm(trElm,"TR");for(var x=0;x<cells.length;x++){if(cells[x].rowSpan>1){var newTD=cells[x].cloneNode(true);var sd=getColRowSpan(cells[x]);newTD.rowSpan=sd.rowspan-1;var nextTD=nextTR.cells[x];if(nextTD==null)nextTR.appendChild(newTD);else nextTR.insertBefore(newTD,nextTD);}}var lastTDElm=null;for(var x=0;tdElm=getCell(grid,cpos.rowindex,x);x++){if(tdElm!=lastTDElm){var sd=getColRowSpan(tdElm);if(sd.rowspan>1){tdElm.rowSpan=sd.rowspan-1;}else{trElm=tdElm.parentNode;if(trElm.parentNode)trElm._delete=true;}lastTDElm=tdElm;}}deleteMarked(tableElm);select(0,-1);break;case"mceTableInsertColBefore":if(!trElm||!tdElm)return true;var grid=getTableGrid(inst.dom.getParent(tableElm,"table"));var cpos=getCellPos(grid,tdElm);var lastTDElm=null;for(var y=0;tdElm=getCell(grid,y,cpos.cellindex);y++){if(tdElm!=lastTDElm){var sd=getColRowSpan(tdElm);if(sd['colspan']==1){var newTD=doc.createElement(tdElm.nodeName);if(!tinymce.isIE)newTD.innerHTML='<br mce_bogus="1"/>';newTD.rowSpan=tdElm.rowSpan;tdElm.parentNode.insertBefore(newTD,tdElm);}else tdElm.colSpan++;lastTDElm=tdElm;}}select();break;case"mceTableInsertColAfter":if(!trElm||!tdElm)return true;var grid=getTableGrid(inst.dom.getParent(tableElm,"table"));var cpos=getCellPos(grid,tdElm);var lastTDElm=null;for(var y=0;tdElm=getCell(grid,y,cpos.cellindex);y++){if(tdElm!=lastTDElm){var sd=getColRowSpan(tdElm);if(sd['colspan']==1){var newTD=doc.createElement(tdElm.nodeName);if(!tinymce.isIE)newTD.innerHTML='<br mce_bogus="1"/>';newTD.rowSpan=tdElm.rowSpan;var nextTD=nextElm(tdElm,"TD,TH");if(nextTD==null)tdElm.parentNode.appendChild(newTD);else nextTD.parentNode.insertBefore(newTD,nextTD);}else tdElm.colSpan++;lastTDElm=tdElm;}}select(1);break;case"mceTableDeleteCol":if(!trElm||!tdElm)return true;var grid=getTableGrid(tableElm);var cpos=getCellPos(grid,tdElm);var lastTDElm=null;if((grid.length>1&&grid[0].length<=1)&&tableElm.nodeName=='TBODY'){inst.dom.remove(inst.dom.getParent(tableElm,"table"));return true;}for(var y=0;tdElm=getCell(grid,y,cpos.cellindex);y++){if(tdElm!=lastTDElm){var sd=getColRowSpan(tdElm);if(sd['colspan']>1)tdElm.colSpan=sd['colspan']-1;else{if(tdElm.parentNode)tdElm.parentNode.removeChild(tdElm);}lastTDElm=tdElm;}}select(-1);break;case"mceTableSplitCells":if(!trElm||!tdElm)return true;var spandata=getColRowSpan(tdElm);var colspan=spandata["colspan"];var rowspan=spandata["rowspan"];if(colspan>1||rowspan>1){tdElm.colSpan=1;for(var i=1;i<colspan;i++){var newTD=doc.createElement("td");if(!tinymce.isIE)newTD.innerHTML='<br mce_bogus="1"/>';trElm.insertBefore(newTD,nextElm(tdElm,"TD,TH"));if(rowspan>1)addRows(newTD,trElm,rowspan);}addRows(tdElm,trElm,rowspan);}tableElm=inst.dom.getParent(inst.selection.getNode(),"table");break;case"mceTableMergeCells":var rows=[];var sel=inst.selection.getSel();var grid=getTableGrid(tableElm);if(tinymce.isIE||sel.rangeCount==1){if(user_interface){var sp=getColRowSpan(tdElm);inst.windowManager.open({url:url+'/merge_cells.htm',width:240+parseInt(inst.getLang('table.merge_cells_delta_width',0)),height:110+parseInt(inst.getLang('table.merge_cells_delta_height',0)),inline:1},{action:"update",numcols:sp.colspan,numrows:sp.rowspan,plugin_url:url});return true;}else{var numRows=parseInt(value['numrows']);var numCols=parseInt(value['numcols']);var cpos=getCellPos(grid,tdElm);if((""+numRows)=="NaN")numRows=1;if((""+numCols)=="NaN")numCols=1;var tRows=tableElm.rows;for(var y=cpos.rowindex;y<grid.length;y++){var rowCells=[];for(var x=cpos.cellindex;x<grid[y].length;x++){var td=getCell(grid,y,x);if(td&&!inArray(rows,td)&&!inArray(rowCells,td)){var cp=getCellPos(grid,td);if(cp.cellindex<cpos.cellindex+numCols&&cp.rowindex<cpos.rowindex+numRows)rowCells[rowCells.length]=td;}}if(rowCells.length>0)rows[rows.length]=rowCells;var td=getCell(grid,cpos.rowindex,cpos.cellindex);each(ed.dom.select('br',td),function(e,i){if(i>0&&ed.dom.getAttrib('mce_bogus'))ed.dom.remove(e);});}}}else{var cells=[];var sel=inst.selection.getSel();var lastTR=null;var curRow=null;var x1=-1,y1=-1,x2,y2;if(sel.rangeCount<2)return true;for(var i=0;i<sel.rangeCount;i++){var rng=sel.getRangeAt(i);var tdElm=rng.startContainer.childNodes[rng.startOffset];if(!tdElm)break;if(tdElm.nodeName=="TD"||tdElm.nodeName=="TH")cells[cells.length]=tdElm;}var tRows=tableElm.rows;for(var y=0;y<tRows.length;y++){var rowCells=[];for(var x=0;x<tRows[y].cells.length;x++){var td=tRows[y].cells[x];for(var i=0;i<cells.length;i++){if(td==cells[i]){rowCells[rowCells.length]=td;}}}if(rowCells.length>0)rows[rows.length]=rowCells;}var curRow=[];var lastTR=null;for(var y=0;y<grid.length;y++){for(var x=0;x<grid[y].length;x++){grid[y][x]._selected=false;for(var i=0;i<cells.length;i++){if(grid[y][x]==cells[i]){if(x1==-1){x1=x;y1=y;}x2=x;y2=y;grid[y][x]._selected=true;}}}}for(var y=y1;y<=y2;y++){for(var x=x1;x<=x2;x++){if(!grid[y][x]._selected){alert("Invalid selection for merge.");return true;}}}}var rowSpan=1,colSpan=1;var lastRowSpan=-1;for(var y=0;y<rows.length;y++){var rowColSpan=0;for(var x=0;x<rows[y].length;x++){var sd=getColRowSpan(rows[y][x]);rowColSpan+=sd['colspan'];if(lastRowSpan!=-1&&sd['rowspan']!=lastRowSpan){alert("Invalid selection for merge.");return true;}lastRowSpan=sd['rowspan'];}if(rowColSpan>colSpan)colSpan=rowColSpan;lastRowSpan=-1;}var lastColSpan=-1;for(var x=0;x<rows[0].length;x++){var colRowSpan=0;for(var y=0;y<rows.length;y++){var sd=getColRowSpan(rows[y][x]);colRowSpan+=sd['rowspan'];if(lastColSpan!=-1&&sd['colspan']!=lastColSpan){alert("Invalid selection for merge.");return true;}lastColSpan=sd['colspan'];}if(colRowSpan>rowSpan)rowSpan=colRowSpan;lastColSpan=-1;}tdElm=rows[0][0];tdElm.rowSpan=rowSpan;tdElm.colSpan=colSpan;for(var y=0;y<rows.length;y++){for(var x=0;x<rows[y].length;x++){var html=rows[y][x].innerHTML;var chk=html.replace(/[ \t\r\n]/g,"");if(chk!="<br/>"&&chk!="<br>"&&chk!='<br mce_bogus="1"/>'&&(x+y>0))tdElm.innerHTML+=html;if(rows[y][x]!=tdElm&&!rows[y][x]._deleted){var cpos=getCellPos(grid,rows[y][x]);var tr=rows[y][x].parentNode;tr.removeChild(rows[y][x]);rows[y][x]._deleted=true;if(!tr.hasChildNodes()){tr.parentNode.removeChild(tr);var lastCell=null;for(var x=0;cellElm=getCell(grid,cpos.rowindex,x);x++){if(cellElm!=lastCell&&cellElm.rowSpan>1)cellElm.rowSpan--;lastCell=cellElm;}if(tdElm.rowSpan>1)tdElm.rowSpan--;}}}}each(ed.dom.select('br',tdElm),function(e,i){if(i>0&&ed.dom.getAttrib(e,'mce_bogus'))ed.dom.remove(e);});break;}tableElm=inst.dom.getParent(inst.selection.getNode(),"table");inst.addVisual(tableElm);inst.nodeChanged();}return true;}return false;}});tinymce.PluginManager.add('table',tinymce.plugins.TablePlugin);})(); \ No newline at end of file | |||
diff --git a/public/javascripts/tiny_mce/plugins/table/editor_plugin_src.js b/public/javascripts/tiny_mce/plugins/table/editor_plugin_src.js new file mode 100755 index 0000000..80cf748 --- /dev/null +++ b/public/javascripts/tiny_mce/plugins/table/editor_plugin_src.js | |||
| @@ -0,0 +1,1136 @@ | |||
| 1 | /** | ||
| 2 | * $Id: editor_plugin_src.js 953 2008-11-04 10:16:50Z spocke $ | ||
| 3 | * | ||
| 4 | * @author Moxiecode | ||
| 5 | * @copyright Copyright © 2004-2008, Moxiecode Systems AB, All rights reserved. | ||
| 6 | */ | ||
| 7 | |||
| 8 | (function() { | ||
| 9 | var each = tinymce.each; | ||
| 10 | |||
| 11 | tinymce.create('tinymce.plugins.TablePlugin', { | ||
| 12 | init : function(ed, url) { | ||
| 13 | var t = this; | ||
| 14 | |||
| 15 | t.editor = ed; | ||
| 16 | t.url = url; | ||
| 17 | |||
| 18 | // Register buttons | ||
| 19 | each([ | ||
| 20 | ['table', 'table.desc', 'mceInsertTable', true], | ||
| 21 | ['delete_table', 'table.del', 'mceTableDelete'], | ||
| 22 | ['delete_col', 'table.delete_col_desc', 'mceTableDeleteCol'], | ||
| 23 | ['delete_row', 'table.delete_row_desc', 'mceTableDeleteRow'], | ||
| 24 | ['col_after', 'table.col_after_desc', 'mceTableInsertColAfter'], | ||
| 25 | ['col_before', 'table.col_before_desc', 'mceTableInsertColBefore'], | ||
| 26 | ['row_after', 'table.row_after_desc', 'mceTableInsertRowAfter'], | ||
| 27 | ['row_before', 'table.row_before_desc', 'mceTableInsertRowBefore'], | ||
| 28 | ['row_props', 'table.row_desc', 'mceTableRowProps', true], | ||
| 29 | ['cell_props', 'table.cell_desc', 'mceTableCellProps', true], | ||
| 30 | ['split_cells', 'table.split_cells_desc', 'mceTableSplitCells', true], | ||
| 31 | ['merge_cells', 'table.merge_cells_desc', 'mceTableMergeCells', true] | ||
| 32 | ], function(c) { | ||
| 33 | ed.addButton(c[0], {title : c[1], cmd : c[2], ui : c[3]}); | ||
| 34 | }); | ||
| 35 | |||
| 36 | if (ed.getParam('inline_styles')) { | ||
| 37 | // Force move of attribs to styles in strict mode | ||
| 38 | ed.onPreProcess.add(function(ed, o) { | ||
| 39 | var dom = ed.dom; | ||
| 40 | |||
| 41 | each(dom.select('table', o.node), function(n) { | ||
| 42 | var v; | ||
| 43 | |||
| 44 | if (v = dom.getAttrib(n, 'width')) { | ||
| 45 | dom.setStyle(n, 'width', v); | ||
| 46 | dom.setAttrib(n, 'width'); | ||
| 47 | } | ||
| 48 | |||
| 49 | if (v = dom.getAttrib(n, 'height')) { | ||
| 50 | dom.setStyle(n, 'height', v); | ||
| 51 | dom.setAttrib(n, 'height'); | ||
| 52 | } | ||
| 53 | }); | ||
| 54 | }); | ||
| 55 | } | ||
| 56 | |||
| 57 | ed.onInit.add(function() { | ||
| 58 | if (ed && ed.plugins.contextmenu) { | ||
| 59 | ed.plugins.contextmenu.onContextMenu.add(function(th, m, e) { | ||
| 60 | var sm, se = ed.selection, el = se.getNode() || ed.getBody(); | ||
| 61 | |||
| 62 | if (ed.dom.getParent(e, 'td') || ed.dom.getParent(e, 'th')) { | ||
| 63 | m.removeAll(); | ||
| 64 | |||
| 65 | if (el.nodeName == 'A' && !ed.dom.getAttrib(el, 'name')) { | ||
| 66 | m.add({title : 'advanced.link_desc', icon : 'link', cmd : ed.plugins.advlink ? 'mceAdvLink' : 'mceLink', ui : true}); | ||
| 67 | m.add({title : 'advanced.unlink_desc', icon : 'unlink', cmd : 'UnLink'}); | ||
| 68 | m.addSeparator(); | ||
| 69 | } | ||
| 70 | |||
| 71 | if (el.nodeName == 'IMG' && el.className.indexOf('mceItem') == -1) { | ||
| 72 | m.add({title : 'advanced.image_desc', icon : 'image', cmd : ed.plugins.advimage ? 'mceAdvImage' : 'mceImage', ui : true}); | ||
| 73 | m.addSeparator(); | ||
| 74 | } | ||
| 75 | |||
| 76 | m.add({title : 'table.desc', icon : 'table', cmd : 'mceInsertTable', ui : true, value : {action : 'insert'}}); | ||
| 77 | m.add({title : 'table.props_desc', icon : 'table_props', cmd : 'mceInsertTable', ui : true}); | ||
| 78 | m.add({title : 'table.del', icon : 'delete_table', cmd : 'mceTableDelete', ui : true}); | ||
| 79 | m.addSeparator(); | ||
| 80 | |||
| 81 | // Cell menu | ||
| 82 | sm = m.addMenu({title : 'table.cell'}); | ||
| 83 | sm.add({title : 'table.cell_desc', icon : 'cell_props', cmd : 'mceTableCellProps', ui : true}); | ||
| 84 | sm.add({title : 'table.split_cells_desc', icon : 'split_cells', cmd : 'mceTableSplitCells', ui : true}); | ||
| 85 | sm.add({title : 'table.merge_cells_desc', icon : 'merge_cells', cmd : 'mceTableMergeCells', ui : true}); | ||
| 86 | |||
| 87 | // Row menu | ||
| 88 | sm = m.addMenu({title : 'table.row'}); | ||
| 89 | sm.add({title : 'table.row_desc', icon : 'row_props', cmd : 'mceTableRowProps', ui : true}); | ||
| 90 | sm.add({title : 'table.row_before_desc', icon : 'row_before', cmd : 'mceTableInsertRowBefore'}); | ||
| 91 | sm.add({title : 'table.row_after_desc', icon : 'row_after', cmd : 'mceTableInsertRowAfter'}); | ||
| 92 | sm.add({title : 'table.delete_row_desc', icon : 'delete_row', cmd : 'mceTableDeleteRow'}); | ||
| 93 | sm.addSeparator(); | ||
| 94 | sm.add({title : 'table.cut_row_desc', icon : 'cut', cmd : 'mceTableCutRow'}); | ||
| 95 | sm.add({title : 'table.copy_row_desc', icon : 'copy', cmd : 'mceTableCopyRow'}); | ||
| 96 | sm.add({title : 'table.paste_row_before_desc', icon : 'paste', cmd : 'mceTablePasteRowBefore'}); | ||
| 97 | sm.add({title : 'table.paste_row_after_desc', icon : 'paste', cmd : 'mceTablePasteRowAfter'}); | ||
| 98 | |||
| 99 | // Column menu | ||
| 100 | sm = m.addMenu({title : 'table.col'}); | ||
| 101 | sm.add({title : 'table.col_before_desc', icon : 'col_before', cmd : 'mceTableInsertColBefore'}); | ||
| 102 | sm.add({title : 'table.col_after_desc', icon : 'col_after', cmd : 'mceTableInsertColAfter'}); | ||
| 103 | sm.add({title : 'table.delete_col_desc', icon : 'delete_col', cmd : 'mceTableDeleteCol'}); | ||
| 104 | } else | ||
| 105 | m.add({title : 'table.desc', icon : 'table', cmd : 'mceInsertTable', ui : true}); | ||
| 106 | }); | ||
| 107 | } | ||
| 108 | }); | ||
| 109 | |||
| 110 | // Add undo level when new rows are created using the tab key | ||
| 111 | ed.onKeyDown.add(function(ed, e) { | ||
| 112 | if (e.keyCode == 9 && ed.dom.getParent(ed.selection.getNode(), 'TABLE')) { | ||
| 113 | if (!tinymce.isGecko && !tinymce.isOpera) { | ||
| 114 | tinyMCE.execInstanceCommand(ed.editorId, "mceTableMoveToNextRow", true); | ||
| 115 | return tinymce.dom.Event.cancel(e); | ||
| 116 | } | ||
| 117 | |||
| 118 | ed.undoManager.add(); | ||
| 119 | } | ||
| 120 | }); | ||
| 121 | |||
| 122 | // Select whole table is a table border is clicked | ||
| 123 | if (!tinymce.isIE) { | ||
| 124 | if (ed.getParam('table_selection', true)) { | ||
| 125 | ed.onClick.add(function(ed, e) { | ||
| 126 | e = e.target; | ||
| 127 | |||
| 128 | if (e.nodeName === 'TABLE') | ||
| 129 | ed.selection.select(e); | ||
| 130 | }); | ||
| 131 | } | ||
| 132 | } | ||
| 133 | |||
| 134 | ed.onNodeChange.add(function(ed, cm, n) { | ||
| 135 | var p = ed.dom.getParent(n, 'td,th,caption'); | ||
| 136 | |||
| 137 | cm.setActive('table', n.nodeName === 'TABLE' || !!p); | ||
| 138 | if (p && p.nodeName === 'CAPTION') | ||
| 139 | p = null; | ||
| 140 | |||
| 141 | cm.setDisabled('delete_table', !p); | ||
| 142 | cm.setDisabled('delete_col', !p); | ||
| 143 | cm.setDisabled('delete_table', !p); | ||
| 144 | cm.setDisabled('delete_row', !p); | ||
| 145 | cm.setDisabled('col_after', !p); | ||
| 146 | cm.setDisabled('col_before', !p); | ||
| 147 | cm.setDisabled('row_after', !p); | ||
| 148 | cm.setDisabled('row_before', !p); | ||
| 149 | cm.setDisabled('row_props', !p); | ||
| 150 | cm.setDisabled('cell_props', !p); | ||
| 151 | cm.setDisabled('split_cells', !p || (parseInt(ed.dom.getAttrib(p, 'colspan', '1')) < 2 && parseInt(ed.dom.getAttrib(p, 'rowspan', '1')) < 2)); | ||
| 152 | cm.setDisabled('merge_cells', !p); | ||
| 153 | }); | ||
| 154 | |||
| 155 | // Padd empty table cells | ||
| 156 | if (!tinymce.isIE) { | ||
| 157 | ed.onBeforeSetContent.add(function(ed, o) { | ||
| 158 | if (o.initial) | ||
| 159 | o.content = o.content.replace(/<(td|th)([^>]+|)>\s*<\/(td|th)>/g, tinymce.isOpera ? '<$1$2> </$1>' : '<$1$2><br mce_bogus="1" /></$1>'); | ||
| 160 | }); | ||
| 161 | } | ||
| 162 | }, | ||
| 163 | |||
| 164 | execCommand : function(cmd, ui, val) { | ||
| 165 | var ed = this.editor, b; | ||
| 166 | |||
| 167 | // Is table command | ||
| 168 | switch (cmd) { | ||
| 169 | case "mceTableMoveToNextRow": | ||
| 170 | case "mceInsertTable": | ||
| 171 | case "mceTableRowProps": | ||
| 172 | case "mceTableCellProps": | ||
| 173 | case "mceTableSplitCells": | ||
| 174 | case "mceTableMergeCells": | ||
| 175 | case "mceTableInsertRowBefore": | ||
| 176 | case "mceTableInsertRowAfter": | ||
| 177 | case "mceTableDeleteRow": | ||
| 178 | case "mceTableInsertColBefore": | ||
| 179 | case "mceTableInsertColAfter": | ||
| 180 | case "mceTableDeleteCol": | ||
| 181 | case "mceTableCutRow": | ||
| 182 | case "mceTableCopyRow": | ||
| 183 | case "mceTablePasteRowBefore": | ||
| 184 | case "mceTablePasteRowAfter": | ||
| 185 | case "mceTableDelete": | ||
| 186 | ed.execCommand('mceBeginUndoLevel'); | ||
| 187 | this._doExecCommand(cmd, ui, val); | ||
| 188 | ed.execCommand('mceEndUndoLevel'); | ||
| 189 | |||
| 190 | return true; | ||
| 191 | } | ||
| 192 | |||
| 193 | // Pass to next handler in chain | ||
| 194 | return false; | ||
| 195 | }, | ||
| 196 | |||
| 197 | getInfo : function() { | ||
| 198 | return { | ||
| 199 | longname : 'Tables', | ||
| 200 | author : 'Moxiecode Systems AB', | ||
| 201 | authorurl : 'http://tinymce.moxiecode.com', | ||
| 202 | infourl : 'http://wiki.moxiecode.com/index.php/TinyMCE:Plugins/table', | ||
| 203 | version : tinymce.majorVersion + "." + tinymce.minorVersion | ||
| 204 | }; | ||
| 205 | }, | ||
| 206 | |||
| 207 | // Private plugin internal methods | ||
| 208 | |||
| 209 | /** | ||
| 210 | * Executes the table commands. | ||
| 211 | */ | ||
| 212 | _doExecCommand : function(command, user_interface, value) { | ||
| 213 | var inst = this.editor, ed = inst, url = this.url; | ||
| 214 | var focusElm = inst.selection.getNode(); | ||
| 215 | var trElm = inst.dom.getParent(focusElm, "tr"); | ||
| 216 | var tdElm = inst.dom.getParent(focusElm, "td,th"); | ||
| 217 | var tableElm = inst.dom.getParent(focusElm, "table"); | ||
| 218 | var doc = inst.contentWindow.document; | ||
| 219 | var tableBorder = tableElm ? tableElm.getAttribute("border") : ""; | ||
| 220 | |||
| 221 | // Get first TD if no TD found | ||
| 222 | if (trElm && tdElm == null) | ||
| 223 | tdElm = trElm.cells[0]; | ||
| 224 | |||
| 225 | function inArray(ar, v) { | ||
| 226 | for (var i=0; i<ar.length; i++) { | ||
| 227 | // Is array | ||
| 228 | if (ar[i].length > 0 && inArray(ar[i], v)) | ||
| 229 | return true; | ||
| 230 | |||
| 231 | // Found value | ||
| 232 | if (ar[i] == v) | ||
| 233 | return true; | ||
| 234 | } | ||
| 235 | |||
| 236 | return false; | ||
| 237 | } | ||
| 238 | |||
| 239 | function select(dx, dy) { | ||
| 240 | var td; | ||
| 241 | |||
| 242 | grid = getTableGrid(tableElm); | ||
| 243 | dx = dx || 0; | ||
| 244 | dy = dy || 0; | ||
| 245 | dx = Math.max(cpos.cellindex + dx, 0); | ||
| 246 | dy = Math.max(cpos.rowindex + dy, 0); | ||
| 247 | |||
| 248 | // Recalculate grid and select | ||
| 249 | inst.execCommand('mceRepaint'); | ||
| 250 | td = getCell(grid, dy, dx); | ||
| 251 | |||
| 252 | if (td) { | ||
| 253 | inst.selection.select(td.firstChild || td); | ||
| 254 | inst.selection.collapse(1); | ||
| 255 | } | ||
| 256 | }; | ||
| 257 | |||
| 258 | function makeTD() { | ||
| 259 | var newTD = doc.createElement("td"); | ||
| 260 | |||
| 261 | if (!tinymce.isIE) | ||
| 262 | newTD.innerHTML = '<br mce_bogus="1"/>'; | ||
| 263 | } | ||
| 264 | |||
| 265 | function getColRowSpan(td) { | ||
| 266 | var colspan = inst.dom.getAttrib(td, "colspan"); | ||
| 267 | var rowspan = inst.dom.getAttrib(td, "rowspan"); | ||
| 268 | |||
| 269 | colspan = colspan == "" ? 1 : parseInt(colspan); | ||
| 270 | rowspan = rowspan == "" ? 1 : parseInt(rowspan); | ||
| 271 | |||
| 272 | return {colspan : colspan, rowspan : rowspan}; | ||
| 273 | } | ||
| 274 | |||
| 275 | function getCellPos(grid, td) { | ||
| 276 | var x, y; | ||
| 277 | |||
| 278 | for (y=0; y<grid.length; y++) { | ||
| 279 | for (x=0; x<grid[y].length; x++) { | ||
| 280 | if (grid[y][x] == td) | ||
| 281 | return {cellindex : x, rowindex : y}; | ||
| 282 | } | ||
| 283 | } | ||
| 284 | |||
| 285 | return null; | ||
| 286 | } | ||
| 287 | |||
| 288 | function getCell(grid, row, col) { | ||
| 289 | if (grid[row] && grid[row][col]) | ||
| 290 | return grid[row][col]; | ||
| 291 | |||
| 292 | return null; | ||
| 293 | } | ||
| 294 | |||
| 295 | function getNextCell(table, cell) { | ||
| 296 | var cells = [], x = 0, i, j, cell, nextCell; | ||
| 297 | |||
| 298 | for (i = 0; i < table.rows.length; i++) | ||
| 299 | for (j = 0; j < table.rows[i].cells.length; j++, x++) | ||
| 300 | cells[x] = table.rows[i].cells[j]; | ||
| 301 | |||
| 302 | for (i = 0; i < cells.length; i++) | ||
| 303 | if (cells[i] == cell) | ||
| 304 | if (nextCell = cells[i+1]) | ||
| 305 | return nextCell; | ||
| 306 | } | ||
| 307 | |||
| 308 | function getTableGrid(table) { | ||
| 309 | var grid = [], rows = table.rows, x, y, td, sd, xstart, x2, y2; | ||
| 310 | |||
| 311 | for (y=0; y<rows.length; y++) { | ||
| 312 | for (x=0; x<rows[y].cells.length; x++) { | ||
| 313 | td = rows[y].cells[x]; | ||
| 314 | sd = getColRowSpan(td); | ||
| 315 | |||
| 316 | // All ready filled | ||
| 317 | for (xstart = x; grid[y] && grid[y][xstart]; xstart++) ; | ||
| 318 | |||
| 319 | // Fill box | ||
| 320 | for (y2=y; y2<y+sd['rowspan']; y2++) { | ||
| 321 | if (!grid[y2]) | ||
| 322 | grid[y2] = []; | ||
| 323 | |||
| 324 | for (x2=xstart; x2<xstart+sd['colspan']; x2++) | ||
| 325 | grid[y2][x2] = td; | ||
| 326 | } | ||
| 327 | } | ||
| 328 | } | ||
| 329 | |||
| 330 | return grid; | ||
| 331 | } | ||
| 332 | |||
| 333 | function trimRow(table, tr, td, new_tr) { | ||
| 334 | var grid = getTableGrid(table), cpos = getCellPos(grid, td); | ||
| 335 | var cells, lastElm; | ||
| 336 | |||
| 337 | // Time to crop away some | ||
| 338 | if (new_tr.cells.length != tr.childNodes.length) { | ||
| 339 | cells = tr.childNodes; | ||
| 340 | lastElm = null; | ||
| 341 | |||
| 342 | for (var x=0; td = getCell(grid, cpos.rowindex, x); x++) { | ||
| 343 | var remove = true; | ||
| 344 | var sd = getColRowSpan(td); | ||
| 345 | |||
| 346 | // Remove due to rowspan | ||
| 347 | if (inArray(cells, td)) { | ||
| 348 | new_tr.childNodes[x]._delete = true; | ||
| 349 | } else if ((lastElm == null || td != lastElm) && sd.colspan > 1) { // Remove due to colspan | ||
| 350 | for (var i=x; i<x+td.colSpan; i++) | ||
| 351 | new_tr.childNodes[i]._delete = true; | ||
| 352 | } | ||
| 353 | |||
| 354 | if ((lastElm == null || td != lastElm) && sd.rowspan > 1) | ||
| 355 | td.rowSpan = sd.rowspan + 1; | ||
| 356 | |||
| 357 | lastElm = td; | ||
| 358 | } | ||
| 359 | |||
| 360 | deleteMarked(tableElm); | ||
| 361 | } | ||
| 362 | } | ||
| 363 | |||
| 364 | function prevElm(node, name) { | ||
| 365 | while ((node = node.previousSibling) != null) { | ||
| 366 | if (node.nodeName == name) | ||
| 367 | return node; | ||
| 368 | } | ||
| 369 | |||
| 370 | return null; | ||
| 371 | } | ||
| 372 | |||
| 373 | function nextElm(node, names) { | ||
| 374 | var namesAr = names.split(','); | ||
| 375 | |||
| 376 | while ((node = node.nextSibling) != null) { | ||
| 377 | for (var i=0; i<namesAr.length; i++) { | ||
| 378 | if (node.nodeName.toLowerCase() == namesAr[i].toLowerCase() ) | ||
| 379 | return node; | ||
| 380 | } | ||
| 381 | } | ||
| 382 | |||
| 383 | return null; | ||
| 384 | } | ||
| 385 | |||
| 386 | function deleteMarked(tbl) { | ||
| 387 | if (tbl.rows == 0) | ||
| 388 | return; | ||
| 389 | |||
| 390 | var tr = tbl.rows[0]; | ||
| 391 | do { | ||
| 392 | var next = nextElm(tr, "TR"); | ||
| 393 | |||
| 394 | // Delete row | ||
| 395 | if (tr._delete) { | ||
| 396 | tr.parentNode.removeChild(tr); | ||
| 397 | continue; | ||
| 398 | } | ||
| 399 | |||
| 400 | // Delete cells | ||
| 401 | var td = tr.cells[0]; | ||
| 402 | if (td.cells > 1) { | ||
| 403 | do { | ||
| 404 | var nexttd = nextElm(td, "TD,TH"); | ||
| 405 | |||
| 406 | if (td._delete) | ||
| 407 | td.parentNode.removeChild(td); | ||
| 408 | } while ((td = nexttd) != null); | ||
| 409 | } | ||
| 410 | } while ((tr = next) != null); | ||
| 411 | } | ||
| 412 | |||
| 413 | function addRows(td_elm, tr_elm, rowspan) { | ||
| 414 | // Add rows | ||
| 415 | td_elm.rowSpan = 1; | ||
| 416 | var trNext = nextElm(tr_elm, "TR"); | ||
| 417 | for (var i=1; i<rowspan && trNext; i++) { | ||
| 418 | var newTD = doc.createElement("td"); | ||
| 419 | |||
| 420 | if (!tinymce.isIE) | ||
| 421 | newTD.innerHTML = '<br mce_bogus="1"/>'; | ||
| 422 | |||
| 423 | if (tinymce.isIE) | ||
| 424 | trNext.insertBefore(newTD, trNext.cells(td_elm.cellIndex)); | ||
| 425 | else | ||
| 426 | trNext.insertBefore(newTD, trNext.cells[td_elm.cellIndex]); | ||
| 427 | |||
| 428 | trNext = nextElm(trNext, "TR"); | ||
| 429 | } | ||
| 430 | } | ||
| 431 | |||
| 432 | function copyRow(doc, table, tr) { | ||
| 433 | var grid = getTableGrid(table); | ||
| 434 | var newTR = tr.cloneNode(false); | ||
| 435 | var cpos = getCellPos(grid, tr.cells[0]); | ||
| 436 | var lastCell = null; | ||
| 437 | var tableBorder = inst.dom.getAttrib(table, "border"); | ||
| 438 | var tdElm = null; | ||
| 439 | |||
| 440 | for (var x=0; tdElm = getCell(grid, cpos.rowindex, x); x++) { | ||
| 441 | var newTD = null; | ||
| 442 | |||
| 443 | if (lastCell != tdElm) { | ||
| 444 | for (var i=0; i<tr.cells.length; i++) { | ||
| 445 | if (tdElm == tr.cells[i]) { | ||
| 446 | newTD = tdElm.cloneNode(true); | ||
| 447 | break; | ||
| 448 | } | ||
| 449 | } | ||
| 450 | } | ||
| 451 | |||
| 452 | if (newTD == null) { | ||
| 453 | newTD = doc.createElement("td"); | ||
| 454 | |||
| 455 | if (!tinymce.isIE) | ||
| 456 | newTD.innerHTML = '<br mce_bogus="1"/>'; | ||
| 457 | } | ||
| 458 | |||
| 459 | // Reset col/row span | ||
| 460 | newTD.colSpan = 1; | ||
| 461 | newTD.rowSpan = 1; | ||
| 462 | |||
| 463 | newTR.appendChild(newTD); | ||
| 464 | |||
| 465 | lastCell = tdElm; | ||
| 466 | } | ||
| 467 | |||
| 468 | return newTR; | ||
| 469 | } | ||
| 470 | |||
| 471 | // ---- Commands ----- | ||
| 472 | |||
| 473 | // Handle commands | ||
| 474 | switch (command) { | ||
| 475 | case "mceTableMoveToNextRow": | ||
| 476 | var nextCell = getNextCell(tableElm, tdElm); | ||
| 477 | |||
| 478 | if (!nextCell) { | ||
| 479 | inst.execCommand("mceTableInsertRowAfter", tdElm); | ||
| 480 | nextCell = getNextCell(tableElm, tdElm); | ||
| 481 | } | ||
| 482 | |||
| 483 | inst.selection.select(nextCell); | ||
| 484 | inst.selection.collapse(true); | ||
| 485 | |||
| 486 | return true; | ||
| 487 | |||
| 488 | case "mceTableRowProps": | ||
| 489 | if (trElm == null) | ||
| 490 | return true; | ||
| 491 | |||
| 492 | if (user_interface) { | ||
| 493 | inst.windowManager.open({ | ||
| 494 | url : url + '/row.htm', | ||
| 495 | width : 400 + parseInt(inst.getLang('table.rowprops_delta_width', 0)), | ||
| 496 | height : 295 + parseInt(inst.getLang('table.rowprops_delta_height', 0)), | ||
| 497 | inline : 1 | ||
| 498 | }, { | ||
| 499 | plugin_url : url | ||
| 500 | }); | ||
| 501 | } | ||
| 502 | |||
| 503 | return true; | ||
| 504 | |||
| 505 | case "mceTableCellProps": | ||
| 506 | if (tdElm == null) | ||
| 507 | return true; | ||
| 508 | |||
| 509 | if (user_interface) { | ||
| 510 | inst.windowManager.open({ | ||
| 511 | url : url + '/cell.htm', | ||
| 512 | width : 400 + parseInt(inst.getLang('table.cellprops_delta_width', 0)), | ||
| 513 | height : 295 + parseInt(inst.getLang('table.cellprops_delta_height', 0)), | ||
| 514 | inline : 1 | ||
| 515 | }, { | ||
| 516 | plugin_url : url | ||
| 517 | }); | ||
| 518 | } | ||
| 519 | |||
| 520 | return true; | ||
| 521 | |||
| 522 | case "mceInsertTable": | ||
| 523 | if (user_interface) { | ||
| 524 | inst.windowManager.open({ | ||
| 525 | url : url + '/table.htm', | ||
| 526 | width : 400 + parseInt(inst.getLang('table.table_delta_width', 0)), | ||
| 527 | height : 320 + parseInt(inst.getLang('table.table_delta_height', 0)), | ||
| 528 | inline : 1 | ||
| 529 | }, { | ||
| 530 | plugin_url : url, | ||
| 531 | action : value ? value.action : 0 | ||
| 532 | }); | ||
| 533 | } | ||
| 534 | |||
| 535 | return true; | ||
| 536 | |||
| 537 | case "mceTableDelete": | ||
| 538 | var table = inst.dom.getParent(inst.selection.getNode(), "table"); | ||
| 539 | if (table) { | ||
| 540 | table.parentNode.removeChild(table); | ||
| 541 | inst.execCommand('mceRepaint'); | ||
| 542 | } | ||
| 543 | return true; | ||
| 544 | |||
| 545 | case "mceTableSplitCells": | ||
| 546 | case "mceTableMergeCells": | ||
| 547 | case "mceTableInsertRowBefore": | ||
| 548 | case "mceTableInsertRowAfter": | ||
| 549 | case "mceTableDeleteRow": | ||
| 550 | case "mceTableInsertColBefore": | ||
| 551 | case "mceTableInsertColAfter": | ||
| 552 | case "mceTableDeleteCol": | ||
| 553 | case "mceTableCutRow": | ||
| 554 | case "mceTableCopyRow": | ||
| 555 | case "mceTablePasteRowBefore": | ||
| 556 | case "mceTablePasteRowAfter": | ||
| 557 | // No table just return (invalid command) | ||
| 558 | if (!tableElm) | ||
| 559 | return true; | ||
| 560 | |||
| 561 | // Table has a tbody use that reference | ||
| 562 | // Changed logic by ApTest 2005.07.12 (www.aptest.com) | ||
| 563 | // Now lookk at the focused element and take its parentNode. That will be a tbody or a table. | ||
| 564 | if (trElm && tableElm != trElm.parentNode) | ||
| 565 | tableElm = trElm.parentNode; | ||
| 566 | |||
| 567 | if (tableElm && trElm) { | ||
| 568 | switch (command) { | ||
| 569 | case "mceTableCutRow": | ||
| 570 | if (!trElm || !tdElm) | ||
| 571 | return true; | ||
| 572 | |||
| 573 | inst.tableRowClipboard = copyRow(doc, tableElm, trElm); | ||
| 574 | inst.execCommand("mceTableDeleteRow"); | ||
| 575 | break; | ||
| 576 | |||
| 577 | case "mceTableCopyRow": | ||
| 578 | if (!trElm || !tdElm) | ||
| 579 | return true; | ||
| 580 | |||
| 581 | inst.tableRowClipboard = copyRow(doc, tableElm, trElm); | ||
| 582 | break; | ||
| 583 | |||
| 584 | case "mceTablePasteRowBefore": | ||
| 585 | if (!trElm || !tdElm) | ||
| 586 | return true; | ||
| 587 | |||
| 588 | var newTR = inst.tableRowClipboard.cloneNode(true); | ||
| 589 | |||
| 590 | var prevTR = prevElm(trElm, "TR"); | ||
| 591 | if (prevTR != null) | ||
| 592 | trimRow(tableElm, prevTR, prevTR.cells[0], newTR); | ||
| 593 | |||
| 594 | trElm.parentNode.insertBefore(newTR, trElm); | ||
| 595 | break; | ||
| 596 | |||
| 597 | case "mceTablePasteRowAfter": | ||
| 598 | if (!trElm || !tdElm) | ||
| 599 | return true; | ||
| 600 | |||
| 601 | var nextTR = nextElm(trElm, "TR"); | ||
| 602 | var newTR = inst.tableRowClipboard.cloneNode(true); | ||
| 603 | |||
| 604 | trimRow(tableElm, trElm, tdElm, newTR); | ||
| 605 | |||
| 606 | if (nextTR == null) | ||
| 607 | trElm.parentNode.appendChild(newTR); | ||
| 608 | else | ||
| 609 | nextTR.parentNode.insertBefore(newTR, nextTR); | ||
| 610 | |||
| 611 | break; | ||
| 612 | |||
| 613 | case "mceTableInsertRowBefore": | ||
| 614 | if (!trElm || !tdElm) | ||
| 615 | return true; | ||
| 616 | |||
| 617 | var grid = getTableGrid(tableElm); | ||
| 618 | var cpos = getCellPos(grid, tdElm); | ||
| 619 | var newTR = doc.createElement("tr"); | ||
| 620 | var lastTDElm = null; | ||
| 621 | |||
| 622 | cpos.rowindex--; | ||
| 623 | if (cpos.rowindex < 0) | ||
| 624 | cpos.rowindex = 0; | ||
| 625 | |||
| 626 | // Create cells | ||
| 627 | for (var x=0; tdElm = getCell(grid, cpos.rowindex, x); x++) { | ||
| 628 | if (tdElm != lastTDElm) { | ||
| 629 | var sd = getColRowSpan(tdElm); | ||
| 630 | |||
| 631 | if (sd['rowspan'] == 1) { | ||
| 632 | var newTD = doc.createElement("td"); | ||
| 633 | |||
| 634 | if (!tinymce.isIE) | ||
| 635 | newTD.innerHTML = '<br mce_bogus="1"/>'; | ||
| 636 | |||
| 637 | newTD.colSpan = tdElm.colSpan; | ||
| 638 | |||
| 639 | newTR.appendChild(newTD); | ||
| 640 | } else | ||
| 641 | tdElm.rowSpan = sd['rowspan'] + 1; | ||
| 642 | |||
| 643 | lastTDElm = tdElm; | ||
| 644 | } | ||
| 645 | } | ||
| 646 | |||
| 647 | trElm.parentNode.insertBefore(newTR, trElm); | ||
| 648 | select(0, 1); | ||
| 649 | break; | ||
| 650 | |||
| 651 | case "mceTableInsertRowAfter": | ||
| 652 | if (!trElm || !tdElm) | ||
| 653 | return true; | ||
| 654 | |||
| 655 | var grid = getTableGrid(tableElm); | ||
| 656 | var cpos = getCellPos(grid, tdElm); | ||
| 657 | var newTR = doc.createElement("tr"); | ||
| 658 | var lastTDElm = null; | ||
| 659 | |||
| 660 | // Create cells | ||
| 661 | for (var x=0; tdElm = getCell(grid, cpos.rowindex, x); x++) { | ||
| 662 | if (tdElm != lastTDElm) { | ||
| 663 | var sd = getColRowSpan(tdElm); | ||
| 664 | |||
| 665 | if (sd['rowspan'] == 1) { | ||
| 666 | var newTD = doc.createElement("td"); | ||
| 667 | |||
| 668 | if (!tinymce.isIE) | ||
| 669 | newTD.innerHTML = '<br mce_bogus="1"/>'; | ||
| 670 | |||
| 671 | newTD.colSpan = tdElm.colSpan; | ||
| 672 | |||
| 673 | newTR.appendChild(newTD); | ||
| 674 | } else | ||
| 675 | tdElm.rowSpan = sd['rowspan'] + 1; | ||
| 676 | |||
| 677 | lastTDElm = tdElm; | ||
| 678 | } | ||
| 679 | } | ||
| 680 | |||
| 681 | if (newTR.hasChildNodes()) { | ||
| 682 | var nextTR = nextElm(trElm, "TR"); | ||
| 683 | if (nextTR) | ||
| 684 | nextTR.parentNode.insertBefore(newTR, nextTR); | ||
| 685 | else | ||
| 686 | tableElm.appendChild(newTR); | ||
| 687 | } | ||
| 688 | |||
| 689 | select(0, 1); | ||
| 690 | break; | ||
| 691 | |||
| 692 | case "mceTableDeleteRow": | ||
| 693 | if (!trElm || !tdElm) | ||
| 694 | return true; | ||
| 695 | |||
| 696 | var grid = getTableGrid(tableElm); | ||
| 697 | var cpos = getCellPos(grid, tdElm); | ||
| 698 | |||
| 699 | // Only one row, remove whole table | ||
| 700 | if (grid.length == 1 && tableElm.nodeName == 'TBODY') { | ||
| 701 | inst.dom.remove(inst.dom.getParent(tableElm, "table")); | ||
| 702 | return true; | ||
| 703 | } | ||
| 704 | |||
| 705 | // Move down row spanned cells | ||
| 706 | var cells = trElm.cells; | ||
| 707 | var nextTR = nextElm(trElm, "TR"); | ||
| 708 | for (var x=0; x<cells.length; x++) { | ||
| 709 | if (cells[x].rowSpan > 1) { | ||
| 710 | var newTD = cells[x].cloneNode(true); | ||
| 711 | var sd = getColRowSpan(cells[x]); | ||
| 712 | |||
| 713 | newTD.rowSpan = sd.rowspan - 1; | ||
| 714 | |||
| 715 | var nextTD = nextTR.cells[x]; | ||
| 716 | |||
| 717 | if (nextTD == null) | ||
| 718 | nextTR.appendChild(newTD); | ||
| 719 | else | ||
| 720 | nextTR.insertBefore(newTD, nextTD); | ||
| 721 | } | ||
| 722 | } | ||
| 723 | |||
| 724 | // Delete cells | ||
| 725 | var lastTDElm = null; | ||
| 726 | for (var x=0; tdElm = getCell(grid, cpos.rowindex, x); x++) { | ||
| 727 | if (tdElm != lastTDElm) { | ||
| 728 | var sd = getColRowSpan(tdElm); | ||
| 729 | |||
| 730 | if (sd.rowspan > 1) { | ||
| 731 | tdElm.rowSpan = sd.rowspan - 1; | ||
| 732 | } else { | ||
| 733 | trElm = tdElm.parentNode; | ||
| 734 | |||
| 735 | if (trElm.parentNode) | ||
| 736 | trElm._delete = true; | ||
| 737 | } | ||
| 738 | |||
| 739 | lastTDElm = tdElm; | ||
| 740 | } | ||
| 741 | } | ||
| 742 | |||
| 743 | deleteMarked(tableElm); | ||
| 744 | |||
| 745 | select(0, -1); | ||
| 746 | break; | ||
| 747 | |||
| 748 | case "mceTableInsertColBefore": | ||
| 749 | if (!trElm || !tdElm) | ||
| 750 | return true; | ||
| 751 | |||
| 752 | var grid = getTableGrid(inst.dom.getParent(tableElm, "table")); | ||
| 753 | var cpos = getCellPos(grid, tdElm); | ||
| 754 | var lastTDElm = null; | ||
| 755 | |||
| 756 | for (var y=0; tdElm = getCell(grid, y, cpos.cellindex); y++) { | ||
| 757 | if (tdElm != lastTDElm) { | ||
| 758 | var sd = getColRowSpan(tdElm); | ||
| 759 | |||
| 760 | if (sd['colspan'] == 1) { | ||
| 761 | var newTD = doc.createElement(tdElm.nodeName); | ||
| 762 | |||
| 763 | if (!tinymce.isIE) | ||
| 764 | newTD.innerHTML = '<br mce_bogus="1"/>'; | ||
| 765 | |||
| 766 | newTD.rowSpan = tdElm.rowSpan; | ||
| 767 | |||
| 768 | tdElm.parentNode.insertBefore(newTD, tdElm); | ||
| 769 | } else | ||
| 770 | tdElm.colSpan++; | ||
| 771 | |||
| 772 | lastTDElm = tdElm; | ||
| 773 | } | ||
| 774 | } | ||
| 775 | |||
| 776 | select(); | ||
| 777 | break; | ||
| 778 | |||
| 779 | case "mceTableInsertColAfter": | ||
| 780 | if (!trElm || !tdElm) | ||
| 781 | return true; | ||
| 782 | |||
| 783 | var grid = getTableGrid(inst.dom.getParent(tableElm, "table")); | ||
| 784 | var cpos = getCellPos(grid, tdElm); | ||
| 785 | var lastTDElm = null; | ||
| 786 | |||
| 787 | for (var y=0; tdElm = getCell(grid, y, cpos.cellindex); y++) { | ||
| 788 | if (tdElm != lastTDElm) { | ||
| 789 | var sd = getColRowSpan(tdElm); | ||
| 790 | |||
| 791 | if (sd['colspan'] == 1) { | ||
| 792 | var newTD = doc.createElement(tdElm.nodeName); | ||
| 793 | |||
| 794 | if (!tinymce.isIE) | ||
| 795 | newTD.innerHTML = '<br mce_bogus="1"/>'; | ||
| 796 | |||
| 797 | newTD.rowSpan = tdElm.rowSpan; | ||
| 798 | |||
| 799 | var nextTD = nextElm(tdElm, "TD,TH"); | ||
| 800 | if (nextTD == null) | ||
| 801 | tdElm.parentNode.appendChild(newTD); | ||
| 802 | else | ||
| 803 | nextTD.parentNode.insertBefore(newTD, nextTD); | ||
| 804 | } else | ||
| 805 | tdElm.colSpan++; | ||
| 806 | |||
| 807 | lastTDElm = tdElm; | ||
| 808 | } | ||
| 809 | } | ||
| 810 | |||
| 811 | select(1); | ||
| 812 | break; | ||
| 813 | |||
| 814 | case "mceTableDeleteCol": | ||
| 815 | if (!trElm || !tdElm) | ||
| 816 | return true; | ||
| 817 | |||
| 818 | var grid = getTableGrid(tableElm); | ||
| 819 | var cpos = getCellPos(grid, tdElm); | ||
| 820 | var lastTDElm = null; | ||
| 821 | |||
| 822 | // Only one col, remove whole table | ||
| 823 | if ((grid.length > 1 && grid[0].length <= 1) && tableElm.nodeName == 'TBODY') { | ||
| 824 | inst.dom.remove(inst.dom.getParent(tableElm, "table")); | ||
| 825 | return true; | ||
| 826 | } | ||
| 827 | |||
| 828 | // Delete cells | ||
| 829 | for (var y=0; tdElm = getCell(grid, y, cpos.cellindex); y++) { | ||
| 830 | if (tdElm != lastTDElm) { | ||
| 831 | var sd = getColRowSpan(tdElm); | ||
| 832 | |||
| 833 | if (sd['colspan'] > 1) | ||
| 834 | tdElm.colSpan = sd['colspan'] - 1; | ||
| 835 | else { | ||
| 836 | if (tdElm.parentNode) | ||
| 837 | tdElm.parentNode.removeChild(tdElm); | ||
| 838 | } | ||
| 839 | |||
| 840 | lastTDElm = tdElm; | ||
| 841 | } | ||
| 842 | } | ||
| 843 | |||
| 844 | select(-1); | ||
| 845 | break; | ||
| 846 | |||
| 847 | case "mceTableSplitCells": | ||
| 848 | if (!trElm || !tdElm) | ||
| 849 | return true; | ||
| 850 | |||
| 851 | var spandata = getColRowSpan(tdElm); | ||
| 852 | |||
| 853 | var colspan = spandata["colspan"]; | ||
| 854 | var rowspan = spandata["rowspan"]; | ||
| 855 | |||
| 856 | // Needs splitting | ||
| 857 | if (colspan > 1 || rowspan > 1) { | ||
| 858 | // Generate cols | ||
| 859 | tdElm.colSpan = 1; | ||
| 860 | for (var i=1; i<colspan; i++) { | ||
| 861 | var newTD = doc.createElement("td"); | ||
| 862 | |||
| 863 | if (!tinymce.isIE) | ||
| 864 | newTD.innerHTML = '<br mce_bogus="1"/>'; | ||
| 865 | |||
| 866 | trElm.insertBefore(newTD, nextElm(tdElm, "TD,TH")); | ||
| 867 | |||
| 868 | if (rowspan > 1) | ||
| 869 | addRows(newTD, trElm, rowspan); | ||
| 870 | } | ||
| 871 | |||
| 872 | addRows(tdElm, trElm, rowspan); | ||
| 873 | } | ||
| 874 | |||
| 875 | // Apply visual aids | ||
| 876 | tableElm = inst.dom.getParent(inst.selection.getNode(), "table"); | ||
| 877 | break; | ||
| 878 | |||
| 879 | case "mceTableMergeCells": | ||
| 880 | var rows = []; | ||
| 881 | var sel = inst.selection.getSel(); | ||
| 882 | var grid = getTableGrid(tableElm); | ||
| 883 | |||
| 884 | if (tinymce.isIE || sel.rangeCount == 1) { | ||
| 885 | if (user_interface) { | ||
| 886 | // Setup template | ||
| 887 | var sp = getColRowSpan(tdElm); | ||
| 888 | |||
| 889 | inst.windowManager.open({ | ||
| 890 | url : url + '/merge_cells.htm', | ||
| 891 | width : 240 + parseInt(inst.getLang('table.merge_cells_delta_width', 0)), | ||
| 892 | height : 110 + parseInt(inst.getLang('table.merge_cells_delta_height', 0)), | ||
| 893 | inline : 1 | ||
| 894 | }, { | ||
| 895 | action : "update", | ||
| 896 | numcols : sp.colspan, | ||
| 897 | numrows : sp.rowspan, | ||
| 898 | plugin_url : url | ||
| 899 | }); | ||
| 900 | |||
| 901 | return true; | ||
| 902 | } else { | ||
| 903 | var numRows = parseInt(value['numrows']); | ||
| 904 | var numCols = parseInt(value['numcols']); | ||
| 905 | var cpos = getCellPos(grid, tdElm); | ||
| 906 | |||
| 907 | if (("" + numRows) == "NaN") | ||
| 908 | numRows = 1; | ||
| 909 | |||
| 910 | if (("" + numCols) == "NaN") | ||
| 911 | numCols = 1; | ||
| 912 | |||
| 913 | // Get rows and cells | ||
| 914 | var tRows = tableElm.rows; | ||
| 915 | for (var y=cpos.rowindex; y<grid.length; y++) { | ||
| 916 | var rowCells = []; | ||
| 917 | |||
| 918 | for (var x=cpos.cellindex; x<grid[y].length; x++) { | ||
| 919 | var td = getCell(grid, y, x); | ||
| 920 | |||
| 921 | if (td && !inArray(rows, td) && !inArray(rowCells, td)) { | ||
| 922 | var cp = getCellPos(grid, td); | ||
| 923 | |||
| 924 | // Within range | ||
| 925 | if (cp.cellindex < cpos.cellindex+numCols && cp.rowindex < cpos.rowindex+numRows) | ||
| 926 | rowCells[rowCells.length] = td; | ||
| 927 | } | ||
| 928 | } | ||
| 929 | |||
| 930 | if (rowCells.length > 0) | ||
| 931 | rows[rows.length] = rowCells; | ||
| 932 | |||
| 933 | var td = getCell(grid, cpos.rowindex, cpos.cellindex); | ||
| 934 | each(ed.dom.select('br', td), function(e, i) { | ||
| 935 | if (i > 0 && ed.dom.getAttrib('mce_bogus')) | ||
| 936 | ed.dom.remove(e); | ||
| 937 | }); | ||
| 938 | } | ||
| 939 | |||
| 940 | //return true; | ||
| 941 | } | ||
| 942 | } else { | ||
| 943 | var cells = []; | ||
| 944 | var sel = inst.selection.getSel(); | ||
| 945 | var lastTR = null; | ||
| 946 | var curRow = null; | ||
| 947 | var x1 = -1, y1 = -1, x2, y2; | ||
| 948 | |||
| 949 | // Only one cell selected, whats the point? | ||
| 950 | if (sel.rangeCount < 2) | ||
| 951 | return true; | ||
| 952 | |||
| 953 | // Get all selected cells | ||
| 954 | for (var i=0; i<sel.rangeCount; i++) { | ||
| 955 | var rng = sel.getRangeAt(i); | ||
| 956 | var tdElm = rng.startContainer.childNodes[rng.startOffset]; | ||
| 957 | |||
| 958 | if (!tdElm) | ||
| 959 | break; | ||
| 960 | |||
| 961 | if (tdElm.nodeName == "TD" || tdElm.nodeName == "TH") | ||
| 962 | cells[cells.length] = tdElm; | ||
| 963 | } | ||
| 964 | |||
| 965 | // Get rows and cells | ||
| 966 | var tRows = tableElm.rows; | ||
| 967 | for (var y=0; y<tRows.length; y++) { | ||
| 968 | var rowCells = []; | ||
| 969 | |||
| 970 | for (var x=0; x<tRows[y].cells.length; x++) { | ||
| 971 | var td = tRows[y].cells[x]; | ||
| 972 | |||
| 973 | for (var i=0; i<cells.length; i++) { | ||
| 974 | if (td == cells[i]) { | ||
| 975 | rowCells[rowCells.length] = td; | ||
| 976 | } | ||
| 977 | } | ||
| 978 | } | ||
| 979 | |||
| 980 | if (rowCells.length > 0) | ||
| 981 | rows[rows.length] = rowCells; | ||
| 982 | } | ||
| 983 | |||
| 984 | // Find selected cells in grid and box | ||
| 985 | var curRow = []; | ||
| 986 | var lastTR = null; | ||
| 987 | for (var y=0; y<grid.length; y++) { | ||
| 988 | for (var x=0; x<grid[y].length; x++) { | ||
| 989 | grid[y][x]._selected = false; | ||
| 990 | |||
| 991 | for (var i=0; i<cells.length; i++) { | ||
| 992 | if (grid[y][x] == cells[i]) { | ||
| 993 | // Get start pos | ||
| 994 | if (x1 == -1) { | ||
| 995 | x1 = x; | ||
| 996 | y1 = y; | ||
| 997 | } | ||
| 998 | |||
| 999 | // Get end pos | ||
| 1000 | x2 = x; | ||
| 1001 | y2 = y; | ||
| 1002 | |||
| 1003 | grid[y][x]._selected = true; | ||
| 1004 | } | ||
| 1005 | } | ||
| 1006 | } | ||
| 1007 | } | ||
| 1008 | |||
| 1009 | // Is there gaps, if so deny | ||
| 1010 | for (var y=y1; y<=y2; y++) { | ||
| 1011 | for (var x=x1; x<=x2; x++) { | ||
| 1012 | if (!grid[y][x]._selected) { | ||
| 1013 | alert("Invalid selection for merge."); | ||
| 1014 | return true; | ||
| 1015 | } | ||
| 1016 | } | ||
| 1017 | } | ||
| 1018 | } | ||
| 1019 | |||
| 1020 | // Validate selection and get total rowspan and colspan | ||
| 1021 | var rowSpan = 1, colSpan = 1; | ||
| 1022 | |||
| 1023 | // Validate horizontal and get total colspan | ||
| 1024 | var lastRowSpan = -1; | ||
| 1025 | for (var y=0; y<rows.length; y++) { | ||
| 1026 | var rowColSpan = 0; | ||
| 1027 | |||
| 1028 | for (var x=0; x<rows[y].length; x++) { | ||
| 1029 | var sd = getColRowSpan(rows[y][x]); | ||
| 1030 | |||
| 1031 | rowColSpan += sd['colspan']; | ||
| 1032 | |||
| 1033 | if (lastRowSpan != -1 && sd['rowspan'] != lastRowSpan) { | ||
| 1034 | alert("Invalid selection for merge."); | ||
| 1035 | return true; | ||
| 1036 | } | ||
| 1037 | |||
| 1038 | lastRowSpan = sd['rowspan']; | ||
| 1039 | } | ||
| 1040 | |||
| 1041 | if (rowColSpan > colSpan) | ||
| 1042 | colSpan = rowColSpan; | ||
| 1043 | |||
| 1044 | lastRowSpan = -1; | ||
| 1045 | } | ||
| 1046 | |||
| 1047 | // Validate vertical and get total rowspan | ||
| 1048 | var lastColSpan = -1; | ||
| 1049 | for (var x=0; x<rows[0].length; x++) { | ||
| 1050 | var colRowSpan = 0; | ||
| 1051 | |||
| 1052 | for (var y=0; y<rows.length; y++) { | ||
| 1053 | var sd = getColRowSpan(rows[y][x]); | ||
| 1054 | |||
| 1055 | colRowSpan += sd['rowspan']; | ||
| 1056 | |||
| 1057 | if (lastColSpan != -1 && sd['colspan'] != lastColSpan) { | ||
| 1058 | alert("Invalid selection for merge."); | ||
| 1059 | return true; | ||
| 1060 | } | ||
| 1061 | |||
| 1062 | lastColSpan = sd['colspan']; | ||
| 1063 | } | ||
| 1064 | |||
| 1065 | if (colRowSpan > rowSpan) | ||
| 1066 | rowSpan = colRowSpan; | ||
| 1067 | |||
| 1068 | lastColSpan = -1; | ||
| 1069 | } | ||
| 1070 | |||
| 1071 | // Setup td | ||
| 1072 | tdElm = rows[0][0]; | ||
| 1073 | tdElm.rowSpan = rowSpan; | ||
| 1074 | tdElm.colSpan = colSpan; | ||
| 1075 | |||
| 1076 | // Merge cells | ||
| 1077 | for (var y=0; y<rows.length; y++) { | ||
| 1078 | for (var x=0; x<rows[y].length; x++) { | ||
| 1079 | var html = rows[y][x].innerHTML; | ||
| 1080 | var chk = html.replace(/[ \t\r\n]/g, ""); | ||
| 1081 | |||
| 1082 | if (chk != "<br/>" && chk != "<br>" && chk != '<br mce_bogus="1"/>' && (x+y > 0)) | ||
| 1083 | tdElm.innerHTML += html; | ||
| 1084 | |||
| 1085 | // Not current cell | ||
| 1086 | if (rows[y][x] != tdElm && !rows[y][x]._deleted) { | ||
| 1087 | var cpos = getCellPos(grid, rows[y][x]); | ||
| 1088 | var tr = rows[y][x].parentNode; | ||
| 1089 | |||
| 1090 | tr.removeChild(rows[y][x]); | ||
| 1091 | rows[y][x]._deleted = true; | ||
| 1092 | |||
| 1093 | // Empty TR, remove it | ||
| 1094 | if (!tr.hasChildNodes()) { | ||
| 1095 | tr.parentNode.removeChild(tr); | ||
| 1096 | |||
| 1097 | var lastCell = null; | ||
| 1098 | for (var x=0; cellElm = getCell(grid, cpos.rowindex, x); x++) { | ||
| 1099 | if (cellElm != lastCell && cellElm.rowSpan > 1) | ||
| 1100 | cellElm.rowSpan--; | ||
| 1101 | |||
| 1102 | lastCell = cellElm; | ||
| 1103 | } | ||
| 1104 | |||
| 1105 | if (tdElm.rowSpan > 1) | ||
| 1106 | tdElm.rowSpan--; | ||
| 1107 | } | ||
| 1108 | } | ||
| 1109 | } | ||
| 1110 | } | ||
| 1111 | |||
| 1112 | // Remove all but one bogus br | ||
| 1113 | each(ed.dom.select('br', tdElm), function(e, i) { | ||
| 1114 | if (i > 0 && ed.dom.getAttrib(e, 'mce_bogus')) | ||
| 1115 | ed.dom.remove(e); | ||
| 1116 | }); | ||
| 1117 | |||
| 1118 | break; | ||
| 1119 | } | ||
| 1120 | |||
| 1121 | tableElm = inst.dom.getParent(inst.selection.getNode(), "table"); | ||
| 1122 | inst.addVisual(tableElm); | ||
| 1123 | inst.nodeChanged(); | ||
| 1124 | } | ||
| 1125 | |||
| 1126 | return true; | ||
| 1127 | } | ||
| 1128 | |||
| 1129 | // Pass to next handler in chain | ||
| 1130 | return false; | ||
| 1131 | } | ||
| 1132 | }); | ||
| 1133 | |||
| 1134 | // Register plugin | ||
| 1135 | tinymce.PluginManager.add('table', tinymce.plugins.TablePlugin); | ||
| 1136 | })(); \ No newline at end of file | ||
diff --git a/public/javascripts/tiny_mce/plugins/table/js/cell.js b/public/javascripts/tiny_mce/plugins/table/js/cell.js new file mode 100755 index 0000000..f23b067 --- /dev/null +++ b/public/javascripts/tiny_mce/plugins/table/js/cell.js | |||
| @@ -0,0 +1,269 @@ | |||
| 1 | tinyMCEPopup.requireLangPack(); | ||
| 2 | |||
| 3 | var ed; | ||
| 4 | |||
| 5 | function init() { | ||
| 6 | ed = tinyMCEPopup.editor; | ||
| 7 | tinyMCEPopup.resizeToInnerSize(); | ||
| 8 | |||
| 9 | document.getElementById('backgroundimagebrowsercontainer').innerHTML = getBrowserHTML('backgroundimagebrowser','backgroundimage','image','table'); | ||
| 10 | document.getElementById('bordercolor_pickcontainer').innerHTML = getColorPickerHTML('bordercolor_pick','bordercolor'); | ||
| 11 | document.getElementById('bgcolor_pickcontainer').innerHTML = getColorPickerHTML('bgcolor_pick','bgcolor') | ||
| 12 | |||
| 13 | var inst = ed; | ||
| 14 | var tdElm = ed.dom.getParent(ed.selection.getNode(), "td,th"); | ||
| 15 | var formObj = document.forms[0]; | ||
| 16 | var st = ed.dom.parseStyle(ed.dom.getAttrib(tdElm, "style")); | ||
| 17 | |||
| 18 | // Get table cell data | ||
| 19 | var celltype = tdElm.nodeName.toLowerCase(); | ||
| 20 | var align = ed.dom.getAttrib(tdElm, 'align'); | ||
| 21 | var valign = ed.dom.getAttrib(tdElm, 'valign'); | ||
| 22 | var width = trimSize(getStyle(tdElm, 'width', 'width')); | ||
| 23 | var height = trimSize(getStyle(tdElm, 'height', 'height')); | ||
| 24 | var bordercolor = convertRGBToHex(getStyle(tdElm, 'bordercolor', 'borderLeftColor')); | ||
| 25 | var bgcolor = convertRGBToHex(getStyle(tdElm, 'bgcolor', 'backgroundColor')); | ||
| 26 | var className = ed.dom.getAttrib(tdElm, 'class'); | ||
| 27 | var backgroundimage = getStyle(tdElm, 'background', 'backgroundImage').replace(new RegExp("url\\('?([^']*)'?\\)", 'gi'), "$1");; | ||
| 28 | var id = ed.dom.getAttrib(tdElm, 'id'); | ||
| 29 | var lang = ed.dom.getAttrib(tdElm, 'lang'); | ||
| 30 | var dir = ed.dom.getAttrib(tdElm, 'dir'); | ||
| 31 | var scope = ed.dom.getAttrib(tdElm, 'scope'); | ||
| 32 | |||
| 33 | // Setup form | ||
| 34 | addClassesToList('class', 'table_cell_styles'); | ||
| 35 | TinyMCE_EditableSelects.init(); | ||
| 36 | |||
| 37 | formObj.bordercolor.value = bordercolor; | ||
| 38 | formObj.bgcolor.value = bgcolor; | ||
| 39 | formObj.backgroundimage.value = backgroundimage; | ||
| 40 | formObj.width.value = width; | ||
| 41 | formObj.height.value = height; | ||
| 42 | formObj.id.value = id; | ||
| 43 | formObj.lang.value = lang; | ||
| 44 | formObj.style.value = ed.dom.serializeStyle(st); | ||
| 45 | selectByValue(formObj, 'align', align); | ||
| 46 | selectByValue(formObj, 'valign', valign); | ||
| 47 | selectByValue(formObj, 'class', className, true, true); | ||
| 48 | selectByValue(formObj, 'celltype', celltype); | ||
| 49 | selectByValue(formObj, 'dir', dir); | ||
| 50 | selectByValue(formObj, 'scope', scope); | ||
| 51 | |||
| 52 | // Resize some elements | ||
| 53 | if (isVisible('backgroundimagebrowser')) | ||
| 54 | document.getElementById('backgroundimage').style.width = '180px'; | ||
| 55 | |||
| 56 | updateColor('bordercolor_pick', 'bordercolor'); | ||
| 57 | updateColor('bgcolor_pick', 'bgcolor'); | ||
| 58 | } | ||
| 59 | |||
| 60 | function updateAction() { | ||
| 61 | var el, inst = ed, tdElm, trElm, tableElm, formObj = document.forms[0]; | ||
| 62 | |||
| 63 | tinyMCEPopup.restoreSelection(); | ||
| 64 | el = ed.selection.getNode(); | ||
| 65 | tdElm = ed.dom.getParent(el, "td,th"); | ||
| 66 | trElm = ed.dom.getParent(el, "tr"); | ||
| 67 | tableElm = ed.dom.getParent(el, "table"); | ||
| 68 | |||
| 69 | ed.execCommand('mceBeginUndoLevel'); | ||
| 70 | |||
| 71 | switch (getSelectValue(formObj, 'action')) { | ||
| 72 | case "cell": | ||
| 73 | var celltype = getSelectValue(formObj, 'celltype'); | ||
| 74 | var scope = getSelectValue(formObj, 'scope'); | ||
| 75 | |||
| 76 | function doUpdate(s) { | ||
| 77 | if (s) { | ||
| 78 | updateCell(tdElm); | ||
| 79 | |||
| 80 | ed.addVisual(); | ||
| 81 | ed.nodeChanged(); | ||
| 82 | inst.execCommand('mceEndUndoLevel'); | ||
| 83 | tinyMCEPopup.close(); | ||
| 84 | } | ||
| 85 | }; | ||
| 86 | |||
| 87 | if (ed.getParam("accessibility_warnings", 1)) { | ||
| 88 | if (celltype == "th" && scope == "") | ||
| 89 | tinyMCEPopup.confirm(ed.getLang('table_dlg.missing_scope', '', true), doUpdate); | ||
| 90 | else | ||
| 91 | doUpdate(1); | ||
| 92 | |||
| 93 | return; | ||
| 94 | } | ||
| 95 | |||
| 96 | updateCell(tdElm); | ||
| 97 | break; | ||
| 98 | |||
| 99 | case "row": | ||
| 100 | var cell = trElm.firstChild; | ||
| 101 | |||
| 102 | if (cell.nodeName != "TD" && cell.nodeName != "TH") | ||
| 103 | cell = nextCell(cell); | ||
| 104 | |||
| 105 | do { | ||
| 106 | cell = updateCell(cell, true); | ||
| 107 | } while ((cell = nextCell(cell)) != null); | ||
| 108 | |||
| 109 | break; | ||
| 110 | |||
| 111 | case "all": | ||
| 112 | var rows = tableElm.getElementsByTagName("tr"); | ||
| 113 | |||
| 114 | for (var i=0; i<rows.length; i++) { | ||
| 115 | var cell = rows[i].firstChild; | ||
| 116 | |||
| 117 | if (cell.nodeName != "TD" && cell.nodeName != "TH") | ||
| 118 | cell = nextCell(cell); | ||
| 119 | |||
| 120 | do { | ||
| 121 | cell = updateCell(cell, true); | ||
| 122 | } while ((cell = nextCell(cell)) != null); | ||
| 123 | } | ||
| 124 | |||
| 125 | break; | ||
| 126 | } | ||
| 127 | |||
| 128 | ed.addVisual(); | ||
| 129 | ed.nodeChanged(); | ||
| 130 | inst.execCommand('mceEndUndoLevel'); | ||
| 131 | tinyMCEPopup.close(); | ||
| 132 | } | ||
| 133 | |||
| 134 | function nextCell(elm) { | ||
| 135 | while ((elm = elm.nextSibling) != null) { | ||
| 136 | if (elm.nodeName == "TD" || elm.nodeName == "TH") | ||
| 137 | return elm; | ||
| 138 | } | ||
| 139 | |||
| 140 | return null; | ||
| 141 | } | ||
| 142 | |||
| 143 | function updateCell(td, skip_id) { | ||
| 144 | var inst = ed; | ||
| 145 | var formObj = document.forms[0]; | ||
| 146 | var curCellType = td.nodeName.toLowerCase(); | ||
| 147 | var celltype = getSelectValue(formObj, 'celltype'); | ||
| 148 | var doc = inst.getDoc(); | ||
| 149 | var dom = ed.dom; | ||
| 150 | |||
| 151 | if (!skip_id) | ||
| 152 | td.setAttribute('id', formObj.id.value); | ||
| 153 | |||
| 154 | td.setAttribute('align', formObj.align.value); | ||
| 155 | td.setAttribute('vAlign', formObj.valign.value); | ||
| 156 | td.setAttribute('lang', formObj.lang.value); | ||
| 157 | td.setAttribute('dir', getSelectValue(formObj, 'dir')); | ||
| 158 | td.setAttribute('style', ed.dom.serializeStyle(ed.dom.parseStyle(formObj.style.value))); | ||
| 159 | td.setAttribute('scope', formObj.scope.value); | ||
| 160 | ed.dom.setAttrib(td, 'class', getSelectValue(formObj, 'class')); | ||
| 161 | |||
| 162 | // Clear deprecated attributes | ||
| 163 | ed.dom.setAttrib(td, 'width', ''); | ||
| 164 | ed.dom.setAttrib(td, 'height', ''); | ||
| 165 | ed.dom.setAttrib(td, 'bgColor', ''); | ||
| 166 | ed.dom.setAttrib(td, 'borderColor', ''); | ||
| 167 | ed.dom.setAttrib(td, 'background', ''); | ||
| 168 | |||
| 169 | // Set styles | ||
| 170 | td.style.width = getCSSSize(formObj.width.value); | ||
| 171 | td.style.height = getCSSSize(formObj.height.value); | ||
| 172 | if (formObj.bordercolor.value != "") { | ||
| 173 | td.style.borderColor = formObj.bordercolor.value; | ||
| 174 | td.style.borderStyle = td.style.borderStyle == "" ? "solid" : td.style.borderStyle; | ||
| 175 | td.style.borderWidth = td.style.borderWidth == "" ? "1px" : td.style.borderWidth; | ||
| 176 | } else | ||
| 177 | td.style.borderColor = ''; | ||
| 178 | |||
| 179 | td.style.backgroundColor = formObj.bgcolor.value; | ||
| 180 | |||
| 181 | if (formObj.backgroundimage.value != "") | ||
| 182 | td.style.backgroundImage = "url('" + formObj.backgroundimage.value + "')"; | ||
| 183 | else | ||
| 184 | td.style.backgroundImage = ''; | ||
| 185 | |||
| 186 | if (curCellType != celltype) { | ||
| 187 | // changing to a different node type | ||
| 188 | var newCell = doc.createElement(celltype); | ||
| 189 | |||
| 190 | for (var c=0; c<td.childNodes.length; c++) | ||
| 191 | newCell.appendChild(td.childNodes[c].cloneNode(1)); | ||
| 192 | |||
| 193 | for (var a=0; a<td.attributes.length; a++) | ||
| 194 | ed.dom.setAttrib(newCell, td.attributes[a].name, ed.dom.getAttrib(td, td.attributes[a].name)); | ||
| 195 | |||
| 196 | td.parentNode.replaceChild(newCell, td); | ||
| 197 | td = newCell; | ||
| 198 | } | ||
| 199 | |||
| 200 | dom.setAttrib(td, 'style', dom.serializeStyle(dom.parseStyle(td.style.cssText))); | ||
| 201 | |||
| 202 | return td; | ||
| 203 | } | ||
| 204 | |||
| 205 | function changedBackgroundImage() { | ||
| 206 | var formObj = document.forms[0]; | ||
| 207 | var st = ed.dom.parseStyle(formObj.style.value); | ||
| 208 | |||
| 209 | st['background-image'] = "url('" + formObj.backgroundimage.value + "')"; | ||
| 210 | |||
| 211 | formObj.style.value = ed.dom.serializeStyle(st); | ||
| 212 | } | ||
| 213 | |||
| 214 | function changedSize() { | ||
| 215 | var formObj = document.forms[0]; | ||
| 216 | var st = ed.dom.parseStyle(formObj.style.value); | ||
| 217 | |||
| 218 | var width = formObj.width.value; | ||
| 219 | if (width != "") | ||
| 220 | st['width'] = getCSSSize(width); | ||
| 221 | else | ||
| 222 | st['width'] = ""; | ||
| 223 | |||
| 224 | var height = formObj.height.value; | ||
| 225 | if (height != "") | ||
| 226 | st['height'] = getCSSSize(height); | ||
| 227 | else | ||
| 228 | st['height'] = ""; | ||
| 229 | |||
| 230 | formObj.style.value = ed.dom.serializeStyle(st); | ||
| 231 | } | ||
| 232 | |||
| 233 | function changedColor() { | ||
| 234 | var formObj = document.forms[0]; | ||
| 235 | var st = ed.dom.parseStyle(formObj.style.value); | ||
| 236 | |||
| 237 | st['background-color'] = formObj.bgcolor.value; | ||
| 238 | st['border-color'] = formObj.bordercolor.value; | ||
| 239 | |||
| 240 | formObj.style.value = ed.dom.serializeStyle(st); | ||
| 241 | } | ||
| 242 | |||
| 243 | function changedStyle() { | ||
| 244 | var formObj = document.forms[0]; | ||
| 245 | var st = ed.dom.parseStyle(formObj.style.value); | ||
| 246 | |||
| 247 | if (st['background-image']) | ||
| 248 | formObj.backgroundimage.value = st['background-image'].replace(new RegExp("url\\('?([^']*)'?\\)", 'gi'), "$1"); | ||
| 249 | else | ||
| 250 | formObj.backgroundimage.value = ''; | ||
| 251 | |||
| 252 | if (st['width']) | ||
| 253 | formObj.width.value = trimSize(st['width']); | ||
| 254 | |||
| 255 | if (st['height']) | ||
| 256 | formObj.height.value = trimSize(st['height']); | ||
| 257 | |||
| 258 | if (st['background-color']) { | ||
| 259 | formObj.bgcolor.value = st['background-color']; | ||
| 260 | updateColor('bgcolor_pick','bgcolor'); | ||
| 261 | } | ||
| 262 | |||
| 263 | if (st['border-color']) { | ||
| 264 | formObj.bordercolor.value = st['border-color']; | ||
| 265 | updateColor('bordercolor_pick','bordercolor'); | ||
| 266 | } | ||
| 267 | } | ||
| 268 | |||
| 269 | tinyMCEPopup.onInit.add(init); | ||
diff --git a/public/javascripts/tiny_mce/plugins/table/js/merge_cells.js b/public/javascripts/tiny_mce/plugins/table/js/merge_cells.js new file mode 100755 index 0000000..31d6df0 --- /dev/null +++ b/public/javascripts/tiny_mce/plugins/table/js/merge_cells.js | |||
| @@ -0,0 +1,29 @@ | |||
| 1 | tinyMCEPopup.requireLangPack(); | ||
| 2 | |||
| 3 | function init() { | ||
| 4 | var f = document.forms[0], v; | ||
| 5 | |||
| 6 | tinyMCEPopup.resizeToInnerSize(); | ||
| 7 | |||
| 8 | f.numcols.value = tinyMCEPopup.getWindowArg('numcols', 1); | ||
| 9 | f.numrows.value = tinyMCEPopup.getWindowArg('numrows', 1); | ||
| 10 | } | ||
| 11 | |||
| 12 | function mergeCells() { | ||
| 13 | var args = [], f = document.forms[0]; | ||
| 14 | |||
| 15 | tinyMCEPopup.restoreSelection(); | ||
| 16 | |||
| 17 | if (!AutoValidator.validate(f)) { | ||
| 18 | tinyMCEPopup.alert(tinyMCEPopup.getLang('invalid_data')); | ||
| 19 | return false; | ||
| 20 | } | ||
| 21 | |||
| 22 | args["numcols"] = f.numcols.value; | ||
| 23 | args["numrows"] = f.numrows.value; | ||
| 24 | |||
| 25 | tinyMCEPopup.execCommand("mceTableMergeCells", false, args); | ||
| 26 | tinyMCEPopup.close(); | ||
| 27 | } | ||
| 28 | |||
| 29 | tinyMCEPopup.onInit.add(init); | ||
diff --git a/public/javascripts/tiny_mce/plugins/table/js/row.js b/public/javascripts/tiny_mce/plugins/table/js/row.js new file mode 100755 index 0000000..d25f635 --- /dev/null +++ b/public/javascripts/tiny_mce/plugins/table/js/row.js | |||
| @@ -0,0 +1,212 @@ | |||
| 1 | tinyMCEPopup.requireLangPack(); | ||
| 2 | |||
| 3 | function init() { | ||
| 4 | tinyMCEPopup.resizeToInnerSize(); | ||
| 5 | |||
| 6 | document.getElementById('backgroundimagebrowsercontainer').innerHTML = getBrowserHTML('backgroundimagebrowser','backgroundimage','image','table'); | ||
| 7 | document.getElementById('bgcolor_pickcontainer').innerHTML = getColorPickerHTML('bgcolor_pick','bgcolor'); | ||
| 8 | |||
| 9 | var inst = tinyMCEPopup.editor; | ||
| 10 | var dom = inst.dom; | ||
| 11 | var trElm = dom.getParent(inst.selection.getNode(), "tr"); | ||
| 12 | var formObj = document.forms[0]; | ||
| 13 | var st = dom.parseStyle(dom.getAttrib(trElm, "style")); | ||
| 14 | |||
| 15 | // Get table row data | ||
| 16 | var rowtype = trElm.parentNode.nodeName.toLowerCase(); | ||
| 17 | var align = dom.getAttrib(trElm, 'align'); | ||
| 18 | var valign = dom.getAttrib(trElm, 'valign'); | ||
| 19 | var height = trimSize(getStyle(trElm, 'height', 'height')); | ||
| 20 | var className = dom.getAttrib(trElm, 'class'); | ||
| 21 | var bgcolor = convertRGBToHex(getStyle(trElm, 'bgcolor', 'backgroundColor')); | ||
| 22 | var backgroundimage = getStyle(trElm, 'background', 'backgroundImage').replace(new RegExp("url\\('?([^']*)'?\\)", 'gi'), "$1");; | ||
| 23 | var id = dom.getAttrib(trElm, 'id'); | ||
| 24 | var lang = dom.getAttrib(trElm, 'lang'); | ||
| 25 | var dir = dom.getAttrib(trElm, 'dir'); | ||
| 26 | |||
| 27 | // Setup form | ||
| 28 | addClassesToList('class', 'table_row_styles'); | ||
| 29 | TinyMCE_EditableSelects.init(); | ||
| 30 | |||
| 31 | formObj.bgcolor.value = bgcolor; | ||
| 32 | formObj.backgroundimage.value = backgroundimage; | ||
| 33 | formObj.height.value = height; | ||
| 34 | formObj.id.value = id; | ||
| 35 | formObj.lang.value = lang; | ||
| 36 | formObj.style.value = dom.serializeStyle(st); | ||
| 37 | selectByValue(formObj, 'align', align); | ||
| 38 | selectByValue(formObj, 'valign', valign); | ||
| 39 | selectByValue(formObj, 'class', className, true, true); | ||
| 40 | selectByValue(formObj, 'rowtype', rowtype); | ||
| 41 | selectByValue(formObj, 'dir', dir); | ||
| 42 | |||
| 43 | // Resize some elements | ||
| 44 | if (isVisible('backgroundimagebrowser')) | ||
| 45 | document.getElementById('backgroundimage').style.width = '180px'; | ||
| 46 | |||
| 47 | updateColor('bgcolor_pick', 'bgcolor'); | ||
| 48 | } | ||
| 49 | |||
| 50 | function updateAction() { | ||
| 51 | var inst = tinyMCEPopup.editor, dom = inst.dom, trElm, tableElm, formObj = document.forms[0]; | ||
| 52 | var action = getSelectValue(formObj, 'action'); | ||
| 53 | |||
| 54 | tinyMCEPopup.restoreSelection(); | ||
| 55 | trElm = dom.getParent(inst.selection.getNode(), "tr"); | ||
| 56 | tableElm = dom.getParent(inst.selection.getNode(), "table"); | ||
| 57 | |||
| 58 | inst.execCommand('mceBeginUndoLevel'); | ||
| 59 | |||
| 60 | switch (action) { | ||
| 61 | case "row": | ||
| 62 | updateRow(trElm); | ||
| 63 | break; | ||
| 64 | |||
| 65 | case "all": | ||
| 66 | var rows = tableElm.getElementsByTagName("tr"); | ||
| 67 | |||
| 68 | for (var i=0; i<rows.length; i++) | ||
| 69 | updateRow(rows[i], true); | ||
| 70 | |||
| 71 | break; | ||
| 72 | |||
| 73 | case "odd": | ||
| 74 | case "even": | ||
| 75 | var rows = tableElm.getElementsByTagName("tr"); | ||
| 76 | |||
| 77 | for (var i=0; i<rows.length; i++) { | ||
| 78 | if ((i % 2 == 0 && action == "odd") || (i % 2 != 0 && action == "even")) | ||
| 79 | updateRow(rows[i], true, true); | ||
| 80 | } | ||
| 81 | |||
| 82 | break; | ||
| 83 | } | ||
| 84 | |||
| 85 | inst.addVisual(); | ||
| 86 | inst.nodeChanged(); | ||
| 87 | inst.execCommand('mceEndUndoLevel'); | ||
| 88 | tinyMCEPopup.close(); | ||
| 89 | } | ||
| 90 | |||
| 91 | function updateRow(tr_elm, skip_id, skip_parent) { | ||
| 92 | var inst = tinyMCEPopup.editor; | ||
| 93 | var formObj = document.forms[0]; | ||
| 94 | var dom = inst.dom; | ||
| 95 | var curRowType = tr_elm.parentNode.nodeName.toLowerCase(); | ||
| 96 | var rowtype = getSelectValue(formObj, 'rowtype'); | ||
| 97 | var doc = inst.getDoc(); | ||
| 98 | |||
| 99 | // Update row element | ||
| 100 | if (!skip_id) | ||
| 101 | tr_elm.setAttribute('id', formObj.id.value); | ||
| 102 | |||
| 103 | tr_elm.setAttribute('align', getSelectValue(formObj, 'align')); | ||
| 104 | tr_elm.setAttribute('vAlign', getSelectValue(formObj, 'valign')); | ||
| 105 | tr_elm.setAttribute('lang', formObj.lang.value); | ||
| 106 | tr_elm.setAttribute('dir', getSelectValue(formObj, 'dir')); | ||
| 107 | tr_elm.setAttribute('style', dom.serializeStyle(dom.parseStyle(formObj.style.value))); | ||
| 108 | dom.setAttrib(tr_elm, 'class', getSelectValue(formObj, 'class')); | ||
| 109 | |||
| 110 | // Clear deprecated attributes | ||
| 111 | tr_elm.setAttribute('background', ''); | ||
| 112 | tr_elm.setAttribute('bgColor', ''); | ||
| 113 | tr_elm.setAttribute('height', ''); | ||
| 114 | |||
| 115 | // Set styles | ||
| 116 | tr_elm.style.height = getCSSSize(formObj.height.value); | ||
| 117 | tr_elm.style.backgroundColor = formObj.bgcolor.value; | ||
| 118 | |||
| 119 | if (formObj.backgroundimage.value != "") | ||
| 120 | tr_elm.style.backgroundImage = "url('" + formObj.backgroundimage.value + "')"; | ||
| 121 | else | ||
| 122 | tr_elm.style.backgroundImage = ''; | ||
| 123 | |||
| 124 | // Setup new rowtype | ||
| 125 | if (curRowType != rowtype && !skip_parent) { | ||
| 126 | // first, clone the node we are working on | ||
| 127 | var newRow = tr_elm.cloneNode(1); | ||
| 128 | |||
| 129 | // next, find the parent of its new destination (creating it if necessary) | ||
| 130 | var theTable = dom.getParent(tr_elm, "table"); | ||
| 131 | var dest = rowtype; | ||
| 132 | var newParent = null; | ||
| 133 | for (var i = 0; i < theTable.childNodes.length; i++) { | ||
| 134 | if (theTable.childNodes[i].nodeName.toLowerCase() == dest) | ||
| 135 | newParent = theTable.childNodes[i]; | ||
| 136 | } | ||
| 137 | |||
| 138 | if (newParent == null) { | ||
| 139 | newParent = doc.createElement(dest); | ||
| 140 | |||
| 141 | if (dest == "thead") { | ||
| 142 | if (theTable.firstChild.nodeName == 'CAPTION') | ||
| 143 | inst.dom.insertAfter(newParent, theTable.firstChild); | ||
| 144 | else | ||
| 145 | theTable.insertBefore(newParent, theTable.firstChild); | ||
| 146 | } else | ||
| 147 | theTable.appendChild(newParent); | ||
| 148 | } | ||
| 149 | |||
| 150 | // append the row to the new parent | ||
| 151 | newParent.appendChild(newRow); | ||
| 152 | |||
| 153 | // remove the original | ||
| 154 | tr_elm.parentNode.removeChild(tr_elm); | ||
| 155 | |||
| 156 | // set tr_elm to the new node | ||
| 157 | tr_elm = newRow; | ||
| 158 | } | ||
| 159 | |||
| 160 | dom.setAttrib(tr_elm, 'style', dom.serializeStyle(dom.parseStyle(tr_elm.style.cssText))); | ||
| 161 | } | ||
| 162 | |||
| 163 | function changedBackgroundImage() { | ||
| 164 | var formObj = document.forms[0], dom = tinyMCEPopup.editor.dom; | ||
| 165 | var st = dom.parseStyle(formObj.style.value); | ||
| 166 | |||
| 167 | st['background-image'] = "url('" + formObj.backgroundimage.value + "')"; | ||
| 168 | |||
| 169 | formObj.style.value = dom.serializeStyle(st); | ||
| 170 | } | ||
| 171 | |||
| 172 | function changedStyle() { | ||
| 173 | var formObj = document.forms[0], dom = tinyMCEPopup.editor.dom; | ||
| 174 | var st = dom.parseStyle(formObj.style.value); | ||
| 175 | |||
| 176 | if (st['background-image']) | ||
| 177 | formObj.backgroundimage.value = st['background-image'].replace(new RegExp("url\\('?([^']*)'?\\)", 'gi'), "$1"); | ||
| 178 | else | ||
| 179 | formObj.backgroundimage.value = ''; | ||
| 180 | |||
| 181 | if (st['height']) | ||
| 182 | formObj.height.value = trimSize(st['height']); | ||
| 183 | |||
| 184 | if (st['background-color']) { | ||
| 185 | formObj.bgcolor.value = st['background-color']; | ||
| 186 | updateColor('bgcolor_pick','bgcolor'); | ||
| 187 | } | ||
| 188 | } | ||
| 189 | |||
| 190 | function changedSize() { | ||
| 191 | var formObj = document.forms[0], dom = tinyMCEPopup.editor.dom; | ||
| 192 | var st = dom.parseStyle(formObj.style.value); | ||
| 193 | |||
| 194 | var height = formObj.height.value; | ||
| 195 | if (height != "") | ||
| 196 | st['height'] = getCSSSize(height); | ||
| 197 | else | ||
| 198 | st['height'] = ""; | ||
| 199 | |||
| 200 | formObj.style.value = dom.serializeStyle(st); | ||
| 201 | } | ||
| 202 | |||
| 203 | function changedColor() { | ||
| 204 | var formObj = document.forms[0], dom = tinyMCEPopup.editor.dom; | ||
| 205 | var st = dom.parseStyle(formObj.style.value); | ||
| 206 | |||
| 207 | st['background-color'] = formObj.bgcolor.value; | ||
| 208 | |||
| 209 | formObj.style.value = dom.serializeStyle(st); | ||
| 210 | } | ||
| 211 | |||
| 212 | tinyMCEPopup.onInit.add(init); | ||
diff --git a/public/javascripts/tiny_mce/plugins/table/js/table.js b/public/javascripts/tiny_mce/plugins/table/js/table.js new file mode 100755 index 0000000..a7f3c3a --- /dev/null +++ b/public/javascripts/tiny_mce/plugins/table/js/table.js | |||
| @@ -0,0 +1,413 @@ | |||
| 1 | tinyMCEPopup.requireLangPack(); | ||
| 2 | |||
| 3 | var action, orgTableWidth, orgTableHeight, dom = tinyMCEPopup.editor.dom; | ||
| 4 | |||
| 5 | function insertTable() { | ||
| 6 | var formObj = document.forms[0]; | ||
| 7 | var inst = tinyMCEPopup.editor, dom = inst.dom; | ||
| 8 | var cols = 2, rows = 2, border = 0, cellpadding = -1, cellspacing = -1, align, width, height, className, caption, frame, rules; | ||
| 9 | var html = '', capEl, elm; | ||
| 10 | var cellLimit, rowLimit, colLimit; | ||
| 11 | |||
| 12 | tinyMCEPopup.restoreSelection(); | ||
| 13 | |||
| 14 | if (!AutoValidator.validate(formObj)) { | ||
| 15 | tinyMCEPopup.alert(inst.getLang('invalid_data')); | ||
| 16 | return false; | ||
| 17 | } | ||
| 18 | |||
| 19 | elm = dom.getParent(inst.selection.getNode(), 'table'); | ||
| 20 | |||
| 21 | // Get form data | ||
| 22 | cols = formObj.elements['cols'].value; | ||
| 23 | rows = formObj.elements['rows'].value; | ||
| 24 | border = formObj.elements['border'].value != "" ? formObj.elements['border'].value : 0; | ||
| 25 | cellpadding = formObj.elements['cellpadding'].value != "" ? formObj.elements['cellpadding'].value : ""; | ||
| 26 | cellspacing = formObj.elements['cellspacing'].value != "" ? formObj.elements['cellspacing'].value : ""; | ||
| 27 | align = formObj.elements['align'].options[formObj.elements['align'].selectedIndex].value; | ||
| 28 | frame = formObj.elements['frame'].options[formObj.elements['frame'].selectedIndex].value; | ||
| 29 | rules = formObj.elements['rules'].options[formObj.elements['rules'].selectedIndex].value; | ||
| 30 | width = formObj.elements['width'].value; | ||
| 31 | height = formObj.elements['height'].value; | ||
| 32 | bordercolor = formObj.elements['bordercolor'].value; | ||
| 33 | bgcolor = formObj.elements['bgcolor'].value; | ||
| 34 | className = formObj.elements['class'].options[formObj.elements['class'].selectedIndex].value; | ||
| 35 | id = formObj.elements['id'].value; | ||
| 36 | summary = formObj.elements['summary'].value; | ||
| 37 | style = formObj.elements['style'].value; | ||
| 38 | dir = formObj.elements['dir'].value; | ||
| 39 | lang = formObj.elements['lang'].value; | ||
| 40 | background = formObj.elements['backgroundimage'].value; | ||
| 41 | caption = formObj.elements['caption'].checked; | ||
| 42 | |||
| 43 | cellLimit = tinyMCEPopup.getParam('table_cell_limit', false); | ||
| 44 | rowLimit = tinyMCEPopup.getParam('table_row_limit', false); | ||
| 45 | colLimit = tinyMCEPopup.getParam('table_col_limit', false); | ||
| 46 | |||
| 47 | // Validate table size | ||
| 48 | if (colLimit && cols > colLimit) { | ||
| 49 | tinyMCEPopup.alert(inst.getLang('table_dlg.col_limit').replace(/\{\$cols\}/g, colLimit)); | ||
| 50 | return false; | ||
| 51 | } else if (rowLimit && rows > rowLimit) { | ||
| 52 | tinyMCEPopup.alert(inst.getLang('table_dlg.row_limit').replace(/\{\$rows\}/g, rowLimit)); | ||
| 53 | return false; | ||
| 54 | } else if (cellLimit && cols * rows > cellLimit) { | ||
| 55 | tinyMCEPopup.alert(inst.getLang('table_dlg.cell_limit').replace(/\{\$cells\}/g, cellLimit)); | ||
| 56 | return false; | ||
| 57 | } | ||
| 58 | |||
| 59 | // Update table | ||
| 60 | if (action == "update") { | ||
| 61 | inst.execCommand('mceBeginUndoLevel'); | ||
| 62 | |||
| 63 | dom.setAttrib(elm, 'cellPadding', cellpadding, true); | ||
| 64 | dom.setAttrib(elm, 'cellSpacing', cellspacing, true); | ||
| 65 | dom.setAttrib(elm, 'border', border); | ||
| 66 | dom.setAttrib(elm, 'align', align); | ||
| 67 | dom.setAttrib(elm, 'frame', frame); | ||
| 68 | dom.setAttrib(elm, 'rules', rules); | ||
| 69 | dom.setAttrib(elm, 'class', className); | ||
| 70 | dom.setAttrib(elm, 'style', style); | ||
| 71 | dom.setAttrib(elm, 'id', id); | ||
| 72 | dom.setAttrib(elm, 'summary', summary); | ||
| 73 | dom.setAttrib(elm, 'dir', dir); | ||
| 74 | dom.setAttrib(elm, 'lang', lang); | ||
| 75 | |||
| 76 | capEl = inst.dom.select('caption', elm)[0]; | ||
| 77 | |||
| 78 | if (capEl && !caption) | ||
| 79 | capEl.parentNode.removeChild(capEl); | ||
| 80 | |||
| 81 | if (!capEl && caption) { | ||
| 82 | capEl = elm.ownerDocument.createElement('caption'); | ||
| 83 | |||
| 84 | if (!tinymce.isIE) | ||
| 85 | capEl.innerHTML = '<br mce_bogus="1"/>'; | ||
| 86 | |||
| 87 | elm.insertBefore(capEl, elm.firstChild); | ||
| 88 | } | ||
| 89 | |||
| 90 | if (width && inst.settings.inline_styles) { | ||
| 91 | dom.setStyle(elm, 'width', width); | ||
| 92 | dom.setAttrib(elm, 'width', ''); | ||
| 93 | } else { | ||
| 94 | dom.setAttrib(elm, 'width', width, true); | ||
| 95 | dom.setStyle(elm, 'width', ''); | ||
| 96 | } | ||
| 97 | |||
| 98 | // Remove these since they are not valid XHTML | ||
| 99 | dom.setAttrib(elm, 'borderColor', ''); | ||
| 100 | dom.setAttrib(elm, 'bgColor', ''); | ||
| 101 | dom.setAttrib(elm, 'background', ''); | ||
| 102 | |||
| 103 | if (height && inst.settings.inline_styles) { | ||
| 104 | dom.setStyle(elm, 'height', height); | ||
| 105 | dom.setAttrib(elm, 'height', ''); | ||
| 106 | } else { | ||
| 107 | dom.setAttrib(elm, 'height', height, true); | ||
| 108 | dom.setStyle(elm, 'height', ''); | ||
| 109 | } | ||
| 110 | |||
| 111 | if (background != '') | ||
| 112 | elm.style.backgroundImage = "url('" + background + "')"; | ||
| 113 | else | ||
| 114 | elm.style.backgroundImage = ''; | ||
| 115 | |||
| 116 | /* if (tinyMCEPopup.getParam("inline_styles")) { | ||
| 117 | if (width != '') | ||
| 118 | elm.style.width = getCSSSize(width); | ||
| 119 | }*/ | ||
| 120 | |||
| 121 | if (bordercolor != "") { | ||
| 122 | elm.style.borderColor = bordercolor; | ||
| 123 | elm.style.borderStyle = elm.style.borderStyle == "" ? "solid" : elm.style.borderStyle; | ||
| 124 | elm.style.borderWidth = border == "" ? "1px" : border; | ||
| 125 | } else | ||
| 126 | elm.style.borderColor = ''; | ||
| 127 | |||
| 128 | elm.style.backgroundColor = bgcolor; | ||
| 129 | elm.style.height = getCSSSize(height); | ||
| 130 | |||
| 131 | inst.addVisual(); | ||
| 132 | |||
| 133 | // Fix for stange MSIE align bug | ||
| 134 | //elm.outerHTML = elm.outerHTML; | ||
| 135 | |||
| 136 | inst.nodeChanged(); | ||
| 137 | inst.execCommand('mceEndUndoLevel'); | ||
| 138 | |||
| 139 | // Repaint if dimensions changed | ||
| 140 | if (formObj.width.value != orgTableWidth || formObj.height.value != orgTableHeight) | ||
| 141 | inst.execCommand('mceRepaint'); | ||
| 142 | |||
| 143 | tinyMCEPopup.close(); | ||
| 144 | return true; | ||
| 145 | } | ||
| 146 | |||
| 147 | // Create new table | ||
| 148 | html += '<table'; | ||
| 149 | |||
| 150 | html += makeAttrib('id', id); | ||
| 151 | html += makeAttrib('border', border); | ||
| 152 | html += makeAttrib('cellpadding', cellpadding); | ||
| 153 | html += makeAttrib('cellspacing', cellspacing); | ||
| 154 | |||
| 155 | if (width && inst.settings.inline_styles) { | ||
| 156 | if (style) | ||
| 157 | style += '; '; | ||
| 158 | |||
| 159 | style += 'width: ' + width; | ||
| 160 | } else | ||
| 161 | html += makeAttrib('width', width); | ||
| 162 | |||
| 163 | /* if (height) { | ||
| 164 | if (style) | ||
| 165 | style += '; '; | ||
| 166 | |||
| 167 | style += 'height: ' + height; | ||
| 168 | }*/ | ||
| 169 | |||
| 170 | //html += makeAttrib('height', height); | ||
| 171 | //html += makeAttrib('bordercolor', bordercolor); | ||
| 172 | //html += makeAttrib('bgcolor', bgcolor); | ||
| 173 | html += makeAttrib('align', align); | ||
| 174 | html += makeAttrib('frame', frame); | ||
| 175 | html += makeAttrib('rules', rules); | ||
| 176 | html += makeAttrib('class', className); | ||
| 177 | html += makeAttrib('style', style); | ||
| 178 | html += makeAttrib('summary', summary); | ||
| 179 | html += makeAttrib('dir', dir); | ||
| 180 | html += makeAttrib('lang', lang); | ||
| 181 | html += '>'; | ||
| 182 | |||
| 183 | if (caption) { | ||
| 184 | if (!tinymce.isIE) | ||
| 185 | html += '<caption><br mce_bogus="1"/></caption>'; | ||
| 186 | else | ||
| 187 | html += '<caption></caption>'; | ||
| 188 | } | ||
| 189 | |||
| 190 | for (var y=0; y<rows; y++) { | ||
| 191 | html += "<tr>"; | ||
| 192 | |||
| 193 | for (var x=0; x<cols; x++) { | ||
| 194 | if (!tinymce.isIE) | ||
| 195 | html += '<td><br mce_bogus="1"/></td>'; | ||
| 196 | else | ||
| 197 | html += '<td></td>'; | ||
| 198 | } | ||
| 199 | |||
| 200 | html += "</tr>"; | ||
| 201 | } | ||
| 202 | |||
| 203 | html += "</table>"; | ||
| 204 | |||
| 205 | inst.execCommand('mceBeginUndoLevel'); | ||
| 206 | inst.execCommand('mceInsertContent', false, html); | ||
| 207 | inst.addVisual(); | ||
| 208 | inst.execCommand('mceEndUndoLevel'); | ||
| 209 | |||
| 210 | tinyMCEPopup.close(); | ||
| 211 | } | ||
| 212 | |||
| 213 | function makeAttrib(attrib, value) { | ||
| 214 | var formObj = document.forms[0]; | ||
| 215 | var valueElm = formObj.elements[attrib]; | ||
| 216 | |||
| 217 | if (typeof(value) == "undefined" || value == null) { | ||
| 218 | value = ""; | ||
| 219 | |||
| 220 | if (valueElm) | ||
| 221 | value = valueElm.value; | ||
| 222 | } | ||
| 223 | |||
| 224 | if (value == "") | ||
| 225 | return ""; | ||
| 226 | |||
| 227 | // XML encode it | ||
| 228 | value = value.replace(/&/g, '&'); | ||
| 229 | value = value.replace(/\"/g, '"'); | ||
| 230 | value = value.replace(/</g, '<'); | ||
| 231 | value = value.replace(/>/g, '>'); | ||
| 232 | |||
| 233 | return ' ' + attrib + '="' + value + '"'; | ||
| 234 | } | ||
| 235 | |||
| 236 | function init() { | ||
| 237 | tinyMCEPopup.resizeToInnerSize(); | ||
| 238 | |||
| 239 | document.getElementById('backgroundimagebrowsercontainer').innerHTML = getBrowserHTML('backgroundimagebrowser','backgroundimage','image','table'); | ||
| 240 | document.getElementById('backgroundimagebrowsercontainer').innerHTML = getBrowserHTML('backgroundimagebrowser','backgroundimage','image','table'); | ||
| 241 | document.getElementById('bordercolor_pickcontainer').innerHTML = getColorPickerHTML('bordercolor_pick','bordercolor'); | ||
| 242 | document.getElementById('bgcolor_pickcontainer').innerHTML = getColorPickerHTML('bgcolor_pick','bgcolor'); | ||
| 243 | |||
| 244 | var cols = 2, rows = 2, border = tinyMCEPopup.getParam('table_default_border', '0'), cellpadding = tinyMCEPopup.getParam('table_default_cellpadding', ''), cellspacing = tinyMCEPopup.getParam('table_default_cellspacing', ''); | ||
| 245 | var align = "", width = "", height = "", bordercolor = "", bgcolor = "", className = ""; | ||
| 246 | var id = "", summary = "", style = "", dir = "", lang = "", background = "", bgcolor = "", bordercolor = "", rules, frame; | ||
| 247 | var inst = tinyMCEPopup.editor, dom = inst.dom; | ||
| 248 | var formObj = document.forms[0]; | ||
| 249 | var elm = dom.getParent(inst.selection.getNode(), "table"); | ||
| 250 | |||
| 251 | action = tinyMCEPopup.getWindowArg('action'); | ||
| 252 | |||
| 253 | if (!action) | ||
| 254 | action = elm ? "update" : "insert"; | ||
| 255 | |||
| 256 | if (elm && action != "insert") { | ||
| 257 | var rowsAr = elm.rows; | ||
| 258 | var cols = 0; | ||
| 259 | for (var i=0; i<rowsAr.length; i++) | ||
| 260 | if (rowsAr[i].cells.length > cols) | ||
| 261 | cols = rowsAr[i].cells.length; | ||
| 262 | |||
| 263 | cols = cols; | ||
| 264 | rows = rowsAr.length; | ||
| 265 | |||
| 266 | st = dom.parseStyle(dom.getAttrib(elm, "style")); | ||
| 267 | border = trimSize(getStyle(elm, 'border', 'borderWidth')); | ||
| 268 | cellpadding = dom.getAttrib(elm, 'cellpadding', ""); | ||
| 269 | cellspacing = dom.getAttrib(elm, 'cellspacing', ""); | ||
| 270 | width = trimSize(getStyle(elm, 'width', 'width')); | ||
| 271 | height = trimSize(getStyle(elm, 'height', 'height')); | ||
| 272 | bordercolor = convertRGBToHex(getStyle(elm, 'bordercolor', 'borderLeftColor')); | ||
| 273 | bgcolor = convertRGBToHex(getStyle(elm, 'bgcolor', 'backgroundColor')); | ||
| 274 | align = dom.getAttrib(elm, 'align', align); | ||
| 275 | frame = dom.getAttrib(elm, 'frame'); | ||
| 276 | rules = dom.getAttrib(elm, 'rules'); | ||
| 277 | className = tinymce.trim(dom.getAttrib(elm, 'class').replace(/mceItem.+/g, '')); | ||
| 278 | id = dom.getAttrib(elm, 'id'); | ||
| 279 | summary = dom.getAttrib(elm, 'summary'); | ||
| 280 | style = dom.serializeStyle(st); | ||
| 281 | dir = dom.getAttrib(elm, 'dir'); | ||
| 282 | lang = dom.getAttrib(elm, 'lang'); | ||
| 283 | background = getStyle(elm, 'background', 'backgroundImage').replace(new RegExp("url\\('?([^']*)'?\\)", 'gi'), "$1"); | ||
| 284 | formObj.caption.checked = elm.getElementsByTagName('caption').length > 0; | ||
| 285 | |||
| 286 | orgTableWidth = width; | ||
| 287 | orgTableHeight = height; | ||
| 288 | |||
| 289 | action = "update"; | ||
| 290 | formObj.insert.value = inst.getLang('update'); | ||
| 291 | } | ||
| 292 | |||
| 293 | addClassesToList('class', "table_styles"); | ||
| 294 | TinyMCE_EditableSelects.init(); | ||
| 295 | |||
| 296 | // Update form | ||
| 297 | selectByValue(formObj, 'align', align); | ||
| 298 | selectByValue(formObj, 'frame', frame); | ||
| 299 | selectByValue(formObj, 'rules', rules); | ||
| 300 | selectByValue(formObj, 'class', className, true, true); | ||
| 301 | formObj.cols.value = cols; | ||
| 302 | formObj.rows.value = rows; | ||
| 303 | formObj.border.value = border; | ||
| 304 | formObj.cellpadding.value = cellpadding; | ||
| 305 | formObj.cellspacing.value = cellspacing; | ||
| 306 | formObj.width.value = width; | ||
| 307 | formObj.height.value = height; | ||
| 308 | formObj.bordercolor.value = bordercolor; | ||
| 309 | formObj.bgcolor.value = bgcolor; | ||
| 310 | formObj.id.value = id; | ||
| 311 | formObj.summary.value = summary; | ||
| 312 | formObj.style.value = style; | ||
| 313 | formObj.dir.value = dir; | ||
| 314 | formObj.lang.value = lang; | ||
| 315 | formObj.backgroundimage.value = background; | ||
| 316 | |||
| 317 | updateColor('bordercolor_pick', 'bordercolor'); | ||
| 318 | updateColor('bgcolor_pick', 'bgcolor'); | ||
| 319 | |||
| 320 | // Resize some elements | ||
| 321 | if (isVisible('backgroundimagebrowser')) | ||
| 322 | document.getElementById('backgroundimage').style.width = '180px'; | ||
| 323 | |||
| 324 | // Disable some fields in update mode | ||
| 325 | if (action == "update") { | ||
| 326 | formObj.cols.disabled = true; | ||
| 327 | formObj.rows.disabled = true; | ||
| 328 | } | ||
| 329 | } | ||
| 330 | |||
| 331 | function changedSize() { | ||
| 332 | var formObj = document.forms[0]; | ||
| 333 | var st = dom.parseStyle(formObj.style.value); | ||
| 334 | |||
| 335 | /* var width = formObj.width.value; | ||
| 336 | if (width != "") | ||
| 337 | st['width'] = tinyMCEPopup.getParam("inline_styles") ? getCSSSize(width) : ""; | ||
| 338 | else | ||
| 339 | st['width'] = "";*/ | ||
| 340 | |||
| 341 | var height = formObj.height.value; | ||
| 342 | if (height != "") | ||
| 343 | st['height'] = getCSSSize(height); | ||
| 344 | else | ||
| 345 | st['height'] = ""; | ||
| 346 | |||
| 347 | formObj.style.value = dom.serializeStyle(st); | ||
| 348 | } | ||
| 349 | |||
| 350 | function changedBackgroundImage() { | ||
| 351 | var formObj = document.forms[0]; | ||
| 352 | var st = dom.parseStyle(formObj.style.value); | ||
| 353 | |||
| 354 | st['background-image'] = "url('" + formObj.backgroundimage.value + "')"; | ||
| 355 | |||
| 356 | formObj.style.value = dom.serializeStyle(st); | ||
| 357 | } | ||
| 358 | |||
| 359 | function changedBorder() { | ||
| 360 | var formObj = document.forms[0]; | ||
| 361 | var st = dom.parseStyle(formObj.style.value); | ||
| 362 | |||
| 363 | // Update border width if the element has a color | ||
| 364 | if (formObj.border.value != "" && formObj.bordercolor.value != "") | ||
| 365 | st['border-width'] = formObj.border.value + "px"; | ||
| 366 | |||
| 367 | formObj.style.value = dom.serializeStyle(st); | ||
| 368 | } | ||
| 369 | |||
| 370 | function changedColor() { | ||
| 371 | var formObj = document.forms[0]; | ||
| 372 | var st = dom.parseStyle(formObj.style.value); | ||
| 373 | |||
| 374 | st['background-color'] = formObj.bgcolor.value; | ||
| 375 | |||
| 376 | if (formObj.bordercolor.value != "") { | ||
| 377 | st['border-color'] = formObj.bordercolor.value; | ||
| 378 | |||
| 379 | // Add border-width if it's missing | ||
| 380 | if (!st['border-width']) | ||
| 381 | st['border-width'] = formObj.border.value == "" ? "1px" : formObj.border.value + "px"; | ||
| 382 | } | ||
| 383 | |||
| 384 | formObj.style.value = dom.serializeStyle(st); | ||
| 385 | } | ||
| 386 | |||
| 387 | function changedStyle() { | ||
| 388 | var formObj = document.forms[0]; | ||
| 389 | var st = dom.parseStyle(formObj.style.value); | ||
| 390 | |||
| 391 | if (st['background-image']) | ||
| 392 | formObj.backgroundimage.value = st['background-image'].replace(new RegExp("url\\('?([^']*)'?\\)", 'gi'), "$1"); | ||
| 393 | else | ||
| 394 | formObj.backgroundimage.value = ''; | ||
| 395 | |||
| 396 | if (st['width']) | ||
| 397 | formObj.width.value = trimSize(st['width']); | ||
| 398 | |||
| 399 | if (st['height']) | ||
| 400 | formObj.height.value = trimSize(st['height']); | ||
| 401 | |||
| 402 | if (st['background-color']) { | ||
| 403 | formObj.bgcolor.value = st['background-color']; | ||
| 404 | updateColor('bgcolor_pick','bgcolor'); | ||
| 405 | } | ||
| 406 | |||
| 407 | if (st['border-color']) { | ||
| 408 | formObj.bordercolor.value = st['border-color']; | ||
| 409 | updateColor('bordercolor_pick','bordercolor'); | ||
| 410 | } | ||
| 411 | } | ||
| 412 | |||
| 413 | tinyMCEPopup.onInit.add(init); | ||
diff --git a/public/javascripts/tiny_mce/plugins/table/langs/en_dlg.js b/public/javascripts/tiny_mce/plugins/table/langs/en_dlg.js new file mode 100755 index 0000000..000332a --- /dev/null +++ b/public/javascripts/tiny_mce/plugins/table/langs/en_dlg.js | |||
| @@ -0,0 +1,74 @@ | |||
| 1 | tinyMCE.addI18n('en.table_dlg',{ | ||
| 2 | general_tab:"General", | ||
| 3 | advanced_tab:"Advanced", | ||
| 4 | general_props:"General properties", | ||
| 5 | advanced_props:"Advanced properties", | ||
| 6 | rowtype:"Row in table part", | ||
| 7 | title:"Insert/Modify table", | ||
| 8 | width:"Width", | ||
| 9 | height:"Height", | ||
| 10 | cols:"Cols", | ||
| 11 | rows:"Rows", | ||
| 12 | cellspacing:"Cellspacing", | ||
| 13 | cellpadding:"Cellpadding", | ||
| 14 | border:"Border", | ||
| 15 | align:"Alignment", | ||
| 16 | align_default:"Default", | ||
| 17 | align_left:"Left", | ||
| 18 | align_right:"Right", | ||
| 19 | align_middle:"Center", | ||
| 20 | row_title:"Table row properties", | ||
| 21 | cell_title:"Table cell properties", | ||
| 22 | cell_type:"Cell type", | ||
| 23 | valign:"Vertical alignment", | ||
| 24 | align_top:"Top", | ||
| 25 | align_bottom:"Bottom", | ||
| 26 | bordercolor:"Border color", | ||
| 27 | bgcolor:"Background color", | ||
| 28 | merge_cells_title:"Merge table cells", | ||
| 29 | id:"Id", | ||
| 30 | style:"Style", | ||
| 31 | langdir:"Language direction", | ||
| 32 | langcode:"Language code", | ||
| 33 | mime:"Target MIME type", | ||
| 34 | ltr:"Left to right", | ||
| 35 | rtl:"Right to left", | ||
| 36 | bgimage:"Background image", | ||
| 37 | summary:"Summary", | ||
| 38 | td:"Data", | ||
| 39 | th:"Header", | ||
| 40 | cell_cell:"Update current cell", | ||
| 41 | cell_row:"Update all cells in row", | ||
| 42 | cell_all:"Update all cells in table", | ||
| 43 | row_row:"Update current row", | ||
| 44 | row_odd:"Update odd rows in table", | ||
| 45 | row_even:"Update even rows in table", | ||
| 46 | row_all:"Update all rows in table", | ||
| 47 | thead:"Table Head", | ||
| 48 | tbody:"Table Body", | ||
| 49 | tfoot:"Table Foot", | ||
| 50 | scope:"Scope", | ||
| 51 | rowgroup:"Row Group", | ||
| 52 | colgroup:"Col Group", | ||
| 53 | col_limit:"You've exceeded the maximum number of columns of {$cols}.", | ||
| 54 | row_limit:"You've exceeded the maximum number of rows of {$rows}.", | ||
| 55 | cell_limit:"You've exceeded the maximum number of cells of {$cells}.", | ||
| 56 | missing_scope:"Are you sure you want to continue without specifying a scope for this table header cell. Without it, it may be difficult for some users with disabilities to understand the content or data displayed of the table.", | ||
| 57 | caption:"Table caption", | ||
| 58 | frame:"Frame", | ||
| 59 | frame_none:"none", | ||
| 60 | frame_groups:"groups", | ||
| 61 | frame_rows:"rows", | ||
| 62 | frame_cols:"cols", | ||
| 63 | frame_all:"all", | ||
| 64 | rules:"Rules", | ||
| 65 | rules_void:"void", | ||
| 66 | rules_above:"above", | ||
| 67 | rules_below:"below", | ||
| 68 | rules_hsides:"hsides", | ||
| 69 | rules_lhs:"lhs", | ||
| 70 | rules_rhs:"rhs", | ||
| 71 | rules_vsides:"vsides", | ||
| 72 | rules_box:"box", | ||
| 73 | rules_border:"border" | ||
| 74 | }); \ No newline at end of file | ||
diff --git a/public/javascripts/tiny_mce/plugins/table/merge_cells.htm b/public/javascripts/tiny_mce/plugins/table/merge_cells.htm new file mode 100755 index 0000000..9d34a88 --- /dev/null +++ b/public/javascripts/tiny_mce/plugins/table/merge_cells.htm | |||
| @@ -0,0 +1,38 @@ | |||
| 1 | <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"> | ||
| 2 | <html xmlns="http://www.w3.org/1999/xhtml"> | ||
| 3 | <head> | ||
| 4 | <title>{#table_dlg.merge_cells_title}</title> | ||
| 5 | <script type="text/javascript" src="../../tiny_mce_popup.js"></script> | ||
| 6 | <script type="text/javascript" src="../../utils/mctabs.js"></script> | ||
| 7 | <script type="text/javascript" src="../../utils/validate.js"></script> | ||
| 8 | <script type="text/javascript" src="js/merge_cells.js"></script> | ||
| 9 | <base target="_self" /> | ||
| 10 | </head> | ||
| 11 | <body style="margin: 8px" style="display: none"> | ||
| 12 | <form onsubmit="mergeCells();return false;" action="#"> | ||
| 13 | <fieldset> | ||
| 14 | <legend>{#table_dlg.merge_cells_title}</legend> | ||
| 15 | <table border="0" cellpadding="0" cellspacing="3" width="100%"> | ||
| 16 | <tr> | ||
| 17 | <td>{#table_dlg.cols}:</td> | ||
| 18 | <td align="right"><input type="text" name="numcols" value="" class="number min1 mceFocus" style="width: 30px" /></td> | ||
| 19 | </tr> | ||
| 20 | <tr> | ||
| 21 | <td>{#table_dlg.rows}:</td> | ||
| 22 | <td align="right"><input type="text" name="numrows" value="" class="number min1" style="width: 30px" /></td> | ||
| 23 | </tr> | ||
| 24 | </table> | ||
| 25 | </fieldset> | ||
| 26 | |||
| 27 | <div class="mceActionPanel"> | ||
| 28 | <div style="float: left"> | ||
| 29 | <input type="submit" id="insert" name="insert" value="{#update}" /> | ||
| 30 | </div> | ||
| 31 | |||
| 32 | <div style="float: right"> | ||
| 33 | <input type="button" id="cancel" name="cancel" value="{#cancel}" onclick="tinyMCEPopup.close();" /> | ||
| 34 | </div> | ||
| 35 | </div> | ||
| 36 | </form> | ||
| 37 | </body> | ||
| 38 | </html> | ||
diff --git a/public/javascripts/tiny_mce/plugins/table/row.htm b/public/javascripts/tiny_mce/plugins/table/row.htm new file mode 100755 index 0000000..fe75bf6 --- /dev/null +++ b/public/javascripts/tiny_mce/plugins/table/row.htm | |||
| @@ -0,0 +1,161 @@ | |||
| 1 | <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"> | ||
| 2 | <html xmlns="http://www.w3.org/1999/xhtml"> | ||
| 3 | <head> | ||
| 4 | <title>{#table_dlg.row_title}</title> | ||
| 5 | <script type="text/javascript" src="../../tiny_mce_popup.js"></script> | ||
| 6 | <script type="text/javascript" src="../../utils/mctabs.js"></script> | ||
| 7 | <script type="text/javascript" src="../../utils/form_utils.js"></script> | ||
| 8 | <script type="text/javascript" src="../../utils/editable_selects.js"></script> | ||
| 9 | <script type="text/javascript" src="js/row.js"></script> | ||
| 10 | <link href="css/row.css" rel="stylesheet" type="text/css" /> | ||
| 11 | <base target="_self" /> | ||
| 12 | </head> | ||
| 13 | <body id="tablerow" style="display: none"> | ||
| 14 | <form onsubmit="updateAction();return false;"> | ||
| 15 | <div class="tabs"> | ||
| 16 | <ul> | ||
| 17 | <li id="general_tab" class="current"><span><a href="javascript:mcTabs.displayTab('general_tab','general_panel');" onmousedown="return false;">{#table_dlg.general_tab}</a></span></li> | ||
| 18 | <li id="advanced_tab"><span><a href="javascript:mcTabs.displayTab('advanced_tab','advanced_panel');" onmousedown="return false;">{#table_dlg.advanced_tab}</a></span></li> | ||
| 19 | </ul> | ||
| 20 | </div> | ||
| 21 | |||
| 22 | <div class="panel_wrapper"> | ||
| 23 | <div id="general_panel" class="panel current"> | ||
| 24 | <fieldset> | ||
| 25 | <legend>{#table_dlg.general_props}</legend> | ||
| 26 | |||
| 27 | <table border="0" cellpadding="4" cellspacing="0"> | ||
| 28 | <tr> | ||
| 29 | <td><label for="rowtype">{#table_dlg.rowtype}</label></td> | ||
| 30 | <td class="col2"> | ||
| 31 | <select id="rowtype" name="rowtype" class="mceFocus"> | ||
| 32 | <option value="thead">{#table_dlg.thead}</option> | ||
| 33 | <option value="tbody">{#table_dlg.tbody}</option> | ||
| 34 | <option value="tfoot">{#table_dlg.tfoot}</option> | ||
| 35 | </select> | ||
| 36 | </td> | ||
| 37 | </tr> | ||
| 38 | |||
| 39 | <tr> | ||
| 40 | <td><label for="align">{#table_dlg.align}</label></td> | ||
| 41 | <td class="col2"> | ||
| 42 | <select id="align" name="align"> | ||
| 43 | <option value="">{#not_set}</option> | ||
| 44 | <option value="center">{#table_dlg.align_middle}</option> | ||
| 45 | <option value="left">{#table_dlg.align_left}</option> | ||
| 46 | <option value="right">{#table_dlg.align_right}</option> | ||
| 47 | </select> | ||
| 48 | </td> | ||
| 49 | </tr> | ||
| 50 | |||
| 51 | <tr> | ||
| 52 | <td><label for="valign">{#table_dlg.valign}</label></td> | ||
| 53 | <td class="col2"> | ||
| 54 | <select id="valign" name="valign"> | ||
| 55 | <option value="">{#not_set}</option> | ||
| 56 | <option value="top">{#table_dlg.align_top}</option> | ||
| 57 | <option value="middle">{#table_dlg.align_middle}</option> | ||
| 58 | <option value="bottom">{#table_dlg.align_bottom}</option> | ||
| 59 | </select> | ||
| 60 | </td> | ||
| 61 | </tr> | ||
| 62 | |||
| 63 | <tr id="styleSelectRow"> | ||
| 64 | <td><label for="class">{#class_name}</label></td> | ||
| 65 | <td class="col2"> | ||
| 66 | <select id="class" name="class" class="mceEditableSelect"> | ||
| 67 | <option value="" selected="selected">{#not_set}</option> | ||
| 68 | </select> | ||
| 69 | </td> | ||
| 70 | </tr> | ||
| 71 | |||
| 72 | <tr> | ||
| 73 | <td><label for="height">{#table_dlg.height}</label></td> | ||
| 74 | <td class="col2"><input name="height" type="text" id="height" value="" size="4" maxlength="4" onchange="changedSize();" /></td> | ||
| 75 | </tr> | ||
| 76 | </table> | ||
| 77 | </fieldset> | ||
| 78 | </div> | ||
| 79 | |||
| 80 | <div id="advanced_panel" class="panel"> | ||
| 81 | <fieldset> | ||
| 82 | <legend>{#table_dlg.advanced_props}</legend> | ||
| 83 | |||
| 84 | <table border="0" cellpadding="0" cellspacing="4"> | ||
| 85 | <tr> | ||
| 86 | <td class="column1"><label for="id">{#table_dlg.id}</label></td> | ||
| 87 | <td><input id="id" name="id" type="text" value="" style="width: 200px" /></td> | ||
| 88 | </tr> | ||
| 89 | |||
| 90 | <tr> | ||
| 91 | <td><label for="style">{#table_dlg.style}</label></td> | ||
| 92 | <td><input type="text" id="style" name="style" value="" style="width: 200px;" onchange="changedStyle();" /></td> | ||
| 93 | </tr> | ||
| 94 | |||
| 95 | <tr> | ||
| 96 | <td class="column1"><label for="dir">{#table_dlg.langdir}</label></td> | ||
| 97 | <td> | ||
| 98 | <select id="dir" name="dir" style="width: 200px"> | ||
| 99 | <option value="">{#not_set}</option> | ||
| 100 | <option value="ltr">{#table_dlg.ltr}</option> | ||
| 101 | <option value="rtl">{#table_dlg.rtl}</option> | ||
| 102 | </select> | ||
| 103 | </td> | ||
| 104 | </tr> | ||
| 105 | |||
| 106 | <tr> | ||
| 107 | <td class="column1"><label for="lang">{#table_dlg.langcode}</label></td> | ||
| 108 | <td> | ||
| 109 | <input id="lang" name="lang" type="text" value="" style="width: 200px" /> | ||
| 110 | </td> | ||
| 111 | </tr> | ||
| 112 | |||
| 113 | <tr> | ||
| 114 | <td class="column1"><label for="backgroundimage">{#table_dlg.bgimage}</label></td> | ||
| 115 | <td> | ||
| 116 | <table border="0" cellpadding="0" cellspacing="0"> | ||
| 117 | <tr> | ||
| 118 | <td><input id="backgroundimage" name="backgroundimage" type="text" value="" style="width: 200px" onchange="changedBackgroundImage();" /></td> | ||
| 119 | <td id="backgroundimagebrowsercontainer"> </td> | ||
| 120 | </tr> | ||
| 121 | </table> | ||
| 122 | </td> | ||
| 123 | </tr> | ||
| 124 | |||
| 125 | <tr> | ||
| 126 | <td class="column1"><label for="bgcolor">{#table_dlg.bgcolor}</label></td> | ||
| 127 | <td> | ||
| 128 | <table border="0" cellpadding="0" cellspacing="0"> | ||
| 129 | <tr> | ||
| 130 | <td><input id="bgcolor" name="bgcolor" type="text" value="" size="9" onchange="updateColor('bgcolor_pick','bgcolor');changedColor();" /></td> | ||
| 131 | <td id="bgcolor_pickcontainer"> </td> | ||
| 132 | </tr> | ||
| 133 | </table> | ||
| 134 | </td> | ||
| 135 | </tr> | ||
| 136 | </table> | ||
| 137 | </fieldset> | ||
| 138 | </div> | ||
| 139 | </div> | ||
| 140 | |||
| 141 | <div class="mceActionPanel"> | ||
| 142 | <div> | ||
| 143 | <select id="action" name="action"> | ||
| 144 | <option value="row">{#table_dlg.row_row}</option> | ||
| 145 | <option value="odd">{#table_dlg.row_odd}</option> | ||
| 146 | <option value="even">{#table_dlg.row_even}</option> | ||
| 147 | <option value="all">{#table_dlg.row_all}</option> | ||
| 148 | </select> | ||
| 149 | </div> | ||
| 150 | |||
| 151 | <div style="float: left"> | ||
| 152 | <div><input type="submit" id="insert" name="insert" value="{#update}" /></div> | ||
| 153 | </div> | ||
| 154 | |||
| 155 | <div style="float: right"> | ||
| 156 | <input type="button" id="cancel" name="cancel" value="{#cancel}" onclick="tinyMCEPopup.close();" /> | ||
| 157 | </div> | ||
| 158 | </div> | ||
| 159 | </form> | ||
| 160 | </body> | ||
| 161 | </html> | ||
diff --git a/public/javascripts/tiny_mce/plugins/table/table.htm b/public/javascripts/tiny_mce/plugins/table/table.htm new file mode 100755 index 0000000..75136e6 --- /dev/null +++ b/public/javascripts/tiny_mce/plugins/table/table.htm | |||
| @@ -0,0 +1,193 @@ | |||
| 1 | <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"> | ||
| 2 | <html xmlns="http://www.w3.org/1999/xhtml"> | ||
| 3 | <head> | ||
| 4 | <title>{#table_dlg.title}</title> | ||
| 5 | <script type="text/javascript" src="../../tiny_mce_popup.js"></script> | ||
| 6 | <script type="text/javascript" src="../../utils/mctabs.js"></script> | ||
| 7 | <script type="text/javascript" src="../../utils/form_utils.js"></script> | ||
| 8 | <script type="text/javascript" src="../../utils/validate.js"></script> | ||
| 9 | <script type="text/javascript" src="../../utils/editable_selects.js"></script> | ||
| 10 | <script type="text/javascript" src="js/table.js"></script> | ||
| 11 | <link href="css/table.css" rel="stylesheet" type="text/css" /> | ||
| 12 | <base target="_self" /> | ||
| 13 | </head> | ||
| 14 | <body id="table" style="display: none"> | ||
| 15 | <form onsubmit="insertTable();return false;" action="#"> | ||
| 16 | <div class="tabs"> | ||
| 17 | <ul> | ||
| 18 | <li id="general_tab" class="current"><span><a href="javascript:mcTabs.displayTab('general_tab','general_panel');" onmousedown="return false;">{#table_dlg.general_tab}</a></span></li> | ||
| 19 | <li id="advanced_tab"><span><a href="javascript:mcTabs.displayTab('advanced_tab','advanced_panel');" onmousedown="return false;">{#table_dlg.advanced_tab}</a></span></li> | ||
| 20 | </ul> | ||
| 21 | </div> | ||
| 22 | |||
| 23 | <div class="panel_wrapper"> | ||
| 24 | <div id="general_panel" class="panel current"> | ||
| 25 | <fieldset> | ||
| 26 | <legend>{#table_dlg.general_props}</legend> | ||
| 27 | <table border="0" cellpadding="4" cellspacing="0" width="100%"> | ||
| 28 | <tr> | ||
| 29 | <td><label id="colslabel" for="cols">{#table_dlg.cols}</label></td> | ||
| 30 | <td><input id="cols" name="cols" type="text" value="" size="3" maxlength="3" class="required number min1 mceFocus" /></td> | ||
| 31 | <td><label id="rowslabel" for="rows">{#table_dlg.rows}</label></td> | ||
| 32 | <td><input id="rows" name="rows" type="text" value="" size="3" maxlength="3" class="required number min1" /></td> | ||
| 33 | </tr> | ||
| 34 | <tr> | ||
| 35 | <td><label id="cellpaddinglabel" for="cellpadding">{#table_dlg.cellpadding}</label></td> | ||
| 36 | <td><input id="cellpadding" name="cellpadding" type="text" value="" size="3" maxlength="3" class="number" /></td> | ||
| 37 | <td><label id="cellspacinglabel" for="cellspacing">{#table_dlg.cellspacing}</label></td> | ||
| 38 | <td><input id="cellspacing" name="cellspacing" type="text" value="" size="3" maxlength="3" class="number" /></td> | ||
| 39 | </tr> | ||
| 40 | <tr> | ||
| 41 | <td><label id="alignlabel" for="align">{#table_dlg.align}</label></td> | ||
| 42 | <td><select id="align" name="align"> | ||
| 43 | <option value="">{#not_set}</option> | ||
| 44 | <option value="center">{#table_dlg.align_middle}</option> | ||
| 45 | <option value="left">{#table_dlg.align_left}</option> | ||
| 46 | <option value="right">{#table_dlg.align_right}</option> | ||
| 47 | </select></td> | ||
| 48 | <td><label id="borderlabel" for="border">{#table_dlg.border}</label></td> | ||
| 49 | <td><input id="border" name="border" type="text" value="" size="3" maxlength="3" onchange="changedBorder();" class="number" /></td> | ||
| 50 | </tr> | ||
| 51 | <tr id="width_row"> | ||
| 52 | <td><label id="widthlabel" for="width">{#table_dlg.width}</label></td> | ||
| 53 | <td><input name="width" type="text" id="width" value="" size="4" maxlength="4" onchange="changedSize();" class="size" /></td> | ||
| 54 | <td><label id="heightlabel" for="height">{#table_dlg.height}</label></td> | ||
| 55 | <td><input name="height" type="text" id="height" value="" size="4" maxlength="4" onchange="changedSize();" class="size" /></td> | ||
| 56 | </tr> | ||
| 57 | <tr id="styleSelectRow"> | ||
| 58 | <td><label id="classlabel" for="class">{#class_name}</label></td> | ||
| 59 | <td colspan="3"> | ||
| 60 | <select id="class" name="class" class="mceEditableSelect"> | ||
| 61 | <option value="" selected>{#not_set}</option> | ||
| 62 | </select></td> | ||
| 63 | </tr> | ||
| 64 | <tr> | ||
| 65 | <td class="column1"><label for="caption">{#table_dlg.caption}</label></td> | ||
| 66 | <td><input id="caption" name="caption" type="checkbox" class="checkbox" value="true" /></td> | ||
| 67 | </tr> | ||
| 68 | </table> | ||
| 69 | </fieldset> | ||
| 70 | </div> | ||
| 71 | |||
| 72 | <div id="advanced_panel" class="panel"> | ||
| 73 | <fieldset> | ||
| 74 | <legend>{#table_dlg.advanced_props}</legend> | ||
| 75 | |||
| 76 | <table border="0" cellpadding="0" cellspacing="4"> | ||
| 77 | <tr> | ||
| 78 | <td class="column1"><label for="id">{#table_dlg.id}</label></td> | ||
| 79 | <td><input id="id" name="id" type="text" value="" class="advfield" /></td> | ||
| 80 | </tr> | ||
| 81 | |||
| 82 | <tr> | ||
| 83 | <td class="column1"><label for="summary">{#table_dlg.summary}</label></td> | ||
| 84 | <td><input id="summary" name="summary" type="text" value="" class="advfield" /></td> | ||
| 85 | </tr> | ||
| 86 | |||
| 87 | <tr> | ||
| 88 | <td><label for="style">{#table_dlg.style}</label></td> | ||
| 89 | <td><input type="text" id="style" name="style" value="" class="advfield" onchange="changedStyle();" /></td> | ||
| 90 | </tr> | ||
| 91 | |||
| 92 | <tr> | ||
| 93 | <td class="column1"><label id="langlabel" for="lang">{#table_dlg.langcode}</label></td> | ||
| 94 | <td> | ||
| 95 | <input id="lang" name="lang" type="text" value="" class="advfield" /> | ||
| 96 | </td> | ||
| 97 | </tr> | ||
| 98 | |||
| 99 | <tr> | ||
| 100 | <td class="column1"><label for="backgroundimage">{#table_dlg.bgimage}</label></td> | ||
| 101 | <td> | ||
| 102 | <table border="0" cellpadding="0" cellspacing="0"> | ||
| 103 | <tr> | ||
| 104 | <td><input id="backgroundimage" name="backgroundimage" type="text" value="" class="advfield" onchange="changedBackgroundImage();" /></td> | ||
| 105 | <td id="backgroundimagebrowsercontainer"> </td> | ||
| 106 | </tr> | ||
| 107 | </table> | ||
| 108 | </td> | ||
| 109 | </tr> | ||
| 110 | |||
| 111 | <tr> | ||
| 112 | <td class="column1"><label for="frame">{#table_dlg.frame}</label></td> | ||
| 113 | <td> | ||
| 114 | <select id="frame" name="frame" class="advfield"> | ||
| 115 | <option value="">{#not_set}</option> | ||
| 116 | <option value="void">{#table_dlg.rules_void}</option> | ||
| 117 | <option value="above">{#table_dlg.rules_above}</option> | ||
| 118 | <option value="below">{#table_dlg.rules_below}</option> | ||
| 119 | <option value="hsides">{#table_dlg.rules_hsides}</option> | ||
| 120 | <option value="lhs">{#table_dlg.rules_lhs}</option> | ||
| 121 | <option value="rhs">{#table_dlg.rules_rhs}</option> | ||
| 122 | <option value="vsides">{#table_dlg.rules_vsides}</option> | ||
| 123 | <option value="box">{#table_dlg.rules_box}</option> | ||
| 124 | <option value="border">{#table_dlg.rules_border}</option> | ||
| 125 | </select> | ||
| 126 | </td> | ||
| 127 | </tr> | ||
| 128 | |||
| 129 | <tr> | ||
| 130 | <td class="column1"><label for="rules">{#table_dlg.rules}</label></td> | ||
| 131 | <td> | ||
| 132 | <select id="rules" name="rules" class="advfield"> | ||
| 133 | <option value="">{#not_set}</option> | ||
| 134 | <option value="none">{#table_dlg.frame_none}</option> | ||
| 135 | <option value="groups">{#table_dlg.frame_groups}</option> | ||
| 136 | <option value="rows">{#table_dlg.frame_rows}</option> | ||
| 137 | <option value="cols">{#table_dlg.frame_cols}</option> | ||
| 138 | <option value="all">{#table_dlg.frame_all}</option> | ||
| 139 | </select> | ||
| 140 | </td> | ||
| 141 | </tr> | ||
| 142 | |||
| 143 | <tr> | ||
| 144 | <td class="column1"><label for="dir">{#table_dlg.langdir}</label></td> | ||
| 145 | <td> | ||
| 146 | <select id="dir" name="dir" class="advfield"> | ||
| 147 | <option value="">{#not_set}</option> | ||
| 148 | <option value="ltr">{#table_dlg.ltr}</option> | ||
| 149 | <option value="rtl">{#table_dlg.rtl}</option> | ||
| 150 | </select> | ||
| 151 | </td> | ||
| 152 | </tr> | ||
| 153 | |||
| 154 | <tr> | ||
| 155 | <td class="column1"><label for="bordercolor">{#table_dlg.bordercolor}</label></td> | ||
| 156 | <td> | ||
| 157 | <table border="0" cellpadding="0" cellspacing="0"> | ||
| 158 | <tr> | ||
| 159 | <td><input id="bordercolor" name="bordercolor" type="text" value="" size="9" onchange="updateColor('bordercolor_pick','bordercolor');changedColor();" /></td> | ||
| 160 | <td id="bordercolor_pickcontainer"> </td> | ||
| 161 | </tr> | ||
| 162 | </table> | ||
| 163 | </td> | ||
| 164 | </tr> | ||
| 165 | |||
| 166 | <tr> | ||
| 167 | <td class="column1"><label for="bgcolor">{#table_dlg.bgcolor}</label></td> | ||
| 168 | <td> | ||
| 169 | <table border="0" cellpadding="0" cellspacing="0"> | ||
| 170 | <tr> | ||
| 171 | <td><input id="bgcolor" name="bgcolor" type="text" value="" size="9" onchange="updateColor('bgcolor_pick','bgcolor');changedColor();" /></td> | ||
| 172 | <td id="bgcolor_pickcontainer"> </td> | ||
| 173 | </tr> | ||
| 174 | </table> | ||
| 175 | </td> | ||
| 176 | </tr> | ||
| 177 | </table> | ||
| 178 | </fieldset> | ||
| 179 | </div> | ||
| 180 | </div> | ||
| 181 | |||
| 182 | <div class="mceActionPanel"> | ||
| 183 | <div style="float: left"> | ||
| 184 | <input type="submit" id="insert" name="insert" value="{#insert}" /> | ||
| 185 | </div> | ||
| 186 | |||
| 187 | <div style="float: right"> | ||
| 188 | <input type="button" id="cancel" name="cancel" value="{#cancel}" onclick="tinyMCEPopup.close();" /> | ||
| 189 | </div> | ||
| 190 | </div> | ||
| 191 | </form> | ||
| 192 | </body> | ||
| 193 | </html> | ||
