]> git.donarmstrong.com Git - roundcube.git/blob - program/js/tiny_mce/plugins/table/js/table.js
Merge commit 'upstream/0.2_alpha' into experimental-import
[roundcube.git] / program / js / 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                 alert(inst.getLang('invalid_data'));\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 = formObj.elements['align'].options[formObj.elements['align'].selectedIndex].value;\r
28         frame = formObj.elements['frame'].options[formObj.elements['frame'].selectedIndex].value;\r
29         rules = formObj.elements['rules'].options[formObj.elements['rules'].selectedIndex].value;\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 = formObj.elements['class'].options[formObj.elements['class'].selectedIndex].value;\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                 alert(inst.getLang('table_col_limit', '', true, {cols : colLimit}));\r
50                 return false;\r
51         } else if (rowLimit && rows > rowLimit) {\r
52                 alert(inst.getLang('table_row_limit', '', true, {rows : rowLimit}));\r
53                 return false;\r
54         } else if (cellLimit && cols * rows > cellLimit) {\r
55                 alert(inst.getLang('table_cell_limit', '', true, {cells : cellLimit}));\r
56                 return false;\r
57         }\r
58 \r
59         // Update table\r
60         if (action == "update") {\r
61                 inst.execCommand('mceBeginUndoLevel');\r
62 \r
63                 dom.setAttrib(elm, 'cellPadding', cellpadding, true);\r
64                 dom.setAttrib(elm, 'cellSpacing', cellspacing, true);\r
65                 dom.setAttrib(elm, 'border', border);\r
66                 dom.setAttrib(elm, 'align', align);\r
67                 dom.setAttrib(elm, 'frame', frame);\r
68                 dom.setAttrib(elm, 'rules', rules);\r
69                 dom.setAttrib(elm, 'class', className);\r
70                 dom.setAttrib(elm, 'style', style);\r
71                 dom.setAttrib(elm, 'id', id);\r
72                 dom.setAttrib(elm, 'summary', summary);\r
73                 dom.setAttrib(elm, 'dir', dir);\r
74                 dom.setAttrib(elm, 'lang', lang);\r
75 \r
76                 capEl = inst.dom.select('caption', elm)[0];\r
77 \r
78                 if (capEl && !caption)\r
79                         capEl.parentNode.removeChild(capEl);\r
80 \r
81                 if (!capEl && caption) {\r
82                         capEl = elm.ownerDocument.createElement('caption');\r
83 \r
84                         if (!tinymce.isIE)\r
85                                 capEl.innerHTML = '<br mce_bogus="1"/>';\r
86 \r
87                         elm.insertBefore(capEl, elm.firstChild);\r
88                 }\r
89 \r
90                 if (width && /(pt|em|cm)$/.test(width)) {\r
91                         dom.setStyle(elm, 'width', width);\r
92                         dom.setAttrib(elm, 'width', '');\r
93                 } else {\r
94                         dom.setAttrib(elm, 'width', width, true);\r
95                         dom.setStyle(elm, 'width', '');\r
96                 }\r
97 \r
98                 // Remove these since they are not valid XHTML\r
99                 dom.setAttrib(elm, 'borderColor', '');\r
100                 dom.setAttrib(elm, 'bgColor', '');\r
101                 dom.setAttrib(elm, 'background', '');\r
102 \r
103                 if (height) {\r
104                         dom.setStyle(elm, 'height', height);\r
105                         dom.setAttrib(elm, 'height', '');\r
106                 }\r
107 \r
108                 if (background != '')\r
109                         elm.style.backgroundImage = "url('" + background + "')";\r
110                 else\r
111                         elm.style.backgroundImage = '';\r
112 \r
113 /*              if (tinyMCEPopup.getParam("inline_styles")) {\r
114                         if (width != '')\r
115                                 elm.style.width = getCSSSize(width);\r
116                 }*/\r
117 \r
118                 if (bordercolor != "") {\r
119                         elm.style.borderColor = bordercolor;\r
120                         elm.style.borderStyle = elm.style.borderStyle == "" ? "solid" : elm.style.borderStyle;\r
121                         elm.style.borderWidth = border == "" ? "1px" : border;\r
122                 } else\r
123                         elm.style.borderColor = '';\r
124 \r
125                 elm.style.backgroundColor = bgcolor;\r
126                 elm.style.height = getCSSSize(height);\r
127 \r
128                 inst.addVisual();\r
129 \r
130                 // Fix for stange MSIE align bug\r
131                 //elm.outerHTML = elm.outerHTML;\r
132 \r
133                 inst.nodeChanged();\r
134                 inst.execCommand('mceEndUndoLevel');\r
135 \r
136                 // Repaint if dimensions changed\r
137                 if (formObj.width.value != orgTableWidth || formObj.height.value != orgTableHeight)\r
138                         inst.execCommand('mceRepaint');\r
139 \r
140                 tinyMCEPopup.close();\r
141                 return true;\r
142         }\r
143 \r
144         // Create new table\r
145         html += '<table';\r
146 \r
147         html += makeAttrib('id', id);\r
148         html += makeAttrib('border', border);\r
149         html += makeAttrib('cellpadding', cellpadding);\r
150         html += makeAttrib('cellspacing', cellspacing);\r
151 \r
152         if (width && /(pt|em|cm)$/.test(width)) {\r
153                 if (style)\r
154                         style += '; ';\r
155 \r
156                 style += 'width: ' + width;\r
157         } else\r
158                 html += makeAttrib('width', width);\r
159 \r
160 /*      if (height) {\r
161                 if (style)\r
162                         style += '; ';\r
163 \r
164                 style += 'height: ' + height;\r
165         }*/\r
166 \r
167         //html += makeAttrib('height', height);\r
168         //html += makeAttrib('bordercolor', bordercolor);\r
169         //html += makeAttrib('bgcolor', bgcolor);\r
170         html += makeAttrib('align', align);\r
171         html += makeAttrib('frame', frame);\r
172         html += makeAttrib('rules', rules);\r
173         html += makeAttrib('class', className);\r
174         html += makeAttrib('style', style);\r
175         html += makeAttrib('summary', summary);\r
176         html += makeAttrib('dir', dir);\r
177         html += makeAttrib('lang', lang);\r
178         html += '>';\r
179 \r
180         if (caption) {\r
181                 if (!tinymce.isIE)\r
182                         html += '<caption><br mce_bogus="1"/></caption>';\r
183                 else\r
184                         html += '<caption></caption>';\r
185         }\r
186 \r
187         for (var y=0; y<rows; y++) {\r
188                 html += "<tr>";\r
189 \r
190                 for (var x=0; x<cols; x++) {\r
191                         if (!tinymce.isIE)\r
192                                 html += '<td><br mce_bogus="1"/></td>';\r
193                         else\r
194                                 html += '<td></td>';\r
195                 }\r
196 \r
197                 html += "</tr>";\r
198         }\r
199 \r
200         html += "</table>";\r
201 \r
202         inst.execCommand('mceBeginUndoLevel');\r
203         inst.execCommand('mceInsertContent', false, html);\r
204         inst.addVisual();\r
205         inst.execCommand('mceEndUndoLevel');\r
206 \r
207         tinyMCEPopup.close();\r
208 }\r
209 \r
210 function makeAttrib(attrib, value) {\r
211         var formObj = document.forms[0];\r
212         var valueElm = formObj.elements[attrib];\r
213 \r
214         if (typeof(value) == "undefined" || value == null) {\r
215                 value = "";\r
216 \r
217                 if (valueElm)\r
218                         value = valueElm.value;\r
219         }\r
220 \r
221         if (value == "")\r
222                 return "";\r
223 \r
224         // XML encode it\r
225         value = value.replace(/&/g, '&amp;');\r
226         value = value.replace(/\"/g, '&quot;');\r
227         value = value.replace(/</g, '&lt;');\r
228         value = value.replace(/>/g, '&gt;');\r
229 \r
230         return ' ' + attrib + '="' + value + '"';\r
231 }\r
232 \r
233 function init() {\r
234         tinyMCEPopup.resizeToInnerSize();\r
235 \r
236         document.getElementById('backgroundimagebrowsercontainer').innerHTML = getBrowserHTML('backgroundimagebrowser','backgroundimage','image','table');\r
237         document.getElementById('backgroundimagebrowsercontainer').innerHTML = getBrowserHTML('backgroundimagebrowser','backgroundimage','image','table');\r
238         document.getElementById('bordercolor_pickcontainer').innerHTML = getColorPickerHTML('bordercolor_pick','bordercolor');\r
239         document.getElementById('bgcolor_pickcontainer').innerHTML = getColorPickerHTML('bgcolor_pick','bgcolor');\r
240 \r
241         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
242         var align = "", width = "", height = "", bordercolor = "", bgcolor = "", className = "";\r
243         var id = "", summary = "", style = "", dir = "", lang = "", background = "", bgcolor = "", bordercolor = "", rules, frame;\r
244         var inst = tinyMCEPopup.editor, dom = inst.dom;\r
245         var formObj = document.forms[0];\r
246         var elm = dom.getParent(inst.selection.getNode(), "table");\r
247 \r
248         action = tinyMCEPopup.getWindowArg('action');\r
249 \r
250         if (!action)\r
251                 action = elm ? "update" : "insert";\r
252 \r
253         if (elm && action != "insert") {\r
254                 var rowsAr = elm.rows;\r
255                 var cols = 0;\r
256                 for (var i=0; i<rowsAr.length; i++)\r
257                         if (rowsAr[i].cells.length > cols)\r
258                                 cols = rowsAr[i].cells.length;\r
259 \r
260                 cols = cols;\r
261                 rows = rowsAr.length;\r
262 \r
263                 st = dom.parseStyle(dom.getAttrib(elm, "style"));\r
264                 border = trimSize(getStyle(elm, 'border', 'borderWidth'));\r
265                 cellpadding = dom.getAttrib(elm, 'cellpadding', "");\r
266                 cellspacing = dom.getAttrib(elm, 'cellspacing', "");\r
267                 width = trimSize(getStyle(elm, 'width', 'width'));\r
268                 height = trimSize(getStyle(elm, 'height', 'height'));\r
269                 bordercolor = convertRGBToHex(getStyle(elm, 'bordercolor', 'borderLeftColor'));\r
270                 bgcolor = convertRGBToHex(getStyle(elm, 'bgcolor', 'backgroundColor'));\r
271                 align = dom.getAttrib(elm, 'align', align);\r
272                 frame = dom.getAttrib(elm, 'frame');\r
273                 rules = dom.getAttrib(elm, 'rules');\r
274                 className = tinymce.trim(dom.getAttrib(elm, 'class').replace(/mceItem.+/g, ''));\r
275                 id = dom.getAttrib(elm, 'id');\r
276                 summary = dom.getAttrib(elm, 'summary');\r
277                 style = dom.serializeStyle(st);\r
278                 dir = dom.getAttrib(elm, 'dir');\r
279                 lang = dom.getAttrib(elm, 'lang');\r
280                 background = getStyle(elm, 'background', 'backgroundImage').replace(new RegExp("url\\('?([^']*)'?\\)", 'gi'), "$1");\r
281                 formObj.caption.checked = elm.getElementsByTagName('caption').length > 0;\r
282 \r
283                 orgTableWidth = width;\r
284                 orgTableHeight = height;\r
285 \r
286                 action = "update";\r
287                 formObj.insert.value = inst.getLang('update');\r
288         }\r
289 \r
290         addClassesToList('class', "table_styles");\r
291         TinyMCE_EditableSelects.init();\r
292 \r
293         // Update form\r
294         selectByValue(formObj, 'align', align);\r
295         selectByValue(formObj, 'frame', frame);\r
296         selectByValue(formObj, 'rules', rules);\r
297         selectByValue(formObj, 'class', className, true, true);\r
298         formObj.cols.value = cols;\r
299         formObj.rows.value = rows;\r
300         formObj.border.value = border;\r
301         formObj.cellpadding.value = cellpadding;\r
302         formObj.cellspacing.value = cellspacing;\r
303         formObj.width.value = width;\r
304         formObj.height.value = height;\r
305         formObj.bordercolor.value = bordercolor;\r
306         formObj.bgcolor.value = bgcolor;\r
307         formObj.id.value = id;\r
308         formObj.summary.value = summary;\r
309         formObj.style.value = style;\r
310         formObj.dir.value = dir;\r
311         formObj.lang.value = lang;\r
312         formObj.backgroundimage.value = background;\r
313 \r
314         updateColor('bordercolor_pick', 'bordercolor');\r
315         updateColor('bgcolor_pick', 'bgcolor');\r
316 \r
317         // Resize some elements\r
318         if (isVisible('backgroundimagebrowser'))\r
319                 document.getElementById('backgroundimage').style.width = '180px';\r
320 \r
321         // Disable some fields in update mode\r
322         if (action == "update") {\r
323                 formObj.cols.disabled = true;\r
324                 formObj.rows.disabled = true;\r
325         }\r
326 }\r
327 \r
328 function changedSize() {\r
329         var formObj = document.forms[0];\r
330         var st = dom.parseStyle(formObj.style.value);\r
331 \r
332 /*      var width = formObj.width.value;\r
333         if (width != "")\r
334                 st['width'] = tinyMCEPopup.getParam("inline_styles") ? getCSSSize(width) : "";\r
335         else\r
336                 st['width'] = "";*/\r
337 \r
338         var height = formObj.height.value;\r
339         if (height != "")\r
340                 st['height'] = getCSSSize(height);\r
341         else\r
342                 st['height'] = "";\r
343 \r
344         formObj.style.value = dom.serializeStyle(st);\r
345 }\r
346 \r
347 function changedBackgroundImage() {\r
348         var formObj = document.forms[0];\r
349         var st = dom.parseStyle(formObj.style.value);\r
350 \r
351         st['background-image'] = "url('" + formObj.backgroundimage.value + "')";\r
352 \r
353         formObj.style.value = dom.serializeStyle(st);\r
354 }\r
355 \r
356 function changedBorder() {\r
357         var formObj = document.forms[0];\r
358         var st = dom.parseStyle(formObj.style.value);\r
359 \r
360         // Update border width if the element has a color\r
361         if (formObj.border.value != "" && formObj.bordercolor.value != "")\r
362                 st['border-width'] = formObj.border.value + "px";\r
363 \r
364         formObj.style.value = dom.serializeStyle(st);\r
365 }\r
366 \r
367 function changedColor() {\r
368         var formObj = document.forms[0];\r
369         var st = dom.parseStyle(formObj.style.value);\r
370 \r
371         st['background-color'] = formObj.bgcolor.value;\r
372 \r
373         if (formObj.bordercolor.value != "") {\r
374                 st['border-color'] = formObj.bordercolor.value;\r
375 \r
376                 // Add border-width if it's missing\r
377                 if (!st['border-width'])\r
378                         st['border-width'] = formObj.border.value == "" ? "1px" : formObj.border.value + "px";\r
379         }\r
380 \r
381         formObj.style.value = dom.serializeStyle(st);\r
382 }\r
383 \r
384 function changedStyle() {\r
385         var formObj = document.forms[0];\r
386         var st = dom.parseStyle(formObj.style.value);\r
387 \r
388         if (st['background-image'])\r
389                 formObj.backgroundimage.value = st['background-image'].replace(new RegExp("url\\('?([^']*)'?\\)", 'gi'), "$1");\r
390         else\r
391                 formObj.backgroundimage.value = '';\r
392 \r
393         if (st['width'])\r
394                 formObj.width.value = trimSize(st['width']);\r
395 \r
396         if (st['height'])\r
397                 formObj.height.value = trimSize(st['height']);\r
398 \r
399         if (st['background-color']) {\r
400                 formObj.bgcolor.value = st['background-color'];\r
401                 updateColor('bgcolor_pick','bgcolor');\r
402         }\r
403 \r
404         if (st['border-color']) {\r
405                 formObj.bordercolor.value = st['border-color'];\r
406                 updateColor('bordercolor_pick','bordercolor');\r
407         }\r
408 }\r
409 \r
410 tinyMCEPopup.onInit.add(init);\r