CKEDITOR.plugins.add( 'html5video', { requires: 'widget', lang: 'de,en,eu,es,ru,uk,fr', icons: 'html5video', init: function( editor ) { editor.widgets.add( 'html5video', { button: editor.lang.html5video.button, template: '
', /* * Allowed content rules (http://docs.ckeditor.com/#!/guide/dev_allowed_content_rules): * - div-s with text-align,float,margin-left,margin-right inline style rules and required ckeditor-html5-video class. * - video tags with src, controls, width and height attributes. */ allowedContent: 'div[data-responsive](!ckeditor-html5-video){text-align,float,margin-left,margin-right}; video[src,controls,autoplay,width, height]{max-width,height};', requiredContent: 'div(ckeditor-html5-video); video[src,controls];', upcast: function( element ) { return element.name === 'div' && element.hasClass( 'ckeditor-html5-video' ); }, dialog: 'html5video', init: function() { var src = ''; var autoplay = ''; var align = this.element.getStyle( 'text-align' ); var width = ''; var height = ''; // If there's a child (the video element) if ( this.element.getChild( 0 ) ) { // get it's attributes. src = this.element.getChild( 0 ).getAttribute( 'src' ); width = this.element.getChild( 0 ).getAttribute( 'width' ); height = this.element.getChild( 0 ).getAttribute( 'height' ); autoplay = this.element.getChild( 0 ).getAttribute( 'autoplay' ); responsive = this.element.getAttribute( 'data-responsive' ); } if ( src ) { this.setData( 'src', src ); if ( align ) { this.setData( 'align', align ); } else { this.setData( 'align', 'none' ); } if ( width ) { this.setData( 'width', width ); } if ( height ) { this.setData( 'height', height ); } if ( autoplay ) { this.setData( 'autoplay', 'yes' ); } if ( responsive ) { this.setData( 'responsive', responsive ); } } }, data: function() { // If there is an video source if ( this.data.src ) { // and there isn't a child (the video element) if ( !this.element.getChild( 0 ) ) { // Create a new