You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
					
					
						
							1149 lines
						
					
					
						
							35 KiB
						
					
					
				
			
		
		
		
			
			
			
				
					
				
				
					
				
			
		
		
	
	
							1149 lines
						
					
					
						
							35 KiB
						
					
					
				| (function () { | |
| var media = (function () { | |
|   'use strict'; | |
| 
 | |
|   var PluginManager = tinymce.util.Tools.resolve('tinymce.PluginManager'); | |
| 
 | |
|   var Env = tinymce.util.Tools.resolve('tinymce.Env'); | |
| 
 | |
|   var Tools = tinymce.util.Tools.resolve('tinymce.util.Tools'); | |
| 
 | |
|   var getScripts = function (editor) { | |
|     return editor.getParam('media_scripts'); | |
|   }; | |
|   var getAudioTemplateCallback = function (editor) { | |
|     return editor.getParam('audio_template_callback'); | |
|   }; | |
|   var getVideoTemplateCallback = function (editor) { | |
|     return editor.getParam('video_template_callback'); | |
|   }; | |
|   var hasLiveEmbeds = function (editor) { | |
|     return editor.getParam('media_live_embeds', true); | |
|   }; | |
|   var shouldFilterHtml = function (editor) { | |
|     return editor.getParam('media_filter_html', true); | |
|   }; | |
|   var getUrlResolver = function (editor) { | |
|     return editor.getParam('media_url_resolver'); | |
|   }; | |
|   var hasAltSource = function (editor) { | |
|     return editor.getParam('media_alt_source', true); | |
|   }; | |
|   var hasPoster = function (editor) { | |
|     return editor.getParam('media_poster', true); | |
|   }; | |
|   var hasDimensions = function (editor) { | |
|     return editor.getParam('media_dimensions', true); | |
|   }; | |
|   var $_1tfjqtfmjd09ewkg = { | |
|     getScripts: getScripts, | |
|     getAudioTemplateCallback: getAudioTemplateCallback, | |
|     getVideoTemplateCallback: getVideoTemplateCallback, | |
|     hasLiveEmbeds: hasLiveEmbeds, | |
|     shouldFilterHtml: shouldFilterHtml, | |
|     getUrlResolver: getUrlResolver, | |
|     hasAltSource: hasAltSource, | |
|     hasPoster: hasPoster, | |
|     hasDimensions: hasDimensions | |
|   }; | |
| 
 | |
|   var SaxParser = tinymce.util.Tools.resolve('tinymce.html.SaxParser'); | |
| 
 | |
|   var DOMUtils = tinymce.util.Tools.resolve('tinymce.dom.DOMUtils'); | |
| 
 | |
|   var getVideoScriptMatch = function (prefixes, src) { | |
|     if (prefixes) { | |
|       for (var i = 0; i < prefixes.length; i++) { | |
|         if (src.indexOf(prefixes[i].filter) !== -1) { | |
|           return prefixes[i]; | |
|         } | |
|       } | |
|     } | |
|   }; | |
|   var $_1bx4sdfqjd09ewkl = { getVideoScriptMatch: getVideoScriptMatch }; | |
| 
 | |
|   var trimPx = function (value) { | |
|     return value.replace(/px$/, ''); | |
|   }; | |
|   var addPx = function (value) { | |
|     return /^[0-9.]+$/.test(value) ? value + 'px' : value; | |
|   }; | |
|   var getSize = function (name) { | |
|     return function (elm) { | |
|       return elm ? trimPx(elm.style[name]) : ''; | |
|     }; | |
|   }; | |
|   var setSize = function (name) { | |
|     return function (elm, value) { | |
|       if (elm) { | |
|         elm.style[name] = addPx(value); | |
|       } | |
|     }; | |
|   }; | |
|   var $_8ety5pfrjd09ewkm = { | |
|     getMaxWidth: getSize('maxWidth'), | |
|     getMaxHeight: getSize('maxHeight'), | |
|     setMaxWidth: setSize('maxWidth'), | |
|     setMaxHeight: setSize('maxHeight') | |
|   }; | |
| 
 | |
|   var DOM = DOMUtils.DOM; | |
|   var getEphoxEmbedIri = function (elm) { | |
|     return DOM.getAttrib(elm, 'data-ephox-embed-iri'); | |
|   }; | |
|   var isEphoxEmbed = function (html) { | |
|     var fragment = DOM.createFragment(html); | |
|     return getEphoxEmbedIri(fragment.firstChild) !== ''; | |
|   }; | |
|   var htmlToDataSax = function (prefixes, html) { | |
|     var data = {}; | |
|     SaxParser({ | |
|       validate: false, | |
|       allow_conditional_comments: true, | |
|       special: 'script,noscript', | |
|       start: function (name, attrs) { | |
|         if (!data.source1 && name === 'param') { | |
|           data.source1 = attrs.map.movie; | |
|         } | |
|         if (name === 'iframe' || name === 'object' || name === 'embed' || name === 'video' || name === 'audio') { | |
|           if (!data.type) { | |
|             data.type = name; | |
|           } | |
|           data = Tools.extend(attrs.map, data); | |
|         } | |
|         if (name === 'script') { | |
|           var videoScript = $_1bx4sdfqjd09ewkl.getVideoScriptMatch(prefixes, attrs.map.src); | |
|           if (!videoScript) { | |
|             return; | |
|           } | |
|           data = { | |
|             type: 'script', | |
|             source1: attrs.map.src, | |
|             width: videoScript.width, | |
|             height: videoScript.height | |
|           }; | |
|         } | |
|         if (name === 'source') { | |
|           if (!data.source1) { | |
|             data.source1 = attrs.map.src; | |
|           } else if (!data.source2) { | |
|             data.source2 = attrs.map.src; | |
|           } | |
|         } | |
|         if (name === 'img' && !data.poster) { | |
|           data.poster = attrs.map.src; | |
|         } | |
|       } | |
|     }).parse(html); | |
|     data.source1 = data.source1 || data.src || data.data; | |
|     data.source2 = data.source2 || ''; | |
|     data.poster = data.poster || ''; | |
|     return data; | |
|   }; | |
|   var ephoxEmbedHtmlToData = function (html) { | |
|     var fragment = DOM.createFragment(html); | |
|     var div = fragment.firstChild; | |
|     return { | |
|       type: 'ephox-embed-iri', | |
|       source1: getEphoxEmbedIri(div), | |
|       source2: '', | |
|       poster: '', | |
|       width: $_8ety5pfrjd09ewkm.getMaxWidth(div), | |
|       height: $_8ety5pfrjd09ewkm.getMaxHeight(div) | |
|     }; | |
|   }; | |
|   var htmlToData = function (prefixes, html) { | |
|     return isEphoxEmbed(html) ? ephoxEmbedHtmlToData(html) : htmlToDataSax(prefixes, html); | |
|   }; | |
|   var $_9yns3gfnjd09ewki = { htmlToData: htmlToData }; | |
| 
 | |
|   var Promise = tinymce.util.Tools.resolve('tinymce.util.Promise'); | |
| 
 | |
|   var guess = function (url) { | |
|     var mimes = { | |
|       mp3: 'audio/mpeg', | |
|       wav: 'audio/wav', | |
|       mp4: 'video/mp4', | |
|       webm: 'video/webm', | |
|       ogg: 'video/ogg', | |
|       swf: 'application/x-shockwave-flash' | |
|     }; | |
|     var fileEnd = url.toLowerCase().split('.').pop(); | |
|     var mime = mimes[fileEnd]; | |
|     return mime ? mime : ''; | |
|   }; | |
|   var $_ewf2vefvjd09ewku = { guess: guess }; | |
| 
 | |
|   var Writer = tinymce.util.Tools.resolve('tinymce.html.Writer'); | |
| 
 | |
|   var Schema = tinymce.util.Tools.resolve('tinymce.html.Schema'); | |
| 
 | |
|   var DOM$1 = DOMUtils.DOM; | |
|   var setAttributes = function (attrs, updatedAttrs) { | |
|     var name; | |
|     var i; | |
|     var value; | |
|     var attr; | |
|     for (name in updatedAttrs) { | |
|       value = '' + updatedAttrs[name]; | |
|       if (attrs.map[name]) { | |
|         i = attrs.length; | |
|         while (i--) { | |
|           attr = attrs[i]; | |
|           if (attr.name === name) { | |
|             if (value) { | |
|               attrs.map[name] = value; | |
|               attr.value = value; | |
|             } else { | |
|               delete attrs.map[name]; | |
|               attrs.splice(i, 1); | |
|             } | |
|           } | |
|         } | |
|       } else if (value) { | |
|         attrs.push({ | |
|           name: name, | |
|           value: value | |
|         }); | |
|         attrs.map[name] = value; | |
|       } | |
|     } | |
|   }; | |
|   var normalizeHtml = function (html) { | |
|     var writer = Writer(); | |
|     var parser = SaxParser(writer); | |
|     parser.parse(html); | |
|     return writer.getContent(); | |
|   }; | |
|   var updateHtmlSax = function (html, data, updateAll) { | |
|     var writer = Writer(); | |
|     var sourceCount = 0; | |
|     var hasImage; | |
|     SaxParser({ | |
|       validate: false, | |
|       allow_conditional_comments: true, | |
|       special: 'script,noscript', | |
|       comment: function (text) { | |
|         writer.comment(text); | |
|       }, | |
|       cdata: function (text) { | |
|         writer.cdata(text); | |
|       }, | |
|       text: function (text, raw) { | |
|         writer.text(text, raw); | |
|       }, | |
|       start: function (name, attrs, empty) { | |
|         switch (name) { | |
|         case 'video': | |
|         case 'object': | |
|         case 'embed': | |
|         case 'img': | |
|         case 'iframe': | |
|           if (data.height !== undefined && data.width !== undefined) { | |
|             setAttributes(attrs, { | |
|               width: data.width, | |
|               height: data.height | |
|             }); | |
|           } | |
|           break; | |
|         } | |
|         if (updateAll) { | |
|           switch (name) { | |
|           case 'video': | |
|             setAttributes(attrs, { | |
|               poster: data.poster, | |
|               src: '' | |
|             }); | |
|             if (data.source2) { | |
|               setAttributes(attrs, { src: '' }); | |
|             } | |
|             break; | |
|           case 'iframe': | |
|             setAttributes(attrs, { src: data.source1 }); | |
|             break; | |
|           case 'source': | |
|             sourceCount++; | |
|             if (sourceCount <= 2) { | |
|               setAttributes(attrs, { | |
|                 src: data['source' + sourceCount], | |
|                 type: data['source' + sourceCount + 'mime'] | |
|               }); | |
|               if (!data['source' + sourceCount]) { | |
|                 return; | |
|               } | |
|             } | |
|             break; | |
|           case 'img': | |
|             if (!data.poster) { | |
|               return; | |
|             } | |
|             hasImage = true; | |
|             break; | |
|           } | |
|         } | |
|         writer.start(name, attrs, empty); | |
|       }, | |
|       end: function (name) { | |
|         if (name === 'video' && updateAll) { | |
|           for (var index = 1; index <= 2; index++) { | |
|             if (data['source' + index]) { | |
|               var attrs = []; | |
|               attrs.map = {}; | |
|               if (sourceCount < index) { | |
|                 setAttributes(attrs, { | |
|                   src: data['source' + index], | |
|                   type: data['source' + index + 'mime'] | |
|                 }); | |
|                 writer.start('source', attrs, true); | |
|               } | |
|             } | |
|           } | |
|         } | |
|         if (data.poster && name === 'object' && updateAll && !hasImage) { | |
|           var imgAttrs = []; | |
|           imgAttrs.map = {}; | |
|           setAttributes(imgAttrs, { | |
|             src: data.poster, | |
|             width: data.width, | |
|             height: data.height | |
|           }); | |
|           writer.start('img', imgAttrs, true); | |
|         } | |
|         writer.end(name); | |
|       } | |
|     }, Schema({})).parse(html); | |
|     return writer.getContent(); | |
|   }; | |
|   var isEphoxEmbed$1 = function (html) { | |
|     var fragment = DOM$1.createFragment(html); | |
|     return DOM$1.getAttrib(fragment.firstChild, 'data-ephox-embed-iri') !== ''; | |
|   }; | |
|   var updateEphoxEmbed = function (html, data) { | |
|     var fragment = DOM$1.createFragment(html); | |
|     var div = fragment.firstChild; | |
|     $_8ety5pfrjd09ewkm.setMaxWidth(div, data.width); | |
|     $_8ety5pfrjd09ewkm.setMaxHeight(div, data.height); | |
|     return normalizeHtml(div.outerHTML); | |
|   }; | |
|   var updateHtml = function (html, data, updateAll) { | |
|     return isEphoxEmbed$1(html) ? updateEphoxEmbed(html, data) : updateHtmlSax(html, data, updateAll); | |
|   }; | |
|   var $_cvzdjgfwjd09ewkv = { updateHtml: updateHtml }; | |
| 
 | |
|   var urlPatterns = [ | |
|     { | |
|       regex: /youtu\.be\/([\w\-.]+)/, | |
|       type: 'iframe', | |
|       w: 560, | |
|       h: 314, | |
|       url: '//www.youtube.com/embed/$1', | |
|       allowFullscreen: true | |
|     }, | |
|     { | |
|       regex: /youtube\.com(.+)v=([^&]+)/, | |
|       type: 'iframe', | |
|       w: 560, | |
|       h: 314, | |
|       url: '//www.youtube.com/embed/$2', | |
|       allowFullscreen: true | |
|     }, | |
|     { | |
|       regex: /youtube.com\/embed\/([a-z0-9\-_]+(?:\?.+)?)/i, | |
|       type: 'iframe', | |
|       w: 560, | |
|       h: 314, | |
|       url: '//www.youtube.com/embed/$1', | |
|       allowFullscreen: true | |
|     }, | |
|     { | |
|       regex: /vimeo\.com\/([0-9]+)/, | |
|       type: 'iframe', | |
|       w: 425, | |
|       h: 350, | |
|       url: '//player.vimeo.com/video/$1?title=0&byline=0&portrait=0&color=8dc7dc', | |
|       allowfullscreen: true | |
|     }, | |
|     { | |
|       regex: /vimeo\.com\/(.*)\/([0-9]+)/, | |
|       type: 'iframe', | |
|       w: 425, | |
|       h: 350, | |
|       url: '//player.vimeo.com/video/$2?title=0&byline=0', | |
|       allowfullscreen: true | |
|     }, | |
|     { | |
|       regex: /maps\.google\.([a-z]{2,3})\/maps\/(.+)msid=(.+)/, | |
|       type: 'iframe', | |
|       w: 425, | |
|       h: 350, | |
|       url: '//maps.google.com/maps/ms?msid=$2&output=embed"', | |
|       allowFullscreen: false | |
|     }, | |
|     { | |
|       regex: /dailymotion\.com\/video\/([^_]+)/, | |
|       type: 'iframe', | |
|       w: 480, | |
|       h: 270, | |
|       url: '//www.dailymotion.com/embed/video/$1', | |
|       allowFullscreen: true | |
|     }, | |
|     { | |
|       regex: /dai\.ly\/([^_]+)/, | |
|       type: 'iframe', | |
|       w: 480, | |
|       h: 270, | |
|       url: '//www.dailymotion.com/embed/video/$1', | |
|       allowFullscreen: true | |
|     } | |
|   ]; | |
|   var $_2crhf0fzjd09ewl0 = { urlPatterns: urlPatterns }; | |
| 
 | |
|   var getIframeHtml = function (data) { | |
|     var allowFullscreen = data.allowFullscreen ? ' allowFullscreen="1"' : ''; | |
|     return '<iframe src="' + data.source1 + '" width="' + data.width + '" height="' + data.height + '"' + allowFullscreen + '></iframe>'; | |
|   }; | |
|   var getFlashHtml = function (data) { | |
|     var html = '<object data="' + data.source1 + '" width="' + data.width + '" height="' + data.height + '" type="application/x-shockwave-flash">'; | |
|     if (data.poster) { | |
|       html += '<img src="' + data.poster + '" width="' + data.width + '" height="' + data.height + '" />'; | |
|     } | |
|     html += '</object>'; | |
|     return html; | |
|   }; | |
|   var getAudioHtml = function (data, audioTemplateCallback) { | |
|     if (audioTemplateCallback) { | |
|       return audioTemplateCallback(data); | |
|     } else { | |
|       return '<audio controls="controls" src="' + data.source1 + '">' + (data.source2 ? '\n<source src="' + data.source2 + '"' + (data.source2mime ? ' type="' + data.source2mime + '"' : '') + ' />\n' : '') + '</audio>'; | |
|     } | |
|   }; | |
|   var getVideoHtml = function (data, videoTemplateCallback) { | |
|     if (videoTemplateCallback) { | |
|       return videoTemplateCallback(data); | |
|     } else { | |
|       return '<video width="' + data.width + '" height="' + data.height + '"' + (data.poster ? ' poster="' + data.poster + '"' : '') + ' controls="controls">\n' + '<source src="' + data.source1 + '"' + (data.source1mime ? ' type="' + data.source1mime + '"' : '') + ' />\n' + (data.source2 ? '<source src="' + data.source2 + '"' + (data.source2mime ? ' type="' + data.source2mime + '"' : '') + ' />\n' : '') + '</video>'; | |
|     } | |
|   }; | |
|   var getScriptHtml = function (data) { | |
|     return '<script src="' + data.source1 + '"></script>'; | |
|   }; | |
|   var dataToHtml = function (editor, dataIn) { | |
|     var data = Tools.extend({}, dataIn); | |
|     if (!data.source1) { | |
|       Tools.extend(data, $_9yns3gfnjd09ewki.htmlToData($_1tfjqtfmjd09ewkg.getScripts(editor), data.embed)); | |
|       if (!data.source1) { | |
|         return ''; | |
|       } | |
|     } | |
|     if (!data.source2) { | |
|       data.source2 = ''; | |
|     } | |
|     if (!data.poster) { | |
|       data.poster = ''; | |
|     } | |
|     data.source1 = editor.convertURL(data.source1, 'source'); | |
|     data.source2 = editor.convertURL(data.source2, 'source'); | |
|     data.source1mime = $_ewf2vefvjd09ewku.guess(data.source1); | |
|     data.source2mime = $_ewf2vefvjd09ewku.guess(data.source2); | |
|     data.poster = editor.convertURL(data.poster, 'poster'); | |
|     Tools.each($_2crhf0fzjd09ewl0.urlPatterns, function (pattern) { | |
|       var i; | |
|       var url; | |
|       var match = pattern.regex.exec(data.source1); | |
|       if (match) { | |
|         url = pattern.url; | |
|         for (i = 0; match[i]; i++) { | |
|           url = url.replace('$' + i, function () { | |
|             return match[i]; | |
|           }); | |
|         } | |
|         data.source1 = url; | |
|         data.type = pattern.type; | |
|         data.allowFullscreen = pattern.allowFullscreen; | |
|         data.width = data.width || pattern.w; | |
|         data.height = data.height || pattern.h; | |
|       } | |
|     }); | |
|     if (data.embed) { | |
|       return $_cvzdjgfwjd09ewkv.updateHtml(data.embed, data, true); | |
|     } else { | |
|       var videoScript = $_1bx4sdfqjd09ewkl.getVideoScriptMatch($_1tfjqtfmjd09ewkg.getScripts(editor), data.source1); | |
|       if (videoScript) { | |
|         data.type = 'script'; | |
|         data.width = videoScript.width; | |
|         data.height = videoScript.height; | |
|       } | |
|       var audioTemplateCallback = $_1tfjqtfmjd09ewkg.getAudioTemplateCallback(editor); | |
|       var videoTemplateCallback = $_1tfjqtfmjd09ewkg.getVideoTemplateCallback(editor); | |
|       data.width = data.width || 300; | |
|       data.height = data.height || 150; | |
|       Tools.each(data, function (value, key) { | |
|         data[key] = editor.dom.encode(value); | |
|       }); | |
|       if (data.type === 'iframe') { | |
|         return getIframeHtml(data); | |
|       } else if (data.source1mime === 'application/x-shockwave-flash') { | |
|         return getFlashHtml(data); | |
|       } else if (data.source1mime.indexOf('audio') !== -1) { | |
|         return getAudioHtml(data, audioTemplateCallback); | |
|       } else if (data.type === 'script') { | |
|         return getScriptHtml(data); | |
|       } else { | |
|         return getVideoHtml(data, videoTemplateCallback); | |
|       } | |
|     } | |
|   }; | |
|   var $_dxqeshfujd09ewkq = { dataToHtml: dataToHtml }; | |
| 
 | |
|   var cache = {}; | |
|   var embedPromise = function (data, dataToHtml, handler) { | |
|     return new Promise(function (res, rej) { | |
|       var wrappedResolve = function (response) { | |
|         if (response.html) { | |
|           cache[data.source1] = response; | |
|         } | |
|         return res({ | |
|           url: data.source1, | |
|           html: response.html ? response.html : dataToHtml(data) | |
|         }); | |
|       }; | |
|       if (cache[data.source1]) { | |
|         wrappedResolve(cache[data.source1]); | |
|       } else { | |
|         handler({ url: data.source1 }, wrappedResolve, rej); | |
|       } | |
|     }); | |
|   }; | |
|   var defaultPromise = function (data, dataToHtml) { | |
|     return new Promise(function (res) { | |
|       res({ | |
|         html: dataToHtml(data), | |
|         url: data.source1 | |
|       }); | |
|     }); | |
|   }; | |
|   var loadedData = function (editor) { | |
|     return function (data) { | |
|       return $_dxqeshfujd09ewkq.dataToHtml(editor, data); | |
|     }; | |
|   }; | |
|   var getEmbedHtml = function (editor, data) { | |
|     var embedHandler = $_1tfjqtfmjd09ewkg.getUrlResolver(editor); | |
|     return embedHandler ? embedPromise(data, loadedData(editor), embedHandler) : defaultPromise(data, loadedData(editor)); | |
|   }; | |
|   var isCached = function (url) { | |
|     return cache.hasOwnProperty(url); | |
|   }; | |
|   var $_9g41lqfsjd09ewko = { | |
|     getEmbedHtml: getEmbedHtml, | |
|     isCached: isCached | |
|   }; | |
| 
 | |
|   var doSyncSize = function (widthCtrl, heightCtrl) { | |
|     widthCtrl.state.set('oldVal', widthCtrl.value()); | |
|     heightCtrl.state.set('oldVal', heightCtrl.value()); | |
|   }; | |
|   var doSizeControls = function (win, f) { | |
|     var widthCtrl = win.find('#width')[0]; | |
|     var heightCtrl = win.find('#height')[0]; | |
|     var constrained = win.find('#constrain')[0]; | |
|     if (widthCtrl && heightCtrl && constrained) { | |
|       f(widthCtrl, heightCtrl, constrained.checked()); | |
|     } | |
|   }; | |
|   var doUpdateSize = function (widthCtrl, heightCtrl, isContrained) { | |
|     var oldWidth = widthCtrl.state.get('oldVal'); | |
|     var oldHeight = heightCtrl.state.get('oldVal'); | |
|     var newWidth = widthCtrl.value(); | |
|     var newHeight = heightCtrl.value(); | |
|     if (isContrained && oldWidth && oldHeight && newWidth && newHeight) { | |
|       if (newWidth !== oldWidth) { | |
|         newHeight = Math.round(newWidth / oldWidth * newHeight); | |
|         if (!isNaN(newHeight)) { | |
|           heightCtrl.value(newHeight); | |
|         } | |
|       } else { | |
|         newWidth = Math.round(newHeight / oldHeight * newWidth); | |
|         if (!isNaN(newWidth)) { | |
|           widthCtrl.value(newWidth); | |
|         } | |
|       } | |
|     } | |
|     doSyncSize(widthCtrl, heightCtrl); | |
|   }; | |
|   var syncSize = function (win) { | |
|     doSizeControls(win, doSyncSize); | |
|   }; | |
|   var updateSize = function (win) { | |
|     doSizeControls(win, doUpdateSize); | |
|   }; | |
|   var createUi = function (onChange) { | |
|     var recalcSize = function () { | |
|       onChange(function (win) { | |
|         updateSize(win); | |
|       }); | |
|     }; | |
|     return { | |
|       type: 'container', | |
|       label: 'Dimensions', | |
|       layout: 'flex', | |
|       align: 'center', | |
|       spacing: 5, | |
|       items: [ | |
|         { | |
|           name: 'width', | |
|           type: 'textbox', | |
|           maxLength: 5, | |
|           size: 5, | |
|           onchange: recalcSize, | |
|           ariaLabel: 'Width' | |
|         }, | |
|         { | |
|           type: 'label', | |
|           text: 'x' | |
|         }, | |
|         { | |
|           name: 'height', | |
|           type: 'textbox', | |
|           maxLength: 5, | |
|           size: 5, | |
|           onchange: recalcSize, | |
|           ariaLabel: 'Height' | |
|         }, | |
|         { | |
|           name: 'constrain', | |
|           type: 'checkbox', | |
|           checked: true, | |
|           text: 'Constrain proportions' | |
|         } | |
|       ] | |
|     }; | |
|   }; | |
|   var $_d5khl5g0jd09ewl1 = { | |
|     createUi: createUi, | |
|     syncSize: syncSize, | |
|     updateSize: updateSize | |
|   }; | |
| 
 | |
|   var embedChange = Env.ie && Env.ie <= 8 ? 'onChange' : 'onInput'; | |
|   var handleError = function (editor) { | |
|     return function (error) { | |
|       var errorMessage = error && error.msg ? 'Media embed handler error: ' + error.msg : 'Media embed handler threw unknown error.'; | |
|       editor.notificationManager.open({ | |
|         type: 'error', | |
|         text: errorMessage | |
|       }); | |
|     }; | |
|   }; | |
|   var getData = function (editor) { | |
|     var element = editor.selection.getNode(); | |
|     var dataEmbed = element.getAttribute('data-ephox-embed-iri'); | |
|     if (dataEmbed) { | |
|       return { | |
|         'source1': dataEmbed, | |
|         'data-ephox-embed-iri': dataEmbed, | |
|         'width': $_8ety5pfrjd09ewkm.getMaxWidth(element), | |
|         'height': $_8ety5pfrjd09ewkm.getMaxHeight(element) | |
|       }; | |
|     } | |
|     return element.getAttribute('data-mce-object') ? $_9yns3gfnjd09ewki.htmlToData($_1tfjqtfmjd09ewkg.getScripts(editor), editor.serializer.serialize(element, { selection: true })) : {}; | |
|   }; | |
|   var getSource = function (editor) { | |
|     var elm = editor.selection.getNode(); | |
|     if (elm.getAttribute('data-mce-object') || elm.getAttribute('data-ephox-embed-iri')) { | |
|       return editor.selection.getContent(); | |
|     } | |
|   }; | |
|   var addEmbedHtml = function (win, editor) { | |
|     return function (response) { | |
|       var html = response.html; | |
|       var embed = win.find('#embed')[0]; | |
|       var data = Tools.extend($_9yns3gfnjd09ewki.htmlToData($_1tfjqtfmjd09ewkg.getScripts(editor), html), { source1: response.url }); | |
|       win.fromJSON(data); | |
|       if (embed) { | |
|         embed.value(html); | |
|         $_d5khl5g0jd09ewl1.updateSize(win); | |
|       } | |
|     }; | |
|   }; | |
|   var selectPlaceholder = function (editor, beforeObjects) { | |
|     var i; | |
|     var y; | |
|     var afterObjects = editor.dom.select('img[data-mce-object]'); | |
|     for (i = 0; i < beforeObjects.length; i++) { | |
|       for (y = afterObjects.length - 1; y >= 0; y--) { | |
|         if (beforeObjects[i] === afterObjects[y]) { | |
|           afterObjects.splice(y, 1); | |
|         } | |
|       } | |
|     } | |
|     editor.selection.select(afterObjects[0]); | |
|   }; | |
|   var handleInsert = function (editor, html) { | |
|     var beforeObjects = editor.dom.select('img[data-mce-object]'); | |
|     editor.insertContent(html); | |
|     selectPlaceholder(editor, beforeObjects); | |
|     editor.nodeChanged(); | |
|   }; | |
|   var submitForm = function (win, editor) { | |
|     var data = win.toJSON(); | |
|     data.embed = $_cvzdjgfwjd09ewkv.updateHtml(data.embed, data); | |
|     if (data.embed && $_9g41lqfsjd09ewko.isCached(data.source1)) { | |
|       handleInsert(editor, data.embed); | |
|     } else { | |
|       $_9g41lqfsjd09ewko.getEmbedHtml(editor, data).then(function (response) { | |
|         handleInsert(editor, response.html); | |
|       }).catch(handleError(editor)); | |
|     } | |
|   }; | |
|   var populateMeta = function (win, meta) { | |
|     Tools.each(meta, function (value, key) { | |
|       win.find('#' + key).value(value); | |
|     }); | |
|   }; | |
|   var showDialog = function (editor) { | |
|     var win; | |
|     var data; | |
|     var generalFormItems = [{ | |
|         name: 'source1', | |
|         type: 'filepicker', | |
|         filetype: 'media', | |
|         size: 40, | |
|         autofocus: true, | |
|         label: 'Source', | |
|         onpaste: function () { | |
|           setTimeout(function () { | |
|             $_9g41lqfsjd09ewko.getEmbedHtml(editor, win.toJSON()).then(addEmbedHtml(win, editor)).catch(handleError(editor)); | |
|           }, 1); | |
|         }, | |
|         onchange: function (e) { | |
|           $_9g41lqfsjd09ewko.getEmbedHtml(editor, win.toJSON()).then(addEmbedHtml(win, editor)).catch(handleError(editor)); | |
|           populateMeta(win, e.meta); | |
|         }, | |
|         onbeforecall: function (e) { | |
|           e.meta = win.toJSON(); | |
|         } | |
|       }]; | |
|     var advancedFormItems = []; | |
|     var reserialise = function (update) { | |
|       update(win); | |
|       data = win.toJSON(); | |
|       win.find('#embed').value($_cvzdjgfwjd09ewkv.updateHtml(data.embed, data)); | |
|     }; | |
|     if ($_1tfjqtfmjd09ewkg.hasAltSource(editor)) { | |
|       advancedFormItems.push({ | |
|         name: 'source2', | |
|         type: 'filepicker', | |
|         filetype: 'media', | |
|         size: 40, | |
|         label: 'Alternative source' | |
|       }); | |
|     } | |
|     if ($_1tfjqtfmjd09ewkg.hasPoster(editor)) { | |
|       advancedFormItems.push({ | |
|         name: 'poster', | |
|         type: 'filepicker', | |
|         filetype: 'image', | |
|         size: 40, | |
|         label: 'Poster' | |
|       }); | |
|     } | |
|     if ($_1tfjqtfmjd09ewkg.hasDimensions(editor)) { | |
|       var control = $_d5khl5g0jd09ewl1.createUi(reserialise); | |
|       generalFormItems.push(control); | |
|     } | |
|     data = getData(editor); | |
|     var embedTextBox = { | |
|       id: 'mcemediasource', | |
|       type: 'textbox', | |
|       flex: 1, | |
|       name: 'embed', | |
|       value: getSource(editor), | |
|       multiline: true, | |
|       rows: 5, | |
|       label: 'Source' | |
|     }; | |
|     var updateValueOnChange = function () { | |
|       data = Tools.extend({}, $_9yns3gfnjd09ewki.htmlToData($_1tfjqtfmjd09ewkg.getScripts(editor), this.value())); | |
|       this.parent().parent().fromJSON(data); | |
|     }; | |
|     embedTextBox[embedChange] = updateValueOnChange; | |
|     win = editor.windowManager.open({ | |
|       title: 'Insert/edit media', | |
|       data: data, | |
|       bodyType: 'tabpanel', | |
|       body: [ | |
|         { | |
|           title: 'General', | |
|           type: 'form', | |
|           items: generalFormItems | |
|         }, | |
|         { | |
|           title: 'Embed', | |
|           type: 'container', | |
|           layout: 'flex', | |
|           direction: 'column', | |
|           align: 'stretch', | |
|           padding: 10, | |
|           spacing: 10, | |
|           items: [ | |
|             { | |
|               type: 'label', | |
|               text: 'Paste your embed code below:', | |
|               forId: 'mcemediasource' | |
|             }, | |
|             embedTextBox | |
|           ] | |
|         }, | |
|         { | |
|           title: 'Advanced', | |
|           type: 'form', | |
|           items: advancedFormItems | |
|         } | |
|       ], | |
|       onSubmit: function () { | |
|         $_d5khl5g0jd09ewl1.updateSize(win); | |
|         submitForm(win, editor); | |
|       } | |
|     }); | |
|     $_d5khl5g0jd09ewl1.syncSize(win); | |
|   }; | |
|   var $_7fafopfjjd09ewk8 = { showDialog: showDialog }; | |
| 
 | |
|   var get = function (editor) { | |
|     var showDialog = function () { | |
|       $_7fafopfjjd09ewk8.showDialog(editor); | |
|     }; | |
|     return { showDialog: showDialog }; | |
|   }; | |
|   var $_umcglfijd09ewk7 = { get: get }; | |
| 
 | |
|   var register = function (editor) { | |
|     var showDialog = function () { | |
|       $_7fafopfjjd09ewk8.showDialog(editor); | |
|     }; | |
|     editor.addCommand('mceMedia', showDialog); | |
|   }; | |
|   var $_7snympg1jd09ewla = { register: register }; | |
| 
 | |
|   var Node = tinymce.util.Tools.resolve('tinymce.html.Node'); | |
| 
 | |
|   var sanitize = function (editor, html) { | |
|     if ($_1tfjqtfmjd09ewkg.shouldFilterHtml(editor) === false) { | |
|       return html; | |
|     } | |
|     var writer = Writer(); | |
|     var blocked; | |
|     SaxParser({ | |
|       validate: false, | |
|       allow_conditional_comments: false, | |
|       special: 'script,noscript', | |
|       comment: function (text) { | |
|         writer.comment(text); | |
|       }, | |
|       cdata: function (text) { | |
|         writer.cdata(text); | |
|       }, | |
|       text: function (text, raw) { | |
|         writer.text(text, raw); | |
|       }, | |
|       start: function (name, attrs, empty) { | |
|         blocked = true; | |
|         if (name === 'script' || name === 'noscript') { | |
|           return; | |
|         } | |
|         for (var i = 0; i < attrs.length; i++) { | |
|           if (attrs[i].name.indexOf('on') === 0) { | |
|             return; | |
|           } | |
|           if (attrs[i].name === 'style') { | |
|             attrs[i].value = editor.dom.serializeStyle(editor.dom.parseStyle(attrs[i].value), name); | |
|           } | |
|         } | |
|         writer.start(name, attrs, empty); | |
|         blocked = false; | |
|       }, | |
|       end: function (name) { | |
|         if (blocked) { | |
|           return; | |
|         } | |
|         writer.end(name); | |
|       } | |
|     }, Schema({})).parse(html); | |
|     return writer.getContent(); | |
|   }; | |
|   var $_8f3uzfg5jd09ewll = { sanitize: sanitize }; | |
| 
 | |
|   var createPlaceholderNode = function (editor, node) { | |
|     var placeHolder; | |
|     var name = node.name; | |
|     placeHolder = new Node('img', 1); | |
|     placeHolder.shortEnded = true; | |
|     retainAttributesAndInnerHtml(editor, node, placeHolder); | |
|     placeHolder.attr({ | |
|       'width': node.attr('width') || '300', | |
|       'height': node.attr('height') || (name === 'audio' ? '30' : '150'), | |
|       'style': node.attr('style'), | |
|       'src': Env.transparentSrc, | |
|       'data-mce-object': name, | |
|       'class': 'mce-object mce-object-' + name | |
|     }); | |
|     return placeHolder; | |
|   }; | |
|   var createPreviewIframeNode = function (editor, node) { | |
|     var previewWrapper; | |
|     var previewNode; | |
|     var shimNode; | |
|     var name = node.name; | |
|     previewWrapper = new Node('span', 1); | |
|     previewWrapper.attr({ | |
|       'contentEditable': 'false', | |
|       'style': node.attr('style'), | |
|       'data-mce-object': name, | |
|       'class': 'mce-preview-object mce-object-' + name | |
|     }); | |
|     retainAttributesAndInnerHtml(editor, node, previewWrapper); | |
|     previewNode = new Node(name, 1); | |
|     previewNode.attr({ | |
|       src: node.attr('src'), | |
|       allowfullscreen: node.attr('allowfullscreen'), | |
|       width: node.attr('width') || '300', | |
|       height: node.attr('height') || (name === 'audio' ? '30' : '150'), | |
|       frameborder: '0' | |
|     }); | |
|     shimNode = new Node('span', 1); | |
|     shimNode.attr('class', 'mce-shim'); | |
|     previewWrapper.append(previewNode); | |
|     previewWrapper.append(shimNode); | |
|     return previewWrapper; | |
|   }; | |
|   var retainAttributesAndInnerHtml = function (editor, sourceNode, targetNode) { | |
|     var attrName; | |
|     var attrValue; | |
|     var attribs; | |
|     var ai; | |
|     var innerHtml; | |
|     attribs = sourceNode.attributes; | |
|     ai = attribs.length; | |
|     while (ai--) { | |
|       attrName = attribs[ai].name; | |
|       attrValue = attribs[ai].value; | |
|       if (attrName !== 'width' && attrName !== 'height' && attrName !== 'style') { | |
|         if (attrName === 'data' || attrName === 'src') { | |
|           attrValue = editor.convertURL(attrValue, attrName); | |
|         } | |
|         targetNode.attr('data-mce-p-' + attrName, attrValue); | |
|       } | |
|     } | |
|     innerHtml = sourceNode.firstChild && sourceNode.firstChild.value; | |
|     if (innerHtml) { | |
|       targetNode.attr('data-mce-html', escape($_8f3uzfg5jd09ewll.sanitize(editor, innerHtml))); | |
|       targetNode.firstChild = null; | |
|     } | |
|   }; | |
|   var isWithinEphoxEmbed = function (node) { | |
|     while (node = node.parent) { | |
|       if (node.attr('data-ephox-embed-iri')) { | |
|         return true; | |
|       } | |
|     } | |
|     return false; | |
|   }; | |
|   var placeHolderConverter = function (editor) { | |
|     return function (nodes) { | |
|       var i = nodes.length; | |
|       var node; | |
|       var videoScript; | |
|       while (i--) { | |
|         node = nodes[i]; | |
|         if (!node.parent) { | |
|           continue; | |
|         } | |
|         if (node.parent.attr('data-mce-object')) { | |
|           continue; | |
|         } | |
|         if (node.name === 'script') { | |
|           videoScript = $_1bx4sdfqjd09ewkl.getVideoScriptMatch($_1tfjqtfmjd09ewkg.getScripts(editor), node.attr('src')); | |
|           if (!videoScript) { | |
|             continue; | |
|           } | |
|         } | |
|         if (videoScript) { | |
|           if (videoScript.width) { | |
|             node.attr('width', videoScript.width.toString()); | |
|           } | |
|           if (videoScript.height) { | |
|             node.attr('height', videoScript.height.toString()); | |
|           } | |
|         } | |
|         if (node.name === 'iframe' && $_1tfjqtfmjd09ewkg.hasLiveEmbeds(editor) && Env.ceFalse) { | |
|           if (!isWithinEphoxEmbed(node)) { | |
|             node.replace(createPreviewIframeNode(editor, node)); | |
|           } | |
|         } else { | |
|           if (!isWithinEphoxEmbed(node)) { | |
|             node.replace(createPlaceholderNode(editor, node)); | |
|           } | |
|         } | |
|       } | |
|     }; | |
|   }; | |
|   var $_504mbjg4jd09ewlg = { | |
|     createPreviewIframeNode: createPreviewIframeNode, | |
|     createPlaceholderNode: createPlaceholderNode, | |
|     placeHolderConverter: placeHolderConverter | |
|   }; | |
| 
 | |
|   var setup = function (editor) { | |
|     editor.on('preInit', function () { | |
|       var specialElements = editor.schema.getSpecialElements(); | |
|       Tools.each('video audio iframe object'.split(' '), function (name) { | |
|         specialElements[name] = new RegExp('</' + name + '[^>]*>', 'gi'); | |
|       }); | |
|       var boolAttrs = editor.schema.getBoolAttrs(); | |
|       Tools.each('webkitallowfullscreen mozallowfullscreen allowfullscreen'.split(' '), function (name) { | |
|         boolAttrs[name] = {}; | |
|       }); | |
|       editor.parser.addNodeFilter('iframe,video,audio,object,embed,script', $_504mbjg4jd09ewlg.placeHolderConverter(editor)); | |
|       editor.serializer.addAttributeFilter('data-mce-object', function (nodes, name) { | |
|         var i = nodes.length; | |
|         var node; | |
|         var realElm; | |
|         var ai; | |
|         var attribs; | |
|         var innerHtml; | |
|         var innerNode; | |
|         var realElmName; | |
|         var className; | |
|         while (i--) { | |
|           node = nodes[i]; | |
|           if (!node.parent) { | |
|             continue; | |
|           } | |
|           realElmName = node.attr(name); | |
|           realElm = new Node(realElmName, 1); | |
|           if (realElmName !== 'audio' && realElmName !== 'script') { | |
|             className = node.attr('class'); | |
|             if (className && className.indexOf('mce-preview-object') !== -1) { | |
|               realElm.attr({ | |
|                 width: node.firstChild.attr('width'), | |
|                 height: node.firstChild.attr('height') | |
|               }); | |
|             } else { | |
|               realElm.attr({ | |
|                 width: node.attr('width'), | |
|                 height: node.attr('height') | |
|               }); | |
|             } | |
|           } | |
|           realElm.attr({ style: node.attr('style') }); | |
|           attribs = node.attributes; | |
|           ai = attribs.length; | |
|           while (ai--) { | |
|             var attrName = attribs[ai].name; | |
|             if (attrName.indexOf('data-mce-p-') === 0) { | |
|               realElm.attr(attrName.substr(11), attribs[ai].value); | |
|             } | |
|           } | |
|           if (realElmName === 'script') { | |
|             realElm.attr('type', 'text/javascript'); | |
|           } | |
|           innerHtml = node.attr('data-mce-html'); | |
|           if (innerHtml) { | |
|             innerNode = new Node('#text', 3); | |
|             innerNode.raw = true; | |
|             innerNode.value = $_8f3uzfg5jd09ewll.sanitize(editor, unescape(innerHtml)); | |
|             realElm.append(innerNode); | |
|           } | |
|           node.replace(realElm); | |
|         } | |
|       }); | |
|     }); | |
|     editor.on('setContent', function () { | |
|       editor.$('span.mce-preview-object').each(function (index, elm) { | |
|         var $elm = editor.$(elm); | |
|         if ($elm.find('span.mce-shim', elm).length === 0) { | |
|           $elm.append('<span class="mce-shim"></span>'); | |
|         } | |
|       }); | |
|     }); | |
|   }; | |
|   var $_7dtdp0g2jd09ewlb = { setup: setup }; | |
| 
 | |
|   var setup$1 = function (editor) { | |
|     editor.on('ResolveName', function (e) { | |
|       var name; | |
|       if (e.target.nodeType === 1 && (name = e.target.getAttribute('data-mce-object'))) { | |
|         e.name = name; | |
|       } | |
|     }); | |
|   }; | |
|   var $_1z5hrgg6jd09ewlo = { setup: setup$1 }; | |
| 
 | |
|   var setup$2 = function (editor) { | |
|     editor.on('click keyup', function () { | |
|       var selectedNode = editor.selection.getNode(); | |
|       if (selectedNode && editor.dom.hasClass(selectedNode, 'mce-preview-object')) { | |
|         if (editor.dom.getAttrib(selectedNode, 'data-mce-selected')) { | |
|           selectedNode.setAttribute('data-mce-selected', '2'); | |
|         } | |
|       } | |
|     }); | |
|     editor.on('ObjectSelected', function (e) { | |
|       var objectType = e.target.getAttribute('data-mce-object'); | |
|       if (objectType === 'audio' || objectType === 'script') { | |
|         e.preventDefault(); | |
|       } | |
|     }); | |
|     editor.on('objectResized', function (e) { | |
|       var target = e.target; | |
|       var html; | |
|       if (target.getAttribute('data-mce-object')) { | |
|         html = target.getAttribute('data-mce-html'); | |
|         if (html) { | |
|           html = unescape(html); | |
|           target.setAttribute('data-mce-html', escape($_cvzdjgfwjd09ewkv.updateHtml(html, { | |
|             width: e.width, | |
|             height: e.height | |
|           }))); | |
|         } | |
|       } | |
|     }); | |
|   }; | |
|   var $_915dq9g7jd09ewlp = { setup: setup$2 }; | |
| 
 | |
|   var register$1 = function (editor) { | |
|     editor.addButton('media', { | |
|       tooltip: 'Insert/edit media', | |
|       cmd: 'mceMedia', | |
|       stateSelector: [ | |
|         'img[data-mce-object]', | |
|         'span[data-mce-object]', | |
|         'div[data-ephox-embed-iri]' | |
|       ] | |
|     }); | |
|     editor.addMenuItem('media', { | |
|       icon: 'media', | |
|       text: 'Media', | |
|       cmd: 'mceMedia', | |
|       context: 'insert', | |
|       prependToContext: true | |
|     }); | |
|   }; | |
|   var $_8bj9zkg8jd09ewlr = { register: register$1 }; | |
| 
 | |
|   PluginManager.add('media', function (editor) { | |
|     $_7snympg1jd09ewla.register(editor); | |
|     $_8bj9zkg8jd09ewlr.register(editor); | |
|     $_1z5hrgg6jd09ewlo.setup(editor); | |
|     $_7dtdp0g2jd09ewlb.setup(editor); | |
|     $_915dq9g7jd09ewlp.setup(editor); | |
|     return $_umcglfijd09ewk7.get(editor); | |
|   }); | |
|   function Plugin () { | |
|   } | |
| 
 | |
|   return Plugin; | |
| 
 | |
| }()); | |
| })()
 |