webcit_before_automake is now the trunk
[citadel.git] / webcit / tiny_mce / plugins / table / jscripts / table.js
1 var action, orgTableWidth, orgTableHeight;\r
2 \r
3 function insertTable() {\r
4         tinyMCEPopup.restoreSelection();\r
5 \r
6         var formObj = document.forms[0];\r
7         var inst = tinyMCE.selectedInstance;\r
8         var cols = 2, rows = 2, border = 0, cellpadding = -1, cellspacing = -1, align, width, height, className;\r
9         var html = '';\r
10         var elm = tinyMCE.tableElm;\r
11 \r
12         // Get form data\r
13         cols = formObj.elements['cols'].value;\r
14         rows = formObj.elements['rows'].value;\r
15         border = formObj.elements['border'].value != "" ? formObj.elements['border'].value  : 0;\r
16         cellpadding = formObj.elements['cellpadding'].value != "" ? formObj.elements['cellpadding'].value : "";\r
17         cellspacing = formObj.elements['cellspacing'].value != "" ? formObj.elements['cellspacing'].value : "";\r
18         align = formObj.elements['align'].options[formObj.elements['align'].selectedIndex].value;\r
19         width = formObj.elements['width'].value;\r
20         height = formObj.elements['height'].value;\r
21         bordercolor = formObj.elements['bordercolor'].value;\r
22         bgcolor = formObj.elements['bgcolor'].value;\r
23         className = formObj.elements['class'].options[formObj.elements['class'].selectedIndex].value;\r
24         id = formObj.elements['id'].value;\r
25         summary = formObj.elements['summary'].value;\r
26         style = formObj.elements['style'].value;\r
27         dir = formObj.elements['dir'].value;\r
28         lang = formObj.elements['lang'].value;\r
29         background = formObj.elements['backgroundimage'].value;\r
30 \r
31         // Update table\r
32         if (action == "update") {\r
33                 inst.execCommand('mceBeginUndoLevel');\r
34 \r
35                 tinyMCE.setAttrib(elm, 'cellPadding', cellpadding, true);\r
36                 tinyMCE.setAttrib(elm, 'cellSpacing', cellspacing, true);\r
37                 tinyMCE.setAttrib(elm, 'border', border, true);\r
38                 tinyMCE.setAttrib(elm, 'align', align);\r
39                 tinyMCE.setAttrib(elm, 'class', className);\r
40                 tinyMCE.setAttrib(elm, 'style', style);\r
41                 tinyMCE.setAttrib(elm, 'id', id);\r
42                 tinyMCE.setAttrib(elm, 'summary', summary);\r
43                 tinyMCE.setAttrib(elm, 'dir', dir);\r
44                 tinyMCE.setAttrib(elm, 'lang', lang);\r
45 \r
46                 // Not inline styles\r
47                 if (!tinyMCE.getParam("inline_styles"))\r
48                         tinyMCE.setAttrib(elm, 'width', width, true);\r
49 \r
50                 // Remove these since they are not valid XHTML\r
51                 tinyMCE.setAttrib(elm, 'borderColor', '');\r
52                 tinyMCE.setAttrib(elm, 'bgColor', '');\r
53                 tinyMCE.setAttrib(elm, 'background', '');\r
54                 tinyMCE.setAttrib(elm, 'height', '');\r
55 \r
56                 if (background != '')\r
57                         elm.style.backgroundImage = "url('" + background + "')";\r
58                 else\r
59                         elm.style.backgroundImage = '';\r
60 \r
61                 if (tinyMCE.getParam("inline_styles"))\r
62                         elm.style.borderWidth = border + "px";\r
63 \r
64                 if (tinyMCE.getParam("inline_styles")) {\r
65                         if (width != '')\r
66                                 elm.style.width = getCSSSize(width);\r
67                 }\r
68 \r
69                 if (bordercolor != "") {\r
70                         elm.style.borderColor = bordercolor;\r
71                         elm.style.borderStyle = elm.style.borderStyle == "" ? "solid" : elm.style.borderStyle;\r
72                         elm.style.borderWidth = border == "" ? "1px" : border;\r
73                 } else\r
74                         elm.style.borderColor = '';\r
75 \r
76                 elm.style.backgroundColor = bgcolor;\r
77                 elm.style.height = getCSSSize(height);\r
78 \r
79                 tinyMCE.handleVisualAid(tinyMCE.tableElm, false, inst.visualAid, inst);\r
80 \r
81                 // Fix for stange MSIE align bug\r
82                 tinyMCE.tableElm.outerHTML = tinyMCE.tableElm.outerHTML;\r
83 \r
84                 tinyMCE.handleVisualAid(inst.getBody(), true, inst.visualAid, inst);\r
85                 tinyMCE.triggerNodeChange();\r
86                 inst.execCommand('mceEndUndoLevel');\r
87 \r
88                 // Repaint if dimensions changed\r
89                 if (formObj.width.value != orgTableWidth || formObj.height.value != orgTableHeight)\r
90                         inst.repaint();\r
91 \r
92                 tinyMCEPopup.close();\r
93                 return true;\r
94         }\r
95 \r
96         // Create new table\r
97         html += '<table';\r
98 \r
99         html += makeAttrib('id', id);\r
100         html += makeAttrib('border', border);\r
101         html += makeAttrib('cellpadding', cellpadding);\r
102         html += makeAttrib('cellspacing', cellspacing);\r
103         html += makeAttrib('width', width);\r
104         //html += makeAttrib('height', height);\r
105         //html += makeAttrib('bordercolor', bordercolor);\r
106         //html += makeAttrib('bgcolor', bgcolor);\r
107         html += makeAttrib('align', align);\r
108         html += makeAttrib('class', tinyMCE.getVisualAidClass(className, border == 0));\r
109         html += makeAttrib('style', style);\r
110         html += makeAttrib('summary', summary);\r
111         html += makeAttrib('dir', dir);\r
112         html += makeAttrib('lang', lang);\r
113 \r
114         html += '>';\r
115 \r
116         for (var y=0; y<rows; y++) {\r
117                 html += "<tr>";\r
118 \r
119                 for (var x=0; x<cols; x++)\r
120                         html += '<td>&nbsp;</td>';\r
121 \r
122                 html += "</tr>";\r
123         }\r
124 \r
125         html += "</table>";\r
126 \r
127         inst.execCommand('mceBeginUndoLevel');\r
128         inst.execCommand('mceInsertContent', false, html);\r
129         tinyMCE.handleVisualAid(inst.getBody(), true, tinyMCE.settings['visual']);\r
130         inst.execCommand('mceEndUndoLevel');\r
131 \r
132         tinyMCEPopup.close();\r
133 }\r
134 \r
135 function makeAttrib(attrib, value) {\r
136         var formObj = document.forms[0];\r
137         var valueElm = formObj.elements[attrib];\r
138 \r
139         if (typeof(value) == "undefined" || value == null) {\r
140                 value = "";\r
141 \r
142                 if (valueElm)\r
143                         value = valueElm.value;\r
144         }\r
145 \r
146         if (value == "")\r
147                 return "";\r
148 \r
149         // XML encode it\r
150         value = value.replace(/&/g, '&amp;');\r
151         value = value.replace(/\"/g, '&quot;');\r
152         value = value.replace(/</g, '&lt;');\r
153         value = value.replace(/>/g, '&gr;');\r
154 \r
155         return ' ' + attrib + '="' + value + '"';\r
156 }\r
157 \r
158 function init() {\r
159         tinyMCEPopup.resizeToInnerSize();\r
160 \r
161         document.getElementById('backgroundimagebrowsercontainer').innerHTML = getBrowserHTML('backgroundimagebrowser','backgroundimage','image','table');\r
162         document.getElementById('backgroundimagebrowsercontainer').innerHTML = getBrowserHTML('backgroundimagebrowser','backgroundimage','image','table');\r
163         document.getElementById('bordercolor_pickcontainer').innerHTML = getColorPickerHTML('bordercolor_pick','bordercolor');\r
164         document.getElementById('bgcolor_pickcontainer').innerHTML = getColorPickerHTML('bgcolor_pick','bgcolor');\r
165 \r
166         var cols = 2, rows = 2, border = 0, cellpadding = "", cellspacing = "";\r
167         var align = "", width = "", height = "", bordercolor = "", bgcolor = "", className = "";\r
168         var id = "", summary = "", style = "", dir = "", lang = "", background = "", bgcolor = "", bordercolor = "";\r
169         var inst = tinyMCE.selectedInstance;\r
170         var formObj = document.forms[0];\r
171         var elm = tinyMCE.getParentElement(inst.getFocusElement(), "table");\r
172 \r
173         tinyMCE.tableElm = elm;\r
174         action = tinyMCE.getWindowArg('action');\r
175         if (action == null)\r
176                 action = tinyMCE.tableElm ? "update" : "insert";\r
177 \r
178         if (tinyMCE.tableElm && action != "insert") {\r
179                 var rowsAr = tinyMCE.tableElm.rows;\r
180                 var cols = 0;\r
181                 for (var i=0; i<rowsAr.length; i++)\r
182                         if (rowsAr[i].cells.length > cols)\r
183                                 cols = rowsAr[i].cells.length;\r
184 \r
185                 cols = cols;\r
186                 rows = rowsAr.length;\r
187 \r
188                 st = tinyMCE.parseStyle(tinyMCE.getAttrib(tinyMCE.tableElm, "style"));\r
189                 border = trimSize(getStyle(elm, 'border', 'borderWidth'));\r
190                 cellpadding = tinyMCE.getAttrib(tinyMCE.tableElm, 'cellpadding', "");\r
191                 cellspacing = tinyMCE.getAttrib(tinyMCE.tableElm, 'cellspacing', "");\r
192                 width = trimSize(getStyle(elm, 'width', 'width'));\r
193                 height = trimSize(getStyle(elm, 'height', 'height'));\r
194                 bordercolor = convertRGBToHex(getStyle(elm, 'bordercolor', 'borderLeftColor'));\r
195                 bgcolor = convertRGBToHex(getStyle(elm, 'bgcolor', 'backgroundColor'));\r
196                 align = tinyMCE.getAttrib(tinyMCE.tableElm, 'align', align);\r
197                 className = tinyMCE.getVisualAidClass(tinyMCE.getAttrib(tinyMCE.tableElm, 'class'), false);\r
198                 id = tinyMCE.getAttrib(tinyMCE.tableElm, 'id');\r
199                 summary = tinyMCE.getAttrib(tinyMCE.tableElm, 'summary');\r
200                 style = tinyMCE.serializeStyle(st);\r
201                 dir = tinyMCE.getAttrib(tinyMCE.tableElm, 'dir');\r
202                 lang = tinyMCE.getAttrib(tinyMCE.tableElm, 'lang');\r
203                 background = getStyle(elm, 'background', 'backgroundImage').replace(new RegExp("url\\('?([^']*)'?\\)", 'gi'), "$1");\r
204 \r
205                 orgTableWidth = width;\r
206                 orgTableHeight = height;\r
207 \r
208                 action = "update";\r
209         }\r
210 \r
211         addClassesToList('class', "table_styles");\r
212 \r
213         // Update form\r
214         selectByValue(formObj, 'align', align);\r
215         selectByValue(formObj, 'class', className);\r
216         formObj.cols.value = cols;\r
217         formObj.rows.value = rows;\r
218         formObj.border.value = border;\r
219         formObj.cellpadding.value = cellpadding;\r
220         formObj.cellspacing.value = cellspacing;\r
221         formObj.width.value = width;\r
222         formObj.height.value = height;\r
223         formObj.bordercolor.value = bordercolor;\r
224         formObj.bgcolor.value = bgcolor;\r
225         formObj.id.value = id;\r
226         formObj.summary.value = summary;\r
227         formObj.style.value = style;\r
228         formObj.dir.value = dir;\r
229         formObj.lang.value = lang;\r
230         formObj.backgroundimage.value = background;\r
231         formObj.insert.value = tinyMCE.getLang('lang_' + action, 'Insert', true); \r
232 \r
233         updateColor('bordercolor_pick', 'bordercolor');\r
234         updateColor('bgcolor_pick', 'bgcolor');\r
235 \r
236         // Resize some elements\r
237         if (isVisible('backgroundimagebrowser'))\r
238                 document.getElementById('backgroundimage').style.width = '180px';\r
239 \r
240         // Disable some fields in update mode\r
241         if (action == "update") {\r
242                 formObj.cols.disabled = true;\r
243                 formObj.rows.disabled = true;\r
244         }\r
245 }\r
246 \r
247 function changedSize() {\r
248         var formObj = document.forms[0];\r
249         var st = tinyMCE.parseStyle(formObj.style.value);\r
250 \r
251         var width = formObj.width.value;\r
252         if (width != "")\r
253                 st['width'] = tinyMCE.getParam("inline_styles") ? getCSSSize(width) : "";\r
254         else\r
255                 st['width'] = "";\r
256 \r
257         var height = formObj.height.value;\r
258         if (height != "")\r
259                 st['height'] = getCSSSize(height);\r
260         else\r
261                 st['height'] = "";\r
262 \r
263         formObj.style.value = tinyMCE.serializeStyle(st);\r
264 }\r
265 \r
266 function changedBackgroundImage() {\r
267         var formObj = document.forms[0];\r
268         var st = tinyMCE.parseStyle(formObj.style.value);\r
269 \r
270         st['background-image'] = "url('" + formObj.backgroundimage.value + "')";\r
271 \r
272         formObj.style.value = tinyMCE.serializeStyle(st);\r
273 }\r
274 \r
275 function changedBorder() {\r
276         var formObj = document.forms[0];\r
277         var st = tinyMCE.parseStyle(formObj.style.value);\r
278 \r
279         // Update border width if the element has a color\r
280         if (formObj.border.value != "" && formObj.bordercolor.value != "")\r
281                 st['border-width'] = formObj.border.value + "px";\r
282 \r
283         formObj.style.value = tinyMCE.serializeStyle(st);\r
284 }\r
285 \r
286 function changedColor() {\r
287         var formObj = document.forms[0];\r
288         var st = tinyMCE.parseStyle(formObj.style.value);\r
289 \r
290         st['background-color'] = formObj.bgcolor.value;\r
291 \r
292         if (formObj.bordercolor.value != "") {\r
293                 st['border-color'] = formObj.bordercolor.value;\r
294 \r
295                 // Add border-width if it's missing\r
296                 if (!st['border-width'])\r
297                         st['border-width'] = formObj.border.value == "" ? "1px" : formObj.border.value + "px";\r
298         }\r
299 \r
300         formObj.style.value = tinyMCE.serializeStyle(st);\r
301 }\r
302 \r
303 function changedStyle() {\r
304         var formObj = document.forms[0];\r
305         var st = tinyMCE.parseStyle(formObj.style.value);\r
306 \r
307         if (st['background-image'])\r
308                 formObj.backgroundimage.value = st['background-image'].replace(new RegExp("url\\('?([^']*)'?\\)", 'gi'), "$1");\r
309         else\r
310                 formObj.backgroundimage.value = '';\r
311 \r
312         if (st['width'])\r
313                 formObj.width.value = trimSize(st['width']);\r
314 \r
315         if (st['height'])\r
316                 formObj.height.value = trimSize(st['height']);\r
317 \r
318         if (st['background-color']) {\r
319                 formObj.bgcolor.value = st['background-color'];\r
320                 updateColor('bgcolor_pick','bgcolor');\r
321         }\r
322 \r
323         if (st['border-color']) {\r
324                 formObj.bordercolor.value = st['border-color'];\r
325                 updateColor('bordercolor_pick','bordercolor');\r
326         }\r
327 }\r