editor_plugin_src.js 12 KB

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