]> git.mxchange.org Git - friendica.git/blob - library/tinymce/jscripts/tiny_mce/plugins/table/js/table.js
updated tinymce to 3.5.11
[friendica.git] / library / tinymce / jscripts / 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 \r
64                 if (!isCssSize(border)) {\r
65                         dom.setAttrib(elm, 'border', border);\r
66                 } else {\r
67                         dom.setAttrib(elm, 'border', '');\r
68                 }\r
69 \r
70                 if (border == '') {\r
71                         dom.setStyle(elm, 'border-width', '');\r
72                         dom.setStyle(elm, 'border', '');\r
73                         dom.setAttrib(elm, 'border', '');\r
74                 }\r
75 \r
76                 dom.setAttrib(elm, 'align', align);\r
77                 dom.setAttrib(elm, 'frame', frame);\r
78                 dom.setAttrib(elm, 'rules', rules);\r
79                 dom.setAttrib(elm, 'class', className);\r
80                 dom.setAttrib(elm, 'style', style);\r
81                 dom.setAttrib(elm, 'id', id);\r
82                 dom.setAttrib(elm, 'summary', summary);\r
83                 dom.setAttrib(elm, 'dir', dir);\r
84                 dom.setAttrib(elm, 'lang', lang);\r
85 \r
86                 capEl = inst.dom.select('caption', elm)[0];\r
87 \r
88                 if (capEl && !caption)\r
89                         capEl.parentNode.removeChild(capEl);\r
90 \r
91                 if (!capEl && caption) {\r
92                         capEl = elm.ownerDocument.createElement('caption');\r
93 \r
94                         if (!tinymce.isIE || tinymce.isIE11)\r
95                                 capEl.innerHTML = '<br data-mce-bogus="1"/>';\r
96 \r
97                         elm.insertBefore(capEl, elm.firstChild);\r
98                 }\r
99 \r
100                 if (width && inst.settings.inline_styles) {\r
101                         dom.setStyle(elm, 'width', width);\r
102                         dom.setAttrib(elm, 'width', '');\r
103                 } else {\r
104                         dom.setAttrib(elm, 'width', width, true);\r
105                         dom.setStyle(elm, 'width', '');\r
106                 }\r
107 \r
108                 // Remove these since they are not valid XHTML\r
109                 dom.setAttrib(elm, 'borderColor', '');\r
110                 dom.setAttrib(elm, 'bgColor', '');\r
111                 dom.setAttrib(elm, 'background', '');\r
112 \r
113                 if (height && inst.settings.inline_styles) {\r
114                         dom.setStyle(elm, 'height', height);\r
115                         dom.setAttrib(elm, 'height', '');\r
116                 } else {\r
117                         dom.setAttrib(elm, 'height', height, true);\r
118                         dom.setStyle(elm, 'height', '');\r
119                 }\r
120 \r
121                 if (background != '')\r
122                         elm.style.backgroundImage = "url('" + background + "')";\r
123                 else\r
124                         elm.style.backgroundImage = '';\r
125 \r
126 /*              if (tinyMCEPopup.getParam("inline_styles")) {\r
127                         if (width != '')\r
128                                 elm.style.width = getCSSSize(width);\r
129                 }*/\r
130 \r
131                 if (bordercolor != "") {\r
132                         elm.style.borderColor = bordercolor;\r
133                         elm.style.borderStyle = elm.style.borderStyle == "" ? "solid" : elm.style.borderStyle;\r
134                         elm.style.borderWidth = cssSize(border);\r
135                 } else\r
136                         elm.style.borderColor = '';\r
137 \r
138                 elm.style.backgroundColor = bgcolor;\r
139                 elm.style.height = getCSSSize(height);\r
140 \r
141                 inst.addVisual();\r
142 \r
143                 // Fix for stange MSIE align bug\r
144                 //elm.outerHTML = elm.outerHTML;\r
145 \r
146                 inst.nodeChanged();\r
147                 inst.execCommand('mceEndUndoLevel', false, {}, {skip_undo: true});\r
148 \r
149                 // Repaint if dimensions changed\r
150                 if (formObj.width.value != orgTableWidth || formObj.height.value != orgTableHeight)\r
151                         inst.execCommand('mceRepaint');\r
152 \r
153                 tinyMCEPopup.close();\r
154                 return true;\r
155         }\r
156 \r
157         // Create new table\r
158         html += '<table';\r
159 \r
160         html += makeAttrib('id', id);\r
161         if (!isCssSize(border)) {\r
162                 html += makeAttrib('border', border);\r
163         }\r
164 \r
165         html += makeAttrib('cellpadding', cellpadding);\r
166         html += makeAttrib('cellspacing', cellspacing);\r
167         html += makeAttrib('data-mce-new', '1');\r
168 \r
169         if (width && inst.settings.inline_styles) {\r
170                 if (style)\r
171                         style += '; ';\r
172 \r
173                 // Force px\r
174                 if (/^[0-9\.]+$/.test(width))\r
175                         width += 'px';\r
176 \r
177                 style += 'width: ' + width;\r
178         } else\r
179                 html += makeAttrib('width', width);\r
180 \r
181 /*      if (height) {\r
182                 if (style)\r
183                         style += '; ';\r
184 \r
185                 style += 'height: ' + height;\r
186         }*/\r
187 \r
188         //html += makeAttrib('height', height);\r
189         //html += makeAttrib('bordercolor', bordercolor);\r
190         //html += makeAttrib('bgcolor', bgcolor);\r
191         html += makeAttrib('align', align);\r
192         html += makeAttrib('frame', frame);\r
193         html += makeAttrib('rules', rules);\r
194         html += makeAttrib('class', className);\r
195         html += makeAttrib('style', style);\r
196         html += makeAttrib('summary', summary);\r
197         html += makeAttrib('dir', dir);\r
198         html += makeAttrib('lang', lang);\r
199         html += '>';\r
200 \r
201         if (caption) {\r
202                 if (!tinymce.isIE || tinymce.isIE11)\r
203                         html += '<caption><br data-mce-bogus="1"/></caption>';\r
204                 else\r
205                         html += '<caption></caption>';\r
206         }\r
207 \r
208         for (var y=0; y<rows; y++) {\r
209                 html += "<tr>";\r
210 \r
211                 for (var x=0; x<cols; x++) {\r
212                         if (!tinymce.isIE || tinymce.isIE11)\r
213                                 html += '<td><br data-mce-bogus="1"/></td>';\r
214                         else\r
215                                 html += '<td></td>';\r
216                 }\r
217 \r
218                 html += "</tr>";\r
219         }\r
220 \r
221         html += "</table>";\r
222 \r
223         // Move table\r
224         if (inst.settings.fix_table_elements) {\r
225                 var patt = '';\r
226 \r
227                 inst.focus();\r
228                 inst.selection.setContent('<br class="_mce_marker" />');\r
229 \r
230                 tinymce.each('h1,h2,h3,h4,h5,h6,p'.split(','), function(n) {\r
231                         if (patt)\r
232                                 patt += ',';\r
233 \r
234                         patt += n + ' ._mce_marker';\r
235                 });\r
236 \r
237                 tinymce.each(inst.dom.select(patt), function(n) {\r
238                         inst.dom.split(inst.dom.getParent(n, 'h1,h2,h3,h4,h5,h6,p'), n);\r
239                 });\r
240 \r
241                 dom.setOuterHTML(dom.select('br._mce_marker')[0], html);\r
242         } else\r
243                 inst.execCommand('mceInsertContent', false, html);\r
244 \r
245         tinymce.each(dom.select('table[data-mce-new]'), function(node) {\r
246                 var tdorth = dom.select('td,th', node);\r
247 \r
248                 // Fixes a bug in IE where the caret cannot be placed after the table if the table is at the end of the document\r
249                 if (tinymce.isIE && !tinymce.isIE11 && node.nextSibling == null) {\r
250                         if (inst.settings.forced_root_block)\r
251                                 dom.insertAfter(dom.create(inst.settings.forced_root_block), node);\r
252                         else\r
253                                 dom.insertAfter(dom.create('br', {'data-mce-bogus': '1'}), node);\r
254                 }\r
255 \r
256                 try {\r
257                         // IE9 might fail to do this selection \r
258                         inst.selection.setCursorLocation(tdorth[0], 0);\r
259                 } catch (ex) {\r
260                         // Ignore\r
261                 }\r
262 \r
263                 dom.setAttrib(node, 'data-mce-new', '');\r
264         });\r
265 \r
266         inst.addVisual();\r
267         inst.execCommand('mceEndUndoLevel', false, {}, {skip_undo: true});\r
268 \r
269         tinyMCEPopup.close();\r
270 }\r
271 \r
272 function makeAttrib(attrib, value) {\r
273         var formObj = document.forms[0];\r
274         var valueElm = formObj.elements[attrib];\r
275 \r
276         if (typeof(value) == "undefined" || value == null) {\r
277                 value = "";\r
278 \r
279                 if (valueElm)\r
280                         value = valueElm.value;\r
281         }\r
282 \r
283         if (value == "")\r
284                 return "";\r
285 \r
286         // XML encode it\r
287         value = value.replace(/&/g, '&amp;');\r
288         value = value.replace(/\"/g, '&quot;');\r
289         value = value.replace(/</g, '&lt;');\r
290         value = value.replace(/>/g, '&gt;');\r
291 \r
292         return ' ' + attrib + '="' + value + '"';\r
293 }\r
294 \r
295 function init() {\r
296         tinyMCEPopup.resizeToInnerSize();\r
297 \r
298         document.getElementById('backgroundimagebrowsercontainer').innerHTML = getBrowserHTML('backgroundimagebrowser','backgroundimage','image','table');\r
299         document.getElementById('backgroundimagebrowsercontainer').innerHTML = getBrowserHTML('backgroundimagebrowser','backgroundimage','image','table');\r
300         document.getElementById('bordercolor_pickcontainer').innerHTML = getColorPickerHTML('bordercolor_pick','bordercolor');\r
301         document.getElementById('bgcolor_pickcontainer').innerHTML = getColorPickerHTML('bgcolor_pick','bgcolor');\r
302 \r
303         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
304         var align = "", width = "", height = "", bordercolor = "", bgcolor = "", className = "";\r
305         var id = "", summary = "", style = "", dir = "", lang = "", background = "", bgcolor = "", bordercolor = "", rules = "", frame = "";\r
306         var inst = tinyMCEPopup.editor, dom = inst.dom;\r
307         var formObj = document.forms[0];\r
308         var elm = dom.getParent(inst.selection.getNode(), "table");\r
309 \r
310         // Hide advanced fields that isn't available in the schema\r
311         tinymce.each("summary id rules dir style frame".split(" "), function(name) {\r
312                 var tr = tinyMCEPopup.dom.getParent(name, "tr") || tinyMCEPopup.dom.getParent("t" + name, "tr");\r
313 \r
314                 if (tr && !tinyMCEPopup.editor.schema.isValid("table", name)) {\r
315                         tr.style.display = 'none';\r
316                 }\r
317         });\r
318 \r
319         action = tinyMCEPopup.getWindowArg('action');\r
320 \r
321         if (!action)\r
322                 action = elm ? "update" : "insert";\r
323 \r
324         if (elm && action != "insert") {\r
325                 var rowsAr = elm.rows;\r
326                 var cols = 0;\r
327                 for (var i=0; i<rowsAr.length; i++)\r
328                         if (rowsAr[i].cells.length > cols)\r
329                                 cols = rowsAr[i].cells.length;\r
330 \r
331                 cols = cols;\r
332                 rows = rowsAr.length;\r
333 \r
334                 st = dom.parseStyle(dom.getAttrib(elm, "style"));\r
335                 border = trimSize(getStyle(elm, 'border', 'borderWidth'));\r
336                 cellpadding = dom.getAttrib(elm, 'cellpadding', "");\r
337                 cellspacing = dom.getAttrib(elm, 'cellspacing', "");\r
338                 width = trimSize(getStyle(elm, 'width', 'width'));\r
339                 height = trimSize(getStyle(elm, 'height', 'height'));\r
340                 bordercolor = convertRGBToHex(getStyle(elm, 'bordercolor', 'borderLeftColor'));\r
341                 bgcolor = convertRGBToHex(getStyle(elm, 'bgcolor', 'backgroundColor'));\r
342                 align = dom.getAttrib(elm, 'align', align);\r
343                 frame = dom.getAttrib(elm, 'frame');\r
344                 rules = dom.getAttrib(elm, 'rules');\r
345                 className = tinymce.trim(dom.getAttrib(elm, 'class').replace(/mceItem.+/g, ''));\r
346                 id = dom.getAttrib(elm, 'id');\r
347                 summary = dom.getAttrib(elm, 'summary');\r
348                 style = dom.serializeStyle(st);\r
349                 dir = dom.getAttrib(elm, 'dir');\r
350                 lang = dom.getAttrib(elm, 'lang');\r
351                 background = getStyle(elm, 'background', 'backgroundImage').replace(new RegExp("url\\(['\"]?([^'\"]*)['\"]?\\)", 'gi'), "$1");\r
352                 formObj.caption.checked = elm.getElementsByTagName('caption').length > 0;\r
353 \r
354                 orgTableWidth = width;\r
355                 orgTableHeight = height;\r
356 \r
357                 action = "update";\r
358                 formObj.insert.value = inst.getLang('update');\r
359         }\r
360 \r
361         addClassesToList('class', "table_styles");\r
362         TinyMCE_EditableSelects.init();\r
363 \r
364         // Update form\r
365         selectByValue(formObj, 'align', align);\r
366         selectByValue(formObj, 'tframe', frame);\r
367         selectByValue(formObj, 'rules', rules);\r
368         selectByValue(formObj, 'class', className, true, true);\r
369         formObj.cols.value = cols;\r
370         formObj.rows.value = rows;\r
371         formObj.border.value = border;\r
372         formObj.cellpadding.value = cellpadding;\r
373         formObj.cellspacing.value = cellspacing;\r
374         formObj.width.value = width;\r
375         formObj.height.value = height;\r
376         formObj.bordercolor.value = bordercolor;\r
377         formObj.bgcolor.value = bgcolor;\r
378         formObj.id.value = id;\r
379         formObj.summary.value = summary;\r
380         formObj.style.value = style;\r
381         formObj.dir.value = dir;\r
382         formObj.lang.value = lang;\r
383         formObj.backgroundimage.value = background;\r
384 \r
385         updateColor('bordercolor_pick', 'bordercolor');\r
386         updateColor('bgcolor_pick', 'bgcolor');\r
387 \r
388         // Resize some elements\r
389         if (isVisible('backgroundimagebrowser'))\r
390                 document.getElementById('backgroundimage').style.width = '180px';\r
391 \r
392         // Disable some fields in update mode\r
393         if (action == "update") {\r
394                 formObj.cols.disabled = true;\r
395                 formObj.rows.disabled = true;\r
396         }\r
397 }\r
398 \r
399 function changedSize() {\r
400         var formObj = document.forms[0];\r
401         var st = dom.parseStyle(formObj.style.value);\r
402 \r
403 /*      var width = formObj.width.value;\r
404         if (width != "")\r
405                 st['width'] = tinyMCEPopup.getParam("inline_styles") ? getCSSSize(width) : "";\r
406         else\r
407                 st['width'] = "";*/\r
408 \r
409         var height = formObj.height.value;\r
410         if (height != "")\r
411                 st['height'] = getCSSSize(height);\r
412         else\r
413                 st['height'] = "";\r
414 \r
415         formObj.style.value = dom.serializeStyle(st);\r
416 }\r
417 \r
418 function isCssSize(value) {\r
419         return /^[0-9.]+(%|in|cm|mm|em|ex|pt|pc|px)$/.test(value);\r
420 }\r
421 \r
422 function cssSize(value, def) {\r
423         value = tinymce.trim(value || def);\r
424 \r
425         if (!isCssSize(value)) {\r
426                 return parseInt(value, 10) + 'px';\r
427         }\r
428 \r
429         return value;\r
430 }\r
431 \r
432 function changedBackgroundImage() {\r
433         var formObj = document.forms[0];\r
434         var st = dom.parseStyle(formObj.style.value);\r
435 \r
436         st['background-image'] = "url('" + formObj.backgroundimage.value + "')";\r
437 \r
438         formObj.style.value = dom.serializeStyle(st);\r
439 }\r
440 \r
441 function changedBorder() {\r
442         var formObj = document.forms[0];\r
443         var st = dom.parseStyle(formObj.style.value);\r
444 \r
445         // Update border width if the element has a color\r
446         if (formObj.border.value != "" && (isCssSize(formObj.border.value) || formObj.bordercolor.value != ""))\r
447                 st['border-width'] = cssSize(formObj.border.value);\r
448         else {\r
449                 if (!formObj.border.value) {\r
450                         st['border'] = '';\r
451                         st['border-width'] = '';\r
452                 }\r
453         }\r
454 \r
455         formObj.style.value = dom.serializeStyle(st);\r
456 }\r
457 \r
458 function changedColor() {\r
459         var formObj = document.forms[0];\r
460         var st = dom.parseStyle(formObj.style.value);\r
461 \r
462         st['background-color'] = formObj.bgcolor.value;\r
463 \r
464         if (formObj.bordercolor.value != "") {\r
465                 st['border-color'] = formObj.bordercolor.value;\r
466 \r
467                 // Add border-width if it's missing\r
468                 if (!st['border-width'])\r
469                         st['border-width'] = cssSize(formObj.border.value, 1);\r
470         }\r
471 \r
472         formObj.style.value = dom.serializeStyle(st);\r
473 }\r
474 \r
475 function changedStyle() {\r
476         var formObj = document.forms[0];\r
477         var st = dom.parseStyle(formObj.style.value);\r
478 \r
479         if (st['background-image'])\r
480                 formObj.backgroundimage.value = st['background-image'].replace(new RegExp("url\\(['\"]?([^'\"]*)['\"]?\\)", 'gi'), "$1");\r
481         else\r
482                 formObj.backgroundimage.value = '';\r
483 \r
484         if (st['width'])\r
485                 formObj.width.value = trimSize(st['width']);\r
486 \r
487         if (st['height'])\r
488                 formObj.height.value = trimSize(st['height']);\r
489 \r
490         if (st['background-color']) {\r
491                 formObj.bgcolor.value = st['background-color'];\r
492                 updateColor('bgcolor_pick','bgcolor');\r
493         }\r
494 \r
495         if (st['border-color']) {\r
496                 formObj.bordercolor.value = st['border-color'];\r
497                 updateColor('bordercolor_pick','bordercolor');\r
498         }\r
499 }\r
500 \r
501 tinyMCEPopup.onInit.add(init);\r