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