Upgrade TinyMCE to v3.4.5
[citadel.git] / webcit / tiny_mce / plugins / table / js / table.js
1 tinyMCEPopup.requireLangPack();\r
2 \r
3 var action, orgTableWidth, orgTableHeight, dom = tinyMCEPopup.editor.dom;\r
4 \r
5 function insertTable() {\r
6         var formObj = document.forms[0];\r
7         var inst = tinyMCEPopup.editor, dom = inst.dom;\r
8         var cols = 2, rows = 2, border = 0, cellpadding = -1, cellspacing = -1, align, width, height, className, caption, frame, rules;\r
9         var html = '', capEl, elm;\r
10         var cellLimit, rowLimit, colLimit;\r
11 \r
12         tinyMCEPopup.restoreSelection();\r
13 \r
14         if (!AutoValidator.validate(formObj)) {\r
15                 tinyMCEPopup.alert(AutoValidator.getErrorMessages(formObj).join('. ') + '.');\r
16                 return false;\r
17         }\r
18 \r
19         elm = dom.getParent(inst.selection.getNode(), 'table');\r
20 \r
21         // Get form data\r
22         cols = formObj.elements['cols'].value;\r
23         rows = formObj.elements['rows'].value;\r
24         border = formObj.elements['border'].value != "" ? formObj.elements['border'].value : 0;\r
25         cellpadding = formObj.elements['cellpadding'].value != "" ? formObj.elements['cellpadding'].value : "";\r
26         cellspacing = formObj.elements['cellspacing'].value != "" ? formObj.elements['cellspacing'].value : "";\r
27         align = getSelectValue(formObj, "align");\r
28         frame = getSelectValue(formObj, "tframe");\r
29         rules = getSelectValue(formObj, "rules");\r
30         width = formObj.elements['width'].value;\r
31         height = formObj.elements['height'].value;\r
32         bordercolor = formObj.elements['bordercolor'].value;\r
33         bgcolor = formObj.elements['bgcolor'].value;\r
34         className = getSelectValue(formObj, "class");\r
35         id = formObj.elements['id'].value;\r
36         summary = formObj.elements['summary'].value;\r
37         style = formObj.elements['style'].value;\r
38         dir = formObj.elements['dir'].value;\r
39         lang = formObj.elements['lang'].value;\r
40         background = formObj.elements['backgroundimage'].value;\r
41         caption = formObj.elements['caption'].checked;\r
42 \r
43         cellLimit = tinyMCEPopup.getParam('table_cell_limit', false);\r
44         rowLimit = tinyMCEPopup.getParam('table_row_limit', false);\r
45         colLimit = tinyMCEPopup.getParam('table_col_limit', false);\r
46 \r
47         // Validate table size\r
48         if (colLimit && cols > colLimit) {\r
49                 tinyMCEPopup.alert(inst.getLang('table_dlg.col_limit').replace(/\{\$cols\}/g, colLimit));\r
50                 return false;\r
51         } else if (rowLimit && rows > rowLimit) {\r
52                 tinyMCEPopup.alert(inst.getLang('table_dlg.row_limit').replace(/\{\$rows\}/g, rowLimit));\r
53                 return false;\r
54         } else if (cellLimit && cols * rows > cellLimit) {\r
55                 tinyMCEPopup.alert(inst.getLang('table_dlg.cell_limit').replace(/\{\$cells\}/g, cellLimit));\r
56                 return false;\r
57         }\r
58 \r
59         // Update table\r
60         if (action == "update") {\r
61                 dom.setAttrib(elm, 'cellPadding', cellpadding, true);\r
62                 dom.setAttrib(elm, 'cellSpacing', cellspacing, true);\r
63                 dom.setAttrib(elm, 'border', border);\r
64                 dom.setAttrib(elm, 'align', align);\r
65                 dom.setAttrib(elm, 'frame', frame);\r
66                 dom.setAttrib(elm, 'rules', rules);\r
67                 dom.setAttrib(elm, 'class', className);\r
68                 dom.setAttrib(elm, 'style', style);\r
69                 dom.setAttrib(elm, 'id', id);\r
70                 dom.setAttrib(elm, 'summary', summary);\r
71                 dom.setAttrib(elm, 'dir', dir);\r
72                 dom.setAttrib(elm, 'lang', lang);\r
73 \r
74                 capEl = inst.dom.select('caption', elm)[0];\r
75 \r
76                 if (capEl && !caption)\r
77                         capEl.parentNode.removeChild(capEl);\r
78 \r
79                 if (!capEl && caption) {\r
80                         capEl = elm.ownerDocument.createElement('caption');\r
81 \r
82                         if (!tinymce.isIE)\r
83                                 capEl.innerHTML = '<br data-mce-bogus="1"/>';\r
84 \r
85                         elm.insertBefore(capEl, elm.firstChild);\r
86                 }\r
87 \r
88                 if (width && inst.settings.inline_styles) {\r
89                         dom.setStyle(elm, 'width', width);\r
90                         dom.setAttrib(elm, 'width', '');\r
91                 } else {\r
92                         dom.setAttrib(elm, 'width', width, true);\r
93                         dom.setStyle(elm, 'width', '');\r
94                 }\r
95 \r
96                 // Remove these since they are not valid XHTML\r
97                 dom.setAttrib(elm, 'borderColor', '');\r
98                 dom.setAttrib(elm, 'bgColor', '');\r
99                 dom.setAttrib(elm, 'background', '');\r
100 \r
101                 if (height && inst.settings.inline_styles) {\r
102                         dom.setStyle(elm, 'height', height);\r
103                         dom.setAttrib(elm, 'height', '');\r
104                 } else {\r
105                         dom.setAttrib(elm, 'height', height, true);\r
106                         dom.setStyle(elm, 'height', '');\r
107                 }\r
108 \r
109                 if (background != '')\r
110                         elm.style.backgroundImage = "url('" + background + "')";\r
111                 else\r
112                         elm.style.backgroundImage = '';\r
113 \r
114 /*              if (tinyMCEPopup.getParam("inline_styles")) {\r
115                         if (width != '')\r
116                                 elm.style.width = getCSSSize(width);\r
117                 }*/\r
118 \r
119                 if (bordercolor != "") {\r
120                         elm.style.borderColor = bordercolor;\r
121                         elm.style.borderStyle = elm.style.borderStyle == "" ? "solid" : elm.style.borderStyle;\r
122                         elm.style.borderWidth = border == "" ? "1px" : border;\r
123                 } else\r
124                         elm.style.borderColor = '';\r
125 \r
126                 elm.style.backgroundColor = bgcolor;\r
127                 elm.style.height = getCSSSize(height);\r
128 \r
129                 inst.addVisual();\r
130 \r
131                 // Fix for stange MSIE align bug\r
132                 //elm.outerHTML = elm.outerHTML;\r
133 \r
134                 inst.nodeChanged();\r
135                 inst.execCommand('mceEndUndoLevel');\r
136 \r
137                 // Repaint if dimensions changed\r
138                 if (formObj.width.value != orgTableWidth || formObj.height.value != orgTableHeight)\r
139                         inst.execCommand('mceRepaint');\r
140 \r
141                 tinyMCEPopup.close();\r
142                 return true;\r
143         }\r
144 \r
145         // Create new table\r
146         html += '<table';\r
147 \r
148         html += makeAttrib('id', id);\r
149         html += makeAttrib('border', border);\r
150         html += makeAttrib('cellpadding', cellpadding);\r
151         html += makeAttrib('cellspacing', cellspacing);\r
152         html += makeAttrib('data-mce-new', '1');\r
153 \r
154         if (width && inst.settings.inline_styles) {\r
155                 if (style)\r
156                         style += '; ';\r
157 \r
158                 // Force px\r
159                 if (/^[0-9\.]+$/.test(width))\r
160                         width += 'px';\r
161 \r
162                 style += 'width: ' + width;\r
163         } else\r
164                 html += makeAttrib('width', width);\r
165 \r
166 /*      if (height) {\r
167                 if (style)\r
168                         style += '; ';\r
169 \r
170                 style += 'height: ' + height;\r
171         }*/\r
172 \r
173         //html += makeAttrib('height', height);\r
174         //html += makeAttrib('bordercolor', bordercolor);\r
175         //html += makeAttrib('bgcolor', bgcolor);\r
176         html += makeAttrib('align', align);\r
177         html += makeAttrib('frame', frame);\r
178         html += makeAttrib('rules', rules);\r
179         html += makeAttrib('class', className);\r
180         html += makeAttrib('style', style);\r
181         html += makeAttrib('summary', summary);\r
182         html += makeAttrib('dir', dir);\r
183         html += makeAttrib('lang', lang);\r
184         html += '>';\r
185 \r
186         if (caption) {\r
187                 if (!tinymce.isIE)\r
188                         html += '<caption><br data-mce-bogus="1"/></caption>';\r
189                 else\r
190                         html += '<caption></caption>';\r
191         }\r
192 \r
193         for (var y=0; y<rows; y++) {\r
194                 html += "<tr>";\r
195 \r
196                 for (var x=0; x<cols; x++) {\r
197                         if (!tinymce.isIE)\r
198                                 html += '<td><br data-mce-bogus="1"/></td>';\r
199                         else\r
200                                 html += '<td></td>';\r
201                 }\r
202 \r
203                 html += "</tr>";\r
204         }\r
205 \r
206         html += "</table>";\r
207 \r
208         // Move table\r
209         if (inst.settings.fix_table_elements) {\r
210                 var patt = '';\r
211 \r
212                 inst.focus();\r
213                 inst.selection.setContent('<br class="_mce_marker" />');\r
214 \r
215                 tinymce.each('h1,h2,h3,h4,h5,h6,p'.split(','), function(n) {\r
216                         if (patt)\r
217                                 patt += ',';\r
218 \r
219                         patt += n + ' ._mce_marker';\r
220                 });\r
221 \r
222                 tinymce.each(inst.dom.select(patt), function(n) {\r
223                         inst.dom.split(inst.dom.getParent(n, 'h1,h2,h3,h4,h5,h6,p'), n);\r
224                 });\r
225 \r
226                 dom.setOuterHTML(dom.select('br._mce_marker')[0], html);\r
227         } else\r
228                 inst.execCommand('mceInsertContent', false, html);\r
229 \r
230         tinymce.each(dom.select('table[data-mce-new]'), function(node) {\r
231                 var td = dom.select('td', node);\r
232 \r
233                 try {\r
234                         // IE9 might fail to do this selection\r
235                         inst.selection.select(td[0], true);\r
236                         inst.selection.collapse();\r
237                 } catch (ex) {\r
238                         // Ignore\r
239                 }\r
240 \r
241                 dom.setAttrib(node, 'data-mce-new', '');\r
242         });\r
243 \r
244         inst.addVisual();\r
245         inst.execCommand('mceEndUndoLevel');\r
246 \r
247         tinyMCEPopup.close();\r
248 }\r
249 \r
250 function makeAttrib(attrib, value) {\r
251         var formObj = document.forms[0];\r
252         var valueElm = formObj.elements[attrib];\r
253 \r
254         if (typeof(value) == "undefined" || value == null) {\r
255                 value = "";\r
256 \r
257                 if (valueElm)\r
258                         value = valueElm.value;\r
259         }\r
260 \r
261         if (value == "")\r
262                 return "";\r
263 \r
264         // XML encode it\r
265         value = value.replace(/&/g, '&amp;');\r
266         value = value.replace(/\"/g, '&quot;');\r
267         value = value.replace(/</g, '&lt;');\r
268         value = value.replace(/>/g, '&gt;');\r
269 \r
270         return ' ' + attrib + '="' + value + '"';\r
271 }\r
272 \r
273 function init() {\r
274         tinyMCEPopup.resizeToInnerSize();\r
275 \r
276         document.getElementById('backgroundimagebrowsercontainer').innerHTML = getBrowserHTML('backgroundimagebrowser','backgroundimage','image','table');\r
277         document.getElementById('backgroundimagebrowsercontainer').innerHTML = getBrowserHTML('backgroundimagebrowser','backgroundimage','image','table');\r
278         document.getElementById('bordercolor_pickcontainer').innerHTML = getColorPickerHTML('bordercolor_pick','bordercolor');\r
279         document.getElementById('bgcolor_pickcontainer').innerHTML = getColorPickerHTML('bgcolor_pick','bgcolor');\r
280 \r
281         var cols = 2, rows = 2, border = tinyMCEPopup.getParam('table_default_border', '0'), cellpadding = tinyMCEPopup.getParam('table_default_cellpadding', ''), cellspacing = tinyMCEPopup.getParam('table_default_cellspacing', '');\r
282         var align = "", width = "", height = "", bordercolor = "", bgcolor = "", className = "";\r
283         var id = "", summary = "", style = "", dir = "", lang = "", background = "", bgcolor = "", bordercolor = "", rules = "", frame = "";\r
284         var inst = tinyMCEPopup.editor, dom = inst.dom;\r
285         var formObj = document.forms[0];\r
286         var elm = dom.getParent(inst.selection.getNode(), "table");\r
287 \r
288         action = tinyMCEPopup.getWindowArg('action');\r
289 \r
290         if (!action)\r
291                 action = elm ? "update" : "insert";\r
292 \r
293         if (elm && action != "insert") {\r
294                 var rowsAr = elm.rows;\r
295                 var cols = 0;\r
296                 for (var i=0; i<rowsAr.length; i++)\r
297                         if (rowsAr[i].cells.length > cols)\r
298                                 cols = rowsAr[i].cells.length;\r
299 \r
300                 cols = cols;\r
301                 rows = rowsAr.length;\r
302 \r
303                 st = dom.parseStyle(dom.getAttrib(elm, "style"));\r
304                 border = trimSize(getStyle(elm, 'border', 'borderWidth'));\r
305                 cellpadding = dom.getAttrib(elm, 'cellpadding', "");\r
306                 cellspacing = dom.getAttrib(elm, 'cellspacing', "");\r
307                 width = trimSize(getStyle(elm, 'width', 'width'));\r
308                 height = trimSize(getStyle(elm, 'height', 'height'));\r
309                 bordercolor = convertRGBToHex(getStyle(elm, 'bordercolor', 'borderLeftColor'));\r
310                 bgcolor = convertRGBToHex(getStyle(elm, 'bgcolor', 'backgroundColor'));\r
311                 align = dom.getAttrib(elm, 'align', align);\r
312                 frame = dom.getAttrib(elm, 'frame');\r
313                 rules = dom.getAttrib(elm, 'rules');\r
314                 className = tinymce.trim(dom.getAttrib(elm, 'class').replace(/mceItem.+/g, ''));\r
315                 id = dom.getAttrib(elm, 'id');\r
316                 summary = dom.getAttrib(elm, 'summary');\r
317                 style = dom.serializeStyle(st);\r
318                 dir = dom.getAttrib(elm, 'dir');\r
319                 lang = dom.getAttrib(elm, 'lang');\r
320                 background = getStyle(elm, 'background', 'backgroundImage').replace(new RegExp("url\\(['\"]?([^'\"]*)['\"]?\\)", 'gi'), "$1");\r
321                 formObj.caption.checked = elm.getElementsByTagName('caption').length > 0;\r
322 \r
323                 orgTableWidth = width;\r
324                 orgTableHeight = height;\r
325 \r
326                 action = "update";\r
327                 formObj.insert.value = inst.getLang('update');\r
328         }\r
329 \r
330         addClassesToList('class', "table_styles");\r
331         TinyMCE_EditableSelects.init();\r
332 \r
333         // Update form\r
334         selectByValue(formObj, 'align', align);\r
335         selectByValue(formObj, 'tframe', frame);\r
336         selectByValue(formObj, 'rules', rules);\r
337         selectByValue(formObj, 'class', className, true, true);\r
338         formObj.cols.value = cols;\r
339         formObj.rows.value = rows;\r
340         formObj.border.value = border;\r
341         formObj.cellpadding.value = cellpadding;\r
342         formObj.cellspacing.value = cellspacing;\r
343         formObj.width.value = width;\r
344         formObj.height.value = height;\r
345         formObj.bordercolor.value = bordercolor;\r
346         formObj.bgcolor.value = bgcolor;\r
347         formObj.id.value = id;\r
348         formObj.summary.value = summary;\r
349         formObj.style.value = style;\r
350         formObj.dir.value = dir;\r
351         formObj.lang.value = lang;\r
352         formObj.backgroundimage.value = background;\r
353 \r
354         updateColor('bordercolor_pick', 'bordercolor');\r
355         updateColor('bgcolor_pick', 'bgcolor');\r
356 \r
357         // Resize some elements\r
358         if (isVisible('backgroundimagebrowser'))\r
359                 document.getElementById('backgroundimage').style.width = '180px';\r
360 \r
361         // Disable some fields in update mode\r
362         if (action == "update") {\r
363                 formObj.cols.disabled = true;\r
364                 formObj.rows.disabled = true;\r
365         }\r
366 }\r
367 \r
368 function changedSize() {\r
369         var formObj = document.forms[0];\r
370         var st = dom.parseStyle(formObj.style.value);\r
371 \r
372 /*      var width = formObj.width.value;\r
373         if (width != "")\r
374                 st['width'] = tinyMCEPopup.getParam("inline_styles") ? getCSSSize(width) : "";\r
375         else\r
376                 st['width'] = "";*/\r
377 \r
378         var height = formObj.height.value;\r
379         if (height != "")\r
380                 st['height'] = getCSSSize(height);\r
381         else\r
382                 st['height'] = "";\r
383 \r
384         formObj.style.value = dom.serializeStyle(st);\r
385 }\r
386 \r
387 function changedBackgroundImage() {\r
388         var formObj = document.forms[0];\r
389         var st = dom.parseStyle(formObj.style.value);\r
390 \r
391         st['background-image'] = "url('" + formObj.backgroundimage.value + "')";\r
392 \r
393         formObj.style.value = dom.serializeStyle(st);\r
394 }\r
395 \r
396 function changedBorder() {\r
397         var formObj = document.forms[0];\r
398         var st = dom.parseStyle(formObj.style.value);\r
399 \r
400         // Update border width if the element has a color\r
401         if (formObj.border.value != "" && formObj.bordercolor.value != "")\r
402                 st['border-width'] = formObj.border.value + "px";\r
403 \r
404         formObj.style.value = dom.serializeStyle(st);\r
405 }\r
406 \r
407 function changedColor() {\r
408         var formObj = document.forms[0];\r
409         var st = dom.parseStyle(formObj.style.value);\r
410 \r
411         st['background-color'] = formObj.bgcolor.value;\r
412 \r
413         if (formObj.bordercolor.value != "") {\r
414                 st['border-color'] = formObj.bordercolor.value;\r
415 \r
416                 // Add border-width if it's missing\r
417                 if (!st['border-width'])\r
418                         st['border-width'] = formObj.border.value == "" ? "1px" : formObj.border.value + "px";\r
419         }\r
420 \r
421         formObj.style.value = dom.serializeStyle(st);\r
422 }\r
423 \r
424 function changedStyle() {\r
425         var formObj = document.forms[0];\r
426         var st = dom.parseStyle(formObj.style.value);\r
427 \r
428         if (st['background-image'])\r
429                 formObj.backgroundimage.value = st['background-image'].replace(new RegExp("url\\(['\"]?([^'\"]*)['\"]?\\)", 'gi'), "$1");\r
430         else\r
431                 formObj.backgroundimage.value = '';\r
432 \r
433         if (st['width'])\r
434                 formObj.width.value = trimSize(st['width']);\r
435 \r
436         if (st['height'])\r
437                 formObj.height.value = trimSize(st['height']);\r
438 \r
439         if (st['background-color']) {\r
440                 formObj.bgcolor.value = st['background-color'];\r
441                 updateColor('bgcolor_pick','bgcolor');\r
442         }\r
443 \r
444         if (st['border-color']) {\r
445                 formObj.bordercolor.value = st['border-color'];\r
446                 updateColor('bordercolor_pick','bordercolor');\r
447         }\r
448 }\r
449 \r
450 tinyMCEPopup.onInit.add(init);\r