plugin.js 7.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252
  1. /*
  2. * @file Video plugin for CKEditor
  3. * Copyright (C) 2011 Alfonso Martínez de Lizarrondo
  4. *
  5. * == BEGIN LICENSE ==
  6. *
  7. * Licensed under the terms of any of the following licenses at your
  8. * choice:
  9. *
  10. * - GNU General Public License Version 2 or later (the "GPL")
  11. * http://www.gnu.org/licenses/gpl.html
  12. *
  13. * - GNU Lesser General Public License Version 2.1 or later (the "LGPL")
  14. * http://www.gnu.org/licenses/lgpl.html
  15. *
  16. * - Mozilla Public License Version 1.1 or later (the "MPL")
  17. * http://www.mozilla.org/MPL/MPL-1.1.html
  18. *
  19. * == END LICENSE ==
  20. *
  21. */
  22. ( function() {
  23. CKEDITOR.plugins.add( 'video',
  24. {
  25. // Translations, available at the end of this file, without extra requests
  26. lang : [ 'en', 'es' ],
  27. getPlaceholderCss : function()
  28. {
  29. return 'img.cke_video' +
  30. '{' +
  31. 'background-image: url(' + CKEDITOR.getUrl( this.path + 'images/placeholder.png' ) + ');' +
  32. 'background-position: center center;' +
  33. 'background-repeat: no-repeat;' +
  34. 'background-color:gray;'+
  35. 'border: 1px solid #a9a9a9;' +
  36. 'width: 80px;' +
  37. 'height: 80px;' +
  38. '}';
  39. },
  40. onLoad : function()
  41. {
  42. // v4
  43. if (CKEDITOR.addCss)
  44. CKEDITOR.addCss( this.getPlaceholderCss() );
  45. },
  46. init : function( editor )
  47. {
  48. var lang = editor.lang.video;
  49. // Check for CKEditor 3.5
  50. if (typeof editor.element.data == 'undefined')
  51. {
  52. alert('The "video" plugin requires CKEditor 3.5 or newer');
  53. return;
  54. }
  55. CKEDITOR.dialog.add( 'video', this.path + 'dialogs/video.js' );
  56. editor.addCommand( 'Video', new CKEDITOR.dialogCommand( 'video' ) );
  57. editor.ui.addButton( 'Video',
  58. {
  59. label : lang.toolbar,
  60. command : 'Video',
  61. icon : this.path + 'images/icon.png'
  62. } );
  63. // v3
  64. if (editor.addCss)
  65. editor.addCss( this.getPlaceholderCss() );
  66. // If the "menu" plugin is loaded, register the menu items.
  67. if ( editor.addMenuItems )
  68. {
  69. editor.addMenuItems(
  70. {
  71. video :
  72. {
  73. label : lang.properties,
  74. command : 'Video',
  75. group : 'flash'
  76. }
  77. });
  78. }
  79. editor.on( 'doubleclick', function( evt )
  80. {
  81. var element = evt.data.element;
  82. if ( element.is( 'img' ) && element.data( 'cke-real-element-type' ) == 'video' )
  83. evt.data.dialog = 'video';
  84. });
  85. // If the "contextmenu" plugin is loaded, register the listeners.
  86. if ( editor.contextMenu )
  87. {
  88. editor.contextMenu.addListener( function( element, selection )
  89. {
  90. if ( element && element.is( 'img' ) && !element.isReadOnly()
  91. && element.data( 'cke-real-element-type' ) == 'video' )
  92. return { video : CKEDITOR.TRISTATE_OFF };
  93. });
  94. }
  95. // Add special handling for these items
  96. CKEDITOR.dtd.$empty['cke:source']=1;
  97. CKEDITOR.dtd.$empty['source']=1;
  98. editor.lang.fakeobjects.video = lang.fakeObject;
  99. }, //Init
  100. afterInit: function( editor )
  101. {
  102. var dataProcessor = editor.dataProcessor,
  103. htmlFilter = dataProcessor && dataProcessor.htmlFilter,
  104. dataFilter = dataProcessor && dataProcessor.dataFilter;
  105. // dataFilter : conversion from html input to internal data
  106. dataFilter.addRules(
  107. {
  108. elements : {
  109. $ : function( realElement )
  110. {
  111. if ( realElement.name == 'video' )
  112. {
  113. realElement.name = 'cke:video';
  114. for( var i=0; i < realElement.children.length; i++)
  115. {
  116. if ( realElement.children[ i ].name == 'source' )
  117. realElement.children[ i ].name = 'cke:source'
  118. }
  119. var fakeElement = editor.createFakeParserElement( realElement, 'cke_video', 'video', false ),
  120. fakeStyle = fakeElement.attributes.style || '';
  121. var width = realElement.attributes.width,
  122. height = realElement.attributes.height,
  123. poster = realElement.attributes.poster,
  124. responsive = realElement.attributes.responsive;
  125. if ( typeof width != 'undefined' )
  126. fakeStyle = fakeElement.attributes.style = fakeStyle + 'width:' + CKEDITOR.tools.cssLength( width ) + ';';
  127. if ( typeof height != 'undefined' )
  128. fakeStyle = fakeElement.attributes.style = fakeStyle + 'height:' + CKEDITOR.tools.cssLength( height ) + ';';
  129. if ( poster )
  130. fakeStyle = fakeElement.attributes.style = fakeStyle + 'background-image:url(' + poster + ');';
  131. if (typeof responsive != 'undefined' && responsive && responsive !== 'null') {
  132. fakeElement.addClass('embed-responsive-item');
  133. }
  134. return fakeElement;
  135. }
  136. }
  137. }
  138. }
  139. );
  140. } // afterInit
  141. } ); // plugins.add
  142. var en = {
  143. toolbar: 'Video',
  144. dialogTitle: 'Video properties',
  145. fakeObject: 'Video',
  146. properties: 'Edit video',
  147. widthRequired: 'Width field cannot be empty',
  148. heightRequired: 'Height field cannot be empty',
  149. poster: 'Poster image',
  150. sourceVideo: 'Source video',
  151. sourceType: 'Video type',
  152. linkTemplate: '<a href="%src%">%type%</a> ',
  153. fallbackTemplate: 'Your browser doesn\'t support video.<br>Please download the file: %links%',
  154. infoLabel: 'Information',
  155. html360: 'This feature (only MP4 videos) is currently still in BETA mode.<br />It only works on dynamic pages, not inside documents created<br />in the documents tool or seen through learning paths.<br />Please do not add more than one 360° video on a single page<br /> as more than one on the same page might generate conflicts.',
  156. video360: 'Enable 360° video player',
  157. video360stereo: 'Stereo video (1:1 aspect ratio)',
  158. responsive: 'Resposive size (mobile-optimized)',
  159. ratio16by9: '16:9 aspect ratio',
  160. ratio4by3: '4:3 aspect ratio'
  161. };
  162. var es = {
  163. toolbar: 'Vídeo',
  164. dialogTitle: 'Propiedades del vídeo',
  165. fakeObject: 'Vídeo',
  166. properties: 'Editar el vídeo',
  167. widthRequired: 'La anchura no se puede dejar en blanco',
  168. heightRequired: 'La altura no se puede dejar en blanco',
  169. poster: 'Imagen de presentación',
  170. sourceVideo: 'Archivo de vídeo',
  171. sourceType: 'Tipo',
  172. linkTemplate: '<a href="%src%">%type%</a> ',
  173. fallbackTemplate: 'Su navegador no soporta el tag video.<br>Por favor, descargue el fichero: %links%',
  174. infoLabel: 'Información',
  175. html360: 'Esta funcionalidad (sólo MP4) todavía se encuentra en modo BETA.<br />Sólo funciona en páginas dinámicas, mas no dentro de documentos<br />creados en la herramienta de documentos o visualizados a través<br />de las lecciones.<br />Por favor no colocar más de un vídeo 360° en una misma página<br />ya que puede provocar conflictos y bloquearlos todos.',
  176. video360: 'Habilitar reproductor de vídeo 360°',
  177. video360stereo: 'Vídeo estéreo (relación de aspecto 1:1)',
  178. responsive: 'Tamaño adaptable (tamaño optimizado para móviles)',
  179. ratio16by9: 'Relación de aspecto 16:9',
  180. ratio4by3: 'Relación de aspecto 4:3'
  181. };
  182. var fr = {
  183. toolbar: 'Vidéo',
  184. dialogTitle: 'Propiétés de la vidéo',
  185. fakeObject: 'Vidéo',
  186. properties: 'Éditer la vidéo',
  187. widthRequired: 'La largeur ne peut pas être vide',
  188. heightRequired: 'La hauteur ne peut pas être vide',
  189. poster: 'Image de prévisualisation',
  190. sourceVideo: 'Fichier vidéo',
  191. sourceType: 'Type',
  192. linkTemplate: '<a href="%src%">%type%</a> ',
  193. fallbackTemplate: 'Votre navigateur ne supporte pas le tag video.<br>Merci de télécharger la vidéo ici: %links%',
  194. infoLabel: 'Information',
  195. html360: 'Cette fonctionnalité (MP4 uniquement) est actuellement en mode BETA.<br />Elle ne fonctionne que sur les pages dynamiques, et pas<br />dans les documents créés à partir de l\'outil document ou visualisés<br />au travers de l\'outil parcours.<br />Merci de ne pas placer plus d\'une vidéo 360° par page. Cela<br />peut causer des conflits et toutes les rendre inactives.',
  196. video360: 'Activer la visualisation 360°',
  197. video360stereo: 'Vidéo stéréo (proportions 1:1 / apparence de 2 vidéos superposées)',
  198. responsive: 'Resposive',
  199. ratio16by9: '16:9 aspect ratio',
  200. ratio4by3: '4:3 aspect ratio'
  201. };
  202. // v3
  203. if (CKEDITOR.skins)
  204. {
  205. en = { video : en} ;
  206. es = { video : es} ;
  207. fr = { video : fr} ;
  208. }
  209. // Translations
  210. CKEDITOR.plugins.setLang( 'video', 'en', en );
  211. CKEDITOR.plugins.setLang( 'video', 'es', es );
  212. CKEDITOR.plugins.setLang( 'video', 'fr', fr );
  213. })();