]> git.donarmstrong.com Git - roundcube.git/blob - program/js/tiny_mce/plugins/media/editor_plugin_src.js
Merge commit 'upstream/0.2_stable' into unstable-import
[roundcube.git] / program / js / tiny_mce / plugins / media / editor_plugin_src.js
1 /**\r
2  * $Id: editor_plugin_src.js 870 2008-06-13 09:25:41Z spocke $\r
3  *\r
4  * @author Moxiecode\r
5  * @copyright Copyright © 2004-2008, Moxiecode Systems AB, All rights reserved.\r
6  */\r
7 \r
8 (function() {\r
9         var each = tinymce.each;\r
10 \r
11         tinymce.create('tinymce.plugins.MediaPlugin', {\r
12                 init : function(ed, url) {\r
13                         var t = this;\r
14                         \r
15                         t.editor = ed;\r
16                         t.url = url;\r
17 \r
18                         function isMediaElm(n) {\r
19                                 return /^(mceItemFlash|mceItemShockWave|mceItemWindowsMedia|mceItemQuickTime|mceItemRealMedia)$/.test(n.className);\r
20                         };\r
21 \r
22                         ed.onPreInit.add(function() {\r
23                                 // Force in _value parameter this extra parameter is required for older Opera versions\r
24                                 ed.serializer.addRules('param[name|value|_value]');\r
25                         });\r
26 \r
27                         // Register commands\r
28                         ed.addCommand('mceMedia', function() {\r
29                                 ed.windowManager.open({\r
30                                         file : url + '/media.htm',\r
31                                         width : 430 + parseInt(ed.getLang('media.delta_width', 0)),\r
32                                         height : 470 + parseInt(ed.getLang('media.delta_height', 0)),\r
33                                         inline : 1\r
34                                 }, {\r
35                                         plugin_url : url\r
36                                 });\r
37                         });\r
38 \r
39                         // Register buttons\r
40                         ed.addButton('media', {title : 'media.desc', cmd : 'mceMedia'});\r
41 \r
42                         ed.onNodeChange.add(function(ed, cm, n) {\r
43                                 cm.setActive('media', n.nodeName == 'IMG' && isMediaElm(n));\r
44                         });\r
45 \r
46                         ed.onInit.add(function() {\r
47                                 var lo = {\r
48                                         mceItemFlash : 'flash',\r
49                                         mceItemShockWave : 'shockwave',\r
50                                         mceItemWindowsMedia : 'windowsmedia',\r
51                                         mceItemQuickTime : 'quicktime',\r
52                                         mceItemRealMedia : 'realmedia'\r
53                                 };\r
54 \r
55                                 if (ed.settings.content_css !== false)\r
56                                         ed.dom.loadCSS(url + "/css/content.css");\r
57 \r
58                                 if (ed.theme.onResolveName) {\r
59                                         ed.theme.onResolveName.add(function(th, o) {\r
60                                                 if (o.name == 'img') {\r
61                                                         each(lo, function(v, k) {\r
62                                                                 if (ed.dom.hasClass(o.node, k)) {\r
63                                                                         o.name = v;\r
64                                                                         o.title = ed.dom.getAttrib(o.node, 'title');\r
65                                                                         return false;\r
66                                                                 }\r
67                                                         });\r
68                                                 }\r
69                                         });\r
70                                 }\r
71 \r
72                                 if (ed && ed.plugins.contextmenu) {\r
73                                         ed.plugins.contextmenu.onContextMenu.add(function(th, m, e) {\r
74                                                 if (e.nodeName == 'IMG' && /mceItem(Flash|ShockWave|WindowsMedia|QuickTime|RealMedia)/.test(e.className)) {\r
75                                                         m.add({title : 'media.edit', icon : 'media', cmd : 'mceMedia'});\r
76                                                 }\r
77                                         });\r
78                                 }\r
79                         });\r
80 \r
81                         ed.onBeforeSetContent.add(function(ed, o) {\r
82                                 var h = o.content;\r
83 \r
84                                 h = h.replace(/<script[^>]*>\s*write(Flash|ShockWave|WindowsMedia|QuickTime|RealMedia)\(\{([^\)]*)\}\);\s*<\/script>/gi, function(a, b, c) {\r
85                                         var o = t._parse(c);\r
86 \r
87                                         return '<img class="mceItem' + b + '" title="' + ed.dom.encode(c) + '" src="' + url + '/img/trans.gif" width="' + o.width + '" height="' + o.height + '" />'\r
88                                 });\r
89 \r
90                                 h = h.replace(/<object([^>]*)>/gi, '<span class="mceItemObject" $1>');\r
91                                 h = h.replace(/<embed([^>]*)\/>/gi, '<span class="mceItemEmbed" $1>');\r
92                                 h = h.replace(/<embed([^>]*)>/gi, '<span class="mceItemEmbed" $1>');\r
93                                 h = h.replace(/<\/(object|embed)([^>]*)>/gi, '</span>');\r
94                                 h = h.replace(/<param([^>]*)>/gi, function(a, b) {return '<span ' + b.replace(/value=/gi, '_value=') + ' class="mceItemParam"></span>'});\r
95                                 h = h.replace(/\/ class=\"mceItemParam\"><\/span>/gi, 'class="mceItemParam"></span>');\r
96 \r
97                                 o.content = h;\r
98                         });\r
99 \r
100                         ed.onSetContent.add(function() {\r
101                                 t._spansToImgs(ed.getBody());\r
102                         });\r
103 \r
104                         ed.onPreProcess.add(function(ed, o) {\r
105                                 var dom = ed.dom;\r
106 \r
107                                 if (o.set) {\r
108                                         t._spansToImgs(o.node);\r
109 \r
110                                         each(dom.select('IMG', o.node), function(n) {\r
111                                                 var p;\r
112 \r
113                                                 if (isMediaElm(n)) {\r
114                                                         p = t._parse(n.title);\r
115                                                         dom.setAttrib(n, 'width', dom.getAttrib(n, 'width', p.width || 100));\r
116                                                         dom.setAttrib(n, 'height', dom.getAttrib(n, 'height', p.height || 100));\r
117                                                 }\r
118                                         });\r
119                                 }\r
120 \r
121                                 if (o.get) {\r
122                                         each(dom.select('IMG', o.node), function(n) {\r
123                                                 var ci, cb, mt;\r
124 \r
125                                                 if (ed.getParam('media_use_script')) {\r
126                                                         if (isMediaElm(n))\r
127                                                                 n.className = n.className.replace(/mceItem/g, 'mceTemp');\r
128 \r
129                                                         return;\r
130                                                 }\r
131 \r
132                                                 switch (n.className) {\r
133                                                         case 'mceItemFlash':\r
134                                                                 ci = 'd27cdb6e-ae6d-11cf-96b8-444553540000';\r
135                                                                 cb = 'http://download.macromedia.com/pub/shockwave/cabs/flash/swflash.cab#version=6,0,40,0';\r
136                                                                 mt = 'application/x-shockwave-flash';\r
137                                                                 break;\r
138 \r
139                                                         case 'mceItemShockWave':\r
140                                                                 ci = '166b1bca-3f9c-11cf-8075-444553540000';\r
141                                                                 cb = 'http://download.macromedia.com/pub/shockwave/cabs/director/sw.cab#version=8,5,1,0';\r
142                                                                 mt = 'application/x-director';\r
143                                                                 break;\r
144 \r
145                                                         case 'mceItemWindowsMedia':\r
146                                                                 ci = ed.getParam('media_wmp6_compatible') ? '05589fa1-c356-11ce-bf01-00aa0055595a' : '6bf52a52-394a-11d3-b153-00c04f79faa6';\r
147                                                                 cb = 'http://activex.microsoft.com/activex/controls/mplayer/en/nsmp2inf.cab#Version=5,1,52,701';\r
148                                                                 mt = 'application/x-mplayer2';\r
149                                                                 break;\r
150 \r
151                                                         case 'mceItemQuickTime':\r
152                                                                 ci = '02bf25d5-8c17-4b23-bc80-d3488abddc6b';\r
153                                                                 cb = 'http://www.apple.com/qtactivex/qtplugin.cab#version=6,0,2,0';\r
154                                                                 mt = 'video/quicktime';\r
155                                                                 break;\r
156 \r
157                                                         case 'mceItemRealMedia':\r
158                                                                 ci = 'cfcdaa03-8be4-11cf-b84b-0020afbbccfa';\r
159                                                                 cb = 'http://download.macromedia.com/pub/shockwave/cabs/flash/swflash.cab#version=6,0,40,0';\r
160                                                                 mt = 'audio/x-pn-realaudio-plugin';\r
161                                                                 break;\r
162                                                 }\r
163 \r
164                                                 if (ci) {\r
165                                                         dom.replace(t._buildObj({\r
166                                                                 classid : ci,\r
167                                                                 codebase : cb,\r
168                                                                 type : mt\r
169                                                         }, n), n);\r
170                                                 }\r
171                                         });\r
172                                 }\r
173                         });\r
174 \r
175                         ed.onPostProcess.add(function(ed, o) {\r
176                                 o.content = o.content.replace(/_value=/g, 'value=');\r
177                         });\r
178 \r
179                         if (ed.getParam('media_use_script')) {\r
180                                 function getAttr(s, n) {\r
181                                         n = new RegExp(n + '=\"([^\"]+)\"', 'g').exec(s);\r
182 \r
183                                         return n ? ed.dom.decode(n[1]) : '';\r
184                                 };\r
185 \r
186                                 ed.onPostProcess.add(function(ed, o) {\r
187                                         o.content = o.content.replace(/<img[^>]+>/g, function(im) {\r
188                                                 var cl = getAttr(im, 'class');\r
189 \r
190                                                 if (/^(mceTempFlash|mceTempShockWave|mceTempWindowsMedia|mceTempQuickTime|mceTempRealMedia)$/.test(cl)) {\r
191                                                         at = t._parse(getAttr(im, 'title'));\r
192                                                         at.width = getAttr(im, 'width');\r
193                                                         at.height = getAttr(im, 'height');\r
194                                                         im = '<script type="text/javascript">write' + cl.substring(7) + '({' + t._serialize(at) + '});</script>';\r
195                                                 }\r
196 \r
197                                                 return im;\r
198                                         });\r
199                                 });\r
200                         }\r
201                 },\r
202 \r
203                 getInfo : function() {\r
204                         return {\r
205                                 longname : 'Media',\r
206                                 author : 'Moxiecode Systems AB',\r
207                                 authorurl : 'http://tinymce.moxiecode.com',\r
208                                 infourl : 'http://wiki.moxiecode.com/index.php/TinyMCE:Plugins/media',\r
209                                 version : tinymce.majorVersion + "." + tinymce.minorVersion\r
210                         };\r
211                 },\r
212 \r
213                 // Private methods\r
214 \r
215                 _buildObj : function(o, n) {\r
216                         var ob, ed = this.editor, dom = ed.dom, p = this._parse(n.title);\r
217 \r
218                         p.width = o.width = dom.getAttrib(n, 'width') || 100;\r
219                         p.height = o.height = dom.getAttrib(n, 'height') || 100;\r
220 \r
221                         ob = dom.create('span', {\r
222                                 mce_name : 'object',\r
223                                 classid : "clsid:" + o.classid,\r
224                                 codebase : o.codebase,\r
225                                 width : o.width,\r
226                                 height : o.height\r
227                         });\r
228 \r
229                         if (p.src)\r
230                                 p.src = ed.convertURL(p.src, 'src', n);\r
231 \r
232                         each (p, function(v, k) {\r
233                                 if (!/^(width|height|codebase|classid)$/.test(k)) {\r
234                                         // Use url instead of src in IE for Windows media\r
235                                         if (o.type == 'application/x-mplayer2' && k == 'src')\r
236                                                 k = 'url';\r
237 \r
238                                         dom.add(ob, 'span', {mce_name : 'param', name : k, '_value' : v});\r
239                                 }\r
240                         });\r
241 \r
242                         dom.add(ob, 'span', tinymce.extend({mce_name : 'embed', type : o.type}, p));\r
243 \r
244                         return ob;\r
245                 },\r
246 \r
247                 _spansToImgs : function(p) {\r
248                         var t = this, dom = t.editor.dom, im, ci;\r
249 \r
250                         each(dom.select('span', p), function(n) {\r
251                                 // Convert object into image\r
252                                 if (dom.getAttrib(n, 'class') == 'mceItemObject') {\r
253                                         ci = dom.getAttrib(n, "classid").toLowerCase().replace(/\s+/g, '');\r
254 \r
255                                         switch (ci) {\r
256                                                 case 'clsid:d27cdb6e-ae6d-11cf-96b8-444553540000':\r
257                                                         dom.replace(t._createImg('mceItemFlash', n), n);\r
258                                                         break;\r
259 \r
260                                                 case 'clsid:166b1bca-3f9c-11cf-8075-444553540000':\r
261                                                         dom.replace(t._createImg('mceItemShockWave', n), n);\r
262                                                         break;\r
263 \r
264                                                 case 'clsid:6bf52a52-394a-11d3-b153-00c04f79faa6':\r
265                                                 case 'clsid:22d6f312-b0f6-11d0-94ab-0080c74c7e95':\r
266                                                 case 'clsid:05589fa1-c356-11ce-bf01-00aa0055595a':\r
267                                                         dom.replace(t._createImg('mceItemWindowsMedia', n), n);\r
268                                                         break;\r
269 \r
270                                                 case 'clsid:02bf25d5-8c17-4b23-bc80-d3488abddc6b':\r
271                                                         dom.replace(t._createImg('mceItemQuickTime', n), n);\r
272                                                         break;\r
273 \r
274                                                 case 'clsid:cfcdaa03-8be4-11cf-b84b-0020afbbccfa':\r
275                                                         dom.replace(t._createImg('mceItemRealMedia', n), n);\r
276                                                         break;\r
277 \r
278                                                 default:\r
279                                                         dom.replace(t._createImg('mceItemFlash', n), n);\r
280                                         }\r
281                                         \r
282                                         return;\r
283                                 }\r
284 \r
285                                 // Convert embed into image\r
286                                 if (dom.getAttrib(n, 'class') == 'mceItemEmbed') {\r
287                                         switch (dom.getAttrib(n, 'type')) {\r
288                                                 case 'application/x-shockwave-flash':\r
289                                                         dom.replace(t._createImg('mceItemFlash', n), n);\r
290                                                         break;\r
291 \r
292                                                 case 'application/x-director':\r
293                                                         dom.replace(t._createImg('mceItemShockWave', n), n);\r
294                                                         break;\r
295 \r
296                                                 case 'application/x-mplayer2':\r
297                                                         dom.replace(t._createImg('mceItemWindowsMedia', n), n);\r
298                                                         break;\r
299 \r
300                                                 case 'video/quicktime':\r
301                                                         dom.replace(t._createImg('mceItemQuickTime', n), n);\r
302                                                         break;\r
303 \r
304                                                 case 'audio/x-pn-realaudio-plugin':\r
305                                                         dom.replace(t._createImg('mceItemRealMedia', n), n);\r
306                                                         break;\r
307 \r
308                                                 default:\r
309                                                         dom.replace(t._createImg('mceItemFlash', n), n);\r
310                                         }\r
311                                 }                       \r
312                         });\r
313                 },\r
314 \r
315                 _createImg : function(cl, n) {\r
316                         var im, dom = this.editor.dom, pa = {}, ti = '';\r
317 \r
318                         // Create image\r
319                         im = dom.create('img', {\r
320                                 src : this.url + '/img/trans.gif',\r
321                                 width : dom.getAttrib(n, 'width') || 100,\r
322                                 height : dom.getAttrib(n, 'height') || 100,\r
323                                 'class' : cl\r
324                         });\r
325 \r
326                         // Setup base parameters\r
327                         each(['id', 'name', 'width', 'height', 'bgcolor', 'align', 'flashvars', 'src', 'wmode'], function(na) {\r
328                                 var v = dom.getAttrib(n, na);\r
329 \r
330                                 if (v)\r
331                                         pa[na] = v;\r
332                         });\r
333 \r
334                         // Add optional parameters\r
335                         each(dom.select('span', n), function(n) {\r
336                                 if (dom.hasClass(n, 'mceItemParam'))\r
337                                         pa[dom.getAttrib(n, 'name')] = dom.getAttrib(n, '_value');\r
338                         });\r
339 \r
340                         // Use src not movie\r
341                         if (pa.movie) {\r
342                                 pa.src = pa.movie;\r
343                                 delete pa.movie;\r
344                         }\r
345 \r
346                         delete pa.width;\r
347                         delete pa.height;\r
348 \r
349                         im.title = this._serialize(pa);\r
350 \r
351                         return im;\r
352                 },\r
353 \r
354                 _parse : function(s) {\r
355                         return tinymce.util.JSON.parse('{' + s + '}');\r
356                 },\r
357 \r
358                 _serialize : function(o) {\r
359                         return tinymce.util.JSON.serialize(o).replace(/[{}]/g, '');\r
360                 }\r
361         });\r
362 \r
363         // Register plugin\r
364         tinymce.PluginManager.add('media', tinymce.plugins.MediaPlugin);\r
365 })();