--- /dev/null
+/**\r
+ * editor_plugin_src.js\r
+ *\r
+ * Copyright 2009, Moxiecode Systems AB\r
+ * Released under LGPL License.\r
+ *\r
+ * License: http://tinymce.moxiecode.com/license\r
+ * Contributing: http://tinymce.moxiecode.com/contributing\r
+ */\r
+\r
+(function() {\r
+ var each = tinymce.each;\r
+\r
+ tinymce.create('tinymce.plugins.MediaPlugin', {\r
+ init : function(ed, url) {\r
+ var t = this;\r
+ \r
+ t.editor = ed;\r
+ t.url = url;\r
+\r
+ function isMediaElm(n) {\r
+ return /^(mceItemFlash|mceItemShockWave|mceItemWindowsMedia|mceItemQuickTime|mceItemRealMedia)$/.test(n.className);\r
+ };\r
+\r
+ ed.onPreInit.add(function() {\r
+ // Force in _value parameter this extra parameter is required for older Opera versions\r
+ ed.serializer.addRules('param[name|value|_mce_value]');\r
+ });\r
+\r
+ // Register commands\r
+ ed.addCommand('mceMedia', function() {\r
+ ed.windowManager.open({\r
+ file : url + '/media.htm',\r
+ width : 430 + parseInt(ed.getLang('media.delta_width', 0)),\r
+ height : 470 + parseInt(ed.getLang('media.delta_height', 0)),\r
+ inline : 1\r
+ }, {\r
+ plugin_url : url\r
+ });\r
+ });\r
+\r
+ // Register buttons\r
+ ed.addButton('media', {title : 'media.desc', cmd : 'mceMedia'});\r
+\r
+ ed.onNodeChange.add(function(ed, cm, n) {\r
+ cm.setActive('media', n.nodeName == 'IMG' && isMediaElm(n));\r
+ });\r
+\r
+ ed.onInit.add(function() {\r
+ var lo = {\r
+ mceItemFlash : 'flash',\r
+ mceItemShockWave : 'shockwave',\r
+ mceItemWindowsMedia : 'windowsmedia',\r
+ mceItemQuickTime : 'quicktime',\r
+ mceItemRealMedia : 'realmedia'\r
+ };\r
+\r
+ ed.selection.onSetContent.add(function() {\r
+ t._spansToImgs(ed.getBody());\r
+ });\r
+\r
+ ed.selection.onBeforeSetContent.add(t._objectsToSpans, t);\r
+\r
+ if (ed.settings.content_css !== false)\r
+ ed.dom.loadCSS(url + "/css/content.css");\r
+\r
+ if (ed.theme && ed.theme.onResolveName) {\r
+ ed.theme.onResolveName.add(function(th, o) {\r
+ if (o.name == 'img') {\r
+ each(lo, function(v, k) {\r
+ if (ed.dom.hasClass(o.node, k)) {\r
+ o.name = v;\r
+ o.title = ed.dom.getAttrib(o.node, 'title');\r
+ return false;\r
+ }\r
+ });\r
+ }\r
+ });\r
+ }\r
+\r
+ if (ed && ed.plugins.contextmenu) {\r
+ ed.plugins.contextmenu.onContextMenu.add(function(th, m, e) {\r
+ if (e.nodeName == 'IMG' && /mceItem(Flash|ShockWave|WindowsMedia|QuickTime|RealMedia)/.test(e.className)) {\r
+ m.add({title : 'media.edit', icon : 'media', cmd : 'mceMedia'});\r
+ }\r
+ });\r
+ }\r
+ });\r
+\r
+ ed.onBeforeSetContent.add(t._objectsToSpans, t);\r
+\r
+ ed.onSetContent.add(function() {\r
+ t._spansToImgs(ed.getBody());\r
+ });\r
+\r
+ ed.onPreProcess.add(function(ed, o) {\r
+ var dom = ed.dom;\r
+\r
+ if (o.set) {\r
+ t._spansToImgs(o.node);\r
+\r
+ each(dom.select('IMG', o.node), function(n) {\r
+ var p;\r
+\r
+ if (isMediaElm(n)) {\r
+ p = t._parse(n.title);\r
+ dom.setAttrib(n, 'width', dom.getAttrib(n, 'width', p.width || 100));\r
+ dom.setAttrib(n, 'height', dom.getAttrib(n, 'height', p.height || 100));\r
+ }\r
+ });\r
+ }\r
+\r
+ if (o.get) {\r
+ each(dom.select('IMG', o.node), function(n) {\r
+ var ci, cb, mt;\r
+\r
+ if (ed.getParam('media_use_script')) {\r
+ if (isMediaElm(n))\r
+ n.className = n.className.replace(/mceItem/g, 'mceTemp');\r
+\r
+ return;\r
+ }\r
+\r
+ switch (n.className) {\r
+ case 'mceItemFlash':\r
+ ci = 'd27cdb6e-ae6d-11cf-96b8-444553540000';\r
+ cb = 'http://download.macromedia.com/pub/shockwave/cabs/flash/swflash.cab#version=6,0,40,0';\r
+ mt = 'application/x-shockwave-flash';\r
+ break;\r
+\r
+ case 'mceItemShockWave':\r
+ ci = '166b1bca-3f9c-11cf-8075-444553540000';\r
+ cb = 'http://download.macromedia.com/pub/shockwave/cabs/director/sw.cab#version=8,5,1,0';\r
+ mt = 'application/x-director';\r
+ break;\r
+\r
+ case 'mceItemWindowsMedia':\r
+ ci = ed.getParam('media_wmp6_compatible') ? '05589fa1-c356-11ce-bf01-00aa0055595a' : '6bf52a52-394a-11d3-b153-00c04f79faa6';\r
+ cb = 'http://activex.microsoft.com/activex/controls/mplayer/en/nsmp2inf.cab#Version=5,1,52,701';\r
+ mt = 'application/x-mplayer2';\r
+ break;\r
+\r
+ case 'mceItemQuickTime':\r
+ ci = '02bf25d5-8c17-4b23-bc80-d3488abddc6b';\r
+ cb = 'http://www.apple.com/qtactivex/qtplugin.cab#version=6,0,2,0';\r
+ mt = 'video/quicktime';\r
+ break;\r
+\r
+ case 'mceItemRealMedia':\r
+ ci = 'cfcdaa03-8be4-11cf-b84b-0020afbbccfa';\r
+ cb = 'http://download.macromedia.com/pub/shockwave/cabs/flash/swflash.cab#version=6,0,40,0';\r
+ mt = 'audio/x-pn-realaudio-plugin';\r
+ break;\r
+ }\r
+\r
+ if (ci) {\r
+ dom.replace(t._buildObj({\r
+ classid : ci,\r
+ codebase : cb,\r
+ type : mt\r
+ }, n), n);\r
+ }\r
+ });\r
+ }\r
+ });\r
+\r
+ ed.onPostProcess.add(function(ed, o) {\r
+ o.content = o.content.replace(/_mce_value=/g, 'value=');\r
+ });\r
+\r
+ function getAttr(s, n) {\r
+ n = new RegExp(n + '=\"([^\"]+)\"', 'g').exec(s);\r
+\r
+ return n ? ed.dom.decode(n[1]) : '';\r
+ };\r
+\r
+ ed.onPostProcess.add(function(ed, o) {\r
+ if (ed.getParam('media_use_script')) {\r
+ o.content = o.content.replace(/<img[^>]+>/g, function(im) {\r
+ var cl = getAttr(im, 'class');\r
+\r
+ if (/^(mceTempFlash|mceTempShockWave|mceTempWindowsMedia|mceTempQuickTime|mceTempRealMedia)$/.test(cl)) {\r
+ at = t._parse(getAttr(im, 'title'));\r
+ at.width = getAttr(im, 'width');\r
+ at.height = getAttr(im, 'height');\r
+ im = '<script type="text/javascript">write' + cl.substring(7) + '({' + t._serialize(at) + '});</script>';\r
+ }\r
+\r
+ return im;\r
+ });\r
+ }\r
+ });\r
+ },\r
+\r
+ getInfo : function() {\r
+ return {\r
+ longname : 'Media',\r
+ author : 'Moxiecode Systems AB',\r
+ authorurl : 'http://tinymce.moxiecode.com',\r
+ infourl : 'http://wiki.moxiecode.com/index.php/TinyMCE:Plugins/media',\r
+ version : tinymce.majorVersion + "." + tinymce.minorVersion\r
+ };\r
+ },\r
+\r
+ // Private methods\r
+ _objectsToSpans : function(ed, o) {\r
+ var t = this, h = o.content;\r
+\r
+ h = h.replace(/<script[^>]*>\s*write(Flash|ShockWave|WindowsMedia|QuickTime|RealMedia)\(\{([^\)]*)\}\);\s*<\/script>/gi, function(a, b, c) {\r
+ var o = t._parse(c);\r
+\r
+ return '<img class="mceItem' + b + '" title="' + ed.dom.encode(c) + '" src="' + t.url + '/img/trans.gif" width="' + o.width + '" height="' + o.height + '" />'\r
+ });\r
+\r
+ h = h.replace(/<object([^>]*)>/gi, '<span class="mceItemObject" $1>');\r
+ h = h.replace(/<embed([^>]*)\/?>/gi, '<span class="mceItemEmbed" $1></span>');\r
+ h = h.replace(/<embed([^>]*)>/gi, '<span class="mceItemEmbed" $1>');\r
+ h = h.replace(/<\/(object)([^>]*)>/gi, '</span>');\r
+ h = h.replace(/<\/embed>/gi, '');\r
+ h = h.replace(/<param([^>]*)>/gi, function(a, b) {return '<span ' + b.replace(/value=/gi, '_mce_value=') + ' class="mceItemParam"></span>'});\r
+ h = h.replace(/\/ class=\"mceItemParam\"><\/span>/gi, 'class="mceItemParam"></span>');\r
+\r
+ o.content = h;\r
+ },\r
+\r
+ _buildObj : function(o, n) {\r
+ var ob, ed = this.editor, dom = ed.dom, p = this._parse(n.title), stc;\r
+ \r
+ stc = ed.getParam('media_strict', true) && o.type == 'application/x-shockwave-flash';\r
+\r
+ p.width = o.width = dom.getAttrib(n, 'width') || 100;\r
+ p.height = o.height = dom.getAttrib(n, 'height') || 100;\r
+\r
+ if (p.src)\r
+ p.src = ed.convertURL(p.src, 'src', n);\r
+\r
+ if (stc) {\r
+ ob = dom.create('span', {\r
+ id : p.id,\r
+ _mce_name : 'object',\r
+ type : 'application/x-shockwave-flash',\r
+ data : p.src,\r
+ style : dom.getAttrib(n, 'style'),\r
+ width : o.width,\r
+ height : o.height\r
+ });\r
+ } else {\r
+ ob = dom.create('span', {\r
+ id : p.id,\r
+ _mce_name : 'object',\r
+ classid : "clsid:" + o.classid,\r
+ style : dom.getAttrib(n, 'style'),\r
+ codebase : o.codebase,\r
+ width : o.width,\r
+ height : o.height\r
+ });\r
+ }\r
+\r
+ each (p, function(v, k) {\r
+ if (!/^(width|height|codebase|classid|id|_cx|_cy)$/.test(k)) {\r
+ // Use url instead of src in IE for Windows media\r
+ if (o.type == 'application/x-mplayer2' && k == 'src' && !p.url)\r
+ k = 'url';\r
+\r
+ if (v)\r
+ dom.add(ob, 'span', {_mce_name : 'param', name : k, '_mce_value' : v});\r
+ }\r
+ });\r
+\r
+ if (!stc)\r
+ dom.add(ob, 'span', tinymce.extend({_mce_name : 'embed', type : o.type, style : dom.getAttrib(n, 'style')}, p));\r
+\r
+ return ob;\r
+ },\r
+\r
+ _spansToImgs : function(p) {\r
+ var t = this, dom = t.editor.dom, im, ci;\r
+\r
+ each(dom.select('span', p), function(n) {\r
+ // Convert object into image\r
+ if (dom.getAttrib(n, 'class') == 'mceItemObject') {\r
+ ci = dom.getAttrib(n, "classid").toLowerCase().replace(/\s+/g, '');\r
+\r
+ switch (ci) {\r
+ case 'clsid:d27cdb6e-ae6d-11cf-96b8-444553540000':\r
+ dom.replace(t._createImg('mceItemFlash', n), n);\r
+ break;\r
+\r
+ case 'clsid:166b1bca-3f9c-11cf-8075-444553540000':\r
+ dom.replace(t._createImg('mceItemShockWave', n), n);\r
+ break;\r
+\r
+ case 'clsid:6bf52a52-394a-11d3-b153-00c04f79faa6':\r
+ case 'clsid:22d6f312-b0f6-11d0-94ab-0080c74c7e95':\r
+ case 'clsid:05589fa1-c356-11ce-bf01-00aa0055595a':\r
+ dom.replace(t._createImg('mceItemWindowsMedia', n), n);\r
+ break;\r
+\r
+ case 'clsid:02bf25d5-8c17-4b23-bc80-d3488abddc6b':\r
+ dom.replace(t._createImg('mceItemQuickTime', n), n);\r
+ break;\r
+\r
+ case 'clsid:cfcdaa03-8be4-11cf-b84b-0020afbbccfa':\r
+ dom.replace(t._createImg('mceItemRealMedia', n), n);\r
+ break;\r
+\r
+ default:\r
+ dom.replace(t._createImg('mceItemFlash', n), n);\r
+ }\r
+ \r
+ return;\r
+ }\r
+\r
+ // Convert embed into image\r
+ if (dom.getAttrib(n, 'class') == 'mceItemEmbed') {\r
+ switch (dom.getAttrib(n, 'type')) {\r
+ case 'application/x-shockwave-flash':\r
+ dom.replace(t._createImg('mceItemFlash', n), n);\r
+ break;\r
+\r
+ case 'application/x-director':\r
+ dom.replace(t._createImg('mceItemShockWave', n), n);\r
+ break;\r
+\r
+ case 'application/x-mplayer2':\r
+ dom.replace(t._createImg('mceItemWindowsMedia', n), n);\r
+ break;\r
+\r
+ case 'video/quicktime':\r
+ dom.replace(t._createImg('mceItemQuickTime', n), n);\r
+ break;\r
+\r
+ case 'audio/x-pn-realaudio-plugin':\r
+ dom.replace(t._createImg('mceItemRealMedia', n), n);\r
+ break;\r
+\r
+ default:\r
+ dom.replace(t._createImg('mceItemFlash', n), n);\r
+ }\r
+ } \r
+ });\r
+ },\r
+\r
+ _createImg : function(cl, n) {\r
+ var im, dom = this.editor.dom, pa = {}, ti = '', args;\r
+\r
+ args = ['id', 'name', 'width', 'height', 'bgcolor', 'align', 'flashvars', 'src', 'wmode', 'allowfullscreen', 'quality', 'data']; \r
+\r
+ // Create image\r
+ im = dom.create('img', {\r
+ src : this.url + '/img/trans.gif',\r
+ width : dom.getAttrib(n, 'width') || 100,\r
+ height : dom.getAttrib(n, 'height') || 100,\r
+ style : dom.getAttrib(n, 'style'),\r
+ 'class' : cl\r
+ });\r
+\r
+ // Setup base parameters\r
+ each(args, function(na) {\r
+ var v = dom.getAttrib(n, na);\r
+\r
+ if (v)\r
+ pa[na] = v;\r
+ });\r
+\r
+ // Add optional parameters\r
+ each(dom.select('span', n), function(n) {\r
+ if (dom.hasClass(n, 'mceItemParam'))\r
+ pa[dom.getAttrib(n, 'name')] = dom.getAttrib(n, '_mce_value');\r
+ });\r
+\r
+ // Use src not movie\r
+ if (pa.movie) {\r
+ pa.src = pa.movie;\r
+ delete pa.movie;\r
+ }\r
+\r
+ // No src try data\r
+ if (!pa.src) {\r
+ pa.src = pa.data;\r
+ delete pa.data;\r
+ }\r
+\r
+ // Merge with embed args\r
+ n = dom.select('.mceItemEmbed', n)[0];\r
+ if (n) {\r
+ each(args, function(na) {\r
+ var v = dom.getAttrib(n, na);\r
+\r
+ if (v && !pa[na])\r
+ pa[na] = v;\r
+ });\r
+ }\r
+\r
+ delete pa.width;\r
+ delete pa.height;\r
+\r
+ im.title = this._serialize(pa);\r
+\r
+ return im;\r
+ },\r
+\r
+ _parse : function(s) {\r
+ return tinymce.util.JSON.parse('{' + s + '}');\r
+ },\r
+\r
+ _serialize : function(o) {\r
+ return tinymce.util.JSON.serialize(o).replace(/[{}]/g, '');\r
+ }\r
+ });\r
+\r
+ // Register plugin\r
+ tinymce.PluginManager.add('media', tinymce.plugins.MediaPlugin);\r
+})();
\ No newline at end of file