+++ /dev/null
-var action, orgTableWidth, orgTableHeight;\r
-\r
-function insertTable() {\r
- var formObj = document.forms[0];\r
- var inst = tinyMCE.selectedInstance;\r
- var cols = 2, rows = 2, border = 0, cellpadding = -1, cellspacing = -1, align, width, height, className, caption;\r
- var html = '', capEl;\r
- var elm = tinyMCE.tableElm;\r
- var cellLimit, rowLimit, colLimit;\r
-\r
- if (!AutoValidator.validate(formObj)) {\r
- alert(tinyMCE.getLang('lang_invalid_data'));\r
- return false;\r
- }\r
-\r
- tinyMCEPopup.restoreSelection();\r
-\r
- // Get form data\r
- cols = formObj.elements['cols'].value;\r
- rows = formObj.elements['rows'].value;\r
- border = formObj.elements['border'].value != "" ? formObj.elements['border'].value : 0;\r
- cellpadding = formObj.elements['cellpadding'].value != "" ? formObj.elements['cellpadding'].value : "";\r
- cellspacing = formObj.elements['cellspacing'].value != "" ? formObj.elements['cellspacing'].value : "";\r
- align = formObj.elements['align'].options[formObj.elements['align'].selectedIndex].value;\r
- width = formObj.elements['width'].value;\r
- height = formObj.elements['height'].value;\r
- bordercolor = formObj.elements['bordercolor'].value;\r
- bgcolor = formObj.elements['bgcolor'].value;\r
- className = formObj.elements['class'].options[formObj.elements['class'].selectedIndex].value;\r
- id = formObj.elements['id'].value;\r
- summary = formObj.elements['summary'].value;\r
- style = formObj.elements['style'].value;\r
- dir = formObj.elements['dir'].value;\r
- lang = formObj.elements['lang'].value;\r
- background = formObj.elements['backgroundimage'].value;\r
- caption = formObj.elements['caption'].checked;\r
-\r
- cellLimit = tinyMCE.getParam('table_cell_limit', false);\r
- rowLimit = tinyMCE.getParam('table_row_limit', false);\r
- colLimit = tinyMCE.getParam('table_col_limit', false);\r
-\r
- // Validate table size\r
- if (colLimit && cols > colLimit) {\r
- alert(tinyMCE.getLang('lang_table_col_limit', '', true, {cols : colLimit}));\r
- return false;\r
- } else if (rowLimit && rows > rowLimit) {\r
- alert(tinyMCE.getLang('lang_table_row_limit', '', true, {rows : rowLimit}));\r
- return false;\r
- } else if (cellLimit && cols * rows > cellLimit) {\r
- alert(tinyMCE.getLang('lang_table_cell_limit', '', true, {cells : cellLimit}));\r
- return false;\r
- }\r
-\r
- // Update table\r
- if (action == "update") {\r
- inst.execCommand('mceBeginUndoLevel');\r
-\r
- tinyMCE.setAttrib(elm, 'cellPadding', cellpadding, true);\r
- tinyMCE.setAttrib(elm, 'cellSpacing', cellspacing, true);\r
- tinyMCE.setAttrib(elm, 'border', border, true);\r
- tinyMCE.setAttrib(elm, 'align', align);\r
- tinyMCE.setAttrib(elm, 'class', className);\r
- tinyMCE.setAttrib(elm, 'style', style);\r
- tinyMCE.setAttrib(elm, 'id', id);\r
- tinyMCE.setAttrib(elm, 'summary', summary);\r
- tinyMCE.setAttrib(elm, 'dir', dir);\r
- tinyMCE.setAttrib(elm, 'lang', lang);\r
-\r
- capEl = elm.getElementsByTagName('caption')[0];\r
-\r
- if (capEl && !caption)\r
- capEl.parentNode.removeChild(capEl);\r
-\r
- if (!capEl && caption) {\r
- capEl = elm.ownerDocument.createElement('caption');\r
- capEl.innerHTML = ' ';\r
- elm.insertBefore(capEl, elm.firstChild);\r
- }\r
-\r
- // Not inline styles\r
- if (!tinyMCE.getParam("inline_styles"))\r
- tinyMCE.setAttrib(elm, 'width', width, true);\r
-\r
- // Remove these since they are not valid XHTML\r
- tinyMCE.setAttrib(elm, 'borderColor', '');\r
- tinyMCE.setAttrib(elm, 'bgColor', '');\r
- tinyMCE.setAttrib(elm, 'background', '');\r
- tinyMCE.setAttrib(elm, 'height', '');\r
-\r
- if (background != '')\r
- elm.style.backgroundImage = "url('" + background + "')";\r
- else\r
- elm.style.backgroundImage = '';\r
-\r
- if (tinyMCE.getParam("inline_styles"))\r
- elm.style.borderWidth = border + "px";\r
-\r
- if (tinyMCE.getParam("inline_styles")) {\r
- if (width != '')\r
- elm.style.width = getCSSSize(width);\r
- }\r
-\r
- if (bordercolor != "") {\r
- elm.style.borderColor = bordercolor;\r
- elm.style.borderStyle = elm.style.borderStyle == "" ? "solid" : elm.style.borderStyle;\r
- elm.style.borderWidth = border == "" ? "1px" : border;\r
- } else\r
- elm.style.borderColor = '';\r
-\r
- elm.style.backgroundColor = bgcolor;\r
- elm.style.height = getCSSSize(height);\r
-\r
- tinyMCE.handleVisualAid(tinyMCE.tableElm, false, inst.visualAid, inst);\r
-\r
- // Fix for stange MSIE align bug\r
- tinyMCE.tableElm.outerHTML = tinyMCE.tableElm.outerHTML;\r
-\r
- tinyMCE.handleVisualAid(inst.getBody(), true, inst.visualAid, inst);\r
- tinyMCE.triggerNodeChange();\r
- inst.execCommand('mceEndUndoLevel');\r
-\r
- // Repaint if dimensions changed\r
- if (formObj.width.value != orgTableWidth || formObj.height.value != orgTableHeight)\r
- inst.repaint();\r
-\r
- tinyMCEPopup.close();\r
- return true;\r
- }\r
-\r
- // Create new table\r
- html += '<table';\r
-\r
- html += makeAttrib('id', id);\r
- html += makeAttrib('border', border);\r
- html += makeAttrib('cellpadding', cellpadding);\r
- html += makeAttrib('cellspacing', cellspacing);\r
- html += makeAttrib('width', width);\r
- //html += makeAttrib('height', height);\r
- //html += makeAttrib('bordercolor', bordercolor);\r
- //html += makeAttrib('bgcolor', bgcolor);\r
- html += makeAttrib('align', align);\r
- html += makeAttrib('class', tinyMCE.getVisualAidClass(className, border == 0));\r
- html += makeAttrib('style', style);\r
- html += makeAttrib('summary', summary);\r
- html += makeAttrib('dir', dir);\r
- html += makeAttrib('lang', lang);\r
- html += '>';\r
-\r
- if (caption)\r
- html += '<caption> </caption>';\r
-\r
- for (var y=0; y<rows; y++) {\r
- html += "<tr>";\r
-\r
- for (var x=0; x<cols; x++)\r
- html += '<td> </td>';\r
-\r
- html += "</tr>";\r
- }\r
-\r
- html += "</table>";\r
-\r
- inst.execCommand('mceBeginUndoLevel');\r
- inst.execCommand('mceInsertContent', false, html);\r
- tinyMCE.handleVisualAid(inst.getBody(), true, tinyMCE.settings['visual']);\r
- inst.execCommand('mceEndUndoLevel');\r
-\r
- tinyMCEPopup.close();\r
-}\r
-\r
-function makeAttrib(attrib, value) {\r
- var formObj = document.forms[0];\r
- var valueElm = formObj.elements[attrib];\r
-\r
- if (typeof(value) == "undefined" || value == null) {\r
- value = "";\r
-\r
- if (valueElm)\r
- value = valueElm.value;\r
- }\r
-\r
- if (value == "")\r
- return "";\r
-\r
- // XML encode it\r
- value = value.replace(/&/g, '&');\r
- value = value.replace(/\"/g, '"');\r
- value = value.replace(/</g, '<');\r
- value = value.replace(/>/g, '>');\r
-\r
- return ' ' + attrib + '="' + value + '"';\r
-}\r
-\r
-function init() {\r
- tinyMCEPopup.resizeToInnerSize();\r
-\r
- document.getElementById('backgroundimagebrowsercontainer').innerHTML = getBrowserHTML('backgroundimagebrowser','backgroundimage','image','table');\r
- document.getElementById('backgroundimagebrowsercontainer').innerHTML = getBrowserHTML('backgroundimagebrowser','backgroundimage','image','table');\r
- document.getElementById('bordercolor_pickcontainer').innerHTML = getColorPickerHTML('bordercolor_pick','bordercolor');\r
- document.getElementById('bgcolor_pickcontainer').innerHTML = getColorPickerHTML('bgcolor_pick','bgcolor');\r
-\r
- var cols = 2, rows = 2, border = tinyMCE.getParam('table_default_border', '0'), cellpadding = tinyMCE.getParam('table_default_cellpadding', ''), cellspacing = tinyMCE.getParam('table_default_cellspacing', '');\r
- var align = "", width = "", height = "", bordercolor = "", bgcolor = "", className = "";\r
- var id = "", summary = "", style = "", dir = "", lang = "", background = "", bgcolor = "", bordercolor = "";\r
- var inst = tinyMCE.selectedInstance;\r
- var formObj = document.forms[0];\r
- var elm = tinyMCE.getParentElement(inst.getFocusElement(), "table");\r
-\r
- tinyMCE.tableElm = elm;\r
- action = tinyMCE.getWindowArg('action');\r
- if (action == null)\r
- action = tinyMCE.tableElm ? "update" : "insert";\r
-\r
- if (tinyMCE.tableElm && action != "insert") {\r
- var rowsAr = tinyMCE.tableElm.rows;\r
- var cols = 0;\r
- for (var i=0; i<rowsAr.length; i++)\r
- if (rowsAr[i].cells.length > cols)\r
- cols = rowsAr[i].cells.length;\r
-\r
- cols = cols;\r
- rows = rowsAr.length;\r
-\r
- st = tinyMCE.parseStyle(tinyMCE.getAttrib(tinyMCE.tableElm, "style"));\r
- border = trimSize(getStyle(elm, 'border', 'borderWidth'));\r
- cellpadding = tinyMCE.getAttrib(tinyMCE.tableElm, 'cellpadding', "");\r
- cellspacing = tinyMCE.getAttrib(tinyMCE.tableElm, 'cellspacing', "");\r
- width = trimSize(getStyle(elm, 'width', 'width'));\r
- height = trimSize(getStyle(elm, 'height', 'height'));\r
- bordercolor = convertRGBToHex(getStyle(elm, 'bordercolor', 'borderLeftColor'));\r
- bgcolor = convertRGBToHex(getStyle(elm, 'bgcolor', 'backgroundColor'));\r
- align = tinyMCE.getAttrib(tinyMCE.tableElm, 'align', align);\r
- className = tinyMCE.getVisualAidClass(tinyMCE.getAttrib(tinyMCE.tableElm, 'class'), false);\r
- id = tinyMCE.getAttrib(tinyMCE.tableElm, 'id');\r
- summary = tinyMCE.getAttrib(tinyMCE.tableElm, 'summary');\r
- style = tinyMCE.serializeStyle(st);\r
- dir = tinyMCE.getAttrib(tinyMCE.tableElm, 'dir');\r
- lang = tinyMCE.getAttrib(tinyMCE.tableElm, 'lang');\r
- background = getStyle(elm, 'background', 'backgroundImage').replace(new RegExp("url\\('?([^']*)'?\\)", 'gi'), "$1");\r
- formObj.caption.checked = tinyMCE.tableElm.getElementsByTagName('caption').length > 0;\r
-\r
- orgTableWidth = width;\r
- orgTableHeight = height;\r
-\r
- action = "update";\r
- }\r
-\r
- addClassesToList('class', "table_styles");\r
-\r
- // Update form\r
- selectByValue(formObj, 'align', align);\r
- selectByValue(formObj, 'class', className);\r
- formObj.cols.value = cols;\r
- formObj.rows.value = rows;\r
- formObj.border.value = border;\r
- formObj.cellpadding.value = cellpadding;\r
- formObj.cellspacing.value = cellspacing;\r
- formObj.width.value = width;\r
- formObj.height.value = height;\r
- formObj.bordercolor.value = bordercolor;\r
- formObj.bgcolor.value = bgcolor;\r
- formObj.id.value = id;\r
- formObj.summary.value = summary;\r
- formObj.style.value = style;\r
- formObj.dir.value = dir;\r
- formObj.lang.value = lang;\r
- formObj.backgroundimage.value = background;\r
- formObj.insert.value = tinyMCE.getLang('lang_' + action, 'Insert', true); \r
-\r
- updateColor('bordercolor_pick', 'bordercolor');\r
- updateColor('bgcolor_pick', 'bgcolor');\r
-\r
- // Resize some elements\r
- if (isVisible('backgroundimagebrowser'))\r
- document.getElementById('backgroundimage').style.width = '180px';\r
-\r
- // Disable some fields in update mode\r
- if (action == "update") {\r
- formObj.cols.disabled = true;\r
- formObj.rows.disabled = true;\r
- }\r
-}\r
-\r
-function changedSize() {\r
- var formObj = document.forms[0];\r
- var st = tinyMCE.parseStyle(formObj.style.value);\r
-\r
- var width = formObj.width.value;\r
- if (width != "")\r
- st['width'] = tinyMCE.getParam("inline_styles") ? getCSSSize(width) : "";\r
- else\r
- st['width'] = "";\r
-\r
- var height = formObj.height.value;\r
- if (height != "")\r
- st['height'] = getCSSSize(height);\r
- else\r
- st['height'] = "";\r
-\r
- formObj.style.value = tinyMCE.serializeStyle(st);\r
-}\r
-\r
-function changedBackgroundImage() {\r
- var formObj = document.forms[0];\r
- var st = tinyMCE.parseStyle(formObj.style.value);\r
-\r
- st['background-image'] = "url('" + formObj.backgroundimage.value + "')";\r
-\r
- formObj.style.value = tinyMCE.serializeStyle(st);\r
-}\r
-\r
-function changedBorder() {\r
- var formObj = document.forms[0];\r
- var st = tinyMCE.parseStyle(formObj.style.value);\r
-\r
- // Update border width if the element has a color\r
- if (formObj.border.value != "" && formObj.bordercolor.value != "")\r
- st['border-width'] = formObj.border.value + "px";\r
-\r
- formObj.style.value = tinyMCE.serializeStyle(st);\r
-}\r
-\r
-function changedColor() {\r
- var formObj = document.forms[0];\r
- var st = tinyMCE.parseStyle(formObj.style.value);\r
-\r
- st['background-color'] = formObj.bgcolor.value;\r
-\r
- if (formObj.bordercolor.value != "") {\r
- st['border-color'] = formObj.bordercolor.value;\r
-\r
- // Add border-width if it's missing\r
- if (!st['border-width'])\r
- st['border-width'] = formObj.border.value == "" ? "1px" : formObj.border.value + "px";\r
- }\r
-\r
- formObj.style.value = tinyMCE.serializeStyle(st);\r
-}\r
-\r
-function changedStyle() {\r
- var formObj = document.forms[0];\r
- var st = tinyMCE.parseStyle(formObj.style.value);\r
-\r
- if (st['background-image'])\r
- formObj.backgroundimage.value = st['background-image'].replace(new RegExp("url\\('?([^']*)'?\\)", 'gi'), "$1");\r
- else\r
- formObj.backgroundimage.value = '';\r
-\r
- if (st['width'])\r
- formObj.width.value = trimSize(st['width']);\r
-\r
- if (st['height'])\r
- formObj.height.value = trimSize(st['height']);\r
-\r
- if (st['background-color']) {\r
- formObj.bgcolor.value = st['background-color'];\r
- updateColor('bgcolor_pick','bgcolor');\r
- }\r
-\r
- if (st['border-color']) {\r
- formObj.bordercolor.value = st['border-color'];\r
- updateColor('bordercolor_pick','bordercolor');\r
- }\r
-}\r