| 
									
										
										
										
											2019-03-12 09:27:46 +00:00
										 |  |  | (function () { | 
					
						
							|  |  |  | var media = (function () { | 
					
						
							| 
									
										
										
										
											2019-04-16 20:56:22 +01:00
										 |  |  |     'use strict'; | 
					
						
							| 
									
										
										
										
											2019-03-12 09:27:46 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-16 20:56:22 +01:00
										 |  |  |     var global = tinymce.util.Tools.resolve('tinymce.PluginManager'); | 
					
						
							| 
									
										
										
										
											2019-03-12 09:27:46 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-16 20:56:22 +01:00
										 |  |  |     var global$1 = tinymce.util.Tools.resolve('tinymce.Env'); | 
					
						
							| 
									
										
										
										
											2019-03-12 09:27:46 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-16 20:56:22 +01:00
										 |  |  |     var global$2 = tinymce.util.Tools.resolve('tinymce.util.Tools'); | 
					
						
							| 
									
										
										
										
											2019-03-12 09:27:46 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-16 20:56:22 +01:00
										 |  |  |     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 Settings = { | 
					
						
							|  |  |  |       getScripts: getScripts, | 
					
						
							|  |  |  |       getAudioTemplateCallback: getAudioTemplateCallback, | 
					
						
							|  |  |  |       getVideoTemplateCallback: getVideoTemplateCallback, | 
					
						
							|  |  |  |       hasLiveEmbeds: hasLiveEmbeds, | 
					
						
							|  |  |  |       shouldFilterHtml: shouldFilterHtml, | 
					
						
							|  |  |  |       getUrlResolver: getUrlResolver, | 
					
						
							|  |  |  |       hasAltSource: hasAltSource, | 
					
						
							|  |  |  |       hasPoster: hasPoster, | 
					
						
							|  |  |  |       hasDimensions: hasDimensions | 
					
						
							|  |  |  |     }; | 
					
						
							| 
									
										
										
										
											2019-03-12 09:27:46 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-16 20:56:22 +01:00
										 |  |  |     var global$3 = tinymce.util.Tools.resolve('tinymce.html.SaxParser'); | 
					
						
							| 
									
										
										
										
											2019-03-12 09:27:46 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-16 20:56:22 +01:00
										 |  |  |     var global$4 = tinymce.util.Tools.resolve('tinymce.dom.DOMUtils'); | 
					
						
							| 
									
										
										
										
											2019-03-12 09:27:46 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-16 20:56:22 +01:00
										 |  |  |     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]; | 
					
						
							|  |  |  |           } | 
					
						
							| 
									
										
										
										
											2019-03-12 09:27:46 +00:00
										 |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     }; | 
					
						
							| 
									
										
										
										
											2019-04-16 20:56:22 +01:00
										 |  |  |     var VideoScript = { getVideoScriptMatch: getVideoScriptMatch }; | 
					
						
							| 
									
										
										
										
											2019-03-12 09:27:46 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-16 20:56:22 +01:00
										 |  |  |     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); | 
					
						
							| 
									
										
										
										
											2019-03-12 09:27:46 +00:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2019-04-16 20:56:22 +01:00
										 |  |  |       }; | 
					
						
							|  |  |  |     }; | 
					
						
							|  |  |  |     var Size = { | 
					
						
							|  |  |  |       getMaxWidth: getSize('maxWidth'), | 
					
						
							|  |  |  |       getMaxHeight: getSize('maxHeight'), | 
					
						
							|  |  |  |       setMaxWidth: setSize('maxWidth'), | 
					
						
							|  |  |  |       setMaxHeight: setSize('maxHeight') | 
					
						
							|  |  |  |     }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     var DOM = global$4.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 = {}; | 
					
						
							|  |  |  |       global$3({ | 
					
						
							|  |  |  |         validate: false, | 
					
						
							|  |  |  |         allow_conditional_comments: true, | 
					
						
							|  |  |  |         special: 'script,noscript', | 
					
						
							|  |  |  |         start: function (name, attrs) { | 
					
						
							|  |  |  |           if (!data.source1 && name === 'param') { | 
					
						
							|  |  |  |             data.source1 = attrs.map.movie; | 
					
						
							| 
									
										
										
										
											2019-03-12 09:27:46 +00:00
										 |  |  |           } | 
					
						
							| 
									
										
										
										
											2019-04-16 20:56:22 +01:00
										 |  |  |           if (name === 'iframe' || name === 'object' || name === 'embed' || name === 'video' || name === 'audio') { | 
					
						
							|  |  |  |             if (!data.type) { | 
					
						
							|  |  |  |               data.type = name; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |             data = global$2.extend(attrs.map, data); | 
					
						
							| 
									
										
										
										
											2019-03-12 09:27:46 +00:00
										 |  |  |           } | 
					
						
							| 
									
										
										
										
											2019-04-16 20:56:22 +01:00
										 |  |  |           if (name === 'script') { | 
					
						
							|  |  |  |             var videoScript = VideoScript.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; | 
					
						
							| 
									
										
										
										
											2019-03-12 09:27:46 +00:00
										 |  |  |           } | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2019-04-16 20:56:22 +01:00
										 |  |  |       }).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: Size.getMaxWidth(div), | 
					
						
							|  |  |  |         height: Size.getMaxHeight(div) | 
					
						
							|  |  |  |       }; | 
					
						
							|  |  |  |     }; | 
					
						
							|  |  |  |     var htmlToData = function (prefixes, html) { | 
					
						
							|  |  |  |       return isEphoxEmbed(html) ? ephoxEmbedHtmlToData(html) : htmlToDataSax(prefixes, html); | 
					
						
							|  |  |  |     }; | 
					
						
							|  |  |  |     var HtmlToData = { htmlToData: htmlToData }; | 
					
						
							| 
									
										
										
										
											2019-03-12 09:27:46 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-16 20:56:22 +01:00
										 |  |  |     var global$5 = tinymce.util.Tools.resolve('tinymce.util.Promise'); | 
					
						
							| 
									
										
										
										
											2019-03-12 09:27:46 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-16 20:56:22 +01:00
										 |  |  |     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 Mime = { guess: guess }; | 
					
						
							| 
									
										
										
										
											2019-03-12 09:27:46 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-16 20:56:22 +01:00
										 |  |  |     var global$6 = tinymce.util.Tools.resolve('tinymce.html.Writer'); | 
					
						
							| 
									
										
										
										
											2019-03-12 09:27:46 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-16 20:56:22 +01:00
										 |  |  |     var global$7 = tinymce.util.Tools.resolve('tinymce.html.Schema'); | 
					
						
							| 
									
										
										
										
											2019-03-12 09:27:46 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-16 20:56:22 +01:00
										 |  |  |     var DOM$1 = global$4.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); | 
					
						
							|  |  |  |               } | 
					
						
							| 
									
										
										
										
											2019-03-12 09:27:46 +00:00
										 |  |  |             } | 
					
						
							|  |  |  |           } | 
					
						
							| 
									
										
										
										
											2019-04-16 20:56:22 +01:00
										 |  |  |         } else if (value) { | 
					
						
							|  |  |  |           attrs.push({ | 
					
						
							|  |  |  |             name: name, | 
					
						
							|  |  |  |             value: value | 
					
						
							|  |  |  |           }); | 
					
						
							|  |  |  |           attrs.map[name] = value; | 
					
						
							| 
									
										
										
										
											2019-03-12 09:27:46 +00:00
										 |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							| 
									
										
										
										
											2019-04-16 20:56:22 +01:00
										 |  |  |     }; | 
					
						
							|  |  |  |     var normalizeHtml = function (html) { | 
					
						
							|  |  |  |       var writer = global$6(); | 
					
						
							|  |  |  |       var parser = global$3(writer); | 
					
						
							|  |  |  |       parser.parse(html); | 
					
						
							|  |  |  |       return writer.getContent(); | 
					
						
							|  |  |  |     }; | 
					
						
							|  |  |  |     var updateHtmlSax = function (html, data, updateAll) { | 
					
						
							|  |  |  |       var writer = global$6(); | 
					
						
							|  |  |  |       var sourceCount = 0; | 
					
						
							|  |  |  |       var hasImage; | 
					
						
							|  |  |  |       global$3({ | 
					
						
							|  |  |  |         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) { | 
					
						
							| 
									
										
										
										
											2019-03-12 09:27:46 +00:00
										 |  |  |           switch (name) { | 
					
						
							|  |  |  |           case 'video': | 
					
						
							| 
									
										
										
										
											2019-04-16 20:56:22 +01:00
										 |  |  |           case 'object': | 
					
						
							|  |  |  |           case 'embed': | 
					
						
							|  |  |  |           case 'img': | 
					
						
							| 
									
										
										
										
											2019-03-12 09:27:46 +00:00
										 |  |  |           case 'iframe': | 
					
						
							| 
									
										
										
										
											2019-04-16 20:56:22 +01:00
										 |  |  |             if (data.height !== undefined && data.width !== undefined) { | 
					
						
							| 
									
										
										
										
											2019-03-12 09:27:46 +00:00
										 |  |  |               setAttributes(attrs, { | 
					
						
							| 
									
										
										
										
											2019-04-16 20:56:22 +01:00
										 |  |  |                 width: data.width, | 
					
						
							|  |  |  |                 height: data.height | 
					
						
							| 
									
										
										
										
											2019-03-12 09:27:46 +00:00
										 |  |  |               }); | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |             break; | 
					
						
							|  |  |  |           } | 
					
						
							| 
									
										
										
										
											2019-04-16 20:56:22 +01:00
										 |  |  |           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) { | 
					
						
							| 
									
										
										
										
											2019-03-12 09:27:46 +00:00
										 |  |  |                 setAttributes(attrs, { | 
					
						
							| 
									
										
										
										
											2019-04-16 20:56:22 +01:00
										 |  |  |                   src: data['source' + sourceCount], | 
					
						
							|  |  |  |                   type: data['source' + sourceCount + 'mime'] | 
					
						
							| 
									
										
										
										
											2019-03-12 09:27:46 +00:00
										 |  |  |                 }); | 
					
						
							| 
									
										
										
										
											2019-04-16 20:56:22 +01:00
										 |  |  |                 if (!data['source' + sourceCount]) { | 
					
						
							|  |  |  |                   return; | 
					
						
							|  |  |  |                 } | 
					
						
							| 
									
										
										
										
											2019-03-12 09:27:46 +00:00
										 |  |  |               } | 
					
						
							| 
									
										
										
										
											2019-04-16 20:56:22 +01:00
										 |  |  |               break; | 
					
						
							|  |  |  |             case 'img': | 
					
						
							|  |  |  |               if (!data.poster) { | 
					
						
							|  |  |  |                 return; | 
					
						
							|  |  |  |               } | 
					
						
							|  |  |  |               hasImage = true; | 
					
						
							|  |  |  |               break; | 
					
						
							| 
									
										
										
										
											2019-03-12 09:27:46 +00:00
										 |  |  |             } | 
					
						
							|  |  |  |           } | 
					
						
							| 
									
										
										
										
											2019-04-16 20:56:22 +01:00
										 |  |  |           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); | 
					
						
							| 
									
										
										
										
											2019-03-12 09:27:46 +00:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2019-04-16 20:56:22 +01:00
										 |  |  |       }, global$7({})).parse(html); | 
					
						
							|  |  |  |       return writer.getContent(); | 
					
						
							| 
									
										
										
										
											2019-03-12 09:27:46 +00:00
										 |  |  |     }; | 
					
						
							| 
									
										
										
										
											2019-04-16 20:56:22 +01:00
										 |  |  |     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; | 
					
						
							|  |  |  |       Size.setMaxWidth(div, data.width); | 
					
						
							|  |  |  |       Size.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 UpdateHtml = { updateHtml: updateHtml }; | 
					
						
							| 
									
										
										
										
											2019-03-12 09:27:46 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-16 20:56:22 +01:00
										 |  |  |     var urlPatterns = [ | 
					
						
							|  |  |  |       { | 
					
						
							|  |  |  |         regex: /youtu\.be\/([\w\-_\?&=.]+)/i, | 
					
						
							|  |  |  |         type: 'iframe', | 
					
						
							|  |  |  |         w: 560, | 
					
						
							|  |  |  |         h: 314, | 
					
						
							|  |  |  |         url: '//www.youtube.com/embed/$1', | 
					
						
							|  |  |  |         allowFullscreen: true | 
					
						
							|  |  |  |       }, | 
					
						
							|  |  |  |       { | 
					
						
							|  |  |  |         regex: /youtube\.com(.+)v=([^&]+)(&([a-z0-9&=\-_]+))?/i, | 
					
						
							|  |  |  |         type: 'iframe', | 
					
						
							|  |  |  |         w: 560, | 
					
						
							|  |  |  |         h: 314, | 
					
						
							|  |  |  |         url: '//www.youtube.com/embed/$2?$4', | 
					
						
							|  |  |  |         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 | 
					
						
							| 
									
										
										
										
											2019-03-12 09:27:46 +00:00
										 |  |  |       } | 
					
						
							| 
									
										
										
										
											2019-04-16 20:56:22 +01:00
										 |  |  |     ]; | 
					
						
							|  |  |  |     var getUrl = function (pattern, url) { | 
					
						
							|  |  |  |       var match = pattern.regex.exec(url); | 
					
						
							|  |  |  |       var newUrl = pattern.url; | 
					
						
							|  |  |  |       var _loop_1 = function (i) { | 
					
						
							|  |  |  |         newUrl = newUrl.replace('$' + i, function () { | 
					
						
							|  |  |  |           return match[i] ? match[i] : ''; | 
					
						
							|  |  |  |         }); | 
					
						
							|  |  |  |       }; | 
					
						
							|  |  |  |       for (var i = 0; i < match.length; i++) { | 
					
						
							|  |  |  |         _loop_1(i); | 
					
						
							| 
									
										
										
										
											2019-03-12 09:27:46 +00:00
										 |  |  |       } | 
					
						
							| 
									
										
										
										
											2019-04-16 20:56:22 +01:00
										 |  |  |       return newUrl.replace(/\?$/, ''); | 
					
						
							|  |  |  |     }; | 
					
						
							|  |  |  |     var matchPattern = function (url) { | 
					
						
							|  |  |  |       var pattern = urlPatterns.filter(function (pattern) { | 
					
						
							|  |  |  |         return pattern.regex.test(url); | 
					
						
							| 
									
										
										
										
											2019-03-12 09:27:46 +00:00
										 |  |  |       }); | 
					
						
							| 
									
										
										
										
											2019-04-16 20:56:22 +01:00
										 |  |  |       if (pattern.length > 0) { | 
					
						
							|  |  |  |         return global$2.extend({}, pattern[0], { url: getUrl(pattern[0], url) }); | 
					
						
							| 
									
										
										
										
											2019-03-12 09:27:46 +00:00
										 |  |  |       } else { | 
					
						
							| 
									
										
										
										
											2019-04-16 20:56:22 +01:00
										 |  |  |         return null; | 
					
						
							| 
									
										
										
										
											2019-03-12 09:27:46 +00:00
										 |  |  |       } | 
					
						
							| 
									
										
										
										
											2019-04-16 20:56:22 +01:00
										 |  |  |     }; | 
					
						
							| 
									
										
										
										
											2019-03-12 09:27:46 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-16 20:56:22 +01:00
										 |  |  |     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); | 
					
						
							| 
									
										
										
										
											2019-03-12 09:27:46 +00:00
										 |  |  |       } else { | 
					
						
							| 
									
										
										
										
											2019-04-16 20:56:22 +01:00
										 |  |  |         return '<audio controls="controls" src="' + data.source1 + '">' + (data.source2 ? '\n<source src="' + data.source2 + '"' + (data.source2mime ? ' type="' + data.source2mime + '"' : '') + ' />\n' : '') + '</audio>'; | 
					
						
							| 
									
										
										
										
											2019-03-12 09:27:46 +00:00
										 |  |  |       } | 
					
						
							| 
									
										
										
										
											2019-04-16 20:56:22 +01:00
										 |  |  |     }; | 
					
						
							|  |  |  |     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 = global$2.extend({}, dataIn); | 
					
						
							|  |  |  |       if (!data.source1) { | 
					
						
							|  |  |  |         global$2.extend(data, HtmlToData.htmlToData(Settings.getScripts(editor), data.embed)); | 
					
						
							|  |  |  |         if (!data.source1) { | 
					
						
							|  |  |  |           return ''; | 
					
						
							| 
									
										
										
										
											2019-03-12 09:27:46 +00:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2019-04-16 20:56:22 +01:00
										 |  |  |       } | 
					
						
							|  |  |  |       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 = Mime.guess(data.source1); | 
					
						
							|  |  |  |       data.source2mime = Mime.guess(data.source2); | 
					
						
							|  |  |  |       data.poster = editor.convertURL(data.poster, 'poster'); | 
					
						
							|  |  |  |       var pattern = matchPattern(data.source1); | 
					
						
							|  |  |  |       if (pattern) { | 
					
						
							|  |  |  |         data.source1 = pattern.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 UpdateHtml.updateHtml(data.embed, data, true); | 
					
						
							| 
									
										
										
										
											2019-03-12 09:27:46 +00:00
										 |  |  |       } else { | 
					
						
							| 
									
										
										
										
											2019-04-16 20:56:22 +01:00
										 |  |  |         var videoScript = VideoScript.getVideoScriptMatch(Settings.getScripts(editor), data.source1); | 
					
						
							|  |  |  |         if (videoScript) { | 
					
						
							|  |  |  |           data.type = 'script'; | 
					
						
							|  |  |  |           data.width = videoScript.width; | 
					
						
							|  |  |  |           data.height = videoScript.height; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         var audioTemplateCallback = Settings.getAudioTemplateCallback(editor); | 
					
						
							|  |  |  |         var videoTemplateCallback = Settings.getVideoTemplateCallback(editor); | 
					
						
							|  |  |  |         data.width = data.width || 300; | 
					
						
							|  |  |  |         data.height = data.height || 150; | 
					
						
							|  |  |  |         global$2.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); | 
					
						
							| 
									
										
										
										
											2019-03-12 09:27:46 +00:00
										 |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     }; | 
					
						
							| 
									
										
										
										
											2019-04-16 20:56:22 +01:00
										 |  |  |     var DataToHtml = { dataToHtml: dataToHtml }; | 
					
						
							| 
									
										
										
										
											2019-03-12 09:27:46 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-16 20:56:22 +01:00
										 |  |  |     var cache = {}; | 
					
						
							|  |  |  |     var embedPromise = function (data, dataToHtml, handler) { | 
					
						
							|  |  |  |       return new global$5(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); | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2019-03-12 09:27:46 +00:00
										 |  |  |       }); | 
					
						
							|  |  |  |     }; | 
					
						
							| 
									
										
										
										
											2019-04-16 20:56:22 +01:00
										 |  |  |     var defaultPromise = function (data, dataToHtml) { | 
					
						
							|  |  |  |       return new global$5(function (res) { | 
					
						
							|  |  |  |         res({ | 
					
						
							|  |  |  |           html: dataToHtml(data), | 
					
						
							|  |  |  |           url: data.source1 | 
					
						
							|  |  |  |         }); | 
					
						
							|  |  |  |       }); | 
					
						
							|  |  |  |     }; | 
					
						
							|  |  |  |     var loadedData = function (editor) { | 
					
						
							|  |  |  |       return function (data) { | 
					
						
							|  |  |  |         return DataToHtml.dataToHtml(editor, data); | 
					
						
							| 
									
										
										
										
											2019-03-12 09:27:46 +00:00
										 |  |  |       }; | 
					
						
							| 
									
										
										
										
											2019-04-16 20:56:22 +01:00
										 |  |  |     }; | 
					
						
							|  |  |  |     var getEmbedHtml = function (editor, data) { | 
					
						
							|  |  |  |       var embedHandler = Settings.getUrlResolver(editor); | 
					
						
							|  |  |  |       return embedHandler ? embedPromise(data, loadedData(editor), embedHandler) : defaultPromise(data, loadedData(editor)); | 
					
						
							|  |  |  |     }; | 
					
						
							|  |  |  |     var isCached = function (url) { | 
					
						
							|  |  |  |       return cache.hasOwnProperty(url); | 
					
						
							|  |  |  |     }; | 
					
						
							|  |  |  |     var Service = { | 
					
						
							|  |  |  |       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()); | 
					
						
							| 
									
										
										
										
											2019-03-12 09:27:46 +00:00
										 |  |  |       } | 
					
						
							|  |  |  |     }; | 
					
						
							| 
									
										
										
										
											2019-04-16 20:56:22 +01:00
										 |  |  |     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); | 
					
						
							|  |  |  |           } | 
					
						
							| 
									
										
										
										
											2019-03-12 09:27:46 +00:00
										 |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							| 
									
										
										
										
											2019-04-16 20:56:22 +01:00
										 |  |  |       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 { | 
					
						
							| 
									
										
										
										
											2019-03-12 09:27:46 +00:00
										 |  |  |         type: 'container', | 
					
						
							| 
									
										
										
										
											2019-04-16 20:56:22 +01:00
										 |  |  |         label: 'Dimensions', | 
					
						
							| 
									
										
										
										
											2019-03-12 09:27:46 +00:00
										 |  |  |         layout: 'flex', | 
					
						
							| 
									
										
										
										
											2019-04-16 20:56:22 +01:00
										 |  |  |         align: 'center', | 
					
						
							|  |  |  |         spacing: 5, | 
					
						
							| 
									
										
										
										
											2019-03-12 09:27:46 +00:00
										 |  |  |         items: [ | 
					
						
							| 
									
										
										
										
											2019-04-16 20:56:22 +01:00
										 |  |  |           { | 
					
						
							|  |  |  |             name: 'width', | 
					
						
							|  |  |  |             type: 'textbox', | 
					
						
							|  |  |  |             maxLength: 5, | 
					
						
							|  |  |  |             size: 5, | 
					
						
							|  |  |  |             onchange: recalcSize, | 
					
						
							|  |  |  |             ariaLabel: 'Width' | 
					
						
							|  |  |  |           }, | 
					
						
							| 
									
										
										
										
											2019-03-12 09:27:46 +00:00
										 |  |  |           { | 
					
						
							|  |  |  |             type: 'label', | 
					
						
							| 
									
										
										
										
											2019-04-16 20:56:22 +01:00
										 |  |  |             text: 'x' | 
					
						
							|  |  |  |           }, | 
					
						
							|  |  |  |           { | 
					
						
							|  |  |  |             name: 'height', | 
					
						
							|  |  |  |             type: 'textbox', | 
					
						
							|  |  |  |             maxLength: 5, | 
					
						
							|  |  |  |             size: 5, | 
					
						
							|  |  |  |             onchange: recalcSize, | 
					
						
							|  |  |  |             ariaLabel: 'Height' | 
					
						
							| 
									
										
										
										
											2019-03-12 09:27:46 +00:00
										 |  |  |           }, | 
					
						
							| 
									
										
										
										
											2019-04-16 20:56:22 +01:00
										 |  |  |           { | 
					
						
							|  |  |  |             name: 'constrain', | 
					
						
							|  |  |  |             type: 'checkbox', | 
					
						
							|  |  |  |             checked: true, | 
					
						
							|  |  |  |             text: 'Constrain proportions' | 
					
						
							|  |  |  |           } | 
					
						
							| 
									
										
										
										
											2019-03-12 09:27:46 +00:00
										 |  |  |         ] | 
					
						
							| 
									
										
										
										
											2019-04-16 20:56:22 +01:00
										 |  |  |       }; | 
					
						
							|  |  |  |     }; | 
					
						
							|  |  |  |     var SizeManager = { | 
					
						
							|  |  |  |       createUi: createUi, | 
					
						
							|  |  |  |       syncSize: syncSize, | 
					
						
							|  |  |  |       updateSize: updateSize | 
					
						
							|  |  |  |     }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     var embedChange = global$1.ie && global$1.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': Size.getMaxWidth(element), | 
					
						
							|  |  |  |           'height': Size.getMaxHeight(element) | 
					
						
							|  |  |  |         }; | 
					
						
							| 
									
										
										
										
											2019-03-12 09:27:46 +00:00
										 |  |  |       } | 
					
						
							| 
									
										
										
										
											2019-04-16 20:56:22 +01:00
										 |  |  |       return element.getAttribute('data-mce-object') ? HtmlToData.htmlToData(Settings.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 = global$2.extend(HtmlToData.htmlToData(Settings.getScripts(editor), html), { source1: response.url }); | 
					
						
							|  |  |  |         win.fromJSON(data); | 
					
						
							|  |  |  |         if (embed) { | 
					
						
							|  |  |  |           embed.value(html); | 
					
						
							|  |  |  |           SizeManager.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 = UpdateHtml.updateHtml(data.embed, data); | 
					
						
							|  |  |  |       if (data.embed && Service.isCached(data.source1)) { | 
					
						
							|  |  |  |         handleInsert(editor, data.embed); | 
					
						
							|  |  |  |       } else { | 
					
						
							|  |  |  |         Service.getEmbedHtml(editor, data).then(function (response) { | 
					
						
							|  |  |  |           handleInsert(editor, response.html); | 
					
						
							|  |  |  |         }).catch(handleError(editor)); | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     }; | 
					
						
							|  |  |  |     var populateMeta = function (win, meta) { | 
					
						
							|  |  |  |       global$2.each(meta, function (value, key) { | 
					
						
							|  |  |  |         win.find('#' + key).value(value); | 
					
						
							| 
									
										
										
										
											2019-03-12 09:27:46 +00:00
										 |  |  |       }); | 
					
						
							| 
									
										
										
										
											2019-04-16 20:56:22 +01:00
										 |  |  |     }; | 
					
						
							|  |  |  |     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 () { | 
					
						
							|  |  |  |               Service.getEmbedHtml(editor, win.toJSON()).then(addEmbedHtml(win, editor)).catch(handleError(editor)); | 
					
						
							|  |  |  |             }, 1); | 
					
						
							|  |  |  |           }, | 
					
						
							|  |  |  |           onchange: function (e) { | 
					
						
							|  |  |  |             Service.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(UpdateHtml.updateHtml(data.embed, data)); | 
					
						
							|  |  |  |       }; | 
					
						
							|  |  |  |       if (Settings.hasAltSource(editor)) { | 
					
						
							|  |  |  |         advancedFormItems.push({ | 
					
						
							|  |  |  |           name: 'source2', | 
					
						
							|  |  |  |           type: 'filepicker', | 
					
						
							|  |  |  |           filetype: 'media', | 
					
						
							|  |  |  |           size: 40, | 
					
						
							|  |  |  |           label: 'Alternative source' | 
					
						
							|  |  |  |         }); | 
					
						
							| 
									
										
										
										
											2019-03-12 09:27:46 +00:00
										 |  |  |       } | 
					
						
							| 
									
										
										
										
											2019-04-16 20:56:22 +01:00
										 |  |  |       if (Settings.hasPoster(editor)) { | 
					
						
							|  |  |  |         advancedFormItems.push({ | 
					
						
							|  |  |  |           name: 'poster', | 
					
						
							|  |  |  |           type: 'filepicker', | 
					
						
							|  |  |  |           filetype: 'image', | 
					
						
							|  |  |  |           size: 40, | 
					
						
							|  |  |  |           label: 'Poster' | 
					
						
							|  |  |  |         }); | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |       if (Settings.hasDimensions(editor)) { | 
					
						
							|  |  |  |         var control = SizeManager.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 = global$2.extend({}, HtmlToData.htmlToData(Settings.getScripts(editor), this.value())); | 
					
						
							|  |  |  |         this.parent().parent().fromJSON(data); | 
					
						
							|  |  |  |       }; | 
					
						
							|  |  |  |       embedTextBox[embedChange] = updateValueOnChange; | 
					
						
							|  |  |  |       var 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 | 
					
						
							|  |  |  |           ] | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       ]; | 
					
						
							|  |  |  |       if (advancedFormItems.length > 0) { | 
					
						
							|  |  |  |         body.push({ | 
					
						
							|  |  |  |           title: 'Advanced', | 
					
						
							|  |  |  |           type: 'form', | 
					
						
							|  |  |  |           items: advancedFormItems | 
					
						
							|  |  |  |         }); | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |       win = editor.windowManager.open({ | 
					
						
							|  |  |  |         title: 'Insert/edit media', | 
					
						
							|  |  |  |         data: data, | 
					
						
							|  |  |  |         bodyType: 'tabpanel', | 
					
						
							|  |  |  |         body: body, | 
					
						
							|  |  |  |         onSubmit: function () { | 
					
						
							|  |  |  |           SizeManager.updateSize(win); | 
					
						
							|  |  |  |           submitForm(win, editor); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       }); | 
					
						
							|  |  |  |       SizeManager.syncSize(win); | 
					
						
							|  |  |  |     }; | 
					
						
							|  |  |  |     var Dialog = { showDialog: showDialog }; | 
					
						
							| 
									
										
										
										
											2019-03-12 09:27:46 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-16 20:56:22 +01:00
										 |  |  |     var get = function (editor) { | 
					
						
							|  |  |  |       var showDialog = function () { | 
					
						
							|  |  |  |         Dialog.showDialog(editor); | 
					
						
							|  |  |  |       }; | 
					
						
							|  |  |  |       return { showDialog: showDialog }; | 
					
						
							| 
									
										
										
										
											2019-03-12 09:27:46 +00:00
										 |  |  |     }; | 
					
						
							| 
									
										
										
										
											2019-04-16 20:56:22 +01:00
										 |  |  |     var Api = { get: get }; | 
					
						
							| 
									
										
										
										
											2019-03-12 09:27:46 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-16 20:56:22 +01:00
										 |  |  |     var register = function (editor) { | 
					
						
							|  |  |  |       var showDialog = function () { | 
					
						
							|  |  |  |         Dialog.showDialog(editor); | 
					
						
							|  |  |  |       }; | 
					
						
							|  |  |  |       editor.addCommand('mceMedia', showDialog); | 
					
						
							| 
									
										
										
										
											2019-03-12 09:27:46 +00:00
										 |  |  |     }; | 
					
						
							| 
									
										
										
										
											2019-04-16 20:56:22 +01:00
										 |  |  |     var Commands = { register: register }; | 
					
						
							| 
									
										
										
										
											2019-03-12 09:27:46 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-16 20:56:22 +01:00
										 |  |  |     var global$8 = tinymce.util.Tools.resolve('tinymce.html.Node'); | 
					
						
							| 
									
										
										
										
											2019-03-12 09:27:46 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-16 20:56:22 +01:00
										 |  |  |     var sanitize = function (editor, html) { | 
					
						
							|  |  |  |       if (Settings.shouldFilterHtml(editor) === false) { | 
					
						
							|  |  |  |         return html; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |       var writer = global$6(); | 
					
						
							|  |  |  |       var blocked; | 
					
						
							|  |  |  |       global$3({ | 
					
						
							|  |  |  |         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') { | 
					
						
							| 
									
										
										
										
											2019-03-12 09:27:46 +00:00
										 |  |  |             return; | 
					
						
							|  |  |  |           } | 
					
						
							| 
									
										
										
										
											2019-04-16 20:56:22 +01:00
										 |  |  |           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); | 
					
						
							|  |  |  |             } | 
					
						
							| 
									
										
										
										
											2019-03-12 09:27:46 +00:00
										 |  |  |           } | 
					
						
							| 
									
										
										
										
											2019-04-16 20:56:22 +01:00
										 |  |  |           writer.start(name, attrs, empty); | 
					
						
							|  |  |  |           blocked = false; | 
					
						
							|  |  |  |         }, | 
					
						
							|  |  |  |         end: function (name) { | 
					
						
							|  |  |  |           if (blocked) { | 
					
						
							|  |  |  |             return; | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |           writer.end(name); | 
					
						
							| 
									
										
										
										
											2019-03-12 09:27:46 +00:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2019-04-16 20:56:22 +01:00
										 |  |  |       }, global$7({})).parse(html); | 
					
						
							|  |  |  |       return writer.getContent(); | 
					
						
							|  |  |  |     }; | 
					
						
							|  |  |  |     var Sanitize = { sanitize: sanitize }; | 
					
						
							| 
									
										
										
										
											2019-03-12 09:27:46 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-16 20:56:22 +01:00
										 |  |  |     var createPlaceholderNode = function (editor, node) { | 
					
						
							|  |  |  |       var placeHolder; | 
					
						
							|  |  |  |       var name = node.name; | 
					
						
							|  |  |  |       placeHolder = new global$8('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': global$1.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 global$8('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 global$8(name, 1); | 
					
						
							|  |  |  |       previewNode.attr({ | 
					
						
							|  |  |  |         src: node.attr('src'), | 
					
						
							|  |  |  |         allowfullscreen: node.attr('allowfullscreen'), | 
					
						
							|  |  |  |         style: node.attr('style'), | 
					
						
							|  |  |  |         class: node.attr('class'), | 
					
						
							|  |  |  |         width: node.attr('width'), | 
					
						
							|  |  |  |         height: node.attr('height'), | 
					
						
							|  |  |  |         frameborder: '0' | 
					
						
							|  |  |  |       }); | 
					
						
							|  |  |  |       shimNode = new global$8('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); | 
					
						
							| 
									
										
										
										
											2019-03-12 09:27:46 +00:00
										 |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							| 
									
										
										
										
											2019-04-16 20:56:22 +01:00
										 |  |  |       innerHtml = sourceNode.firstChild && sourceNode.firstChild.value; | 
					
						
							|  |  |  |       if (innerHtml) { | 
					
						
							|  |  |  |         targetNode.attr('data-mce-html', escape(Sanitize.sanitize(editor, innerHtml))); | 
					
						
							|  |  |  |         targetNode.firstChild = null; | 
					
						
							| 
									
										
										
										
											2019-03-12 09:27:46 +00:00
										 |  |  |       } | 
					
						
							| 
									
										
										
										
											2019-04-16 20:56:22 +01:00
										 |  |  |     }; | 
					
						
							|  |  |  |     var isWithinEphoxEmbed = function (node) { | 
					
						
							|  |  |  |       while (node = node.parent) { | 
					
						
							|  |  |  |         if (node.attr('data-ephox-embed-iri')) { | 
					
						
							|  |  |  |           return true; | 
					
						
							| 
									
										
										
										
											2019-03-12 09:27:46 +00:00
										 |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							| 
									
										
										
										
											2019-04-16 20:56:22 +01:00
										 |  |  |       return false; | 
					
						
							| 
									
										
										
										
											2019-03-12 09:27:46 +00:00
										 |  |  |     }; | 
					
						
							| 
									
										
										
										
											2019-04-16 20:56:22 +01:00
										 |  |  |     var placeHolderConverter = function (editor) { | 
					
						
							|  |  |  |       return function (nodes) { | 
					
						
							| 
									
										
										
										
											2019-03-12 09:27:46 +00:00
										 |  |  |         var i = nodes.length; | 
					
						
							|  |  |  |         var node; | 
					
						
							| 
									
										
										
										
											2019-04-16 20:56:22 +01:00
										 |  |  |         var videoScript; | 
					
						
							| 
									
										
										
										
											2019-03-12 09:27:46 +00:00
										 |  |  |         while (i--) { | 
					
						
							|  |  |  |           node = nodes[i]; | 
					
						
							|  |  |  |           if (!node.parent) { | 
					
						
							|  |  |  |             continue; | 
					
						
							|  |  |  |           } | 
					
						
							| 
									
										
										
										
											2019-04-16 20:56:22 +01:00
										 |  |  |           if (node.parent.attr('data-mce-object')) { | 
					
						
							|  |  |  |             continue; | 
					
						
							| 
									
										
										
										
											2019-03-12 09:27:46 +00:00
										 |  |  |           } | 
					
						
							| 
									
										
										
										
											2019-04-16 20:56:22 +01:00
										 |  |  |           if (node.name === 'script') { | 
					
						
							|  |  |  |             videoScript = VideoScript.getVideoScriptMatch(Settings.getScripts(editor), node.attr('src')); | 
					
						
							|  |  |  |             if (!videoScript) { | 
					
						
							|  |  |  |               continue; | 
					
						
							| 
									
										
										
										
											2019-03-12 09:27:46 +00:00
										 |  |  |             } | 
					
						
							|  |  |  |           } | 
					
						
							| 
									
										
										
										
											2019-04-16 20:56:22 +01:00
										 |  |  |           if (videoScript) { | 
					
						
							|  |  |  |             if (videoScript.width) { | 
					
						
							|  |  |  |               node.attr('width', videoScript.width.toString()); | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |             if (videoScript.height) { | 
					
						
							|  |  |  |               node.attr('height', videoScript.height.toString()); | 
					
						
							|  |  |  |             } | 
					
						
							| 
									
										
										
										
											2019-03-12 09:27:46 +00:00
										 |  |  |           } | 
					
						
							| 
									
										
										
										
											2019-04-16 20:56:22 +01:00
										 |  |  |           if (node.name === 'iframe' && Settings.hasLiveEmbeds(editor) && global$1.ceFalse) { | 
					
						
							|  |  |  |             if (!isWithinEphoxEmbed(node)) { | 
					
						
							|  |  |  |               node.replace(createPreviewIframeNode(editor, node)); | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |           } else { | 
					
						
							|  |  |  |             if (!isWithinEphoxEmbed(node)) { | 
					
						
							|  |  |  |               node.replace(createPlaceholderNode(editor, node)); | 
					
						
							|  |  |  |             } | 
					
						
							| 
									
										
										
										
											2019-03-12 09:27:46 +00:00
										 |  |  |           } | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2019-04-16 20:56:22 +01:00
										 |  |  |       }; | 
					
						
							|  |  |  |     }; | 
					
						
							|  |  |  |     var Nodes = { | 
					
						
							|  |  |  |       createPreviewIframeNode: createPreviewIframeNode, | 
					
						
							|  |  |  |       createPlaceholderNode: createPlaceholderNode, | 
					
						
							|  |  |  |       placeHolderConverter: placeHolderConverter | 
					
						
							|  |  |  |     }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     var setup = function (editor) { | 
					
						
							|  |  |  |       editor.on('preInit', function () { | 
					
						
							|  |  |  |         var specialElements = editor.schema.getSpecialElements(); | 
					
						
							|  |  |  |         global$2.each('video audio iframe object'.split(' '), function (name) { | 
					
						
							|  |  |  |           specialElements[name] = new RegExp('</' + name + '[^>]*>', 'gi'); | 
					
						
							|  |  |  |         }); | 
					
						
							|  |  |  |         var boolAttrs = editor.schema.getBoolAttrs(); | 
					
						
							|  |  |  |         global$2.each('webkitallowfullscreen mozallowfullscreen allowfullscreen'.split(' '), function (name) { | 
					
						
							|  |  |  |           boolAttrs[name] = {}; | 
					
						
							|  |  |  |         }); | 
					
						
							|  |  |  |         editor.parser.addNodeFilter('iframe,video,audio,object,embed,script', Nodes.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 global$8(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 global$8('#text', 3); | 
					
						
							|  |  |  |               innerNode.raw = true; | 
					
						
							|  |  |  |               innerNode.value = Sanitize.sanitize(editor, unescape(innerHtml)); | 
					
						
							|  |  |  |               realElm.append(innerNode); | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |             node.replace(realElm); | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |         }); | 
					
						
							| 
									
										
										
										
											2019-03-12 09:27:46 +00:00
										 |  |  |       }); | 
					
						
							| 
									
										
										
										
											2019-04-16 20:56:22 +01:00
										 |  |  |       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>'); | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |         }); | 
					
						
							| 
									
										
										
										
											2019-03-12 09:27:46 +00:00
										 |  |  |       }); | 
					
						
							| 
									
										
										
										
											2019-04-16 20:56:22 +01:00
										 |  |  |     }; | 
					
						
							|  |  |  |     var FilterContent = { setup: setup }; | 
					
						
							| 
									
										
										
										
											2019-03-12 09:27:46 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-16 20:56:22 +01:00
										 |  |  |     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 ResolveName = { setup: setup$1 }; | 
					
						
							| 
									
										
										
										
											2019-03-12 09:27:46 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-16 20:56:22 +01:00
										 |  |  |     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'); | 
					
						
							|  |  |  |           } | 
					
						
							| 
									
										
										
										
											2019-03-12 09:27:46 +00:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2019-04-16 20:56:22 +01:00
										 |  |  |       }); | 
					
						
							|  |  |  |       editor.on('ObjectSelected', function (e) { | 
					
						
							|  |  |  |         var objectType = e.target.getAttribute('data-mce-object'); | 
					
						
							|  |  |  |         if (objectType === 'audio' || objectType === 'script') { | 
					
						
							|  |  |  |           e.preventDefault(); | 
					
						
							| 
									
										
										
										
											2019-03-12 09:27:46 +00:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2019-04-16 20:56:22 +01:00
										 |  |  |       }); | 
					
						
							|  |  |  |       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(UpdateHtml.updateHtml(html, { | 
					
						
							|  |  |  |               width: e.width, | 
					
						
							|  |  |  |               height: e.height | 
					
						
							|  |  |  |             }))); | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       }); | 
					
						
							|  |  |  |     }; | 
					
						
							|  |  |  |     var Selection = { setup: setup$2 }; | 
					
						
							| 
									
										
										
										
											2019-03-12 09:27:46 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-16 20:56:22 +01:00
										 |  |  |     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 Buttons = { register: register$1 }; | 
					
						
							| 
									
										
										
										
											2019-03-12 09:27:46 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-16 20:56:22 +01:00
										 |  |  |     global.add('media', function (editor) { | 
					
						
							|  |  |  |       Commands.register(editor); | 
					
						
							|  |  |  |       Buttons.register(editor); | 
					
						
							|  |  |  |       ResolveName.setup(editor); | 
					
						
							|  |  |  |       FilterContent.setup(editor); | 
					
						
							|  |  |  |       Selection.setup(editor); | 
					
						
							|  |  |  |       return Api.get(editor); | 
					
						
							|  |  |  |     }); | 
					
						
							|  |  |  |     function Plugin () { | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2019-03-12 09:27:46 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-16 20:56:22 +01:00
										 |  |  |     return Plugin; | 
					
						
							| 
									
										
										
										
											2019-03-12 09:27:46 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | }()); | 
					
						
							|  |  |  | })(); |