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