/** * Copyright (c) Tiny Technologies, Inc. All rights reserved. * Licensed under the LGPL or a commercial license. * For LGPL see License.txt in the project root for license information. * For commercial licenses see https://www.tiny.cloud/ * * Version: 5.10.2 (2021-11-17) */ ;(function () { 'use strict' var typeOf$1 = function (x) { if (x === null) { return 'null' } if (x === undefined) { return 'undefined' } var t = typeof x if ( t === 'object' && (Array.prototype.isPrototypeOf(x) || (x.constructor && x.constructor.name === 'Array')) ) { return 'array' } if ( t === 'object' && (String.prototype.isPrototypeOf(x) || (x.constructor && x.constructor.name === 'String')) ) { return 'string' } return t } var isEquatableType = function (x) { return ( [ 'undefined', 'boolean', 'number', 'string', 'function', 'xml', 'null', ].indexOf(x) !== -1 ) } var sort$1 = function (xs, compareFn) { var clone = Array.prototype.slice.call(xs) return clone.sort(compareFn) } var contramap = function (eqa, f) { return eq$2(function (x, y) { return eqa.eq(f(x), f(y)) }) } var eq$2 = function (f) { return { eq: f } } var tripleEq = eq$2(function (x, y) { return x === y }) var eqString = tripleEq var eqArray = function (eqa) { return eq$2(function (x, y) { if (x.length !== y.length) { return false } var len = x.length for (var i = 0; i < len; i++) { if (!eqa.eq(x[i], y[i])) { return false } } return true }) } var eqSortedArray = function (eqa, compareFn) { return contramap(eqArray(eqa), function (xs) { return sort$1(xs, compareFn) }) } var eqRecord = function (eqa) { return eq$2(function (x, y) { var kx = Object.keys(x) var ky = Object.keys(y) if (!eqSortedArray(eqString).eq(kx, ky)) { return false } var len = kx.length for (var i = 0; i < len; i++) { var q = kx[i] if (!eqa.eq(x[q], y[q])) { return false } } return true }) } var eqAny = eq$2(function (x, y) { if (x === y) { return true } var tx = typeOf$1(x) var ty = typeOf$1(y) if (tx !== ty) { return false } if (isEquatableType(tx)) { return x === y } else if (tx === 'array') { return eqArray(eqAny).eq(x, y) } else if (tx === 'object') { return eqRecord(eqAny).eq(x, y) } return false }) var typeOf = function (x) { var t = typeof x if (x === null) { return 'null' } else if ( t === 'object' && (Array.prototype.isPrototypeOf(x) || (x.constructor && x.constructor.name === 'Array')) ) { return 'array' } else if ( t === 'object' && (String.prototype.isPrototypeOf(x) || (x.constructor && x.constructor.name === 'String')) ) { return 'string' } else { return t } } var isType$1 = function (type) { return function (value) { return typeOf(value) === type } } var isSimpleType = function (type) { return function (value) { return typeof value === type } } var eq$1 = function (t) { return function (a) { return t === a } } var isString$1 = isType$1('string') var isObject = isType$1('object') var isArray$1 = isType$1('array') var isNull = eq$1(null) var isBoolean = isSimpleType('boolean') var isUndefined = eq$1(undefined) var isNullable = function (a) { return a === null || a === undefined } var isNonNullable = function (a) { return !isNullable(a) } var isFunction = isSimpleType('function') var isNumber = isSimpleType('number') var noop = function () {} var compose = function (fa, fb) { return function () { var args = [] for (var _i = 0; _i < arguments.length; _i++) { args[_i] = arguments[_i] } return fa(fb.apply(null, args)) } } var compose1 = function (fbc, fab) { return function (a) { return fbc(fab(a)) } } var constant = function (value) { return function () { return value } } var identity = function (x) { return x } var tripleEquals = function (a, b) { return a === b } function curry(fn) { var initialArgs = [] for (var _i = 1; _i < arguments.length; _i++) { initialArgs[_i - 1] = arguments[_i] } return function () { var restArgs = [] for (var _i = 0; _i < arguments.length; _i++) { restArgs[_i] = arguments[_i] } var all = initialArgs.concat(restArgs) return fn.apply(null, all) } } var not = function (f) { return function (t) { return !f(t) } } var die = function (msg) { return function () { throw new Error(msg) } } var apply = function (f) { return f() } var call = function (f) { f() } var never = constant(false) var always = constant(true) var none = function () { return NONE } var NONE = (function () { var call = function (thunk) { return thunk() } var id = identity var me = { fold: function (n, _s) { return n() }, isSome: never, isNone: always, getOr: id, getOrThunk: call, getOrDie: function (msg) { throw new Error(msg || 'error: getOrDie called on none.') }, getOrNull: constant(null), getOrUndefined: constant(undefined), or: id, orThunk: call, map: none, each: noop, bind: none, exists: never, forall: always, filter: function () { return none() }, toArray: function () { return [] }, toString: constant('none()'), } return me })() var some = function (a) { var constant_a = constant(a) var self = function () { return me } var bind = function (f) { return f(a) } var me = { fold: function (n, s) { return s(a) }, isSome: always, isNone: never, getOr: constant_a, getOrThunk: constant_a, getOrDie: constant_a, getOrNull: constant_a, getOrUndefined: constant_a, or: self, orThunk: self, map: function (f) { return some(f(a)) }, each: function (f) { f(a) }, bind: bind, exists: bind, forall: bind, filter: function (f) { return f(a) ? me : NONE }, toArray: function () { return [a] }, toString: function () { return 'some(' + a + ')' }, } return me } var from$1 = function (value) { return value === null || value === undefined ? NONE : some(value) } var Optional = { some: some, none: none, from: from$1, } var nativeSlice = Array.prototype.slice var nativeIndexOf = Array.prototype.indexOf var nativePush = Array.prototype.push var rawIndexOf = function (ts, t) { return nativeIndexOf.call(ts, t) } var indexOf$2 = function (xs, x) { var r = rawIndexOf(xs, x) return r === -1 ? Optional.none() : Optional.some(r) } var contains$3 = function (xs, x) { return rawIndexOf(xs, x) > -1 } var exists = function (xs, pred) { for (var i = 0, len = xs.length; i < len; i++) { var x = xs[i] if (pred(x, i)) { return true } } return false } var map$3 = function (xs, f) { var len = xs.length var r = new Array(len) for (var i = 0; i < len; i++) { var x = xs[i] r[i] = f(x, i) } return r } var each$k = function (xs, f) { for (var i = 0, len = xs.length; i < len; i++) { var x = xs[i] f(x, i) } } var eachr = function (xs, f) { for (var i = xs.length - 1; i >= 0; i--) { var x = xs[i] f(x, i) } } var partition = function (xs, pred) { var pass = [] var fail = [] for (var i = 0, len = xs.length; i < len; i++) { var x = xs[i] var arr = pred(x, i) ? pass : fail arr.push(x) } return { pass: pass, fail: fail, } } var filter$4 = function (xs, pred) { var r = [] for (var i = 0, len = xs.length; i < len; i++) { var x = xs[i] if (pred(x, i)) { r.push(x) } } return r } var foldr = function (xs, f, acc) { eachr(xs, function (x, i) { acc = f(acc, x, i) }) return acc } var foldl = function (xs, f, acc) { each$k(xs, function (x, i) { acc = f(acc, x, i) }) return acc } var findUntil$1 = function (xs, pred, until) { for (var i = 0, len = xs.length; i < len; i++) { var x = xs[i] if (pred(x, i)) { return Optional.some(x) } else if (until(x, i)) { break } } return Optional.none() } var find$3 = function (xs, pred) { return findUntil$1(xs, pred, never) } var findIndex$2 = function (xs, pred) { for (var i = 0, len = xs.length; i < len; i++) { var x = xs[i] if (pred(x, i)) { return Optional.some(i) } } return Optional.none() } var flatten = function (xs) { var r = [] for (var i = 0, len = xs.length; i < len; ++i) { if (!isArray$1(xs[i])) { throw new Error( 'Arr.flatten item ' + i + ' was not an array, input: ' + xs ) } nativePush.apply(r, xs[i]) } return r } var bind = function (xs, f) { return flatten(map$3(xs, f)) } var forall = function (xs, pred) { for (var i = 0, len = xs.length; i < len; ++i) { var x = xs[i] if (pred(x, i) !== true) { return false } } return true } var reverse = function (xs) { var r = nativeSlice.call(xs, 0) r.reverse() return r } var difference = function (a1, a2) { return filter$4(a1, function (x) { return !contains$3(a2, x) }) } var mapToObject = function (xs, f) { var r = {} for (var i = 0, len = xs.length; i < len; i++) { var x = xs[i] r[String(x)] = f(x, i) } return r } var sort = function (xs, comparator) { var copy = nativeSlice.call(xs, 0) copy.sort(comparator) return copy } var get$a = function (xs, i) { return i >= 0 && i < xs.length ? Optional.some(xs[i]) : Optional.none() } var head = function (xs) { return get$a(xs, 0) } var last$2 = function (xs) { return get$a(xs, xs.length - 1) } var from = isFunction(Array.from) ? Array.from : function (x) { return nativeSlice.call(x) } var findMap = function (arr, f) { for (var i = 0; i < arr.length; i++) { var r = f(arr[i], i) if (r.isSome()) { return r } } return Optional.none() } var keys = Object.keys var hasOwnProperty$1 = Object.hasOwnProperty var each$j = function (obj, f) { var props = keys(obj) for (var k = 0, len = props.length; k < len; k++) { var i = props[k] var x = obj[i] f(x, i) } } var map$2 = function (obj, f) { return tupleMap(obj, function (x, i) { return { k: i, v: f(x, i), } }) } var tupleMap = function (obj, f) { var r = {} each$j(obj, function (x, i) { var tuple = f(x, i) r[tuple.k] = tuple.v }) return r } var objAcc = function (r) { return function (x, i) { r[i] = x } } var internalFilter = function (obj, pred, onTrue, onFalse) { var r = {} each$j(obj, function (x, i) { ;(pred(x, i) ? onTrue : onFalse)(x, i) }) return r } var bifilter = function (obj, pred) { var t = {} var f = {} internalFilter(obj, pred, objAcc(t), objAcc(f)) return { t: t, f: f, } } var filter$3 = function (obj, pred) { var t = {} internalFilter(obj, pred, objAcc(t), noop) return t } var mapToArray = function (obj, f) { var r = [] each$j(obj, function (value, name) { r.push(f(value, name)) }) return r } var values = function (obj) { return mapToArray(obj, identity) } var get$9 = function (obj, key) { return has$2(obj, key) ? Optional.from(obj[key]) : Optional.none() } var has$2 = function (obj, key) { return hasOwnProperty$1.call(obj, key) } var hasNonNullableKey = function (obj, key) { return has$2(obj, key) && obj[key] !== undefined && obj[key] !== null } var equal$1 = function (a1, a2, eq) { if (eq === void 0) { eq = eqAny } return eqRecord(eq).eq(a1, a2) } var isArray = Array.isArray var toArray$1 = function (obj) { if (!isArray(obj)) { var array = [] for (var i = 0, l = obj.length; i < l; i++) { array[i] = obj[i] } return array } else { return obj } } var each$i = function (o, cb, s) { var n, l if (!o) { return false } s = s || o if (o.length !== undefined) { for (n = 0, l = o.length; n < l; n++) { if (cb.call(s, o[n], n, o) === false) { return false } } } else { for (n in o) { if (has$2(o, n)) { if (cb.call(s, o[n], n, o) === false) { return false } } } } return true } var map$1 = function (array, callback) { var out = [] each$i(array, function (item, index) { out.push(callback(item, index, array)) }) return out } var filter$2 = function (a, f) { var o = [] each$i(a, function (v, index) { if (!f || f(v, index, a)) { o.push(v) } }) return o } var indexOf$1 = function (a, v) { if (a) { for (var i = 0, l = a.length; i < l; i++) { if (a[i] === v) { return i } } } return -1 } var reduce = function (collection, iteratee, accumulator, thisArg) { var acc = isUndefined(accumulator) ? collection[0] : accumulator for (var i = 0; i < collection.length; i++) { acc = iteratee.call(thisArg, acc, collection[i], i) } return acc } var findIndex$1 = function (array, predicate, thisArg) { var i, l for (i = 0, l = array.length; i < l; i++) { if (predicate.call(thisArg, array[i], i, array)) { return i } } return -1 } var last$1 = function (collection) { return collection[collection.length - 1] } var __assign = function () { __assign = Object.assign || function __assign(t) { for (var s, i = 1, n = arguments.length; i < n; i++) { s = arguments[i] for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p] } return t } return __assign.apply(this, arguments) } function __rest(s, e) { var t = {} for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0) t[p] = s[p] if (s != null && typeof Object.getOwnPropertySymbols === 'function') for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) { if ( e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]) ) t[p[i]] = s[p[i]] } return t } function __spreadArray(to, from, pack) { if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) { if (ar || !(i in from)) { if (!ar) ar = Array.prototype.slice.call(from, 0, i) ar[i] = from[i] } } return to.concat(ar || Array.prototype.slice.call(from)) } var cached = function (f) { var called = false var r return function () { var args = [] for (var _i = 0; _i < arguments.length; _i++) { args[_i] = arguments[_i] } if (!called) { called = true r = f.apply(null, args) } return r } } var DeviceType = function (os, browser, userAgent, mediaMatch) { var isiPad = os.isiOS() && /ipad/i.test(userAgent) === true var isiPhone = os.isiOS() && !isiPad var isMobile = os.isiOS() || os.isAndroid() var isTouch = isMobile || mediaMatch('(pointer:coarse)') var isTablet = isiPad || (!isiPhone && isMobile && mediaMatch('(min-device-width:768px)')) var isPhone = isiPhone || (isMobile && !isTablet) var iOSwebview = browser.isSafari() && os.isiOS() && /safari/i.test(userAgent) === false var isDesktop = !isPhone && !isTablet && !iOSwebview return { isiPad: constant(isiPad), isiPhone: constant(isiPhone), isTablet: constant(isTablet), isPhone: constant(isPhone), isTouch: constant(isTouch), isAndroid: os.isAndroid, isiOS: os.isiOS, isWebView: constant(iOSwebview), isDesktop: constant(isDesktop), } } var firstMatch = function (regexes, s) { for (var i = 0; i < regexes.length; i++) { var x = regexes[i] if (x.test(s)) { return x } } return undefined } var find$2 = function (regexes, agent) { var r = firstMatch(regexes, agent) if (!r) { return { major: 0, minor: 0, } } var group = function (i) { return Number(agent.replace(r, '$' + i)) } return nu$4(group(1), group(2)) } var detect$3 = function (versionRegexes, agent) { var cleanedAgent = String(agent).toLowerCase() if (versionRegexes.length === 0) { return unknown$2() } return find$2(versionRegexes, cleanedAgent) } var unknown$2 = function () { return nu$4(0, 0) } var nu$4 = function (major, minor) { return { major: major, minor: minor, } } var Version = { nu: nu$4, detect: detect$3, unknown: unknown$2, } var detectBrowser$1 = function (browsers, userAgentData) { return findMap(userAgentData.brands, function (uaBrand) { var lcBrand = uaBrand.brand.toLowerCase() return find$3(browsers, function (browser) { var _a return ( lcBrand === ((_a = browser.brand) === null || _a === void 0 ? void 0 : _a.toLowerCase()) ) }).map(function (info) { return { current: info.name, version: Version.nu(parseInt(uaBrand.version, 10), 0), } }) }) } var detect$2 = function (candidates, userAgent) { var agent = String(userAgent).toLowerCase() return find$3(candidates, function (candidate) { return candidate.search(agent) }) } var detectBrowser = function (browsers, userAgent) { return detect$2(browsers, userAgent).map(function (browser) { var version = Version.detect(browser.versionRegexes, userAgent) return { current: browser.name, version: version, } }) } var detectOs = function (oses, userAgent) { return detect$2(oses, userAgent).map(function (os) { var version = Version.detect(os.versionRegexes, userAgent) return { current: os.name, version: version, } }) } var removeFromStart = function (str, numChars) { return str.substring(numChars) } var checkRange = function (str, substr, start) { return ( substr === '' || (str.length >= substr.length && str.substr(start, start + substr.length) === substr) ) } var removeLeading = function (str, prefix) { return startsWith(str, prefix) ? removeFromStart(str, prefix.length) : str } var contains$2 = function (str, substr) { return str.indexOf(substr) !== -1 } var startsWith = function (str, prefix) { return checkRange(str, prefix, 0) } var blank = function (r) { return function (s) { return s.replace(r, '') } } var trim$4 = blank(/^\s+|\s+$/g) var lTrim = blank(/^\s+/g) var rTrim = blank(/\s+$/g) var isNotEmpty = function (s) { return s.length > 0 } var isEmpty$3 = function (s) { return !isNotEmpty(s) } var normalVersionRegex = /.*?version\/\ ?([0-9]+)\.([0-9]+).*/ var checkContains = function (target) { return function (uastring) { return contains$2(uastring, target) } } var browsers = [ { name: 'Edge', versionRegexes: [/.*?edge\/ ?([0-9]+)\.([0-9]+)$/], search: function (uastring) { return ( contains$2(uastring, 'edge/') && contains$2(uastring, 'chrome') && contains$2(uastring, 'safari') && contains$2(uastring, 'applewebkit') ) }, }, { name: 'Chrome', brand: 'Chromium', versionRegexes: [/.*?chrome\/([0-9]+)\.([0-9]+).*/, normalVersionRegex], search: function (uastring) { return ( contains$2(uastring, 'chrome') && !contains$2(uastring, 'chromeframe') ) }, }, { name: 'IE', versionRegexes: [ /.*?msie\ ?([0-9]+)\.([0-9]+).*/, /.*?rv:([0-9]+)\.([0-9]+).*/, ], search: function (uastring) { return contains$2(uastring, 'msie') || contains$2(uastring, 'trident') }, }, { name: 'Opera', versionRegexes: [normalVersionRegex, /.*?opera\/([0-9]+)\.([0-9]+).*/], search: checkContains('opera'), }, { name: 'Firefox', versionRegexes: [/.*?firefox\/\ ?([0-9]+)\.([0-9]+).*/], search: checkContains('firefox'), }, { name: 'Safari', versionRegexes: [normalVersionRegex, /.*?cpu os ([0-9]+)_([0-9]+).*/], search: function (uastring) { return ( (contains$2(uastring, 'safari') || contains$2(uastring, 'mobile/')) && contains$2(uastring, 'applewebkit') ) }, }, ] var oses = [ { name: 'Windows', search: checkContains('win'), versionRegexes: [/.*?windows\ nt\ ?([0-9]+)\.([0-9]+).*/], }, { name: 'iOS', search: function (uastring) { return contains$2(uastring, 'iphone') || contains$2(uastring, 'ipad') }, versionRegexes: [ /.*?version\/\ ?([0-9]+)\.([0-9]+).*/, /.*cpu os ([0-9]+)_([0-9]+).*/, /.*cpu iphone os ([0-9]+)_([0-9]+).*/, ], }, { name: 'Android', search: checkContains('android'), versionRegexes: [/.*?android\ ?([0-9]+)\.([0-9]+).*/], }, { name: 'OSX', search: checkContains('mac os x'), versionRegexes: [/.*?mac\ os\ x\ ?([0-9]+)_([0-9]+).*/], }, { name: 'Linux', search: checkContains('linux'), versionRegexes: [], }, { name: 'Solaris', search: checkContains('sunos'), versionRegexes: [], }, { name: 'FreeBSD', search: checkContains('freebsd'), versionRegexes: [], }, { name: 'ChromeOS', search: checkContains('cros'), versionRegexes: [/.*?chrome\/([0-9]+)\.([0-9]+).*/], }, ] var PlatformInfo = { browsers: constant(browsers), oses: constant(oses), } var edge = 'Edge' var chrome = 'Chrome' var ie$1 = 'IE' var opera = 'Opera' var firefox = 'Firefox' var safari = 'Safari' var unknown$1 = function () { return nu$3({ current: undefined, version: Version.unknown(), }) } var nu$3 = function (info) { var current = info.current var version = info.version var isBrowser = function (name) { return function () { return current === name } } return { current: current, version: version, isEdge: isBrowser(edge), isChrome: isBrowser(chrome), isIE: isBrowser(ie$1), isOpera: isBrowser(opera), isFirefox: isBrowser(firefox), isSafari: isBrowser(safari), } } var Browser = { unknown: unknown$1, nu: nu$3, edge: constant(edge), chrome: constant(chrome), ie: constant(ie$1), opera: constant(opera), firefox: constant(firefox), safari: constant(safari), } var windows = 'Windows' var ios = 'iOS' var android = 'Android' var linux = 'Linux' var osx = 'OSX' var solaris = 'Solaris' var freebsd = 'FreeBSD' var chromeos = 'ChromeOS' var unknown = function () { return nu$2({ current: undefined, version: Version.unknown(), }) } var nu$2 = function (info) { var current = info.current var version = info.version var isOS = function (name) { return function () { return current === name } } return { current: current, version: version, isWindows: isOS(windows), isiOS: isOS(ios), isAndroid: isOS(android), isOSX: isOS(osx), isLinux: isOS(linux), isSolaris: isOS(solaris), isFreeBSD: isOS(freebsd), isChromeOS: isOS(chromeos), } } var OperatingSystem = { unknown: unknown, nu: nu$2, windows: constant(windows), ios: constant(ios), android: constant(android), linux: constant(linux), osx: constant(osx), solaris: constant(solaris), freebsd: constant(freebsd), chromeos: constant(chromeos), } var detect$1 = function (userAgent, userAgentDataOpt, mediaMatch) { var browsers = PlatformInfo.browsers() var oses = PlatformInfo.oses() var browser = userAgentDataOpt .bind(function (userAgentData) { return detectBrowser$1(browsers, userAgentData) }) .orThunk(function () { return detectBrowser(browsers, userAgent) }) .fold(Browser.unknown, Browser.nu) var os = detectOs(oses, userAgent).fold( OperatingSystem.unknown, OperatingSystem.nu ) var deviceType = DeviceType(os, browser, userAgent, mediaMatch) return { browser: browser, os: os, deviceType: deviceType, } } var PlatformDetection = { detect: detect$1 } var mediaMatch = function (query) { return window.matchMedia(query).matches } var platform$2 = cached(function () { return PlatformDetection.detect( navigator.userAgent, Optional.from(navigator.userAgentData), mediaMatch ) }) var detect = function () { return platform$2() } var userAgent = navigator.userAgent var platform$1 = detect() var browser$4 = platform$1.browser var os = platform$1.os var deviceType = platform$1.deviceType var webkit = /WebKit/.test(userAgent) && !browser$4.isEdge() var fileApi = 'FormData' in window && 'FileReader' in window && 'URL' in window && !!URL.createObjectURL var windowsPhone = userAgent.indexOf('Windows Phone') !== -1 var Env = { opera: browser$4.isOpera(), webkit: webkit, ie: browser$4.isIE() || browser$4.isEdge() ? browser$4.version.major : false, gecko: browser$4.isFirefox(), mac: os.isOSX() || os.isiOS(), iOS: deviceType.isiPad() || deviceType.isiPhone(), android: os.isAndroid(), contentEditable: true, transparentSrc: '', caretAfter: true, range: window.getSelection && 'Range' in window, documentMode: browser$4.isIE() ? document.documentMode || 7 : 10, fileApi: fileApi, ceFalse: true, cacheSuffix: null, container: null, experimentalShadowDom: false, canHaveCSP: !browser$4.isIE(), desktop: deviceType.isDesktop(), windowsPhone: windowsPhone, browser: { current: browser$4.current, version: browser$4.version, isChrome: browser$4.isChrome, isEdge: browser$4.isEdge, isFirefox: browser$4.isFirefox, isIE: browser$4.isIE, isOpera: browser$4.isOpera, isSafari: browser$4.isSafari, }, os: { current: os.current, version: os.version, isAndroid: os.isAndroid, isChromeOS: os.isChromeOS, isFreeBSD: os.isFreeBSD, isiOS: os.isiOS, isLinux: os.isLinux, isOSX: os.isOSX, isSolaris: os.isSolaris, isWindows: os.isWindows, }, deviceType: { isDesktop: deviceType.isDesktop, isiPad: deviceType.isiPad, isiPhone: deviceType.isiPhone, isPhone: deviceType.isPhone, isTablet: deviceType.isTablet, isTouch: deviceType.isTouch, isWebView: deviceType.isWebView, }, } var whiteSpaceRegExp$2 = /^\s*|\s*$/g var trim$3 = function (str) { return str === null || str === undefined ? '' : ('' + str).replace(whiteSpaceRegExp$2, '') } var is$3 = function (obj, type) { if (!type) { return obj !== undefined } if (type === 'array' && isArray(obj)) { return true } return typeof obj === type } var makeMap$4 = function (items, delim, map) { var i items = items || [] delim = delim || ',' if (typeof items === 'string') { items = items.split(delim) } map = map || {} i = items.length while (i--) { map[items[i]] = {} } return map } var hasOwnProperty = has$2 var create$9 = function (s, p, root) { var self = this var sp, scn, c, de = 0 s = /^((static) )?([\w.]+)(:([\w.]+))?/.exec(s) var cn = s[3].match(/(^|\.)(\w+)$/i)[2] var ns = self.createNS(s[3].replace(/\.\w+$/, ''), root) if (ns[cn]) { return } if (s[2] === 'static') { ns[cn] = p if (this.onCreate) { this.onCreate(s[2], s[3], ns[cn]) } return } if (!p[cn]) { p[cn] = function () {} de = 1 } ns[cn] = p[cn] self.extend(ns[cn].prototype, p) if (s[5]) { sp = self.resolve(s[5]).prototype scn = s[5].match(/\.(\w+)$/i)[1] c = ns[cn] if (de) { ns[cn] = function () { return sp[scn].apply(this, arguments) } } else { ns[cn] = function () { this.parent = sp[scn] return c.apply(this, arguments) } } ns[cn].prototype[cn] = ns[cn] self.each(sp, function (f, n) { ns[cn].prototype[n] = sp[n] }) self.each(p, function (f, n) { if (sp[n]) { ns[cn].prototype[n] = function () { this.parent = sp[n] return f.apply(this, arguments) } } else { if (n !== cn) { ns[cn].prototype[n] = f } } }) } self.each(p.static, function (f, n) { ns[cn][n] = f }) } var extend$6 = function (obj) { var exts = [] for (var _i = 1; _i < arguments.length; _i++) { exts[_i - 1] = arguments[_i] } for (var i = 0; i < exts.length; i++) { var ext = exts[i] for (var name_1 in ext) { if (has$2(ext, name_1)) { var value = ext[name_1] if (value !== undefined) { obj[name_1] = value } } } } return obj } var walk$3 = function (o, f, n, s) { s = s || this if (o) { if (n) { o = o[n] } each$i(o, function (o, i) { if (f.call(s, o, i, n) === false) { return false } walk$3(o, f, n, s) }) } } var createNS = function (n, o) { var i, v o = o || window n = n.split('.') for (i = 0; i < n.length; i++) { v = n[i] if (!o[v]) { o[v] = {} } o = o[v] } return o } var resolve$3 = function (n, o) { var i, l o = o || window n = n.split('.') for (i = 0, l = n.length; i < l; i++) { o = o[n[i]] if (!o) { break } } return o } var explode$4 = function (s, d) { if (!s || is$3(s, 'array')) { return s } return map$1(s.split(d || ','), trim$3) } var _addCacheSuffix = function (url) { var cacheSuffix = Env.cacheSuffix if (cacheSuffix) { url += (url.indexOf('?') === -1 ? '?' : '&') + cacheSuffix } return url } var Tools = { trim: trim$3, isArray: isArray, is: is$3, toArray: toArray$1, makeMap: makeMap$4, each: each$i, map: map$1, grep: filter$2, inArray: indexOf$1, hasOwn: hasOwnProperty, extend: extend$6, create: create$9, walk: walk$3, createNS: createNS, resolve: resolve$3, explode: explode$4, _addCacheSuffix: _addCacheSuffix, } var fromHtml$1 = function (html, scope) { var doc = scope || document var div = doc.createElement('div') div.innerHTML = html if (!div.hasChildNodes() || div.childNodes.length > 1) { console.error('HTML does not have a single root node', html) throw new Error('HTML must have a single root node') } return fromDom$2(div.childNodes[0]) } var fromTag = function (tag, scope) { var doc = scope || document var node = doc.createElement(tag) return fromDom$2(node) } var fromText = function (text, scope) { var doc = scope || document var node = doc.createTextNode(text) return fromDom$2(node) } var fromDom$2 = function (node) { if (node === null || node === undefined) { throw new Error('Node cannot be null or undefined') } return { dom: node } } var fromPoint$1 = function (docElm, x, y) { return Optional.from(docElm.dom.elementFromPoint(x, y)).map(fromDom$2) } var SugarElement = { fromHtml: fromHtml$1, fromTag: fromTag, fromText: fromText, fromDom: fromDom$2, fromPoint: fromPoint$1, } var toArray = function (target, f) { var r = [] var recurse = function (e) { r.push(e) return f(e) } var cur = f(target) do { cur = cur.bind(recurse) } while (cur.isSome()) return r } var compareDocumentPosition = function (a, b, match) { return (a.compareDocumentPosition(b) & match) !== 0 } var documentPositionContainedBy = function (a, b) { return compareDocumentPosition(a, b, Node.DOCUMENT_POSITION_CONTAINED_BY) } var COMMENT = 8 var DOCUMENT = 9 var DOCUMENT_FRAGMENT = 11 var ELEMENT = 1 var TEXT = 3 var is$2 = function (element, selector) { var dom = element.dom if (dom.nodeType !== ELEMENT) { return false } else { var elem = dom if (elem.matches !== undefined) { return elem.matches(selector) } else if (elem.msMatchesSelector !== undefined) { return elem.msMatchesSelector(selector) } else if (elem.webkitMatchesSelector !== undefined) { return elem.webkitMatchesSelector(selector) } else if (elem.mozMatchesSelector !== undefined) { return elem.mozMatchesSelector(selector) } else { throw new Error('Browser lacks native selectors') } } } var bypassSelector = function (dom) { return ( (dom.nodeType !== ELEMENT && dom.nodeType !== DOCUMENT && dom.nodeType !== DOCUMENT_FRAGMENT) || dom.childElementCount === 0 ) } var all = function (selector, scope) { var base = scope === undefined ? document : scope.dom return bypassSelector(base) ? [] : map$3(base.querySelectorAll(selector), SugarElement.fromDom) } var one = function (selector, scope) { var base = scope === undefined ? document : scope.dom return bypassSelector(base) ? Optional.none() : Optional.from(base.querySelector(selector)).map(SugarElement.fromDom) } var eq = function (e1, e2) { return e1.dom === e2.dom } var regularContains = function (e1, e2) { var d1 = e1.dom var d2 = e2.dom return d1 === d2 ? false : d1.contains(d2) } var ieContains = function (e1, e2) { return documentPositionContainedBy(e1.dom, e2.dom) } var contains$1 = function (e1, e2) { return detect().browser.isIE() ? ieContains(e1, e2) : regularContains(e1, e2) } typeof window !== 'undefined' ? window : Function('return this;')() var name = function (element) { var r = element.dom.nodeName return r.toLowerCase() } var type = function (element) { return element.dom.nodeType } var isType = function (t) { return function (element) { return type(element) === t } } var isComment$1 = function (element) { return type(element) === COMMENT || name(element) === '#comment' } var isElement$6 = isType(ELEMENT) var isText$8 = isType(TEXT) var isDocument$2 = isType(DOCUMENT) var isDocumentFragment$1 = isType(DOCUMENT_FRAGMENT) var isTag = function (tag) { return function (e) { return isElement$6(e) && name(e) === tag } } var owner$1 = function (element) { return SugarElement.fromDom(element.dom.ownerDocument) } var documentOrOwner = function (dos) { return isDocument$2(dos) ? dos : owner$1(dos) } var documentElement = function (element) { return SugarElement.fromDom(documentOrOwner(element).dom.documentElement) } var defaultView = function (element) { return SugarElement.fromDom(documentOrOwner(element).dom.defaultView) } var parent = function (element) { return Optional.from(element.dom.parentNode).map(SugarElement.fromDom) } var parents$1 = function (element, isRoot) { var stop = isFunction(isRoot) ? isRoot : never var dom = element.dom var ret = [] while (dom.parentNode !== null && dom.parentNode !== undefined) { var rawParent = dom.parentNode var p = SugarElement.fromDom(rawParent) ret.push(p) if (stop(p) === true) { break } else { dom = rawParent } } return ret } var siblings = function (element) { var filterSelf = function (elements) { return filter$4(elements, function (x) { return !eq(element, x) }) } return parent(element).map(children).map(filterSelf).getOr([]) } var prevSibling = function (element) { return Optional.from(element.dom.previousSibling).map(SugarElement.fromDom) } var nextSibling = function (element) { return Optional.from(element.dom.nextSibling).map(SugarElement.fromDom) } var prevSiblings = function (element) { return reverse(toArray(element, prevSibling)) } var nextSiblings = function (element) { return toArray(element, nextSibling) } var children = function (element) { return map$3(element.dom.childNodes, SugarElement.fromDom) } var child$1 = function (element, index) { var cs = element.dom.childNodes return Optional.from(cs[index]).map(SugarElement.fromDom) } var firstChild = function (element) { return child$1(element, 0) } var lastChild = function (element) { return child$1(element, element.dom.childNodes.length - 1) } var childNodesCount = function (element) { return element.dom.childNodes.length } var getHead = function (doc) { var b = doc.dom.head if (b === null || b === undefined) { throw new Error('Head is not available yet') } return SugarElement.fromDom(b) } var isShadowRoot = function (dos) { return isDocumentFragment$1(dos) && isNonNullable(dos.dom.host) } var supported = isFunction(Element.prototype.attachShadow) && isFunction(Node.prototype.getRootNode) var isSupported$1 = constant(supported) var getRootNode = supported ? function (e) { return SugarElement.fromDom(e.dom.getRootNode()) } : documentOrOwner var getStyleContainer = function (dos) { return isShadowRoot(dos) ? dos : getHead(documentOrOwner(dos)) } var getShadowRoot = function (e) { var r = getRootNode(e) return isShadowRoot(r) ? Optional.some(r) : Optional.none() } var getShadowHost = function (e) { return SugarElement.fromDom(e.dom.host) } var getOriginalEventTarget = function (event) { if (isSupported$1() && isNonNullable(event.target)) { var el = SugarElement.fromDom(event.target) if (isElement$6(el) && isOpenShadowHost(el)) { if (event.composed && event.composedPath) { var composedPath = event.composedPath() if (composedPath) { return head(composedPath) } } } } return Optional.from(event.target) } var isOpenShadowHost = function (element) { return isNonNullable(element.dom.shadowRoot) } var before$4 = function (marker, element) { var parent$1 = parent(marker) parent$1.each(function (v) { v.dom.insertBefore(element.dom, marker.dom) }) } var after$3 = function (marker, element) { var sibling = nextSibling(marker) sibling.fold( function () { var parent$1 = parent(marker) parent$1.each(function (v) { append$1(v, element) }) }, function (v) { before$4(v, element) } ) } var prepend = function (parent, element) { var firstChild$1 = firstChild(parent) firstChild$1.fold( function () { append$1(parent, element) }, function (v) { parent.dom.insertBefore(element.dom, v.dom) } ) } var append$1 = function (parent, element) { parent.dom.appendChild(element.dom) } var wrap$3 = function (element, wrapper) { before$4(element, wrapper) append$1(wrapper, element) } var before$3 = function (marker, elements) { each$k(elements, function (x) { before$4(marker, x) }) } var append = function (parent, elements) { each$k(elements, function (x) { append$1(parent, x) }) } var empty = function (element) { element.dom.textContent = '' each$k(children(element), function (rogue) { remove$7(rogue) }) } var remove$7 = function (element) { var dom = element.dom if (dom.parentNode !== null) { dom.parentNode.removeChild(dom) } } var unwrap = function (wrapper) { var children$1 = children(wrapper) if (children$1.length > 0) { before$3(wrapper, children$1) } remove$7(wrapper) } var inBody = function (element) { var dom = isText$8(element) ? element.dom.parentNode : element.dom if (dom === undefined || dom === null || dom.ownerDocument === null) { return false } var doc = dom.ownerDocument return getShadowRoot(SugarElement.fromDom(dom)).fold(function () { return doc.body.contains(dom) }, compose1(inBody, getShadowHost)) } var r = function (left, top) { var translate = function (x, y) { return r(left + x, top + y) } return { left: left, top: top, translate: translate, } } var SugarPosition = r var boxPosition = function (dom) { var box = dom.getBoundingClientRect() return SugarPosition(box.left, box.top) } var firstDefinedOrZero = function (a, b) { if (a !== undefined) { return a } else { return b !== undefined ? b : 0 } } var absolute = function (element) { var doc = element.dom.ownerDocument var body = doc.body var win = doc.defaultView var html = doc.documentElement if (body === element.dom) { return SugarPosition(body.offsetLeft, body.offsetTop) } var scrollTop = firstDefinedOrZero( win === null || win === void 0 ? void 0 : win.pageYOffset, html.scrollTop ) var scrollLeft = firstDefinedOrZero( win === null || win === void 0 ? void 0 : win.pageXOffset, html.scrollLeft ) var clientTop = firstDefinedOrZero(html.clientTop, body.clientTop) var clientLeft = firstDefinedOrZero(html.clientLeft, body.clientLeft) return viewport(element).translate( scrollLeft - clientLeft, scrollTop - clientTop ) } var viewport = function (element) { var dom = element.dom var doc = dom.ownerDocument var body = doc.body if (body === dom) { return SugarPosition(body.offsetLeft, body.offsetTop) } if (!inBody(element)) { return SugarPosition(0, 0) } return boxPosition(dom) } var get$8 = function (_DOC) { var doc = _DOC !== undefined ? _DOC.dom : document var x = doc.body.scrollLeft || doc.documentElement.scrollLeft var y = doc.body.scrollTop || doc.documentElement.scrollTop return SugarPosition(x, y) } var to = function (x, y, _DOC) { var doc = _DOC !== undefined ? _DOC.dom : document var win = doc.defaultView if (win) { win.scrollTo(x, y) } } var intoView = function (element, alignToTop) { var isSafari = detect().browser.isSafari() if (isSafari && isFunction(element.dom.scrollIntoViewIfNeeded)) { element.dom.scrollIntoViewIfNeeded(false) } else { element.dom.scrollIntoView(alignToTop) } } var get$7 = function (_win) { var win = _win === undefined ? window : _win if (detect().browser.isFirefox()) { return Optional.none() } else { return Optional.from(win['visualViewport']) } } var bounds = function (x, y, width, height) { return { x: x, y: y, width: width, height: height, right: x + width, bottom: y + height, } } var getBounds = function (_win) { var win = _win === undefined ? window : _win var doc = win.document var scroll = get$8(SugarElement.fromDom(doc)) return get$7(win).fold( function () { var html = win.document.documentElement var width = html.clientWidth var height = html.clientHeight return bounds(scroll.left, scroll.top, width, height) }, function (visualViewport) { return bounds( Math.max(visualViewport.pageLeft, scroll.left), Math.max(visualViewport.pageTop, scroll.top), visualViewport.width, visualViewport.height ) } ) } var isNodeType = function (type) { return function (node) { return !!node && node.nodeType === type } } var isRestrictedNode = function (node) { return !!node && !Object.getPrototypeOf(node) } var isElement$5 = isNodeType(1) var matchNodeNames = function (names) { var lowercasedNames = names.map(function (s) { return s.toLowerCase() }) return function (node) { if (node && node.nodeName) { var nodeName = node.nodeName.toLowerCase() return contains$3(lowercasedNames, nodeName) } return false } } var matchStyleValues = function (name, values) { var items = values.toLowerCase().split(' ') return function (node) { if (isElement$5(node)) { for (var i = 0; i < items.length; i++) { var computed = node.ownerDocument.defaultView.getComputedStyle( node, null ) var cssValue = computed ? computed.getPropertyValue(name) : null if (cssValue === items[i]) { return true } } } return false } } var hasAttribute = function (attrName) { return function (node) { return isElement$5(node) && node.hasAttribute(attrName) } } var hasAttributeValue = function (attrName, attrValue) { return function (node) { return isElement$5(node) && node.getAttribute(attrName) === attrValue } } var isBogus$2 = function (node) { return isElement$5(node) && node.hasAttribute('data-mce-bogus') } var isBogusAll$1 = function (node) { return isElement$5(node) && node.getAttribute('data-mce-bogus') === 'all' } var isTable$3 = function (node) { return isElement$5(node) && node.tagName === 'TABLE' } var hasContentEditableState = function (value) { return function (node) { if (isElement$5(node)) { if (node.contentEditable === value) { return true } if (node.getAttribute('data-mce-contenteditable') === value) { return true } } return false } } var isTextareaOrInput = matchNodeNames(['textarea', 'input']) var isText$7 = isNodeType(3) var isComment = isNodeType(8) var isDocument$1 = isNodeType(9) var isDocumentFragment = isNodeType(11) var isBr$5 = matchNodeNames(['br']) var isImg = matchNodeNames(['img']) var isContentEditableTrue$4 = hasContentEditableState('true') var isContentEditableFalse$b = hasContentEditableState('false') var isTableCell$5 = matchNodeNames(['td', 'th']) var isMedia$2 = matchNodeNames(['video', 'audio', 'object', 'embed']) var is$1 = function (lhs, rhs, comparator) { if (comparator === void 0) { comparator = tripleEquals } return lhs.exists(function (left) { return comparator(left, rhs) }) } var cat = function (arr) { var r = [] var push = function (x) { r.push(x) } for (var i = 0; i < arr.length; i++) { arr[i].each(push) } return r } var lift2 = function (oa, ob, f) { return oa.isSome() && ob.isSome() ? Optional.some(f(oa.getOrDie(), ob.getOrDie())) : Optional.none() } var lift3 = function (oa, ob, oc, f) { return oa.isSome() && ob.isSome() && oc.isSome() ? Optional.some(f(oa.getOrDie(), ob.getOrDie(), oc.getOrDie())) : Optional.none() } var someIf = function (b, a) { return b ? Optional.some(a) : Optional.none() } var isSupported = function (dom) { return dom.style !== undefined && isFunction(dom.style.getPropertyValue) } var rawSet = function (dom, key, value) { if (isString$1(value) || isBoolean(value) || isNumber(value)) { dom.setAttribute(key, value + '') } else { console.error( 'Invalid call to Attribute.set. Key ', key, ':: Value ', value, ':: Element ', dom ) throw new Error('Attribute value was not simple') } } var set$1 = function (element, key, value) { rawSet(element.dom, key, value) } var setAll$1 = function (element, attrs) { var dom = element.dom each$j(attrs, function (v, k) { rawSet(dom, k, v) }) } var get$6 = function (element, key) { var v = element.dom.getAttribute(key) return v === null ? undefined : v } var getOpt = function (element, key) { return Optional.from(get$6(element, key)) } var has$1 = function (element, key) { var dom = element.dom return dom && dom.hasAttribute ? dom.hasAttribute(key) : false } var remove$6 = function (element, key) { element.dom.removeAttribute(key) } var clone$3 = function (element) { return foldl( element.dom.attributes, function (acc, attr) { acc[attr.name] = attr.value return acc }, {} ) } var internalSet = function (dom, property, value) { if (!isString$1(value)) { console.error( 'Invalid call to CSS.set. Property ', property, ':: Value ', value, ':: Element ', dom ) throw new Error('CSS value must be a string: ' + value) } if (isSupported(dom)) { dom.style.setProperty(property, value) } } var setAll = function (element, css) { var dom = element.dom each$j(css, function (v, k) { internalSet(dom, k, v) }) } var get$5 = function (element, property) { var dom = element.dom var styles = window.getComputedStyle(dom) var r = styles.getPropertyValue(property) return r === '' && !inBody(element) ? getUnsafeProperty(dom, property) : r } var getUnsafeProperty = function (dom, property) { return isSupported(dom) ? dom.style.getPropertyValue(property) : '' } var getRaw = function (element, property) { var dom = element.dom var raw = getUnsafeProperty(dom, property) return Optional.from(raw).filter(function (r) { return r.length > 0 }) } var getAllRaw = function (element) { var css = {} var dom = element.dom if (isSupported(dom)) { for (var i = 0; i < dom.style.length; i++) { var ruleName = dom.style.item(i) css[ruleName] = dom.style[ruleName] } } return css } var reflow = function (e) { return e.dom.offsetWidth } var browser$3 = detect().browser var firstElement = function (nodes) { return find$3(nodes, isElement$6) } var getTableCaptionDeltaY = function (elm) { if (browser$3.isFirefox() && name(elm) === 'table') { return firstElement(children(elm)) .filter(function (elm) { return name(elm) === 'caption' }) .bind(function (caption) { return firstElement(nextSiblings(caption)).map(function (body) { var bodyTop = body.dom.offsetTop var captionTop = caption.dom.offsetTop var captionHeight = caption.dom.offsetHeight return bodyTop <= captionTop ? -captionHeight : 0 }) }) .getOr(0) } else { return 0 } } var hasChild = function (elm, child) { return elm.children && contains$3(elm.children, child) } var getPos = function (body, elm, rootElm) { var x = 0, y = 0 var doc = body.ownerDocument rootElm = rootElm ? rootElm : body if (elm) { if ( rootElm === body && elm.getBoundingClientRect && get$5(SugarElement.fromDom(body), 'position') === 'static' ) { var pos = elm.getBoundingClientRect() x = pos.left + (doc.documentElement.scrollLeft || body.scrollLeft) - doc.documentElement.clientLeft y = pos.top + (doc.documentElement.scrollTop || body.scrollTop) - doc.documentElement.clientTop return { x: x, y: y, } } var offsetParent = elm while ( offsetParent && offsetParent !== rootElm && offsetParent.nodeType && !hasChild(offsetParent, rootElm) ) { var castOffsetParent = offsetParent x += castOffsetParent.offsetLeft || 0 y += castOffsetParent.offsetTop || 0 offsetParent = castOffsetParent.offsetParent } offsetParent = elm.parentNode while ( offsetParent && offsetParent !== rootElm && offsetParent.nodeType && !hasChild(offsetParent, rootElm) ) { x -= offsetParent.scrollLeft || 0 y -= offsetParent.scrollTop || 0 offsetParent = offsetParent.parentNode } y += getTableCaptionDeltaY(SugarElement.fromDom(elm)) } return { x: x, y: y, } } var exports$1 = {}, module$1 = { exports: exports$1 } ;(function (define, exports, module, require) { ;(function (global, factory) { typeof exports === 'object' && typeof module !== 'undefined' ? (module.exports = factory()) : typeof define === 'function' && define.amd ? define(factory) : ((global = typeof globalThis !== 'undefined' ? globalThis : global || self), (global.EphoxContactWrapper = factory())) })(this, function () { var commonjsGlobal = typeof globalThis !== 'undefined' ? globalThis : typeof window !== 'undefined' ? window : typeof global !== 'undefined' ? global : typeof self !== 'undefined' ? self : {} var promise = { exports: {} } ;(function (module) { ;(function (root) { var setTimeoutFunc = setTimeout function noop() {} function bind(fn, thisArg) { return function () { fn.apply(thisArg, arguments) } } function Promise(fn) { if (typeof this !== 'object') throw new TypeError('Promises must be constructed via new') if (typeof fn !== 'function') throw new TypeError('not a function') this._state = 0 this._handled = false this._value = undefined this._deferreds = [] doResolve(fn, this) } function handle(self, deferred) { while (self._state === 3) { self = self._value } if (self._state === 0) { self._deferreds.push(deferred) return } self._handled = true Promise._immediateFn(function () { var cb = self._state === 1 ? deferred.onFulfilled : deferred.onRejected if (cb === null) { ;(self._state === 1 ? resolve : reject)( deferred.promise, self._value ) return } var ret try { ret = cb(self._value) } catch (e) { reject(deferred.promise, e) return } resolve(deferred.promise, ret) }) } function resolve(self, newValue) { try { if (newValue === self) throw new TypeError('A promise cannot be resolved with itself.') if ( newValue && (typeof newValue === 'object' || typeof newValue === 'function') ) { var then = newValue.then if (newValue instanceof Promise) { self._state = 3 self._value = newValue finale(self) return } else if (typeof then === 'function') { doResolve(bind(then, newValue), self) return } } self._state = 1 self._value = newValue finale(self) } catch (e) { reject(self, e) } } function reject(self, newValue) { self._state = 2 self._value = newValue finale(self) } function finale(self) { if (self._state === 2 && self._deferreds.length === 0) { Promise._immediateFn(function () { if (!self._handled) { Promise._unhandledRejectionFn(self._value) } }) } for (var i = 0, len = self._deferreds.length; i < len; i++) { handle(self, self._deferreds[i]) } self._deferreds = null } function Handler(onFulfilled, onRejected, promise) { this.onFulfilled = typeof onFulfilled === 'function' ? onFulfilled : null this.onRejected = typeof onRejected === 'function' ? onRejected : null this.promise = promise } function doResolve(fn, self) { var done = false try { fn( function (value) { if (done) return done = true resolve(self, value) }, function (reason) { if (done) return done = true reject(self, reason) } ) } catch (ex) { if (done) return done = true reject(self, ex) } } Promise.prototype['catch'] = function (onRejected) { return this.then(null, onRejected) } Promise.prototype.then = function (onFulfilled, onRejected) { var prom = new this.constructor(noop) handle(this, new Handler(onFulfilled, onRejected, prom)) return prom } Promise.all = function (arr) { var args = Array.prototype.slice.call(arr) return new Promise(function (resolve, reject) { if (args.length === 0) return resolve([]) var remaining = args.length function res(i, val) { try { if ( val && (typeof val === 'object' || typeof val === 'function') ) { var then = val.then if (typeof then === 'function') { then.call( val, function (val) { res(i, val) }, reject ) return } } args[i] = val if (--remaining === 0) { resolve(args) } } catch (ex) { reject(ex) } } for (var i = 0; i < args.length; i++) { res(i, args[i]) } }) } Promise.resolve = function (value) { if ( value && typeof value === 'object' && value.constructor === Promise ) { return value } return new Promise(function (resolve) { resolve(value) }) } Promise.reject = function (value) { return new Promise(function (resolve, reject) { reject(value) }) } Promise.race = function (values) { return new Promise(function (resolve, reject) { for (var i = 0, len = values.length; i < len; i++) { values[i].then(resolve, reject) } }) } Promise._immediateFn = typeof setImmediate === 'function' ? function (fn) { setImmediate(fn) } : function (fn) { setTimeoutFunc(fn, 0) } Promise._unhandledRejectionFn = function _unhandledRejectionFn(err) { if (typeof console !== 'undefined' && console) { console.warn('Possible Unhandled Promise Rejection:', err) } } Promise._setImmediateFn = function _setImmediateFn(fn) { Promise._immediateFn = fn } Promise._setUnhandledRejectionFn = function _setUnhandledRejectionFn( fn ) { Promise._unhandledRejectionFn = fn } if (module.exports) { module.exports = Promise } else if (!root.Promise) { root.Promise = Promise } })(commonjsGlobal) })(promise) var promisePolyfill = promise.exports var Global = (function () { if (typeof window !== 'undefined') { return window } else { return Function('return this;')() } })() var promisePolyfill_1 = { boltExport: Global.Promise || promisePolyfill } return promisePolyfill_1 }) })(undefined, exports$1, module$1) var Promise$1 = module$1.exports.boltExport var nu$1 = function (baseFn) { var data = Optional.none() var callbacks = [] var map = function (f) { return nu$1(function (nCallback) { get(function (data) { nCallback(f(data)) }) }) } var get = function (nCallback) { if (isReady()) { call(nCallback) } else { callbacks.push(nCallback) } } var set = function (x) { if (!isReady()) { data = Optional.some(x) run(callbacks) callbacks = [] } } var isReady = function () { return data.isSome() } var run = function (cbs) { each$k(cbs, call) } var call = function (cb) { data.each(function (x) { setTimeout(function () { cb(x) }, 0) }) } baseFn(set) return { get: get, map: map, isReady: isReady, } } var pure$1 = function (a) { return nu$1(function (callback) { callback(a) }) } var LazyValue = { nu: nu$1, pure: pure$1, } var errorReporter = function (err) { setTimeout(function () { throw err }, 0) } var make = function (run) { var get = function (callback) { run().then(callback, errorReporter) } var map = function (fab) { return make(function () { return run().then(fab) }) } var bind = function (aFutureB) { return make(function () { return run().then(function (v) { return aFutureB(v).toPromise() }) }) } var anonBind = function (futureB) { return make(function () { return run().then(function () { return futureB.toPromise() }) }) } var toLazy = function () { return LazyValue.nu(get) } var toCached = function () { var cache = null return make(function () { if (cache === null) { cache = run() } return cache }) } var toPromise = run return { map: map, bind: bind, anonBind: anonBind, toLazy: toLazy, toCached: toCached, toPromise: toPromise, get: get, } } var nu = function (baseFn) { return make(function () { return new Promise$1(baseFn) }) } var pure = function (a) { return make(function () { return Promise$1.resolve(a) }) } var Future = { nu: nu, pure: pure, } var par$1 = function (asyncValues, nu) { return nu(function (callback) { var r = [] var count = 0 var cb = function (i) { return function (value) { r[i] = value count++ if (count >= asyncValues.length) { callback(r) } } } if (asyncValues.length === 0) { callback([]) } else { each$k(asyncValues, function (asyncValue, i) { asyncValue.get(cb(i)) }) } }) } var par = function (futures) { return par$1(futures, Future.nu) } var value$1 = function (o) { var or = function (_opt) { return value$1(o) } var orThunk = function (_f) { return value$1(o) } var map = function (f) { return value$1(f(o)) } var mapError = function (_f) { return value$1(o) } var each = function (f) { f(o) } var bind = function (f) { return f(o) } var fold = function (_, onValue) { return onValue(o) } var exists = function (f) { return f(o) } var forall = function (f) { return f(o) } var toOptional = function () { return Optional.some(o) } return { isValue: always, isError: never, getOr: constant(o), getOrThunk: constant(o), getOrDie: constant(o), or: or, orThunk: orThunk, fold: fold, map: map, mapError: mapError, each: each, bind: bind, exists: exists, forall: forall, toOptional: toOptional, } } var error = function (message) { var getOrThunk = function (f) { return f() } var getOrDie = function () { return die(String(message))() } var or = identity var orThunk = function (f) { return f() } var map = function (_f) { return error(message) } var mapError = function (f) { return error(f(message)) } var bind = function (_f) { return error(message) } var fold = function (onError, _) { return onError(message) } return { isValue: never, isError: always, getOr: identity, getOrThunk: getOrThunk, getOrDie: getOrDie, or: or, orThunk: orThunk, fold: fold, map: map, mapError: mapError, each: noop, bind: bind, exists: never, forall: always, toOptional: Optional.none, } } var fromOption = function (opt, err) { return opt.fold(function () { return error(err) }, value$1) } var Result = { value: value$1, error: error, fromOption: fromOption, } var generate$1 = function (cases) { if (!isArray$1(cases)) { throw new Error('cases must be an array') } if (cases.length === 0) { throw new Error('there must be at least one case') } var constructors = [] var adt = {} each$k(cases, function (acase, count) { var keys$1 = keys(acase) if (keys$1.length !== 1) { throw new Error('one and only one name per case') } var key = keys$1[0] var value = acase[key] if (adt[key] !== undefined) { throw new Error('duplicate key detected:' + key) } else if (key === 'cata') { throw new Error('cannot have a case named cata (sorry)') } else if (!isArray$1(value)) { throw new Error('case arguments must be an array') } constructors.push(key) adt[key] = function () { var args = [] for (var _i = 0; _i < arguments.length; _i++) { args[_i] = arguments[_i] } var argLength = args.length if (argLength !== value.length) { throw new Error( 'Wrong number of arguments to case ' + key + '. Expected ' + value.length + ' (' + value + '), got ' + argLength ) } var match = function (branches) { var branchKeys = keys(branches) if (constructors.length !== branchKeys.length) { throw new Error( 'Wrong number of arguments to match. Expected: ' + constructors.join(',') + '\nActual: ' + branchKeys.join(',') ) } var allReqd = forall(constructors, function (reqKey) { return contains$3(branchKeys, reqKey) }) if (!allReqd) { throw new Error( 'Not all branches were specified when using match. Specified: ' + branchKeys.join(', ') + '\nRequired: ' + constructors.join(', ') ) } return branches[key].apply(null, args) } return { fold: function () { var foldArgs = [] for (var _i = 0; _i < arguments.length; _i++) { foldArgs[_i] = arguments[_i] } if (foldArgs.length !== cases.length) { throw new Error( 'Wrong number of arguments to fold. Expected ' + cases.length + ', got ' + foldArgs.length ) } var target = foldArgs[count] return target.apply(null, args) }, match: match, log: function (label) { console.log(label, { constructors: constructors, constructor: key, params: args, }) }, } } }) return adt } var Adt = { generate: generate$1 } Adt.generate([ { bothErrors: ['error1', 'error2'], }, { firstError: ['error1', 'value2'], }, { secondError: ['value1', 'error2'], }, { bothValues: ['value1', 'value2'], }, ]) var unite = function (result) { return result.fold(identity, identity) } function ClosestOrAncestor(is, ancestor, scope, a, isRoot) { if (is(scope, a)) { return Optional.some(scope) } else if (isFunction(isRoot) && isRoot(scope)) { return Optional.none() } else { return ancestor(scope, a, isRoot) } } var ancestor$3 = function (scope, predicate, isRoot) { var element = scope.dom var stop = isFunction(isRoot) ? isRoot : never while (element.parentNode) { element = element.parentNode var el = SugarElement.fromDom(element) if (predicate(el)) { return Optional.some(el) } else if (stop(el)) { break } } return Optional.none() } var closest$3 = function (scope, predicate, isRoot) { var is = function (s, test) { return test(s) } return ClosestOrAncestor(is, ancestor$3, scope, predicate, isRoot) } var sibling$2 = function (scope, predicate) { var element = scope.dom if (!element.parentNode) { return Optional.none() } return child(SugarElement.fromDom(element.parentNode), function (x) { return !eq(scope, x) && predicate(x) }) } var child = function (scope, predicate) { var pred = function (node) { return predicate(SugarElement.fromDom(node)) } var result = find$3(scope.dom.childNodes, pred) return result.map(SugarElement.fromDom) } var ancestor$2 = function (scope, selector, isRoot) { return ancestor$3( scope, function (e) { return is$2(e, selector) }, isRoot ) } var descendant = function (scope, selector) { return one(selector, scope) } var closest$2 = function (scope, selector, isRoot) { var is = function (element, selector) { return is$2(element, selector) } return ClosestOrAncestor(is, ancestor$2, scope, selector, isRoot) } var promiseObj = window.Promise ? window.Promise : Promise$1 var requestAnimationFramePromise var requestAnimationFrame = function (callback, element) { var requestAnimationFrameFunc = window.requestAnimationFrame var vendors = ['ms', 'moz', 'webkit'] var featurefill = function (cb) { window.setTimeout(cb, 0) } for (var i = 0; i < vendors.length && !requestAnimationFrameFunc; i++) { requestAnimationFrameFunc = window[vendors[i] + 'RequestAnimationFrame'] } if (!requestAnimationFrameFunc) { requestAnimationFrameFunc = featurefill } requestAnimationFrameFunc(callback, element) } var wrappedSetTimeout = function (callback, time) { if (typeof time !== 'number') { time = 0 } return setTimeout(callback, time) } var wrappedSetInterval = function (callback, time) { if (typeof time !== 'number') { time = 1 } return setInterval(callback, time) } var wrappedClearTimeout = function (id) { return clearTimeout(id) } var wrappedClearInterval = function (id) { return clearInterval(id) } var debounce = function (callback, time) { var timer var func = function () { var args = [] for (var _i = 0; _i < arguments.length; _i++) { args[_i] = arguments[_i] } clearTimeout(timer) timer = wrappedSetTimeout(function () { callback.apply(this, args) }, time) } func.stop = function () { clearTimeout(timer) } return func } var Delay = { requestAnimationFrame: function (callback, element) { if (requestAnimationFramePromise) { requestAnimationFramePromise.then(callback) return } requestAnimationFramePromise = new promiseObj(function (resolve) { if (!element) { element = document.body } requestAnimationFrame(resolve, element) }).then(callback) }, setTimeout: wrappedSetTimeout, setInterval: wrappedSetInterval, setEditorTimeout: function (editor, callback, time) { return wrappedSetTimeout(function () { if (!editor.removed) { callback() } }, time) }, setEditorInterval: function (editor, callback, time) { var timer = wrappedSetInterval(function () { if (!editor.removed) { callback() } else { clearInterval(timer) } }, time) return timer }, debounce: debounce, throttle: debounce, clearInterval: wrappedClearInterval, clearTimeout: wrappedClearTimeout, } var StyleSheetLoader = function (documentOrShadowRoot, settings) { if (settings === void 0) { settings = {} } var idCount = 0 var loadedStates = {} var edos = SugarElement.fromDom(documentOrShadowRoot) var doc = documentOrOwner(edos) var maxLoadTime = settings.maxLoadTime || 5000 var _setReferrerPolicy = function (referrerPolicy) { settings.referrerPolicy = referrerPolicy } var addStyle = function (element) { append$1(getStyleContainer(edos), element) } var removeStyle = function (id) { var styleContainer = getStyleContainer(edos) descendant(styleContainer, '#' + id).each(remove$7) } var getOrCreateState = function (url) { return get$9(loadedStates, url).getOrThunk(function () { return { id: 'mce-u' + idCount++, passed: [], failed: [], count: 0, } }) } var load = function (url, success, failure) { var link var urlWithSuffix = Tools._addCacheSuffix(url) var state = getOrCreateState(urlWithSuffix) loadedStates[urlWithSuffix] = state state.count++ var resolve = function (callbacks, status) { var i = callbacks.length while (i--) { callbacks[i]() } state.status = status state.passed = [] state.failed = [] if (link) { link.onload = null link.onerror = null link = null } } var passed = function () { return resolve(state.passed, 2) } var failed = function () { return resolve(state.failed, 3) } var wait = function (testCallback, waitCallback) { if (!testCallback()) { if (Date.now() - startTime < maxLoadTime) { Delay.setTimeout(waitCallback) } else { failed() } } } var waitForWebKitLinkLoaded = function () { wait(function () { var styleSheets = documentOrShadowRoot.styleSheets var i = styleSheets.length while (i--) { var styleSheet = styleSheets[i] var owner = styleSheet.ownerNode if (owner && owner.id === link.id) { passed() return true } } return false }, waitForWebKitLinkLoaded) } if (success) { state.passed.push(success) } if (failure) { state.failed.push(failure) } if (state.status === 1) { return } if (state.status === 2) { passed() return } if (state.status === 3) { failed() return } state.status = 1 var linkElem = SugarElement.fromTag('link', doc.dom) setAll$1(linkElem, { rel: 'stylesheet', type: 'text/css', id: state.id, }) var startTime = Date.now() if (settings.contentCssCors) { set$1(linkElem, 'crossOrigin', 'anonymous') } if (settings.referrerPolicy) { set$1(linkElem, 'referrerpolicy', settings.referrerPolicy) } link = linkElem.dom link.onload = waitForWebKitLinkLoaded link.onerror = failed addStyle(linkElem) set$1(linkElem, 'href', urlWithSuffix) } var loadF = function (url) { return Future.nu(function (resolve) { load( url, compose(resolve, constant(Result.value(url))), compose(resolve, constant(Result.error(url))) ) }) } var loadAll = function (urls, success, failure) { par(map$3(urls, loadF)).get(function (result) { var parts = partition(result, function (r) { return r.isValue() }) if (parts.fail.length > 0) { failure(parts.fail.map(unite)) } else { success(parts.pass.map(unite)) } }) } var unload = function (url) { var urlWithSuffix = Tools._addCacheSuffix(url) get$9(loadedStates, urlWithSuffix).each(function (state) { var count = --state.count if (count === 0) { delete loadedStates[urlWithSuffix] removeStyle(state.id) } }) } var unloadAll = function (urls) { each$k(urls, function (url) { unload(url) }) } return { load: load, loadAll: loadAll, unload: unload, unloadAll: unloadAll, _setReferrerPolicy: _setReferrerPolicy, } } var create$8 = function () { var map = new WeakMap() var forElement = function (referenceElement, settings) { var root = getRootNode(referenceElement) var rootDom = root.dom return Optional.from(map.get(rootDom)).getOrThunk(function () { var sl = StyleSheetLoader(rootDom, settings) map.set(rootDom, sl) return sl }) } return { forElement: forElement } } var instance = create$8() var DomTreeWalker = (function () { function DomTreeWalker(startNode, rootNode) { this.node = startNode this.rootNode = rootNode this.current = this.current.bind(this) this.next = this.next.bind(this) this.prev = this.prev.bind(this) this.prev2 = this.prev2.bind(this) } DomTreeWalker.prototype.current = function () { return this.node } DomTreeWalker.prototype.next = function (shallow) { this.node = this.findSibling( this.node, 'firstChild', 'nextSibling', shallow ) return this.node } DomTreeWalker.prototype.prev = function (shallow) { this.node = this.findSibling( this.node, 'lastChild', 'previousSibling', shallow ) return this.node } DomTreeWalker.prototype.prev2 = function (shallow) { this.node = this.findPreviousNode( this.node, 'lastChild', 'previousSibling', shallow ) return this.node } DomTreeWalker.prototype.findSibling = function ( node, startName, siblingName, shallow ) { var sibling, parent if (node) { if (!shallow && node[startName]) { return node[startName] } if (node !== this.rootNode) { sibling = node[siblingName] if (sibling) { return sibling } for ( parent = node.parentNode; parent && parent !== this.rootNode; parent = parent.parentNode ) { sibling = parent[siblingName] if (sibling) { return sibling } } } } } DomTreeWalker.prototype.findPreviousNode = function ( node, startName, siblingName, shallow ) { var sibling, parent, child if (node) { sibling = node[siblingName] if (this.rootNode && sibling === this.rootNode) { return } if (sibling) { if (!shallow) { for (child = sibling[startName]; child; child = child[startName]) { if (!child[startName]) { return child } } } return sibling } parent = node.parentNode if (parent && parent !== this.rootNode) { return parent } } } return DomTreeWalker })() var blocks = [ 'article', 'aside', 'details', 'div', 'dt', 'figcaption', 'footer', 'form', 'fieldset', 'header', 'hgroup', 'html', 'main', 'nav', 'section', 'summary', 'body', 'p', 'dl', 'multicol', 'dd', 'figure', 'address', 'center', 'blockquote', 'h1', 'h2', 'h3', 'h4', 'h5', 'h6', 'listing', 'xmp', 'pre', 'plaintext', 'menu', 'dir', 'ul', 'ol', 'li', 'hr', 'table', 'tbody', 'thead', 'tfoot', 'th', 'tr', 'td', 'caption', ] var tableCells = ['td', 'th'] var tableSections = ['thead', 'tbody', 'tfoot'] var textBlocks = [ 'h1', 'h2', 'h3', 'h4', 'h5', 'h6', 'p', 'div', 'address', 'pre', 'form', 'blockquote', 'center', 'dir', 'fieldset', 'header', 'footer', 'article', 'section', 'hgroup', 'aside', 'nav', 'figure', ] var headings = ['h1', 'h2', 'h3', 'h4', 'h5', 'h6'] var listItems$1 = ['li', 'dd', 'dt'] var lists = ['ul', 'ol', 'dl'] var wsElements = ['pre', 'script', 'textarea', 'style'] var lazyLookup = function (items) { var lookup return function (node) { lookup = lookup ? lookup : mapToObject(items, always) return has$2(lookup, name(node)) } } var isHeading = lazyLookup(headings) var isBlock$2 = lazyLookup(blocks) var isTable$2 = function (node) { return name(node) === 'table' } var isInline$1 = function (node) { return isElement$6(node) && !isBlock$2(node) } var isBr$4 = function (node) { return isElement$6(node) && name(node) === 'br' } var isTextBlock$2 = lazyLookup(textBlocks) var isList = lazyLookup(lists) var isListItem = lazyLookup(listItems$1) var isTableSection = lazyLookup(tableSections) var isTableCell$4 = lazyLookup(tableCells) var isWsPreserveElement = lazyLookup(wsElements) var ancestor$1 = function (scope, selector, isRoot) { return ancestor$2(scope, selector, isRoot).isSome() } var zeroWidth = '\uFEFF' var nbsp = '\xA0' var isZwsp$1 = function (char) { return char === zeroWidth } var removeZwsp = function (s) { return s.replace(/\uFEFF/g, '') } var ZWSP$1 = zeroWidth var isZwsp = isZwsp$1 var trim$2 = removeZwsp var isElement$4 = isElement$5 var isText$6 = isText$7 var isCaretContainerBlock$1 = function (node) { if (isText$6(node)) { node = node.parentNode } return isElement$4(node) && node.hasAttribute('data-mce-caret') } var isCaretContainerInline = function (node) { return isText$6(node) && isZwsp(node.data) } var isCaretContainer$2 = function (node) { return isCaretContainerBlock$1(node) || isCaretContainerInline(node) } var hasContent = function (node) { return node.firstChild !== node.lastChild || !isBr$5(node.firstChild) } var insertInline$1 = function (node, before) { var doc = node.ownerDocument var textNode = doc.createTextNode(ZWSP$1) var parentNode = node.parentNode if (!before) { var sibling = node.nextSibling if (isText$6(sibling)) { if (isCaretContainer$2(sibling)) { return sibling } if (startsWithCaretContainer$1(sibling)) { sibling.splitText(1) return sibling } } if (node.nextSibling) { parentNode.insertBefore(textNode, node.nextSibling) } else { parentNode.appendChild(textNode) } } else { var sibling = node.previousSibling if (isText$6(sibling)) { if (isCaretContainer$2(sibling)) { return sibling } if (endsWithCaretContainer$1(sibling)) { return sibling.splitText(sibling.data.length - 1) } } parentNode.insertBefore(textNode, node) } return textNode } var isBeforeInline = function (pos) { var container = pos.container() if (!isText$7(container)) { return false } return ( container.data.charAt(pos.offset()) === ZWSP$1 || (pos.isAtStart() && isCaretContainerInline(container.previousSibling)) ) } var isAfterInline = function (pos) { var container = pos.container() if (!isText$7(container)) { return false } return ( container.data.charAt(pos.offset() - 1) === ZWSP$1 || (pos.isAtEnd() && isCaretContainerInline(container.nextSibling)) ) } var createBogusBr = function () { var br = document.createElement('br') br.setAttribute('data-mce-bogus', '1') return br } var insertBlock$1 = function (blockName, node, before) { var doc = node.ownerDocument var blockNode = doc.createElement(blockName) blockNode.setAttribute('data-mce-caret', before ? 'before' : 'after') blockNode.setAttribute('data-mce-bogus', 'all') blockNode.appendChild(createBogusBr()) var parentNode = node.parentNode if (!before) { if (node.nextSibling) { parentNode.insertBefore(blockNode, node.nextSibling) } else { parentNode.appendChild(blockNode) } } else { parentNode.insertBefore(blockNode, node) } return blockNode } var startsWithCaretContainer$1 = function (node) { return isText$6(node) && node.data[0] === ZWSP$1 } var endsWithCaretContainer$1 = function (node) { return isText$6(node) && node.data[node.data.length - 1] === ZWSP$1 } var trimBogusBr = function (elm) { var brs = elm.getElementsByTagName('br') var lastBr = brs[brs.length - 1] if (isBogus$2(lastBr)) { lastBr.parentNode.removeChild(lastBr) } } var showCaretContainerBlock = function (caretContainer) { if (caretContainer && caretContainer.hasAttribute('data-mce-caret')) { trimBogusBr(caretContainer) caretContainer.removeAttribute('data-mce-caret') caretContainer.removeAttribute('data-mce-bogus') caretContainer.removeAttribute('style') caretContainer.removeAttribute('_moz_abspos') return caretContainer } return null } var isRangeInCaretContainerBlock = function (range) { return isCaretContainerBlock$1(range.startContainer) } var isContentEditableTrue$3 = isContentEditableTrue$4 var isContentEditableFalse$a = isContentEditableFalse$b var isBr$3 = isBr$5 var isText$5 = isText$7 var isInvalidTextElement = matchNodeNames(['script', 'style', 'textarea']) var isAtomicInline = matchNodeNames([ 'img', 'input', 'textarea', 'hr', 'iframe', 'video', 'audio', 'object', 'embed', ]) var isTable$1 = matchNodeNames(['table']) var isCaretContainer$1 = isCaretContainer$2 var isCaretCandidate$3 = function (node) { if (isCaretContainer$1(node)) { return false } if (isText$5(node)) { return !isInvalidTextElement(node.parentNode) } return ( isAtomicInline(node) || isBr$3(node) || isTable$1(node) || isNonUiContentEditableFalse(node) ) } var isUnselectable = function (node) { return isElement$5(node) && node.getAttribute('unselectable') === 'true' } var isNonUiContentEditableFalse = function (node) { return isUnselectable(node) === false && isContentEditableFalse$a(node) } var isInEditable = function (node, root) { for ( node = node.parentNode; node && node !== root; node = node.parentNode ) { if (isNonUiContentEditableFalse(node)) { return false } if (isContentEditableTrue$3(node)) { return true } } return true } var isAtomicContentEditableFalse = function (node) { if (!isNonUiContentEditableFalse(node)) { return false } return ( foldl( from(node.getElementsByTagName('*')), function (result, elm) { return result || isContentEditableTrue$3(elm) }, false ) !== true ) } var isAtomic$1 = function (node) { return isAtomicInline(node) || isAtomicContentEditableFalse(node) } var isEditableCaretCandidate$1 = function (node, root) { return isCaretCandidate$3(node) && isInEditable(node, root) } var whiteSpaceRegExp$1 = /^[ \t\r\n]*$/ var isWhitespaceText = function (text) { return whiteSpaceRegExp$1.test(text) } var hasWhitespacePreserveParent = function (node, rootNode) { var rootElement = SugarElement.fromDom(rootNode) var startNode = SugarElement.fromDom(node) return ancestor$1(startNode, 'pre,code', curry(eq, rootElement)) } var isWhitespace = function (node, rootNode) { return ( isText$7(node) && isWhitespaceText(node.data) && hasWhitespacePreserveParent(node, rootNode) === false ) } var isNamedAnchor = function (node) { return ( isElement$5(node) && node.nodeName === 'A' && !node.hasAttribute('href') && (node.hasAttribute('name') || node.hasAttribute('id')) ) } var isContent$1 = function (node, rootNode) { return ( (isCaretCandidate$3(node) && isWhitespace(node, rootNode) === false) || isNamedAnchor(node) || isBookmark(node) ) } var isBookmark = hasAttribute('data-mce-bookmark') var isBogus$1 = hasAttribute('data-mce-bogus') var isBogusAll = hasAttributeValue('data-mce-bogus', 'all') var isEmptyNode = function (targetNode, skipBogus) { var brCount = 0 if (isContent$1(targetNode, targetNode)) { return false } else { var node = targetNode.firstChild if (!node) { return true } var walker = new DomTreeWalker(node, targetNode) do { if (skipBogus) { if (isBogusAll(node)) { node = walker.next(true) continue } if (isBogus$1(node)) { node = walker.next() continue } } if (isBr$5(node)) { brCount++ node = walker.next() continue } if (isContent$1(node, targetNode)) { return false } node = walker.next() } while (node) return brCount <= 1 } } var isEmpty$2 = function (elm, skipBogus) { if (skipBogus === void 0) { skipBogus = true } return isEmptyNode(elm.dom, skipBogus) } var isSpan = function (node) { return node.nodeName.toLowerCase() === 'span' } var isInlineContent = function (node, root) { return ( isNonNullable(node) && (isContent$1(node, root) || isInline$1(SugarElement.fromDom(node))) ) } var surroundedByInlineContent = function (node, root) { var prev = new DomTreeWalker(node, root).prev(false) var next = new DomTreeWalker(node, root).next(false) var prevIsInline = isUndefined(prev) || isInlineContent(prev, root) var nextIsInline = isUndefined(next) || isInlineContent(next, root) return prevIsInline && nextIsInline } var isBookmarkNode$2 = function (node) { return isSpan(node) && node.getAttribute('data-mce-type') === 'bookmark' } var isKeepTextNode = function (node, root) { return ( isText$7(node) && node.data.length > 0 && surroundedByInlineContent(node, root) ) } var isKeepElement = function (node) { return isElement$5(node) ? node.childNodes.length > 0 : false } var isDocument = function (node) { return isDocumentFragment(node) || isDocument$1(node) } var trimNode = function (dom, node, root) { var rootNode = root || node if (isElement$5(node) && isBookmarkNode$2(node)) { return node } var children = node.childNodes for (var i = children.length - 1; i >= 0; i--) { trimNode(dom, children[i], rootNode) } if (isElement$5(node)) { var currentChildren = node.childNodes if ( currentChildren.length === 1 && isBookmarkNode$2(currentChildren[0]) ) { node.parentNode.insertBefore(currentChildren[0], node) } } if ( !isDocument(node) && !isContent$1(node, rootNode) && !isKeepElement(node) && !isKeepTextNode(node, rootNode) ) { dom.remove(node) } return node } var makeMap$3 = Tools.makeMap var attrsCharsRegExp = /[&<>\"\u0060\u007E-\uD7FF\uE000-\uFFEF]|[\uD800-\uDBFF][\uDC00-\uDFFF]/g var textCharsRegExp = /[<>&\u007E-\uD7FF\uE000-\uFFEF]|[\uD800-\uDBFF][\uDC00-\uDFFF]/g var rawCharsRegExp = /[<>&\"\']/g var entityRegExp = /&#([a-z0-9]+);?|&([a-z0-9]+);/gi var asciiMap = { 128: '\u20AC', 130: '\u201A', 131: '\u0192', 132: '\u201E', 133: '\u2026', 134: '\u2020', 135: '\u2021', 136: '\u02c6', 137: '\u2030', 138: '\u0160', 139: '\u2039', 140: '\u0152', 142: '\u017d', 145: '\u2018', 146: '\u2019', 147: '\u201C', 148: '\u201D', 149: '\u2022', 150: '\u2013', 151: '\u2014', 152: '\u02DC', 153: '\u2122', 154: '\u0161', 155: '\u203A', 156: '\u0153', 158: '\u017e', 159: '\u0178', } var baseEntities = { '"': '"', "'": ''', '<': '<', '>': '>', '&': '&', '`': '`', } var reverseEntities = { '<': '<', '>': '>', '&': '&', '"': '"', ''': "'", } var nativeDecode = function (text) { var elm = SugarElement.fromTag('div').dom elm.innerHTML = text return elm.textContent || elm.innerText || text } var buildEntitiesLookup = function (items, radix) { var i, chr, entity var lookup = {} if (items) { items = items.split(',') radix = radix || 10 for (i = 0; i < items.length; i += 2) { chr = String.fromCharCode(parseInt(items[i], radix)) if (!baseEntities[chr]) { entity = '&' + items[i + 1] + ';' lookup[chr] = entity lookup[entity] = chr } } return lookup } } var namedEntities = buildEntitiesLookup( '50,nbsp,51,iexcl,52,cent,53,pound,54,curren,55,yen,56,brvbar,57,sect,58,uml,59,copy,' + '5a,ordf,5b,laquo,5c,not,5d,shy,5e,reg,5f,macr,5g,deg,5h,plusmn,5i,sup2,5j,sup3,5k,acute,' + '5l,micro,5m,para,5n,middot,5o,cedil,5p,sup1,5q,ordm,5r,raquo,5s,frac14,5t,frac12,5u,frac34,' + '5v,iquest,60,Agrave,61,Aacute,62,Acirc,63,Atilde,64,Auml,65,Aring,66,AElig,67,Ccedil,' + '68,Egrave,69,Eacute,6a,Ecirc,6b,Euml,6c,Igrave,6d,Iacute,6e,Icirc,6f,Iuml,6g,ETH,6h,Ntilde,' + '6i,Ograve,6j,Oacute,6k,Ocirc,6l,Otilde,6m,Ouml,6n,times,6o,Oslash,6p,Ugrave,6q,Uacute,' + '6r,Ucirc,6s,Uuml,6t,Yacute,6u,THORN,6v,szlig,70,agrave,71,aacute,72,acirc,73,atilde,74,auml,' + '75,aring,76,aelig,77,ccedil,78,egrave,79,eacute,7a,ecirc,7b,euml,7c,igrave,7d,iacute,7e,icirc,' + '7f,iuml,7g,eth,7h,ntilde,7i,ograve,7j,oacute,7k,ocirc,7l,otilde,7m,ouml,7n,divide,7o,oslash,' + '7p,ugrave,7q,uacute,7r,ucirc,7s,uuml,7t,yacute,7u,thorn,7v,yuml,ci,fnof,sh,Alpha,si,Beta,' + 'sj,Gamma,sk,Delta,sl,Epsilon,sm,Zeta,sn,Eta,so,Theta,sp,Iota,sq,Kappa,sr,Lambda,ss,Mu,' + 'st,Nu,su,Xi,sv,Omicron,t0,Pi,t1,Rho,t3,Sigma,t4,Tau,t5,Upsilon,t6,Phi,t7,Chi,t8,Psi,' + 't9,Omega,th,alpha,ti,beta,tj,gamma,tk,delta,tl,epsilon,tm,zeta,tn,eta,to,theta,tp,iota,' + 'tq,kappa,tr,lambda,ts,mu,tt,nu,tu,xi,tv,omicron,u0,pi,u1,rho,u2,sigmaf,u3,sigma,u4,tau,' + 'u5,upsilon,u6,phi,u7,chi,u8,psi,u9,omega,uh,thetasym,ui,upsih,um,piv,812,bull,816,hellip,' + '81i,prime,81j,Prime,81u,oline,824,frasl,88o,weierp,88h,image,88s,real,892,trade,89l,alefsym,' + '8cg,larr,8ch,uarr,8ci,rarr,8cj,darr,8ck,harr,8dl,crarr,8eg,lArr,8eh,uArr,8ei,rArr,8ej,dArr,' + '8ek,hArr,8g0,forall,8g2,part,8g3,exist,8g5,empty,8g7,nabla,8g8,isin,8g9,notin,8gb,ni,8gf,prod,' + '8gh,sum,8gi,minus,8gn,lowast,8gq,radic,8gt,prop,8gu,infin,8h0,ang,8h7,and,8h8,or,8h9,cap,8ha,cup,' + '8hb,int,8hk,there4,8hs,sim,8i5,cong,8i8,asymp,8j0,ne,8j1,equiv,8j4,le,8j5,ge,8k2,sub,8k3,sup,8k4,' + 'nsub,8k6,sube,8k7,supe,8kl,oplus,8kn,otimes,8l5,perp,8m5,sdot,8o8,lceil,8o9,rceil,8oa,lfloor,8ob,' + 'rfloor,8p9,lang,8pa,rang,9ea,loz,9j0,spades,9j3,clubs,9j5,hearts,9j6,diams,ai,OElig,aj,oelig,b0,' + 'Scaron,b1,scaron,bo,Yuml,m6,circ,ms,tilde,802,ensp,803,emsp,809,thinsp,80c,zwnj,80d,zwj,80e,lrm,' + '80f,rlm,80j,ndash,80k,mdash,80o,lsquo,80p,rsquo,80q,sbquo,80s,ldquo,80t,rdquo,80u,bdquo,810,dagger,' + '811,Dagger,81g,permil,81p,lsaquo,81q,rsaquo,85c,euro', 32 ) var encodeRaw = function (text, attr) { return text.replace( attr ? attrsCharsRegExp : textCharsRegExp, function (chr) { return baseEntities[chr] || chr } ) } var encodeAllRaw = function (text) { return ('' + text).replace(rawCharsRegExp, function (chr) { return baseEntities[chr] || chr }) } var encodeNumeric = function (text, attr) { return text.replace( attr ? attrsCharsRegExp : textCharsRegExp, function (chr) { if (chr.length > 1) { return ( '&#' + ((chr.charCodeAt(0) - 55296) * 1024 + (chr.charCodeAt(1) - 56320) + 65536) + ';' ) } return baseEntities[chr] || '&#' + chr.charCodeAt(0) + ';' } ) } var encodeNamed = function (text, attr, entities) { entities = entities || namedEntities return text.replace( attr ? attrsCharsRegExp : textCharsRegExp, function (chr) { return baseEntities[chr] || entities[chr] || chr } ) } var getEncodeFunc = function (name, entities) { var entitiesMap = buildEntitiesLookup(entities) || namedEntities var encodeNamedAndNumeric = function (text, attr) { return text.replace( attr ? attrsCharsRegExp : textCharsRegExp, function (chr) { if (baseEntities[chr] !== undefined) { return baseEntities[chr] } if (entitiesMap[chr] !== undefined) { return entitiesMap[chr] } if (chr.length > 1) { return ( '&#' + ((chr.charCodeAt(0) - 55296) * 1024 + (chr.charCodeAt(1) - 56320) + 65536) + ';' ) } return '&#' + chr.charCodeAt(0) + ';' } ) } var encodeCustomNamed = function (text, attr) { return encodeNamed(text, attr, entitiesMap) } var nameMap = makeMap$3(name.replace(/\+/g, ',')) if (nameMap.named && nameMap.numeric) { return encodeNamedAndNumeric } if (nameMap.named) { if (entities) { return encodeCustomNamed } return encodeNamed } if (nameMap.numeric) { return encodeNumeric } return encodeRaw } var decode = function (text) { return text.replace(entityRegExp, function (all, numeric) { if (numeric) { if (numeric.charAt(0).toLowerCase() === 'x') { numeric = parseInt(numeric.substr(1), 16) } else { numeric = parseInt(numeric, 10) } if (numeric > 65535) { numeric -= 65536 return String.fromCharCode( 55296 + (numeric >> 10), 56320 + (numeric & 1023) ) } return asciiMap[numeric] || String.fromCharCode(numeric) } return reverseEntities[all] || namedEntities[all] || nativeDecode(all) }) } var Entities = { encodeRaw: encodeRaw, encodeAllRaw: encodeAllRaw, encodeNumeric: encodeNumeric, encodeNamed: encodeNamed, getEncodeFunc: getEncodeFunc, decode: decode, } var mapCache = {}, dummyObj = {} var makeMap$2 = Tools.makeMap, each$h = Tools.each, extend$5 = Tools.extend, explode$3 = Tools.explode, inArray$2 = Tools.inArray var split$1 = function (items, delim) { items = Tools.trim(items) return items ? items.split(delim || ' ') : [] } var compileSchema = function (type) { var schema = {} var globalAttributes, blockContent var phrasingContent, flowContent, html4BlockContent, html4PhrasingContent var add = function (name, attributes, children) { var ni, attributesOrder, element var arrayToMap = function (array, obj) { var map = {} var i, l for (i = 0, l = array.length; i < l; i++) { map[array[i]] = obj || {} } return map } children = children || [] attributes = attributes || '' if (typeof children === 'string') { children = split$1(children) } var names = split$1(name) ni = names.length while (ni--) { attributesOrder = split$1([globalAttributes, attributes].join(' ')) element = { attributes: arrayToMap(attributesOrder), attributesOrder: attributesOrder, children: arrayToMap(children, dummyObj), } schema[names[ni]] = element } } var addAttrs = function (name, attributes) { var ni, schemaItem, i, l var names = split$1(name) ni = names.length var attrs = split$1(attributes) while (ni--) { schemaItem = schema[names[ni]] for (i = 0, l = attrs.length; i < l; i++) { schemaItem.attributes[attrs[i]] = {} schemaItem.attributesOrder.push(attrs[i]) } } } if (mapCache[type]) { return mapCache[type] } globalAttributes = 'id accesskey class dir lang style tabindex title role' blockContent = 'address blockquote div dl fieldset form h1 h2 h3 h4 h5 h6 hr menu ol p pre table ul' phrasingContent = 'a abbr b bdo br button cite code del dfn em embed i iframe img input ins kbd ' + 'label map noscript object q s samp script select small span strong sub sup ' + 'textarea u var #text #comment' if (type !== 'html4') { globalAttributes += ' contenteditable contextmenu draggable dropzone ' + 'hidden spellcheck translate' blockContent += ' article aside details dialog figure main header footer hgroup section nav' phrasingContent += ' audio canvas command datalist mark meter output picture ' + 'progress time wbr video ruby bdi keygen' } if (type !== 'html5-strict') { globalAttributes += ' xml:lang' html4PhrasingContent = 'acronym applet basefont big font strike tt' phrasingContent = [phrasingContent, html4PhrasingContent].join(' ') each$h(split$1(html4PhrasingContent), function (name) { add(name, '', phrasingContent) }) html4BlockContent = 'center dir isindex noframes' blockContent = [blockContent, html4BlockContent].join(' ') flowContent = [blockContent, phrasingContent].join(' ') each$h(split$1(html4BlockContent), function (name) { add(name, '', flowContent) }) } flowContent = flowContent || [blockContent, phrasingContent].join(' ') add('html', 'manifest', 'head body') add('head', '', 'base command link meta noscript script style title') add('title hr noscript br') add('base', 'href target') add('link', 'href rel media hreflang type sizes hreflang') add('meta', 'name http-equiv content charset') add('style', 'media type scoped') add('script', 'src async defer type charset') add( 'body', 'onafterprint onbeforeprint onbeforeunload onblur onerror onfocus ' + 'onhashchange onload onmessage onoffline ononline onpagehide onpageshow ' + 'onpopstate onresize onscroll onstorage onunload', flowContent ) add('address dt dd div caption', '', flowContent) add( 'h1 h2 h3 h4 h5 h6 pre p abbr code var samp kbd sub sup i b u bdo span legend em strong small s cite dfn', '', phrasingContent ) add('blockquote', 'cite', flowContent) add('ol', 'reversed start type', 'li') add('ul', '', 'li') add('li', 'value', flowContent) add('dl', '', 'dt dd') add('a', 'href target rel media hreflang type', phrasingContent) add('q', 'cite', phrasingContent) add('ins del', 'cite datetime', flowContent) add('img', 'src sizes srcset alt usemap ismap width height') add('iframe', 'src name width height', flowContent) add('embed', 'src type width height') add( 'object', 'data type typemustmatch name usemap form width height', [flowContent, 'param'].join(' ') ) add('param', 'name value') add('map', 'name', [flowContent, 'area'].join(' ')) add('area', 'alt coords shape href target rel media hreflang type') add( 'table', 'border', 'caption colgroup thead tfoot tbody tr' + (type === 'html4' ? ' col' : '') ) add('colgroup', 'span', 'col') add('col', 'span') add('tbody thead tfoot', '', 'tr') add('tr', '', 'td th') add('td', 'colspan rowspan headers', flowContent) add('th', 'colspan rowspan headers scope abbr', flowContent) add( 'form', 'accept-charset action autocomplete enctype method name novalidate target', flowContent ) add('fieldset', 'disabled form name', [flowContent, 'legend'].join(' ')) add('label', 'form for', phrasingContent) add( 'input', 'accept alt autocomplete checked dirname disabled form formaction formenctype formmethod formnovalidate ' + 'formtarget height list max maxlength min multiple name pattern readonly required size src step type value width' ) add( 'button', 'disabled form formaction formenctype formmethod formnovalidate formtarget name type value', type === 'html4' ? flowContent : phrasingContent ) add( 'select', 'disabled form multiple name required size', 'option optgroup' ) add('optgroup', 'disabled label', 'option') add('option', 'disabled label selected value') add( 'textarea', 'cols dirname disabled form maxlength name readonly required rows wrap' ) add('menu', 'type label', [flowContent, 'li'].join(' ')) add('noscript', '', flowContent) if (type !== 'html4') { add('wbr') add('ruby', '', [phrasingContent, 'rt rp'].join(' ')) add('figcaption', '', flowContent) add('mark rt rp summary bdi', '', phrasingContent) add('canvas', 'width height', flowContent) add( 'video', 'src crossorigin poster preload autoplay mediagroup loop ' + 'muted controls width height buffered', [flowContent, 'track source'].join(' ') ) add( 'audio', 'src crossorigin preload autoplay mediagroup loop muted controls ' + 'buffered volume', [flowContent, 'track source'].join(' ') ) add('picture', '', 'img source') add('source', 'src srcset type media sizes') add('track', 'kind src srclang label default') add('datalist', '', [phrasingContent, 'option'].join(' ')) add('article section nav aside main header footer', '', flowContent) add('hgroup', '', 'h1 h2 h3 h4 h5 h6') add('figure', '', [flowContent, 'figcaption'].join(' ')) add('time', 'datetime', phrasingContent) add('dialog', 'open', flowContent) add('command', 'type label icon disabled checked radiogroup command') add('output', 'for form name', phrasingContent) add('progress', 'value max', phrasingContent) add('meter', 'value min max low high optimum', phrasingContent) add('details', 'open', [flowContent, 'summary'].join(' ')) add('keygen', 'autofocus challenge disabled form keytype name') } if (type !== 'html5-strict') { addAttrs('script', 'language xml:space') addAttrs('style', 'xml:space') addAttrs( 'object', 'declare classid code codebase codetype archive standby align border hspace vspace' ) addAttrs('embed', 'align name hspace vspace') addAttrs('param', 'valuetype type') addAttrs('a', 'charset name rev shape coords') addAttrs('br', 'clear') addAttrs( 'applet', 'codebase archive code object alt name width height align hspace vspace' ) addAttrs('img', 'name longdesc align border hspace vspace') addAttrs( 'iframe', 'longdesc frameborder marginwidth marginheight scrolling align' ) addAttrs('font basefont', 'size color face') addAttrs('input', 'usemap align') addAttrs('select') addAttrs('textarea') addAttrs('h1 h2 h3 h4 h5 h6 div p legend caption', 'align') addAttrs('ul', 'type compact') addAttrs('li', 'type') addAttrs('ol dl menu dir', 'compact') addAttrs('pre', 'width xml:space') addAttrs('hr', 'align noshade size width') addAttrs('isindex', 'prompt') addAttrs( 'table', 'summary width frame rules cellspacing cellpadding align bgcolor' ) addAttrs('col', 'width align char charoff valign') addAttrs('colgroup', 'width align char charoff valign') addAttrs('thead', 'align char charoff valign') addAttrs('tr', 'align char charoff valign bgcolor') addAttrs( 'th', 'axis align char charoff valign nowrap bgcolor width height' ) addAttrs('form', 'accept') addAttrs( 'td', 'abbr axis scope align char charoff valign nowrap bgcolor width height' ) addAttrs('tfoot', 'align char charoff valign') addAttrs('tbody', 'align char charoff valign') addAttrs('area', 'nohref') addAttrs('body', 'background bgcolor text link vlink alink') } if (type !== 'html4') { addAttrs('input button select textarea', 'autofocus') addAttrs('input textarea', 'placeholder') addAttrs('a', 'download') addAttrs('link script img', 'crossorigin') addAttrs('img', 'loading') addAttrs('iframe', 'sandbox seamless allowfullscreen loading') } each$h(split$1('a form meter progress dfn'), function (name) { if (schema[name]) { delete schema[name].children[name] } }) delete schema.caption.children.table delete schema.script mapCache[type] = schema return schema } var compileElementMap = function (value, mode) { var styles if (value) { styles = {} if (typeof value === 'string') { value = { '*': value } } each$h(value, function (value, key) { styles[key] = styles[key.toUpperCase()] = mode === 'map' ? makeMap$2(value, /[, ]/) : explode$3(value, /[, ]/) }) } return styles } var Schema = function (settings) { var elements = {} var children = {} var patternElements = [] var customElementsMap = {}, specialElements = {} var createLookupTable = function (option, defaultValue, extendWith) { var value = settings[option] if (!value) { value = mapCache[option] if (!value) { value = makeMap$2( defaultValue, ' ', makeMap$2(defaultValue.toUpperCase(), ' ') ) value = extend$5(value, extendWith) mapCache[option] = value } } else { value = makeMap$2(value, /[, ]/, makeMap$2(value.toUpperCase(), /[, ]/)) } return value } settings = settings || {} var schemaItems = compileSchema(settings.schema) if (settings.verify_html === false) { settings.valid_elements = '*[*]' } var validStyles = compileElementMap(settings.valid_styles) var invalidStyles = compileElementMap(settings.invalid_styles, 'map') var validClasses = compileElementMap(settings.valid_classes, 'map') var whiteSpaceElementsMap = createLookupTable( 'whitespace_elements', 'pre script noscript style textarea video audio iframe object code' ) var selfClosingElementsMap = createLookupTable( 'self_closing_elements', 'colgroup dd dt li option p td tfoot th thead tr' ) var shortEndedElementsMap = createLookupTable( 'short_ended_elements', 'area base basefont br col frame hr img input isindex link ' + 'meta param embed source wbr track' ) var boolAttrMap = createLookupTable( 'boolean_attributes', 'checked compact declare defer disabled ismap multiple nohref noresize ' + 'noshade nowrap readonly selected autoplay loop controls' ) var nonEmptyOrMoveCaretBeforeOnEnter = 'td th iframe video audio object script code' var nonEmptyElementsMap = createLookupTable( 'non_empty_elements', nonEmptyOrMoveCaretBeforeOnEnter + ' pre', shortEndedElementsMap ) var moveCaretBeforeOnEnterElementsMap = createLookupTable( 'move_caret_before_on_enter_elements', nonEmptyOrMoveCaretBeforeOnEnter + ' table', shortEndedElementsMap ) var textBlockElementsMap = createLookupTable( 'text_block_elements', 'h1 h2 h3 h4 h5 h6 p div address pre form ' + 'blockquote center dir fieldset header footer article section hgroup aside main nav figure' ) var blockElementsMap = createLookupTable( 'block_elements', 'hr table tbody thead tfoot ' + 'th tr td li ol ul caption dl dt dd noscript menu isindex option ' + 'datalist select optgroup figcaption details summary', textBlockElementsMap ) var textInlineElementsMap = createLookupTable( 'text_inline_elements', 'span strong b em i font strike u var cite ' + 'dfn code mark q sup sub samp' ) each$h( ( settings.special || 'script noscript iframe noframes noembed title style textarea xmp' ).split(' '), function (name) { specialElements[name] = new RegExp(']*>', 'gi') } ) var patternToRegExp = function (str) { return new RegExp('^' + str.replace(/([?+*])/g, '.$1') + '$') } var addValidElements = function (validElements) { var ei, el, ai, al, matches, element, attr, attrData, elementName, attrName, attrType, attributes, attributesOrder, prefix, outputName, globalAttributes, globalAttributesOrder, value var elementRuleRegExp = /^([#+\-])?([^\[!\/]+)(?:\/([^\[!]+))?(?:(!?)\[([^\]]+)])?$/, attrRuleRegExp = /^([!\-])?(\w+[\\:]:\w+|[^=:<]+)?(?:([=:<])(.*))?$/, hasPatternsRegExp = /[*?+]/ if (validElements) { var validElementsArr = split$1(validElements, ',') if (elements['@']) { globalAttributes = elements['@'].attributes globalAttributesOrder = elements['@'].attributesOrder } for (ei = 0, el = validElementsArr.length; ei < el; ei++) { matches = elementRuleRegExp.exec(validElementsArr[ei]) if (matches) { prefix = matches[1] elementName = matches[2] outputName = matches[3] attrData = matches[5] attributes = {} attributesOrder = [] element = { attributes: attributes, attributesOrder: attributesOrder, } if (prefix === '#') { element.paddEmpty = true } if (prefix === '-') { element.removeEmpty = true } if (matches[4] === '!') { element.removeEmptyAttrs = true } if (globalAttributes) { each$j(globalAttributes, function (value, key) { attributes[key] = value }) attributesOrder.push.apply(attributesOrder, globalAttributesOrder) } if (attrData) { attrData = split$1(attrData, '|') for (ai = 0, al = attrData.length; ai < al; ai++) { matches = attrRuleRegExp.exec(attrData[ai]) if (matches) { attr = {} attrType = matches[1] attrName = matches[2].replace(/[\\:]:/g, ':') prefix = matches[3] value = matches[4] if (attrType === '!') { element.attributesRequired = element.attributesRequired || [] element.attributesRequired.push(attrName) attr.required = true } if (attrType === '-') { delete attributes[attrName] attributesOrder.splice( inArray$2(attributesOrder, attrName), 1 ) continue } if (prefix) { if (prefix === '=') { element.attributesDefault = element.attributesDefault || [] element.attributesDefault.push({ name: attrName, value: value, }) attr.defaultValue = value } if (prefix === ':') { element.attributesForced = element.attributesForced || [] element.attributesForced.push({ name: attrName, value: value, }) attr.forcedValue = value } if (prefix === '<') { attr.validValues = makeMap$2(value, '?') } } if (hasPatternsRegExp.test(attrName)) { element.attributePatterns = element.attributePatterns || [] attr.pattern = patternToRegExp(attrName) element.attributePatterns.push(attr) } else { if (!attributes[attrName]) { attributesOrder.push(attrName) } attributes[attrName] = attr } } } } if (!globalAttributes && elementName === '@') { globalAttributes = attributes globalAttributesOrder = attributesOrder } if (outputName) { element.outputName = elementName elements[outputName] = element } if (hasPatternsRegExp.test(elementName)) { element.pattern = patternToRegExp(elementName) patternElements.push(element) } else { elements[elementName] = element } } } } } var setValidElements = function (validElements) { elements = {} patternElements = [] addValidElements(validElements) each$h(schemaItems, function (element, name) { children[name] = element.children }) } var addCustomElements = function (customElements) { var customElementRegExp = /^(~)?(.+)$/ if (customElements) { mapCache.text_block_elements = mapCache.block_elements = null each$h(split$1(customElements, ','), function (rule) { var matches = customElementRegExp.exec(rule), inline = matches[1] === '~', cloneName = inline ? 'span' : 'div', name = matches[2] children[name] = children[cloneName] customElementsMap[name] = cloneName if (!inline) { blockElementsMap[name.toUpperCase()] = {} blockElementsMap[name] = {} } if (!elements[name]) { var customRule = elements[cloneName] customRule = extend$5({}, customRule) delete customRule.removeEmptyAttrs delete customRule.removeEmpty elements[name] = customRule } each$h(children, function (element, elmName) { if (element[cloneName]) { children[elmName] = element = extend$5({}, children[elmName]) element[name] = element[cloneName] } }) }) } } var addValidChildren = function (validChildren) { var childRuleRegExp = /^([+\-]?)([A-Za-z0-9_\-.\u00b7\u00c0-\u00d6\u00d8-\u00f6\u00f8-\u037d\u037f-\u1fff\u200c-\u200d\u203f-\u2040\u2070-\u218f\u2c00-\u2fef\u3001-\ud7ff\uf900-\ufdcf\ufdf0-\ufffd]+)\[([^\]]+)]$/ mapCache[settings.schema] = null if (validChildren) { each$h(split$1(validChildren, ','), function (rule) { var matches = childRuleRegExp.exec(rule) var parent, prefix if (matches) { prefix = matches[1] if (prefix) { parent = children[matches[2]] } else { parent = children[matches[2]] = { '#comment': {} } } parent = children[matches[2]] each$h(split$1(matches[3], '|'), function (child) { if (prefix === '-') { delete parent[child] } else { parent[child] = {} } }) } }) } } var getElementRule = function (name) { var element = elements[name], i if (element) { return element } i = patternElements.length while (i--) { element = patternElements[i] if (element.pattern.test(name)) { return element } } } if (!settings.valid_elements) { each$h(schemaItems, function (element, name) { elements[name] = { attributes: element.attributes, attributesOrder: element.attributesOrder, } children[name] = element.children }) if (settings.schema !== 'html5') { each$h(split$1('strong/b em/i'), function (item) { var items = split$1(item, '/') elements[items[1]].outputName = items[0] }) } each$h( split$1( 'ol ul sub sup blockquote span font a table tbody strong em b i' ), function (name) { if (elements[name]) { elements[name].removeEmpty = true } } ) each$h( split$1('p h1 h2 h3 h4 h5 h6 th td pre div address caption li'), function (name) { elements[name].paddEmpty = true } ) each$h(split$1('span'), function (name) { elements[name].removeEmptyAttrs = true }) } else { setValidElements(settings.valid_elements) } addCustomElements(settings.custom_elements) addValidChildren(settings.valid_children) addValidElements(settings.extended_valid_elements) addValidChildren('+ol[ul|ol],+ul[ul|ol]') each$h( { dd: 'dl', dt: 'dl', li: 'ul ol', td: 'tr', th: 'tr', tr: 'tbody thead tfoot', tbody: 'table', thead: 'table', tfoot: 'table', legend: 'fieldset', area: 'map', param: 'video audio object', }, function (parents, item) { if (elements[item]) { elements[item].parentsRequired = split$1(parents) } } ) if (settings.invalid_elements) { each$h(explode$3(settings.invalid_elements), function (item) { if (elements[item]) { delete elements[item] } }) } if (!getElementRule('span')) { addValidElements('span[!data-mce-type|*]') } var getValidStyles = constant(validStyles) var getInvalidStyles = constant(invalidStyles) var getValidClasses = constant(validClasses) var getBoolAttrs = constant(boolAttrMap) var getBlockElements = constant(blockElementsMap) var getTextBlockElements = constant(textBlockElementsMap) var getTextInlineElements = constant(textInlineElementsMap) var getShortEndedElements = constant(shortEndedElementsMap) var getSelfClosingElements = constant(selfClosingElementsMap) var getNonEmptyElements = constant(nonEmptyElementsMap) var getMoveCaretBeforeOnEnterElements = constant( moveCaretBeforeOnEnterElementsMap ) var getWhiteSpaceElements = constant(whiteSpaceElementsMap) var getSpecialElements = constant(specialElements) var isValidChild = function (name, child) { var parent = children[name.toLowerCase()] return !!(parent && parent[child.toLowerCase()]) } var isValid = function (name, attr) { var attrPatterns, i var rule = getElementRule(name) if (rule) { if (attr) { if (rule.attributes[attr]) { return true } attrPatterns = rule.attributePatterns if (attrPatterns) { i = attrPatterns.length while (i--) { if (attrPatterns[i].pattern.test(name)) { return true } } } } else { return true } } return false } var getCustomElements = constant(customElementsMap) return { children: children, elements: elements, getValidStyles: getValidStyles, getValidClasses: getValidClasses, getBlockElements: getBlockElements, getInvalidStyles: getInvalidStyles, getShortEndedElements: getShortEndedElements, getTextBlockElements: getTextBlockElements, getTextInlineElements: getTextInlineElements, getBoolAttrs: getBoolAttrs, getElementRule: getElementRule, getSelfClosingElements: getSelfClosingElements, getNonEmptyElements: getNonEmptyElements, getMoveCaretBeforeOnEnterElements: getMoveCaretBeforeOnEnterElements, getWhiteSpaceElements: getWhiteSpaceElements, getSpecialElements: getSpecialElements, isValidChild: isValidChild, isValid: isValid, getCustomElements: getCustomElements, addValidElements: addValidElements, setValidElements: setValidElements, addCustomElements: addCustomElements, addValidChildren: addValidChildren, } } var toHex = function (match, r, g, b) { var hex = function (val) { val = parseInt(val, 10).toString(16) return val.length > 1 ? val : '0' + val } return '#' + hex(r) + hex(g) + hex(b) } var Styles = function (settings, schema) { var _this = this var rgbRegExp = /rgb\s*\(\s*([0-9]+)\s*,\s*([0-9]+)\s*,\s*([0-9]+)\s*\)/gi var urlOrStrRegExp = /(?:url(?:(?:\(\s*\"([^\"]+)\"\s*\))|(?:\(\s*\'([^\']+)\'\s*\))|(?:\(\s*([^)\s]+)\s*\))))|(?:\'([^\']+)\')|(?:\"([^\"]+)\")/gi var styleRegExp = /\s*([^:]+):\s*([^;]+);?/g var trimRightRegExp = /\s+$/ var i var encodingLookup = {} var validStyles var invalidStyles var invisibleChar = zeroWidth settings = settings || {} if (schema) { validStyles = schema.getValidStyles() invalidStyles = schema.getInvalidStyles() } var encodingItems = ('\\" \\\' \\; \\: ; : ' + invisibleChar).split(' ') for (i = 0; i < encodingItems.length; i++) { encodingLookup[encodingItems[i]] = invisibleChar + i encodingLookup[invisibleChar + i] = encodingItems[i] } return { toHex: function (color) { return color.replace(rgbRegExp, toHex) }, parse: function (css) { var styles = {} var matches, name, value, isEncoded var urlConverter = settings.url_converter var urlConverterScope = settings.url_converter_scope || _this var compress = function (prefix, suffix, noJoin) { var top = styles[prefix + '-top' + suffix] if (!top) { return } var right = styles[prefix + '-right' + suffix] if (!right) { return } var bottom = styles[prefix + '-bottom' + suffix] if (!bottom) { return } var left = styles[prefix + '-left' + suffix] if (!left) { return } var box = [top, right, bottom, left] i = box.length - 1 while (i--) { if (box[i] !== box[i + 1]) { break } } if (i > -1 && noJoin) { return } styles[prefix + suffix] = i === -1 ? box[0] : box.join(' ') delete styles[prefix + '-top' + suffix] delete styles[prefix + '-right' + suffix] delete styles[prefix + '-bottom' + suffix] delete styles[prefix + '-left' + suffix] } var canCompress = function (key) { var value = styles[key], i if (!value) { return } value = value.split(' ') i = value.length while (i--) { if (value[i] !== value[0]) { return false } } styles[key] = value[0] return true } var compress2 = function (target, a, b, c) { if (!canCompress(a)) { return } if (!canCompress(b)) { return } if (!canCompress(c)) { return } styles[target] = styles[a] + ' ' + styles[b] + ' ' + styles[c] delete styles[a] delete styles[b] delete styles[c] } var encode = function (str) { isEncoded = true return encodingLookup[str] } var decode = function (str, keepSlashes) { if (isEncoded) { str = str.replace(/\uFEFF[0-9]/g, function (str) { return encodingLookup[str] }) } if (!keepSlashes) { str = str.replace(/\\([\'\";:])/g, '$1') } return str } var decodeSingleHexSequence = function (escSeq) { return String.fromCharCode(parseInt(escSeq.slice(1), 16)) } var decodeHexSequences = function (value) { return value.replace(/\\[0-9a-f]+/gi, decodeSingleHexSequence) } var processUrl = function (match, url, url2, url3, str, str2) { str = str || str2 if (str) { str = decode(str) return "'" + str.replace(/\'/g, "\\'") + "'" } url = decode(url || url2 || url3) if (!settings.allow_script_urls) { var scriptUrl = url.replace(/[\s\r\n]+/g, '') if (/(java|vb)script:/i.test(scriptUrl)) { return '' } if ( !settings.allow_svg_data_urls && /^data:image\/svg/i.test(scriptUrl) ) { return '' } } if (urlConverter) { url = urlConverter.call(urlConverterScope, url, 'style') } return "url('" + url.replace(/\'/g, "\\'") + "')" } if (css) { css = css.replace(/[\u0000-\u001F]/g, '') css = css .replace(/\\[\"\';:\uFEFF]/g, encode) .replace(/\"[^\"]+\"|\'[^\']+\'/g, function (str) { return str.replace(/[;:]/g, encode) }) while ((matches = styleRegExp.exec(css))) { styleRegExp.lastIndex = matches.index + matches[0].length name = matches[1].replace(trimRightRegExp, '').toLowerCase() value = matches[2].replace(trimRightRegExp, '') if (name && value) { name = decodeHexSequences(name) value = decodeHexSequences(value) if ( name.indexOf(invisibleChar) !== -1 || name.indexOf('"') !== -1 ) { continue } if ( !settings.allow_script_urls && (name === 'behavior' || /expression\s*\(|\/\*|\*\//.test(value)) ) { continue } if (name === 'font-weight' && value === '700') { value = 'bold' } else if (name === 'color' || name === 'background-color') { value = value.toLowerCase() } value = value.replace(rgbRegExp, toHex) value = value.replace(urlOrStrRegExp, processUrl) styles[name] = isEncoded ? decode(value, true) : value } } compress('border', '', true) compress('border', '-width') compress('border', '-color') compress('border', '-style') compress('padding', '') compress('margin', '') compress2('border', 'border-width', 'border-style', 'border-color') if (styles.border === 'medium none') { delete styles.border } if (styles['border-image'] === 'none') { delete styles['border-image'] } } return styles }, serialize: function (styles, elementName) { var css = '' var serializeStyles = function (name) { var value var styleList = validStyles[name] if (styleList) { for (var i_1 = 0, l = styleList.length; i_1 < l; i_1++) { name = styleList[i_1] value = styles[name] if (value) { css += (css.length > 0 ? ' ' : '') + name + ': ' + value + ';' } } } } var isValid = function (name, elementName) { var styleMap = invalidStyles['*'] if (styleMap && styleMap[name]) { return false } styleMap = invalidStyles[elementName] return !(styleMap && styleMap[name]) } if (elementName && validStyles) { serializeStyles('*') serializeStyles(elementName) } else { each$j(styles, function (value, name) { if (value && (!invalidStyles || isValid(name, elementName))) { css += (css.length > 0 ? ' ' : '') + name + ': ' + value + ';' } }) } return css }, } } var deprecated = { keyLocation: true, layerX: true, layerY: true, returnValue: true, webkitMovementX: true, webkitMovementY: true, keyIdentifier: true, mozPressure: true, } var isNativeEvent = function (event) { return event instanceof Event || isFunction(event.initEvent) } var hasIsDefaultPrevented = function (event) { return ( event.isDefaultPrevented === always || event.isDefaultPrevented === never ) } var needsNormalizing = function (event) { return isNullable(event.preventDefault) || isNativeEvent(event) } var clone$2 = function (originalEvent, data) { var event = data !== null && data !== void 0 ? data : {} for (var name_1 in originalEvent) { if (!has$2(deprecated, name_1)) { event[name_1] = originalEvent[name_1] } } if (isNonNullable(event.composedPath)) { event.composedPath = function () { return originalEvent.composedPath() } } return event } var normalize$3 = function (type, originalEvent, fallbackTarget, data) { var _a var event = clone$2(originalEvent, data) event.type = type if (isNullable(event.target)) { event.target = (_a = event.srcElement) !== null && _a !== void 0 ? _a : fallbackTarget } if (needsNormalizing(originalEvent)) { event.preventDefault = function () { event.defaultPrevented = true event.isDefaultPrevented = always if (isFunction(originalEvent.preventDefault)) { originalEvent.preventDefault() } else if (isNativeEvent(originalEvent)) { originalEvent.returnValue = false } } event.stopPropagation = function () { event.cancelBubble = true event.isPropagationStopped = always if (isFunction(originalEvent.stopPropagation)) { originalEvent.stopPropagation() } else if (isNativeEvent(originalEvent)) { originalEvent.cancelBubble = true } } event.stopImmediatePropagation = function () { event.isImmediatePropagationStopped = always event.stopPropagation() } if (!hasIsDefaultPrevented(event)) { event.isDefaultPrevented = event.defaultPrevented === true ? always : never event.isPropagationStopped = event.cancelBubble === true ? always : never event.isImmediatePropagationStopped = never } } return event } var eventExpandoPrefix = 'mce-data-' var mouseEventRe = /^(?:mouse|contextmenu)|click/ var addEvent = function (target, name, callback, capture) { if (target.addEventListener) { target.addEventListener(name, callback, capture || false) } else if (target.attachEvent) { target.attachEvent('on' + name, callback) } } var removeEvent = function (target, name, callback, capture) { if (target.removeEventListener) { target.removeEventListener(name, callback, capture || false) } else if (target.detachEvent) { target.detachEvent('on' + name, callback) } } var isMouseEvent = function (event) { return isNonNullable(event) && mouseEventRe.test(event.type) } var fix = function (originalEvent, data) { var event = normalize$3(originalEvent.type, originalEvent, document, data) if ( isMouseEvent(originalEvent) && isUndefined(originalEvent.pageX) && !isUndefined(originalEvent.clientX) ) { var eventDoc = event.target.ownerDocument || document var doc = eventDoc.documentElement var body = eventDoc.body var mouseEvent = event mouseEvent.pageX = originalEvent.clientX + ((doc && doc.scrollLeft) || (body && body.scrollLeft) || 0) - ((doc && doc.clientLeft) || (body && body.clientLeft) || 0) mouseEvent.pageY = originalEvent.clientY + ((doc && doc.scrollTop) || (body && body.scrollTop) || 0) - ((doc && doc.clientTop) || (body && body.clientTop) || 0) } if (isUndefined(event.metaKey)) { event.metaKey = false } return event } var bindOnReady = function (win, callback, eventUtils) { var doc = win.document, event = { type: 'ready' } if (eventUtils.domLoaded) { callback(event) return } var isDocReady = function () { return ( doc.readyState === 'complete' || (doc.readyState === 'interactive' && doc.body) ) } var readyHandler = function () { removeEvent(win, 'DOMContentLoaded', readyHandler) removeEvent(win, 'load', readyHandler) if (!eventUtils.domLoaded) { eventUtils.domLoaded = true callback(event) } win = null } if (isDocReady()) { readyHandler() } else { addEvent(win, 'DOMContentLoaded', readyHandler) } if (!eventUtils.domLoaded) { addEvent(win, 'load', readyHandler) } } var EventUtils = (function () { function EventUtils() { this.domLoaded = false this.events = {} this.count = 1 this.expando = eventExpandoPrefix + (+new Date()).toString(32) this.hasMouseEnterLeave = 'onmouseenter' in document.documentElement this.hasFocusIn = 'onfocusin' in document.documentElement this.count = 1 } EventUtils.prototype.bind = function (target, names, callback, scope) { var self = this var id, callbackList, i, name, fakeName, nativeHandler, capture var win = window var defaultNativeHandler = function (evt) { self.executeHandlers(fix(evt || win.event), id) } if (!target || target.nodeType === 3 || target.nodeType === 8) { return } if (!target[self.expando]) { id = self.count++ target[self.expando] = id self.events[id] = {} } else { id = target[self.expando] } scope = scope || target var namesList = names.split(' ') i = namesList.length while (i--) { name = namesList[i] nativeHandler = defaultNativeHandler fakeName = capture = false if (name === 'DOMContentLoaded') { name = 'ready' } if ( self.domLoaded && name === 'ready' && target.readyState === 'complete' ) { callback.call(scope, fix({ type: name })) continue } if (!self.hasMouseEnterLeave) { fakeName = self.mouseEnterLeave[name] if (fakeName) { nativeHandler = function (evt) { var current = evt.currentTarget var related = evt.relatedTarget if (related && current.contains) { related = current.contains(related) } else { while (related && related !== current) { related = related.parentNode } } if (!related) { evt = fix(evt || win.event) evt.type = evt.type === 'mouseout' ? 'mouseleave' : 'mouseenter' evt.target = current self.executeHandlers(evt, id) } } } } if (!self.hasFocusIn && (name === 'focusin' || name === 'focusout')) { capture = true fakeName = name === 'focusin' ? 'focus' : 'blur' nativeHandler = function (evt) { evt = fix(evt || win.event) evt.type = evt.type === 'focus' ? 'focusin' : 'focusout' self.executeHandlers(evt, id) } } callbackList = self.events[id][name] if (!callbackList) { self.events[id][name] = callbackList = [ { func: callback, scope: scope, }, ] callbackList.fakeName = fakeName callbackList.capture = capture callbackList.nativeHandler = nativeHandler if (name === 'ready') { bindOnReady(target, nativeHandler, self) } else { addEvent(target, fakeName || name, nativeHandler, capture) } } else { if (name === 'ready' && self.domLoaded) { callback(fix({ type: name })) } else { callbackList.push({ func: callback, scope: scope, }) } } } target = callbackList = null return callback } EventUtils.prototype.unbind = function (target, names, callback) { var callbackList, i, ci, name, eventMap if (!target || target.nodeType === 3 || target.nodeType === 8) { return this } var id = target[this.expando] if (id) { eventMap = this.events[id] if (names) { var namesList = names.split(' ') i = namesList.length while (i--) { name = namesList[i] callbackList = eventMap[name] if (callbackList) { if (callback) { ci = callbackList.length while (ci--) { if (callbackList[ci].func === callback) { var nativeHandler = callbackList.nativeHandler var fakeName = callbackList.fakeName, capture = callbackList.capture callbackList = callbackList .slice(0, ci) .concat(callbackList.slice(ci + 1)) callbackList.nativeHandler = nativeHandler callbackList.fakeName = fakeName callbackList.capture = capture eventMap[name] = callbackList } } } if (!callback || callbackList.length === 0) { delete eventMap[name] removeEvent( target, callbackList.fakeName || name, callbackList.nativeHandler, callbackList.capture ) } } } } else { each$j(eventMap, function (callbackList, name) { removeEvent( target, callbackList.fakeName || name, callbackList.nativeHandler, callbackList.capture ) }) eventMap = {} } for (name in eventMap) { if (has$2(eventMap, name)) { return this } } delete this.events[id] try { delete target[this.expando] } catch (ex) { target[this.expando] = null } } return this } EventUtils.prototype.fire = function (target, name, args) { var id if (!target || target.nodeType === 3 || target.nodeType === 8) { return this } var event = fix( { type: name, target: target, }, args ) do { id = target[this.expando] if (id) { this.executeHandlers(event, id) } target = target.parentNode || target.ownerDocument || target.defaultView || target.parentWindow } while (target && !event.isPropagationStopped()) return this } EventUtils.prototype.clean = function (target) { var i, children if (!target || target.nodeType === 3 || target.nodeType === 8) { return this } if (target[this.expando]) { this.unbind(target) } if (!target.getElementsByTagName) { target = target.document } if (target && target.getElementsByTagName) { this.unbind(target) children = target.getElementsByTagName('*') i = children.length while (i--) { target = children[i] if (target[this.expando]) { this.unbind(target) } } } return this } EventUtils.prototype.destroy = function () { this.events = {} } EventUtils.prototype.cancel = function (e) { if (e) { e.preventDefault() e.stopImmediatePropagation() } return false } EventUtils.prototype.executeHandlers = function (evt, id) { var container = this.events[id] var callbackList = container && container[evt.type] if (callbackList) { for (var i = 0, l = callbackList.length; i < l; i++) { var callback = callbackList[i] if (callback && callback.func.call(callback.scope, evt) === false) { evt.preventDefault() } if (evt.isImmediatePropagationStopped()) { return } } } } EventUtils.Event = new EventUtils() return EventUtils })() var support, Expr, getText, isXML, tokenize, compile, select$1, outermostContext, sortInput, hasDuplicate, setDocument, document$1, docElem, documentIsHTML, rbuggyQSA, rbuggyMatches, matches, contains, expando = 'sizzle' + -new Date(), preferredDoc = window.document, dirruns = 0, done = 0, classCache = createCache(), tokenCache = createCache(), compilerCache = createCache(), sortOrder = function (a, b) { if (a === b) { hasDuplicate = true } return 0 }, strundefined = typeof undefined, MAX_NEGATIVE = 1 << 31, hasOwn = {}.hasOwnProperty, arr = [], pop = arr.pop, push_native = arr.push, push$1 = arr.push, slice$1 = arr.slice, indexOf = arr.indexOf || function (elem) { var i = 0, len = this.length for (; i < len; i++) { if (this[i] === elem) { return i } } return -1 }, booleans = 'checked|selected|async|autofocus|autoplay|controls|defer|disabled|hidden|ismap|loop|multiple|open|readonly|required|scoped', whitespace = '[\\x20\\t\\r\\n\\f]', identifier = '(?:\\\\.|[\\w-]|[^\\x00-\\xa0])+', attributes = '\\[' + whitespace + '*(' + identifier + ')(?:' + whitespace + '*([*^$|!~]?=)' + whitespace + '*(?:\'((?:\\\\.|[^\\\\\'])*)\'|"((?:\\\\.|[^\\\\"])*)"|(' + identifier + '))|)' + whitespace + '*\\]', pseudos = ':(' + identifier + ')(?:\\((' + '(\'((?:\\\\.|[^\\\\\'])*)\'|"((?:\\\\.|[^\\\\"])*)")|' + '((?:\\\\.|[^\\\\()[\\]]|' + attributes + ')*)|' + '.*' + ')\\)|)', rtrim = new RegExp( '^' + whitespace + '+|((?:^|[^\\\\])(?:\\\\.)*)' + whitespace + '+$', 'g' ), rcomma = new RegExp('^' + whitespace + '*,' + whitespace + '*'), rcombinators = new RegExp( '^' + whitespace + '*([>+~]|' + whitespace + ')' + whitespace + '*' ), rattributeQuotes = new RegExp( '=' + whitespace + '*([^\\]\'"]*?)' + whitespace + '*\\]', 'g' ), rpseudo = new RegExp(pseudos), ridentifier = new RegExp('^' + identifier + '$'), matchExpr = { ID: new RegExp('^#(' + identifier + ')'), CLASS: new RegExp('^\\.(' + identifier + ')'), TAG: new RegExp('^(' + identifier + '|[*])'), ATTR: new RegExp('^' + attributes), PSEUDO: new RegExp('^' + pseudos), CHILD: new RegExp( '^:(only|first|last|nth|nth-last)-(child|of-type)(?:\\(' + whitespace + '*(even|odd|(([+-]|)(\\d*)n|)' + whitespace + '*(?:([+-]|)' + whitespace + '*(\\d+)|))' + whitespace + '*\\)|)', 'i' ), bool: new RegExp('^(?:' + booleans + ')$', 'i'), needsContext: new RegExp( '^' + whitespace + '*[>+~]|:(even|odd|eq|gt|lt|nth|first|last)(?:\\(' + whitespace + '*((?:-\\d)?\\d*)' + whitespace + '*\\)|)(?=[^-]|$)', 'i' ), }, rinputs = /^(?:input|select|textarea|button)$/i, rheader = /^h\d$/i, rnative = /^[^{]+\{\s*\[native \w/, rquickExpr$1 = /^(?:#([\w-]+)|(\w+)|\.([\w-]+))$/, rsibling = /[+~]/, rescape = /'|\\/g, runescape = new RegExp( '\\\\([\\da-f]{1,6}' + whitespace + '?|(' + whitespace + ')|.)', 'ig' ), funescape = function (_, escaped, escapedWhitespace) { var high = '0x' + escaped - 65536 return high !== high || escapedWhitespace ? escaped : high < 0 ? String.fromCharCode(high + 65536) : String.fromCharCode((high >> 10) | 55296, (high & 1023) | 56320) } try { push$1.apply( (arr = slice$1.call(preferredDoc.childNodes)), preferredDoc.childNodes ) arr[preferredDoc.childNodes.length].nodeType } catch (e) { push$1 = { apply: arr.length ? function (target, els) { push_native.apply(target, slice$1.call(els)) } : function (target, els) { var j = target.length, i = 0 while ((target[j++] = els[i++])) {} target.length = j - 1 }, } } var Sizzle = function (selector, context, results, seed) { var match, elem, m, nodeType, i, groups, old, nid, newContext, newSelector if ( (context ? context.ownerDocument || context : preferredDoc) !== document$1 ) { setDocument(context) } context = context || document$1 results = results || [] if (!selector || typeof selector !== 'string') { return results } if ((nodeType = context.nodeType) !== 1 && nodeType !== 9) { return [] } if (documentIsHTML && !seed) { if ((match = rquickExpr$1.exec(selector))) { if ((m = match[1])) { if (nodeType === 9) { elem = context.getElementById(m) if (elem && elem.parentNode) { if (elem.id === m) { results.push(elem) return results } } else { return results } } else { if ( context.ownerDocument && (elem = context.ownerDocument.getElementById(m)) && contains(context, elem) && elem.id === m ) { results.push(elem) return results } } } else if (match[2]) { push$1.apply(results, context.getElementsByTagName(selector)) return results } else if ((m = match[3]) && support.getElementsByClassName) { push$1.apply(results, context.getElementsByClassName(m)) return results } } if (support.qsa && (!rbuggyQSA || !rbuggyQSA.test(selector))) { nid = old = expando newContext = context newSelector = nodeType === 9 && selector if (nodeType === 1 && context.nodeName.toLowerCase() !== 'object') { groups = tokenize(selector) if ((old = context.getAttribute('id'))) { nid = old.replace(rescape, '\\$&') } else { context.setAttribute('id', nid) } nid = "[id='" + nid + "'] " i = groups.length while (i--) { groups[i] = nid + toSelector(groups[i]) } newContext = (rsibling.test(selector) && testContext(context.parentNode)) || context newSelector = groups.join(',') } if (newSelector) { try { push$1.apply(results, newContext.querySelectorAll(newSelector)) return results } catch (qsaError) { } finally { if (!old) { context.removeAttribute('id') } } } } } return select$1(selector.replace(rtrim, '$1'), context, results, seed) } function createCache() { var keys = [] function cache(key, value) { if (keys.push(key + ' ') > Expr.cacheLength) { delete cache[keys.shift()] } return (cache[key + ' '] = value) } return cache } function markFunction(fn) { fn[expando] = true return fn } function siblingCheck(a, b) { var cur = b && a, diff = cur && a.nodeType === 1 && b.nodeType === 1 && (~b.sourceIndex || MAX_NEGATIVE) - (~a.sourceIndex || MAX_NEGATIVE) if (diff) { return diff } if (cur) { while ((cur = cur.nextSibling)) { if (cur === b) { return -1 } } } return a ? 1 : -1 } function createInputPseudo(type) { return function (elem) { var name = elem.nodeName.toLowerCase() return name === 'input' && elem.type === type } } function createButtonPseudo(type) { return function (elem) { var name = elem.nodeName.toLowerCase() return (name === 'input' || name === 'button') && elem.type === type } } function createPositionalPseudo(fn) { return markFunction(function (argument) { argument = +argument return markFunction(function (seed, matches) { var j, matchIndexes = fn([], seed.length, argument), i = matchIndexes.length while (i--) { if (seed[(j = matchIndexes[i])]) { seed[j] = !(matches[j] = seed[j]) } } }) }) } function testContext(context) { return ( context && typeof context.getElementsByTagName !== strundefined && context ) } support = Sizzle.support = {} isXML = Sizzle.isXML = function (elem) { var documentElement = elem && (elem.ownerDocument || elem).documentElement return documentElement ? documentElement.nodeName !== 'HTML' : false } setDocument = Sizzle.setDocument = function (node) { var hasCompare, doc = node ? node.ownerDocument || node : preferredDoc, parent = doc.defaultView function getTop(win) { try { return win.top } catch (ex) {} return null } if (doc === document$1 || doc.nodeType !== 9 || !doc.documentElement) { return document$1 } document$1 = doc docElem = doc.documentElement documentIsHTML = !isXML(doc) if (parent && parent !== getTop(parent)) { if (parent.addEventListener) { parent.addEventListener( 'unload', function () { setDocument() }, false ) } else if (parent.attachEvent) { parent.attachEvent('onunload', function () { setDocument() }) } } support.attributes = true support.getElementsByTagName = true support.getElementsByClassName = rnative.test(doc.getElementsByClassName) support.getById = true Expr.find.ID = function (id, context) { if (typeof context.getElementById !== strundefined && documentIsHTML) { var m = context.getElementById(id) return m && m.parentNode ? [m] : [] } } Expr.filter.ID = function (id) { var attrId = id.replace(runescape, funescape) return function (elem) { return elem.getAttribute('id') === attrId } } Expr.find.TAG = support.getElementsByTagName ? function (tag, context) { if (typeof context.getElementsByTagName !== strundefined) { return context.getElementsByTagName(tag) } } : function (tag, context) { var elem, tmp = [], i = 0, results = context.getElementsByTagName(tag) if (tag === '*') { while ((elem = results[i++])) { if (elem.nodeType === 1) { tmp.push(elem) } } return tmp } return results } Expr.find.CLASS = support.getElementsByClassName && function (className, context) { if (documentIsHTML) { return context.getElementsByClassName(className) } } rbuggyMatches = [] rbuggyQSA = [] support.disconnectedMatch = true rbuggyQSA = rbuggyQSA.length && new RegExp(rbuggyQSA.join('|')) rbuggyMatches = rbuggyMatches.length && new RegExp(rbuggyMatches.join('|')) hasCompare = rnative.test(docElem.compareDocumentPosition) contains = hasCompare || rnative.test(docElem.contains) ? function (a, b) { var adown = a.nodeType === 9 ? a.documentElement : a, bup = b && b.parentNode return ( a === bup || !!( bup && bup.nodeType === 1 && (adown.contains ? adown.contains(bup) : a.compareDocumentPosition && a.compareDocumentPosition(bup) & 16) ) ) } : function (a, b) { if (b) { while ((b = b.parentNode)) { if (b === a) { return true } } } return false } sortOrder = hasCompare ? function (a, b) { if (a === b) { hasDuplicate = true return 0 } var compare = !a.compareDocumentPosition - !b.compareDocumentPosition if (compare) { return compare } compare = (a.ownerDocument || a) === (b.ownerDocument || b) ? a.compareDocumentPosition(b) : 1 if ( compare & 1 || (!support.sortDetached && b.compareDocumentPosition(a) === compare) ) { if ( a === doc || (a.ownerDocument === preferredDoc && contains(preferredDoc, a)) ) { return -1 } if ( b === doc || (b.ownerDocument === preferredDoc && contains(preferredDoc, b)) ) { return 1 } return sortInput ? indexOf.call(sortInput, a) - indexOf.call(sortInput, b) : 0 } return compare & 4 ? -1 : 1 } : function (a, b) { if (a === b) { hasDuplicate = true return 0 } var cur, i = 0, aup = a.parentNode, bup = b.parentNode, ap = [a], bp = [b] if (!aup || !bup) { return a === doc ? -1 : b === doc ? 1 : aup ? -1 : bup ? 1 : sortInput ? indexOf.call(sortInput, a) - indexOf.call(sortInput, b) : 0 } else if (aup === bup) { return siblingCheck(a, b) } cur = a while ((cur = cur.parentNode)) { ap.unshift(cur) } cur = b while ((cur = cur.parentNode)) { bp.unshift(cur) } while (ap[i] === bp[i]) { i++ } return i ? siblingCheck(ap[i], bp[i]) : ap[i] === preferredDoc ? -1 : bp[i] === preferredDoc ? 1 : 0 } return doc } Sizzle.matches = function (expr, elements) { return Sizzle(expr, null, null, elements) } Sizzle.matchesSelector = function (elem, expr) { if ((elem.ownerDocument || elem) !== document$1) { setDocument(elem) } expr = expr.replace(rattributeQuotes, "='$1']") if ( support.matchesSelector && documentIsHTML && (!rbuggyMatches || !rbuggyMatches.test(expr)) && (!rbuggyQSA || !rbuggyQSA.test(expr)) ) { try { var ret = matches.call(elem, expr) if ( ret || support.disconnectedMatch || (elem.document && elem.document.nodeType !== 11) ) { return ret } } catch (e) {} } return Sizzle(expr, document$1, null, [elem]).length > 0 } Sizzle.contains = function (context, elem) { if ((context.ownerDocument || context) !== document$1) { setDocument(context) } return contains(context, elem) } Sizzle.attr = function (elem, name) { if ((elem.ownerDocument || elem) !== document$1) { setDocument(elem) } var fn = Expr.attrHandle[name.toLowerCase()], val = fn && hasOwn.call(Expr.attrHandle, name.toLowerCase()) ? fn(elem, name, !documentIsHTML) : undefined return val !== undefined ? val : support.attributes || !documentIsHTML ? elem.getAttribute(name) : (val = elem.getAttributeNode(name)) && val.specified ? val.value : null } Sizzle.error = function (msg) { throw new Error('Syntax error, unrecognized expression: ' + msg) } Sizzle.uniqueSort = function (results) { var elem, duplicates = [], j = 0, i = 0 hasDuplicate = !support.detectDuplicates sortInput = !support.sortStable && results.slice(0) results.sort(sortOrder) if (hasDuplicate) { while ((elem = results[i++])) { if (elem === results[i]) { j = duplicates.push(i) } } while (j--) { results.splice(duplicates[j], 1) } } sortInput = null return results } getText = Sizzle.getText = function (elem) { var node, ret = '', i = 0, nodeType = elem.nodeType if (!nodeType) { while ((node = elem[i++])) { ret += getText(node) } } else if (nodeType === 1 || nodeType === 9 || nodeType === 11) { if (typeof elem.textContent === 'string') { return elem.textContent } else { for (elem = elem.firstChild; elem; elem = elem.nextSibling) { ret += getText(elem) } } } else if (nodeType === 3 || nodeType === 4) { return elem.nodeValue } return ret } Expr = Sizzle.selectors = { cacheLength: 50, createPseudo: markFunction, match: matchExpr, attrHandle: {}, find: {}, relative: { '>': { dir: 'parentNode', first: true, }, ' ': { dir: 'parentNode' }, '+': { dir: 'previousSibling', first: true, }, '~': { dir: 'previousSibling' }, }, preFilter: { ATTR: function (match) { match[1] = match[1].replace(runescape, funescape) match[3] = (match[3] || match[4] || match[5] || '').replace( runescape, funescape ) if (match[2] === '~=') { match[3] = ' ' + match[3] + ' ' } return match.slice(0, 4) }, CHILD: function (match) { match[1] = match[1].toLowerCase() if (match[1].slice(0, 3) === 'nth') { if (!match[3]) { Sizzle.error(match[0]) } match[4] = +(match[4] ? match[5] + (match[6] || 1) : 2 * (match[3] === 'even' || match[3] === 'odd')) match[5] = +(match[7] + match[8] || match[3] === 'odd') } else if (match[3]) { Sizzle.error(match[0]) } return match }, PSEUDO: function (match) { var excess, unquoted = !match[6] && match[2] if (matchExpr.CHILD.test(match[0])) { return null } if (match[3]) { match[2] = match[4] || match[5] || '' } else if ( unquoted && rpseudo.test(unquoted) && (excess = tokenize(unquoted, true)) && (excess = unquoted.indexOf(')', unquoted.length - excess) - unquoted.length) ) { match[0] = match[0].slice(0, excess) match[2] = unquoted.slice(0, excess) } return match.slice(0, 3) }, }, filter: { TAG: function (nodeNameSelector) { var nodeName = nodeNameSelector .replace(runescape, funescape) .toLowerCase() return nodeNameSelector === '*' ? function () { return true } : function (elem) { return elem.nodeName && elem.nodeName.toLowerCase() === nodeName } }, CLASS: function (className) { var pattern = classCache[className + ' '] return ( pattern || ((pattern = new RegExp( '(^|' + whitespace + ')' + className + '(' + whitespace + '|$)' )) && classCache(className, function (elem) { return pattern.test( (typeof elem.className === 'string' && elem.className) || (typeof elem.getAttribute !== strundefined && elem.getAttribute('class')) || '' ) })) ) }, ATTR: function (name, operator, check) { return function (elem) { var result = Sizzle.attr(elem, name) if (result == null) { return operator === '!=' } if (!operator) { return true } result += '' return operator === '=' ? result === check : operator === '!=' ? result !== check : operator === '^=' ? check && result.indexOf(check) === 0 : operator === '*=' ? check && result.indexOf(check) > -1 : operator === '$=' ? check && result.slice(-check.length) === check : operator === '~=' ? (' ' + result + ' ').indexOf(check) > -1 : operator === '|=' ? result === check || result.slice(0, check.length + 1) === check + '-' : false } }, CHILD: function (type, what, argument, first, last) { var simple = type.slice(0, 3) !== 'nth', forward = type.slice(-4) !== 'last', ofType = what === 'of-type' return first === 1 && last === 0 ? function (elem) { return !!elem.parentNode } : function (elem, context, xml) { var cache, outerCache, node, diff, nodeIndex, start, dir = simple !== forward ? 'nextSibling' : 'previousSibling', parent = elem.parentNode, name = ofType && elem.nodeName.toLowerCase(), useCache = !xml && !ofType if (parent) { if (simple) { while (dir) { node = elem while ((node = node[dir])) { if ( ofType ? node.nodeName.toLowerCase() === name : node.nodeType === 1 ) { return false } } start = dir = type === 'only' && !start && 'nextSibling' } return true } start = [forward ? parent.firstChild : parent.lastChild] if (forward && useCache) { outerCache = parent[expando] || (parent[expando] = {}) cache = outerCache[type] || [] nodeIndex = cache[0] === dirruns && cache[1] diff = cache[0] === dirruns && cache[2] node = nodeIndex && parent.childNodes[nodeIndex] while ( (node = (++nodeIndex && node && node[dir]) || (diff = nodeIndex = 0) || start.pop()) ) { if (node.nodeType === 1 && ++diff && node === elem) { outerCache[type] = [dirruns, nodeIndex, diff] break } } } else if ( useCache && (cache = (elem[expando] || (elem[expando] = {}))[type]) && cache[0] === dirruns ) { diff = cache[1] } else { while ( (node = (++nodeIndex && node && node[dir]) || (diff = nodeIndex = 0) || start.pop()) ) { if ( (ofType ? node.nodeName.toLowerCase() === name : node.nodeType === 1) && ++diff ) { if (useCache) { ;(node[expando] || (node[expando] = {}))[type] = [ dirruns, diff, ] } if (node === elem) { break } } } } diff -= last return ( diff === first || (diff % first === 0 && diff / first >= 0) ) } } }, PSEUDO: function (pseudo, argument) { var args, fn = Expr.pseudos[pseudo] || Expr.setFilters[pseudo.toLowerCase()] || Sizzle.error('unsupported pseudo: ' + pseudo) if (fn[expando]) { return fn(argument) } if (fn.length > 1) { args = [pseudo, pseudo, '', argument] return Expr.setFilters.hasOwnProperty(pseudo.toLowerCase()) ? markFunction(function (seed, matches) { var idx, matched = fn(seed, argument), i = matched.length while (i--) { idx = indexOf.call(seed, matched[i]) seed[idx] = !(matches[idx] = matched[i]) } }) : function (elem) { return fn(elem, 0, args) } } return fn }, }, pseudos: { not: markFunction(function (selector) { var input = [], results = [], matcher = compile(selector.replace(rtrim, '$1')) return matcher[expando] ? markFunction(function (seed, matches, context, xml) { var elem, unmatched = matcher(seed, null, xml, []), i = seed.length while (i--) { if ((elem = unmatched[i])) { seed[i] = !(matches[i] = elem) } } }) : function (elem, context, xml) { input[0] = elem matcher(input, null, xml, results) input[0] = null return !results.pop() } }), has: markFunction(function (selector) { return function (elem) { return Sizzle(selector, elem).length > 0 } }), contains: markFunction(function (text) { text = text.replace(runescape, funescape) return function (elem) { return ( (elem.textContent || elem.innerText || getText(elem)).indexOf( text ) > -1 ) } }), lang: markFunction(function (lang) { if (!ridentifier.test(lang || '')) { Sizzle.error('unsupported lang: ' + lang) } lang = lang.replace(runescape, funescape).toLowerCase() return function (elem) { var elemLang do { if ( (elemLang = documentIsHTML ? elem.lang : elem.getAttribute('xml:lang') || elem.getAttribute('lang')) ) { elemLang = elemLang.toLowerCase() return elemLang === lang || elemLang.indexOf(lang + '-') === 0 } } while ((elem = elem.parentNode) && elem.nodeType === 1) return false } }), target: function (elem) { var hash = window.location && window.location.hash return hash && hash.slice(1) === elem.id }, root: function (elem) { return elem === docElem }, focus: function (elem) { return ( elem === document$1.activeElement && (!document$1.hasFocus || document$1.hasFocus()) && !!(elem.type || elem.href || ~elem.tabIndex) ) }, enabled: function (elem) { return elem.disabled === false }, disabled: function (elem) { return elem.disabled === true }, checked: function (elem) { var nodeName = elem.nodeName.toLowerCase() return ( (nodeName === 'input' && !!elem.checked) || (nodeName === 'option' && !!elem.selected) ) }, selected: function (elem) { if (elem.parentNode) { elem.parentNode.selectedIndex } return elem.selected === true }, empty: function (elem) { for (elem = elem.firstChild; elem; elem = elem.nextSibling) { if (elem.nodeType < 6) { return false } } return true }, parent: function (elem) { return !Expr.pseudos.empty(elem) }, header: function (elem) { return rheader.test(elem.nodeName) }, input: function (elem) { return rinputs.test(elem.nodeName) }, button: function (elem) { var name = elem.nodeName.toLowerCase() return (name === 'input' && elem.type === 'button') || name === 'button' }, text: function (elem) { var attr return ( elem.nodeName.toLowerCase() === 'input' && elem.type === 'text' && ((attr = elem.getAttribute('type')) == null || attr.toLowerCase() === 'text') ) }, first: createPositionalPseudo(function () { return [0] }), last: createPositionalPseudo(function (matchIndexes, length) { return [length - 1] }), eq: createPositionalPseudo(function (matchIndexes, length, argument) { return [argument < 0 ? argument + length : argument] }), even: createPositionalPseudo(function (matchIndexes, length) { var i = 0 for (; i < length; i += 2) { matchIndexes.push(i) } return matchIndexes }), odd: createPositionalPseudo(function (matchIndexes, length) { var i = 1 for (; i < length; i += 2) { matchIndexes.push(i) } return matchIndexes }), lt: createPositionalPseudo(function (matchIndexes, length, argument) { var i = argument < 0 ? argument + length : argument for (; --i >= 0; ) { matchIndexes.push(i) } return matchIndexes }), gt: createPositionalPseudo(function (matchIndexes, length, argument) { var i = argument < 0 ? argument + length : argument for (; ++i < length; ) { matchIndexes.push(i) } return matchIndexes }), }, } Expr.pseudos.nth = Expr.pseudos.eq each$k(['radio', 'checkbox', 'file', 'password', 'image'], function (i) { Expr.pseudos[i] = createInputPseudo(i) }) each$k(['submit', 'reset'], function (i) { Expr.pseudos[i] = createButtonPseudo(i) }) function setFilters() {} setFilters.prototype = Expr.filters = Expr.pseudos Expr.setFilters = new setFilters() tokenize = Sizzle.tokenize = function (selector, parseOnly) { var matched, match, tokens, type, soFar, groups, preFilters, cached = tokenCache[selector + ' '] if (cached) { return parseOnly ? 0 : cached.slice(0) } soFar = selector groups = [] preFilters = Expr.preFilter while (soFar) { if (!matched || (match = rcomma.exec(soFar))) { if (match) { soFar = soFar.slice(match[0].length) || soFar } groups.push((tokens = [])) } matched = false if ((match = rcombinators.exec(soFar))) { matched = match.shift() tokens.push({ value: matched, type: match[0].replace(rtrim, ' '), }) soFar = soFar.slice(matched.length) } for (type in Expr.filter) { if (!Expr.filter.hasOwnProperty(type)) { continue } if ( (match = matchExpr[type].exec(soFar)) && (!preFilters[type] || (match = preFilters[type](match))) ) { matched = match.shift() tokens.push({ value: matched, type: type, matches: match, }) soFar = soFar.slice(matched.length) } } if (!matched) { break } } return parseOnly ? soFar.length : soFar ? Sizzle.error(selector) : tokenCache(selector, groups).slice(0) } function toSelector(tokens) { var i = 0, len = tokens.length, selector = '' for (; i < len; i++) { selector += tokens[i].value } return selector } function addCombinator(matcher, combinator, base) { var dir = combinator.dir, checkNonElements = base && dir === 'parentNode', doneName = done++ return combinator.first ? function (elem, context, xml) { while ((elem = elem[dir])) { if (elem.nodeType === 1 || checkNonElements) { return matcher(elem, context, xml) } } } : function (elem, context, xml) { var oldCache, outerCache, newCache = [dirruns, doneName] if (xml) { while ((elem = elem[dir])) { if (elem.nodeType === 1 || checkNonElements) { if (matcher(elem, context, xml)) { return true } } } } else { while ((elem = elem[dir])) { if (elem.nodeType === 1 || checkNonElements) { outerCache = elem[expando] || (elem[expando] = {}) if ( (oldCache = outerCache[dir]) && oldCache[0] === dirruns && oldCache[1] === doneName ) { return (newCache[2] = oldCache[2]) } else { outerCache[dir] = newCache if ((newCache[2] = matcher(elem, context, xml))) { return true } } } } } } } function elementMatcher(matchers) { return matchers.length > 1 ? function (elem, context, xml) { var i = matchers.length while (i--) { if (!matchers[i](elem, context, xml)) { return false } } return true } : matchers[0] } function multipleContexts(selector, contexts, results) { var i = 0, len = contexts.length for (; i < len; i++) { Sizzle(selector, contexts[i], results) } return results } function condense(unmatched, map, filter, context, xml) { var elem, newUnmatched = [], i = 0, len = unmatched.length, mapped = map != null for (; i < len; i++) { if ((elem = unmatched[i])) { if (!filter || filter(elem, context, xml)) { newUnmatched.push(elem) if (mapped) { map.push(i) } } } } return newUnmatched } function setMatcher( preFilter, selector, matcher, postFilter, postFinder, postSelector ) { if (postFilter && !postFilter[expando]) { postFilter = setMatcher(postFilter) } if (postFinder && !postFinder[expando]) { postFinder = setMatcher(postFinder, postSelector) } return markFunction(function (seed, results, context, xml) { var temp, i, elem, preMap = [], postMap = [], preexisting = results.length, elems = seed || multipleContexts( selector || '*', context.nodeType ? [context] : context, [] ), matcherIn = preFilter && (seed || !selector) ? condense(elems, preMap, preFilter, context, xml) : elems, matcherOut = matcher ? postFinder || (seed ? preFilter : preexisting || postFilter) ? [] : results : matcherIn if (matcher) { matcher(matcherIn, matcherOut, context, xml) } if (postFilter) { temp = condense(matcherOut, postMap) postFilter(temp, [], context, xml) i = temp.length while (i--) { if ((elem = temp[i])) { matcherOut[postMap[i]] = !(matcherIn[postMap[i]] = elem) } } } if (seed) { if (postFinder || preFilter) { if (postFinder) { temp = [] i = matcherOut.length while (i--) { if ((elem = matcherOut[i])) { temp.push((matcherIn[i] = elem)) } } postFinder(null, (matcherOut = []), temp, xml) } i = matcherOut.length while (i--) { if ( (elem = matcherOut[i]) && (temp = postFinder ? indexOf.call(seed, elem) : preMap[i]) > -1 ) { seed[temp] = !(results[temp] = elem) } } } } else { matcherOut = condense( matcherOut === results ? matcherOut.splice(preexisting, matcherOut.length) : matcherOut ) if (postFinder) { postFinder(null, results, matcherOut, xml) } else { push$1.apply(results, matcherOut) } } }) } function matcherFromTokens(tokens) { var checkContext, matcher, j, len = tokens.length, leadingRelative = Expr.relative[tokens[0].type], implicitRelative = leadingRelative || Expr.relative[' '], i = leadingRelative ? 1 : 0, matchContext = addCombinator( function (elem) { return elem === checkContext }, implicitRelative, true ), matchAnyContext = addCombinator( function (elem) { return indexOf.call(checkContext, elem) > -1 }, implicitRelative, true ), matchers = [ function (elem, context, xml) { var ret = (!leadingRelative && (xml || context !== outermostContext)) || ((checkContext = context).nodeType ? matchContext(elem, context, xml) : matchAnyContext(elem, context, xml)) checkContext = null return ret }, ] for (; i < len; i++) { if ((matcher = Expr.relative[tokens[i].type])) { matchers = [addCombinator(elementMatcher(matchers), matcher)] } else { matcher = Expr.filter[tokens[i].type].apply(null, tokens[i].matches) if (matcher[expando]) { j = ++i for (; j < len; j++) { if (Expr.relative[tokens[j].type]) { break } } return setMatcher( i > 1 && elementMatcher(matchers), i > 1 && toSelector( tokens .slice(0, i - 1) .concat({ value: tokens[i - 2].type === ' ' ? '*' : '' }) ).replace(rtrim, '$1'), matcher, i < j && matcherFromTokens(tokens.slice(i, j)), j < len && matcherFromTokens((tokens = tokens.slice(j))), j < len && toSelector(tokens) ) } matchers.push(matcher) } } return elementMatcher(matchers) } function matcherFromGroupMatchers(elementMatchers, setMatchers) { var bySet = setMatchers.length > 0, byElement = elementMatchers.length > 0, superMatcher = function (seed, context, xml, results, outermost) { var elem, j, matcher, matchedCount = 0, i = '0', unmatched = seed && [], setMatched = [], contextBackup = outermostContext, elems = seed || (byElement && Expr.find.TAG('*', outermost)), dirrunsUnique = (dirruns += contextBackup == null ? 1 : Math.random() || 0.1), len = elems.length if (outermost) { outermostContext = context !== document$1 && context } for (; i !== len && (elem = elems[i]) != null; i++) { if (byElement && elem) { j = 0 while ((matcher = elementMatchers[j++])) { if (matcher(elem, context, xml)) { results.push(elem) break } } if (outermost) { dirruns = dirrunsUnique } } if (bySet) { if ((elem = !matcher && elem)) { matchedCount-- } if (seed) { unmatched.push(elem) } } } matchedCount += i if (bySet && i !== matchedCount) { j = 0 while ((matcher = setMatchers[j++])) { matcher(unmatched, setMatched, context, xml) } if (seed) { if (matchedCount > 0) { while (i--) { if (!(unmatched[i] || setMatched[i])) { setMatched[i] = pop.call(results) } } } setMatched = condense(setMatched) } push$1.apply(results, setMatched) if ( outermost && !seed && setMatched.length > 0 && matchedCount + setMatchers.length > 1 ) { Sizzle.uniqueSort(results) } } if (outermost) { dirruns = dirrunsUnique outermostContext = contextBackup } return unmatched } return bySet ? markFunction(superMatcher) : superMatcher } compile = Sizzle.compile = function (selector, match) { var i, setMatchers = [], elementMatchers = [], cached = compilerCache[selector + ' '] if (!cached) { if (!match) { match = tokenize(selector) } i = match.length while (i--) { cached = matcherFromTokens(match[i]) if (cached[expando]) { setMatchers.push(cached) } else { elementMatchers.push(cached) } } cached = compilerCache( selector, matcherFromGroupMatchers(elementMatchers, setMatchers) ) cached.selector = selector } return cached } select$1 = Sizzle.select = function (selector, context, results, seed) { var i, tokens, token, type, find, compiled = typeof selector === 'function' && selector, match = !seed && tokenize((selector = compiled.selector || selector)) results = results || [] if (match.length === 1) { tokens = match[0] = match[0].slice(0) if ( tokens.length > 2 && (token = tokens[0]).type === 'ID' && support.getById && context.nodeType === 9 && documentIsHTML && Expr.relative[tokens[1].type] ) { context = (Expr.find.ID( token.matches[0].replace(runescape, funescape), context ) || [])[0] if (!context) { return results } else if (compiled) { context = context.parentNode } selector = selector.slice(tokens.shift().value.length) } i = matchExpr.needsContext.test(selector) ? 0 : tokens.length while (i--) { token = tokens[i] if (Expr.relative[(type = token.type)]) { break } if ((find = Expr.find[type])) { if ( (seed = find( token.matches[0].replace(runescape, funescape), (rsibling.test(tokens[0].type) && testContext(context.parentNode)) || context )) ) { tokens.splice(i, 1) selector = seed.length && toSelector(tokens) if (!selector) { push$1.apply(results, seed) return results } break } } } } ;(compiled || compile(selector, match))( seed, context, !documentIsHTML, results, (rsibling.test(selector) && testContext(context.parentNode)) || context ) return results } support.sortStable = expando.split('').sort(sortOrder).join('') === expando support.detectDuplicates = !!hasDuplicate setDocument() support.sortDetached = true var doc = document var push = Array.prototype.push var slice = Array.prototype.slice var rquickExpr = /^(?:[^#<]*(<[\w\W]+>)[^>]*$|#([\w\-]*)$)/ var Event$1 = EventUtils.Event var skipUniques = Tools.makeMap('children,contents,next,prev') var isDefined = function (obj) { return typeof obj !== 'undefined' } var isString = function (obj) { return typeof obj === 'string' } var isWindow = function (obj) { return obj && obj === obj.window } var createFragment$1 = function (html, fragDoc) { fragDoc = fragDoc || doc var container = fragDoc.createElement('div') var frag = fragDoc.createDocumentFragment() container.innerHTML = html var node while ((node = container.firstChild)) { frag.appendChild(node) } return frag } var domManipulate = function (targetNodes, sourceItem, callback, reverse) { var i if (isString(sourceItem)) { sourceItem = createFragment$1( sourceItem, getElementDocument(targetNodes[0]) ) } else if (sourceItem.length && !sourceItem.nodeType) { sourceItem = DomQuery.makeArray(sourceItem) if (reverse) { for (i = sourceItem.length - 1; i >= 0; i--) { domManipulate(targetNodes, sourceItem[i], callback, reverse) } } else { for (i = 0; i < sourceItem.length; i++) { domManipulate(targetNodes, sourceItem[i], callback, reverse) } } return targetNodes } if (sourceItem.nodeType) { i = targetNodes.length while (i--) { callback.call(targetNodes[i], sourceItem) } } return targetNodes } var hasClass = function (node, className) { return ( node && className && (' ' + node.className + ' ').indexOf(' ' + className + ' ') !== -1 ) } var wrap$2 = function (elements, wrapper, all) { var lastParent, newWrapper wrapper = DomQuery(wrapper)[0] elements.each(function () { var self = this if (!all || lastParent !== self.parentNode) { lastParent = self.parentNode newWrapper = wrapper.cloneNode(false) self.parentNode.insertBefore(newWrapper, self) newWrapper.appendChild(self) } else { newWrapper.appendChild(self) } }) return elements } var numericCssMap = Tools.makeMap( 'fillOpacity fontWeight lineHeight opacity orphans widows zIndex zoom', ' ' ) var booleanMap = Tools.makeMap( 'checked compact declare defer disabled ismap multiple nohref noshade nowrap readonly selected', ' ' ) var propFix = { for: 'htmlFor', class: 'className', readonly: 'readOnly', } var cssFix = { float: 'cssFloat' } var attrHooks = {}, cssHooks = {} var DomQueryConstructor = function (selector, context) { return new DomQuery.fn.init(selector, context) } var inArray$1 = function (item, array) { var i if (array.indexOf) { return array.indexOf(item) } i = array.length while (i--) { if (array[i] === item) { return i } } return -1 } var whiteSpaceRegExp = /^\s*|\s*$/g var trim$1 = function (str) { return str === null || str === undefined ? '' : ('' + str).replace(whiteSpaceRegExp, '') } var each$g = function (obj, callback) { var length, key, i, value if (obj) { length = obj.length if (length === undefined) { for (key in obj) { if (obj.hasOwnProperty(key)) { value = obj[key] if (callback.call(value, key, value) === false) { break } } } } else { for (i = 0; i < length; i++) { value = obj[i] if (callback.call(value, i, value) === false) { break } } } } return obj } var grep$2 = function (array, callback) { var out = [] each$g(array, function (i, item) { if (callback(item, i)) { out.push(item) } }) return out } var getElementDocument = function (element) { if (!element) { return doc } if (element.nodeType === 9) { return element } return element.ownerDocument } DomQueryConstructor.fn = DomQueryConstructor.prototype = { constructor: DomQueryConstructor, selector: '', context: null, length: 0, init: function (selector, context) { var self = this var match, node if (!selector) { return self } if (selector.nodeType) { self.context = self[0] = selector self.length = 1 return self } if (context && context.nodeType) { self.context = context } else { if (context) { return DomQuery(selector).attr(context) } self.context = context = document } if (isString(selector)) { self.selector = selector if ( selector.charAt(0) === '<' && selector.charAt(selector.length - 1) === '>' && selector.length >= 3 ) { match = [null, selector, null] } else { match = rquickExpr.exec(selector) } if (match) { if (match[1]) { node = createFragment$1( selector, getElementDocument(context) ).firstChild while (node) { push.call(self, node) node = node.nextSibling } } else { node = getElementDocument(context).getElementById(match[2]) if (!node) { return self } if (node.id !== match[2]) { return self.find(selector) } self.length = 1 self[0] = node } } else { return DomQuery(context).find(selector) } } else { this.add(selector, false) } return self }, toArray: function () { return Tools.toArray(this) }, add: function (items, sort) { var self = this var nodes, i if (isString(items)) { return self.add(DomQuery(items)) } if (sort !== false) { nodes = DomQuery.unique( self.toArray().concat(DomQuery.makeArray(items)) ) self.length = nodes.length for (i = 0; i < nodes.length; i++) { self[i] = nodes[i] } } else { push.apply(self, DomQuery.makeArray(items)) } return self }, attr: function (name, value) { var self = this var hook if (typeof name === 'object') { each$g(name, function (name, value) { self.attr(name, value) }) } else if (isDefined(value)) { this.each(function () { var hook if (this.nodeType === 1) { hook = attrHooks[name] if (hook && hook.set) { hook.set(this, value) return } if (value === null) { this.removeAttribute(name, 2) } else { this.setAttribute(name, value, 2) } } }) } else { if (self[0] && self[0].nodeType === 1) { hook = attrHooks[name] if (hook && hook.get) { return hook.get(self[0], name) } if (booleanMap[name]) { return self.prop(name) ? name : undefined } value = self[0].getAttribute(name, 2) if (value === null) { value = undefined } } return value } return self }, removeAttr: function (name) { return this.attr(name, null) }, prop: function (name, value) { var self = this name = propFix[name] || name if (typeof name === 'object') { each$g(name, function (name, value) { self.prop(name, value) }) } else if (isDefined(value)) { this.each(function () { if (this.nodeType === 1) { this[name] = value } }) } else { if (self[0] && self[0].nodeType && name in self[0]) { return self[0][name] } return value } return self }, css: function (name, value) { var self = this var elm, hook var camel = function (name) { return name.replace(/-(\D)/g, function (a, b) { return b.toUpperCase() }) } var dashed = function (name) { return name.replace(/[A-Z]/g, function (a) { return '-' + a }) } if (typeof name === 'object') { each$g(name, function (name, value) { self.css(name, value) }) } else { if (isDefined(value)) { name = camel(name) if (typeof value === 'number' && !numericCssMap[name]) { value = value.toString() + 'px' } self.each(function () { var style = this.style hook = cssHooks[name] if (hook && hook.set) { hook.set(this, value) return } try { this.style[cssFix[name] || name] = value } catch (ex) {} if (value === null || value === '') { if (style.removeProperty) { style.removeProperty(dashed(name)) } else { style.removeAttribute(name) } } }) } else { elm = self[0] hook = cssHooks[name] if (hook && hook.get) { return hook.get(elm) } if (elm.ownerDocument.defaultView) { try { return elm.ownerDocument.defaultView .getComputedStyle(elm, null) .getPropertyValue(dashed(name)) } catch (ex) { return undefined } } else if (elm.currentStyle) { return elm.currentStyle[camel(name)] } else { return '' } } } return self }, remove: function () { var self = this var node, i = this.length while (i--) { node = self[i] Event$1.clean(node) if (node.parentNode) { node.parentNode.removeChild(node) } } return this }, empty: function () { var self = this var node, i = this.length while (i--) { node = self[i] while (node.firstChild) { node.removeChild(node.firstChild) } } return this }, html: function (value) { var self = this var i if (isDefined(value)) { i = self.length try { while (i--) { self[i].innerHTML = value } } catch (ex) { DomQuery(self[i]).empty().append(value) } return self } return self[0] ? self[0].innerHTML : '' }, text: function (value) { var self = this var i if (isDefined(value)) { i = self.length while (i--) { if ('innerText' in self[i]) { self[i].innerText = value } else { self[0].textContent = value } } return self } return self[0] ? self[0].innerText || self[0].textContent : '' }, append: function () { return domManipulate(this, arguments, function (node) { if (this.nodeType === 1 || (this.host && this.host.nodeType === 1)) { this.appendChild(node) } }) }, prepend: function () { return domManipulate( this, arguments, function (node) { if (this.nodeType === 1 || (this.host && this.host.nodeType === 1)) { this.insertBefore(node, this.firstChild) } }, true ) }, before: function () { var self = this if (self[0] && self[0].parentNode) { return domManipulate(self, arguments, function (node) { this.parentNode.insertBefore(node, this) }) } return self }, after: function () { var self = this if (self[0] && self[0].parentNode) { return domManipulate( self, arguments, function (node) { this.parentNode.insertBefore(node, this.nextSibling) }, true ) } return self }, appendTo: function (val) { DomQuery(val).append(this) return this }, prependTo: function (val) { DomQuery(val).prepend(this) return this }, replaceWith: function (content) { return this.before(content).remove() }, wrap: function (content) { return wrap$2(this, content) }, wrapAll: function (content) { return wrap$2(this, content, true) }, wrapInner: function (content) { this.each(function () { DomQuery(this).contents().wrapAll(content) }) return this }, unwrap: function () { return this.parent().each(function () { DomQuery(this).replaceWith(this.childNodes) }) }, clone: function () { var result = [] this.each(function () { result.push(this.cloneNode(true)) }) return DomQuery(result) }, addClass: function (className) { return this.toggleClass(className, true) }, removeClass: function (className) { return this.toggleClass(className, false) }, toggleClass: function (className, state) { var self = this if (typeof className !== 'string') { return self } if (className.indexOf(' ') !== -1) { each$g(className.split(' '), function () { self.toggleClass(this, state) }) } else { self.each(function (index, node) { var classState = hasClass(node, className) if (classState !== state) { var existingClassName = node.className if (classState) { node.className = trim$1( (' ' + existingClassName + ' ').replace( ' ' + className + ' ', ' ' ) ) } else { node.className += existingClassName ? ' ' + className : className } } }) } return self }, hasClass: function (className) { return hasClass(this[0], className) }, each: function (callback) { return each$g(this, callback) }, on: function (name, callback) { return this.each(function () { Event$1.bind(this, name, callback) }) }, off: function (name, callback) { return this.each(function () { Event$1.unbind(this, name, callback) }) }, trigger: function (name) { return this.each(function () { if (typeof name === 'object') { Event$1.fire(this, name.type, name) } else { Event$1.fire(this, name) } }) }, show: function () { return this.css('display', '') }, hide: function () { return this.css('display', 'none') }, slice: function () { return DomQuery(slice.apply(this, arguments)) }, eq: function (index) { return index === -1 ? this.slice(index) : this.slice(index, +index + 1) }, first: function () { return this.eq(0) }, last: function () { return this.eq(-1) }, find: function (selector) { var i, l var ret = [] for (i = 0, l = this.length; i < l; i++) { DomQuery.find(selector, this[i], ret) } return DomQuery(ret) }, filter: function (selector) { if (typeof selector === 'function') { return DomQuery( grep$2(this.toArray(), function (item, i) { return selector(i, item) }) ) } return DomQuery(DomQuery.filter(selector, this.toArray())) }, closest: function (selector) { var result = [] if (selector instanceof DomQuery) { selector = selector[0] } this.each(function (i, node) { while (node) { if (typeof selector === 'string' && DomQuery(node).is(selector)) { result.push(node) break } else if (node === selector) { result.push(node) break } node = node.parentNode } }) return DomQuery(result) }, offset: function (offset) { var elm, doc, docElm var x = 0, y = 0, pos if (!offset) { elm = this[0] if (elm) { doc = elm.ownerDocument docElm = doc.documentElement if (elm.getBoundingClientRect) { pos = elm.getBoundingClientRect() x = pos.left + (docElm.scrollLeft || doc.body.scrollLeft) - docElm.clientLeft y = pos.top + (docElm.scrollTop || doc.body.scrollTop) - docElm.clientTop } } return { left: x, top: y, } } return this.css(offset) }, push: push, sort: Array.prototype.sort, splice: Array.prototype.splice, } Tools.extend(DomQueryConstructor, { extend: Tools.extend, makeArray: function (object) { if (isWindow(object) || object.nodeType) { return [object] } return Tools.toArray(object) }, inArray: inArray$1, isArray: Tools.isArray, each: each$g, trim: trim$1, grep: grep$2, find: Sizzle, expr: Sizzle.selectors, unique: Sizzle.uniqueSort, text: Sizzle.getText, contains: Sizzle.contains, filter: function (expr, elems, not) { var i = elems.length if (not) { expr = ':not(' + expr + ')' } while (i--) { if (elems[i].nodeType !== 1) { elems.splice(i, 1) } } if (elems.length === 1) { elems = DomQuery.find.matchesSelector(elems[0], expr) ? [elems[0]] : [] } else { elems = DomQuery.find.matches(expr, elems) } return elems }, }) var dir = function (el, prop, until) { var matched = [] var cur = el[prop] if (typeof until !== 'string' && until instanceof DomQuery) { until = until[0] } while (cur && cur.nodeType !== 9) { if (until !== undefined) { if (cur === until) { break } if (typeof until === 'string' && DomQuery(cur).is(until)) { break } } if (cur.nodeType === 1) { matched.push(cur) } cur = cur[prop] } return matched } var sibling$1 = function (node, siblingName, nodeType, until) { var result = [] if (until instanceof DomQuery) { until = until[0] } for (; node; node = node[siblingName]) { if (nodeType && node.nodeType !== nodeType) { continue } if (until !== undefined) { if (node === until) { break } if (typeof until === 'string' && DomQuery(node).is(until)) { break } } result.push(node) } return result } var firstSibling = function (node, siblingName, nodeType) { for (node = node[siblingName]; node; node = node[siblingName]) { if (node.nodeType === nodeType) { return node } } return null } each$g( { parent: function (node) { var parent = node.parentNode return parent && parent.nodeType !== 11 ? parent : null }, parents: function (node) { return dir(node, 'parentNode') }, next: function (node) { return firstSibling(node, 'nextSibling', 1) }, prev: function (node) { return firstSibling(node, 'previousSibling', 1) }, children: function (node) { return sibling$1(node.firstChild, 'nextSibling', 1) }, contents: function (node) { return Tools.toArray( (node.nodeName === 'iframe' ? node.contentDocument || node.contentWindow.document : node ).childNodes ) }, }, function (name, fn) { DomQueryConstructor.fn[name] = function (selector) { var self = this var result = [] self.each(function () { var nodes = fn.call(result, this, selector, result) if (nodes) { if (DomQuery.isArray(nodes)) { result.push.apply(result, nodes) } else { result.push(nodes) } } }) if (this.length > 1) { if (!skipUniques[name]) { result = DomQuery.unique(result) } if (name.indexOf('parents') === 0) { result = result.reverse() } } var wrappedResult = DomQuery(result) if (selector) { return wrappedResult.filter(selector) } return wrappedResult } } ) each$g( { parentsUntil: function (node, until) { return dir(node, 'parentNode', until) }, nextUntil: function (node, until) { return sibling$1(node, 'nextSibling', 1, until).slice(1) }, prevUntil: function (node, until) { return sibling$1(node, 'previousSibling', 1, until).slice(1) }, }, function (name, fn) { DomQueryConstructor.fn[name] = function (selector, filter) { var self = this var result = [] self.each(function () { var nodes = fn.call(result, this, selector, result) if (nodes) { if (DomQuery.isArray(nodes)) { result.push.apply(result, nodes) } else { result.push(nodes) } } }) if (this.length > 1) { result = DomQuery.unique(result) if (name.indexOf('parents') === 0 || name === 'prevUntil') { result = result.reverse() } } var wrappedResult = DomQuery(result) if (filter) { return wrappedResult.filter(filter) } return wrappedResult } } ) DomQueryConstructor.fn.is = function (selector) { return !!selector && this.filter(selector).length > 0 } DomQueryConstructor.fn.init.prototype = DomQueryConstructor.fn DomQueryConstructor.overrideDefaults = function (callback) { var defaults var sub = function (selector, context) { defaults = defaults || callback() if (arguments.length === 0) { selector = defaults.element } if (!context) { context = defaults.context } return new sub.fn.init(selector, context) } DomQuery.extend(sub, this) return sub } DomQueryConstructor.attrHooks = attrHooks DomQueryConstructor.cssHooks = cssHooks var DomQuery = DomQueryConstructor var each$f = Tools.each var grep$1 = Tools.grep var isIE = Env.ie var simpleSelectorRe = /^([a-z0-9],?)+$/i var setupAttrHooks = function (styles, settings, getContext) { var keepValues = settings.keep_values var keepUrlHook = { set: function ($elm, value, name) { if (settings.url_converter && value !== null) { value = settings.url_converter.call( settings.url_converter_scope || getContext(), value, name, $elm[0] ) } $elm.attr('data-mce-' + name, value).attr(name, value) }, get: function ($elm, name) { return $elm.attr('data-mce-' + name) || $elm.attr(name) }, } var attrHooks = { style: { set: function ($elm, value) { if (value !== null && typeof value === 'object') { $elm.css(value) return } if (keepValues) { $elm.attr('data-mce-style', value) } if (value !== null && typeof value === 'string') { $elm.removeAttr('style') $elm.css(styles.parse(value)) } else { $elm.attr('style', value) } }, get: function ($elm) { var value = $elm.attr('data-mce-style') || $elm.attr('style') value = styles.serialize(styles.parse(value), $elm[0].nodeName) return value }, }, } if (keepValues) { attrHooks.href = attrHooks.src = keepUrlHook } return attrHooks } var updateInternalStyleAttr = function (styles, $elm) { var rawValue = $elm.attr('style') var value = styles.serialize(styles.parse(rawValue), $elm[0].nodeName) if (!value) { value = null } $elm.attr('data-mce-style', value) } var findNodeIndex = function (node, normalized) { var idx = 0, lastNodeType, nodeType if (node) { for ( lastNodeType = node.nodeType, node = node.previousSibling; node; node = node.previousSibling ) { nodeType = node.nodeType if (normalized && nodeType === 3) { if (nodeType === lastNodeType || !node.nodeValue.length) { continue } } idx++ lastNodeType = nodeType } } return idx } var DOMUtils = function (doc, settings) { if (settings === void 0) { settings = {} } var addedStyles = {} var win = window var files = {} var counter = 0 var stdMode = true var boxModel = true var styleSheetLoader = instance.forElement(SugarElement.fromDom(doc), { contentCssCors: settings.contentCssCors, referrerPolicy: settings.referrerPolicy, }) var boundEvents = [] var schema = settings.schema ? settings.schema : Schema({}) var styles = Styles( { url_converter: settings.url_converter, url_converter_scope: settings.url_converter_scope, }, settings.schema ) var events = settings.ownEvents ? new EventUtils() : EventUtils.Event var blockElementsMap = schema.getBlockElements() var $ = DomQuery.overrideDefaults(function () { return { context: doc, element: self.getRoot(), } }) var isBlock = function (node) { if (typeof node === 'string') { return !!blockElementsMap[node] } else if (node) { var type = node.nodeType if (type) { return !!(type === 1 && blockElementsMap[node.nodeName]) } } return false } var get = function (elm) { return elm && doc && isString$1(elm) ? doc.getElementById(elm) : elm } var $$ = function (elm) { return $(typeof elm === 'string' ? get(elm) : elm) } var getAttrib = function (elm, name, defaultVal) { var hook, value var $elm = $$(elm) if ($elm.length) { hook = attrHooks[name] if (hook && hook.get) { value = hook.get($elm, name) } else { value = $elm.attr(name) } } if (typeof value === 'undefined') { value = defaultVal || '' } return value } var getAttribs = function (elm) { var node = get(elm) if (!node) { return [] } return node.attributes } var setAttrib = function (elm, name, value) { if (value === '') { value = null } var $elm = $$(elm) var originalValue = $elm.attr(name) if (!$elm.length) { return } var hook = attrHooks[name] if (hook && hook.set) { hook.set($elm, value, name) } else { $elm.attr(name, value) } if (originalValue !== value && settings.onSetAttrib) { settings.onSetAttrib({ attrElm: $elm, attrName: name, attrValue: value, }) } } var clone = function (node, deep) { if (!isIE || node.nodeType !== 1 || deep) { return node.cloneNode(deep) } else { var clone_1 = doc.createElement(node.nodeName) each$f(getAttribs(node), function (attr) { setAttrib(clone_1, attr.nodeName, getAttrib(node, attr.nodeName)) }) return clone_1 } } var getRoot = function () { return settings.root_element || doc.body } var getViewPort = function (argWin) { var vp = getBounds(argWin) return { x: vp.x, y: vp.y, w: vp.width, h: vp.height, } } var getPos$1 = function (elm, rootElm) { return getPos(doc.body, get(elm), rootElm) } var setStyle = function (elm, name, value) { var $elm = isString$1(name) ? $$(elm).css(name, value) : $$(elm).css(name) if (settings.update_styles) { updateInternalStyleAttr(styles, $elm) } } var setStyles = function (elm, stylesArg) { var $elm = $$(elm).css(stylesArg) if (settings.update_styles) { updateInternalStyleAttr(styles, $elm) } } var getStyle = function (elm, name, computed) { var $elm = $$(elm) if (computed) { return $elm.css(name) } name = name.replace(/-(\D)/g, function (a, b) { return b.toUpperCase() }) if (name === 'float') { name = Env.browser.isIE() ? 'styleFloat' : 'cssFloat' } return $elm[0] && $elm[0].style ? $elm[0].style[name] : undefined } var getSize = function (elm) { var w, h elm = get(elm) w = getStyle(elm, 'width') h = getStyle(elm, 'height') if (w.indexOf('px') === -1) { w = 0 } if (h.indexOf('px') === -1) { h = 0 } return { w: parseInt(w, 10) || elm.offsetWidth || elm.clientWidth, h: parseInt(h, 10) || elm.offsetHeight || elm.clientHeight, } } var getRect = function (elm) { elm = get(elm) var pos = getPos$1(elm) var size = getSize(elm) return { x: pos.x, y: pos.y, w: size.w, h: size.h, } } var is = function (elm, selector) { var i if (!elm) { return false } if (!Array.isArray(elm)) { if (selector === '*') { return elm.nodeType === 1 } if (simpleSelectorRe.test(selector)) { var selectors = selector.toLowerCase().split(/,/) var elmName = elm.nodeName.toLowerCase() for (i = selectors.length - 1; i >= 0; i--) { if (selectors[i] === elmName) { return true } } return false } if (elm.nodeType && elm.nodeType !== 1) { return false } } var elms = !Array.isArray(elm) ? [elm] : elm return ( Sizzle(selector, elms[0].ownerDocument || elms[0], null, elms).length > 0 ) } var getParents = function (elm, selector, root, collect) { var result = [] var selectorVal var node = get(elm) collect = collect === undefined root = root || (getRoot().nodeName !== 'BODY' ? getRoot().parentNode : null) if (Tools.is(selector, 'string')) { selectorVal = selector if (selector === '*') { selector = function (node) { return node.nodeType === 1 } } else { selector = function (node) { return is(node, selectorVal) } } } while (node) { if ( node === root || isNullable(node.nodeType) || isDocument$1(node) || isDocumentFragment(node) ) { break } if (!selector || (typeof selector === 'function' && selector(node))) { if (collect) { result.push(node) } else { return [node] } } node = node.parentNode } return collect ? result : null } var getParent = function (node, selector, root) { var parents = getParents(node, selector, root, false) return parents && parents.length > 0 ? parents[0] : null } var _findSib = function (node, selector, name) { var func = selector if (node) { if (typeof selector === 'string') { func = function (node) { return is(node, selector) } } for (node = node[name]; node; node = node[name]) { if (typeof func === 'function' && func(node)) { return node } } } return null } var getNext = function (node, selector) { return _findSib(node, selector, 'nextSibling') } var getPrev = function (node, selector) { return _findSib(node, selector, 'previousSibling') } var select = function (selector, scope) { return Sizzle(selector, get(scope) || settings.root_element || doc, []) } var run = function (elm, func, scope) { var result var node = typeof elm === 'string' ? get(elm) : elm if (!node) { return false } if (Tools.isArray(node) && (node.length || node.length === 0)) { result = [] each$f(node, function (elm, i) { if (elm) { result.push( func.call(scope, typeof elm === 'string' ? get(elm) : elm, i) ) } }) return result } var context = scope ? scope : this return func.call(context, node) } var setAttribs = function (elm, attrs) { $$(elm).each(function (i, node) { each$f(attrs, function (value, name) { setAttrib(node, name, value) }) }) } var setHTML = function (elm, html) { var $elm = $$(elm) if (isIE) { $elm.each(function (i, target) { if (target.canHaveHTML === false) { return } while (target.firstChild) { target.removeChild(target.firstChild) } try { target.innerHTML = '
' + html target.removeChild(target.firstChild) } catch (ex) { DomQuery('
') .html('
' + html) .contents() .slice(1) .appendTo(target) } return html }) } else { $elm.html(html) } } var add = function (parentElm, name, attrs, html, create) { return run(parentElm, function (parentElm) { var newElm = typeof name === 'string' ? doc.createElement(name) : name setAttribs(newElm, attrs) if (html) { if (typeof html !== 'string' && html.nodeType) { newElm.appendChild(html) } else if (typeof html === 'string') { setHTML(newElm, html) } } return !create ? parentElm.appendChild(newElm) : newElm }) } var create = function (name, attrs, html) { return add(doc.createElement(name), name, attrs, html, true) } var decode = Entities.decode var encode = Entities.encodeAllRaw var createHTML = function (name, attrs, html) { var outHtml = '', key outHtml += '<' + name for (key in attrs) { if (hasNonNullableKey(attrs, key)) { outHtml += ' ' + key + '="' + encode(attrs[key]) + '"' } } if (typeof html !== 'undefined') { return outHtml + '>' + html + '' } return outHtml + ' />' } var createFragment = function (html) { var node var container = doc.createElement('div') var frag = doc.createDocumentFragment() frag.appendChild(container) if (html) { container.innerHTML = html } while ((node = container.firstChild)) { frag.appendChild(node) } frag.removeChild(container) return frag } var remove = function (node, keepChildren) { var $node = $$(node) if (keepChildren) { $node .each(function () { var child while ((child = this.firstChild)) { if (child.nodeType === 3 && child.data.length === 0) { this.removeChild(child) } else { this.parentNode.insertBefore(child, this) } } }) .remove() } else { $node.remove() } return $node.length > 1 ? $node.toArray() : $node[0] } var removeAllAttribs = function (e) { return run(e, function (e) { var i var attrs = e.attributes for (i = attrs.length - 1; i >= 0; i--) { e.removeAttributeNode(attrs.item(i)) } }) } var parseStyle = function (cssText) { return styles.parse(cssText) } var serializeStyle = function (stylesArg, name) { return styles.serialize(stylesArg, name) } var addStyle = function (cssText) { var head, styleElm if (self !== DOMUtils.DOM && doc === document) { if (addedStyles[cssText]) { return } addedStyles[cssText] = true } styleElm = doc.getElementById('mceDefaultStyles') if (!styleElm) { styleElm = doc.createElement('style') styleElm.id = 'mceDefaultStyles' styleElm.type = 'text/css' head = doc.getElementsByTagName('head')[0] if (head.firstChild) { head.insertBefore(styleElm, head.firstChild) } else { head.appendChild(styleElm) } } if (styleElm.styleSheet) { styleElm.styleSheet.cssText += cssText } else { styleElm.appendChild(doc.createTextNode(cssText)) } } var loadCSS = function (urls) { if (!urls) { urls = '' } each$k(urls.split(','), function (url) { files[url] = true styleSheetLoader.load(url, noop) }) } var toggleClass = function (elm, cls, state) { $$(elm) .toggleClass(cls, state) .each(function () { if (this.className === '') { DomQuery(this).attr('class', null) } }) } var addClass = function (elm, cls) { $$(elm).addClass(cls) } var removeClass = function (elm, cls) { toggleClass(elm, cls, false) } var hasClass = function (elm, cls) { return $$(elm).hasClass(cls) } var show = function (elm) { $$(elm).show() } var hide = function (elm) { $$(elm).hide() } var isHidden = function (elm) { return $$(elm).css('display') === 'none' } var uniqueId = function (prefix) { return (!prefix ? 'mce_' : prefix) + counter++ } var getOuterHTML = function (elm) { var node = typeof elm === 'string' ? get(elm) : elm return isElement$5(node) ? node.outerHTML : DomQuery('
').append(DomQuery(node).clone()).html() } var setOuterHTML = function (elm, html) { $$(elm).each(function () { try { if ('outerHTML' in this) { this.outerHTML = html return } } catch (ex) {} remove(DomQuery(this).html(html), true) }) } var insertAfter = function (node, reference) { var referenceNode = get(reference) return run(node, function (node) { var parent = referenceNode.parentNode var nextSibling = referenceNode.nextSibling if (nextSibling) { parent.insertBefore(node, nextSibling) } else { parent.appendChild(node) } return node }) } var replace = function (newElm, oldElm, keepChildren) { return run(oldElm, function (oldElm) { if (Tools.is(oldElm, 'array')) { newElm = newElm.cloneNode(true) } if (keepChildren) { each$f(grep$1(oldElm.childNodes), function (node) { newElm.appendChild(node) }) } return oldElm.parentNode.replaceChild(newElm, oldElm) }) } var rename = function (elm, name) { var newElm if (elm.nodeName !== name.toUpperCase()) { newElm = create(name) each$f(getAttribs(elm), function (attrNode) { setAttrib( newElm, attrNode.nodeName, getAttrib(elm, attrNode.nodeName) ) }) replace(newElm, elm, true) } return newElm || elm } var findCommonAncestor = function (a, b) { var ps = a, pe while (ps) { pe = b while (pe && ps !== pe) { pe = pe.parentNode } if (ps === pe) { break } ps = ps.parentNode } if (!ps && a.ownerDocument) { return a.ownerDocument.documentElement } return ps } var toHex = function (rgbVal) { return styles.toHex(Tools.trim(rgbVal)) } var isNonEmptyElement = function (node) { if (isElement$5(node)) { var isNamedAnchor = node.nodeName.toLowerCase() === 'a' && !getAttrib(node, 'href') && getAttrib(node, 'id') if ( getAttrib(node, 'name') || getAttrib(node, 'data-mce-bookmark') || isNamedAnchor ) { return true } } return false } var isEmpty = function (node, elements) { var type, name, brCount = 0 if (isNonEmptyElement(node)) { return false } node = node.firstChild if (node) { var walker = new DomTreeWalker(node, node.parentNode) var whitespace = schema ? schema.getWhiteSpaceElements() : {} elements = elements || (schema ? schema.getNonEmptyElements() : null) do { type = node.nodeType if (isElement$5(node)) { var bogusVal = node.getAttribute('data-mce-bogus') if (bogusVal) { node = walker.next(bogusVal === 'all') continue } name = node.nodeName.toLowerCase() if (elements && elements[name]) { if (name === 'br') { brCount++ node = walker.next() continue } return false } if (isNonEmptyElement(node)) { return false } } if (type === 8) { return false } if (type === 3 && !isWhitespaceText(node.nodeValue)) { return false } if ( type === 3 && node.parentNode && whitespace[node.parentNode.nodeName] && isWhitespaceText(node.nodeValue) ) { return false } node = walker.next() } while (node) } return brCount <= 1 } var createRng = function () { return doc.createRange() } var split = function (parentElm, splitElm, replacementElm) { var range = createRng() var beforeFragment var afterFragment var parentNode if (parentElm && splitElm) { range.setStart(parentElm.parentNode, findNodeIndex(parentElm)) range.setEnd(splitElm.parentNode, findNodeIndex(splitElm)) beforeFragment = range.extractContents() range = createRng() range.setStart(splitElm.parentNode, findNodeIndex(splitElm) + 1) range.setEnd(parentElm.parentNode, findNodeIndex(parentElm) + 1) afterFragment = range.extractContents() parentNode = parentElm.parentNode parentNode.insertBefore(trimNode(self, beforeFragment), parentElm) if (replacementElm) { parentNode.insertBefore(replacementElm, parentElm) } else { parentNode.insertBefore(splitElm, parentElm) } parentNode.insertBefore(trimNode(self, afterFragment), parentElm) remove(parentElm) return replacementElm || splitElm } } var bind = function (target, name, func, scope) { if (Tools.isArray(target)) { var i = target.length var rv = [] while (i--) { rv[i] = bind(target[i], name, func, scope) } return rv } if (settings.collect && (target === doc || target === win)) { boundEvents.push([target, name, func, scope]) } var output = events.bind(target, name, func, scope || self) return output } var unbind = function (target, name, func) { if (Tools.isArray(target)) { var i = target.length var rv = [] while (i--) { rv[i] = unbind(target[i], name, func) } return rv } else { if (boundEvents.length > 0 && (target === doc || target === win)) { var i = boundEvents.length while (i--) { var item = boundEvents[i] if ( target === item[0] && (!name || name === item[1]) && (!func || func === item[2]) ) { events.unbind(item[0], item[1], item[2]) } } } return events.unbind(target, name, func) } } var fire = function (target, name, evt) { return events.fire(target, name, evt) } var getContentEditable = function (node) { if (node && isElement$5(node)) { var contentEditable = node.getAttribute('data-mce-contenteditable') if (contentEditable && contentEditable !== 'inherit') { return contentEditable } return node.contentEditable !== 'inherit' ? node.contentEditable : null } else { return null } } var getContentEditableParent = function (node) { var root = getRoot() var state = null for (; node && node !== root; node = node.parentNode) { state = getContentEditable(node) if (state !== null) { break } } return state } var destroy = function () { if (boundEvents.length > 0) { var i = boundEvents.length while (i--) { var item = boundEvents[i] events.unbind(item[0], item[1], item[2]) } } each$j(files, function (_, url) { styleSheetLoader.unload(url) delete files[url] }) if (Sizzle.setDocument) { Sizzle.setDocument() } } var isChildOf = function (node, parent) { if (!isIE) { return node === parent || parent.contains(node) } else { while (node) { if (parent === node) { return true } node = node.parentNode } return false } } var dumpRng = function (r) { return ( 'startContainer: ' + r.startContainer.nodeName + ', startOffset: ' + r.startOffset + ', endContainer: ' + r.endContainer.nodeName + ', endOffset: ' + r.endOffset ) } var self = { doc: doc, settings: settings, win: win, files: files, stdMode: stdMode, boxModel: boxModel, styleSheetLoader: styleSheetLoader, boundEvents: boundEvents, styles: styles, schema: schema, events: events, isBlock: isBlock, $: $, $$: $$, root: null, clone: clone, getRoot: getRoot, getViewPort: getViewPort, getRect: getRect, getSize: getSize, getParent: getParent, getParents: getParents, get: get, getNext: getNext, getPrev: getPrev, select: select, is: is, add: add, create: create, createHTML: createHTML, createFragment: createFragment, remove: remove, setStyle: setStyle, getStyle: getStyle, setStyles: setStyles, removeAllAttribs: removeAllAttribs, setAttrib: setAttrib, setAttribs: setAttribs, getAttrib: getAttrib, getPos: getPos$1, parseStyle: parseStyle, serializeStyle: serializeStyle, addStyle: addStyle, loadCSS: loadCSS, addClass: addClass, removeClass: removeClass, hasClass: hasClass, toggleClass: toggleClass, show: show, hide: hide, isHidden: isHidden, uniqueId: uniqueId, setHTML: setHTML, getOuterHTML: getOuterHTML, setOuterHTML: setOuterHTML, decode: decode, encode: encode, insertAfter: insertAfter, replace: replace, rename: rename, findCommonAncestor: findCommonAncestor, toHex: toHex, run: run, getAttribs: getAttribs, isEmpty: isEmpty, createRng: createRng, nodeIndex: findNodeIndex, split: split, bind: bind, unbind: unbind, fire: fire, getContentEditable: getContentEditable, getContentEditableParent: getContentEditableParent, destroy: destroy, isChildOf: isChildOf, dumpRng: dumpRng, } var attrHooks = setupAttrHooks(styles, settings, constant(self)) return self } DOMUtils.DOM = DOMUtils(document) DOMUtils.nodeIndex = findNodeIndex var DOM$a = DOMUtils.DOM var each$e = Tools.each, grep = Tools.grep var QUEUED = 0 var LOADING = 1 var LOADED = 2 var FAILED = 3 var ScriptLoader = (function () { function ScriptLoader(settings) { if (settings === void 0) { settings = {} } this.states = {} this.queue = [] this.scriptLoadedCallbacks = {} this.queueLoadedCallbacks = [] this.loading = 0 this.settings = settings } ScriptLoader.prototype._setReferrerPolicy = function (referrerPolicy) { this.settings.referrerPolicy = referrerPolicy } ScriptLoader.prototype.loadScript = function (url, success, failure) { var dom = DOM$a var elm var cleanup = function () { dom.remove(id) if (elm) { elm.onerror = elm.onload = elm = null } } var done = function () { cleanup() success() } var error = function () { cleanup() if (isFunction(failure)) { failure() } else { if (typeof console !== 'undefined' && console.log) { console.log('Failed to load script: ' + url) } } } var id = dom.uniqueId() elm = document.createElement('script') elm.id = id elm.type = 'text/javascript' elm.src = Tools._addCacheSuffix(url) if (this.settings.referrerPolicy) { dom.setAttrib(elm, 'referrerpolicy', this.settings.referrerPolicy) } elm.onload = done elm.onerror = error ;(document.getElementsByTagName('head')[0] || document.body).appendChild( elm ) } ScriptLoader.prototype.isDone = function (url) { return this.states[url] === LOADED } ScriptLoader.prototype.markDone = function (url) { this.states[url] = LOADED } ScriptLoader.prototype.add = function (url, success, scope, failure) { var state = this.states[url] this.queue.push(url) if (state === undefined) { this.states[url] = QUEUED } if (success) { if (!this.scriptLoadedCallbacks[url]) { this.scriptLoadedCallbacks[url] = [] } this.scriptLoadedCallbacks[url].push({ success: success, failure: failure, scope: scope || this, }) } } ScriptLoader.prototype.load = function (url, success, scope, failure) { return this.add(url, success, scope, failure) } ScriptLoader.prototype.remove = function (url) { delete this.states[url] delete this.scriptLoadedCallbacks[url] } ScriptLoader.prototype.loadQueue = function (success, scope, failure) { this.loadScripts(this.queue, success, scope, failure) } ScriptLoader.prototype.loadScripts = function ( scripts, success, scope, failure ) { var self = this var failures = [] var execCallbacks = function (name, url) { each$e(self.scriptLoadedCallbacks[url], function (callback) { if (isFunction(callback[name])) { callback[name].call(callback.scope) } }) self.scriptLoadedCallbacks[url] = undefined } self.queueLoadedCallbacks.push({ success: success, failure: failure, scope: scope || this, }) var loadScripts = function () { var loadingScripts = grep(scripts) scripts.length = 0 each$e(loadingScripts, function (url) { if (self.states[url] === LOADED) { execCallbacks('success', url) return } if (self.states[url] === FAILED) { execCallbacks('failure', url) return } if (self.states[url] !== LOADING) { self.states[url] = LOADING self.loading++ self.loadScript( url, function () { self.states[url] = LOADED self.loading-- execCallbacks('success', url) loadScripts() }, function () { self.states[url] = FAILED self.loading-- failures.push(url) execCallbacks('failure', url) loadScripts() } ) } }) if (!self.loading) { var notifyCallbacks = self.queueLoadedCallbacks.slice(0) self.queueLoadedCallbacks.length = 0 each$e(notifyCallbacks, function (callback) { if (failures.length === 0) { if (isFunction(callback.success)) { callback.success.call(callback.scope) } } else { if (isFunction(callback.failure)) { callback.failure.call(callback.scope, failures) } } }) } } loadScripts() } ScriptLoader.ScriptLoader = new ScriptLoader() return ScriptLoader })() var Cell = function (initial) { var value = initial var get = function () { return value } var set = function (v) { value = v } return { get: get, set: set, } } var isRaw = function (str) { return isObject(str) && has$2(str, 'raw') } var isTokenised = function (str) { return isArray$1(str) && str.length > 1 } var data = {} var currentCode = Cell('en') var getLanguageData = function () { return get$9(data, currentCode.get()) } var getData = function () { return map$2(data, function (value) { return __assign({}, value) }) } var setCode = function (newCode) { if (newCode) { currentCode.set(newCode) } } var getCode = function () { return currentCode.get() } var add$4 = function (code, items) { var langData = data[code] if (!langData) { data[code] = langData = {} } each$j(items, function (translation, name) { langData[name.toLowerCase()] = translation }) } var translate = function (text) { var langData = getLanguageData().getOr({}) var toString = function (obj) { if (isFunction(obj)) { return Object.prototype.toString.call(obj) } return !isEmpty(obj) ? '' + obj : '' } var isEmpty = function (text) { return text === '' || text === null || text === undefined } var getLangData = function (text) { var textstr = toString(text) return get$9(langData, textstr.toLowerCase()).map(toString).getOr(textstr) } var removeContext = function (str) { return str.replace(/{context:\w+}$/, '') } if (isEmpty(text)) { return '' } if (isRaw(text)) { return toString(text.raw) } if (isTokenised(text)) { var values_1 = text.slice(1) var substitued = getLangData(text[0]).replace( /\{([0-9]+)\}/g, function ($1, $2) { return has$2(values_1, $2) ? toString(values_1[$2]) : $1 } ) return removeContext(substitued) } return removeContext(getLangData(text)) } var isRtl$1 = function () { return getLanguageData() .bind(function (items) { return get$9(items, '_dir') }) .exists(function (dir) { return dir === 'rtl' }) } var hasCode = function (code) { return has$2(data, code) } var I18n = { getData: getData, setCode: setCode, getCode: getCode, add: add$4, translate: translate, isRtl: isRtl$1, hasCode: hasCode, } var AddOnManager = function () { var items = [] var urls = {} var lookup = {} var _listeners = [] var runListeners = function (name, state) { var matchedListeners = filter$4(_listeners, function (listener) { return listener.name === name && listener.state === state }) each$k(matchedListeners, function (listener) { return listener.callback() }) } var get = function (name) { if (lookup[name]) { return lookup[name].instance } return undefined } var dependencies = function (name) { var result if (lookup[name]) { result = lookup[name].dependencies } return result || [] } var requireLangPack = function (name, languages) { if (AddOnManager.languageLoad !== false) { waitFor( name, function () { var language = I18n.getCode() var wrappedLanguages = ',' + (languages || '') + ',' if ( !language || (languages && wrappedLanguages.indexOf(',' + language + ',') === -1) ) { return } ScriptLoader.ScriptLoader.add( urls[name] + '/langs/' + language + '.js' ) }, 'loaded' ) } } var add = function (id, addOn, dependencies) { var addOnConstructor = addOn items.push(addOnConstructor) lookup[id] = { instance: addOnConstructor, dependencies: dependencies, } runListeners(id, 'added') return addOnConstructor } var remove = function (name) { delete urls[name] delete lookup[name] } var createUrl = function (baseUrl, dep) { if (typeof dep === 'object') { return dep } return typeof baseUrl === 'string' ? { prefix: '', resource: dep, suffix: '', } : { prefix: baseUrl.prefix, resource: dep, suffix: baseUrl.suffix, } } var addComponents = function (pluginName, scripts) { var pluginUrl = urls[pluginName] each$k(scripts, function (script) { ScriptLoader.ScriptLoader.add(pluginUrl + '/' + script) }) } var loadDependencies = function (name, addOnUrl, success, scope) { var deps = dependencies(name) each$k(deps, function (dep) { var newUrl = createUrl(addOnUrl, dep) load(newUrl.resource, newUrl, undefined, undefined) }) if (success) { if (scope) { success.call(scope) } else { success.call(ScriptLoader) } } } var load = function (name, addOnUrl, success, scope, failure) { if (urls[name]) { return } var urlString = typeof addOnUrl === 'string' ? addOnUrl : addOnUrl.prefix + addOnUrl.resource + addOnUrl.suffix if (urlString.indexOf('/') !== 0 && urlString.indexOf('://') === -1) { urlString = AddOnManager.baseURL + '/' + urlString } urls[name] = urlString.substring(0, urlString.lastIndexOf('/')) var done = function () { runListeners(name, 'loaded') loadDependencies(name, addOnUrl, success, scope) } if (lookup[name]) { done() } else { ScriptLoader.ScriptLoader.add(urlString, done, scope, failure) } } var waitFor = function (name, callback, state) { if (state === void 0) { state = 'added' } if (has$2(lookup, name) && state === 'added') { callback() } else if (has$2(urls, name) && state === 'loaded') { callback() } else { _listeners.push({ name: name, state: state, callback: callback, }) } } return { items: items, urls: urls, lookup: lookup, _listeners: _listeners, get: get, dependencies: dependencies, requireLangPack: requireLangPack, add: add, remove: remove, createUrl: createUrl, addComponents: addComponents, load: load, waitFor: waitFor, } } AddOnManager.languageLoad = true AddOnManager.baseURL = '' AddOnManager.PluginManager = AddOnManager() AddOnManager.ThemeManager = AddOnManager() var singleton = function (doRevoke) { var subject = Cell(Optional.none()) var revoke = function () { return subject.get().each(doRevoke) } var clear = function () { revoke() subject.set(Optional.none()) } var isSet = function () { return subject.get().isSome() } var get = function () { return subject.get() } var set = function (s) { revoke() subject.set(Optional.some(s)) } return { clear: clear, isSet: isSet, get: get, set: set, } } var value = function () { var subject = singleton(noop) var on = function (f) { return subject.get().each(f) } return __assign(__assign({}, subject), { on: on }) } var first = function (fn, rate) { var timer = null var cancel = function () { if (!isNull(timer)) { clearTimeout(timer) timer = null } } var throttle = function () { var args = [] for (var _i = 0; _i < arguments.length; _i++) { args[_i] = arguments[_i] } if (isNull(timer)) { timer = setTimeout(function () { timer = null fn.apply(null, args) }, rate) } } return { cancel: cancel, throttle: throttle, } } var last = function (fn, rate) { var timer = null var cancel = function () { if (!isNull(timer)) { clearTimeout(timer) timer = null } } var throttle = function () { var args = [] for (var _i = 0; _i < arguments.length; _i++) { args[_i] = arguments[_i] } cancel() timer = setTimeout(function () { timer = null fn.apply(null, args) }, rate) } return { cancel: cancel, throttle: throttle, } } var read$4 = function (element, attr) { var value = get$6(element, attr) return value === undefined || value === '' ? [] : value.split(' ') } var add$3 = function (element, attr, id) { var old = read$4(element, attr) var nu = old.concat([id]) set$1(element, attr, nu.join(' ')) return true } var remove$5 = function (element, attr, id) { var nu = filter$4(read$4(element, attr), function (v) { return v !== id }) if (nu.length > 0) { set$1(element, attr, nu.join(' ')) } else { remove$6(element, attr) } return false } var supports = function (element) { return element.dom.classList !== undefined } var get$4 = function (element) { return read$4(element, 'class') } var add$2 = function (element, clazz) { return add$3(element, 'class', clazz) } var remove$4 = function (element, clazz) { return remove$5(element, 'class', clazz) } var add$1 = function (element, clazz) { if (supports(element)) { element.dom.classList.add(clazz) } else { add$2(element, clazz) } } var cleanClass = function (element) { var classList = supports(element) ? element.dom.classList : get$4(element) if (classList.length === 0) { remove$6(element, 'class') } } var remove$3 = function (element, clazz) { if (supports(element)) { var classList = element.dom.classList classList.remove(clazz) } else { remove$4(element, clazz) } cleanClass(element) } var has = function (element, clazz) { return supports(element) && element.dom.classList.contains(clazz) } var descendants$1 = function (scope, predicate) { var result = [] each$k(children(scope), function (x) { if (predicate(x)) { result = result.concat([x]) } result = result.concat(descendants$1(x, predicate)) }) return result } var descendants = function (scope, selector) { return all(selector, scope) } var annotation = constant('mce-annotation') var dataAnnotation = constant('data-mce-annotation') var dataAnnotationId = constant('data-mce-annotation-uid') var identify = function (editor, annotationName) { var rng = editor.selection.getRng() var start = SugarElement.fromDom(rng.startContainer) var root = SugarElement.fromDom(editor.getBody()) var selector = annotationName.fold( function () { return '.' + annotation() }, function (an) { return '[' + dataAnnotation() + '="' + an + '"]' } ) var newStart = child$1(start, rng.startOffset).getOr(start) var closest = closest$2(newStart, selector, function (n) { return eq(n, root) }) var getAttr = function (c, property) { if (has$1(c, property)) { return Optional.some(get$6(c, property)) } else { return Optional.none() } } return closest.bind(function (c) { return getAttr(c, '' + dataAnnotationId()).bind(function (uid) { return getAttr(c, '' + dataAnnotation()).map(function (name) { var elements = findMarkers(editor, uid) return { uid: uid, name: name, elements: elements, } }) }) }) } var isAnnotation = function (elem) { return isElement$6(elem) && has(elem, annotation()) } var findMarkers = function (editor, uid) { var body = SugarElement.fromDom(editor.getBody()) return descendants(body, '[' + dataAnnotationId() + '="' + uid + '"]') } var findAll = function (editor, name) { var body = SugarElement.fromDom(editor.getBody()) var markers = descendants(body, '[' + dataAnnotation() + '="' + name + '"]') var directory = {} each$k(markers, function (m) { var uid = get$6(m, dataAnnotationId()) var nodesAlready = get$9(directory, uid).getOr([]) directory[uid] = nodesAlready.concat([m]) }) return directory } var setup$n = function (editor, _registry) { var changeCallbacks = Cell({}) var initData = function () { return { listeners: [], previous: value(), } } var withCallbacks = function (name, f) { updateCallbacks(name, function (data) { f(data) return data }) } var updateCallbacks = function (name, f) { var callbackMap = changeCallbacks.get() var data = get$9(callbackMap, name).getOrThunk(initData) var outputData = f(data) callbackMap[name] = outputData changeCallbacks.set(callbackMap) } var fireCallbacks = function (name, uid, elements) { withCallbacks(name, function (data) { each$k(data.listeners, function (f) { return f(true, name, { uid: uid, nodes: map$3(elements, function (elem) { return elem.dom }), }) }) }) } var fireNoAnnotation = function (name) { withCallbacks(name, function (data) { each$k(data.listeners, function (f) { return f(false, name) }) }) } var onNodeChange = last(function () { var callbackMap = changeCallbacks.get() var annotations = sort(keys(callbackMap)) each$k(annotations, function (name) { updateCallbacks(name, function (data) { var prev = data.previous.get() identify(editor, Optional.some(name)).fold( function () { if (prev.isSome()) { fireNoAnnotation(name) data.previous.clear() } }, function (_a) { var uid = _a.uid, name = _a.name, elements = _a.elements if (!is$1(prev, uid)) { fireCallbacks(name, uid, elements) data.previous.set(uid) } } ) return { previous: data.previous, listeners: data.listeners, } }) }) }, 30) editor.on('remove', function () { onNodeChange.cancel() }) editor.on('NodeChange', function () { onNodeChange.throttle() }) var addListener = function (name, f) { updateCallbacks(name, function (data) { return { previous: data.previous, listeners: data.listeners.concat([f]), } }) } return { addListener: addListener } } var setup$m = function (editor, registry) { var identifyParserNode = function (span) { return Optional.from(span.attr(dataAnnotation())).bind(registry.lookup) } editor.on('init', function () { editor.serializer.addNodeFilter('span', function (spans) { each$k(spans, function (span) { identifyParserNode(span).each(function (settings) { if (settings.persistent === false) { span.unwrap() } }) }) }) }) } var create$7 = function () { var annotations = {} var register = function (name, settings) { annotations[name] = { name: name, settings: settings, } } var lookup = function (name) { return get$9(annotations, name).map(function (a) { return a.settings }) } return { register: register, lookup: lookup, } } var unique = 0 var generate = function (prefix) { var date = new Date() var time = date.getTime() var random = Math.floor(Math.random() * 1000000000) unique++ return prefix + '_' + random + unique + String(time) } var add = function (element, classes) { each$k(classes, function (x) { add$1(element, x) }) } var fromHtml = function (html, scope) { var doc = scope || document var div = doc.createElement('div') div.innerHTML = html return children(SugarElement.fromDom(div)) } var fromDom$1 = function (nodes) { return map$3(nodes, SugarElement.fromDom) } var get$3 = function (element) { return element.dom.innerHTML } var set = function (element, content) { var owner = owner$1(element) var docDom = owner.dom var fragment = SugarElement.fromDom(docDom.createDocumentFragment()) var contentElements = fromHtml(content, docDom) append(fragment, contentElements) empty(element) append$1(element, fragment) } var clone$1 = function (original, isDeep) { return SugarElement.fromDom(original.dom.cloneNode(isDeep)) } var shallow = function (original) { return clone$1(original, false) } var deep$1 = function (original) { return clone$1(original, true) } var TextWalker = function (startNode, rootNode, isBoundary) { if (isBoundary === void 0) { isBoundary = never } var walker = new DomTreeWalker(startNode, rootNode) var walk = function (direction) { var next do { next = walker[direction]() } while (next && !isText$7(next) && !isBoundary(next)) return Optional.from(next).filter(isText$7) } return { current: function () { return Optional.from(walker.current()).filter(isText$7) }, next: function () { return walk('next') }, prev: function () { return walk('prev') }, prev2: function () { return walk('prev2') }, } } var TextSeeker = function (dom, isBoundary) { var isBlockBoundary = isBoundary ? isBoundary : function (node) { return ( dom.isBlock(node) || isBr$5(node) || isContentEditableFalse$b(node) ) } var walk = function (node, offset, walker, process) { if (isText$7(node)) { var newOffset = process(node, offset, node.data) if (newOffset !== -1) { return Optional.some({ container: node, offset: newOffset, }) } } return walker().bind(function (next) { return walk(next.container, next.offset, walker, process) }) } var backwards = function (node, offset, process, root) { var walker = TextWalker(node, root, isBlockBoundary) return walk( node, offset, function () { return walker.prev().map(function (prev) { return { container: prev, offset: prev.length, } }) }, process ).getOrNull() } var forwards = function (node, offset, process, root) { var walker = TextWalker(node, root, isBlockBoundary) return walk( node, offset, function () { return walker.next().map(function (next) { return { container: next, offset: 0, } }) }, process ).getOrNull() } return { backwards: backwards, forwards: forwards, } } var round$2 = Math.round var clone = function (rect) { if (!rect) { return { left: 0, top: 0, bottom: 0, right: 0, width: 0, height: 0, } } return { left: round$2(rect.left), top: round$2(rect.top), bottom: round$2(rect.bottom), right: round$2(rect.right), width: round$2(rect.width), height: round$2(rect.height), } } var collapse = function (rect, toStart) { rect = clone(rect) if (toStart) { rect.right = rect.left } else { rect.left = rect.left + rect.width rect.right = rect.left } rect.width = 0 return rect } var isEqual = function (rect1, rect2) { return ( rect1.left === rect2.left && rect1.top === rect2.top && rect1.bottom === rect2.bottom && rect1.right === rect2.right ) } var isValidOverflow = function (overflowY, rect1, rect2) { return ( overflowY >= 0 && overflowY <= Math.min(rect1.height, rect2.height) / 2 ) } var isAbove$1 = function (rect1, rect2) { var halfHeight = Math.min(rect2.height / 2, rect1.height / 2) if (rect1.bottom - halfHeight < rect2.top) { return true } if (rect1.top > rect2.bottom) { return false } return isValidOverflow(rect2.top - rect1.bottom, rect1, rect2) } var isBelow$1 = function (rect1, rect2) { if (rect1.top > rect2.bottom) { return true } if (rect1.bottom < rect2.top) { return false } return isValidOverflow(rect2.bottom - rect1.top, rect1, rect2) } var containsXY = function (rect, clientX, clientY) { return ( clientX >= rect.left && clientX <= rect.right && clientY >= rect.top && clientY <= rect.bottom ) } var clamp$2 = function (value, min, max) { return Math.min(Math.max(value, min), max) } var getSelectedNode = function (range) { var startContainer = range.startContainer, startOffset = range.startOffset if (startContainer.hasChildNodes() && range.endOffset === startOffset + 1) { return startContainer.childNodes[startOffset] } return null } var getNode$1 = function (container, offset) { if (isElement$5(container) && container.hasChildNodes()) { var childNodes = container.childNodes var safeOffset = clamp$2(offset, 0, childNodes.length - 1) return childNodes[safeOffset] } else { return container } } var getNodeUnsafe = function (container, offset) { if (offset < 0 && isElement$5(container) && container.hasChildNodes()) { return undefined } else { return getNode$1(container, offset) } } var extendingChars = new RegExp( '[\u0300-\u036f\u0483-\u0487\u0488-\u0489\u0591-\u05bd\u05bf\u05c1-\u05c2\u05c4-\u05c5\u05c7\u0610-\u061a' + '\u064b-\u065f\u0670\u06d6-\u06dc\u06df-\u06e4\u06e7-\u06e8\u06ea-\u06ed\u0711\u0730-\u074a\u07a6-\u07b0' + '\u07eb-\u07f3\u0816-\u0819\u081b-\u0823\u0825-\u0827\u0829-\u082d\u0859-\u085b\u08e3-\u0902\u093a\u093c' + '\u0941-\u0948\u094d\u0951-\u0957\u0962-\u0963\u0981\u09bc\u09be\u09c1-\u09c4\u09cd\u09d7\u09e2-\u09e3' + '\u0a01-\u0a02\u0a3c\u0a41-\u0a42\u0a47-\u0a48\u0a4b-\u0a4d\u0a51\u0a70-\u0a71\u0a75\u0a81-\u0a82\u0abc' + '\u0ac1-\u0ac5\u0ac7-\u0ac8\u0acd\u0ae2-\u0ae3\u0b01\u0b3c\u0b3e\u0b3f\u0b41-\u0b44\u0b4d\u0b56\u0b57' + '\u0b62-\u0b63\u0b82\u0bbe\u0bc0\u0bcd\u0bd7\u0c00\u0c3e-\u0c40\u0c46-\u0c48\u0c4a-\u0c4d\u0c55-\u0c56' + '\u0c62-\u0c63\u0c81\u0cbc\u0cbf\u0cc2\u0cc6\u0ccc-\u0ccd\u0cd5-\u0cd6\u0ce2-\u0ce3\u0d01\u0d3e\u0d41-\u0d44' + '\u0d4d\u0d57\u0d62-\u0d63\u0dca\u0dcf\u0dd2-\u0dd4\u0dd6\u0ddf\u0e31\u0e34-\u0e3a\u0e47-\u0e4e\u0eb1\u0eb4-\u0eb9' + '\u0ebb-\u0ebc\u0ec8-\u0ecd\u0f18-\u0f19\u0f35\u0f37\u0f39\u0f71-\u0f7e\u0f80-\u0f84\u0f86-\u0f87\u0f8d-\u0f97' + '\u0f99-\u0fbc\u0fc6\u102d-\u1030\u1032-\u1037\u1039-\u103a\u103d-\u103e\u1058-\u1059\u105e-\u1060\u1071-\u1074' + '\u1082\u1085-\u1086\u108d\u109d\u135d-\u135f\u1712-\u1714\u1732-\u1734\u1752-\u1753\u1772-\u1773\u17b4-\u17b5' + '\u17b7-\u17bd\u17c6\u17c9-\u17d3\u17dd\u180b-\u180d\u18a9\u1920-\u1922\u1927-\u1928\u1932\u1939-\u193b\u1a17-\u1a18' + '\u1a1b\u1a56\u1a58-\u1a5e\u1a60\u1a62\u1a65-\u1a6c\u1a73-\u1a7c\u1a7f\u1ab0-\u1abd\u1ABE\u1b00-\u1b03\u1b34' + '\u1b36-\u1b3a\u1b3c\u1b42\u1b6b-\u1b73\u1b80-\u1b81\u1ba2-\u1ba5\u1ba8-\u1ba9\u1bab-\u1bad\u1be6\u1be8-\u1be9' + '\u1bed\u1bef-\u1bf1\u1c2c-\u1c33\u1c36-\u1c37\u1cd0-\u1cd2\u1cd4-\u1ce0\u1ce2-\u1ce8\u1ced\u1cf4\u1cf8-\u1cf9' + '\u1dc0-\u1df5\u1dfc-\u1dff\u200c-\u200d\u20d0-\u20dc\u20DD-\u20E0\u20e1\u20E2-\u20E4\u20e5-\u20f0\u2cef-\u2cf1' + '\u2d7f\u2de0-\u2dff\u302a-\u302d\u302e-\u302f\u3099-\u309a\ua66f\uA670-\uA672\ua674-\ua67d\ua69e-\ua69f\ua6f0-\ua6f1' + '\ua802\ua806\ua80b\ua825-\ua826\ua8c4\ua8e0-\ua8f1\ua926-\ua92d\ua947-\ua951\ua980-\ua982\ua9b3\ua9b6-\ua9b9\ua9bc' + '\ua9e5\uaa29-\uaa2e\uaa31-\uaa32\uaa35-\uaa36\uaa43\uaa4c\uaa7c\uaab0\uaab2-\uaab4\uaab7-\uaab8\uaabe-\uaabf\uaac1' + '\uaaec-\uaaed\uaaf6\uabe5\uabe8\uabed\ufb1e\ufe00-\ufe0f\ufe20-\ufe2f\uff9e-\uff9f]' ) var isExtendingChar = function (ch) { return ( typeof ch === 'string' && ch.charCodeAt(0) >= 768 && extendingChars.test(ch) ) } var or = function () { var args = [] for (var _i = 0; _i < arguments.length; _i++) { args[_i] = arguments[_i] } return function (x) { for (var i = 0; i < args.length; i++) { if (args[i](x)) { return true } } return false } } var and = function () { var args = [] for (var _i = 0; _i < arguments.length; _i++) { args[_i] = arguments[_i] } return function (x) { for (var i = 0; i < args.length; i++) { if (!args[i](x)) { return false } } return true } } var isElement$3 = isElement$5 var isCaretCandidate$2 = isCaretCandidate$3 var isBlock$1 = matchStyleValues('display', 'block table') var isFloated = matchStyleValues('float', 'left right') var isValidElementCaretCandidate = and( isElement$3, isCaretCandidate$2, not(isFloated) ) var isNotPre = not(matchStyleValues('white-space', 'pre pre-line pre-wrap')) var isText$4 = isText$7 var isBr$2 = isBr$5 var nodeIndex$1 = DOMUtils.nodeIndex var resolveIndex$1 = getNodeUnsafe var createRange$1 = function (doc) { return 'createRange' in doc ? doc.createRange() : DOMUtils.DOM.createRng() } var isWhiteSpace$1 = function (chr) { return chr && /[\r\n\t ]/.test(chr) } var isRange = function (rng) { return !!rng.setStart && !!rng.setEnd } var isHiddenWhiteSpaceRange = function (range) { var container = range.startContainer var offset = range.startOffset if ( isWhiteSpace$1(range.toString()) && isNotPre(container.parentNode) && isText$7(container) ) { var text = container.data if ( isWhiteSpace$1(text[offset - 1]) || isWhiteSpace$1(text[offset + 1]) ) { return true } } return false } var getBrClientRect = function (brNode) { var doc = brNode.ownerDocument var rng = createRange$1(doc) var nbsp$1 = doc.createTextNode(nbsp) var parentNode = brNode.parentNode parentNode.insertBefore(nbsp$1, brNode) rng.setStart(nbsp$1, 0) rng.setEnd(nbsp$1, 1) var clientRect = clone(rng.getBoundingClientRect()) parentNode.removeChild(nbsp$1) return clientRect } var getBoundingClientRectWebKitText = function (rng) { var sc = rng.startContainer var ec = rng.endContainer var so = rng.startOffset var eo = rng.endOffset if (sc === ec && isText$7(ec) && so === 0 && eo === 1) { var newRng = rng.cloneRange() newRng.setEndAfter(ec) return getBoundingClientRect$1(newRng) } else { return null } } var isZeroRect = function (r) { return r.left === 0 && r.right === 0 && r.top === 0 && r.bottom === 0 } var getBoundingClientRect$1 = function (item) { var clientRect var clientRects = item.getClientRects() if (clientRects.length > 0) { clientRect = clone(clientRects[0]) } else { clientRect = clone(item.getBoundingClientRect()) } if (!isRange(item) && isBr$2(item) && isZeroRect(clientRect)) { return getBrClientRect(item) } if (isZeroRect(clientRect) && isRange(item)) { return getBoundingClientRectWebKitText(item) } return clientRect } var collapseAndInflateWidth = function (clientRect, toStart) { var newClientRect = collapse(clientRect, toStart) newClientRect.width = 1 newClientRect.right = newClientRect.left + 1 return newClientRect } var getCaretPositionClientRects = function (caretPosition) { var clientRects = [] var addUniqueAndValidRect = function (clientRect) { if (clientRect.height === 0) { return } if (clientRects.length > 0) { if (isEqual(clientRect, clientRects[clientRects.length - 1])) { return } } clientRects.push(clientRect) } var addCharacterOffset = function (container, offset) { var range = createRange$1(container.ownerDocument) if (offset < container.data.length) { if (isExtendingChar(container.data[offset])) { return clientRects } if (isExtendingChar(container.data[offset - 1])) { range.setStart(container, offset) range.setEnd(container, offset + 1) if (!isHiddenWhiteSpaceRange(range)) { addUniqueAndValidRect( collapseAndInflateWidth(getBoundingClientRect$1(range), false) ) return clientRects } } } if (offset > 0) { range.setStart(container, offset - 1) range.setEnd(container, offset) if (!isHiddenWhiteSpaceRange(range)) { addUniqueAndValidRect( collapseAndInflateWidth(getBoundingClientRect$1(range), false) ) } } if (offset < container.data.length) { range.setStart(container, offset) range.setEnd(container, offset + 1) if (!isHiddenWhiteSpaceRange(range)) { addUniqueAndValidRect( collapseAndInflateWidth(getBoundingClientRect$1(range), true) ) } } } var container = caretPosition.container() var offset = caretPosition.offset() if (isText$4(container)) { addCharacterOffset(container, offset) return clientRects } if (isElement$3(container)) { if (caretPosition.isAtEnd()) { var node = resolveIndex$1(container, offset) if (isText$4(node)) { addCharacterOffset(node, node.data.length) } if (isValidElementCaretCandidate(node) && !isBr$2(node)) { addUniqueAndValidRect( collapseAndInflateWidth(getBoundingClientRect$1(node), false) ) } } else { var node = resolveIndex$1(container, offset) if (isText$4(node)) { addCharacterOffset(node, 0) } if (isValidElementCaretCandidate(node) && caretPosition.isAtEnd()) { addUniqueAndValidRect( collapseAndInflateWidth(getBoundingClientRect$1(node), false) ) return clientRects } var beforeNode = resolveIndex$1( caretPosition.container(), caretPosition.offset() - 1 ) if (isValidElementCaretCandidate(beforeNode) && !isBr$2(beforeNode)) { if ( isBlock$1(beforeNode) || isBlock$1(node) || !isValidElementCaretCandidate(node) ) { addUniqueAndValidRect( collapseAndInflateWidth( getBoundingClientRect$1(beforeNode), false ) ) } } if (isValidElementCaretCandidate(node)) { addUniqueAndValidRect( collapseAndInflateWidth(getBoundingClientRect$1(node), true) ) } } } return clientRects } var CaretPosition = function (container, offset, clientRects) { var isAtStart = function () { if (isText$4(container)) { return offset === 0 } return offset === 0 } var isAtEnd = function () { if (isText$4(container)) { return offset >= container.data.length } return offset >= container.childNodes.length } var toRange = function () { var range = createRange$1(container.ownerDocument) range.setStart(container, offset) range.setEnd(container, offset) return range } var getClientRects = function () { if (!clientRects) { clientRects = getCaretPositionClientRects( CaretPosition(container, offset) ) } return clientRects } var isVisible = function () { return getClientRects().length > 0 } var isEqual = function (caretPosition) { return ( caretPosition && container === caretPosition.container() && offset === caretPosition.offset() ) } var getNode = function (before) { return resolveIndex$1(container, before ? offset - 1 : offset) } return { container: constant(container), offset: constant(offset), toRange: toRange, getClientRects: getClientRects, isVisible: isVisible, isAtStart: isAtStart, isAtEnd: isAtEnd, isEqual: isEqual, getNode: getNode, } } CaretPosition.fromRangeStart = function (range) { return CaretPosition(range.startContainer, range.startOffset) } CaretPosition.fromRangeEnd = function (range) { return CaretPosition(range.endContainer, range.endOffset) } CaretPosition.after = function (node) { return CaretPosition(node.parentNode, nodeIndex$1(node) + 1) } CaretPosition.before = function (node) { return CaretPosition(node.parentNode, nodeIndex$1(node)) } CaretPosition.isAbove = function (pos1, pos2) { return lift2( head(pos2.getClientRects()), last$2(pos1.getClientRects()), isAbove$1 ).getOr(false) } CaretPosition.isBelow = function (pos1, pos2) { return lift2( last$2(pos2.getClientRects()), head(pos1.getClientRects()), isBelow$1 ).getOr(false) } CaretPosition.isAtStart = function (pos) { return pos ? pos.isAtStart() : false } CaretPosition.isAtEnd = function (pos) { return pos ? pos.isAtEnd() : false } CaretPosition.isTextPosition = function (pos) { return pos ? isText$7(pos.container()) : false } CaretPosition.isElementPosition = function (pos) { return CaretPosition.isTextPosition(pos) === false } var trimEmptyTextNode$1 = function (dom, node) { if (isText$7(node) && node.data.length === 0) { dom.remove(node) } } var insertNode = function (dom, rng, node) { rng.insertNode(node) trimEmptyTextNode$1(dom, node.previousSibling) trimEmptyTextNode$1(dom, node.nextSibling) } var insertFragment = function (dom, rng, frag) { var firstChild = Optional.from(frag.firstChild) var lastChild = Optional.from(frag.lastChild) rng.insertNode(frag) firstChild.each(function (child) { return trimEmptyTextNode$1(dom, child.previousSibling) }) lastChild.each(function (child) { return trimEmptyTextNode$1(dom, child.nextSibling) }) } var rangeInsertNode = function (dom, rng, node) { if (isDocumentFragment(node)) { insertFragment(dom, rng, node) } else { insertNode(dom, rng, node) } } var isText$3 = isText$7 var isBogus = isBogus$2 var nodeIndex = DOMUtils.nodeIndex var normalizedParent = function (node) { var parentNode = node.parentNode if (isBogus(parentNode)) { return normalizedParent(parentNode) } return parentNode } var getChildNodes = function (node) { if (!node) { return [] } return reduce( node.childNodes, function (result, node) { if (isBogus(node) && node.nodeName !== 'BR') { result = result.concat(getChildNodes(node)) } else { result.push(node) } return result }, [] ) } var normalizedTextOffset = function (node, offset) { while ((node = node.previousSibling)) { if (!isText$3(node)) { break } offset += node.data.length } return offset } var equal = function (a) { return function (b) { return a === b } } var normalizedNodeIndex = function (node) { var nodes, index nodes = getChildNodes(normalizedParent(node)) index = findIndex$1(nodes, equal(node), node) nodes = nodes.slice(0, index + 1) var numTextFragments = reduce( nodes, function (result, node, i) { if (isText$3(node) && isText$3(nodes[i - 1])) { result++ } return result }, 0 ) nodes = filter$2(nodes, matchNodeNames([node.nodeName])) index = findIndex$1(nodes, equal(node), node) return index - numTextFragments } var createPathItem = function (node) { var name if (isText$3(node)) { name = 'text()' } else { name = node.nodeName.toLowerCase() } return name + '[' + normalizedNodeIndex(node) + ']' } var parentsUntil$1 = function (root, node, predicate) { var parents = [] for (node = node.parentNode; node !== root; node = node.parentNode) { if (predicate && predicate(node)) { break } parents.push(node) } return parents } var create$6 = function (root, caretPosition) { var container, offset, path = [], outputOffset, childNodes, parents container = caretPosition.container() offset = caretPosition.offset() if (isText$3(container)) { outputOffset = normalizedTextOffset(container, offset) } else { childNodes = container.childNodes if (offset >= childNodes.length) { outputOffset = 'after' offset = childNodes.length - 1 } else { outputOffset = 'before' } container = childNodes[offset] } path.push(createPathItem(container)) parents = parentsUntil$1(root, container) parents = filter$2(parents, not(isBogus$2)) path = path.concat( map$1(parents, function (node) { return createPathItem(node) }) ) return path.reverse().join('/') + ',' + outputOffset } var resolvePathItem = function (node, name, index) { var nodes = getChildNodes(node) nodes = filter$2(nodes, function (node, index) { return !isText$3(node) || !isText$3(nodes[index - 1]) }) nodes = filter$2(nodes, matchNodeNames([name])) return nodes[index] } var findTextPosition = function (container, offset) { var node = container, targetOffset = 0, dataLen while (isText$3(node)) { dataLen = node.data.length if (offset >= targetOffset && offset <= targetOffset + dataLen) { container = node offset = offset - targetOffset break } if (!isText$3(node.nextSibling)) { container = node offset = dataLen break } targetOffset += dataLen node = node.nextSibling } if (isText$3(container) && offset > container.data.length) { offset = container.data.length } return CaretPosition(container, offset) } var resolve$2 = function (root, path) { var offset if (!path) { return null } var parts = path.split(',') var paths = parts[0].split('/') offset = parts.length > 1 ? parts[1] : 'before' var container = reduce( paths, function (result, value) { var match = /([\w\-\(\)]+)\[([0-9]+)\]/.exec(value) if (!match) { return null } if (match[1] === 'text()') { match[1] = '#text' } return resolvePathItem(result, match[1], parseInt(match[2], 10)) }, root ) if (!container) { return null } if (!isText$3(container)) { if (offset === 'after') { offset = nodeIndex(container) + 1 } else { offset = nodeIndex(container) } return CaretPosition(container.parentNode, offset) } return findTextPosition(container, parseInt(offset, 10)) } var isContentEditableFalse$9 = isContentEditableFalse$b var getNormalizedTextOffset = function (trim, container, offset) { var node, trimmedOffset trimmedOffset = trim(container.data.slice(0, offset)).length for ( node = container.previousSibling; node && isText$7(node); node = node.previousSibling ) { trimmedOffset += trim(node.data).length } return trimmedOffset } var getPoint = function (dom, trim, normalized, rng, start) { var container = rng[start ? 'startContainer' : 'endContainer'] var offset = rng[start ? 'startOffset' : 'endOffset'] var point = [] var childNodes, after = 0 var root = dom.getRoot() if (isText$7(container)) { point.push( normalized ? getNormalizedTextOffset(trim, container, offset) : offset ) } else { childNodes = container.childNodes if (offset >= childNodes.length && childNodes.length) { after = 1 offset = Math.max(0, childNodes.length - 1) } point.push(dom.nodeIndex(childNodes[offset], normalized) + after) } for (; container && container !== root; container = container.parentNode) { point.push(dom.nodeIndex(container, normalized)) } return point } var getLocation = function (trim, selection, normalized, rng) { var dom = selection.dom, bookmark = {} bookmark.start = getPoint(dom, trim, normalized, rng, true) if (!selection.isCollapsed()) { bookmark.end = getPoint(dom, trim, normalized, rng, false) } if (isRangeInCaretContainerBlock(rng)) { bookmark.isFakeCaret = true } return bookmark } var findIndex = function (dom, name, element) { var count = 0 Tools.each(dom.select(name), function (node) { if (node.getAttribute('data-mce-bogus') === 'all') { return } if (node === element) { return false } count++ }) return count } var moveEndPoint$1 = function (rng, start) { var container, offset, childNodes var prefix = start ? 'start' : 'end' container = rng[prefix + 'Container'] offset = rng[prefix + 'Offset'] if (isElement$5(container) && container.nodeName === 'TR') { childNodes = container.childNodes container = childNodes[Math.min(start ? offset : offset - 1, childNodes.length - 1)] if (container) { offset = start ? 0 : container.childNodes.length rng['set' + (start ? 'Start' : 'End')](container, offset) } } } var normalizeTableCellSelection = function (rng) { moveEndPoint$1(rng, true) moveEndPoint$1(rng, false) return rng } var findSibling = function (node, offset) { var sibling if (isElement$5(node)) { node = getNode$1(node, offset) if (isContentEditableFalse$9(node)) { return node } } if (isCaretContainer$2(node)) { if (isText$7(node) && isCaretContainerBlock$1(node)) { node = node.parentNode } sibling = node.previousSibling if (isContentEditableFalse$9(sibling)) { return sibling } sibling = node.nextSibling if (isContentEditableFalse$9(sibling)) { return sibling } } } var findAdjacentContentEditableFalseElm = function (rng) { return ( findSibling(rng.startContainer, rng.startOffset) || findSibling(rng.endContainer, rng.endOffset) ) } var getOffsetBookmark = function (trim, normalized, selection) { var element = selection.getNode() var name = element ? element.nodeName : null var rng = selection.getRng() if (isContentEditableFalse$9(element) || name === 'IMG') { return { name: name, index: findIndex(selection.dom, name, element), } } var sibling = findAdjacentContentEditableFalseElm(rng) if (sibling) { name = sibling.tagName return { name: name, index: findIndex(selection.dom, name, sibling), } } return getLocation(trim, selection, normalized, rng) } var getCaretBookmark = function (selection) { var rng = selection.getRng() return { start: create$6( selection.dom.getRoot(), CaretPosition.fromRangeStart(rng) ), end: create$6(selection.dom.getRoot(), CaretPosition.fromRangeEnd(rng)), } } var getRangeBookmark = function (selection) { return { rng: selection.getRng() } } var createBookmarkSpan = function (dom, id, filled) { var args = { 'data-mce-type': 'bookmark', id: id, style: 'overflow:hidden;line-height:0px', } return filled ? dom.create('span', args, '') : dom.create('span', args) } var getPersistentBookmark = function (selection, filled) { var dom = selection.dom var rng = selection.getRng() var id = dom.uniqueId() var collapsed = selection.isCollapsed() var element = selection.getNode() var name = element.nodeName if (name === 'IMG') { return { name: name, index: findIndex(dom, name, element), } } var rng2 = normalizeTableCellSelection(rng.cloneRange()) if (!collapsed) { rng2.collapse(false) var endBookmarkNode = createBookmarkSpan(dom, id + '_end', filled) rangeInsertNode(dom, rng2, endBookmarkNode) } rng = normalizeTableCellSelection(rng) rng.collapse(true) var startBookmarkNode = createBookmarkSpan(dom, id + '_start', filled) rangeInsertNode(dom, rng, startBookmarkNode) selection.moveToBookmark({ id: id, keep: true, }) return { id: id } } var getBookmark$2 = function (selection, type, normalized) { if (type === 2) { return getOffsetBookmark(trim$2, normalized, selection) } else if (type === 3) { return getCaretBookmark(selection) } else if (type) { return getRangeBookmark(selection) } else { return getPersistentBookmark(selection, false) } } var getUndoBookmark = curry(getOffsetBookmark, identity, true) var DOM$9 = DOMUtils.DOM var defaultPreviewStyles = 'font-family font-size font-weight font-style text-decoration text-transform color background-color border border-radius outline text-shadow' var getBodySetting = function (editor, name, defaultValue) { var value = editor.getParam(name, defaultValue) if (value.indexOf('=') !== -1) { var bodyObj = editor.getParam(name, '', 'hash') return get$9(bodyObj, editor.id).getOr(defaultValue) } else { return value } } var getIframeAttrs = function (editor) { return editor.getParam('iframe_attrs', {}) } var getDocType = function (editor) { return editor.getParam('doctype', '') } var getDocumentBaseUrl = function (editor) { return editor.getParam('document_base_url', '') } var getBodyId = function (editor) { return getBodySetting(editor, 'body_id', 'tinymce') } var getBodyClass = function (editor) { return getBodySetting(editor, 'body_class', '') } var getContentSecurityPolicy = function (editor) { return editor.getParam('content_security_policy', '') } var shouldPutBrInPre$1 = function (editor) { return editor.getParam('br_in_pre', true) } var getForcedRootBlock = function (editor) { if (editor.getParam('force_p_newlines', false)) { return 'p' } var block = editor.getParam('forced_root_block', 'p') if (block === false) { return '' } else if (block === true) { return 'p' } else { return block } } var getForcedRootBlockAttrs = function (editor) { return editor.getParam('forced_root_block_attrs', {}) } var getBrNewLineSelector = function (editor) { return editor.getParam( 'br_newline_selector', '.mce-toc h2,figcaption,caption' ) } var getNoNewLineSelector = function (editor) { return editor.getParam('no_newline_selector', '') } var shouldKeepStyles = function (editor) { return editor.getParam('keep_styles', true) } var shouldEndContainerOnEmptyBlock = function (editor) { return editor.getParam('end_container_on_empty_block', false) } var getFontStyleValues = function (editor) { return Tools.explode( editor.getParam( 'font_size_style_values', 'xx-small,x-small,small,medium,large,x-large,xx-large' ) ) } var getFontSizeClasses = function (editor) { return Tools.explode(editor.getParam('font_size_classes', '')) } var getImagesDataImgFilter = function (editor) { return editor.getParam('images_dataimg_filter', always, 'function') } var isAutomaticUploadsEnabled = function (editor) { return editor.getParam('automatic_uploads', true, 'boolean') } var shouldReuseFileName = function (editor) { return editor.getParam('images_reuse_filename', false, 'boolean') } var shouldReplaceBlobUris = function (editor) { return editor.getParam('images_replace_blob_uris', true, 'boolean') } var getIconPackName = function (editor) { return editor.getParam('icons', '', 'string') } var getIconsUrl = function (editor) { return editor.getParam('icons_url', '', 'string') } var getImageUploadUrl = function (editor) { return editor.getParam('images_upload_url', '', 'string') } var getImageUploadBasePath = function (editor) { return editor.getParam('images_upload_base_path', '', 'string') } var getImagesUploadCredentials = function (editor) { return editor.getParam('images_upload_credentials', false, 'boolean') } var getImagesUploadHandler = function (editor) { return editor.getParam('images_upload_handler', null, 'function') } var shouldUseContentCssCors = function (editor) { return editor.getParam('content_css_cors', false, 'boolean') } var getReferrerPolicy = function (editor) { return editor.getParam('referrer_policy', '', 'string') } var getLanguageCode = function (editor) { return editor.getParam('language', 'en', 'string') } var getLanguageUrl = function (editor) { return editor.getParam('language_url', '', 'string') } var shouldIndentUseMargin = function (editor) { return editor.getParam('indent_use_margin', false) } var getIndentation = function (editor) { return editor.getParam('indentation', '40px', 'string') } var getContentCss = function (editor) { var contentCss = editor.getParam('content_css') if (isString$1(contentCss)) { return map$3(contentCss.split(','), trim$4) } else if (isArray$1(contentCss)) { return contentCss } else if (contentCss === false || editor.inline) { return [] } else { return ['default'] } } var getFontCss = function (editor) { var fontCss = editor.getParam('font_css', []) return isArray$1(fontCss) ? fontCss : map$3(fontCss.split(','), trim$4) } var getDirectionality = function (editor) { return editor.getParam('directionality', I18n.isRtl() ? 'rtl' : undefined) } var getInlineBoundarySelector = function (editor) { return editor.getParam( 'inline_boundaries_selector', 'a[href],code,.mce-annotation', 'string' ) } var getObjectResizing = function (editor) { var selector = editor.getParam('object_resizing') if (selector === false || Env.iOS) { return false } else { return isString$1(selector) ? selector : 'table,img,figure.image,div,video,iframe' } } var getResizeImgProportional = function (editor) { return editor.getParam('resize_img_proportional', true, 'boolean') } var getPlaceholder = function (editor) { return editor.getParam( 'placeholder', DOM$9.getAttrib(editor.getElement(), 'placeholder'), 'string' ) } var getEventRoot = function (editor) { return editor.getParam('event_root') } var getServiceMessage = function (editor) { return editor.getParam('service_message') } var getTheme = function (editor) { return editor.getParam('theme') } var shouldValidate = function (editor) { return editor.getParam('validate') } var isInlineBoundariesEnabled = function (editor) { return editor.getParam('inline_boundaries') !== false } var getFormats = function (editor) { return editor.getParam('formats') } var getPreviewStyles = function (editor) { var style = editor.getParam('preview_styles', defaultPreviewStyles) if (isString$1(style)) { return style } else { return '' } } var canFormatEmptyLines = function (editor) { return editor.getParam('format_empty_lines', false, 'boolean') } var getCustomUiSelector = function (editor) { return editor.getParam('custom_ui_selector', '', 'string') } var getThemeUrl = function (editor) { return editor.getParam('theme_url') } var isInline = function (editor) { return editor.getParam('inline') } var hasHiddenInput = function (editor) { return editor.getParam('hidden_input') } var shouldPatchSubmit = function (editor) { return editor.getParam('submit_patch') } var isEncodingXml = function (editor) { return editor.getParam('encoding') === 'xml' } var shouldAddFormSubmitTrigger = function (editor) { return editor.getParam('add_form_submit_trigger') } var shouldAddUnloadTrigger = function (editor) { return editor.getParam('add_unload_trigger') } var hasForcedRootBlock = function (editor) { return getForcedRootBlock(editor) !== '' } var getCustomUndoRedoLevels = function (editor) { return editor.getParam('custom_undo_redo_levels', 0, 'number') } var shouldDisableNodeChange = function (editor) { return editor.getParam('disable_nodechange') } var isReadOnly$1 = function (editor) { return editor.getParam('readonly') } var hasContentCssCors = function (editor) { return editor.getParam('content_css_cors') } var getPlugins = function (editor) { return editor.getParam('plugins', '', 'string') } var getExternalPlugins$1 = function (editor) { return editor.getParam('external_plugins') } var shouldBlockUnsupportedDrop = function (editor) { return editor.getParam('block_unsupported_drop', true, 'boolean') } var isVisualAidsEnabled = function (editor) { return editor.getParam('visual', true, 'boolean') } var getVisualAidsTableClass = function (editor) { return editor.getParam('visual_table_class', 'mce-item-table', 'string') } var getVisualAidsAnchorClass = function (editor) { return editor.getParam('visual_anchor_class', 'mce-item-anchor', 'string') } var getIframeAriaText = function (editor) { return editor.getParam( 'iframe_aria_text', 'Rich Text Area. Press ALT-0 for help.', 'string' ) } var isElement$2 = isElement$5 var isText$2 = isText$7 var removeNode$1 = function (node) { var parentNode = node.parentNode if (parentNode) { parentNode.removeChild(node) } } var trimCount = function (text) { var trimmedText = trim$2(text) return { count: text.length - trimmedText.length, text: trimmedText, } } var deleteZwspChars = function (caretContainer) { var idx while ((idx = caretContainer.data.lastIndexOf(ZWSP$1)) !== -1) { caretContainer.deleteData(idx, 1) } } var removeUnchanged = function (caretContainer, pos) { remove$2(caretContainer) return pos } var removeTextAndReposition = function (caretContainer, pos) { var before = trimCount(caretContainer.data.substr(0, pos.offset())) var after = trimCount(caretContainer.data.substr(pos.offset())) var text = before.text + after.text if (text.length > 0) { deleteZwspChars(caretContainer) return CaretPosition(caretContainer, pos.offset() - before.count) } else { return pos } } var removeElementAndReposition = function (caretContainer, pos) { var parentNode = pos.container() var newPosition = indexOf$2(from(parentNode.childNodes), caretContainer) .map(function (index) { return index < pos.offset() ? CaretPosition(parentNode, pos.offset() - 1) : pos }) .getOr(pos) remove$2(caretContainer) return newPosition } var removeTextCaretContainer = function (caretContainer, pos) { return isText$2(caretContainer) && pos.container() === caretContainer ? removeTextAndReposition(caretContainer, pos) : removeUnchanged(caretContainer, pos) } var removeElementCaretContainer = function (caretContainer, pos) { return pos.container() === caretContainer.parentNode ? removeElementAndReposition(caretContainer, pos) : removeUnchanged(caretContainer, pos) } var removeAndReposition = function (container, pos) { return CaretPosition.isTextPosition(pos) ? removeTextCaretContainer(container, pos) : removeElementCaretContainer(container, pos) } var remove$2 = function (caretContainerNode) { if ( isElement$2(caretContainerNode) && isCaretContainer$2(caretContainerNode) ) { if (hasContent(caretContainerNode)) { caretContainerNode.removeAttribute('data-mce-caret') } else { removeNode$1(caretContainerNode) } } if (isText$2(caretContainerNode)) { deleteZwspChars(caretContainerNode) if (caretContainerNode.data.length === 0) { removeNode$1(caretContainerNode) } } } var browser$2 = detect().browser var isContentEditableFalse$8 = isContentEditableFalse$b var isMedia$1 = isMedia$2 var isTableCell$3 = isTableCell$5 var inlineFakeCaretSelector = '*[contentEditable=false],video,audio,embed,object' var getAbsoluteClientRect = function (root, element, before) { var clientRect = collapse(element.getBoundingClientRect(), before) var scrollX var scrollY if (root.tagName === 'BODY') { var docElm = root.ownerDocument.documentElement scrollX = root.scrollLeft || docElm.scrollLeft scrollY = root.scrollTop || docElm.scrollTop } else { var rootRect = root.getBoundingClientRect() scrollX = root.scrollLeft - rootRect.left scrollY = root.scrollTop - rootRect.top } clientRect.left += scrollX clientRect.right += scrollX clientRect.top += scrollY clientRect.bottom += scrollY clientRect.width = 1 var margin = element.offsetWidth - element.clientWidth if (margin > 0) { if (before) { margin *= -1 } clientRect.left += margin clientRect.right += margin } return clientRect } var trimInlineCaretContainers = function (root) { var fakeCaretTargetNodes = descendants( SugarElement.fromDom(root), inlineFakeCaretSelector ) for (var i = 0; i < fakeCaretTargetNodes.length; i++) { var node = fakeCaretTargetNodes[i].dom var sibling = node.previousSibling if (endsWithCaretContainer$1(sibling)) { var data = sibling.data if (data.length === 1) { sibling.parentNode.removeChild(sibling) } else { sibling.deleteData(data.length - 1, 1) } } sibling = node.nextSibling if (startsWithCaretContainer$1(sibling)) { var data = sibling.data if (data.length === 1) { sibling.parentNode.removeChild(sibling) } else { sibling.deleteData(0, 1) } } } } var FakeCaret = function (editor, root, isBlock, hasFocus) { var lastVisualCaret = value() var cursorInterval var caretContainerNode var rootBlock = getForcedRootBlock(editor) var caretBlock = rootBlock.length > 0 ? rootBlock : 'p' var show = function (before, element) { var rng hide() if (isTableCell$3(element)) { return null } if (isBlock(element)) { caretContainerNode = insertBlock$1(caretBlock, element, before) var clientRect = getAbsoluteClientRect(root, element, before) DomQuery(caretContainerNode).css('top', clientRect.top) var caret = DomQuery( '
' ) .css(__assign({}, clientRect)) .appendTo(root)[0] lastVisualCaret.set({ caret: caret, element: element, before: before, }) if (before) { DomQuery(caret).addClass('mce-visual-caret-before') } startBlink() rng = element.ownerDocument.createRange() rng.setStart(caretContainerNode, 0) rng.setEnd(caretContainerNode, 0) } else { caretContainerNode = insertInline$1(element, before) rng = element.ownerDocument.createRange() if (isInlineFakeCaretTarget(caretContainerNode.nextSibling)) { rng.setStart(caretContainerNode, 0) rng.setEnd(caretContainerNode, 0) } else { rng.setStart(caretContainerNode, 1) rng.setEnd(caretContainerNode, 1) } return rng } return rng } var hide = function () { trimInlineCaretContainers(root) if (caretContainerNode) { remove$2(caretContainerNode) caretContainerNode = null } lastVisualCaret.on(function (caretState) { DomQuery(caretState.caret).remove() lastVisualCaret.clear() }) if (cursorInterval) { Delay.clearInterval(cursorInterval) cursorInterval = undefined } } var startBlink = function () { cursorInterval = Delay.setInterval(function () { if (hasFocus()) { DomQuery('div.mce-visual-caret', root).toggleClass( 'mce-visual-caret-hidden' ) } else { DomQuery('div.mce-visual-caret', root).addClass( 'mce-visual-caret-hidden' ) } }, 500) } var reposition = function () { lastVisualCaret.on(function (caretState) { var clientRect = getAbsoluteClientRect( root, caretState.element, caretState.before ) DomQuery(caretState.caret).css(__assign({}, clientRect)) }) } var destroy = function () { return Delay.clearInterval(cursorInterval) } var getCss = function () { return ( '.mce-visual-caret {' + 'position: absolute;' + 'background-color: black;' + 'background-color: currentcolor;' + '}' + '.mce-visual-caret-hidden {' + 'display: none;' + '}' + '*[data-mce-caret] {' + 'position: absolute;' + 'left: -1000px;' + 'right: auto;' + 'top: 0;' + 'margin: 0;' + 'padding: 0;' + '}' ) } return { show: show, hide: hide, getCss: getCss, reposition: reposition, destroy: destroy, } } var isFakeCaretTableBrowser = function () { return browser$2.isIE() || browser$2.isEdge() || browser$2.isFirefox() } var isInlineFakeCaretTarget = function (node) { return isContentEditableFalse$8(node) || isMedia$1(node) } var isFakeCaretTarget = function (node) { return ( isInlineFakeCaretTarget(node) || (isTable$3(node) && isFakeCaretTableBrowser()) ) } var isContentEditableFalse$7 = isContentEditableFalse$b var isMedia = isMedia$2 var isBlockLike = matchStyleValues( 'display', 'block table table-cell table-caption list-item' ) var isCaretContainer = isCaretContainer$2 var isCaretContainerBlock = isCaretContainerBlock$1 var isElement$1 = isElement$5 var isCaretCandidate$1 = isCaretCandidate$3 var isForwards = function (direction) { return direction > 0 } var isBackwards = function (direction) { return direction < 0 } var skipCaretContainers = function (walk, shallow) { var node while ((node = walk(shallow))) { if (!isCaretContainerBlock(node)) { return node } } return null } var findNode$1 = function (node, direction, predicateFn, rootNode, shallow) { var walker = new DomTreeWalker(node, rootNode) var isCefOrCaretContainer = isContentEditableFalse$7(node) || isCaretContainerBlock(node) if (isBackwards(direction)) { if (isCefOrCaretContainer) { node = skipCaretContainers(walker.prev.bind(walker), true) if (predicateFn(node)) { return node } } while ((node = skipCaretContainers(walker.prev.bind(walker), shallow))) { if (predicateFn(node)) { return node } } } if (isForwards(direction)) { if (isCefOrCaretContainer) { node = skipCaretContainers(walker.next.bind(walker), true) if (predicateFn(node)) { return node } } while ((node = skipCaretContainers(walker.next.bind(walker), shallow))) { if (predicateFn(node)) { return node } } } return null } var getParentBlock$2 = function (node, rootNode) { while (node && node !== rootNode) { if (isBlockLike(node)) { return node } node = node.parentNode } return null } var isInSameBlock = function (caretPosition1, caretPosition2, rootNode) { return ( getParentBlock$2(caretPosition1.container(), rootNode) === getParentBlock$2(caretPosition2.container(), rootNode) ) } var getChildNodeAtRelativeOffset = function (relativeOffset, caretPosition) { if (!caretPosition) { return null } var container = caretPosition.container() var offset = caretPosition.offset() if (!isElement$1(container)) { return null } return container.childNodes[offset + relativeOffset] } var beforeAfter = function (before, node) { var range = node.ownerDocument.createRange() if (before) { range.setStartBefore(node) range.setEndBefore(node) } else { range.setStartAfter(node) range.setEndAfter(node) } return range } var isNodesInSameBlock = function (root, node1, node2) { return getParentBlock$2(node1, root) === getParentBlock$2(node2, root) } var lean = function (left, root, node) { var siblingName = left ? 'previousSibling' : 'nextSibling' while (node && node !== root) { var sibling = node[siblingName] if (isCaretContainer(sibling)) { sibling = sibling[siblingName] } if (isContentEditableFalse$7(sibling) || isMedia(sibling)) { if (isNodesInSameBlock(root, sibling, node)) { return sibling } break } if (isCaretCandidate$1(sibling)) { break } node = node.parentNode } return null } var before$2 = curry(beforeAfter, true) var after$2 = curry(beforeAfter, false) var normalizeRange = function (direction, root, range) { var node var leanLeft = curry(lean, true, root) var leanRight = curry(lean, false, root) var container = range.startContainer var offset = range.startOffset if (isCaretContainerBlock$1(container)) { if (!isElement$1(container)) { container = container.parentNode } var location_1 = container.getAttribute('data-mce-caret') if (location_1 === 'before') { node = container.nextSibling if (isFakeCaretTarget(node)) { return before$2(node) } } if (location_1 === 'after') { node = container.previousSibling if (isFakeCaretTarget(node)) { return after$2(node) } } } if (!range.collapsed) { return range } if (isText$7(container)) { if (isCaretContainer(container)) { if (direction === 1) { node = leanRight(container) if (node) { return before$2(node) } node = leanLeft(container) if (node) { return after$2(node) } } if (direction === -1) { node = leanLeft(container) if (node) { return after$2(node) } node = leanRight(container) if (node) { return before$2(node) } } return range } if ( endsWithCaretContainer$1(container) && offset >= container.data.length - 1 ) { if (direction === 1) { node = leanRight(container) if (node) { return before$2(node) } } return range } if (startsWithCaretContainer$1(container) && offset <= 1) { if (direction === -1) { node = leanLeft(container) if (node) { return after$2(node) } } return range } if (offset === container.data.length) { node = leanRight(container) if (node) { return before$2(node) } return range } if (offset === 0) { node = leanLeft(container) if (node) { return after$2(node) } return range } } return range } var getRelativeCefElm = function (forward, caretPosition) { return Optional.from( getChildNodeAtRelativeOffset(forward ? 0 : -1, caretPosition) ).filter(isContentEditableFalse$7) } var getNormalizedRangeEndPoint = function (direction, root, range) { var normalizedRange = normalizeRange(direction, root, range) if (direction === -1) { return CaretPosition.fromRangeStart(normalizedRange) } return CaretPosition.fromRangeEnd(normalizedRange) } var getElementFromPosition = function (pos) { return Optional.from(pos.getNode()).map(SugarElement.fromDom) } var getElementFromPrevPosition = function (pos) { return Optional.from(pos.getNode(true)).map(SugarElement.fromDom) } var getVisualCaretPosition = function (walkFn, caretPosition) { while ((caretPosition = walkFn(caretPosition))) { if (caretPosition.isVisible()) { return caretPosition } } return caretPosition } var isMoveInsideSameBlock = function (from, to) { var inSameBlock = isInSameBlock(from, to) if (!inSameBlock && isBr$5(from.getNode())) { return true } return inSameBlock } var HDirection ;(function (HDirection) { HDirection[(HDirection['Backwards'] = -1)] = 'Backwards' HDirection[(HDirection['Forwards'] = 1)] = 'Forwards' })(HDirection || (HDirection = {})) var isContentEditableFalse$6 = isContentEditableFalse$b var isText$1 = isText$7 var isElement = isElement$5 var isBr$1 = isBr$5 var isCaretCandidate = isCaretCandidate$3 var isAtomic = isAtomic$1 var isEditableCaretCandidate = isEditableCaretCandidate$1 var getParents$3 = function (node, root) { var parents = [] while (node && node !== root) { parents.push(node) node = node.parentNode } return parents } var nodeAtIndex = function (container, offset) { if (container.hasChildNodes() && offset < container.childNodes.length) { return container.childNodes[offset] } return null } var getCaretCandidatePosition = function (direction, node) { if (isForwards(direction)) { if ( isCaretCandidate(node.previousSibling) && !isText$1(node.previousSibling) ) { return CaretPosition.before(node) } if (isText$1(node)) { return CaretPosition(node, 0) } } if (isBackwards(direction)) { if (isCaretCandidate(node.nextSibling) && !isText$1(node.nextSibling)) { return CaretPosition.after(node) } if (isText$1(node)) { return CaretPosition(node, node.data.length) } } if (isBackwards(direction)) { if (isBr$1(node)) { return CaretPosition.before(node) } return CaretPosition.after(node) } return CaretPosition.before(node) } var moveForwardFromBr = function (root, nextNode) { var nextSibling = nextNode.nextSibling if (nextSibling && isCaretCandidate(nextSibling)) { if (isText$1(nextSibling)) { return CaretPosition(nextSibling, 0) } else { return CaretPosition.before(nextSibling) } } else { return findCaretPosition$1( HDirection.Forwards, CaretPosition.after(nextNode), root ) } } var findCaretPosition$1 = function (direction, startPos, root) { var node var nextNode var innerNode var caretPosition if (!isElement(root) || !startPos) { return null } if (startPos.isEqual(CaretPosition.after(root)) && root.lastChild) { caretPosition = CaretPosition.after(root.lastChild) if ( isBackwards(direction) && isCaretCandidate(root.lastChild) && isElement(root.lastChild) ) { return isBr$1(root.lastChild) ? CaretPosition.before(root.lastChild) : caretPosition } } else { caretPosition = startPos } var container = caretPosition.container() var offset = caretPosition.offset() if (isText$1(container)) { if (isBackwards(direction) && offset > 0) { return CaretPosition(container, --offset) } if (isForwards(direction) && offset < container.length) { return CaretPosition(container, ++offset) } node = container } else { if (isBackwards(direction) && offset > 0) { nextNode = nodeAtIndex(container, offset - 1) if (isCaretCandidate(nextNode)) { if (!isAtomic(nextNode)) { innerNode = findNode$1( nextNode, direction, isEditableCaretCandidate, nextNode ) if (innerNode) { if (isText$1(innerNode)) { return CaretPosition(innerNode, innerNode.data.length) } return CaretPosition.after(innerNode) } } if (isText$1(nextNode)) { return CaretPosition(nextNode, nextNode.data.length) } return CaretPosition.before(nextNode) } } if (isForwards(direction) && offset < container.childNodes.length) { nextNode = nodeAtIndex(container, offset) if (isCaretCandidate(nextNode)) { if (isBr$1(nextNode)) { return moveForwardFromBr(root, nextNode) } if (!isAtomic(nextNode)) { innerNode = findNode$1( nextNode, direction, isEditableCaretCandidate, nextNode ) if (innerNode) { if (isText$1(innerNode)) { return CaretPosition(innerNode, 0) } return CaretPosition.before(innerNode) } } if (isText$1(nextNode)) { return CaretPosition(nextNode, 0) } return CaretPosition.after(nextNode) } } node = nextNode ? nextNode : caretPosition.getNode() } if ( (isForwards(direction) && caretPosition.isAtEnd()) || (isBackwards(direction) && caretPosition.isAtStart()) ) { node = findNode$1(node, direction, always, root, true) if (isEditableCaretCandidate(node, root)) { return getCaretCandidatePosition(direction, node) } } nextNode = findNode$1(node, direction, isEditableCaretCandidate, root) var rootContentEditableFalseElm = last$1( filter$4(getParents$3(container, root), isContentEditableFalse$6) ) if ( rootContentEditableFalseElm && (!nextNode || !rootContentEditableFalseElm.contains(nextNode)) ) { if (isForwards(direction)) { caretPosition = CaretPosition.after(rootContentEditableFalseElm) } else { caretPosition = CaretPosition.before(rootContentEditableFalseElm) } return caretPosition } if (nextNode) { return getCaretCandidatePosition(direction, nextNode) } return null } var CaretWalker = function (root) { return { next: function (caretPosition) { return findCaretPosition$1(HDirection.Forwards, caretPosition, root) }, prev: function (caretPosition) { return findCaretPosition$1(HDirection.Backwards, caretPosition, root) }, } } var walkToPositionIn = function (forward, root, start) { var position = forward ? CaretPosition.before(start) : CaretPosition.after(start) return fromPosition(forward, root, position) } var afterElement = function (node) { return isBr$5(node) ? CaretPosition.before(node) : CaretPosition.after(node) } var isBeforeOrStart = function (position) { if (CaretPosition.isTextPosition(position)) { return position.offset() === 0 } else { return isCaretCandidate$3(position.getNode()) } } var isAfterOrEnd = function (position) { if (CaretPosition.isTextPosition(position)) { var container = position.container() return position.offset() === container.data.length } else { return isCaretCandidate$3(position.getNode(true)) } } var isBeforeAfterSameElement = function (from, to) { return ( !CaretPosition.isTextPosition(from) && !CaretPosition.isTextPosition(to) && from.getNode() === to.getNode(true) ) } var isAtBr = function (position) { return !CaretPosition.isTextPosition(position) && isBr$5(position.getNode()) } var shouldSkipPosition = function (forward, from, to) { if (forward) { return ( !isBeforeAfterSameElement(from, to) && !isAtBr(from) && isAfterOrEnd(from) && isBeforeOrStart(to) ) } else { return ( !isBeforeAfterSameElement(to, from) && isBeforeOrStart(from) && isAfterOrEnd(to) ) } } var fromPosition = function (forward, root, pos) { var walker = CaretWalker(root) return Optional.from(forward ? walker.next(pos) : walker.prev(pos)) } var navigate = function (forward, root, from) { return fromPosition(forward, root, from).bind(function (to) { if ( isInSameBlock(from, to, root) && shouldSkipPosition(forward, from, to) ) { return fromPosition(forward, root, to) } else { return Optional.some(to) } }) } var navigateIgnore = function (forward, root, from, ignoreFilter) { return navigate(forward, root, from).bind(function (pos) { return ignoreFilter(pos) ? navigateIgnore(forward, root, pos, ignoreFilter) : Optional.some(pos) }) } var positionIn = function (forward, element) { var startNode = forward ? element.firstChild : element.lastChild if (isText$7(startNode)) { return Optional.some( CaretPosition(startNode, forward ? 0 : startNode.data.length) ) } else if (startNode) { if (isCaretCandidate$3(startNode)) { return Optional.some( forward ? CaretPosition.before(startNode) : afterElement(startNode) ) } else { return walkToPositionIn(forward, element, startNode) } } else { return Optional.none() } } var nextPosition = curry(fromPosition, true) var prevPosition = curry(fromPosition, false) var firstPositionIn = curry(positionIn, true) var lastPositionIn = curry(positionIn, false) var CARET_ID$1 = '_mce_caret' var isCaretNode = function (node) { return isElement$5(node) && node.id === CARET_ID$1 } var getParentCaretContainer = function (body, node) { while (node && node !== body) { if (node.id === CARET_ID$1) { return node } node = node.parentNode } return null } var isStringPathBookmark = function (bookmark) { return isString$1(bookmark.start) } var isRangeBookmark = function (bookmark) { return has$2(bookmark, 'rng') } var isIdBookmark = function (bookmark) { return has$2(bookmark, 'id') } var isIndexBookmark = function (bookmark) { return has$2(bookmark, 'name') } var isPathBookmark = function (bookmark) { return Tools.isArray(bookmark.start) } var addBogus = function (dom, node) { if (isElement$5(node) && dom.isBlock(node) && !node.innerHTML && !Env.ie) { node.innerHTML = '
' } return node } var resolveCaretPositionBookmark = function (dom, bookmark) { var pos var rng = dom.createRng() pos = resolve$2(dom.getRoot(), bookmark.start) rng.setStart(pos.container(), pos.offset()) pos = resolve$2(dom.getRoot(), bookmark.end) rng.setEnd(pos.container(), pos.offset()) return rng } var insertZwsp = function (node, rng) { var textNode = node.ownerDocument.createTextNode(ZWSP$1) node.appendChild(textNode) rng.setStart(textNode, 0) rng.setEnd(textNode, 0) } var isEmpty$1 = function (node) { return node.hasChildNodes() === false } var tryFindRangePosition = function (node, rng) { return lastPositionIn(node).fold(never, function (pos) { rng.setStart(pos.container(), pos.offset()) rng.setEnd(pos.container(), pos.offset()) return true }) } var padEmptyCaretContainer = function (root, node, rng) { if (isEmpty$1(node) && getParentCaretContainer(root, node)) { insertZwsp(node, rng) return true } else { return false } } var setEndPoint = function (dom, start, bookmark, rng) { var point = bookmark[start ? 'start' : 'end'] var i, node, offset, children var root = dom.getRoot() if (point) { offset = point[0] for (node = root, i = point.length - 1; i >= 1; i--) { children = node.childNodes if (padEmptyCaretContainer(root, node, rng)) { return true } if (point[i] > children.length - 1) { if (padEmptyCaretContainer(root, node, rng)) { return true } return tryFindRangePosition(node, rng) } node = children[point[i]] } if (node.nodeType === 3) { offset = Math.min(point[0], node.nodeValue.length) } if (node.nodeType === 1) { offset = Math.min(point[0], node.childNodes.length) } if (start) { rng.setStart(node, offset) } else { rng.setEnd(node, offset) } } return true } var isValidTextNode = function (node) { return isText$7(node) && node.data.length > 0 } var restoreEndPoint = function (dom, suffix, bookmark) { var marker = dom.get(bookmark.id + '_' + suffix), node, idx, next, prev var keep = bookmark.keep var container, offset if (marker) { node = marker.parentNode if (suffix === 'start') { if (!keep) { idx = dom.nodeIndex(marker) } else { if (marker.hasChildNodes()) { node = marker.firstChild idx = 1 } else if (isValidTextNode(marker.nextSibling)) { node = marker.nextSibling idx = 0 } else if (isValidTextNode(marker.previousSibling)) { node = marker.previousSibling idx = marker.previousSibling.data.length } else { node = marker.parentNode idx = dom.nodeIndex(marker) + 1 } } container = node offset = idx } else { if (!keep) { idx = dom.nodeIndex(marker) } else { if (marker.hasChildNodes()) { node = marker.firstChild idx = 1 } else if (isValidTextNode(marker.previousSibling)) { node = marker.previousSibling idx = marker.previousSibling.data.length } else { node = marker.parentNode idx = dom.nodeIndex(marker) } } container = node offset = idx } if (!keep) { prev = marker.previousSibling next = marker.nextSibling Tools.each(Tools.grep(marker.childNodes), function (node) { if (isText$7(node)) { node.nodeValue = node.nodeValue.replace(/\uFEFF/g, '') } }) while ((marker = dom.get(bookmark.id + '_' + suffix))) { dom.remove(marker, true) } if ( prev && next && prev.nodeType === next.nodeType && isText$7(prev) && !Env.opera ) { idx = prev.nodeValue.length prev.appendData(next.nodeValue) dom.remove(next) container = prev offset = idx } } return Optional.some(CaretPosition(container, offset)) } else { return Optional.none() } } var resolvePaths = function (dom, bookmark) { var rng = dom.createRng() if ( setEndPoint(dom, true, bookmark, rng) && setEndPoint(dom, false, bookmark, rng) ) { return Optional.some(rng) } else { return Optional.none() } } var resolveId = function (dom, bookmark) { var startPos = restoreEndPoint(dom, 'start', bookmark) var endPos = restoreEndPoint(dom, 'end', bookmark) return lift2(startPos, endPos.or(startPos), function (spos, epos) { var rng = dom.createRng() rng.setStart(addBogus(dom, spos.container()), spos.offset()) rng.setEnd(addBogus(dom, epos.container()), epos.offset()) return rng }) } var resolveIndex = function (dom, bookmark) { return Optional.from(dom.select(bookmark.name)[bookmark.index]).map( function (elm) { var rng = dom.createRng() rng.selectNode(elm) return rng } ) } var resolve$1 = function (selection, bookmark) { var dom = selection.dom if (bookmark) { if (isPathBookmark(bookmark)) { return resolvePaths(dom, bookmark) } else if (isStringPathBookmark(bookmark)) { return Optional.some(resolveCaretPositionBookmark(dom, bookmark)) } else if (isIdBookmark(bookmark)) { return resolveId(dom, bookmark) } else if (isIndexBookmark(bookmark)) { return resolveIndex(dom, bookmark) } else if (isRangeBookmark(bookmark)) { return Optional.some(bookmark.rng) } } return Optional.none() } var getBookmark$1 = function (selection, type, normalized) { return getBookmark$2(selection, type, normalized) } var moveToBookmark = function (selection, bookmark) { resolve$1(selection, bookmark).each(function (rng) { selection.setRng(rng) }) } var isBookmarkNode$1 = function (node) { return ( isElement$5(node) && node.tagName === 'SPAN' && node.getAttribute('data-mce-type') === 'bookmark' ) } var is = function (expected) { return function (actual) { return expected === actual } } var isNbsp = is(nbsp) var isWhiteSpace = function (chr) { return chr !== '' && ' \f\n\r\t\x0B'.indexOf(chr) !== -1 } var isContent = function (chr) { return !isWhiteSpace(chr) && !isNbsp(chr) } var isNode = function (node) { return !!node.nodeType } var isInlineBlock = function (node) { return node && /^(IMG)$/.test(node.nodeName) } var moveStart = function (dom, selection, rng) { var offset = rng.startOffset var container = rng.startContainer if (container === rng.endContainer) { if (isInlineBlock(container.childNodes[offset])) { return } } if (isElement$5(container)) { var nodes = container.childNodes var walker = void 0 if (offset < nodes.length) { container = nodes[offset] walker = new DomTreeWalker( container, dom.getParent(container, dom.isBlock) ) } else { container = nodes[nodes.length - 1] walker = new DomTreeWalker( container, dom.getParent(container, dom.isBlock) ) walker.next(true) } for (var node = walker.current(); node; node = walker.next()) { if (isText$7(node) && !isWhiteSpaceNode$1(node)) { rng.setStart(node, 0) selection.setRng(rng) return } } } } var getNonWhiteSpaceSibling = function (node, next, inc) { if (node) { var nextName = next ? 'nextSibling' : 'previousSibling' for (node = inc ? node : node[nextName]; node; node = node[nextName]) { if (isElement$5(node) || !isWhiteSpaceNode$1(node)) { return node } } } } var isTextBlock$1 = function (editor, name) { if (isNode(name)) { name = name.nodeName } return !!editor.schema.getTextBlockElements()[name.toLowerCase()] } var isValid = function (ed, parent, child) { return ed.schema.isValidChild(parent, child) } var isWhiteSpaceNode$1 = function (node, allowSpaces) { if (allowSpaces === void 0) { allowSpaces = false } if (isNonNullable(node) && isText$7(node)) { var data = allowSpaces ? node.data.replace(/ /g, '\xA0') : node.data return isWhitespaceText(data) } else { return false } } var isEmptyTextNode$1 = function (node) { return isNonNullable(node) && isText$7(node) && node.length === 0 } var replaceVars = function (value, vars) { if (isFunction(value)) { value = value(vars) } else if (isNonNullable(vars)) { value = value.replace(/%(\w+)/g, function (str, name) { return vars[name] || str }) } return value } var isEq$5 = function (str1, str2) { str1 = str1 || '' str2 = str2 || '' str1 = '' + (str1.nodeName || str1) str2 = '' + (str2.nodeName || str2) return str1.toLowerCase() === str2.toLowerCase() } var normalizeStyleValue = function (dom, value, name) { if (name === 'color' || name === 'backgroundColor') { value = dom.toHex(value) } if (name === 'fontWeight' && value === 700) { value = 'bold' } if (name === 'fontFamily') { value = value.replace(/[\'\"]/g, '').replace(/,\s+/g, ',') } return '' + value } var getStyle = function (dom, node, name) { return normalizeStyleValue(dom, dom.getStyle(node, name), name) } var getTextDecoration = function (dom, node) { var decoration dom.getParent(node, function (n) { decoration = dom.getStyle(n, 'text-decoration') return decoration && decoration !== 'none' }) return decoration } var getParents$2 = function (dom, node, selector) { return dom.getParents(node, selector, dom.getRoot()) } var isVariableFormatName = function (editor, formatName) { var hasVariableValues = function (format) { var isVariableValue = function (val) { return val.length > 1 && val.charAt(0) === '%' } return exists(['styles', 'attributes'], function (key) { return get$9(format, key).exists(function (field) { var fieldValues = isArray$1(field) ? field : values(field) return exists(fieldValues, isVariableValue) }) }) } return exists(editor.formatter.get(formatName), hasVariableValues) } var areSimilarFormats = function (editor, formatName, otherFormatName) { var validKeys = [ 'inline', 'block', 'selector', 'attributes', 'styles', 'classes', ] var filterObj = function (format) { return filter$3(format, function (_, key) { return exists(validKeys, function (validKey) { return validKey === key }) }) } return exists(editor.formatter.get(formatName), function (fmt1) { var filteredFmt1 = filterObj(fmt1) return exists(editor.formatter.get(otherFormatName), function (fmt2) { var filteredFmt2 = filterObj(fmt2) return equal$1(filteredFmt1, filteredFmt2) }) }) } var isBlockFormat = function (format) { return hasNonNullableKey(format, 'block') } var isSelectorFormat = function (format) { return hasNonNullableKey(format, 'selector') } var isInlineFormat = function (format) { return hasNonNullableKey(format, 'inline') } var isMixedFormat = function (format) { return ( isSelectorFormat(format) && isInlineFormat(format) && is$1(get$9(format, 'mixed'), true) ) } var shouldExpandToSelector = function (format) { return ( isSelectorFormat(format) && format.expand !== false && !isInlineFormat(format) ) } var isBookmarkNode = isBookmarkNode$1 var getParents$1 = getParents$2 var isWhiteSpaceNode = isWhiteSpaceNode$1 var isTextBlock = isTextBlock$1 var isBogusBr = function (node) { return ( isBr$5(node) && node.getAttribute('data-mce-bogus') && !node.nextSibling ) } var findParentContentEditable = function (dom, node) { var parent = node while (parent) { if (isElement$5(parent) && dom.getContentEditable(parent)) { return dom.getContentEditable(parent) === 'false' ? parent : node } parent = parent.parentNode } return node } var walkText = function (start, node, offset, predicate) { var str = node.data for (var i = offset; start ? i >= 0 : i < str.length; start ? i-- : i++) { if (predicate(str.charAt(i))) { return start ? i + 1 : i } } return -1 } var findSpace = function (start, node, offset) { return walkText(start, node, offset, function (c) { return isNbsp(c) || isWhiteSpace(c) }) } var findContent = function (start, node, offset) { return walkText(start, node, offset, isContent) } var findWordEndPoint = function ( dom, body, container, offset, start, includeTrailingSpaces ) { var lastTextNode var rootNode = dom.getParent(container, dom.isBlock) || body var walk = function (container, offset, pred) { var textSeeker = TextSeeker(dom) var walker = start ? textSeeker.backwards : textSeeker.forwards return Optional.from( walker( container, offset, function (text, textOffset) { if (isBookmarkNode(text.parentNode)) { return -1 } else { lastTextNode = text return pred(start, text, textOffset) } }, rootNode ) ) } var spaceResult = walk(container, offset, findSpace) return spaceResult .bind(function (result) { return includeTrailingSpaces ? walk( result.container, result.offset + (start ? -1 : 0), findContent ) : Optional.some(result) }) .orThunk(function () { return lastTextNode ? Optional.some({ container: lastTextNode, offset: start ? 0 : lastTextNode.length, }) : Optional.none() }) } var findSelectorEndPoint = function ( dom, formatList, rng, container, siblingName ) { if ( isText$7(container) && isEmpty$3(container.data) && container[siblingName] ) { container = container[siblingName] } var parents = getParents$1(dom, container) for (var i = 0; i < parents.length; i++) { for (var y = 0; y < formatList.length; y++) { var curFormat = formatList[y] if ( isNonNullable(curFormat.collapsed) && curFormat.collapsed !== rng.collapsed ) { continue } if ( isSelectorFormat(curFormat) && dom.is(parents[i], curFormat.selector) ) { return parents[i] } } } return container } var findBlockEndPoint = function ( editor, formatList, container, siblingName ) { var node = container var dom = editor.dom var root = dom.getRoot() var format = formatList[0] if (isBlockFormat(format)) { node = format.wrapper ? null : dom.getParent(container, format.block, root) } if (!node) { var scopeRoot = dom.getParent(container, 'LI,TD,TH') node = dom.getParent( isText$7(container) ? container.parentNode : container, function (node) { return node !== root && isTextBlock(editor, node) }, scopeRoot ) } if (node && isBlockFormat(format) && format.wrapper) { node = getParents$1(dom, node, 'ul,ol').reverse()[0] || node } if (!node) { node = container while (node[siblingName] && !dom.isBlock(node[siblingName])) { node = node[siblingName] if (isEq$5(node, 'br')) { break } } } return node || container } var isAtBlockBoundary$1 = function (dom, root, container, siblingName) { var parent = container.parentNode if (isNonNullable(container[siblingName])) { return false } else if (parent === root || isNullable(parent) || dom.isBlock(parent)) { return true } else { return isAtBlockBoundary$1(dom, root, parent, siblingName) } } var findParentContainer = function ( dom, formatList, container, offset, start ) { var parent = container var siblingName = start ? 'previousSibling' : 'nextSibling' var root = dom.getRoot() if (isText$7(container) && !isWhiteSpaceNode(container)) { if (start ? offset > 0 : offset < container.data.length) { return container } } while (true) { if (!formatList[0].block_expand && dom.isBlock(parent)) { return parent } for ( var sibling = parent[siblingName]; sibling; sibling = sibling[siblingName] ) { var allowSpaces = isText$7(sibling) && !isAtBlockBoundary$1(dom, root, sibling, siblingName) if ( !isBookmarkNode(sibling) && !isBogusBr(sibling) && !isWhiteSpaceNode(sibling, allowSpaces) ) { return parent } } if (parent === root || parent.parentNode === root) { container = parent break } parent = parent.parentNode } return container } var isSelfOrParentBookmark = function (container) { return isBookmarkNode(container.parentNode) || isBookmarkNode(container) } var expandRng = function (editor, rng, formatList, includeTrailingSpace) { if (includeTrailingSpace === void 0) { includeTrailingSpace = false } var startContainer = rng.startContainer, startOffset = rng.startOffset, endContainer = rng.endContainer, endOffset = rng.endOffset var dom = editor.dom var format = formatList[0] if (isElement$5(startContainer) && startContainer.hasChildNodes()) { startContainer = getNode$1(startContainer, startOffset) if (isText$7(startContainer)) { startOffset = 0 } } if (isElement$5(endContainer) && endContainer.hasChildNodes()) { endContainer = getNode$1( endContainer, rng.collapsed ? endOffset : endOffset - 1 ) if (isText$7(endContainer)) { endOffset = endContainer.nodeValue.length } } startContainer = findParentContentEditable(dom, startContainer) endContainer = findParentContentEditable(dom, endContainer) if (isSelfOrParentBookmark(startContainer)) { startContainer = isBookmarkNode(startContainer) ? startContainer : startContainer.parentNode if (rng.collapsed) { startContainer = startContainer.previousSibling || startContainer } else { startContainer = startContainer.nextSibling || startContainer } if (isText$7(startContainer)) { startOffset = rng.collapsed ? startContainer.length : 0 } } if (isSelfOrParentBookmark(endContainer)) { endContainer = isBookmarkNode(endContainer) ? endContainer : endContainer.parentNode if (rng.collapsed) { endContainer = endContainer.nextSibling || endContainer } else { endContainer = endContainer.previousSibling || endContainer } if (isText$7(endContainer)) { endOffset = rng.collapsed ? 0 : endContainer.length } } if (rng.collapsed) { var startPoint = findWordEndPoint( dom, editor.getBody(), startContainer, startOffset, true, includeTrailingSpace ) startPoint.each(function (_a) { var container = _a.container, offset = _a.offset startContainer = container startOffset = offset }) var endPoint = findWordEndPoint( dom, editor.getBody(), endContainer, endOffset, false, includeTrailingSpace ) endPoint.each(function (_a) { var container = _a.container, offset = _a.offset endContainer = container endOffset = offset }) } if (isInlineFormat(format) || format.block_expand) { if ( !isInlineFormat(format) || !isText$7(startContainer) || startOffset === 0 ) { startContainer = findParentContainer( dom, formatList, startContainer, startOffset, true ) } if ( !isInlineFormat(format) || !isText$7(endContainer) || endOffset === endContainer.nodeValue.length ) { endContainer = findParentContainer( dom, formatList, endContainer, endOffset, false ) } } if (shouldExpandToSelector(format)) { startContainer = findSelectorEndPoint( dom, formatList, rng, startContainer, 'previousSibling' ) endContainer = findSelectorEndPoint( dom, formatList, rng, endContainer, 'nextSibling' ) } if (isBlockFormat(format) || isSelectorFormat(format)) { startContainer = findBlockEndPoint( editor, formatList, startContainer, 'previousSibling' ) endContainer = findBlockEndPoint( editor, formatList, endContainer, 'nextSibling' ) if (isBlockFormat(format)) { if (!dom.isBlock(startContainer)) { startContainer = findParentContainer( dom, formatList, startContainer, startOffset, true ) } if (!dom.isBlock(endContainer)) { endContainer = findParentContainer( dom, formatList, endContainer, endOffset, false ) } } } if (isElement$5(startContainer)) { startOffset = dom.nodeIndex(startContainer) startContainer = startContainer.parentNode } if (isElement$5(endContainer)) { endOffset = dom.nodeIndex(endContainer) + 1 endContainer = endContainer.parentNode } return { startContainer: startContainer, startOffset: startOffset, endContainer: endContainer, endOffset: endOffset, } } var walk$2 = function (dom, rng, callback) { var startOffset = rng.startOffset var startContainer = getNode$1(rng.startContainer, startOffset) var endOffset = rng.endOffset var endContainer = getNode$1(rng.endContainer, endOffset - 1) var exclude = function (nodes) { var firstNode = nodes[0] if ( isText$7(firstNode) && firstNode === startContainer && startOffset >= firstNode.data.length ) { nodes.splice(0, 1) } var lastNode = nodes[nodes.length - 1] if ( endOffset === 0 && nodes.length > 0 && lastNode === endContainer && isText$7(lastNode) ) { nodes.splice(nodes.length - 1, 1) } return nodes } var collectSiblings = function (node, name, endNode) { var siblings = [] for (; node && node !== endNode; node = node[name]) { siblings.push(node) } return siblings } var findEndPoint = function (node, root) { return dom.getParent( node, function (node) { return node.parentNode === root }, root ) } var walkBoundary = function (startNode, endNode, next) { var siblingName = next ? 'nextSibling' : 'previousSibling' for ( var node = startNode, parent_1 = node.parentNode; node && node !== endNode; node = parent_1 ) { parent_1 = node.parentNode var siblings_1 = collectSiblings( node === startNode ? node : node[siblingName], siblingName ) if (siblings_1.length) { if (!next) { siblings_1.reverse() } callback(exclude(siblings_1)) } } } if (startContainer === endContainer) { return callback(exclude([startContainer])) } var ancestor = dom.findCommonAncestor(startContainer, endContainer) if (dom.isChildOf(startContainer, endContainer)) { return walkBoundary(startContainer, ancestor, true) } if (dom.isChildOf(endContainer, startContainer)) { return walkBoundary(endContainer, ancestor) } var startPoint = findEndPoint(startContainer, ancestor) || startContainer var endPoint = findEndPoint(endContainer, ancestor) || endContainer walkBoundary(startContainer, startPoint, true) var siblings = collectSiblings( startPoint === startContainer ? startPoint : startPoint.nextSibling, 'nextSibling', endPoint === endContainer ? endPoint.nextSibling : endPoint ) if (siblings.length) { callback(exclude(siblings)) } walkBoundary(endContainer, endPoint) } var getRanges = function (selection) { var ranges = [] if (selection) { for (var i = 0; i < selection.rangeCount; i++) { ranges.push(selection.getRangeAt(i)) } } return ranges } var getSelectedNodes = function (ranges) { return bind(ranges, function (range) { var node = getSelectedNode(range) return node ? [SugarElement.fromDom(node)] : [] }) } var hasMultipleRanges = function (selection) { return getRanges(selection).length > 1 } var getCellsFromRanges = function (ranges) { return filter$4(getSelectedNodes(ranges), isTableCell$4) } var getCellsFromElement = function (elm) { return descendants(elm, 'td[data-mce-selected],th[data-mce-selected]') } var getCellsFromElementOrRanges = function (ranges, element) { var selectedCells = getCellsFromElement(element) return selectedCells.length > 0 ? selectedCells : getCellsFromRanges(ranges) } var getCellsFromEditor = function (editor) { return getCellsFromElementOrRanges( getRanges(editor.selection.getSel()), SugarElement.fromDom(editor.getBody()) ) } var getClosestTable = function (cell, isRoot) { return ancestor$2(cell, 'table', isRoot) } var getStartNode = function (rng) { var sc = rng.startContainer, so = rng.startOffset if (isText$7(sc)) { return so === 0 ? Optional.some(SugarElement.fromDom(sc)) : Optional.none() } else { return Optional.from(sc.childNodes[so]).map(SugarElement.fromDom) } } var getEndNode = function (rng) { var ec = rng.endContainer, eo = rng.endOffset if (isText$7(ec)) { return eo === ec.data.length ? Optional.some(SugarElement.fromDom(ec)) : Optional.none() } else { return Optional.from(ec.childNodes[eo - 1]).map(SugarElement.fromDom) } } var getFirstChildren = function (node) { return firstChild(node).fold(constant([node]), function (child) { return [node].concat(getFirstChildren(child)) }) } var getLastChildren$1 = function (node) { return lastChild(node).fold(constant([node]), function (child) { if (name(child) === 'br') { return prevSibling(child) .map(function (sibling) { return [node].concat(getLastChildren$1(sibling)) }) .getOr([]) } else { return [node].concat(getLastChildren$1(child)) } }) } var hasAllContentsSelected = function (elm, rng) { return lift2( getStartNode(rng), getEndNode(rng), function (startNode, endNode) { var start = find$3(getFirstChildren(elm), curry(eq, startNode)) var end = find$3(getLastChildren$1(elm), curry(eq, endNode)) return start.isSome() && end.isSome() } ).getOr(false) } var moveEndPoint = function (dom, rng, node, start) { var root = node, walker = new DomTreeWalker(node, root) var moveCaretBeforeOnEnterElementsMap = filter$3( dom.schema.getMoveCaretBeforeOnEnterElements(), function (_, name) { return !contains$3(['td', 'th', 'table'], name.toLowerCase()) } ) do { if (isText$7(node) && Tools.trim(node.nodeValue).length !== 0) { if (start) { rng.setStart(node, 0) } else { rng.setEnd(node, node.nodeValue.length) } return } if (moveCaretBeforeOnEnterElementsMap[node.nodeName]) { if (start) { rng.setStartBefore(node) } else { if (node.nodeName === 'BR') { rng.setEndBefore(node) } else { rng.setEndAfter(node) } } return } } while ((node = start ? walker.next() : walker.prev())) if (root.nodeName === 'BODY') { if (start) { rng.setStart(root, 0) } else { rng.setEnd(root, root.childNodes.length) } } } var hasAnyRanges = function (editor) { var sel = editor.selection.getSel() return sel && sel.rangeCount > 0 } var runOnRanges = function (editor, executor) { var fakeSelectionNodes = getCellsFromEditor(editor) if (fakeSelectionNodes.length > 0) { each$k(fakeSelectionNodes, function (elem) { var node = elem.dom var fakeNodeRng = editor.dom.createRng() fakeNodeRng.setStartBefore(node) fakeNodeRng.setEndAfter(node) executor(fakeNodeRng, true) }) } else { executor(editor.selection.getRng(), false) } } var preserve = function (selection, fillBookmark, executor) { var bookmark = getPersistentBookmark(selection, fillBookmark) executor(bookmark) selection.moveToBookmark(bookmark) } var NodeValue = function (is, name) { var get = function (element) { if (!is(element)) { throw new Error( 'Can only get ' + name + ' value of a ' + name + ' node' ) } return getOption(element).getOr('') } var getOption = function (element) { return is(element) ? Optional.from(element.dom.nodeValue) : Optional.none() } var set = function (element, value) { if (!is(element)) { throw new Error( 'Can only set raw ' + name + ' value of a ' + name + ' node' ) } element.dom.nodeValue = value } return { get: get, getOption: getOption, set: set, } } var api$1 = NodeValue(isText$8, 'text') var get$2 = function (element) { return api$1.get(element) } var isZeroWidth = function (elem) { return isText$8(elem) && get$2(elem) === ZWSP$1 } var context = function (editor, elem, wrapName, nodeName) { return parent(elem).fold( function () { return 'skipping' }, function (parent) { if (nodeName === 'br' || isZeroWidth(elem)) { return 'valid' } else if (isAnnotation(elem)) { return 'existing' } else if (isCaretNode(elem.dom)) { return 'caret' } else if ( !isValid(editor, wrapName, nodeName) || !isValid(editor, name(parent), wrapName) ) { return 'invalid-child' } else { return 'valid' } } ) } var applyWordGrab = function (editor, rng) { var r = expandRng(editor, rng, [{ inline: 'span' }]) rng.setStart(r.startContainer, r.startOffset) rng.setEnd(r.endContainer, r.endOffset) editor.selection.setRng(rng) } var makeAnnotation = function (eDoc, _a, annotationName, decorate) { var _b = _a.uid, uid = _b === void 0 ? generate('mce-annotation') : _b, data = __rest(_a, ['uid']) var master = SugarElement.fromTag('span', eDoc) add$1(master, annotation()) set$1(master, '' + dataAnnotationId(), uid) set$1(master, '' + dataAnnotation(), annotationName) var _c = decorate(uid, data), _d = _c.attributes, attributes = _d === void 0 ? {} : _d, _e = _c.classes, classes = _e === void 0 ? [] : _e setAll$1(master, attributes) add(master, classes) return master } var annotate = function (editor, rng, annotationName, decorate, data) { var newWrappers = [] var master = makeAnnotation(editor.getDoc(), data, annotationName, decorate) var wrapper = value() var finishWrapper = function () { wrapper.clear() } var getOrOpenWrapper = function () { return wrapper.get().getOrThunk(function () { var nu = shallow(master) newWrappers.push(nu) wrapper.set(nu) return nu }) } var processElements = function (elems) { each$k(elems, processElement) } var processElement = function (elem) { var ctx = context(editor, elem, 'span', name(elem)) switch (ctx) { case 'invalid-child': { finishWrapper() var children$1 = children(elem) processElements(children$1) finishWrapper() break } case 'valid': { var w = getOrOpenWrapper() wrap$3(elem, w) break } } } var processNodes = function (nodes) { var elems = map$3(nodes, SugarElement.fromDom) processElements(elems) } walk$2(editor.dom, rng, function (nodes) { finishWrapper() processNodes(nodes) }) return newWrappers } var annotateWithBookmark = function (editor, name, settings, data) { editor.undoManager.transact(function () { var selection = editor.selection var initialRng = selection.getRng() var hasFakeSelection = getCellsFromEditor(editor).length > 0 if (initialRng.collapsed && !hasFakeSelection) { applyWordGrab(editor, initialRng) } if (selection.getRng().collapsed && !hasFakeSelection) { var wrapper = makeAnnotation( editor.getDoc(), data, name, settings.decorate ) set(wrapper, nbsp) selection.getRng().insertNode(wrapper.dom) selection.select(wrapper.dom) } else { preserve(selection, false, function () { runOnRanges(editor, function (selectionRng) { annotate(editor, selectionRng, name, settings.decorate, data) }) }) } }) } var Annotator = function (editor) { var registry = create$7() setup$m(editor, registry) var changes = setup$n(editor) return { register: function (name, settings) { registry.register(name, settings) }, annotate: function (name, data) { registry.lookup(name).each(function (settings) { annotateWithBookmark(editor, name, settings, data) }) }, annotationChanged: function (name, callback) { changes.addListener(name, callback) }, remove: function (name) { identify(editor, Optional.some(name)).each(function (_a) { var elements = _a.elements each$k(elements, unwrap) }) }, getAll: function (name) { var directory = findAll(editor, name) return map$2(directory, function (elems) { return map$3(elems, function (elem) { return elem.dom }) }) }, } } var BookmarkManager = function (selection) { return { getBookmark: curry(getBookmark$1, selection), moveToBookmark: curry(moveToBookmark, selection), } } BookmarkManager.isBookmarkNode = isBookmarkNode$1 var getContentEditableRoot$1 = function (root, node) { while (node && node !== root) { if (isContentEditableTrue$4(node) || isContentEditableFalse$b(node)) { return node } node = node.parentNode } return null } var isXYWithinRange = function (clientX, clientY, range) { if (range.collapsed) { return false } if ( Env.browser.isIE() && range.startOffset === range.endOffset - 1 && range.startContainer === range.endContainer ) { var elm = range.startContainer.childNodes[range.startOffset] if (isElement$5(elm)) { return exists(elm.getClientRects(), function (rect) { return containsXY(rect, clientX, clientY) }) } } return exists(range.getClientRects(), function (rect) { return containsXY(rect, clientX, clientY) }) } var firePreProcess = function (editor, args) { return editor.fire('PreProcess', args) } var firePostProcess = function (editor, args) { return editor.fire('PostProcess', args) } var fireRemove = function (editor) { return editor.fire('remove') } var fireDetach = function (editor) { return editor.fire('detach') } var fireSwitchMode = function (editor, mode) { return editor.fire('SwitchMode', { mode: mode }) } var fireObjectResizeStart = function (editor, target, width, height, origin) { editor.fire('ObjectResizeStart', { target: target, width: width, height: height, origin: origin, }) } var fireObjectResized = function (editor, target, width, height, origin) { editor.fire('ObjectResized', { target: target, width: width, height: height, origin: origin, }) } var firePreInit = function (editor) { return editor.fire('PreInit') } var firePostRender = function (editor) { return editor.fire('PostRender') } var fireInit = function (editor) { return editor.fire('Init') } var firePlaceholderToggle = function (editor, state) { return editor.fire('PlaceholderToggle', { state: state }) } var fireError = function (editor, errorType, error) { return editor.fire(errorType, error) } var fireFormatApply = function (editor, format, node, vars) { return editor.fire('FormatApply', { format: format, node: node, vars: vars, }) } var fireFormatRemove = function (editor, format, node, vars) { return editor.fire('FormatRemove', { format: format, node: node, vars: vars, }) } var VK = { BACKSPACE: 8, DELETE: 46, DOWN: 40, ENTER: 13, ESC: 27, LEFT: 37, RIGHT: 39, SPACEBAR: 32, TAB: 9, UP: 38, PAGE_UP: 33, PAGE_DOWN: 34, END: 35, HOME: 36, modifierPressed: function (e) { return e.shiftKey || e.ctrlKey || e.altKey || VK.metaKeyPressed(e) }, metaKeyPressed: function (e) { return Env.mac ? e.metaKey : e.ctrlKey && !e.altKey }, } var isContentEditableFalse$5 = isContentEditableFalse$b var ControlSelection = function (selection, editor) { var elementSelectionAttr = 'data-mce-selected' var dom = editor.dom, each = Tools.each var selectedElm, selectedElmGhost, resizeHelper, selectedHandle, resizeBackdrop var startX, startY, selectedElmX, selectedElmY, startW, startH, ratio, resizeStarted var width, height var editableDoc = editor.getDoc(), rootDocument = document var abs = Math.abs, round = Math.round, rootElement = editor.getBody() var startScrollWidth, startScrollHeight var resizeHandles = { nw: [0, 0, -1, -1], ne: [1, 0, 1, -1], se: [1, 1, 1, 1], sw: [0, 1, -1, 1], } var isImage = function (elm) { return ( elm && (elm.nodeName === 'IMG' || editor.dom.is(elm, 'figure.image')) ) } var isMedia = function (elm) { return isMedia$2(elm) || dom.hasClass(elm, 'mce-preview-object') } var isEventOnImageOutsideRange = function (evt, range) { if (evt.type === 'longpress' || evt.type.indexOf('touch') === 0) { var touch = evt.touches[0] return ( isImage(evt.target) && !isXYWithinRange(touch.clientX, touch.clientY, range) ) } else { return ( isImage(evt.target) && !isXYWithinRange(evt.clientX, evt.clientY, range) ) } } var contextMenuSelectImage = function (evt) { var target = evt.target if ( isEventOnImageOutsideRange(evt, editor.selection.getRng()) && !evt.isDefaultPrevented() ) { editor.selection.select(target) } } var getResizeTargets = function (elm) { if (dom.is(elm, 'figure.image')) { return [elm.querySelector('img')] } else if ( dom.hasClass(elm, 'mce-preview-object') && isNonNullable(elm.firstElementChild) ) { return [elm, elm.firstElementChild] } else { return [elm] } } var isResizable = function (elm) { var selector = getObjectResizing(editor) if (!selector) { return false } if (elm.getAttribute('data-mce-resize') === 'false') { return false } if (elm === editor.getBody()) { return false } if (dom.hasClass(elm, 'mce-preview-object')) { return is$2(SugarElement.fromDom(elm.firstElementChild), selector) } else { return is$2(SugarElement.fromDom(elm), selector) } } var createGhostElement = function (elm) { if (isMedia(elm)) { return dom.create('img', { src: Env.transparentSrc }) } else { return elm.cloneNode(true) } } var setSizeProp = function (element, name, value) { if (isNonNullable(value)) { var targets = getResizeTargets(element) each$k(targets, function (target) { if ( target.style[name] || !editor.schema.isValid(target.nodeName.toLowerCase(), name) ) { dom.setStyle(target, name, value) } else { dom.setAttrib(target, name, '' + value) } }) } } var setGhostElmSize = function (ghostElm, width, height) { setSizeProp(ghostElm, 'width', width) setSizeProp(ghostElm, 'height', height) } var resizeGhostElement = function (e) { var deltaX, deltaY, proportional var resizeHelperX, resizeHelperY deltaX = e.screenX - startX deltaY = e.screenY - startY width = deltaX * selectedHandle[2] + startW height = deltaY * selectedHandle[3] + startH width = width < 5 ? 5 : width height = height < 5 ? 5 : height if ( (isImage(selectedElm) || isMedia(selectedElm)) && getResizeImgProportional(editor) !== false ) { proportional = !VK.modifierPressed(e) } else { proportional = VK.modifierPressed(e) } if (proportional) { if (abs(deltaX) > abs(deltaY)) { height = round(width * ratio) width = round(height / ratio) } else { width = round(height / ratio) height = round(width * ratio) } } setGhostElmSize(selectedElmGhost, width, height) resizeHelperX = selectedHandle.startPos.x + deltaX resizeHelperY = selectedHandle.startPos.y + deltaY resizeHelperX = resizeHelperX > 0 ? resizeHelperX : 0 resizeHelperY = resizeHelperY > 0 ? resizeHelperY : 0 dom.setStyles(resizeHelper, { left: resizeHelperX, top: resizeHelperY, display: 'block', }) resizeHelper.innerHTML = width + ' × ' + height if (selectedHandle[2] < 0 && selectedElmGhost.clientWidth <= width) { dom.setStyle(selectedElmGhost, 'left', selectedElmX + (startW - width)) } if (selectedHandle[3] < 0 && selectedElmGhost.clientHeight <= height) { dom.setStyle(selectedElmGhost, 'top', selectedElmY + (startH - height)) } deltaX = rootElement.scrollWidth - startScrollWidth deltaY = rootElement.scrollHeight - startScrollHeight if (deltaX + deltaY !== 0) { dom.setStyles(resizeHelper, { left: resizeHelperX - deltaX, top: resizeHelperY - deltaY, }) } if (!resizeStarted) { fireObjectResizeStart( editor, selectedElm, startW, startH, 'corner-' + selectedHandle.name ) resizeStarted = true } } var endGhostResize = function () { var wasResizeStarted = resizeStarted resizeStarted = false if (wasResizeStarted) { setSizeProp(selectedElm, 'width', width) setSizeProp(selectedElm, 'height', height) } dom.unbind(editableDoc, 'mousemove', resizeGhostElement) dom.unbind(editableDoc, 'mouseup', endGhostResize) if (rootDocument !== editableDoc) { dom.unbind(rootDocument, 'mousemove', resizeGhostElement) dom.unbind(rootDocument, 'mouseup', endGhostResize) } dom.remove(selectedElmGhost) dom.remove(resizeHelper) dom.remove(resizeBackdrop) showResizeRect(selectedElm) if (wasResizeStarted) { fireObjectResized( editor, selectedElm, width, height, 'corner-' + selectedHandle.name ) dom.setAttrib(selectedElm, 'style', dom.getAttrib(selectedElm, 'style')) } editor.nodeChanged() } var showResizeRect = function (targetElm) { unbindResizeHandleEvents() var position = dom.getPos(targetElm, rootElement) var selectedElmX = position.x var selectedElmY = position.y var rect = targetElm.getBoundingClientRect() var targetWidth = rect.width || rect.right - rect.left var targetHeight = rect.height || rect.bottom - rect.top if (selectedElm !== targetElm) { hideResizeRect() selectedElm = targetElm width = height = 0 } var e = editor.fire('ObjectSelected', { target: targetElm }) var selectedValue = dom.getAttrib(selectedElm, elementSelectionAttr, '1') if (isResizable(targetElm) && !e.isDefaultPrevented()) { each(resizeHandles, function (handle, name) { var handleElm var startDrag = function (e) { var target = getResizeTargets(selectedElm)[0] startX = e.screenX startY = e.screenY startW = target.clientWidth startH = target.clientHeight ratio = startH / startW selectedHandle = handle selectedHandle.name = name selectedHandle.startPos = { x: targetWidth * handle[0] + selectedElmX, y: targetHeight * handle[1] + selectedElmY, } startScrollWidth = rootElement.scrollWidth startScrollHeight = rootElement.scrollHeight resizeBackdrop = dom.add(rootElement, 'div', { class: 'mce-resize-backdrop', 'data-mce-bogus': 'all', }) dom.setStyles(resizeBackdrop, { position: 'fixed', left: '0', top: '0', width: '100%', height: '100%', }) selectedElmGhost = createGhostElement(selectedElm) dom.addClass(selectedElmGhost, 'mce-clonedresizable') dom.setAttrib(selectedElmGhost, 'data-mce-bogus', 'all') selectedElmGhost.contentEditable = 'false' dom.setStyles(selectedElmGhost, { left: selectedElmX, top: selectedElmY, margin: 0, }) setGhostElmSize(selectedElmGhost, targetWidth, targetHeight) selectedElmGhost.removeAttribute(elementSelectionAttr) rootElement.appendChild(selectedElmGhost) dom.bind(editableDoc, 'mousemove', resizeGhostElement) dom.bind(editableDoc, 'mouseup', endGhostResize) if (rootDocument !== editableDoc) { dom.bind(rootDocument, 'mousemove', resizeGhostElement) dom.bind(rootDocument, 'mouseup', endGhostResize) } resizeHelper = dom.add( rootElement, 'div', { class: 'mce-resize-helper', 'data-mce-bogus': 'all', }, startW + ' × ' + startH ) } handleElm = dom.get('mceResizeHandle' + name) if (handleElm) { dom.remove(handleElm) } handleElm = dom.add(rootElement, 'div', { id: 'mceResizeHandle' + name, 'data-mce-bogus': 'all', class: 'mce-resizehandle', unselectable: true, style: 'cursor:' + name + '-resize; margin:0; padding:0', }) if (Env.ie === 11) { handleElm.contentEditable = false } dom.bind(handleElm, 'mousedown', function (e) { e.stopImmediatePropagation() e.preventDefault() startDrag(e) }) handle.elm = handleElm dom.setStyles(handleElm, { left: targetWidth * handle[0] + selectedElmX - handleElm.offsetWidth / 2, top: targetHeight * handle[1] + selectedElmY - handleElm.offsetHeight / 2, }) }) } else { hideResizeRect() } if (!dom.getAttrib(selectedElm, elementSelectionAttr)) { selectedElm.setAttribute(elementSelectionAttr, selectedValue) } } var hideResizeRect = function () { unbindResizeHandleEvents() if (selectedElm) { selectedElm.removeAttribute(elementSelectionAttr) } each$j(resizeHandles, function (value, name) { var handleElm = dom.get('mceResizeHandle' + name) if (handleElm) { dom.unbind(handleElm) dom.remove(handleElm) } }) } var updateResizeRect = function (e) { var startElm, controlElm var isChildOrEqual = function (node, parent) { if (node) { do { if (node === parent) { return true } } while ((node = node.parentNode)) } } if (resizeStarted || editor.removed) { return } each( dom.select('img[data-mce-selected],hr[data-mce-selected]'), function (img) { img.removeAttribute(elementSelectionAttr) } ) controlElm = e.type === 'mousedown' ? e.target : selection.getNode() controlElm = dom .$(controlElm) .closest('table,img,figure.image,hr,video,span.mce-preview-object')[0] if (isChildOrEqual(controlElm, rootElement)) { disableGeckoResize() startElm = selection.getStart(true) if ( isChildOrEqual(startElm, controlElm) && isChildOrEqual(selection.getEnd(true), controlElm) ) { showResizeRect(controlElm) return } } hideResizeRect() } var isWithinContentEditableFalse = function (elm) { return isContentEditableFalse$5( getContentEditableRoot$1(editor.getBody(), elm) ) } var unbindResizeHandleEvents = function () { each$j(resizeHandles, function (handle) { if (handle.elm) { dom.unbind(handle.elm) delete handle.elm } }) } var disableGeckoResize = function () { try { editor.getDoc().execCommand('enableObjectResizing', false, 'false') } catch (ex) {} } editor.on('init', function () { disableGeckoResize() if (Env.browser.isIE() || Env.browser.isEdge()) { editor.on('mousedown click', function (e) { var target = e.target, nodeName = target.nodeName if ( !resizeStarted && /^(TABLE|IMG|HR)$/.test(nodeName) && !isWithinContentEditableFalse(target) ) { if (e.button !== 2) { editor.selection.select(target, nodeName === 'TABLE') } if (e.type === 'mousedown') { editor.nodeChanged() } } }) var handleMSControlSelect_1 = function (e) { var delayedSelect = function (node) { Delay.setEditorTimeout(editor, function () { return editor.selection.select(node) }) } if (isWithinContentEditableFalse(e.target) || isMedia$2(e.target)) { e.preventDefault() delayedSelect(e.target) return } if (/^(TABLE|IMG|HR)$/.test(e.target.nodeName)) { e.preventDefault() if (e.target.tagName === 'IMG') { delayedSelect(e.target) } } } dom.bind(rootElement, 'mscontrolselect', handleMSControlSelect_1) editor.on('remove', function () { return dom.unbind( rootElement, 'mscontrolselect', handleMSControlSelect_1 ) }) } var throttledUpdateResizeRect = Delay.throttle(function (e) { if (!editor.composing) { updateResizeRect(e) } }) editor.on( 'nodechange ResizeEditor ResizeWindow ResizeContent drop FullscreenStateChanged', throttledUpdateResizeRect ) editor.on('keyup compositionend', function (e) { if (selectedElm && selectedElm.nodeName === 'TABLE') { throttledUpdateResizeRect(e) } }) editor.on('hide blur', hideResizeRect) editor.on('contextmenu longpress', contextMenuSelectImage, true) }) editor.on('remove', unbindResizeHandleEvents) var destroy = function () { selectedElm = selectedElmGhost = resizeBackdrop = null } return { isResizable: isResizable, showResizeRect: showResizeRect, hideResizeRect: hideResizeRect, updateResizeRect: updateResizeRect, destroy: destroy, } } var hasCeProperty = function (node) { return isContentEditableTrue$4(node) || isContentEditableFalse$b(node) } var findParent$1 = function (node, rootNode, predicate) { while (node && node !== rootNode) { if (predicate(node)) { return node } node = node.parentNode } return null } var findClosestIeRange = function (clientX, clientY, doc) { var rects var element = doc.elementFromPoint(clientX, clientY) var rng = doc.body.createTextRange() if (!element || element.tagName === 'HTML') { element = doc.body } rng.moveToElementText(element) rects = Tools.toArray(rng.getClientRects()) rects = rects.sort(function (a, b) { a = Math.abs(Math.max(a.top - clientY, a.bottom - clientY)) b = Math.abs(Math.max(b.top - clientY, b.bottom - clientY)) return a - b }) if (rects.length > 0) { clientY = (rects[0].bottom + rects[0].top) / 2 try { rng.moveToPoint(clientX, clientY) rng.collapse(true) return rng } catch (ex) {} } return null } var moveOutOfContentEditableFalse = function (rng, rootNode) { var parentElement = rng && rng.parentElement ? rng.parentElement() : null return isContentEditableFalse$b( findParent$1(parentElement, rootNode, hasCeProperty) ) ? null : rng } var fromPoint = function (clientX, clientY, doc) { var rng, point var pointDoc = doc if (pointDoc.caretPositionFromPoint) { point = pointDoc.caretPositionFromPoint(clientX, clientY) if (point) { rng = doc.createRange() rng.setStart(point.offsetNode, point.offset) rng.collapse(true) } } else if (pointDoc.caretRangeFromPoint) { rng = pointDoc.caretRangeFromPoint(clientX, clientY) } else if (pointDoc.body.createTextRange) { rng = pointDoc.body.createTextRange() try { rng.moveToPoint(clientX, clientY) rng.collapse(true) } catch (ex) { rng = findClosestIeRange(clientX, clientY, doc) } return moveOutOfContentEditableFalse(rng, doc.body) } return rng } var isEq$4 = function (rng1, rng2) { return ( rng1 && rng2 && rng1.startContainer === rng2.startContainer && rng1.startOffset === rng2.startOffset && rng1.endContainer === rng2.endContainer && rng1.endOffset === rng2.endOffset ) } var findParent = function (node, rootNode, predicate) { while (node && node !== rootNode) { if (predicate(node)) { return node } node = node.parentNode } return null } var hasParent$1 = function (node, rootNode, predicate) { return findParent(node, rootNode, predicate) !== null } var hasParentWithName = function (node, rootNode, name) { return hasParent$1(node, rootNode, function (node) { return node.nodeName === name }) } var isTable = function (node) { return node && node.nodeName === 'TABLE' } var isTableCell$2 = function (node) { return node && /^(TD|TH|CAPTION)$/.test(node.nodeName) } var isCeFalseCaretContainer = function (node, rootNode) { return ( isCaretContainer$2(node) && hasParent$1(node, rootNode, isCaretNode) === false ) } var hasBrBeforeAfter = function (dom, node, left) { var walker = new DomTreeWalker( node, dom.getParent(node.parentNode, dom.isBlock) || dom.getRoot() ) while ((node = walker[left ? 'prev' : 'next']())) { if (isBr$5(node)) { return true } } } var isPrevNode = function (node, name) { return node.previousSibling && node.previousSibling.nodeName === name } var hasContentEditableFalseParent = function (body, node) { while (node && node !== body) { if (isContentEditableFalse$b(node)) { return true } node = node.parentNode } return false } var findTextNodeRelative = function ( dom, isAfterNode, collapsed, left, startNode ) { var lastInlineElement var body = dom.getRoot() var node var nonEmptyElementsMap = dom.schema.getNonEmptyElements() var parentBlockContainer = dom.getParent(startNode.parentNode, dom.isBlock) || body if ( left && isBr$5(startNode) && isAfterNode && dom.isEmpty(parentBlockContainer) ) { return Optional.some( CaretPosition(startNode.parentNode, dom.nodeIndex(startNode)) ) } var walker = new DomTreeWalker(startNode, parentBlockContainer) while ((node = walker[left ? 'prev' : 'next']())) { if ( dom.getContentEditableParent(node) === 'false' || isCeFalseCaretContainer(node, body) ) { return Optional.none() } if (isText$7(node) && node.nodeValue.length > 0) { if (hasParentWithName(node, body, 'A') === false) { return Optional.some( CaretPosition(node, left ? node.nodeValue.length : 0) ) } return Optional.none() } if ( dom.isBlock(node) || nonEmptyElementsMap[node.nodeName.toLowerCase()] ) { return Optional.none() } lastInlineElement = node } if (collapsed && lastInlineElement) { return Optional.some(CaretPosition(lastInlineElement, 0)) } return Optional.none() } var normalizeEndPoint = function (dom, collapsed, start, rng) { var container, offset var body = dom.getRoot() var node var directionLeft, normalized = false container = rng[(start ? 'start' : 'end') + 'Container'] offset = rng[(start ? 'start' : 'end') + 'Offset'] var isAfterNode = isElement$5(container) && offset === container.childNodes.length var nonEmptyElementsMap = dom.schema.getNonEmptyElements() directionLeft = start if (isCaretContainer$2(container)) { return Optional.none() } if (isElement$5(container) && offset > container.childNodes.length - 1) { directionLeft = false } if (isDocument$1(container)) { container = body offset = 0 } if (container === body) { if (directionLeft) { node = container.childNodes[offset > 0 ? offset - 1 : 0] if (node) { if (isCaretContainer$2(node)) { return Optional.none() } if (nonEmptyElementsMap[node.nodeName] || isTable(node)) { return Optional.none() } } } if (container.hasChildNodes()) { offset = Math.min( !directionLeft && offset > 0 ? offset - 1 : offset, container.childNodes.length - 1 ) container = container.childNodes[offset] offset = isText$7(container) && isAfterNode ? container.data.length : 0 if (!collapsed && container === body.lastChild && isTable(container)) { return Optional.none() } if ( hasContentEditableFalseParent(body, container) || isCaretContainer$2(container) ) { return Optional.none() } if (container.hasChildNodes() && isTable(container) === false) { node = container var walker = new DomTreeWalker(container, body) do { if (isContentEditableFalse$b(node) || isCaretContainer$2(node)) { normalized = false break } if (isText$7(node) && node.nodeValue.length > 0) { offset = directionLeft ? 0 : node.nodeValue.length container = node normalized = true break } if ( nonEmptyElementsMap[node.nodeName.toLowerCase()] && !isTableCell$2(node) ) { offset = dom.nodeIndex(node) container = node.parentNode if (!directionLeft) { offset++ } normalized = true break } } while ((node = directionLeft ? walker.next() : walker.prev())) } } } if (collapsed) { if (isText$7(container) && offset === 0) { findTextNodeRelative(dom, isAfterNode, collapsed, true, container).each( function (pos) { container = pos.container() offset = pos.offset() normalized = true } ) } if (isElement$5(container)) { node = container.childNodes[offset] if (!node) { node = container.childNodes[offset - 1] } if ( node && isBr$5(node) && !isPrevNode(node, 'A') && !hasBrBeforeAfter(dom, node, false) && !hasBrBeforeAfter(dom, node, true) ) { findTextNodeRelative(dom, isAfterNode, collapsed, true, node).each( function (pos) { container = pos.container() offset = pos.offset() normalized = true } ) } } } if ( directionLeft && !collapsed && isText$7(container) && offset === container.nodeValue.length ) { findTextNodeRelative(dom, isAfterNode, collapsed, false, container).each( function (pos) { container = pos.container() offset = pos.offset() normalized = true } ) } return normalized ? Optional.some(CaretPosition(container, offset)) : Optional.none() } var normalize$2 = function (dom, rng) { var collapsed = rng.collapsed, normRng = rng.cloneRange() var startPos = CaretPosition.fromRangeStart(rng) normalizeEndPoint(dom, collapsed, true, normRng).each(function (pos) { if (!collapsed || !CaretPosition.isAbove(startPos, pos)) { normRng.setStart(pos.container(), pos.offset()) } }) if (!collapsed) { normalizeEndPoint(dom, collapsed, false, normRng).each(function (pos) { normRng.setEnd(pos.container(), pos.offset()) }) } if (collapsed) { normRng.collapse(true) } return isEq$4(rng, normRng) ? Optional.none() : Optional.some(normRng) } var splitText = function (node, offset) { return node.splitText(offset) } var split = function (rng) { var startContainer = rng.startContainer, startOffset = rng.startOffset, endContainer = rng.endContainer, endOffset = rng.endOffset if (startContainer === endContainer && isText$7(startContainer)) { if (startOffset > 0 && startOffset < startContainer.nodeValue.length) { endContainer = splitText(startContainer, startOffset) startContainer = endContainer.previousSibling if (endOffset > startOffset) { endOffset = endOffset - startOffset startContainer = endContainer = splitText( endContainer, endOffset ).previousSibling endOffset = endContainer.nodeValue.length startOffset = 0 } else { endOffset = 0 } } } else { if ( isText$7(startContainer) && startOffset > 0 && startOffset < startContainer.nodeValue.length ) { startContainer = splitText(startContainer, startOffset) startOffset = 0 } if ( isText$7(endContainer) && endOffset > 0 && endOffset < endContainer.nodeValue.length ) { endContainer = splitText(endContainer, endOffset).previousSibling endOffset = endContainer.nodeValue.length } } return { startContainer: startContainer, startOffset: startOffset, endContainer: endContainer, endOffset: endOffset, } } var RangeUtils = function (dom) { var walk = function (rng, callback) { return walk$2(dom, rng, callback) } var split$1 = split var normalize = function (rng) { return normalize$2(dom, rng).fold(never, function (normalizedRng) { rng.setStart(normalizedRng.startContainer, normalizedRng.startOffset) rng.setEnd(normalizedRng.endContainer, normalizedRng.endOffset) return true }) } return { walk: walk, split: split$1, normalize: normalize, } } RangeUtils.compareRanges = isEq$4 RangeUtils.getCaretRangeFromPoint = fromPoint RangeUtils.getSelectedNode = getSelectedNode RangeUtils.getNode = getNode$1 var Dimension = function (name, getOffset) { var set = function (element, h) { if (!isNumber(h) && !h.match(/^[0-9]+$/)) { throw new Error( name + '.set accepts only positive integer values. Value was ' + h ) } var dom = element.dom if (isSupported(dom)) { dom.style[name] = h + 'px' } } var get = function (element) { var r = getOffset(element) if (r <= 0 || r === null) { var css = get$5(element, name) return parseFloat(css) || 0 } return r } var getOuter = get var aggregate = function (element, properties) { return foldl( properties, function (acc, property) { var val = get$5(element, property) var value = val === undefined ? 0 : parseInt(val, 10) return isNaN(value) ? acc : acc + value }, 0 ) } var max = function (element, value, properties) { var cumulativeInclusions = aggregate(element, properties) var absoluteMax = value > cumulativeInclusions ? value - cumulativeInclusions : 0 return absoluteMax } return { set: set, get: get, getOuter: getOuter, aggregate: aggregate, max: max, } } var api = Dimension('height', function (element) { var dom = element.dom return inBody(element) ? dom.getBoundingClientRect().height : dom.offsetHeight }) var get$1 = function (element) { return api.get(element) } var walkUp = function (navigation, doc) { var frame = navigation.view(doc) return frame.fold(constant([]), function (f) { var parent = navigation.owner(f) var rest = walkUp(navigation, parent) return [f].concat(rest) }) } var pathTo = function (element, navigation) { var d = navigation.owner(element) return walkUp(navigation, d) } var view = function (doc) { var _a var element = doc.dom === document ? Optional.none() : Optional.from( (_a = doc.dom.defaultView) === null || _a === void 0 ? void 0 : _a.frameElement ) return element.map(SugarElement.fromDom) } var owner = function (element) { return documentOrOwner(element) } var Navigation = /*#__PURE__*/ Object.freeze({ __proto__: null, view: view, owner: owner, }) var find$1 = function (element) { var doc = SugarElement.fromDom(document) var scroll = get$8(doc) var frames = pathTo(element, Navigation) var offset = viewport(element) var r = foldr( frames, function (b, a) { var loc = viewport(a) return { left: b.left + loc.left, top: b.top + loc.top, } }, { left: 0, top: 0, } ) return SugarPosition( r.left + offset.left + scroll.left, r.top + offset.top + scroll.top ) } var excludeFromDescend = function (element) { return name(element) === 'textarea' } var fireScrollIntoViewEvent = function (editor, data) { var scrollEvent = editor.fire('ScrollIntoView', data) return scrollEvent.isDefaultPrevented() } var fireAfterScrollIntoViewEvent = function (editor, data) { editor.fire('AfterScrollIntoView', data) } var descend = function (element, offset) { var children$1 = children(element) if (children$1.length === 0 || excludeFromDescend(element)) { return { element: element, offset: offset, } } else if ( offset < children$1.length && !excludeFromDescend(children$1[offset]) ) { return { element: children$1[offset], offset: 0, } } else { var last = children$1[children$1.length - 1] if (excludeFromDescend(last)) { return { element: element, offset: offset, } } else { if (name(last) === 'img') { return { element: last, offset: 1, } } else if (isText$8(last)) { return { element: last, offset: get$2(last).length, } } else { return { element: last, offset: children(last).length, } } } } } var markerInfo = function (element, cleanupFun) { var pos = absolute(element) var height = get$1(element) return { element: element, bottom: pos.top + height, height: height, pos: pos, cleanup: cleanupFun, } } var createMarker = function (element, offset) { var startPoint = descend(element, offset) var span = SugarElement.fromHtml( '' + ZWSP$1 + '' ) before$4(startPoint.element, span) return markerInfo(span, function () { return remove$7(span) }) } var elementMarker = function (element) { return markerInfo(SugarElement.fromDom(element), noop) } var withMarker = function (editor, f, rng, alignToTop) { preserveWith( editor, function (_s, _e) { return applyWithMarker(editor, f, rng, alignToTop) }, rng ) } var withScrollEvents = function (editor, doc, f, marker, alignToTop) { var data = { elm: marker.element.dom, alignToTop: alignToTop, } if (fireScrollIntoViewEvent(editor, data)) { return } var scrollTop = get$8(doc).top f(doc, scrollTop, marker, alignToTop) fireAfterScrollIntoViewEvent(editor, data) } var applyWithMarker = function (editor, f, rng, alignToTop) { var body = SugarElement.fromDom(editor.getBody()) var doc = SugarElement.fromDom(editor.getDoc()) reflow(body) var marker = createMarker( SugarElement.fromDom(rng.startContainer), rng.startOffset ) withScrollEvents(editor, doc, f, marker, alignToTop) marker.cleanup() } var withElement = function (editor, element, f, alignToTop) { var doc = SugarElement.fromDom(editor.getDoc()) withScrollEvents(editor, doc, f, elementMarker(element), alignToTop) } var preserveWith = function (editor, f, rng) { var startElement = rng.startContainer var startOffset = rng.startOffset var endElement = rng.endContainer var endOffset = rng.endOffset f(SugarElement.fromDom(startElement), SugarElement.fromDom(endElement)) var newRng = editor.dom.createRng() newRng.setStart(startElement, startOffset) newRng.setEnd(endElement, endOffset) editor.selection.setRng(rng) } var scrollToMarker = function (marker, viewHeight, alignToTop, doc) { var pos = marker.pos if (alignToTop) { to(pos.left, pos.top, doc) } else { var y = pos.top - viewHeight + marker.height to(pos.left, y, doc) } } var intoWindowIfNeeded = function ( doc, scrollTop, viewHeight, marker, alignToTop ) { var viewportBottom = viewHeight + scrollTop var markerTop = marker.pos.top var markerBottom = marker.bottom var largerThanViewport = markerBottom - markerTop >= viewHeight if (markerTop < scrollTop) { scrollToMarker(marker, viewHeight, alignToTop !== false, doc) } else if (markerTop > viewportBottom) { var align = largerThanViewport ? alignToTop !== false : alignToTop === true scrollToMarker(marker, viewHeight, align, doc) } else if (markerBottom > viewportBottom && !largerThanViewport) { scrollToMarker(marker, viewHeight, alignToTop === true, doc) } } var intoWindow = function (doc, scrollTop, marker, alignToTop) { var viewHeight = doc.dom.defaultView.innerHeight intoWindowIfNeeded(doc, scrollTop, viewHeight, marker, alignToTop) } var intoFrame = function (doc, scrollTop, marker, alignToTop) { var frameViewHeight = doc.dom.defaultView.innerHeight intoWindowIfNeeded(doc, scrollTop, frameViewHeight, marker, alignToTop) var op = find$1(marker.element) var viewportBounds = getBounds(window) if (op.top < viewportBounds.y) { intoView(marker.element, alignToTop !== false) } else if (op.top > viewportBounds.bottom) { intoView(marker.element, alignToTop === true) } } var rangeIntoWindow = function (editor, rng, alignToTop) { return withMarker(editor, intoWindow, rng, alignToTop) } var elementIntoWindow = function (editor, element, alignToTop) { return withElement(editor, element, intoWindow, alignToTop) } var rangeIntoFrame = function (editor, rng, alignToTop) { return withMarker(editor, intoFrame, rng, alignToTop) } var elementIntoFrame = function (editor, element, alignToTop) { return withElement(editor, element, intoFrame, alignToTop) } var scrollElementIntoView = function (editor, element, alignToTop) { var scroller = editor.inline ? elementIntoWindow : elementIntoFrame scroller(editor, element, alignToTop) } var scrollRangeIntoView = function (editor, rng, alignToTop) { var scroller = editor.inline ? rangeIntoWindow : rangeIntoFrame scroller(editor, rng, alignToTop) } var getDocument = function () { return SugarElement.fromDom(document) } var focus$1 = function (element) { return element.dom.focus() } var hasFocus$1 = function (element) { var root = getRootNode(element).dom return element.dom === root.activeElement } var active = function (root) { if (root === void 0) { root = getDocument() } return Optional.from(root.dom.activeElement).map(SugarElement.fromDom) } var search = function (element) { return active(getRootNode(element)).filter(function (e) { return element.dom.contains(e.dom) }) } var create$5 = function (start, soffset, finish, foffset) { return { start: start, soffset: soffset, finish: finish, foffset: foffset, } } var SimRange = { create: create$5 } var adt$1 = Adt.generate([ { before: ['element'] }, { on: ['element', 'offset'], }, { after: ['element'] }, ]) var cata = function (subject, onBefore, onOn, onAfter) { return subject.fold(onBefore, onOn, onAfter) } var getStart$2 = function (situ) { return situ.fold(identity, identity, identity) } var before$1 = adt$1.before var on = adt$1.on var after$1 = adt$1.after var Situ = { before: before$1, on: on, after: after$1, cata: cata, getStart: getStart$2, } var adt = Adt.generate([ { domRange: ['rng'] }, { relative: ['startSitu', 'finishSitu'], }, { exact: ['start', 'soffset', 'finish', 'foffset'], }, ]) var exactFromRange = function (simRange) { return adt.exact( simRange.start, simRange.soffset, simRange.finish, simRange.foffset ) } var getStart$1 = function (selection) { return selection.match({ domRange: function (rng) { return SugarElement.fromDom(rng.startContainer) }, relative: function (startSitu, _finishSitu) { return Situ.getStart(startSitu) }, exact: function (start, _soffset, _finish, _foffset) { return start }, }) } var domRange = adt.domRange var relative = adt.relative var exact = adt.exact var getWin = function (selection) { var start = getStart$1(selection) return defaultView(start) } var range = SimRange.create var SimSelection = { domRange: domRange, relative: relative, exact: exact, exactFromRange: exactFromRange, getWin: getWin, range: range, } var browser$1 = detect().browser var clamp$1 = function (offset, element) { var max = isText$8(element) ? get$2(element).length : children(element).length + 1 if (offset > max) { return max } else if (offset < 0) { return 0 } return offset } var normalizeRng = function (rng) { return SimSelection.range( rng.start, clamp$1(rng.soffset, rng.start), rng.finish, clamp$1(rng.foffset, rng.finish) ) } var isOrContains = function (root, elm) { return ( !isRestrictedNode(elm.dom) && (contains$1(root, elm) || eq(root, elm)) ) } var isRngInRoot = function (root) { return function (rng) { return isOrContains(root, rng.start) && isOrContains(root, rng.finish) } } var shouldStore = function (editor) { return editor.inline === true || browser$1.isIE() } var nativeRangeToSelectionRange = function (r) { return SimSelection.range( SugarElement.fromDom(r.startContainer), r.startOffset, SugarElement.fromDom(r.endContainer), r.endOffset ) } var readRange = function (win) { var selection = win.getSelection() var rng = !selection || selection.rangeCount === 0 ? Optional.none() : Optional.from(selection.getRangeAt(0)) return rng.map(nativeRangeToSelectionRange) } var getBookmark = function (root) { var win = defaultView(root) return readRange(win.dom).filter(isRngInRoot(root)) } var validate = function (root, bookmark) { return Optional.from(bookmark).filter(isRngInRoot(root)).map(normalizeRng) } var bookmarkToNativeRng = function (bookmark) { var rng = document.createRange() try { rng.setStart(bookmark.start.dom, bookmark.soffset) rng.setEnd(bookmark.finish.dom, bookmark.foffset) return Optional.some(rng) } catch (_) { return Optional.none() } } var store = function (editor) { var newBookmark = shouldStore(editor) ? getBookmark(SugarElement.fromDom(editor.getBody())) : Optional.none() editor.bookmark = newBookmark.isSome() ? newBookmark : editor.bookmark } var storeNative = function (editor, rng) { var root = SugarElement.fromDom(editor.getBody()) var range = shouldStore(editor) ? Optional.from(rng) : Optional.none() var newBookmark = range .map(nativeRangeToSelectionRange) .filter(isRngInRoot(root)) editor.bookmark = newBookmark.isSome() ? newBookmark : editor.bookmark } var getRng = function (editor) { var bookmark = editor.bookmark ? editor.bookmark : Optional.none() return bookmark .bind(function (x) { return validate(SugarElement.fromDom(editor.getBody()), x) }) .bind(bookmarkToNativeRng) } var restore = function (editor) { getRng(editor).each(function (rng) { return editor.selection.setRng(rng) }) } var isEditorUIElement$1 = function (elm) { var className = elm.className.toString() return className.indexOf('tox-') !== -1 || className.indexOf('mce-') !== -1 } var FocusManager = { isEditorUIElement: isEditorUIElement$1 } var isManualNodeChange = function (e) { return e.type === 'nodechange' && e.selectionChange } var registerPageMouseUp = function (editor, throttledStore) { var mouseUpPage = function () { throttledStore.throttle() } DOMUtils.DOM.bind(document, 'mouseup', mouseUpPage) editor.on('remove', function () { DOMUtils.DOM.unbind(document, 'mouseup', mouseUpPage) }) } var registerFocusOut = function (editor) { editor.on('focusout', function () { store(editor) }) } var registerMouseUp = function (editor, throttledStore) { editor.on('mouseup touchend', function (_e) { throttledStore.throttle() }) } var registerEditorEvents = function (editor, throttledStore) { var browser = detect().browser if (browser.isIE()) { registerFocusOut(editor) } else { registerMouseUp(editor, throttledStore) } editor.on('keyup NodeChange', function (e) { if (!isManualNodeChange(e)) { store(editor) } }) } var register$3 = function (editor) { var throttledStore = first(function () { store(editor) }, 0) editor.on('init', function () { if (editor.inline) { registerPageMouseUp(editor, throttledStore) } registerEditorEvents(editor, throttledStore) }) editor.on('remove', function () { throttledStore.cancel() }) } var documentFocusInHandler var DOM$8 = DOMUtils.DOM var isEditorUIElement = function (elm) { return FocusManager.isEditorUIElement(elm) } var isEditorContentAreaElement = function (elm) { var classList = elm.classList if (classList !== undefined) { return ( classList.contains('tox-edit-area') || classList.contains('tox-edit-area__iframe') || classList.contains('mce-content-body') ) } else { return false } } var isUIElement = function (editor, elm) { var customSelector = getCustomUiSelector(editor) var parent = DOM$8.getParent(elm, function (elm) { return ( isEditorUIElement(elm) || (customSelector ? editor.dom.is(elm, customSelector) : false) ) }) return parent !== null } var getActiveElement = function (editor) { try { var root = getRootNode(SugarElement.fromDom(editor.getElement())) return active(root).fold( function () { return document.body }, function (x) { return x.dom } ) } catch (ex) { return document.body } } var registerEvents$1 = function (editorManager, e) { var editor = e.editor register$3(editor) editor.on('focusin', function () { var focusedEditor = editorManager.focusedEditor if (focusedEditor !== editor) { if (focusedEditor) { focusedEditor.fire('blur', { focusedEditor: editor }) } editorManager.setActive(editor) editorManager.focusedEditor = editor editor.fire('focus', { blurredEditor: focusedEditor }) editor.focus(true) } }) editor.on('focusout', function () { Delay.setEditorTimeout(editor, function () { var focusedEditor = editorManager.focusedEditor if ( !isUIElement(editor, getActiveElement(editor)) && focusedEditor === editor ) { editor.fire('blur', { focusedEditor: null }) editorManager.focusedEditor = null } }) }) if (!documentFocusInHandler) { documentFocusInHandler = function (e) { var activeEditor = editorManager.activeEditor if (activeEditor) { getOriginalEventTarget(e).each(function (target) { if (target.ownerDocument === document) { if ( target !== document.body && !isUIElement(activeEditor, target) && editorManager.focusedEditor === activeEditor ) { activeEditor.fire('blur', { focusedEditor: null }) editorManager.focusedEditor = null } } }) } } DOM$8.bind(document, 'focusin', documentFocusInHandler) } } var unregisterDocumentEvents = function (editorManager, e) { if (editorManager.focusedEditor === e.editor) { editorManager.focusedEditor = null } if (!editorManager.activeEditor) { DOM$8.unbind(document, 'focusin', documentFocusInHandler) documentFocusInHandler = null } } var setup$l = function (editorManager) { editorManager.on('AddEditor', curry(registerEvents$1, editorManager)) editorManager.on( 'RemoveEditor', curry(unregisterDocumentEvents, editorManager) ) } var getContentEditableHost = function (editor, node) { return editor.dom.getParent(node, function (node) { return editor.dom.getContentEditable(node) === 'true' }) } var getCollapsedNode = function (rng) { return rng.collapsed ? Optional.from(getNode$1(rng.startContainer, rng.startOffset)).map( SugarElement.fromDom ) : Optional.none() } var getFocusInElement = function (root, rng) { return getCollapsedNode(rng).bind(function (node) { if (isTableSection(node)) { return Optional.some(node) } else if (contains$1(root, node) === false) { return Optional.some(root) } else { return Optional.none() } }) } var normalizeSelection$1 = function (editor, rng) { getFocusInElement(SugarElement.fromDom(editor.getBody()), rng) .bind(function (elm) { return firstPositionIn(elm.dom) }) .fold( function () { editor.selection.normalize() return }, function (caretPos) { return editor.selection.setRng(caretPos.toRange()) } ) } var focusBody = function (body) { if (body.setActive) { try { body.setActive() } catch (ex) { body.focus() } } else { body.focus() } } var hasElementFocus = function (elm) { return hasFocus$1(elm) || search(elm).isSome() } var hasIframeFocus = function (editor) { return ( editor.iframeElement && hasFocus$1(SugarElement.fromDom(editor.iframeElement)) ) } var hasInlineFocus = function (editor) { var rawBody = editor.getBody() return rawBody && hasElementFocus(SugarElement.fromDom(rawBody)) } var hasUiFocus = function (editor) { var dos = getRootNode(SugarElement.fromDom(editor.getElement())) return active(dos) .filter(function (elem) { return ( !isEditorContentAreaElement(elem.dom) && isUIElement(editor, elem.dom) ) }) .isSome() } var hasFocus = function (editor) { return editor.inline ? hasInlineFocus(editor) : hasIframeFocus(editor) } var hasEditorOrUiFocus = function (editor) { return hasFocus(editor) || hasUiFocus(editor) } var focusEditor = function (editor) { var selection = editor.selection var body = editor.getBody() var rng = selection.getRng() editor.quirks.refreshContentEditable() if (editor.bookmark !== undefined && hasFocus(editor) === false) { getRng(editor).each(function (bookmarkRng) { editor.selection.setRng(bookmarkRng) rng = bookmarkRng }) } var contentEditableHost = getContentEditableHost( editor, selection.getNode() ) if (editor.$.contains(body, contentEditableHost)) { focusBody(contentEditableHost) normalizeSelection$1(editor, rng) activateEditor(editor) return } if (!editor.inline) { if (!Env.opera) { focusBody(body) } editor.getWin().focus() } if (Env.gecko || editor.inline) { focusBody(body) normalizeSelection$1(editor, rng) } activateEditor(editor) } var activateEditor = function (editor) { return editor.editorManager.setActive(editor) } var focus = function (editor, skipFocus) { if (editor.removed) { return } if (skipFocus) { activateEditor(editor) } else { focusEditor(editor) } } var getEndpointElement = function (root, rng, start, real, resolve) { var container = start ? rng.startContainer : rng.endContainer var offset = start ? rng.startOffset : rng.endOffset return Optional.from(container) .map(SugarElement.fromDom) .map(function (elm) { return !real || !rng.collapsed ? child$1(elm, resolve(elm, offset)).getOr(elm) : elm }) .bind(function (elm) { return isElement$6(elm) ? Optional.some(elm) : parent(elm).filter(isElement$6) }) .map(function (elm) { return elm.dom }) .getOr(root) } var getStart = function (root, rng, real) { return getEndpointElement(root, rng, true, real, function (elm, offset) { return Math.min(childNodesCount(elm), offset) }) } var getEnd = function (root, rng, real) { return getEndpointElement(root, rng, false, real, function (elm, offset) { return offset > 0 ? offset - 1 : offset }) } var skipEmptyTextNodes = function (node, forwards) { var orig = node while (node && isText$7(node) && node.length === 0) { node = forwards ? node.nextSibling : node.previousSibling } return node || orig } var getNode = function (root, rng) { var elm, startContainer, endContainer if (!rng) { return root } startContainer = rng.startContainer endContainer = rng.endContainer var startOffset = rng.startOffset var endOffset = rng.endOffset elm = rng.commonAncestorContainer if (!rng.collapsed) { if (startContainer === endContainer) { if (endOffset - startOffset < 2) { if (startContainer.hasChildNodes()) { elm = startContainer.childNodes[startOffset] } } } if (startContainer.nodeType === 3 && endContainer.nodeType === 3) { if (startContainer.length === startOffset) { startContainer = skipEmptyTextNodes(startContainer.nextSibling, true) } else { startContainer = startContainer.parentNode } if (endOffset === 0) { endContainer = skipEmptyTextNodes(endContainer.previousSibling, false) } else { endContainer = endContainer.parentNode } if (startContainer && startContainer === endContainer) { return startContainer } } } if (elm && elm.nodeType === 3) { return elm.parentNode } return elm } var getSelectedBlocks = function (dom, rng, startElm, endElm) { var node var selectedBlocks = [] var root = dom.getRoot() startElm = dom.getParent( startElm || getStart(root, rng, rng.collapsed), dom.isBlock ) endElm = dom.getParent( endElm || getEnd(root, rng, rng.collapsed), dom.isBlock ) if (startElm && startElm !== root) { selectedBlocks.push(startElm) } if (startElm && endElm && startElm !== endElm) { node = startElm var walker = new DomTreeWalker(startElm, root) while ((node = walker.next()) && node !== endElm) { if (dom.isBlock(node)) { selectedBlocks.push(node) } } } if (endElm && startElm !== endElm && endElm !== root) { selectedBlocks.push(endElm) } return selectedBlocks } var select = function (dom, node, content) { return Optional.from(node).map(function (node) { var idx = dom.nodeIndex(node) var rng = dom.createRng() rng.setStart(node.parentNode, idx) rng.setEnd(node.parentNode, idx + 1) if (content) { moveEndPoint(dom, rng, node, true) moveEndPoint(dom, rng, node, false) } return rng }) } var processRanges = function (editor, ranges) { return map$3(ranges, function (range) { var evt = editor.fire('GetSelectionRange', { range: range }) return evt.range !== range ? evt.range : range }) } var typeLookup = { '#text': 3, '#comment': 8, '#cdata': 4, '#pi': 7, '#doctype': 10, '#document-fragment': 11, } var walk$1 = function (node, root, prev) { var startName = prev ? 'lastChild' : 'firstChild' var siblingName = prev ? 'prev' : 'next' if (node[startName]) { return node[startName] } if (node !== root) { var sibling = node[siblingName] if (sibling) { return sibling } for ( var parent_1 = node.parent; parent_1 && parent_1 !== root; parent_1 = parent_1.parent ) { sibling = parent_1[siblingName] if (sibling) { return sibling } } } } var isEmptyTextNode = function (node) { if (!isWhitespaceText(node.value)) { return false } var parentNode = node.parent if ( parentNode && (parentNode.name !== 'span' || parentNode.attr('style')) && /^[ ]+$/.test(node.value) ) { return false } return true } var isNonEmptyElement = function (node) { var isNamedAnchor = node.name === 'a' && !node.attr('href') && node.attr('id') return ( node.attr('name') || (node.attr('id') && !node.firstChild) || node.attr('data-mce-bookmark') || isNamedAnchor ) } var AstNode = (function () { function AstNode(name, type) { this.name = name this.type = type if (type === 1) { this.attributes = [] this.attributes.map = {} } } AstNode.create = function (name, attrs) { var node = new AstNode(name, typeLookup[name] || 1) if (attrs) { each$j(attrs, function (value, attrName) { node.attr(attrName, value) }) } return node } AstNode.prototype.replace = function (node) { var self = this if (node.parent) { node.remove() } self.insert(node, self) self.remove() return self } AstNode.prototype.attr = function (name, value) { var self = this var attrs if (typeof name !== 'string') { if (name !== undefined && name !== null) { each$j(name, function (value, key) { self.attr(key, value) }) } return self } if ((attrs = self.attributes)) { if (value !== undefined) { if (value === null) { if (name in attrs.map) { delete attrs.map[name] var i = attrs.length while (i--) { if (attrs[i].name === name) { attrs.splice(i, 1) return self } } } return self } if (name in attrs.map) { var i = attrs.length while (i--) { if (attrs[i].name === name) { attrs[i].value = value break } } } else { attrs.push({ name: name, value: value, }) } attrs.map[name] = value return self } return attrs.map[name] } } AstNode.prototype.clone = function () { var self = this var clone = new AstNode(self.name, self.type) var selfAttrs if ((selfAttrs = self.attributes)) { var cloneAttrs = [] cloneAttrs.map = {} for (var i = 0, l = selfAttrs.length; i < l; i++) { var selfAttr = selfAttrs[i] if (selfAttr.name !== 'id') { cloneAttrs[cloneAttrs.length] = { name: selfAttr.name, value: selfAttr.value, } cloneAttrs.map[selfAttr.name] = selfAttr.value } } clone.attributes = cloneAttrs } clone.value = self.value clone.shortEnded = self.shortEnded return clone } AstNode.prototype.wrap = function (wrapper) { var self = this self.parent.insert(wrapper, self) wrapper.append(self) return self } AstNode.prototype.unwrap = function () { var self = this for (var node = self.firstChild; node; ) { var next = node.next self.insert(node, self, true) node = next } self.remove() } AstNode.prototype.remove = function () { var self = this, parent = self.parent, next = self.next, prev = self.prev if (parent) { if (parent.firstChild === self) { parent.firstChild = next if (next) { next.prev = null } } else { prev.next = next } if (parent.lastChild === self) { parent.lastChild = prev if (prev) { prev.next = null } } else { next.prev = prev } self.parent = self.next = self.prev = null } return self } AstNode.prototype.append = function (node) { var self = this if (node.parent) { node.remove() } var last = self.lastChild if (last) { last.next = node node.prev = last self.lastChild = node } else { self.lastChild = self.firstChild = node } node.parent = self return node } AstNode.prototype.insert = function (node, refNode, before) { if (node.parent) { node.remove() } var parent = refNode.parent || this if (before) { if (refNode === parent.firstChild) { parent.firstChild = node } else { refNode.prev.next = node } node.prev = refNode.prev node.next = refNode refNode.prev = node } else { if (refNode === parent.lastChild) { parent.lastChild = node } else { refNode.next.prev = node } node.next = refNode.next node.prev = refNode refNode.next = node } node.parent = parent return node } AstNode.prototype.getAll = function (name) { var self = this var collection = [] for (var node = self.firstChild; node; node = walk$1(node, self)) { if (node.name === name) { collection.push(node) } } return collection } AstNode.prototype.children = function () { var self = this var collection = [] for (var node = self.firstChild; node; node = node.next) { collection.push(node) } return collection } AstNode.prototype.empty = function () { var self = this if (self.firstChild) { var nodes = [] for (var node = self.firstChild; node; node = walk$1(node, self)) { nodes.push(node) } var i = nodes.length while (i--) { var node = nodes[i] node.parent = node.firstChild = node.lastChild = node.next = node.prev = null } } self.firstChild = self.lastChild = null return self } AstNode.prototype.isEmpty = function (elements, whitespace, predicate) { if (whitespace === void 0) { whitespace = {} } var self = this var node = self.firstChild if (isNonEmptyElement(self)) { return false } if (node) { do { if (node.type === 1) { if (node.attr('data-mce-bogus')) { continue } if (elements[node.name]) { return false } if (isNonEmptyElement(node)) { return false } } if (node.type === 8) { return false } if (node.type === 3 && !isEmptyTextNode(node)) { return false } if ( node.type === 3 && node.parent && whitespace[node.parent.name] && isWhitespaceText(node.value) ) { return false } if (predicate && predicate(node)) { return false } } while ((node = walk$1(node, self))) } return true } AstNode.prototype.walk = function (prev) { return walk$1(this, null, prev) } return AstNode })() var extractBase64DataUris = function (html) { var dataImageUri = /data:[^;]+;base64,([a-z0-9\+\/=\s]+)/gi var chunks = [] var uris = {} var prefix = generate('img') var matches var index = 0 var count = 0 while ((matches = dataImageUri.exec(html))) { var uri = matches[0] var imageId = prefix + '_' + count++ uris[imageId] = uri if (index < matches.index) { chunks.push(html.substr(index, matches.index - index)) } chunks.push(imageId) index = matches.index + uri.length } var re = new RegExp(prefix + '_[0-9]+', 'g') if (index === 0) { return { prefix: prefix, uris: uris, html: html, re: re, } } else { if (index < html.length) { chunks.push(html.substr(index)) } return { prefix: prefix, uris: uris, html: chunks.join(''), re: re, } } } var restoreDataUris = function (html, result) { return html.replace(result.re, function (imageId) { return get$9(result.uris, imageId).getOr(imageId) }) } var parseDataUri$1 = function (uri) { var matches = /data:([^;]+);base64,([a-z0-9\+\/=\s]+)/i.exec(uri) if (matches) { return Optional.some({ type: matches[1], data: decodeURIComponent(matches[2]), }) } else { return Optional.none() } } var each$d = Tools.each, trim = Tools.trim var queryParts = 'source protocol authority userInfo user password host port relative path directory file query anchor'.split( ' ' ) var DEFAULT_PORTS = { ftp: 21, http: 80, https: 443, mailto: 25, } var safeSvgDataUrlElements = ['img', 'video'] var blockSvgDataUris = function (allowSvgDataUrls, tagName) { if (isNonNullable(allowSvgDataUrls)) { return !allowSvgDataUrls } else { return isNonNullable(tagName) ? !contains$3(safeSvgDataUrlElements, tagName) : true } } var isInvalidUri = function (settings, uri, tagName) { if (settings.allow_html_data_urls) { return false } else if (/^data:image\//i.test(uri)) { return ( blockSvgDataUris(settings.allow_svg_data_urls, tagName) && /^data:image\/svg\+xml/i.test(uri) ) } else { return /^data:/i.test(uri) } } var URI = (function () { function URI(url, settings) { url = trim(url) this.settings = settings || {} var baseUri = this.settings.base_uri var self = this if (/^([\w\-]+):([^\/]{2})/i.test(url) || /^\s*#/.test(url)) { self.source = url return } var isProtocolRelative = url.indexOf('//') === 0 if (url.indexOf('/') === 0 && !isProtocolRelative) { url = (baseUri ? baseUri.protocol || 'http' : 'http') + '://mce_host' + url } if (!/^[\w\-]*:?\/\//.test(url)) { var baseUrl = this.settings.base_uri ? this.settings.base_uri.path : new URI(document.location.href).directory if (this.settings.base_uri && this.settings.base_uri.protocol == '') { url = '//mce_host' + self.toAbsPath(baseUrl, url) } else { var match = /([^#?]*)([#?]?.*)/.exec(url) url = ((baseUri && baseUri.protocol) || 'http') + '://mce_host' + self.toAbsPath(baseUrl, match[1]) + match[2] } } url = url.replace(/@@/g, '(mce_at)') var urlMatch = /^(?:(?![^:@]+:[^:@\/]*@)([^:\/?#.]+):)?(?:\/\/)?((?:(([^:@\/]*):?([^:@\/]*))?@)?(\[[a-zA-Z0-9:.%]+\]|[^:\/?#]*)(?::(\d*))?)(((\/(?:[^?#](?![^?#\/]*\.[^?#\/.]+(?:[?#]|$)))*\/?)?([^?#\/]*))(?:\?([^#]*))?(?:#(.*))?)/.exec( url ) each$d(queryParts, function (v, i) { var part = urlMatch[i] if (part) { part = part.replace(/\(mce_at\)/g, '@@') } self[v] = part }) if (baseUri) { if (!self.protocol) { self.protocol = baseUri.protocol } if (!self.userInfo) { self.userInfo = baseUri.userInfo } if (!self.port && self.host === 'mce_host') { self.port = baseUri.port } if (!self.host || self.host === 'mce_host') { self.host = baseUri.host } self.source = '' } if (isProtocolRelative) { self.protocol = '' } } URI.parseDataUri = function (uri) { var type var uriComponents = decodeURIComponent(uri).split(',') var matches = /data:([^;]+)/.exec(uriComponents[0]) if (matches) { type = matches[1] } return { type: type, data: uriComponents[1], } } URI.isDomSafe = function (uri, context, options) { if (options === void 0) { options = {} } if (options.allow_script_urls) { return true } else { var decodedUri = Entities.decode(uri).replace(/[\s\u0000-\u001F]+/g, '') try { decodedUri = decodeURIComponent(decodedUri) } catch (ex) { decodedUri = unescape(decodedUri) } if (/((java|vb)script|mhtml):/i.test(decodedUri)) { return false } return !isInvalidUri(options, decodedUri, context) } } URI.getDocumentBaseUrl = function (loc) { var baseUrl if (loc.protocol.indexOf('http') !== 0 && loc.protocol !== 'file:') { baseUrl = loc.href } else { baseUrl = loc.protocol + '//' + loc.host + loc.pathname } if (/^[^:]+:\/\/\/?[^\/]+\//.test(baseUrl)) { baseUrl = baseUrl.replace(/[\?#].*$/, '').replace(/[\/\\][^\/]+$/, '') if (!/[\/\\]$/.test(baseUrl)) { baseUrl += '/' } } return baseUrl } URI.prototype.setPath = function (path) { var pathMatch = /^(.*?)\/?(\w+)?$/.exec(path) this.path = pathMatch[0] this.directory = pathMatch[1] this.file = pathMatch[2] this.source = '' this.getURI() } URI.prototype.toRelative = function (uri) { var output if (uri === './') { return uri } var relativeUri = new URI(uri, { base_uri: this }) if ( (relativeUri.host !== 'mce_host' && this.host !== relativeUri.host && relativeUri.host) || this.port !== relativeUri.port || (this.protocol !== relativeUri.protocol && relativeUri.protocol !== '') ) { return relativeUri.getURI() } var tu = this.getURI(), uu = relativeUri.getURI() if ( tu === uu || (tu.charAt(tu.length - 1) === '/' && tu.substr(0, tu.length - 1) === uu) ) { return tu } output = this.toRelPath(this.path, relativeUri.path) if (relativeUri.query) { output += '?' + relativeUri.query } if (relativeUri.anchor) { output += '#' + relativeUri.anchor } return output } URI.prototype.toAbsolute = function (uri, noHost) { var absoluteUri = new URI(uri, { base_uri: this }) return absoluteUri.getURI(noHost && this.isSameOrigin(absoluteUri)) } URI.prototype.isSameOrigin = function (uri) { if (this.host == uri.host && this.protocol == uri.protocol) { if (this.port == uri.port) { return true } var defaultPort = DEFAULT_PORTS[this.protocol] if ( defaultPort && (this.port || defaultPort) == (uri.port || defaultPort) ) { return true } } return false } URI.prototype.toRelPath = function (base, path) { var breakPoint = 0, out = '', i, l var normalizedBase = base.substring(0, base.lastIndexOf('/')).split('/') var items = path.split('/') if (normalizedBase.length >= items.length) { for (i = 0, l = normalizedBase.length; i < l; i++) { if (i >= items.length || normalizedBase[i] !== items[i]) { breakPoint = i + 1 break } } } if (normalizedBase.length < items.length) { for (i = 0, l = items.length; i < l; i++) { if (i >= normalizedBase.length || normalizedBase[i] !== items[i]) { breakPoint = i + 1 break } } } if (breakPoint === 1) { return path } for (i = 0, l = normalizedBase.length - (breakPoint - 1); i < l; i++) { out += '../' } for (i = breakPoint - 1, l = items.length; i < l; i++) { if (i !== breakPoint - 1) { out += '/' + items[i] } else { out += items[i] } } return out } URI.prototype.toAbsPath = function (base, path) { var i, nb = 0, o = [], outPath var tr = /\/$/.test(path) ? '/' : '' var normalizedBase = base.split('/') var normalizedPath = path.split('/') each$d(normalizedBase, function (k) { if (k) { o.push(k) } }) normalizedBase = o for (i = normalizedPath.length - 1, o = []; i >= 0; i--) { if (normalizedPath[i].length === 0 || normalizedPath[i] === '.') { continue } if (normalizedPath[i] === '..') { nb++ continue } if (nb > 0) { nb-- continue } o.push(normalizedPath[i]) } i = normalizedBase.length - nb if (i <= 0) { outPath = reverse(o).join('/') } else { outPath = normalizedBase.slice(0, i).join('/') + '/' + reverse(o).join('/') } if (outPath.indexOf('/') !== 0) { outPath = '/' + outPath } if (tr && outPath.lastIndexOf('/') !== outPath.length - 1) { outPath += tr } return outPath } URI.prototype.getURI = function (noProtoHost) { if (noProtoHost === void 0) { noProtoHost = false } var s if (!this.source || noProtoHost) { s = '' if (!noProtoHost) { if (this.protocol) { s += this.protocol + '://' } else { s += '//' } if (this.userInfo) { s += this.userInfo + '@' } if (this.host) { s += this.host } if (this.port) { s += ':' + this.port } } if (this.path) { s += this.path } if (this.query) { s += '?' + this.query } if (this.anchor) { s += '#' + this.anchor } this.source = s } return this.source } return URI })() var filteredClobberElements = Tools.makeMap( 'button,fieldset,form,iframe,img,image,input,object,output,select,textarea' ) var isValidPrefixAttrName = function (name) { return name.indexOf('data-') === 0 || name.indexOf('aria-') === 0 } var findMatchingEndTagIndex = function (schema, html, startIndex) { var startTagRegExp = /<([!?\/])?([A-Za-z0-9\-_:.]+)/g var endTagRegExp = /(?:\s(?:[^'">]+(?:"[^"]*"|'[^']*'))*[^"'>]*(?:"[^">]*|'[^'>]*)?|\s*|\/)>/g var shortEndedElements = schema.getShortEndedElements() var count = 1, index = startIndex while (count !== 0) { startTagRegExp.lastIndex = index while (true) { var startMatch = startTagRegExp.exec(html) if (startMatch === null) { return index } else if (startMatch[1] === '!') { if (startsWith(startMatch[2], '--')) { index = findCommentEndIndex( html, false, startMatch.index + '!--'.length ) } else { index = findCommentEndIndex(html, true, startMatch.index + 1) } break } else { endTagRegExp.lastIndex = startTagRegExp.lastIndex var endMatch = endTagRegExp.exec(html) if (isNull(endMatch) || endMatch.index !== startTagRegExp.lastIndex) { continue } if (startMatch[1] === '/') { count -= 1 } else if (!has$2(shortEndedElements, startMatch[2])) { count += 1 } index = startTagRegExp.lastIndex + endMatch[0].length break } } } return index } var isConditionalComment = function (html, startIndex) { return /^\s*\[if [\w\W]+\]>.*/.test( html.substr(startIndex) ) } var findCommentEndIndex = function (html, isBogus, startIndex) { if (startIndex === void 0) { startIndex = 0 } var lcHtml = html.toLowerCase() if ( lcHtml.indexOf('[if ', startIndex) !== -1 && isConditionalComment(lcHtml, startIndex) ) { var endIfIndex = lcHtml.indexOf('[endif]', startIndex) return lcHtml.indexOf('>', endIfIndex) } else { if (isBogus) { var endIndex = lcHtml.indexOf('>', startIndex) return endIndex !== -1 ? endIndex : lcHtml.length } else { var endCommentRegexp = /--!?>/g endCommentRegexp.lastIndex = startIndex var match = endCommentRegexp.exec(html) return match ? match.index + match[0].length : lcHtml.length } } } var checkBogusAttribute = function (regExp, attrString) { var matches = regExp.exec(attrString) if (matches) { var name_1 = matches[1] var value = matches[2] return typeof name_1 === 'string' && name_1.toLowerCase() === 'data-mce-bogus' ? value : null } else { return null } } var SaxParser = function (settings, schema) { var _a if (schema === void 0) { schema = Schema() } settings = settings || {} var doc = (_a = settings.document) !== null && _a !== void 0 ? _a : document var form = doc.createElement('form') if (settings.fix_self_closing !== false) { settings.fix_self_closing = true } var comment = settings.comment ? settings.comment : noop var cdata = settings.cdata ? settings.cdata : noop var text = settings.text ? settings.text : noop var start = settings.start ? settings.start : noop var end = settings.end ? settings.end : noop var pi = settings.pi ? settings.pi : noop var doctype = settings.doctype ? settings.doctype : noop var parseInternal = function (base64Extract, format) { if (format === void 0) { format = 'html' } var html = base64Extract.html var matches, index = 0, value, endRegExp var stack = [] var attrList, i, textData, name var isInternalElement, isShortEnded var elementRule, isValidElement, attr, attribsValue, validAttributesMap, validAttributePatterns var attributesRequired, attributesDefault, attributesForced var anyAttributesRequired, attrValue, idCount = 0 var decode = Entities.decode var filteredUrlAttrs = Tools.makeMap( 'src,href,data,background,action,formaction,poster,xlink:href' ) var parsingMode = format === 'html' ? 0 : 1 var processEndTag = function (name) { var pos, i pos = stack.length while (pos--) { if (stack[pos].name === name) { break } } if (pos >= 0) { for (i = stack.length - 1; i >= pos; i--) { name = stack[i] if (name.valid) { end(name.name) } } stack.length = pos } } var processText = function (value, raw) { return text(restoreDataUris(value, base64Extract), raw) } var processComment = function (value) { if (value === '') { return } if (value.charAt(0) === '>') { value = ' ' + value } if ( !settings.allow_conditional_comments && value.substr(0, 3).toLowerCase() === '[if' ) { value = ' ' + value } comment(restoreDataUris(value, base64Extract)) } var processAttr = function (value) { return restoreDataUris(value, base64Extract) } var processMalformedComment = function (value, startIndex) { var startTag = value || '' var isBogus = !startsWith(startTag, '--') var endIndex = findCommentEndIndex(html, isBogus, startIndex) value = html.substr(startIndex, endIndex - startIndex) processComment(isBogus ? startTag + value : value) return endIndex + 1 } var parseAttribute = function (tagName, name, value, val2, val3) { name = name.toLowerCase() value = processAttr( name in fillAttrsMap ? name : decode(value || val2 || val3 || '') ) if ( validate && !isInternalElement && isValidPrefixAttrName(name) === false ) { var attrRule = validAttributesMap[name] if (!attrRule && validAttributePatterns) { var i_1 = validAttributePatterns.length while (i_1--) { attrRule = validAttributePatterns[i_1] if (attrRule.pattern.test(name)) { break } } if (i_1 === -1) { attrRule = null } } if (!attrRule) { return } if (attrRule.validValues && !(value in attrRule.validValues)) { return } } var isNameOrId = name === 'name' || name === 'id' if ( isNameOrId && tagName in filteredClobberElements && (value in doc || value in form) ) { return } if ( filteredUrlAttrs[name] && !URI.isDomSafe(value, tagName, settings) ) { return } if ( isInternalElement && (name in filteredUrlAttrs || name.indexOf('on') === 0) ) { return } attrList.map[name] = value attrList.push({ name: name, value: value, }) } var tokenRegExp = new RegExp( '<(?:' + '(?:!--([\\w\\W]*?)--!?>)|' + '(?:!\\[CDATA\\[([\\w\\W]*?)\\]\\]>)|' + '(?:![Dd][Oo][Cc][Tt][Yy][Pp][Ee]([\\w\\W]*?)>)|' + '(?:!(--)?)|' + '(?:\\?([^\\s\\/<>]+) ?([\\w\\W]*?)[?/]>)|' + '(?:\\/([A-Za-z][A-Za-z0-9\\-_\\:\\.]*)>)|' + '(?:([A-Za-z][A-Za-z0-9\\-_:.]*)(\\s(?:[^\'">]+(?:"[^"]*"|\'[^\']*\'))*[^"\'>]*(?:"[^">]*|\'[^\'>]*)?|\\s*|\\/)>)' + ')', 'g' ) var attrRegExp = /([\w:\-]+)(?:\s*=\s*(?:(?:\"((?:[^\"])*)\")|(?:\'((?:[^\'])*)\')|([^>\s]+)))?/g var shortEndedElements = schema.getShortEndedElements() var selfClosing = settings.self_closing_elements || schema.getSelfClosingElements() var fillAttrsMap = schema.getBoolAttrs() var validate = settings.validate var removeInternalElements = settings.remove_internals var fixSelfClosing = settings.fix_self_closing var specialElements = schema.getSpecialElements() var processHtml = html + '>' while ((matches = tokenRegExp.exec(processHtml))) { var matchText = matches[0] if (index < matches.index) { processText(decode(html.substr(index, matches.index - index))) } if ((value = matches[7])) { value = value.toLowerCase() if (value.charAt(0) === ':') { value = value.substr(1) } processEndTag(value) } else if ((value = matches[8])) { if (matches.index + matchText.length > html.length) { processText(decode(html.substr(matches.index))) index = matches.index + matchText.length continue } value = value.toLowerCase() if (value.charAt(0) === ':') { value = value.substr(1) } isShortEnded = value in shortEndedElements if ( fixSelfClosing && selfClosing[value] && stack.length > 0 && stack[stack.length - 1].name === value ) { processEndTag(value) } var bogusValue = checkBogusAttribute(attrRegExp, matches[9]) if (bogusValue !== null) { if (bogusValue === 'all') { index = findMatchingEndTagIndex( schema, html, tokenRegExp.lastIndex ) tokenRegExp.lastIndex = index continue } isValidElement = false } if (!validate || (elementRule = schema.getElementRule(value))) { isValidElement = true if (validate) { validAttributesMap = elementRule.attributes validAttributePatterns = elementRule.attributePatterns } if ((attribsValue = matches[9])) { isInternalElement = attribsValue.indexOf('data-mce-type') !== -1 if (isInternalElement && removeInternalElements) { isValidElement = false } attrList = [] attrList.map = {} attribsValue.replace( attrRegExp, function (match, name, val, val2, val3) { parseAttribute(value, name, val, val2, val3) return '' } ) } else { attrList = [] attrList.map = {} } if (validate && !isInternalElement) { attributesRequired = elementRule.attributesRequired attributesDefault = elementRule.attributesDefault attributesForced = elementRule.attributesForced anyAttributesRequired = elementRule.removeEmptyAttrs if (anyAttributesRequired && !attrList.length) { isValidElement = false } if (attributesForced) { i = attributesForced.length while (i--) { attr = attributesForced[i] name = attr.name attrValue = attr.value if (attrValue === '{$uid}') { attrValue = 'mce_' + idCount++ } attrList.map[name] = attrValue attrList.push({ name: name, value: attrValue, }) } } if (attributesDefault) { i = attributesDefault.length while (i--) { attr = attributesDefault[i] name = attr.name if (!(name in attrList.map)) { attrValue = attr.value if (attrValue === '{$uid}') { attrValue = 'mce_' + idCount++ } attrList.map[name] = attrValue attrList.push({ name: name, value: attrValue, }) } } } if (attributesRequired) { i = attributesRequired.length while (i--) { if (attributesRequired[i] in attrList.map) { break } } if (i === -1) { isValidElement = false } } if ((attr = attrList.map['data-mce-bogus'])) { if (attr === 'all') { index = findMatchingEndTagIndex( schema, html, tokenRegExp.lastIndex ) tokenRegExp.lastIndex = index continue } isValidElement = false } } if (isValidElement) { start(value, attrList, isShortEnded) } } else { isValidElement = false } if ((endRegExp = specialElements[value])) { endRegExp.lastIndex = index = matches.index + matchText.length if ((matches = endRegExp.exec(html))) { if (isValidElement) { textData = html.substr(index, matches.index - index) } index = matches.index + matches[0].length } else { textData = html.substr(index) index = html.length } if (isValidElement) { if (textData.length > 0) { processText(textData, true) } end(value) } tokenRegExp.lastIndex = index continue } if (!isShortEnded) { if ( !attribsValue || attribsValue.indexOf('/') !== attribsValue.length - 1 ) { stack.push({ name: value, valid: isValidElement, }) } else if (isValidElement) { end(value) } } } else if ((value = matches[1])) { processComment(value) } else if ((value = matches[2])) { var isValidCdataSection = parsingMode === 1 || settings.preserve_cdata || (stack.length > 0 && schema.isValidChild(stack[stack.length - 1].name, '#cdata')) if (isValidCdataSection) { cdata(value) } else { index = processMalformedComment('', matches.index + 2) tokenRegExp.lastIndex = index continue } } else if ((value = matches[3])) { doctype(value) } else if ((value = matches[4]) || matchText === '= 0; i--) { value = stack[i] if (value.valid) { end(value.name) } } } var parse = function (html, format) { if (format === void 0) { format = 'html' } parseInternal(extractBase64DataUris(html), format) } return { parse: parse } } SaxParser.findEndTag = findMatchingEndTagIndex var trimHtml = function (tempAttrs, html) { var trimContentRegExp = new RegExp( ['\\s?(' + tempAttrs.join('|') + ')="[^"]+"'].join('|'), 'gi' ) return html.replace(trimContentRegExp, '') } var trimInternal = function (serializer, html) { var bogusAllRegExp = /<(\w+) [^>]*data-mce-bogus="all"[^>]*>/g var schema = serializer.schema var content = trimHtml(serializer.getTempAttrs(), html) var shortEndedElements = schema.getShortEndedElements() var matches while ((matches = bogusAllRegExp.exec(content))) { var index = bogusAllRegExp.lastIndex var matchLength = matches[0].length var endTagIndex = void 0 if (shortEndedElements[matches[1]]) { endTagIndex = index } else { endTagIndex = SaxParser.findEndTag(schema, content, index) } content = content.substring(0, index - matchLength) + content.substring(endTagIndex) bogusAllRegExp.lastIndex = index - matchLength } return trim$2(content) } var trimExternal = trimInternal var trimEmptyContents = function (editor, html) { var blockName = getForcedRootBlock(editor) var emptyRegExp = new RegExp( '^(<' + blockName + '[^>]*>( | |\\s|\xA0|
|)<\\/' + blockName + '>[\r\n]*|
[\r\n]*)$' ) return html.replace(emptyRegExp, '') } var setupArgs$3 = function (args, format) { return __assign(__assign({}, args), { format: format, get: true, getInner: true, }) } var getContentFromBody = function (editor, args, format, body) { var defaultedArgs = setupArgs$3(args, format) var updatedArgs = args.no_events ? defaultedArgs : editor.fire('BeforeGetContent', defaultedArgs) var content if (updatedArgs.format === 'raw') { content = Tools.trim(trimExternal(editor.serializer, body.innerHTML)) } else if (updatedArgs.format === 'text') { content = editor.dom.isEmpty(body) ? '' : trim$2(body.innerText || body.textContent) } else if (updatedArgs.format === 'tree') { content = editor.serializer.serialize(body, updatedArgs) } else { content = trimEmptyContents( editor, editor.serializer.serialize(body, updatedArgs) ) } if ( !contains$3(['text', 'tree'], updatedArgs.format) && !isWsPreserveElement(SugarElement.fromDom(body)) ) { updatedArgs.content = Tools.trim(content) } else { updatedArgs.content = content } if (updatedArgs.no_events) { return updatedArgs.content } else { return editor.fire('GetContent', updatedArgs).content } } var getContentInternal = function (editor, args, format) { return Optional.from(editor.getBody()).fold( constant(args.format === 'tree' ? new AstNode('body', 11) : ''), function (body) { return getContentFromBody(editor, args, format, body) } ) } var each$c = Tools.each var ElementUtils = function (dom) { var compare = function (node1, node2) { if (node1.nodeName !== node2.nodeName) { return false } var getAttribs = function (node) { var attribs = {} each$c(dom.getAttribs(node), function (attr) { var name = attr.nodeName.toLowerCase() if ( name.indexOf('_') !== 0 && name !== 'style' && name.indexOf('data-') !== 0 ) { attribs[name] = dom.getAttrib(node, name) } }) return attribs } var compareObjects = function (obj1, obj2) { var value, name for (name in obj1) { if (has$2(obj1, name)) { value = obj2[name] if (typeof value === 'undefined') { return false } if (obj1[name] !== value) { return false } delete obj2[name] } } for (name in obj2) { if (has$2(obj2, name)) { return false } } return true } if (!compareObjects(getAttribs(node1), getAttribs(node2))) { return false } if ( !compareObjects( dom.parseStyle(dom.getAttrib(node1, 'style')), dom.parseStyle(dom.getAttrib(node2, 'style')) ) ) { return false } return !isBookmarkNode$1(node1) && !isBookmarkNode$1(node2) } return { compare: compare } } var makeMap$1 = Tools.makeMap var Writer = function (settings) { var html = [] settings = settings || {} var indent = settings.indent var indentBefore = makeMap$1(settings.indent_before || '') var indentAfter = makeMap$1(settings.indent_after || '') var encode = Entities.getEncodeFunc( settings.entity_encoding || 'raw', settings.entities ) var htmlOutput = settings.element_format === 'html' return { start: function (name, attrs, empty) { var i, l, attr, value if (indent && indentBefore[name] && html.length > 0) { value = html[html.length - 1] if (value.length > 0 && value !== '\n') { html.push('\n') } } html.push('<', name) if (attrs) { for (i = 0, l = attrs.length; i < l; i++) { attr = attrs[i] html.push(' ', attr.name, '="', encode(attr.value, true), '"') } } if (!empty || htmlOutput) { html[html.length] = '>' } else { html[html.length] = ' />' } if (empty && indent && indentAfter[name] && html.length > 0) { value = html[html.length - 1] if (value.length > 0 && value !== '\n') { html.push('\n') } } }, end: function (name) { var value html.push('') if (indent && indentAfter[name] && html.length > 0) { value = html[html.length - 1] if (value.length > 0 && value !== '\n') { html.push('\n') } } }, text: function (text, raw) { if (text.length > 0) { html[html.length] = raw ? text : encode(text) } }, cdata: function (text) { html.push('') }, comment: function (text) { html.push('') }, pi: function (name, text) { if (text) { html.push('') } else { html.push('') } if (indent) { html.push('\n') } }, doctype: function (text) { html.push('', indent ? '\n' : '') }, reset: function () { html.length = 0 }, getContent: function () { return html.join('').replace(/\n$/, '') }, } } var HtmlSerializer = function (settings, schema) { if (schema === void 0) { schema = Schema() } var writer = Writer(settings) settings = settings || {} settings.validate = 'validate' in settings ? settings.validate : true var serialize = function (node) { var validate = settings.validate var handlers = { 3: function (node) { writer.text(node.value, node.raw) }, 8: function (node) { writer.comment(node.value) }, 7: function (node) { writer.pi(node.name, node.value) }, 10: function (node) { writer.doctype(node.value) }, 4: function (node) { writer.cdata(node.value) }, 11: function (node) { if ((node = node.firstChild)) { do { walk(node) } while ((node = node.next)) } }, } writer.reset() var walk = function (node) { var handler = handlers[node.type] if (!handler) { var name_1 = node.name var isEmpty = node.shortEnded var attrs = node.attributes if (validate && attrs && attrs.length > 1) { var sortedAttrs = [] sortedAttrs.map = {} var elementRule = schema.getElementRule(node.name) if (elementRule) { for ( var i = 0, l = elementRule.attributesOrder.length; i < l; i++ ) { var attrName = elementRule.attributesOrder[i] if (attrName in attrs.map) { var attrValue = attrs.map[attrName] sortedAttrs.map[attrName] = attrValue sortedAttrs.push({ name: attrName, value: attrValue, }) } } for (var i = 0, l = attrs.length; i < l; i++) { var attrName = attrs[i].name if (!(attrName in sortedAttrs.map)) { var attrValue = attrs.map[attrName] sortedAttrs.map[attrName] = attrValue sortedAttrs.push({ name: attrName, value: attrValue, }) } } attrs = sortedAttrs } } writer.start(node.name, attrs, isEmpty) if (!isEmpty) { if ((node = node.firstChild)) { do { walk(node) } while ((node = node.next)) } writer.end(name_1) } } else { handler(node) } } if (node.type === 1 && !settings.inner) { walk(node) } else { handlers[11](node) } return writer.getContent() } return { serialize: serialize } } var nonInheritableStyles = new Set() ;(function () { var nonInheritableStylesArr = [ 'margin', 'margin-left', 'margin-right', 'margin-top', 'margin-bottom', 'padding', 'padding-left', 'padding-right', 'padding-top', 'padding-bottom', 'border', 'border-width', 'border-style', 'border-color', 'background', 'background-attachment', 'background-clip', 'background-color', 'background-image', 'background-origin', 'background-position', 'background-repeat', 'background-size', 'float', 'position', 'left', 'right', 'top', 'bottom', 'z-index', 'display', 'transform', 'width', 'max-width', 'min-width', 'height', 'max-height', 'min-height', 'overflow', 'overflow-x', 'overflow-y', 'text-overflow', 'vertical-align', 'transition', 'transition-delay', 'transition-duration', 'transition-property', 'transition-timing-function', ] each$k(nonInheritableStylesArr, function (style) { nonInheritableStyles.add(style) }) })() var shorthandStyleProps = ['font', 'text-decoration', 'text-emphasis'] var getStyleProps = function (dom, node) { return keys(dom.parseStyle(dom.getAttrib(node, 'style'))) } var isNonInheritableStyle = function (style) { return nonInheritableStyles.has(style) } var hasInheritableStyles = function (dom, node) { return forall(getStyleProps(dom, node), function (style) { return !isNonInheritableStyle(style) }) } var getLonghandStyleProps = function (styles) { return filter$4(styles, function (style) { return exists(shorthandStyleProps, function (prop) { return startsWith(style, prop) }) }) } var hasStyleConflict = function (dom, node, parentNode) { var nodeStyleProps = getStyleProps(dom, node) var parentNodeStyleProps = getStyleProps(dom, parentNode) var valueMismatch = function (prop) { var nodeValue = dom.getStyle(node, prop) var parentValue = dom.getStyle(parentNode, prop) return ( isNotEmpty(nodeValue) && isNotEmpty(parentValue) && nodeValue !== parentValue ) } return exists(nodeStyleProps, function (nodeStyleProp) { var propExists = function (props) { return exists(props, function (prop) { return prop === nodeStyleProp }) } if ( !propExists(parentNodeStyleProps) && propExists(shorthandStyleProps) ) { var longhandProps = getLonghandStyleProps(parentNodeStyleProps) return exists(longhandProps, valueMismatch) } else { return valueMismatch(nodeStyleProp) } }) } var isChar = function (forward, predicate, pos) { return Optional.from(pos.container()) .filter(isText$7) .exists(function (text) { var delta = forward ? 0 : -1 return predicate(text.data.charAt(pos.offset() + delta)) }) } var isBeforeSpace = curry(isChar, true, isWhiteSpace) var isAfterSpace = curry(isChar, false, isWhiteSpace) var isEmptyText = function (pos) { var container = pos.container() return ( isText$7(container) && (container.data.length === 0 || (isZwsp(container.data) && BookmarkManager.isBookmarkNode(container.parentNode))) ) } var matchesElementPosition = function (before, predicate) { return function (pos) { return Optional.from(getChildNodeAtRelativeOffset(before ? 0 : -1, pos)) .filter(predicate) .isSome() } } var isImageBlock = function (node) { return ( isImg(node) && get$5(SugarElement.fromDom(node), 'display') === 'block' ) } var isCefNode = function (node) { return isContentEditableFalse$b(node) && !isBogusAll$1(node) } var isBeforeImageBlock = matchesElementPosition(true, isImageBlock) var isAfterImageBlock = matchesElementPosition(false, isImageBlock) var isBeforeMedia = matchesElementPosition(true, isMedia$2) var isAfterMedia = matchesElementPosition(false, isMedia$2) var isBeforeTable = matchesElementPosition(true, isTable$3) var isAfterTable = matchesElementPosition(false, isTable$3) var isBeforeContentEditableFalse = matchesElementPosition(true, isCefNode) var isAfterContentEditableFalse = matchesElementPosition(false, isCefNode) var getLastChildren = function (elm) { var children = [] var rawNode = elm.dom while (rawNode) { children.push(SugarElement.fromDom(rawNode)) rawNode = rawNode.lastChild } return children } var removeTrailingBr = function (elm) { var allBrs = descendants(elm, 'br') var brs = filter$4(getLastChildren(elm).slice(-1), isBr$4) if (allBrs.length === brs.length) { each$k(brs, remove$7) } } var fillWithPaddingBr = function (elm) { empty(elm) append$1(elm, SugarElement.fromHtml('
')) } var trimBlockTrailingBr = function (elm) { lastChild(elm).each(function (lastChild) { prevSibling(lastChild).each(function (lastChildPrevSibling) { if ( isBlock$2(elm) && isBr$4(lastChild) && isBlock$2(lastChildPrevSibling) ) { remove$7(lastChild) } }) }) } var dropLast = function (xs) { return xs.slice(0, -1) } var parentsUntil = function (start, root, predicate) { if (contains$1(root, start)) { return dropLast( parents$1(start, function (elm) { return predicate(elm) || eq(elm, root) }) ) } else { return [] } } var parents = function (start, root) { return parentsUntil(start, root, never) } var parentsAndSelf = function (start, root) { return [start].concat(parents(start, root)) } var navigateIgnoreEmptyTextNodes = function (forward, root, from) { return navigateIgnore(forward, root, from, isEmptyText) } var getClosestBlock$1 = function (root, pos) { return find$3( parentsAndSelf(SugarElement.fromDom(pos.container()), root), isBlock$2 ) } var isAtBeforeAfterBlockBoundary = function (forward, root, pos) { return navigateIgnoreEmptyTextNodes(forward, root.dom, pos).forall( function (newPos) { return getClosestBlock$1(root, pos).fold( function () { return isInSameBlock(newPos, pos, root.dom) === false }, function (fromBlock) { return ( isInSameBlock(newPos, pos, root.dom) === false && contains$1(fromBlock, SugarElement.fromDom(newPos.container())) ) } ) } ) } var isAtBlockBoundary = function (forward, root, pos) { return getClosestBlock$1(root, pos).fold( function () { return navigateIgnoreEmptyTextNodes(forward, root.dom, pos).forall( function (newPos) { return isInSameBlock(newPos, pos, root.dom) === false } ) }, function (parent) { return navigateIgnoreEmptyTextNodes(forward, parent.dom, pos).isNone() } ) } var isAtStartOfBlock = curry(isAtBlockBoundary, false) var isAtEndOfBlock = curry(isAtBlockBoundary, true) var isBeforeBlock = curry(isAtBeforeAfterBlockBoundary, false) var isAfterBlock = curry(isAtBeforeAfterBlockBoundary, true) var isBr = function (pos) { return getElementFromPosition(pos).exists(isBr$4) } var findBr = function (forward, root, pos) { var parentBlocks = filter$4( parentsAndSelf(SugarElement.fromDom(pos.container()), root), isBlock$2 ) var scope = head(parentBlocks).getOr(root) return fromPosition(forward, scope.dom, pos).filter(isBr) } var isBeforeBr$1 = function (root, pos) { return ( getElementFromPosition(pos).exists(isBr$4) || findBr(true, root, pos).isSome() ) } var isAfterBr = function (root, pos) { return ( getElementFromPrevPosition(pos).exists(isBr$4) || findBr(false, root, pos).isSome() ) } var findPreviousBr = curry(findBr, false) var findNextBr = curry(findBr, true) var isInMiddleOfText = function (pos) { return ( CaretPosition.isTextPosition(pos) && !pos.isAtStart() && !pos.isAtEnd() ) } var getClosestBlock = function (root, pos) { var parentBlocks = filter$4( parentsAndSelf(SugarElement.fromDom(pos.container()), root), isBlock$2 ) return head(parentBlocks).getOr(root) } var hasSpaceBefore = function (root, pos) { if (isInMiddleOfText(pos)) { return isAfterSpace(pos) } else { return ( isAfterSpace(pos) || prevPosition(getClosestBlock(root, pos).dom, pos).exists(isAfterSpace) ) } } var hasSpaceAfter = function (root, pos) { if (isInMiddleOfText(pos)) { return isBeforeSpace(pos) } else { return ( isBeforeSpace(pos) || nextPosition(getClosestBlock(root, pos).dom, pos).exists(isBeforeSpace) ) } } var isPreValue = function (value) { return contains$3(['pre', 'pre-wrap'], value) } var isInPre = function (pos) { return getElementFromPosition(pos) .bind(function (elm) { return closest$3(elm, isElement$6) }) .exists(function (elm) { return isPreValue(get$5(elm, 'white-space')) }) } var isAtBeginningOfBody = function (root, pos) { return prevPosition(root.dom, pos).isNone() } var isAtEndOfBody = function (root, pos) { return nextPosition(root.dom, pos).isNone() } var isAtLineBoundary = function (root, pos) { return ( isAtBeginningOfBody(root, pos) || isAtEndOfBody(root, pos) || isAtStartOfBlock(root, pos) || isAtEndOfBlock(root, pos) || isAfterBr(root, pos) || isBeforeBr$1(root, pos) ) } var needsToHaveNbsp = function (root, pos) { if (isInPre(pos)) { return false } else { return ( isAtLineBoundary(root, pos) || hasSpaceBefore(root, pos) || hasSpaceAfter(root, pos) ) } } var needsToBeNbspLeft = function (root, pos) { if (isInPre(pos)) { return false } else { return ( isAtStartOfBlock(root, pos) || isBeforeBlock(root, pos) || isAfterBr(root, pos) || hasSpaceBefore(root, pos) ) } } var leanRight = function (pos) { var container = pos.container() var offset = pos.offset() if (isText$7(container) && offset < container.data.length) { return CaretPosition(container, offset + 1) } else { return pos } } var needsToBeNbspRight = function (root, pos) { if (isInPre(pos)) { return false } else { return ( isAtEndOfBlock(root, pos) || isAfterBlock(root, pos) || isBeforeBr$1(root, pos) || hasSpaceAfter(root, pos) ) } } var needsToBeNbsp = function (root, pos) { return ( needsToBeNbspLeft(root, pos) || needsToBeNbspRight(root, leanRight(pos)) ) } var isNbspAt = function (text, offset) { return isNbsp(text.charAt(offset)) } var hasNbsp = function (pos) { var container = pos.container() return isText$7(container) && contains$2(container.data, nbsp) } var normalizeNbspMiddle = function (text) { var chars = text.split('') return map$3(chars, function (chr, i) { if ( isNbsp(chr) && i > 0 && i < chars.length - 1 && isContent(chars[i - 1]) && isContent(chars[i + 1]) ) { return ' ' } else { return chr } }).join('') } var normalizeNbspAtStart = function (root, node) { var text = node.data var firstPos = CaretPosition(node, 0) if (isNbspAt(text, 0) && !needsToBeNbsp(root, firstPos)) { node.data = ' ' + text.slice(1) return true } else { return false } } var normalizeNbspInMiddleOfTextNode = function (node) { var text = node.data var newText = normalizeNbspMiddle(text) if (newText !== text) { node.data = newText return true } else { return false } } var normalizeNbspAtEnd = function (root, node) { var text = node.data var lastPos = CaretPosition(node, text.length - 1) if (isNbspAt(text, text.length - 1) && !needsToBeNbsp(root, lastPos)) { node.data = text.slice(0, -1) + ' ' return true } else { return false } } var normalizeNbsps = function (root, pos) { return Optional.some(pos) .filter(hasNbsp) .bind(function (pos) { var container = pos.container() var normalized = normalizeNbspAtStart(root, container) || normalizeNbspInMiddleOfTextNode(container) || normalizeNbspAtEnd(root, container) return normalized ? Optional.some(pos) : Optional.none() }) } var normalizeNbspsInEditor = function (editor) { var root = SugarElement.fromDom(editor.getBody()) if (editor.selection.isCollapsed()) { normalizeNbsps( root, CaretPosition.fromRangeStart(editor.selection.getRng()) ).each(function (pos) { editor.selection.setRng(pos.toRange()) }) } } var normalizeContent = function (content, isStartOfContent, isEndOfContent) { var result = foldl( content, function (acc, c) { if (isWhiteSpace(c) || isNbsp(c)) { if ( acc.previousCharIsSpace || (acc.str === '' && isStartOfContent) || (acc.str.length === content.length - 1 && isEndOfContent) ) { return { previousCharIsSpace: false, str: acc.str + nbsp, } } else { return { previousCharIsSpace: true, str: acc.str + ' ', } } } else { return { previousCharIsSpace: false, str: acc.str + c, } } }, { previousCharIsSpace: false, str: '', } ) return result.str } var normalize$1 = function (node, offset, count) { if (count === 0) { return } var elm = SugarElement.fromDom(node) var root = ancestor$3(elm, isBlock$2).getOr(elm) var whitespace = node.data.slice(offset, offset + count) var isEndOfContent = offset + count >= node.data.length && needsToBeNbspRight(root, CaretPosition(node, node.data.length)) var isStartOfContent = offset === 0 && needsToBeNbspLeft(root, CaretPosition(node, 0)) node.replaceData( offset, count, normalizeContent(whitespace, isStartOfContent, isEndOfContent) ) } var normalizeWhitespaceAfter = function (node, offset) { var content = node.data.slice(offset) var whitespaceCount = content.length - lTrim(content).length normalize$1(node, offset, whitespaceCount) } var normalizeWhitespaceBefore = function (node, offset) { var content = node.data.slice(0, offset) var whitespaceCount = content.length - rTrim(content).length normalize$1(node, offset - whitespaceCount, whitespaceCount) } var mergeTextNodes = function ( prevNode, nextNode, normalizeWhitespace, mergeToPrev ) { if (mergeToPrev === void 0) { mergeToPrev = true } var whitespaceOffset = rTrim(prevNode.data).length var newNode = mergeToPrev ? prevNode : nextNode var removeNode = mergeToPrev ? nextNode : prevNode if (mergeToPrev) { newNode.appendData(removeNode.data) } else { newNode.insertData(0, removeNode.data) } remove$7(SugarElement.fromDom(removeNode)) if (normalizeWhitespace) { normalizeWhitespaceAfter(newNode, whitespaceOffset) } return newNode } var needsReposition = function (pos, elm) { var container = pos.container() var offset = pos.offset() return ( CaretPosition.isTextPosition(pos) === false && container === elm.parentNode && offset > CaretPosition.before(elm).offset() ) } var reposition = function (elm, pos) { return needsReposition(pos, elm) ? CaretPosition(pos.container(), pos.offset() - 1) : pos } var beforeOrStartOf = function (node) { return isText$7(node) ? CaretPosition(node, 0) : CaretPosition.before(node) } var afterOrEndOf = function (node) { return isText$7(node) ? CaretPosition(node, node.data.length) : CaretPosition.after(node) } var getPreviousSiblingCaretPosition = function (elm) { if (isCaretCandidate$3(elm.previousSibling)) { return Optional.some(afterOrEndOf(elm.previousSibling)) } else { return elm.previousSibling ? lastPositionIn(elm.previousSibling) : Optional.none() } } var getNextSiblingCaretPosition = function (elm) { if (isCaretCandidate$3(elm.nextSibling)) { return Optional.some(beforeOrStartOf(elm.nextSibling)) } else { return elm.nextSibling ? firstPositionIn(elm.nextSibling) : Optional.none() } } var findCaretPositionBackwardsFromElm = function (rootElement, elm) { var startPosition = CaretPosition.before( elm.previousSibling ? elm.previousSibling : elm.parentNode ) return prevPosition(rootElement, startPosition).fold(function () { return nextPosition(rootElement, CaretPosition.after(elm)) }, Optional.some) } var findCaretPositionForwardsFromElm = function (rootElement, elm) { return nextPosition(rootElement, CaretPosition.after(elm)).fold( function () { return prevPosition(rootElement, CaretPosition.before(elm)) }, Optional.some ) } var findCaretPositionBackwards = function (rootElement, elm) { return getPreviousSiblingCaretPosition(elm) .orThunk(function () { return getNextSiblingCaretPosition(elm) }) .orThunk(function () { return findCaretPositionBackwardsFromElm(rootElement, elm) }) } var findCaretPositionForward = function (rootElement, elm) { return getNextSiblingCaretPosition(elm) .orThunk(function () { return getPreviousSiblingCaretPosition(elm) }) .orThunk(function () { return findCaretPositionForwardsFromElm(rootElement, elm) }) } var findCaretPosition = function (forward, rootElement, elm) { return forward ? findCaretPositionForward(rootElement, elm) : findCaretPositionBackwards(rootElement, elm) } var findCaretPosOutsideElmAfterDelete = function (forward, rootElement, elm) { return findCaretPosition(forward, rootElement, elm).map( curry(reposition, elm) ) } var setSelection$1 = function (editor, forward, pos) { pos.fold( function () { editor.focus() }, function (pos) { editor.selection.setRng(pos.toRange(), forward) } ) } var eqRawNode = function (rawNode) { return function (elm) { return elm.dom === rawNode } } var isBlock = function (editor, elm) { return elm && has$2(editor.schema.getBlockElements(), name(elm)) } var paddEmptyBlock = function (elm) { if (isEmpty$2(elm)) { var br = SugarElement.fromHtml('
') empty(elm) append$1(elm, br) return Optional.some(CaretPosition.before(br.dom)) } else { return Optional.none() } } var deleteNormalized = function ( elm, afterDeletePosOpt, normalizeWhitespace ) { var prevTextOpt = prevSibling(elm).filter(isText$8) var nextTextOpt = nextSibling(elm).filter(isText$8) remove$7(elm) return lift3( prevTextOpt, nextTextOpt, afterDeletePosOpt, function (prev, next, pos) { var prevNode = prev.dom, nextNode = next.dom var offset = prevNode.data.length mergeTextNodes(prevNode, nextNode, normalizeWhitespace) return pos.container() === nextNode ? CaretPosition(prevNode, offset) : pos } ).orThunk(function () { if (normalizeWhitespace) { prevTextOpt.each(function (elm) { return normalizeWhitespaceBefore(elm.dom, elm.dom.length) }) nextTextOpt.each(function (elm) { return normalizeWhitespaceAfter(elm.dom, 0) }) } return afterDeletePosOpt }) } var isInlineElement = function (editor, element) { return has$2(editor.schema.getTextInlineElements(), name(element)) } var deleteElement$2 = function (editor, forward, elm, moveCaret) { if (moveCaret === void 0) { moveCaret = true } var afterDeletePos = findCaretPosOutsideElmAfterDelete( forward, editor.getBody(), elm.dom ) var parentBlock = ancestor$3( elm, curry(isBlock, editor), eqRawNode(editor.getBody()) ) var normalizedAfterDeletePos = deleteNormalized( elm, afterDeletePos, isInlineElement(editor, elm) ) if (editor.dom.isEmpty(editor.getBody())) { editor.setContent('') editor.selection.setCursorLocation() } else { parentBlock.bind(paddEmptyBlock).fold( function () { if (moveCaret) { setSelection$1(editor, forward, normalizedAfterDeletePos) } }, function (paddPos) { if (moveCaret) { setSelection$1(editor, forward, Optional.some(paddPos)) } } ) } } var isRootFromElement = function (root) { return function (cur) { return eq(root, cur) } } var getTableCells = function (table) { return descendants(table, 'td,th') } var getTableDetailsFromRange = function (rng, isRoot) { var getTable = function (node) { return getClosestTable(SugarElement.fromDom(node), isRoot) } var startTable = getTable(rng.startContainer) var endTable = getTable(rng.endContainer) var isStartInTable = startTable.isSome() var isEndInTable = endTable.isSome() var isSameTable = lift2(startTable, endTable, eq).getOr(false) var isMultiTable = !isSameTable && isStartInTable && isEndInTable return { startTable: startTable, endTable: endTable, isStartInTable: isStartInTable, isEndInTable: isEndInTable, isSameTable: isSameTable, isMultiTable: isMultiTable, } } var tableCellRng = function (start, end) { return { start: start, end: end, } } var tableSelection = function (rng, table, cells) { return { rng: rng, table: table, cells: cells, } } var deleteAction = Adt.generate([ { singleCellTable: ['rng', 'cell'], }, { fullTable: ['table'] }, { partialTable: ['cells', 'outsideDetails'], }, { multiTable: ['startTableCells', 'endTableCells', 'betweenRng'], }, ]) var getClosestCell$1 = function (container, isRoot) { return closest$2(SugarElement.fromDom(container), 'td,th', isRoot) } var isExpandedCellRng = function (cellRng) { return !eq(cellRng.start, cellRng.end) } var getTableFromCellRng = function (cellRng, isRoot) { return getClosestTable(cellRng.start, isRoot).bind(function ( startParentTable ) { return getClosestTable(cellRng.end, isRoot).bind(function ( endParentTable ) { return someIf(eq(startParentTable, endParentTable), startParentTable) }) }) } var isSingleCellTable = function (cellRng, isRoot) { return ( !isExpandedCellRng(cellRng) && getTableFromCellRng(cellRng, isRoot).exists(function (table) { var rows = table.dom.rows return rows.length === 1 && rows[0].cells.length === 1 }) ) } var getCellRng = function (rng, isRoot) { var startCell = getClosestCell$1(rng.startContainer, isRoot) var endCell = getClosestCell$1(rng.endContainer, isRoot) return lift2(startCell, endCell, tableCellRng) } var getCellRangeFromStartTable = function (isRoot) { return function (startCell) { return getClosestTable(startCell, isRoot).bind(function (table) { return last$2(getTableCells(table)).map(function (endCell) { return tableCellRng(startCell, endCell) }) }) } } var getCellRangeFromEndTable = function (isRoot) { return function (endCell) { return getClosestTable(endCell, isRoot).bind(function (table) { return head(getTableCells(table)).map(function (startCell) { return tableCellRng(startCell, endCell) }) }) } } var getTableSelectionFromCellRng = function (isRoot) { return function (cellRng) { return getTableFromCellRng(cellRng, isRoot).map(function (table) { return tableSelection(cellRng, table, getTableCells(table)) }) } } var getTableSelections = function (cellRng, selectionDetails, rng, isRoot) { if (rng.collapsed || !cellRng.forall(isExpandedCellRng)) { return Optional.none() } else if (selectionDetails.isSameTable) { var sameTableSelection = cellRng.bind( getTableSelectionFromCellRng(isRoot) ) return Optional.some({ start: sameTableSelection, end: sameTableSelection, }) } else { var startCell = getClosestCell$1(rng.startContainer, isRoot) var endCell = getClosestCell$1(rng.endContainer, isRoot) var startTableSelection = startCell .bind(getCellRangeFromStartTable(isRoot)) .bind(getTableSelectionFromCellRng(isRoot)) var endTableSelection = endCell .bind(getCellRangeFromEndTable(isRoot)) .bind(getTableSelectionFromCellRng(isRoot)) return Optional.some({ start: startTableSelection, end: endTableSelection, }) } } var getCellIndex = function (cells, cell) { return findIndex$2(cells, function (x) { return eq(x, cell) }) } var getSelectedCells = function (tableSelection) { return lift2( getCellIndex(tableSelection.cells, tableSelection.rng.start), getCellIndex(tableSelection.cells, tableSelection.rng.end), function (startIndex, endIndex) { return tableSelection.cells.slice(startIndex, endIndex + 1) } ) } var isSingleCellTableContentSelected = function (optCellRng, rng, isRoot) { return optCellRng.exists(function (cellRng) { return ( isSingleCellTable(cellRng, isRoot) && hasAllContentsSelected(cellRng.start, rng) ) }) } var unselectCells = function (rng, selectionDetails) { var startTable = selectionDetails.startTable, endTable = selectionDetails.endTable var otherContentRng = rng.cloneRange() startTable.each(function (table) { return otherContentRng.setStartAfter(table.dom) }) endTable.each(function (table) { return otherContentRng.setEndBefore(table.dom) }) return otherContentRng } var handleSingleTable = function (cellRng, selectionDetails, rng, isRoot) { return getTableSelections(cellRng, selectionDetails, rng, isRoot) .bind(function (_a) { var start = _a.start, end = _a.end return start.or(end) }) .bind(function (tableSelection) { var isSameTable = selectionDetails.isSameTable var selectedCells = getSelectedCells(tableSelection).getOr([]) if ( isSameTable && tableSelection.cells.length === selectedCells.length ) { return Optional.some(deleteAction.fullTable(tableSelection.table)) } else if (selectedCells.length > 0) { if (isSameTable) { return Optional.some( deleteAction.partialTable(selectedCells, Optional.none()) ) } else { var otherContentRng = unselectCells(rng, selectionDetails) return Optional.some( deleteAction.partialTable( selectedCells, Optional.some( __assign(__assign({}, selectionDetails), { rng: otherContentRng, }) ) ) ) } } else { return Optional.none() } }) } var handleMultiTable = function (cellRng, selectionDetails, rng, isRoot) { return getTableSelections(cellRng, selectionDetails, rng, isRoot).bind( function (_a) { var start = _a.start, end = _a.end var startTableSelectedCells = start.bind(getSelectedCells).getOr([]) var endTableSelectedCells = end.bind(getSelectedCells).getOr([]) if ( startTableSelectedCells.length > 0 && endTableSelectedCells.length > 0 ) { var otherContentRng = unselectCells(rng, selectionDetails) return Optional.some( deleteAction.multiTable( startTableSelectedCells, endTableSelectedCells, otherContentRng ) ) } else { return Optional.none() } } ) } var getActionFromRange = function (root, rng) { var isRoot = isRootFromElement(root) var optCellRng = getCellRng(rng, isRoot) var selectionDetails = getTableDetailsFromRange(rng, isRoot) if (isSingleCellTableContentSelected(optCellRng, rng, isRoot)) { return optCellRng.map(function (cellRng) { return deleteAction.singleCellTable(rng, cellRng.start) }) } else if (selectionDetails.isMultiTable) { return handleMultiTable(optCellRng, selectionDetails, rng, isRoot) } else { return handleSingleTable(optCellRng, selectionDetails, rng, isRoot) } } var freefallRtl = function (root) { var child = isComment$1(root) ? prevSibling(root) : lastChild(root) return child.bind(freefallRtl).orThunk(function () { return Optional.some(root) }) } var cleanCells = function (cells) { return each$k(cells, function (cell) { remove$6(cell, 'contenteditable') fillWithPaddingBr(cell) }) } var getOutsideBlock = function (editor, container) { return Optional.from( editor.dom.getParent(container, editor.dom.isBlock) ).map(SugarElement.fromDom) } var handleEmptyBlock = function (editor, startInTable, emptyBlock) { emptyBlock.each(function (block) { if (startInTable) { remove$7(block) } else { fillWithPaddingBr(block) editor.selection.setCursorLocation(block.dom, 0) } }) } var deleteContentInsideCell = function ( editor, cell, rng, isFirstCellInSelection ) { var insideTableRng = rng.cloneRange() if (isFirstCellInSelection) { insideTableRng.setStart(rng.startContainer, rng.startOffset) insideTableRng.setEndAfter(cell.dom.lastChild) } else { insideTableRng.setStartBefore(cell.dom.firstChild) insideTableRng.setEnd(rng.endContainer, rng.endOffset) } deleteCellContents(editor, insideTableRng, cell, false) } var collapseAndRestoreCellSelection = function (editor) { var selectedCells = getCellsFromEditor(editor) var selectedNode = SugarElement.fromDom(editor.selection.getNode()) if (isTableCell$5(selectedNode.dom) && isEmpty$2(selectedNode)) { editor.selection.setCursorLocation(selectedNode.dom, 0) } else { editor.selection.collapse(true) } if ( selectedCells.length > 1 && exists(selectedCells, function (cell) { return eq(cell, selectedNode) }) ) { set$1(selectedNode, 'data-mce-selected', '1') } } var emptySingleTableCells = function (editor, cells, outsideDetails) { var editorRng = editor.selection.getRng() var cellsToClean = outsideDetails .bind(function (_a) { var rng = _a.rng, isStartInTable = _a.isStartInTable var outsideBlock = getOutsideBlock( editor, isStartInTable ? rng.endContainer : rng.startContainer ) rng.deleteContents() handleEmptyBlock(editor, isStartInTable, outsideBlock.filter(isEmpty$2)) var endPointCell = isStartInTable ? cells[0] : cells[cells.length - 1] deleteContentInsideCell(editor, endPointCell, editorRng, isStartInTable) if (!isEmpty$2(endPointCell)) { return Optional.some( isStartInTable ? cells.slice(1) : cells.slice(0, -1) ) } else { return Optional.none() } }) .getOr(cells) cleanCells(cellsToClean) collapseAndRestoreCellSelection(editor) return true } var emptyMultiTableCells = function ( editor, startTableCells, endTableCells, betweenRng ) { var rng = editor.selection.getRng() var startCell = startTableCells[0] var endCell = endTableCells[endTableCells.length - 1] deleteContentInsideCell(editor, startCell, rng, true) deleteContentInsideCell(editor, endCell, rng, false) var startTableCellsToClean = isEmpty$2(startCell) ? startTableCells : startTableCells.slice(1) var endTableCellsToClean = isEmpty$2(endCell) ? endTableCells : endTableCells.slice(0, -1) cleanCells(startTableCellsToClean.concat(endTableCellsToClean)) betweenRng.deleteContents() collapseAndRestoreCellSelection(editor) return true } var deleteCellContents = function (editor, rng, cell, moveSelection) { if (moveSelection === void 0) { moveSelection = true } rng.deleteContents() var lastNode = freefallRtl(cell).getOr(cell) var lastBlock = SugarElement.fromDom( editor.dom.getParent(lastNode.dom, editor.dom.isBlock) ) if (isEmpty$2(lastBlock)) { fillWithPaddingBr(lastBlock) if (moveSelection) { editor.selection.setCursorLocation(lastBlock.dom, 0) } } if (!eq(cell, lastBlock)) { var additionalCleanupNodes = is$1(parent(lastBlock), cell) ? [] : siblings(lastBlock) each$k(additionalCleanupNodes.concat(children(cell)), function (node) { if ( !eq(node, lastBlock) && !contains$1(node, lastBlock) && isEmpty$2(node) ) { remove$7(node) } }) } return true } var deleteTableElement = function (editor, table) { deleteElement$2(editor, false, table) return true } var deleteCellRange = function (editor, rootElm, rng) { return getActionFromRange(rootElm, rng).map(function (action) { return action.fold( curry(deleteCellContents, editor), curry(deleteTableElement, editor), curry(emptySingleTableCells, editor), curry(emptyMultiTableCells, editor) ) }) } var deleteCaptionRange = function (editor, caption) { return emptyElement(editor, caption) } var deleteTableRange = function (editor, rootElm, rng, startElm) { return getParentCaption(rootElm, startElm) .fold( function () { return deleteCellRange(editor, rootElm, rng) }, function (caption) { return deleteCaptionRange(editor, caption) } ) .getOr(false) } var deleteRange$2 = function (editor, startElm, selectedCells) { var rootNode = SugarElement.fromDom(editor.getBody()) var rng = editor.selection.getRng() return selectedCells.length !== 0 ? emptySingleTableCells(editor, selectedCells, Optional.none()) : deleteTableRange(editor, rootNode, rng, startElm) } var getParentCell = function (rootElm, elm) { return find$3(parentsAndSelf(elm, rootElm), isTableCell$4) } var getParentCaption = function (rootElm, elm) { return find$3(parentsAndSelf(elm, rootElm), isTag('caption')) } var deleteBetweenCells = function (editor, rootElm, forward, fromCell, from) { return navigate(forward, editor.getBody(), from).bind(function (to) { return getParentCell(rootElm, SugarElement.fromDom(to.getNode())).map( function (toCell) { return eq(toCell, fromCell) === false } ) }) } var emptyElement = function (editor, elm) { fillWithPaddingBr(elm) editor.selection.setCursorLocation(elm.dom, 0) return Optional.some(true) } var isDeleteOfLastCharPos = function (fromCaption, forward, from, to) { return firstPositionIn(fromCaption.dom) .bind(function (first) { return lastPositionIn(fromCaption.dom).map(function (last) { return forward ? from.isEqual(first) && to.isEqual(last) : from.isEqual(last) && to.isEqual(first) }) }) .getOr(true) } var emptyCaretCaption = function (editor, elm) { return emptyElement(editor, elm) } var validateCaretCaption = function (rootElm, fromCaption, to) { return getParentCaption(rootElm, SugarElement.fromDom(to.getNode())).map( function (toCaption) { return eq(toCaption, fromCaption) === false } ) } var deleteCaretInsideCaption = function ( editor, rootElm, forward, fromCaption, from ) { return navigate(forward, editor.getBody(), from) .bind(function (to) { return isDeleteOfLastCharPos(fromCaption, forward, from, to) ? emptyCaretCaption(editor, fromCaption) : validateCaretCaption(rootElm, fromCaption, to) }) .or(Optional.some(true)) } var deleteCaretCells = function (editor, forward, rootElm, startElm) { var from = CaretPosition.fromRangeStart(editor.selection.getRng()) return getParentCell(rootElm, startElm) .bind(function (fromCell) { return isEmpty$2(fromCell) ? emptyElement(editor, fromCell) : deleteBetweenCells(editor, rootElm, forward, fromCell, from) }) .getOr(false) } var deleteCaretCaption = function (editor, forward, rootElm, fromCaption) { var from = CaretPosition.fromRangeStart(editor.selection.getRng()) return isEmpty$2(fromCaption) ? emptyElement(editor, fromCaption) : deleteCaretInsideCaption(editor, rootElm, forward, fromCaption, from) } var isNearTable = function (forward, pos) { return forward ? isBeforeTable(pos) : isAfterTable(pos) } var isBeforeOrAfterTable = function (editor, forward) { var fromPos = CaretPosition.fromRangeStart(editor.selection.getRng()) return ( isNearTable(forward, fromPos) || fromPosition(forward, editor.getBody(), fromPos).exists(function (pos) { return isNearTable(forward, pos) }) ) } var deleteCaret$3 = function (editor, forward, startElm) { var rootElm = SugarElement.fromDom(editor.getBody()) return getParentCaption(rootElm, startElm).fold( function () { return ( deleteCaretCells(editor, forward, rootElm, startElm) || isBeforeOrAfterTable(editor, forward) ) }, function (fromCaption) { return deleteCaretCaption(editor, forward, rootElm, fromCaption).getOr( false ) } ) } var backspaceDelete$9 = function (editor, forward) { var startElm = SugarElement.fromDom(editor.selection.getStart(true)) var cells = getCellsFromEditor(editor) return editor.selection.isCollapsed() && cells.length === 0 ? deleteCaret$3(editor, forward, startElm) : deleteRange$2(editor, startElm, cells) } var createRange = function (sc, so, ec, eo) { var rng = document.createRange() rng.setStart(sc, so) rng.setEnd(ec, eo) return rng } var normalizeBlockSelectionRange = function (rng) { var startPos = CaretPosition.fromRangeStart(rng) var endPos = CaretPosition.fromRangeEnd(rng) var rootNode = rng.commonAncestorContainer return fromPosition(false, rootNode, endPos) .map(function (newEndPos) { if ( !isInSameBlock(startPos, endPos, rootNode) && isInSameBlock(startPos, newEndPos, rootNode) ) { return createRange( startPos.container(), startPos.offset(), newEndPos.container(), newEndPos.offset() ) } else { return rng } }) .getOr(rng) } var normalize = function (rng) { return rng.collapsed ? rng : normalizeBlockSelectionRange(rng) } var hasOnlyOneChild$1 = function (node) { return node.firstChild && node.firstChild === node.lastChild } var isPaddingNode = function (node) { return node.name === 'br' || node.value === nbsp } var isPaddedEmptyBlock = function (schema, node) { var blockElements = schema.getBlockElements() return ( blockElements[node.name] && hasOnlyOneChild$1(node) && isPaddingNode(node.firstChild) ) } var isEmptyFragmentElement = function (schema, node) { var nonEmptyElements = schema.getNonEmptyElements() return ( node && (node.isEmpty(nonEmptyElements) || isPaddedEmptyBlock(schema, node)) ) } var isListFragment = function (schema, fragment) { var firstChild = fragment.firstChild var lastChild = fragment.lastChild if (firstChild && firstChild.name === 'meta') { firstChild = firstChild.next } if (lastChild && lastChild.attr('id') === 'mce_marker') { lastChild = lastChild.prev } if (isEmptyFragmentElement(schema, lastChild)) { lastChild = lastChild.prev } if (!firstChild || firstChild !== lastChild) { return false } return firstChild.name === 'ul' || firstChild.name === 'ol' } var cleanupDomFragment = function (domFragment) { var firstChild = domFragment.firstChild var lastChild = domFragment.lastChild if (firstChild && firstChild.nodeName === 'META') { firstChild.parentNode.removeChild(firstChild) } if (lastChild && lastChild.id === 'mce_marker') { lastChild.parentNode.removeChild(lastChild) } return domFragment } var toDomFragment = function (dom, serializer, fragment) { var html = serializer.serialize(fragment) var domFragment = dom.createFragment(html) return cleanupDomFragment(domFragment) } var listItems = function (elm) { return filter$4(elm.childNodes, function (child) { return child.nodeName === 'LI' }) } var isPadding = function (node) { return node.data === nbsp || isBr$5(node) } var isListItemPadded = function (node) { return ( node && node.firstChild && node.firstChild === node.lastChild && isPadding(node.firstChild) ) } var isEmptyOrPadded = function (elm) { return !elm.firstChild || isListItemPadded(elm) } var trimListItems = function (elms) { return elms.length > 0 && isEmptyOrPadded(elms[elms.length - 1]) ? elms.slice(0, -1) : elms } var getParentLi = function (dom, node) { var parentBlock = dom.getParent(node, dom.isBlock) return parentBlock && parentBlock.nodeName === 'LI' ? parentBlock : null } var isParentBlockLi = function (dom, node) { return !!getParentLi(dom, node) } var getSplit = function (parentNode, rng) { var beforeRng = rng.cloneRange() var afterRng = rng.cloneRange() beforeRng.setStartBefore(parentNode) afterRng.setEndAfter(parentNode) return [beforeRng.cloneContents(), afterRng.cloneContents()] } var findFirstIn = function (node, rootNode) { var caretPos = CaretPosition.before(node) var caretWalker = CaretWalker(rootNode) var newCaretPos = caretWalker.next(caretPos) return newCaretPos ? newCaretPos.toRange() : null } var findLastOf = function (node, rootNode) { var caretPos = CaretPosition.after(node) var caretWalker = CaretWalker(rootNode) var newCaretPos = caretWalker.prev(caretPos) return newCaretPos ? newCaretPos.toRange() : null } var insertMiddle = function (target, elms, rootNode, rng) { var parts = getSplit(target, rng) var parentElm = target.parentNode parentElm.insertBefore(parts[0], target) Tools.each(elms, function (li) { parentElm.insertBefore(li, target) }) parentElm.insertBefore(parts[1], target) parentElm.removeChild(target) return findLastOf(elms[elms.length - 1], rootNode) } var insertBefore$1 = function (target, elms, rootNode) { var parentElm = target.parentNode Tools.each(elms, function (elm) { parentElm.insertBefore(elm, target) }) return findFirstIn(target, rootNode) } var insertAfter$1 = function (target, elms, rootNode, dom) { dom.insertAfter(elms.reverse(), target) return findLastOf(elms[0], rootNode) } var insertAtCaret$1 = function (serializer, dom, rng, fragment) { var domFragment = toDomFragment(dom, serializer, fragment) var liTarget = getParentLi(dom, rng.startContainer) var liElms = trimListItems(listItems(domFragment.firstChild)) var BEGINNING = 1, END = 2 var rootNode = dom.getRoot() var isAt = function (location) { var caretPos = CaretPosition.fromRangeStart(rng) var caretWalker = CaretWalker(dom.getRoot()) var newPos = location === BEGINNING ? caretWalker.prev(caretPos) : caretWalker.next(caretPos) return newPos ? getParentLi(dom, newPos.getNode()) !== liTarget : true } if (isAt(BEGINNING)) { return insertBefore$1(liTarget, liElms, rootNode) } else if (isAt(END)) { return insertAfter$1(liTarget, liElms, rootNode, dom) } return insertMiddle(liTarget, liElms, rootNode, rng) } var trimOrPadLeftRight = function (dom, rng, html) { var root = SugarElement.fromDom(dom.getRoot()) if (needsToBeNbspLeft(root, CaretPosition.fromRangeStart(rng))) { html = html.replace(/^ /, ' ') } else { html = html.replace(/^ /, ' ') } if (needsToBeNbspRight(root, CaretPosition.fromRangeEnd(rng))) { html = html.replace(/( | )()?$/, ' ') } else { html = html.replace(/ ()?$/, ' ') } return html } var isTableCell$1 = isTableCell$5 var isTableCellContentSelected = function (dom, rng, cell) { if (cell !== null) { var endCell = dom.getParent(rng.endContainer, isTableCell$1) return ( cell === endCell && hasAllContentsSelected(SugarElement.fromDom(cell), rng) ) } else { return false } } var validInsertion = function (editor, value, parentNode) { if (parentNode.getAttribute('data-mce-bogus') === 'all') { parentNode.parentNode.insertBefore( editor.dom.createFragment(value), parentNode ) } else { var node = parentNode.firstChild var node2 = parentNode.lastChild if (!node || (node === node2 && node.nodeName === 'BR')) { editor.dom.setHTML(parentNode, value) } else { editor.selection.setContent(value) } } } var trimBrsFromTableCell = function (dom, elm) { Optional.from(dom.getParent(elm, 'td,th')) .map(SugarElement.fromDom) .each(trimBlockTrailingBr) } var reduceInlineTextElements = function (editor, merge) { var textInlineElements = editor.schema.getTextInlineElements() var dom = editor.dom if (merge) { var root_1 = editor.getBody() var elementUtils_1 = ElementUtils(dom) Tools.each(dom.select('*[data-mce-fragment]'), function (node) { var isInline = isNonNullable( textInlineElements[node.nodeName.toLowerCase()] ) if (isInline && hasInheritableStyles(dom, node)) { for ( var parentNode = node.parentNode; isNonNullable(parentNode) && parentNode !== root_1; parentNode = parentNode.parentNode ) { var styleConflict = hasStyleConflict(dom, node, parentNode) if (styleConflict) { break } if (elementUtils_1.compare(parentNode, node)) { dom.remove(node, true) break } } } }) } } var markFragmentElements = function (fragment) { var node = fragment while ((node = node.walk())) { if (node.type === 1) { node.attr('data-mce-fragment', '1') } } } var unmarkFragmentElements = function (elm) { Tools.each(elm.getElementsByTagName('*'), function (elm) { elm.removeAttribute('data-mce-fragment') }) } var isPartOfFragment = function (node) { return !!node.getAttribute('data-mce-fragment') } var canHaveChildren = function (editor, node) { return node && !editor.schema.getShortEndedElements()[node.nodeName] } var moveSelectionToMarker = function (editor, marker) { var nextRng var dom = editor.dom var selection = editor.selection if (!marker) { return } selection.scrollIntoView(marker) var parentEditableElm = getContentEditableRoot$1(editor.getBody(), marker) if (dom.getContentEditable(parentEditableElm) === 'false') { dom.remove(marker) selection.select(parentEditableElm) return } var rng = dom.createRng() var node = marker.previousSibling if (isText$7(node)) { rng.setStart(node, node.nodeValue.length) if (!Env.ie) { var node2 = marker.nextSibling if (isText$7(node2)) { node.appendData(node2.data) node2.parentNode.removeChild(node2) } } } else { rng.setStartBefore(marker) rng.setEndBefore(marker) } var findNextCaretRng = function (rng) { var caretPos = CaretPosition.fromRangeStart(rng) var caretWalker = CaretWalker(editor.getBody()) caretPos = caretWalker.next(caretPos) if (caretPos) { return caretPos.toRange() } } var parentBlock = dom.getParent(marker, dom.isBlock) dom.remove(marker) if (parentBlock && dom.isEmpty(parentBlock)) { editor.$(parentBlock).empty() rng.setStart(parentBlock, 0) rng.setEnd(parentBlock, 0) if ( !isTableCell$1(parentBlock) && !isPartOfFragment(parentBlock) && (nextRng = findNextCaretRng(rng)) ) { rng = nextRng dom.remove(parentBlock) } else { dom.add(parentBlock, dom.create('br', { 'data-mce-bogus': '1' })) } } selection.setRng(rng) } var deleteSelectedContent = function (editor) { var dom = editor.dom var rng = normalize(editor.selection.getRng()) editor.selection.setRng(rng) var startCell = dom.getParent(rng.startContainer, isTableCell$1) if (isTableCellContentSelected(dom, rng, startCell)) { deleteCellContents(editor, rng, SugarElement.fromDom(startCell)) } else { editor.getDoc().execCommand('Delete', false, null) } } var insertHtmlAtCaret = function (editor, value, details) { var parentNode var rng, node var selection = editor.selection var dom = editor.dom if (/^ | $/.test(value)) { value = trimOrPadLeftRight(dom, selection.getRng(), value) } var parser = editor.parser var merge = details.merge var serializer = HtmlSerializer( { validate: shouldValidate(editor) }, editor.schema ) var bookmarkHtml = '' var args = editor.fire('BeforeSetContent', { content: value, format: 'html', selection: true, paste: details.paste, }) if (args.isDefaultPrevented()) { editor.fire('SetContent', { content: args.content, format: 'html', selection: true, paste: details.paste, }) return } value = args.content if (value.indexOf('{$caret}') === -1) { value += '{$caret}' } value = value.replace(/\{\$caret\}/, bookmarkHtml) rng = selection.getRng() var caretElement = rng.startContainer || (rng.parentElement ? rng.parentElement() : null) var body = editor.getBody() if (caretElement === body && selection.isCollapsed()) { if ( dom.isBlock(body.firstChild) && canHaveChildren(editor, body.firstChild) && dom.isEmpty(body.firstChild) ) { rng = dom.createRng() rng.setStart(body.firstChild, 0) rng.setEnd(body.firstChild, 0) selection.setRng(rng) } } if (!selection.isCollapsed()) { deleteSelectedContent(editor) } parentNode = selection.getNode() var parserArgs = { context: parentNode.nodeName.toLowerCase(), data: details.data, insert: true, } var fragment = parser.parse(value, parserArgs) if ( details.paste === true && isListFragment(editor.schema, fragment) && isParentBlockLi(dom, parentNode) ) { rng = insertAtCaret$1(serializer, dom, selection.getRng(), fragment) selection.setRng(rng) editor.fire('SetContent', args) return } markFragmentElements(fragment) node = fragment.lastChild if (node.attr('id') === 'mce_marker') { var marker = node for (node = node.prev; node; node = node.walk(true)) { if (node.type === 3 || !dom.isBlock(node.name)) { if (editor.schema.isValidChild(node.parent.name, 'span')) { node.parent.insert(marker, node, node.name === 'br') } break } } } editor._selectionOverrides.showBlockCaretContainer(parentNode) if (!parserArgs.invalid) { value = serializer.serialize(fragment) validInsertion(editor, value, parentNode) } else { editor.selection.setContent(bookmarkHtml) parentNode = selection.getNode() var rootNode = editor.getBody() if (parentNode.nodeType === 9) { parentNode = node = rootNode } else { node = parentNode } while (node !== rootNode) { parentNode = node node = node.parentNode } value = parentNode === rootNode ? rootNode.innerHTML : dom.getOuterHTML(parentNode) value = serializer.serialize( parser.parse( value.replace( //i, function () { return serializer.serialize(fragment) } ) ) ) if (parentNode === rootNode) { dom.setHTML(rootNode, value) } else { dom.setOuterHTML(parentNode, value) } } reduceInlineTextElements(editor, merge) moveSelectionToMarker(editor, dom.get('mce_marker')) unmarkFragmentElements(editor.getBody()) trimBrsFromTableCell(dom, selection.getStart()) editor.fire('SetContent', args) editor.addVisual() } var traverse = function (node, fn) { fn(node) if (node.firstChild) { traverse(node.firstChild, fn) } if (node.next) { traverse(node.next, fn) } } var findMatchingNodes = function (nodeFilters, attributeFilters, node) { var nodeMatches = {} var attrMatches = {} var matches = [] if (node.firstChild) { traverse(node.firstChild, function (node) { each$k(nodeFilters, function (filter) { if (filter.name === node.name) { if (nodeMatches[filter.name]) { nodeMatches[filter.name].nodes.push(node) } else { nodeMatches[filter.name] = { filter: filter, nodes: [node], } } } }) each$k(attributeFilters, function (filter) { if (typeof node.attr(filter.name) === 'string') { if (attrMatches[filter.name]) { attrMatches[filter.name].nodes.push(node) } else { attrMatches[filter.name] = { filter: filter, nodes: [node], } } } }) }) } for (var name_1 in nodeMatches) { if (has$2(nodeMatches, name_1)) { matches.push(nodeMatches[name_1]) } } for (var name_2 in attrMatches) { if (has$2(attrMatches, name_2)) { matches.push(attrMatches[name_2]) } } return matches } var filter$1 = function (nodeFilters, attributeFilters, node) { var matches = findMatchingNodes(nodeFilters, attributeFilters, node) each$k(matches, function (match) { each$k(match.filter.callbacks, function (callback) { callback(match.nodes, match.filter.name, {}) }) }) } var defaultFormat$1 = 'html' var isTreeNode = function (content) { return content instanceof AstNode } var moveSelection = function (editor) { if (hasFocus(editor)) { firstPositionIn(editor.getBody()).each(function (pos) { var node = pos.getNode() var caretPos = isTable$3(node) ? firstPositionIn(node).getOr(pos) : pos editor.selection.setRng(caretPos.toRange()) }) } } var setEditorHtml = function (editor, html, noSelection) { editor.dom.setHTML(editor.getBody(), html) if (noSelection !== true) { moveSelection(editor) } } var setContentString = function (editor, body, content, args) { if (content.length === 0 || /^\s+$/.test(content)) { var padd = '
' if (body.nodeName === 'TABLE') { content = '' + padd + '' } else if (/^(UL|OL)$/.test(body.nodeName)) { content = '
  • ' + padd + '
  • ' } var forcedRootBlockName = getForcedRootBlock(editor) if ( forcedRootBlockName && editor.schema.isValidChild( body.nodeName.toLowerCase(), forcedRootBlockName.toLowerCase() ) ) { content = padd content = editor.dom.createHTML( forcedRootBlockName, getForcedRootBlockAttrs(editor), content ) } else if (!content) { content = '
    ' } setEditorHtml(editor, content, args.no_selection) editor.fire('SetContent', args) } else { if (args.format !== 'raw') { content = HtmlSerializer( { validate: editor.validate }, editor.schema ).serialize( editor.parser.parse(content, { isRootContent: true, insert: true, }) ) } args.content = isWsPreserveElement(SugarElement.fromDom(body)) ? content : Tools.trim(content) setEditorHtml(editor, args.content, args.no_selection) if (!args.no_events) { editor.fire('SetContent', args) } } return args.content } var setContentTree = function (editor, body, content, args) { filter$1( editor.parser.getNodeFilters(), editor.parser.getAttributeFilters(), content ) var html = HtmlSerializer( { validate: editor.validate }, editor.schema ).serialize(content) args.content = isWsPreserveElement(SugarElement.fromDom(body)) ? html : Tools.trim(html) setEditorHtml(editor, args.content, args.no_selection) if (!args.no_events) { editor.fire('SetContent', args) } return content } var setupArgs$2 = function (args, content) { return __assign(__assign({ format: defaultFormat$1 }, args), { set: true, content: isTreeNode(content) ? '' : content, }) } var setContentInternal = function (editor, content, args) { var defaultedArgs = setupArgs$2(args, content) var updatedArgs = args.no_events ? defaultedArgs : editor.fire('BeforeSetContent', defaultedArgs) if (!isTreeNode(content)) { content = updatedArgs.content } return Optional.from(editor.getBody()).fold( constant(content), function (body) { return isTreeNode(content) ? setContentTree(editor, body, content, updatedArgs) : setContentString(editor, body, content, updatedArgs) } ) } var sibling = function (scope, predicate) { return sibling$2(scope, predicate).isSome() } var ensureIsRoot = function (isRoot) { return isFunction(isRoot) ? isRoot : never } var ancestor = function (scope, transform, isRoot) { var element = scope.dom var stop = ensureIsRoot(isRoot) while (element.parentNode) { element = element.parentNode var el = SugarElement.fromDom(element) var transformed = transform(el) if (transformed.isSome()) { return transformed } else if (stop(el)) { break } } return Optional.none() } var closest$1 = function (scope, transform, isRoot) { var current = transform(scope) var stop = ensureIsRoot(isRoot) return current.orThunk(function () { return stop(scope) ? Optional.none() : ancestor(scope, transform, stop) }) } var isEq$3 = isEq$5 var matchesUnInheritedFormatSelector = function (ed, node, name) { var formatList = ed.formatter.get(name) if (formatList) { for (var i = 0; i < formatList.length; i++) { var format = formatList[i] if ( isSelectorFormat(format) && format.inherit === false && ed.dom.is(node, format.selector) ) { return true } } } return false } var matchParents = function (editor, node, name, vars, similar) { var root = editor.dom.getRoot() if (node === root) { return false } node = editor.dom.getParent(node, function (node) { if (matchesUnInheritedFormatSelector(editor, node, name)) { return true } return ( node.parentNode === root || !!matchNode(editor, node, name, vars, true) ) }) return !!matchNode(editor, node, name, vars, similar) } var matchName$1 = function (dom, node, format) { if (isEq$3(node, format.inline)) { return true } if (isEq$3(node, format.block)) { return true } if (format.selector) { return node.nodeType === 1 && dom.is(node, format.selector) } } var matchItems = function (dom, node, format, itemName, similar, vars) { var items = format[itemName] if (isFunction(format.onmatch)) { return format.onmatch(node, format, itemName) } if (items) { if (isUndefined(items.length)) { for (var key in items) { if (has$2(items, key)) { var value = itemName === 'attributes' ? dom.getAttrib(node, key) : getStyle(dom, node, key) var expectedValue = replaceVars(items[key], vars) var isEmptyValue = isNullable(value) || isEmpty$3(value) if (isEmptyValue && isNullable(expectedValue)) { continue } if (similar && isEmptyValue && !format.exact) { return false } if ( (!similar || format.exact) && !isEq$3(value, normalizeStyleValue(dom, expectedValue, key)) ) { return false } } } } else { for (var i = 0; i < items.length; i++) { if ( itemName === 'attributes' ? dom.getAttrib(node, items[i]) : getStyle(dom, node, items[i]) ) { return true } } } } return true } var matchNode = function (ed, node, name, vars, similar) { var formatList = ed.formatter.get(name) var dom = ed.dom if (formatList && node) { for (var i = 0; i < formatList.length; i++) { var format = formatList[i] if ( matchName$1(ed.dom, node, format) && matchItems(dom, node, format, 'attributes', similar, vars) && matchItems(dom, node, format, 'styles', similar, vars) ) { var classes = format.classes if (classes) { for (var x = 0; x < classes.length; x++) { if (!ed.dom.hasClass(node, replaceVars(classes[x], vars))) { return } } } return format } } } } var match$2 = function (editor, name, vars, node, similar) { if (node) { return matchParents(editor, node, name, vars, similar) } node = editor.selection.getNode() if (matchParents(editor, node, name, vars, similar)) { return true } var startNode = editor.selection.getStart() if (startNode !== node) { if (matchParents(editor, startNode, name, vars, similar)) { return true } } return false } var matchAll = function (editor, names, vars) { var matchedFormatNames = [] var checkedMap = {} var startElement = editor.selection.getStart() editor.dom.getParent( startElement, function (node) { for (var i = 0; i < names.length; i++) { var name_1 = names[i] if (!checkedMap[name_1] && matchNode(editor, node, name_1, vars)) { checkedMap[name_1] = true matchedFormatNames.push(name_1) } } }, editor.dom.getRoot() ) return matchedFormatNames } var closest = function (editor, names) { var isRoot = function (elm) { return eq(elm, SugarElement.fromDom(editor.getBody())) } var match = function (elm, name) { return matchNode(editor, elm.dom, name) ? Optional.some(name) : Optional.none() } return Optional.from(editor.selection.getStart(true)) .bind(function (rawElm) { return closest$1( SugarElement.fromDom(rawElm), function (elm) { return findMap(names, function (name) { return match(elm, name) }) }, isRoot ) }) .getOrNull() } var canApply = function (editor, name) { var formatList = editor.formatter.get(name) var dom = editor.dom if (formatList) { var startNode = editor.selection.getStart() var parents = getParents$2(dom, startNode) for (var x = formatList.length - 1; x >= 0; x--) { var format = formatList[x] if (!isSelectorFormat(format) || isNonNullable(format.defaultBlock)) { return true } for (var i = parents.length - 1; i >= 0; i--) { if (dom.is(parents[i], format.selector)) { return true } } } } return false } var matchAllOnNode = function (editor, node, formatNames) { return foldl( formatNames, function (acc, name) { var matchSimilar = isVariableFormatName(editor, name) if (editor.formatter.matchNode(node, name, {}, matchSimilar)) { return acc.concat([name]) } else { return acc } }, [] ) } var ZWSP = ZWSP$1, CARET_ID = '_mce_caret' var importNode = function (ownerDocument, node) { return ownerDocument.importNode(node, true) } var getEmptyCaretContainers = function (node) { var nodes = [] while (node) { if ( (node.nodeType === 3 && node.nodeValue !== ZWSP) || node.childNodes.length > 1 ) { return [] } if (node.nodeType === 1) { nodes.push(node) } node = node.firstChild } return nodes } var isCaretContainerEmpty = function (node) { return getEmptyCaretContainers(node).length > 0 } var findFirstTextNode = function (node) { if (node) { var walker = new DomTreeWalker(node, node) for (node = walker.current(); node; node = walker.next()) { if (isText$7(node)) { return node } } } return null } var createCaretContainer = function (fill) { var caretContainer = SugarElement.fromTag('span') setAll$1(caretContainer, { id: CARET_ID, 'data-mce-bogus': '1', 'data-mce-type': 'format-caret', }) if (fill) { append$1(caretContainer, SugarElement.fromText(ZWSP)) } return caretContainer } var trimZwspFromCaretContainer = function (caretContainerNode) { var textNode = findFirstTextNode(caretContainerNode) if (textNode && textNode.nodeValue.charAt(0) === ZWSP) { textNode.deleteData(0, 1) } return textNode } var removeCaretContainerNode = function (editor, node, moveCaret) { if (moveCaret === void 0) { moveCaret = true } var dom = editor.dom, selection = editor.selection if (isCaretContainerEmpty(node)) { deleteElement$2(editor, false, SugarElement.fromDom(node), moveCaret) } else { var rng = selection.getRng() var block = dom.getParent(node, dom.isBlock) var startContainer = rng.startContainer var startOffset = rng.startOffset var endContainer = rng.endContainer var endOffset = rng.endOffset var textNode = trimZwspFromCaretContainer(node) dom.remove(node, true) if (startContainer === textNode && startOffset > 0) { rng.setStart(textNode, startOffset - 1) } if (endContainer === textNode && endOffset > 0) { rng.setEnd(textNode, endOffset - 1) } if (block && dom.isEmpty(block)) { fillWithPaddingBr(SugarElement.fromDom(block)) } selection.setRng(rng) } } var removeCaretContainer = function (editor, node, moveCaret) { if (moveCaret === void 0) { moveCaret = true } var dom = editor.dom, selection = editor.selection if (!node) { node = getParentCaretContainer(editor.getBody(), selection.getStart()) if (!node) { while ((node = dom.get(CARET_ID))) { removeCaretContainerNode(editor, node, false) } } } else { removeCaretContainerNode(editor, node, moveCaret) } } var insertCaretContainerNode = function (editor, caretContainer, formatNode) { var dom = editor.dom, block = dom.getParent(formatNode, curry(isTextBlock$1, editor)) if (block && dom.isEmpty(block)) { formatNode.parentNode.replaceChild(caretContainer, formatNode) } else { removeTrailingBr(SugarElement.fromDom(formatNode)) if (dom.isEmpty(formatNode)) { formatNode.parentNode.replaceChild(caretContainer, formatNode) } else { dom.insertAfter(caretContainer, formatNode) } } } var appendNode = function (parentNode, node) { parentNode.appendChild(node) return node } var insertFormatNodesIntoCaretContainer = function ( formatNodes, caretContainer ) { var innerMostFormatNode = foldr( formatNodes, function (parentNode, formatNode) { return appendNode(parentNode, formatNode.cloneNode(false)) }, caretContainer ) return appendNode( innerMostFormatNode, innerMostFormatNode.ownerDocument.createTextNode(ZWSP) ) } var cleanFormatNode = function ( editor, caretContainer, formatNode, name, vars, similar ) { var formatter = editor.formatter var dom = editor.dom var validFormats = filter$4(keys(formatter.get()), function (formatName) { return formatName !== name && !contains$2(formatName, 'removeformat') }) var matchedFormats = matchAllOnNode(editor, formatNode, validFormats) var uniqueFormats = filter$4(matchedFormats, function (fmtName) { return !areSimilarFormats(editor, fmtName, name) }) if (uniqueFormats.length > 0) { var clonedFormatNode = formatNode.cloneNode(false) dom.add(caretContainer, clonedFormatNode) formatter.remove(name, vars, clonedFormatNode, similar) dom.remove(clonedFormatNode) return Optional.some(clonedFormatNode) } else { return Optional.none() } } var applyCaretFormat = function (editor, name, vars) { var caretContainer, textNode var selection = editor.selection var selectionRng = selection.getRng() var offset = selectionRng.startOffset var container = selectionRng.startContainer var text = container.nodeValue caretContainer = getParentCaretContainer( editor.getBody(), selection.getStart() ) if (caretContainer) { textNode = findFirstTextNode(caretContainer) } var wordcharRegex = /[^\s\u00a0\u00ad\u200b\ufeff]/ if ( text && offset > 0 && offset < text.length && wordcharRegex.test(text.charAt(offset)) && wordcharRegex.test(text.charAt(offset - 1)) ) { var bookmark = selection.getBookmark() selectionRng.collapse(true) var rng = expandRng(editor, selectionRng, editor.formatter.get(name)) rng = split(rng) editor.formatter.apply(name, vars, rng) selection.moveToBookmark(bookmark) } else { if (!caretContainer || textNode.nodeValue !== ZWSP) { caretContainer = importNode( editor.getDoc(), createCaretContainer(true).dom ) textNode = caretContainer.firstChild selectionRng.insertNode(caretContainer) offset = 1 editor.formatter.apply(name, vars, caretContainer) } else { editor.formatter.apply(name, vars, caretContainer) } selection.setCursorLocation(textNode, offset) } } var removeCaretFormat = function (editor, name, vars, similar) { var dom = editor.dom var selection = editor.selection var hasContentAfter, node, formatNode var parents = [] var rng = selection.getRng() var container = rng.startContainer var offset = rng.startOffset node = container if (container.nodeType === 3) { if (offset !== container.nodeValue.length) { hasContentAfter = true } node = node.parentNode } while (node) { if (matchNode(editor, node, name, vars, similar)) { formatNode = node break } if (node.nextSibling) { hasContentAfter = true } parents.push(node) node = node.parentNode } if (!formatNode) { return } if (hasContentAfter) { var bookmark = selection.getBookmark() rng.collapse(true) var expandedRng = expandRng(editor, rng, editor.formatter.get(name), true) expandedRng = split(expandedRng) editor.formatter.remove(name, vars, expandedRng, similar) selection.moveToBookmark(bookmark) } else { var caretContainer = getParentCaretContainer(editor.getBody(), formatNode) var newCaretContainer = createCaretContainer(false).dom insertCaretContainerNode( editor, newCaretContainer, caretContainer !== null ? caretContainer : formatNode ) var cleanedFormatNode = cleanFormatNode( editor, newCaretContainer, formatNode, name, vars, similar ) var caretTextNode = insertFormatNodesIntoCaretContainer( parents.concat(cleanedFormatNode.toArray()), newCaretContainer ) removeCaretContainerNode(editor, caretContainer, false) selection.setCursorLocation(caretTextNode, 1) if (dom.isEmpty(formatNode)) { dom.remove(formatNode) } } } var disableCaretContainer = function (editor, keyCode) { var selection = editor.selection, body = editor.getBody() removeCaretContainer(editor, null, false) if ( (keyCode === 8 || keyCode === 46) && selection.isCollapsed() && selection.getStart().innerHTML === ZWSP ) { removeCaretContainer( editor, getParentCaretContainer(body, selection.getStart()) ) } if (keyCode === 37 || keyCode === 39) { removeCaretContainer( editor, getParentCaretContainer(body, selection.getStart()) ) } } var setup$k = function (editor) { editor.on('mouseup keydown', function (e) { disableCaretContainer(editor, e.keyCode) }) } var replaceWithCaretFormat = function (targetNode, formatNodes) { var caretContainer = createCaretContainer(false) var innerMost = insertFormatNodesIntoCaretContainer( formatNodes, caretContainer.dom ) before$4(SugarElement.fromDom(targetNode), caretContainer) remove$7(SugarElement.fromDom(targetNode)) return CaretPosition(innerMost, 0) } var isFormatElement = function (editor, element) { var inlineElements = editor.schema.getTextInlineElements() return ( has$2(inlineElements, name(element)) && !isCaretNode(element.dom) && !isBogus$2(element.dom) ) } var isEmptyCaretFormatElement = function (element) { return isCaretNode(element.dom) && isCaretContainerEmpty(element.dom) } var postProcessHooks = {} var filter = filter$2 var each$b = each$i var addPostProcessHook = function (name, hook) { var hooks = postProcessHooks[name] if (!hooks) { postProcessHooks[name] = [] } postProcessHooks[name].push(hook) } var postProcess$1 = function (name, editor) { each$b(postProcessHooks[name], function (hook) { hook(editor) }) } addPostProcessHook('pre', function (editor) { var rng = editor.selection.getRng() var blocks var hasPreSibling = function (pre) { return ( isPre(pre.previousSibling) && indexOf$1(blocks, pre.previousSibling) !== -1 ) } var joinPre = function (pre1, pre2) { DomQuery(pre2).remove() DomQuery(pre1).append('

    ').append(pre2.childNodes) } var isPre = matchNodeNames(['pre']) if (!rng.collapsed) { blocks = editor.selection.getSelectedBlocks() each$b(filter(filter(blocks, isPre), hasPreSibling), function (pre) { joinPre(pre.previousSibling, pre) }) } }) var each$a = Tools.each var isElementNode$1 = function (node) { return ( isElement$5(node) && !isBookmarkNode$1(node) && !isCaretNode(node) && !isBogus$2(node) ) } var findElementSibling = function (node, siblingName) { for (var sibling = node; sibling; sibling = sibling[siblingName]) { if (isText$7(sibling) && isNotEmpty(sibling.data)) { return node } if (isElement$5(sibling) && !isBookmarkNode$1(sibling)) { return sibling } } return node } var mergeSiblingsNodes = function (dom, prev, next) { var elementUtils = ElementUtils(dom) if (prev && next) { prev = findElementSibling(prev, 'previousSibling') next = findElementSibling(next, 'nextSibling') if (elementUtils.compare(prev, next)) { for (var sibling = prev.nextSibling; sibling && sibling !== next; ) { var tmpSibling = sibling sibling = sibling.nextSibling prev.appendChild(tmpSibling) } dom.remove(next) Tools.each(Tools.grep(next.childNodes), function (node) { prev.appendChild(node) }) return prev } } return next } var mergeSiblings = function (dom, format, vars, node) { if (node && format.merge_siblings !== false) { var newNode = mergeSiblingsNodes(dom, getNonWhiteSpaceSibling(node), node) mergeSiblingsNodes(dom, newNode, getNonWhiteSpaceSibling(newNode, true)) } } var clearChildStyles = function (dom, format, node) { if (format.clear_child_styles) { var selector = format.links ? '*:not(a)' : '*' each$a(dom.select(selector, node), function (node) { if (isElementNode$1(node)) { each$a(format.styles, function (value, name) { dom.setStyle(node, name, '') }) } }) } } var processChildElements = function (node, filter, process) { each$a(node.childNodes, function (node) { if (isElementNode$1(node)) { if (filter(node)) { process(node) } if (node.hasChildNodes()) { processChildElements(node, filter, process) } } }) } var unwrapEmptySpan = function (dom, node) { if (node.nodeName === 'SPAN' && dom.getAttribs(node).length === 0) { dom.remove(node, true) } } var hasStyle = function (dom, name) { return function (node) { return !!(node && getStyle(dom, node, name)) } } var applyStyle = function (dom, name, value) { return function (node) { dom.setStyle(node, name, value) if (node.getAttribute('style') === '') { node.removeAttribute('style') } unwrapEmptySpan(dom, node) } } var removeResult = Adt.generate([ { keep: [] }, { rename: ['name'] }, { removed: [] }, ]) var MCE_ATTR_RE = /^(src|href|style)$/ var each$9 = Tools.each var isEq$2 = isEq$5 var isTableCellOrRow = function (node) { return /^(TR|TH|TD)$/.test(node.nodeName) } var isChildOfInlineParent = function (dom, node, parent) { return ( dom.isChildOf(node, parent) && node !== parent && !dom.isBlock(parent) ) } var getContainer = function (ed, rng, start) { var container = rng[start ? 'startContainer' : 'endContainer'] var offset = rng[start ? 'startOffset' : 'endOffset'] if (isElement$5(container)) { var lastIdx = container.childNodes.length - 1 if (!start && offset) { offset-- } container = container.childNodes[offset > lastIdx ? lastIdx : offset] } if (isText$7(container) && start && offset >= container.nodeValue.length) { container = new DomTreeWalker(container, ed.getBody()).next() || container } if (isText$7(container) && !start && offset === 0) { container = new DomTreeWalker(container, ed.getBody()).prev() || container } return container } var normalizeTableSelection = function (node, start) { var prop = start ? 'firstChild' : 'lastChild' if (isTableCellOrRow(node) && node[prop]) { var childNode = node[prop] if (node.nodeName === 'TR') { return childNode[prop] || childNode } else { return childNode } } return node } var wrap$1 = function (dom, node, name, attrs) { var wrapper = dom.create(name, attrs) node.parentNode.insertBefore(wrapper, node) wrapper.appendChild(node) return wrapper } var wrapWithSiblings = function (dom, node, next, name, attrs) { var start = SugarElement.fromDom(node) var wrapper = SugarElement.fromDom(dom.create(name, attrs)) var siblings = next ? nextSiblings(start) : prevSiblings(start) append(wrapper, siblings) if (next) { before$4(start, wrapper) prepend(wrapper, start) } else { after$3(start, wrapper) append$1(wrapper, start) } return wrapper.dom } var matchName = function (dom, node, format) { if (isInlineFormat(format) && isEq$2(node, format.inline)) { return true } if (isBlockFormat(format) && isEq$2(node, format.block)) { return true } if (isSelectorFormat(format)) { return isElement$5(node) && dom.is(node, format.selector) } } var isColorFormatAndAnchor = function (node, format) { return format.links && node.nodeName === 'A' } var find = function (dom, node, next, inc) { var sibling = getNonWhiteSpaceSibling(node, next, inc) return ( isNullable(sibling) || sibling.nodeName === 'BR' || dom.isBlock(sibling) ) } var removeNode = function (ed, node, format) { var parentNode = node.parentNode var rootBlockElm var dom = ed.dom, forcedRootBlock = getForcedRootBlock(ed) if (isBlockFormat(format)) { if (!forcedRootBlock) { if (dom.isBlock(node) && !dom.isBlock(parentNode)) { if ( !find(dom, node, false) && !find(dom, node.firstChild, true, true) ) { node.insertBefore(dom.create('br'), node.firstChild) } if ( !find(dom, node, true) && !find(dom, node.lastChild, false, true) ) { node.appendChild(dom.create('br')) } } } else { if (parentNode === dom.getRoot()) { if (!format.list_block || !isEq$2(node, format.list_block)) { each$k(from(node.childNodes), function (node) { if (isValid(ed, forcedRootBlock, node.nodeName.toLowerCase())) { if (!rootBlockElm) { rootBlockElm = wrap$1(dom, node, forcedRootBlock) dom.setAttribs( rootBlockElm, ed.settings.forced_root_block_attrs ) } else { rootBlockElm.appendChild(node) } } else { rootBlockElm = null } }) } } } } if (isMixedFormat(format) && !isEq$2(format.inline, node)) { return } dom.remove(node, true) } var removeFormatInternal = function (ed, format, vars, node, compareNode) { var stylesModified var dom = ed.dom if ( !matchName(dom, node, format) && !isColorFormatAndAnchor(node, format) ) { return removeResult.keep() } var elm = node if ( isInlineFormat(format) && format.remove === 'all' && isArray$1(format.preserve_attributes) ) { var attrsToPreserve = filter$4(dom.getAttribs(elm), function (attr) { return contains$3(format.preserve_attributes, attr.name.toLowerCase()) }) dom.removeAllAttribs(elm) each$k(attrsToPreserve, function (attr) { return dom.setAttrib(elm, attr.name, attr.value) }) if (attrsToPreserve.length > 0) { return removeResult.rename('span') } } if (format.remove !== 'all') { each$9(format.styles, function (value, name) { value = normalizeStyleValue(dom, replaceVars(value, vars), name + '') if (isNumber(name)) { name = value compareNode = null } if ( format.remove_similar || !compareNode || isEq$2(getStyle(dom, compareNode, name), value) ) { dom.setStyle(elm, name, '') } stylesModified = true }) if (stylesModified && dom.getAttrib(elm, 'style') === '') { elm.removeAttribute('style') elm.removeAttribute('data-mce-style') } each$9(format.attributes, function (value, name) { var valueOut value = replaceVars(value, vars) if (isNumber(name)) { name = value compareNode = null } if ( format.remove_similar || !compareNode || isEq$2(dom.getAttrib(compareNode, name), value) ) { if (name === 'class') { value = dom.getAttrib(elm, name) if (value) { valueOut = '' each$k(value.split(/\s+/), function (cls) { if (/mce\-\w+/.test(cls)) { valueOut += (valueOut ? ' ' : '') + cls } }) if (valueOut) { dom.setAttrib(elm, name, valueOut) return } } } if (MCE_ATTR_RE.test(name)) { elm.removeAttribute('data-mce-' + name) } if ( name === 'style' && matchNodeNames(['li'])(elm) && dom.getStyle(elm, 'list-style-type') === 'none' ) { elm.removeAttribute(name) dom.setStyle(elm, 'list-style-type', 'none') return } if (name === 'class') { elm.removeAttribute('className') } elm.removeAttribute(name) } }) each$9(format.classes, function (value) { value = replaceVars(value, vars) if (!compareNode || dom.hasClass(compareNode, value)) { dom.removeClass(elm, value) } }) var attrs = dom.getAttribs(elm) for (var i = 0; i < attrs.length; i++) { var attrName = attrs[i].nodeName if (attrName.indexOf('_') !== 0 && attrName.indexOf('data-') !== 0) { return removeResult.keep() } } } if (format.remove !== 'none') { removeNode(ed, elm, format) return removeResult.removed() } return removeResult.keep() } var removeFormat$1 = function (ed, format, vars, node, compareNode) { return removeFormatInternal(ed, format, vars, node, compareNode).fold( never, function (newName) { ed.dom.rename(node, newName) return true }, always ) } var findFormatRoot = function (editor, container, name, vars, similar) { var formatRoot each$k( getParents$2(editor.dom, container.parentNode).reverse(), function (parent) { if (!formatRoot && parent.id !== '_start' && parent.id !== '_end') { var format = matchNode(editor, parent, name, vars, similar) if (format && format.split !== false) { formatRoot = parent } } } ) return formatRoot } var removeFormatFromClone = function (editor, format, vars, clone) { return removeFormatInternal(editor, format, vars, clone, clone).fold( constant(clone), function (newName) { var fragment = editor.dom.createFragment() fragment.appendChild(clone) return editor.dom.rename(clone, newName) }, constant(null) ) } var wrapAndSplit = function ( editor, formatList, formatRoot, container, target, split, format, vars ) { var clone, lastClone, firstClone var dom = editor.dom if (formatRoot) { var formatRootParent = formatRoot.parentNode for ( var parent_1 = container.parentNode; parent_1 && parent_1 !== formatRootParent; parent_1 = parent_1.parentNode ) { clone = dom.clone(parent_1, false) for (var i = 0; i < formatList.length; i++) { clone = removeFormatFromClone(editor, formatList[i], vars, clone) if (clone === null) { break } } if (clone) { if (lastClone) { clone.appendChild(lastClone) } if (!firstClone) { firstClone = clone } lastClone = clone } } if (split && (!format.mixed || !dom.isBlock(formatRoot))) { container = dom.split(formatRoot, container) } if (lastClone) { target.parentNode.insertBefore(lastClone, target) firstClone.appendChild(target) if (isInlineFormat(format)) { mergeSiblings(dom, format, vars, lastClone) } } } return container } var remove$1 = function (ed, name, vars, node, similar) { var formatList = ed.formatter.get(name) var format = formatList[0] var contentEditable = true var dom = ed.dom var selection = ed.selection var splitToFormatRoot = function (container) { var formatRoot = findFormatRoot(ed, container, name, vars, similar) return wrapAndSplit( ed, formatList, formatRoot, container, container, true, format, vars ) } var isRemoveBookmarkNode = function (node) { return ( isBookmarkNode$1(node) && isElement$5(node) && (node.id === '_start' || node.id === '_end') ) } var removeNodeFormat = function (node) { return exists(formatList, function (fmt) { return removeFormat$1(ed, fmt, vars, node, node) }) } var process = function (node) { var lastContentEditable = true var hasContentEditableState = false if (isElement$5(node) && dom.getContentEditable(node)) { lastContentEditable = contentEditable contentEditable = dom.getContentEditable(node) === 'true' hasContentEditableState = true } var children = from(node.childNodes) if (contentEditable && !hasContentEditableState) { var removed = removeNodeFormat(node) var parentNode = node.parentNode if ( !removed && isNonNullable(parentNode) && shouldExpandToSelector(format) ) { removeNodeFormat(parentNode) } } if (format.deep) { if (children.length) { for (var i = 0; i < children.length; i++) { process(children[i]) } if (hasContentEditableState) { contentEditable = lastContentEditable } } } var textDecorations = ['underline', 'line-through', 'overline'] each$k(textDecorations, function (decoration) { if ( isElement$5(node) && ed.dom.getStyle(node, 'text-decoration') === decoration && node.parentNode && getTextDecoration(dom, node.parentNode) === decoration ) { removeFormat$1( ed, { deep: false, exact: true, inline: 'span', styles: { textDecoration: decoration }, }, null, node ) } }) } var unwrap = function (start) { var node = dom.get(start ? '_start' : '_end') var out = node[start ? 'firstChild' : 'lastChild'] if (isRemoveBookmarkNode(out)) { out = out[start ? 'firstChild' : 'lastChild'] } if (isText$7(out) && out.data.length === 0) { out = start ? node.previousSibling || node.nextSibling : node.nextSibling || node.previousSibling } dom.remove(node, true) return out } var removeRngStyle = function (rng) { var startContainer, endContainer var expandedRng = expandRng(ed, rng, formatList, rng.collapsed) if (format.split) { expandedRng = split(expandedRng) startContainer = getContainer(ed, expandedRng, true) endContainer = getContainer(ed, expandedRng) if (startContainer !== endContainer) { startContainer = normalizeTableSelection(startContainer, true) endContainer = normalizeTableSelection(endContainer, false) if (isChildOfInlineParent(dom, startContainer, endContainer)) { var marker = Optional.from(startContainer.firstChild).getOr( startContainer ) splitToFormatRoot( wrapWithSiblings(dom, marker, true, 'span', { id: '_start', 'data-mce-type': 'bookmark', }) ) unwrap(true) return } if (isChildOfInlineParent(dom, endContainer, startContainer)) { var marker = Optional.from(endContainer.lastChild).getOr( endContainer ) splitToFormatRoot( wrapWithSiblings(dom, marker, false, 'span', { id: '_end', 'data-mce-type': 'bookmark', }) ) unwrap(false) return } startContainer = wrap$1(dom, startContainer, 'span', { id: '_start', 'data-mce-type': 'bookmark', }) endContainer = wrap$1(dom, endContainer, 'span', { id: '_end', 'data-mce-type': 'bookmark', }) var newRng = dom.createRng() newRng.setStartAfter(startContainer) newRng.setEndBefore(endContainer) walk$2(dom, newRng, function (nodes) { each$k(nodes, function (n) { if (!isBookmarkNode$1(n) && !isBookmarkNode$1(n.parentNode)) { splitToFormatRoot(n) } }) }) splitToFormatRoot(startContainer) splitToFormatRoot(endContainer) startContainer = unwrap(true) endContainer = unwrap() } else { startContainer = endContainer = splitToFormatRoot(startContainer) } expandedRng.startContainer = startContainer.parentNode ? startContainer.parentNode : startContainer expandedRng.startOffset = dom.nodeIndex(startContainer) expandedRng.endContainer = endContainer.parentNode ? endContainer.parentNode : endContainer expandedRng.endOffset = dom.nodeIndex(endContainer) + 1 } walk$2(dom, expandedRng, function (nodes) { each$k(nodes, process) }) } if (node) { if (isNode(node)) { var rng = dom.createRng() rng.setStartBefore(node) rng.setEndAfter(node) removeRngStyle(rng) } else { removeRngStyle(node) } fireFormatRemove(ed, name, node, vars) return } if (dom.getContentEditable(selection.getNode()) === 'false') { node = selection.getNode() for (var i = 0; i < formatList.length; i++) { if (formatList[i].ceFalseOverride) { if (removeFormat$1(ed, formatList[i], vars, node, node)) { break } } } fireFormatRemove(ed, name, node, vars) return } if ( !selection.isCollapsed() || !isInlineFormat(format) || getCellsFromEditor(ed).length ) { preserve(selection, true, function () { runOnRanges(ed, removeRngStyle) }) if ( isInlineFormat(format) && match$2(ed, name, vars, selection.getStart()) ) { moveStart(dom, selection, selection.getRng()) } ed.nodeChanged() } else { removeCaretFormat(ed, name, vars, similar) } fireFormatRemove(ed, name, node, vars) } var each$8 = Tools.each var mergeTextDecorationsAndColor = function (dom, format, vars, node) { var processTextDecorationsAndColor = function (n) { if (n.nodeType === 1 && n.parentNode && n.parentNode.nodeType === 1) { var textDecoration = getTextDecoration(dom, n.parentNode) if (dom.getStyle(n, 'color') && textDecoration) { dom.setStyle(n, 'text-decoration', textDecoration) } else if (dom.getStyle(n, 'text-decoration') === textDecoration) { dom.setStyle(n, 'text-decoration', null) } } } if ( format.styles && (format.styles.color || format.styles.textDecoration) ) { Tools.walk(node, processTextDecorationsAndColor, 'childNodes') processTextDecorationsAndColor(node) } } var mergeBackgroundColorAndFontSize = function (dom, format, vars, node) { if (format.styles && format.styles.backgroundColor) { processChildElements( node, hasStyle(dom, 'fontSize'), applyStyle( dom, 'backgroundColor', replaceVars(format.styles.backgroundColor, vars) ) ) } } var mergeSubSup = function (dom, format, vars, node) { if ( isInlineFormat(format) && (format.inline === 'sub' || format.inline === 'sup') ) { processChildElements( node, hasStyle(dom, 'fontSize'), applyStyle(dom, 'fontSize', '') ) dom.remove( dom.select(format.inline === 'sup' ? 'sub' : 'sup', node), true ) } } var mergeWithChildren = function (editor, formatList, vars, node) { each$8(formatList, function (format) { if (isInlineFormat(format)) { each$8(editor.dom.select(format.inline, node), function (child) { if (!isElementNode$1(child)) { return } removeFormat$1( editor, format, vars, child, format.exact ? child : null ) }) } clearChildStyles(editor.dom, format, node) }) } var mergeWithParents = function (editor, format, name, vars, node) { if (matchNode(editor, node.parentNode, name, vars)) { if (removeFormat$1(editor, format, vars, node)) { return } } if (format.merge_with_parents) { editor.dom.getParent(node.parentNode, function (parent) { if (matchNode(editor, parent, name, vars)) { removeFormat$1(editor, format, vars, node) return true } }) } } var each$7 = Tools.each var isElementNode = function (node) { return ( isElement$5(node) && !isBookmarkNode$1(node) && !isCaretNode(node) && !isBogus$2(node) ) } var canFormatBR = function (editor, format, node, parentName) { if (canFormatEmptyLines(editor) && isInlineFormat(format)) { var validBRParentElements = __assign( __assign({}, editor.schema.getTextBlockElements()), { td: {}, th: {}, li: {}, dt: {}, dd: {}, figcaption: {}, caption: {}, details: {}, summary: {}, } ) var hasCaretNodeSibling = sibling( SugarElement.fromDom(node), function (sibling) { return isCaretNode(sibling.dom) } ) return ( hasNonNullableKey(validBRParentElements, parentName) && isEmpty$2(SugarElement.fromDom(node.parentNode), false) && !hasCaretNodeSibling ) } else { return false } } var applyFormat$1 = function (ed, name, vars, node) { var formatList = ed.formatter.get(name) var format = formatList[0] var isCollapsed = !node && ed.selection.isCollapsed() var dom = ed.dom var selection = ed.selection var setElementFormat = function (elm, fmt) { if (fmt === void 0) { fmt = format } if (isFunction(fmt.onformat)) { fmt.onformat(elm, fmt, vars, node) } each$7(fmt.styles, function (value, name) { dom.setStyle(elm, name, replaceVars(value, vars)) }) if (fmt.styles) { var styleVal = dom.getAttrib(elm, 'style') if (styleVal) { dom.setAttrib(elm, 'data-mce-style', styleVal) } } each$7(fmt.attributes, function (value, name) { dom.setAttrib(elm, name, replaceVars(value, vars)) }) each$7(fmt.classes, function (value) { value = replaceVars(value, vars) if (!dom.hasClass(elm, value)) { dom.addClass(elm, value) } }) } var applyNodeStyle = function (formatList, node) { var found = false each$7(formatList, function (format) { if (!isSelectorFormat(format)) { return false } if ( isNonNullable(format.collapsed) && format.collapsed !== isCollapsed ) { return } if (dom.is(node, format.selector) && !isCaretNode(node)) { setElementFormat(node, format) found = true return false } }) return found } var createWrapElement = function (wrapName) { if (isString$1(wrapName)) { var wrapElm = dom.create(wrapName) setElementFormat(wrapElm) return wrapElm } else { return null } } var applyRngStyle = function (dom, rng, nodeSpecific) { var newWrappers = [] var contentEditable = true var wrapName = format.inline || format.block var wrapElm = createWrapElement(wrapName) walk$2(dom, rng, function (nodes) { var currentWrapElm var process = function (node) { var hasContentEditableState = false var lastContentEditable = contentEditable var nodeName = node.nodeName.toLowerCase() var parentNode = node.parentNode var parentName = parentNode.nodeName.toLowerCase() if (isElement$5(node) && dom.getContentEditable(node)) { lastContentEditable = contentEditable contentEditable = dom.getContentEditable(node) === 'true' hasContentEditableState = true } if (isBr$5(node) && !canFormatBR(ed, format, node, parentName)) { currentWrapElm = null if (isBlockFormat(format)) { dom.remove(node) } return } if ( isBlockFormat(format) && format.wrapper && matchNode(ed, node, name, vars) ) { currentWrapElm = null return } if ( contentEditable && !hasContentEditableState && isBlockFormat(format) && !format.wrapper && isTextBlock$1(ed, nodeName) && isValid(ed, parentName, wrapName) ) { var elm = dom.rename(node, wrapName) setElementFormat(elm) newWrappers.push(elm) currentWrapElm = null return } if (isSelectorFormat(format)) { var found = applyNodeStyle(formatList, node) if ( !found && isNonNullable(parentNode) && shouldExpandToSelector(format) ) { found = applyNodeStyle(formatList, parentNode) } if (!isInlineFormat(format) || found) { currentWrapElm = null return } } if ( contentEditable && !hasContentEditableState && isValid(ed, wrapName, nodeName) && isValid(ed, parentName, wrapName) && !(!nodeSpecific && isText$7(node) && isZwsp(node.data)) && !isCaretNode(node) && (!isInlineFormat(format) || !dom.isBlock(node)) ) { if (!currentWrapElm) { currentWrapElm = dom.clone(wrapElm, false) node.parentNode.insertBefore(currentWrapElm, node) newWrappers.push(currentWrapElm) } currentWrapElm.appendChild(node) } else { currentWrapElm = null each$k(from(node.childNodes), process) if (hasContentEditableState) { contentEditable = lastContentEditable } currentWrapElm = null } } each$k(nodes, process) }) if (format.links === true) { each$k(newWrappers, function (node) { var process = function (node) { if (node.nodeName === 'A') { setElementFormat(node, format) } each$k(from(node.childNodes), process) } process(node) }) } each$k(newWrappers, function (node) { var getChildCount = function (node) { var count = 0 each$k(node.childNodes, function (node) { if (!isEmptyTextNode$1(node) && !isBookmarkNode$1(node)) { count++ } }) return count } var mergeStyles = function (node) { var childElement = find$3(node.childNodes, isElementNode).filter( function (child) { return matchName$1(dom, child, format) } ) return childElement .map(function (child) { var clone = dom.clone(child, false) setElementFormat(clone) dom.replace(clone, node, true) dom.remove(child, true) return clone }) .getOr(node) } var childCount = getChildCount(node) if ( (newWrappers.length > 1 || !dom.isBlock(node)) && childCount === 0 ) { dom.remove(node, true) return } if ( isInlineFormat(format) || (isBlockFormat(format) && format.wrapper) ) { if (!format.exact && childCount === 1) { node = mergeStyles(node) } mergeWithChildren(ed, formatList, vars, node) mergeWithParents(ed, format, name, vars, node) mergeBackgroundColorAndFontSize(dom, format, vars, node) mergeTextDecorationsAndColor(dom, format, vars, node) mergeSubSup(dom, format, vars, node) mergeSiblings(dom, format, vars, node) } }) } if (dom.getContentEditable(selection.getNode()) === 'false') { node = selection.getNode() for (var i = 0, l = formatList.length; i < l; i++) { var formatItem = formatList[i] if ( formatItem.ceFalseOverride && isSelectorFormat(formatItem) && dom.is(node, formatItem.selector) ) { setElementFormat(node, formatItem) break } } fireFormatApply(ed, name, node, vars) return } if (format) { if (node) { if (isNode(node)) { if (!applyNodeStyle(formatList, node)) { var rng = dom.createRng() rng.setStartBefore(node) rng.setEndAfter(node) applyRngStyle(dom, expandRng(ed, rng, formatList), true) } } else { applyRngStyle(dom, node, true) } } else { if ( !isCollapsed || !isInlineFormat(format) || getCellsFromEditor(ed).length ) { var curSelNode = selection.getNode() var firstFormat = formatList[0] if ( !ed.settings.forced_root_block && firstFormat.defaultBlock && !dom.getParent(curSelNode, dom.isBlock) ) { applyFormat$1(ed, firstFormat.defaultBlock) } selection.setRng(normalize(selection.getRng())) preserve(selection, true, function () { runOnRanges(ed, function (selectionRng, fake) { var expandedRng = fake ? selectionRng : expandRng(ed, selectionRng, formatList) applyRngStyle(dom, expandedRng, false) }) }) moveStart(dom, selection, selection.getRng()) ed.nodeChanged() } else { applyCaretFormat(ed, name, vars) } } postProcess$1(name, ed) } fireFormatApply(ed, name, node, vars) } var hasVars = function (value) { return has$2(value, 'vars') } var setup$j = function (registeredFormatListeners, editor) { registeredFormatListeners.set({}) editor.on('NodeChange', function (e) { updateAndFireChangeCallbacks( editor, e.element, registeredFormatListeners.get() ) }) editor.on('FormatApply FormatRemove', function (e) { var element = Optional.from(e.node) .map(function (nodeOrRange) { return isNode(nodeOrRange) ? nodeOrRange : nodeOrRange.startContainer }) .bind(function (node) { return isElement$5(node) ? Optional.some(node) : Optional.from(node.parentElement) }) .getOrThunk(function () { return fallbackElement(editor) }) updateAndFireChangeCallbacks( editor, element, registeredFormatListeners.get() ) }) } var fallbackElement = function (editor) { return editor.selection.getStart() } var matchingNode = function (editor, parents, format, similar, vars) { var isMatchingNode = function (node) { var matchingFormat = editor.formatter.matchNode( node, format, vars !== null && vars !== void 0 ? vars : {}, similar ) return !isUndefined(matchingFormat) } var isUnableToMatch = function (node) { if (matchesUnInheritedFormatSelector(editor, node, format)) { return true } else { if (!similar) { return isNonNullable( editor.formatter.matchNode(node, format, vars, true) ) } else { return false } } } return findUntil$1(parents, isMatchingNode, isUnableToMatch) } var getParents = function (editor, elm) { var element = elm !== null && elm !== void 0 ? elm : fallbackElement(editor) return filter$4(getParents$2(editor.dom, element), function (node) { return isElement$5(node) && !isBogus$2(node) }) } var updateAndFireChangeCallbacks = function ( editor, elm, registeredCallbacks ) { var parents = getParents(editor, elm) each$j(registeredCallbacks, function (data, format) { var runIfChanged = function (spec) { var match = matchingNode( editor, parents, format, spec.similar, hasVars(spec) ? spec.vars : undefined ) var isSet = match.isSome() if (spec.state.get() !== isSet) { spec.state.set(isSet) var node_1 = match.getOr(elm) if (hasVars(spec)) { spec.callback(isSet, { node: node_1, format: format, parents: parents, }) } else { each$k(spec.callbacks, function (callback) { return callback(isSet, { node: node_1, format: format, parents: parents, }) }) } } } each$k([data.withSimilar, data.withoutSimilar], runIfChanged) each$k(data.withVars, runIfChanged) }) } var addListeners = function ( editor, registeredFormatListeners, formats, callback, similar, vars ) { var formatChangeItems = registeredFormatListeners.get() each$k(formats.split(','), function (format) { var group = get$9(formatChangeItems, format).getOrThunk(function () { var base = { withSimilar: { state: Cell(false), similar: true, callbacks: [], }, withoutSimilar: { state: Cell(false), similar: false, callbacks: [], }, withVars: [], } formatChangeItems[format] = base return base }) var getCurrent = function () { var parents = getParents(editor) return matchingNode(editor, parents, format, similar, vars).isSome() } if (isUndefined(vars)) { var toAppendTo = similar ? group.withSimilar : group.withoutSimilar toAppendTo.callbacks.push(callback) if (toAppendTo.callbacks.length === 1) { toAppendTo.state.set(getCurrent()) } } else { group.withVars.push({ state: Cell(getCurrent()), similar: similar, vars: vars, callback: callback, }) } }) registeredFormatListeners.set(formatChangeItems) } var removeListeners = function ( registeredFormatListeners, formats, callback ) { var formatChangeItems = registeredFormatListeners.get() each$k(formats.split(','), function (format) { return get$9(formatChangeItems, format).each(function (group) { formatChangeItems[format] = { withSimilar: __assign(__assign({}, group.withSimilar), { callbacks: filter$4(group.withSimilar.callbacks, function (cb) { return cb !== callback }), }), withoutSimilar: __assign(__assign({}, group.withoutSimilar), { callbacks: filter$4(group.withoutSimilar.callbacks, function (cb) { return cb !== callback }), }), withVars: filter$4(group.withVars, function (item) { return item.callback !== callback }), } }) }) registeredFormatListeners.set(formatChangeItems) } var formatChangedInternal = function ( editor, registeredFormatListeners, formats, callback, similar, vars ) { if (registeredFormatListeners.get() === null) { setup$j(registeredFormatListeners, editor) } addListeners( editor, registeredFormatListeners, formats, callback, similar, vars ) return { unbind: function () { return removeListeners(registeredFormatListeners, formats, callback) }, } } var toggle = function (editor, name, vars, node) { var fmt = editor.formatter.get(name) if ( match$2(editor, name, vars, node) && (!('toggle' in fmt[0]) || fmt[0].toggle) ) { remove$1(editor, name, vars, node) } else { applyFormat$1(editor, name, vars, node) } } var fromElements = function (elements, scope) { var doc = scope || document var fragment = doc.createDocumentFragment() each$k(elements, function (element) { fragment.appendChild(element.dom) }) return SugarElement.fromDom(fragment) } var tableModel = function (element, width, rows) { return { element: element, width: width, rows: rows, } } var tableRow = function (element, cells) { return { element: element, cells: cells, } } var cellPosition = function (x, y) { return { x: x, y: y, } } var getSpan = function (td, key) { var value = parseInt(get$6(td, key), 10) return isNaN(value) ? 1 : value } var fillout = function (table, x, y, tr, td) { var rowspan = getSpan(td, 'rowspan') var colspan = getSpan(td, 'colspan') var rows = table.rows for (var y2 = y; y2 < y + rowspan; y2++) { if (!rows[y2]) { rows[y2] = tableRow(deep$1(tr), []) } for (var x2 = x; x2 < x + colspan; x2++) { var cells = rows[y2].cells cells[x2] = y2 === y && x2 === x ? td : shallow(td) } } } var cellExists = function (table, x, y) { var rows = table.rows var cells = rows[y] ? rows[y].cells : [] return !!cells[x] } var skipCellsX = function (table, x, y) { while (cellExists(table, x, y)) { x++ } return x } var getWidth = function (rows) { return foldl( rows, function (acc, row) { return row.cells.length > acc ? row.cells.length : acc }, 0 ) } var findElementPos = function (table, element) { var rows = table.rows for (var y = 0; y < rows.length; y++) { var cells = rows[y].cells for (var x = 0; x < cells.length; x++) { if (eq(cells[x], element)) { return Optional.some(cellPosition(x, y)) } } } return Optional.none() } var extractRows = function (table, sx, sy, ex, ey) { var newRows = [] var rows = table.rows for (var y = sy; y <= ey; y++) { var cells = rows[y].cells var slice = sx < ex ? cells.slice(sx, ex + 1) : cells.slice(ex, sx + 1) newRows.push(tableRow(rows[y].element, slice)) } return newRows } var subTable = function (table, startPos, endPos) { var sx = startPos.x, sy = startPos.y var ex = endPos.x, ey = endPos.y var newRows = sy < ey ? extractRows(table, sx, sy, ex, ey) : extractRows(table, sx, ey, ex, sy) return tableModel(table.element, getWidth(newRows), newRows) } var createDomTable = function (table, rows) { var tableElement = shallow(table.element) var tableBody = SugarElement.fromTag('tbody') append(tableBody, rows) append$1(tableElement, tableBody) return tableElement } var modelRowsToDomRows = function (table) { return map$3(table.rows, function (row) { var cells = map$3(row.cells, function (cell) { var td = deep$1(cell) remove$6(td, 'colspan') remove$6(td, 'rowspan') return td }) var tr = shallow(row.element) append(tr, cells) return tr }) } var fromDom = function (tableElm) { var table = tableModel(shallow(tableElm), 0, []) each$k(descendants(tableElm, 'tr'), function (tr, y) { each$k(descendants(tr, 'td,th'), function (td, x) { fillout(table, skipCellsX(table, x, y), y, tr, td) }) }) return tableModel(table.element, getWidth(table.rows), table.rows) } var toDom = function (table) { return createDomTable(table, modelRowsToDomRows(table)) } var subsection = function (table, startElement, endElement) { return findElementPos(table, startElement).bind(function (startPos) { return findElementPos(table, endElement).map(function (endPos) { return subTable(table, startPos, endPos) }) }) } var findParentListContainer = function (parents) { return find$3(parents, function (elm) { return name(elm) === 'ul' || name(elm) === 'ol' }) } var getFullySelectedListWrappers = function (parents, rng) { return find$3(parents, function (elm) { return name(elm) === 'li' && hasAllContentsSelected(elm, rng) }).fold(constant([]), function (_li) { return findParentListContainer(parents) .map(function (listCont) { var listElm = SugarElement.fromTag(name(listCont)) var listStyles = filter$3( getAllRaw(listCont), function (_style, name) { return startsWith(name, 'list-style') } ) setAll(listElm, listStyles) return [SugarElement.fromTag('li'), listElm] }) .getOr([]) }) } var wrap = function (innerElm, elms) { var wrapped = foldl( elms, function (acc, elm) { append$1(elm, acc) return elm }, innerElm ) return elms.length > 0 ? fromElements([wrapped]) : wrapped } var directListWrappers = function (commonAnchorContainer) { if (isListItem(commonAnchorContainer)) { return parent(commonAnchorContainer) .filter(isList) .fold(constant([]), function (listElm) { return [commonAnchorContainer, listElm] }) } else { return isList(commonAnchorContainer) ? [commonAnchorContainer] : [] } } var getWrapElements = function (rootNode, rng) { var commonAnchorContainer = SugarElement.fromDom( rng.commonAncestorContainer ) var parents = parentsAndSelf(commonAnchorContainer, rootNode) var wrapElements = filter$4(parents, function (elm) { return isInline$1(elm) || isHeading(elm) }) var listWrappers = getFullySelectedListWrappers(parents, rng) var allWrappers = wrapElements.concat( listWrappers.length ? listWrappers : directListWrappers(commonAnchorContainer) ) return map$3(allWrappers, shallow) } var emptyFragment = function () { return fromElements([]) } var getFragmentFromRange = function (rootNode, rng) { return wrap( SugarElement.fromDom(rng.cloneContents()), getWrapElements(rootNode, rng) ) } var getParentTable = function (rootElm, cell) { return ancestor$2(cell, 'table', curry(eq, rootElm)) } var getTableFragment = function (rootNode, selectedTableCells) { return getParentTable(rootNode, selectedTableCells[0]) .bind(function (tableElm) { var firstCell = selectedTableCells[0] var lastCell = selectedTableCells[selectedTableCells.length - 1] var fullTableModel = fromDom(tableElm) return subsection(fullTableModel, firstCell, lastCell).map(function ( sectionedTableModel ) { return fromElements([toDom(sectionedTableModel)]) }) }) .getOrThunk(emptyFragment) } var getSelectionFragment = function (rootNode, ranges) { return ranges.length > 0 && ranges[0].collapsed ? emptyFragment() : getFragmentFromRange(rootNode, ranges[0]) } var read$3 = function (rootNode, ranges) { var selectedCells = getCellsFromElementOrRanges(ranges, rootNode) return selectedCells.length > 0 ? getTableFragment(rootNode, selectedCells) : getSelectionFragment(rootNode, ranges) } var trimLeadingCollapsibleText = function (text) { return text.replace(/^[ \f\n\r\t\v]+/, '') } var isCollapsibleWhitespace = function (text, index) { return index >= 0 && index < text.length && isWhiteSpace(text.charAt(index)) } var getInnerText = function (bin, shouldTrim) { var text = trim$2(bin.innerText) return shouldTrim ? trimLeadingCollapsibleText(text) : text } var getContextNodeName = function (parentBlockOpt) { return parentBlockOpt .map(function (block) { return block.nodeName }) .getOr('div') .toLowerCase() } var getTextContent = function (editor) { return Optional.from(editor.selection.getRng()) .map(function (rng) { var parentBlockOpt = Optional.from( editor.dom.getParent(rng.commonAncestorContainer, editor.dom.isBlock) ) var body = editor.getBody() var contextNodeName = getContextNodeName(parentBlockOpt) var shouldTrimSpaces = Env.browser.isIE() && contextNodeName !== 'pre' var bin = editor.dom.add( body, contextNodeName, { 'data-mce-bogus': 'all', style: 'overflow: hidden; opacity: 0;', }, rng.cloneContents() ) var text = getInnerText(bin, shouldTrimSpaces) var nonRenderedText = trim$2(bin.textContent) editor.dom.remove(bin) if ( isCollapsibleWhitespace(nonRenderedText, 0) || isCollapsibleWhitespace(nonRenderedText, nonRenderedText.length - 1) ) { var parentBlock = parentBlockOpt.getOr(body) var parentBlockText = getInnerText(parentBlock, shouldTrimSpaces) var textIndex = parentBlockText.indexOf(text) if (textIndex === -1) { return text } else { var hasProceedingSpace = isCollapsibleWhitespace( parentBlockText, textIndex - 1 ) var hasTrailingSpace = isCollapsibleWhitespace( parentBlockText, textIndex + text.length ) return ( (hasProceedingSpace ? ' ' : '') + text + (hasTrailingSpace ? ' ' : '') ) } } else { return text } }) .getOr('') } var getSerializedContent = function (editor, args) { var rng = editor.selection.getRng(), tmpElm = editor.dom.create('body') var sel = editor.selection.getSel() var ranges = processRanges(editor, getRanges(sel)) var fragment = args.contextual ? read$3(SugarElement.fromDom(editor.getBody()), ranges).dom : rng.cloneContents() if (fragment) { tmpElm.appendChild(fragment) } return editor.selection.serializer.serialize(tmpElm, args) } var setupArgs$1 = function (args, format) { return __assign(__assign({}, args), { format: format, get: true, selection: true, }) } var getSelectedContentInternal = function (editor, format, args) { if (args === void 0) { args = {} } var defaultedArgs = setupArgs$1(args, format) var updatedArgs = editor.fire('BeforeGetContent', defaultedArgs) if (updatedArgs.isDefaultPrevented()) { editor.fire('GetContent', updatedArgs) return updatedArgs.content } if (updatedArgs.format === 'text') { return getTextContent(editor) } else { updatedArgs.getInner = true var content = getSerializedContent(editor, updatedArgs) if (updatedArgs.format === 'tree') { return content } else { updatedArgs.content = editor.selection.isCollapsed() ? '' : content editor.fire('GetContent', updatedArgs) return updatedArgs.content } } } var KEEP = 0, INSERT = 1, DELETE = 2 var diff = function (left, right) { var size = left.length + right.length + 2 var vDown = new Array(size) var vUp = new Array(size) var snake = function (start, end, diag) { return { start: start, end: end, diag: diag, } } var buildScript = function (start1, end1, start2, end2, script) { var middle = getMiddleSnake(start1, end1, start2, end2) if ( middle === null || (middle.start === end1 && middle.diag === end1 - end2) || (middle.end === start1 && middle.diag === start1 - start2) ) { var i = start1 var j = start2 while (i < end1 || j < end2) { if (i < end1 && j < end2 && left[i] === right[j]) { script.push([KEEP, left[i]]) ++i ++j } else { if (end1 - start1 > end2 - start2) { script.push([DELETE, left[i]]) ++i } else { script.push([INSERT, right[j]]) ++j } } } } else { buildScript( start1, middle.start, start2, middle.start - middle.diag, script ) for (var i2 = middle.start; i2 < middle.end; ++i2) { script.push([KEEP, left[i2]]) } buildScript(middle.end, end1, middle.end - middle.diag, end2, script) } } var buildSnake = function (start, diag, end1, end2) { var end = start while ( end - diag < end2 && end < end1 && left[end] === right[end - diag] ) { ++end } return snake(start, end, diag) } var getMiddleSnake = function (start1, end1, start2, end2) { var m = end1 - start1 var n = end2 - start2 if (m === 0 || n === 0) { return null } var delta = m - n var sum = n + m var offset = (sum % 2 === 0 ? sum : sum + 1) / 2 vDown[1 + offset] = start1 vUp[1 + offset] = end1 + 1 var d, k, i, x, y for (d = 0; d <= offset; ++d) { for (k = -d; k <= d; k += 2) { i = k + offset if (k === -d || (k !== d && vDown[i - 1] < vDown[i + 1])) { vDown[i] = vDown[i + 1] } else { vDown[i] = vDown[i - 1] + 1 } x = vDown[i] y = x - start1 + start2 - k while (x < end1 && y < end2 && left[x] === right[y]) { vDown[i] = ++x ++y } if (delta % 2 !== 0 && delta - d <= k && k <= delta + d) { if (vUp[i - delta] <= vDown[i]) { return buildSnake(vUp[i - delta], k + start1 - start2, end1, end2) } } } for (k = delta - d; k <= delta + d; k += 2) { i = k + offset - delta if ( k === delta - d || (k !== delta + d && vUp[i + 1] <= vUp[i - 1]) ) { vUp[i] = vUp[i + 1] - 1 } else { vUp[i] = vUp[i - 1] } x = vUp[i] - 1 y = x - start1 + start2 - k while (x >= start1 && y >= start2 && left[x] === right[y]) { vUp[i] = x-- y-- } if (delta % 2 === 0 && -d <= k && k <= d) { if (vUp[i] <= vDown[i + delta]) { return buildSnake(vUp[i], k + start1 - start2, end1, end2) } } } } } var script = [] buildScript(0, left.length, 0, right.length, script) return script } var getOuterHtml = function (elm) { if (isElement$5(elm)) { return elm.outerHTML } else if (isText$7(elm)) { return Entities.encodeRaw(elm.data, false) } else if (isComment(elm)) { return '' } return '' } var createFragment = function (html) { var node var container = document.createElement('div') var frag = document.createDocumentFragment() if (html) { container.innerHTML = html } while ((node = container.firstChild)) { frag.appendChild(node) } return frag } var insertAt = function (elm, html, index) { var fragment = createFragment(html) if (elm.hasChildNodes() && index < elm.childNodes.length) { var target = elm.childNodes[index] target.parentNode.insertBefore(fragment, target) } else { elm.appendChild(fragment) } } var removeAt = function (elm, index) { if (elm.hasChildNodes() && index < elm.childNodes.length) { var target = elm.childNodes[index] target.parentNode.removeChild(target) } } var applyDiff = function (diff, elm) { var index = 0 each$k(diff, function (action) { if (action[0] === KEEP) { index++ } else if (action[0] === INSERT) { insertAt(elm, action[1], index) index++ } else if (action[0] === DELETE) { removeAt(elm, index) } }) } var read$2 = function (elm) { return filter$4(map$3(from(elm.childNodes), getOuterHtml), function (item) { return item.length > 0 }) } var write = function (fragments, elm) { var currentFragments = map$3(from(elm.childNodes), getOuterHtml) applyDiff(diff(currentFragments, fragments), elm) return elm } var lazyTempDocument = cached(function () { return document.implementation.createHTMLDocument('undo') }) var hasIframes = function (html) { return html.indexOf('') !== -1 } var createFragmentedLevel = function (fragments) { return { type: 'fragmented', fragments: fragments, content: '', bookmark: null, beforeBookmark: null, } } var createCompleteLevel = function (content) { return { type: 'complete', fragments: null, content: content, bookmark: null, beforeBookmark: null, } } var createFromEditor = function (editor) { var fragments = read$2(editor.getBody()) var trimmedFragments = bind(fragments, function (html) { var trimmed = trimInternal(editor.serializer, html) return trimmed.length > 0 ? [trimmed] : [] }) var content = trimmedFragments.join('') return hasIframes(content) ? createFragmentedLevel(trimmedFragments) : createCompleteLevel(content) } var applyToEditor = function (editor, level, before) { var bookmark = before ? level.beforeBookmark : level.bookmark if (level.type === 'fragmented') { write(level.fragments, editor.getBody()) } else { editor.setContent(level.content, { format: 'raw', no_selection: isNonNullable(bookmark) && isPathBookmark(bookmark) ? !bookmark.isFakeCaret : true, }) } editor.selection.moveToBookmark(bookmark) } var getLevelContent = function (level) { return level.type === 'fragmented' ? level.fragments.join('') : level.content } var getCleanLevelContent = function (level) { var elm = SugarElement.fromTag('body', lazyTempDocument()) set(elm, getLevelContent(level)) each$k(descendants(elm, '*[data-mce-bogus]'), unwrap) return get$3(elm) } var hasEqualContent = function (level1, level2) { return getLevelContent(level1) === getLevelContent(level2) } var hasEqualCleanedContent = function (level1, level2) { return getCleanLevelContent(level1) === getCleanLevelContent(level2) } var isEq$1 = function (level1, level2) { if (!level1 || !level2) { return false } else if (hasEqualContent(level1, level2)) { return true } else { return hasEqualCleanedContent(level1, level2) } } var isUnlocked = function (locks) { return locks.get() === 0 } var setTyping = function (undoManager, typing, locks) { if (isUnlocked(locks)) { undoManager.typing = typing } } var endTyping = function (undoManager, locks) { if (undoManager.typing) { setTyping(undoManager, false, locks) undoManager.add() } } var endTypingLevelIgnoreLocks = function (undoManager) { if (undoManager.typing) { undoManager.typing = false undoManager.add() } } var beforeChange$1 = function (editor, locks, beforeBookmark) { if (isUnlocked(locks)) { beforeBookmark.set(getUndoBookmark(editor.selection)) } } var addUndoLevel$1 = function ( editor, undoManager, index, locks, beforeBookmark, level, event ) { var currentLevel = createFromEditor(editor) level = level || {} level = Tools.extend(level, currentLevel) if (isUnlocked(locks) === false || editor.removed) { return null } var lastLevel = undoManager.data[index.get()] if ( editor .fire('BeforeAddUndo', { level: level, lastLevel: lastLevel, originalEvent: event, }) .isDefaultPrevented() ) { return null } if (lastLevel && isEq$1(lastLevel, level)) { return null } if (undoManager.data[index.get()]) { beforeBookmark.get().each(function (bm) { undoManager.data[index.get()].beforeBookmark = bm }) } var customUndoRedoLevels = getCustomUndoRedoLevels(editor) if (customUndoRedoLevels) { if (undoManager.data.length > customUndoRedoLevels) { for (var i = 0; i < undoManager.data.length - 1; i++) { undoManager.data[i] = undoManager.data[i + 1] } undoManager.data.length-- index.set(undoManager.data.length) } } level.bookmark = getUndoBookmark(editor.selection) if (index.get() < undoManager.data.length - 1) { undoManager.data.length = index.get() + 1 } undoManager.data.push(level) index.set(undoManager.data.length - 1) var args = { level: level, lastLevel: lastLevel, originalEvent: event, } if (index.get() > 0) { editor.setDirty(true) editor.fire('AddUndo', args) editor.fire('change', args) } else { editor.fire('AddUndo', args) } return level } var clear$1 = function (editor, undoManager, index) { undoManager.data = [] index.set(0) undoManager.typing = false editor.fire('ClearUndos') } var extra$1 = function (editor, undoManager, index, callback1, callback2) { if (undoManager.transact(callback1)) { var bookmark = undoManager.data[index.get()].bookmark var lastLevel = undoManager.data[index.get() - 1] applyToEditor(editor, lastLevel, true) if (undoManager.transact(callback2)) { undoManager.data[index.get() - 1].beforeBookmark = bookmark } } } var redo$1 = function (editor, index, data) { var level if (index.get() < data.length - 1) { index.set(index.get() + 1) level = data[index.get()] applyToEditor(editor, level, false) editor.setDirty(true) editor.fire('Redo', { level: level }) } return level } var undo$1 = function (editor, undoManager, locks, index) { var level if (undoManager.typing) { undoManager.add() undoManager.typing = false setTyping(undoManager, false, locks) } if (index.get() > 0) { index.set(index.get() - 1) level = undoManager.data[index.get()] applyToEditor(editor, level, true) editor.setDirty(true) editor.fire('Undo', { level: level }) } return level } var reset$1 = function (undoManager) { undoManager.clear() undoManager.add() } var hasUndo$1 = function (editor, undoManager, index) { return ( index.get() > 0 || (undoManager.typing && undoManager.data[0] && !isEq$1(createFromEditor(editor), undoManager.data[0])) ) } var hasRedo$1 = function (undoManager, index) { return index.get() < undoManager.data.length - 1 && !undoManager.typing } var transact$1 = function (undoManager, locks, callback) { endTyping(undoManager, locks) undoManager.beforeChange() undoManager.ignore(callback) return undoManager.add() } var ignore$1 = function (locks, callback) { try { locks.set(locks.get() + 1) callback() } finally { locks.set(locks.get() - 1) } } var addVisualInternal = function (editor, elm) { var dom = editor.dom var scope = isNonNullable(elm) ? elm : editor.getBody() if (isUndefined(editor.hasVisual)) { editor.hasVisual = isVisualAidsEnabled(editor) } each$k(dom.select('table,a', scope), function (matchedElm) { switch (matchedElm.nodeName) { case 'TABLE': var cls = getVisualAidsTableClass(editor) var value = dom.getAttrib(matchedElm, 'border') if ((!value || value === '0') && editor.hasVisual) { dom.addClass(matchedElm, cls) } else { dom.removeClass(matchedElm, cls) } break case 'A': if (!dom.getAttrib(matchedElm, 'href')) { var value_1 = dom.getAttrib(matchedElm, 'name') || matchedElm.id var cls_1 = getVisualAidsAnchorClass(editor) if (value_1 && editor.hasVisual) { dom.addClass(matchedElm, cls_1) } else { dom.removeClass(matchedElm, cls_1) } } break } }) editor.fire('VisualAid', { element: elm, hasVisual: editor.hasVisual, }) } var makePlainAdaptor = function (editor) { return { undoManager: { beforeChange: function (locks, beforeBookmark) { return beforeChange$1(editor, locks, beforeBookmark) }, add: function ( undoManager, index, locks, beforeBookmark, level, event ) { return addUndoLevel$1( editor, undoManager, index, locks, beforeBookmark, level, event ) }, undo: function (undoManager, locks, index) { return undo$1(editor, undoManager, locks, index) }, redo: function (index, data) { return redo$1(editor, index, data) }, clear: function (undoManager, index) { return clear$1(editor, undoManager, index) }, reset: function (undoManager) { return reset$1(undoManager) }, hasUndo: function (undoManager, index) { return hasUndo$1(editor, undoManager, index) }, hasRedo: function (undoManager, index) { return hasRedo$1(undoManager, index) }, transact: function (undoManager, locks, callback) { return transact$1(undoManager, locks, callback) }, ignore: function (locks, callback) { return ignore$1(locks, callback) }, extra: function (undoManager, index, callback1, callback2) { return extra$1(editor, undoManager, index, callback1, callback2) }, }, formatter: { match: function (name, vars, node, similar) { return match$2(editor, name, vars, node, similar) }, matchAll: function (names, vars) { return matchAll(editor, names, vars) }, matchNode: function (node, name, vars, similar) { return matchNode(editor, node, name, vars, similar) }, canApply: function (name) { return canApply(editor, name) }, closest: function (names) { return closest(editor, names) }, apply: function (name, vars, node) { return applyFormat$1(editor, name, vars, node) }, remove: function (name, vars, node, similar) { return remove$1(editor, name, vars, node, similar) }, toggle: function (name, vars, node) { return toggle(editor, name, vars, node) }, formatChanged: function ( registeredFormatListeners, formats, callback, similar, vars ) { return formatChangedInternal( editor, registeredFormatListeners, formats, callback, similar, vars ) }, }, editor: { getContent: function (args, format) { return getContentInternal(editor, args, format) }, setContent: function (content, args) { return setContentInternal(editor, content, args) }, insertContent: function (value, details) { return insertHtmlAtCaret(editor, value, details) }, addVisual: function (elm) { return addVisualInternal(editor, elm) }, }, selection: { getContent: function (format, args) { return getSelectedContentInternal(editor, format, args) }, }, raw: { getModel: function () { return Optional.none() }, }, } } var makeRtcAdaptor = function (rtcEditor) { var defaultVars = function (vars) { return isObject(vars) ? vars : {} } var undoManager = rtcEditor.undoManager, formatter = rtcEditor.formatter, editor = rtcEditor.editor, selection = rtcEditor.selection, raw = rtcEditor.raw return { undoManager: { beforeChange: undoManager.beforeChange, add: undoManager.add, undo: undoManager.undo, redo: undoManager.redo, clear: undoManager.clear, reset: undoManager.reset, hasUndo: undoManager.hasUndo, hasRedo: undoManager.hasRedo, transact: function (_undoManager, _locks, fn) { return undoManager.transact(fn) }, ignore: function (_locks, callback) { return undoManager.ignore(callback) }, extra: function (_undoManager, _index, callback1, callback2) { return undoManager.extra(callback1, callback2) }, }, formatter: { match: function (name, vars, _node, similar) { return formatter.match(name, defaultVars(vars), similar) }, matchAll: formatter.matchAll, matchNode: formatter.matchNode, canApply: function (name) { return formatter.canApply(name) }, closest: function (names) { return formatter.closest(names) }, apply: function (name, vars, _node) { return formatter.apply(name, defaultVars(vars)) }, remove: function (name, vars, _node, _similar) { return formatter.remove(name, defaultVars(vars)) }, toggle: function (name, vars, _node) { return formatter.toggle(name, defaultVars(vars)) }, formatChanged: function (_rfl, formats, callback, similar, vars) { return formatter.formatChanged(formats, callback, similar, vars) }, }, editor: { getContent: function (args, _format) { return editor.getContent(args) }, setContent: function (content, args) { console.log(content, 'contentcontentcontentcontentcontent-----') return editor.setContent(content, args) }, insertContent: function (content, _details) { return editor.insertContent(content) }, addVisual: editor.addVisual, }, selection: { getContent: function (_format, args) { return selection.getContent(args) }, }, raw: { getModel: function () { return Optional.some(raw.getRawModel()) }, }, } } var makeNoopAdaptor = function () { var nul = constant(null) var empty = constant('') return { undoManager: { beforeChange: noop, add: nul, undo: nul, redo: nul, clear: noop, reset: noop, hasUndo: never, hasRedo: never, transact: nul, ignore: noop, extra: noop, }, formatter: { match: never, matchAll: constant([]), matchNode: constant(undefined), canApply: never, closest: empty, apply: noop, remove: noop, toggle: noop, formatChanged: constant({ unbind: noop }), }, editor: { getContent: empty, setContent: empty, insertContent: noop, addVisual: noop, }, selection: { getContent: empty }, raw: { getModel: constant(Optional.none()) }, } } var isRtc = function (editor) { return has$2(editor.plugins, 'rtc') } var getRtcSetup = function (editor) { return get$9(editor.plugins, 'rtc').bind(function (rtcPlugin) { return Optional.from(rtcPlugin.setup) }) } var setup$i = function (editor) { var editorCast = editor return getRtcSetup(editor).fold( function () { editorCast.rtcInstance = makePlainAdaptor(editor) return Optional.none() }, function (setup) { editorCast.rtcInstance = makeNoopAdaptor() return Optional.some(function () { return setup().then(function (rtcEditor) { editorCast.rtcInstance = makeRtcAdaptor(rtcEditor) return rtcEditor.rtc.isRemote }) }) } ) } var getRtcInstanceWithFallback = function (editor) { return editor.rtcInstance ? editor.rtcInstance : makePlainAdaptor(editor) } var getRtcInstanceWithError = function (editor) { var rtcInstance = editor.rtcInstance if (!rtcInstance) { throw new Error('Failed to get RTC instance not yet initialized.') } else { return rtcInstance } } var beforeChange = function (editor, locks, beforeBookmark) { getRtcInstanceWithError(editor).undoManager.beforeChange( locks, beforeBookmark ) } var addUndoLevel = function ( editor, undoManager, index, locks, beforeBookmark, level, event ) { return getRtcInstanceWithError(editor).undoManager.add( undoManager, index, locks, beforeBookmark, level, event ) } var undo = function (editor, undoManager, locks, index) { return getRtcInstanceWithError(editor).undoManager.undo( undoManager, locks, index ) } var redo = function (editor, index, data) { return getRtcInstanceWithError(editor).undoManager.redo(index, data) } var clear = function (editor, undoManager, index) { getRtcInstanceWithError(editor).undoManager.clear(undoManager, index) } var reset = function (editor, undoManager) { getRtcInstanceWithError(editor).undoManager.reset(undoManager) } var hasUndo = function (editor, undoManager, index) { return getRtcInstanceWithError(editor).undoManager.hasUndo( undoManager, index ) } var hasRedo = function (editor, undoManager, index) { return getRtcInstanceWithError(editor).undoManager.hasRedo( undoManager, index ) } var transact = function (editor, undoManager, locks, callback) { return getRtcInstanceWithError(editor).undoManager.transact( undoManager, locks, callback ) } var ignore = function (editor, locks, callback) { getRtcInstanceWithError(editor).undoManager.ignore(locks, callback) } var extra = function (editor, undoManager, index, callback1, callback2) { getRtcInstanceWithError(editor).undoManager.extra( undoManager, index, callback1, callback2 ) } var matchFormat = function (editor, name, vars, node, similar) { return getRtcInstanceWithError(editor).formatter.match( name, vars, node, similar ) } var matchAllFormats = function (editor, names, vars) { return getRtcInstanceWithError(editor).formatter.matchAll(names, vars) } var matchNodeFormat = function (editor, node, name, vars, similar) { return getRtcInstanceWithError(editor).formatter.matchNode( node, name, vars, similar ) } var canApplyFormat = function (editor, name) { return getRtcInstanceWithError(editor).formatter.canApply(name) } var closestFormat = function (editor, names) { return getRtcInstanceWithError(editor).formatter.closest(names) } var applyFormat = function (editor, name, vars, node) { getRtcInstanceWithError(editor).formatter.apply(name, vars, node) } var removeFormat = function (editor, name, vars, node, similar) { getRtcInstanceWithError(editor).formatter.remove(name, vars, node, similar) } var toggleFormat = function (editor, name, vars, node) { getRtcInstanceWithError(editor).formatter.toggle(name, vars, node) } var formatChanged = function ( editor, registeredFormatListeners, formats, callback, similar, vars ) { return getRtcInstanceWithError(editor).formatter.formatChanged( registeredFormatListeners, formats, callback, similar, vars ) } var getContent$2 = function (editor, args, format) { return getRtcInstanceWithFallback(editor).editor.getContent(args, format) } var setContent$2 = function (editor, content, args) { return getRtcInstanceWithFallback(editor).editor.setContent(content, args) } var insertContent = function (editor, value, details) { return getRtcInstanceWithFallback(editor).editor.insertContent( value, details ) } var getSelectedContent = function (editor, format, args) { return getRtcInstanceWithError(editor).selection.getContent(format, args) } var addVisual$1 = function (editor, elm) { return getRtcInstanceWithError(editor).editor.addVisual(elm) } var getContent$1 = function (editor, args) { if (args === void 0) { args = {} } var format = args.format ? args.format : 'html' return getSelectedContent(editor, format, args) } var removeEmpty = function (text) { if (text.dom.length === 0) { remove$7(text) return Optional.none() } else { return Optional.some(text) } } var walkPastBookmark = function (node, start) { return node .filter(function (elm) { return BookmarkManager.isBookmarkNode(elm.dom) }) .bind(start ? nextSibling : prevSibling) } var merge = function (outer, inner, rng, start) { var outerElm = outer.dom var innerElm = inner.dom var oldLength = start ? outerElm.length : innerElm.length if (start) { mergeTextNodes(outerElm, innerElm, false, !start) rng.setStart(innerElm, oldLength) } else { mergeTextNodes(innerElm, outerElm, false, !start) rng.setEnd(innerElm, oldLength) } } var normalizeTextIfRequired = function (inner, start) { parent(inner).each(function (root) { var text = inner.dom if (start && needsToBeNbspLeft(root, CaretPosition(text, 0))) { normalizeWhitespaceAfter(text, 0) } else if ( !start && needsToBeNbspRight(root, CaretPosition(text, text.length)) ) { normalizeWhitespaceBefore(text, text.length) } }) } var mergeAndNormalizeText = function (outerNode, innerNode, rng, start) { outerNode .bind(function (outer) { var normalizer = start ? normalizeWhitespaceBefore : normalizeWhitespaceAfter normalizer(outer.dom, start ? outer.dom.length : 0) return innerNode.filter(isText$8).map(function (inner) { return merge(outer, inner, rng, start) }) }) .orThunk(function () { var innerTextNode = walkPastBookmark(innerNode, start) .or(innerNode) .filter(isText$8) return innerTextNode.map(function (inner) { return normalizeTextIfRequired(inner, start) }) }) } var rngSetContent = function (rng, fragment) { var firstChild = Optional.from(fragment.firstChild).map( SugarElement.fromDom ) var lastChild = Optional.from(fragment.lastChild).map(SugarElement.fromDom) rng.deleteContents() rng.insertNode(fragment) var prevText = firstChild .bind(prevSibling) .filter(isText$8) .bind(removeEmpty) var nextText = lastChild .bind(nextSibling) .filter(isText$8) .bind(removeEmpty) mergeAndNormalizeText(prevText, firstChild, rng, true) mergeAndNormalizeText(nextText, lastChild, rng, false) rng.collapse(false) } var setupArgs = function (args, content) { return __assign(__assign({ format: 'html' }, args), { set: true, selection: true, content: content, }) } var cleanContent = function (editor, args) { if (args.format !== 'raw') { var rng = editor.selection.getRng() var contextBlock = editor.dom.getParent( rng.commonAncestorContainer, editor.dom.isBlock ) var contextArgs = contextBlock ? { context: contextBlock.nodeName.toLowerCase() } : {} var node = editor.parser.parse( args.content, __assign( __assign( { isRootContent: true, forced_root_block: false, }, contextArgs ), args ) ) return HtmlSerializer( { validate: editor.validate }, editor.schema ).serialize(node) } else { return args.content } } var setContent$1 = function (editor, content, args) { if (args === void 0) { args = {} } var defaultedArgs = setupArgs(args, content) var updatedArgs = defaultedArgs if (!defaultedArgs.no_events) { var eventArgs = editor.fire('BeforeSetContent', defaultedArgs) if (eventArgs.isDefaultPrevented()) { editor.fire('SetContent', eventArgs) return } else { updatedArgs = eventArgs } } updatedArgs.content = cleanContent(editor, updatedArgs) var rng = editor.selection.getRng() rngSetContent(rng, rng.createContextualFragment(updatedArgs.content)) editor.selection.setRng(rng) scrollRangeIntoView(editor, rng) if (!updatedArgs.no_events) { editor.fire('SetContent', updatedArgs) } } var deleteFromCallbackMap = function (callbackMap, selector, callback) { if (callbackMap && has$2(callbackMap, selector)) { var newCallbacks = filter$4(callbackMap[selector], function (cb) { return cb !== callback }) if (newCallbacks.length === 0) { delete callbackMap[selector] } else { callbackMap[selector] = newCallbacks } } } function SelectorChanged(dom, editor) { var selectorChangedData var currentSelectors var findMatchingNode = function (selector, nodes) { return find$3(nodes, function (node) { return dom.is(node, selector) }) } var getParents = function (elem) { return dom.getParents(elem, null, dom.getRoot()) } return { selectorChangedWithUnbind: function (selector, callback) { if (!selectorChangedData) { selectorChangedData = {} currentSelectors = {} editor.on('NodeChange', function (e) { var node = e.element var parents = getParents(node) var matchedSelectors = {} Tools.each(selectorChangedData, function (callbacks, selector) { findMatchingNode(selector, parents).each(function (node) { if (!currentSelectors[selector]) { each$k(callbacks, function (callback) { callback(true, { node: node, selector: selector, parents: parents, }) }) currentSelectors[selector] = callbacks } matchedSelectors[selector] = callbacks }) }) Tools.each(currentSelectors, function (callbacks, selector) { if (!matchedSelectors[selector]) { delete currentSelectors[selector] Tools.each(callbacks, function (callback) { callback(false, { node: node, selector: selector, parents: parents, }) }) } }) }) } if (!selectorChangedData[selector]) { selectorChangedData[selector] = [] } selectorChangedData[selector].push(callback) findMatchingNode( selector, getParents(editor.selection.getStart()) ).each(function () { currentSelectors[selector] = selectorChangedData[selector] }) return { unbind: function () { deleteFromCallbackMap(selectorChangedData, selector, callback) deleteFromCallbackMap(currentSelectors, selector, callback) }, } }, } } var isNativeIeSelection = function (rng) { return !!rng.select } var isAttachedToDom = function (node) { return ( !!(node && node.ownerDocument) && contains$1( SugarElement.fromDom(node.ownerDocument), SugarElement.fromDom(node) ) ) } var isValidRange = function (rng) { if (!rng) { return false } else if (isNativeIeSelection(rng)) { return true } else { return ( isAttachedToDom(rng.startContainer) && isAttachedToDom(rng.endContainer) ) } } var EditorSelection = function (dom, win, serializer, editor) { var selectedRange var explicitRange var selectorChangedWithUnbind = SelectorChanged( dom, editor ).selectorChangedWithUnbind var setCursorLocation = function (node, offset) { var rng = dom.createRng() if (isNonNullable(node) && isNonNullable(offset)) { rng.setStart(node, offset) rng.setEnd(node, offset) setRng(rng) collapse(false) } else { moveEndPoint(dom, rng, editor.getBody(), true) setRng(rng) } } var getContent = function (args) { return getContent$1(editor, args) } var setContent = function (content, args) { return setContent$1(editor, content, args) } var getStart$1 = function (real) { return getStart(editor.getBody(), getRng$1(), real) } var getEnd$1 = function (real) { return getEnd(editor.getBody(), getRng$1(), real) } var getBookmark = function (type, normalized) { return bookmarkManager.getBookmark(type, normalized) } var moveToBookmark = function (bookmark) { return bookmarkManager.moveToBookmark(bookmark) } var select$1 = function (node, content) { select(dom, node, content).each(setRng) return node } var isCollapsed = function () { var rng = getRng$1(), sel = getSel() if (!rng || rng.item) { return false } if (rng.compareEndPoints) { return rng.compareEndPoints('StartToEnd', rng) === 0 } return !sel || rng.collapsed } var collapse = function (toStart) { var rng = getRng$1() rng.collapse(!!toStart) setRng(rng) } var getSel = function () { return win.getSelection ? win.getSelection() : win.document.selection } var getRng$1 = function () { var selection, rng, elm var tryCompareBoundaryPoints = function ( how, sourceRange, destinationRange ) { try { return sourceRange.compareBoundaryPoints(how, destinationRange) } catch (ex) { return -1 } } var doc = win.document if (editor.bookmark !== undefined && hasFocus(editor) === false) { var bookmark = getRng(editor) if (bookmark.isSome()) { return bookmark .map(function (r) { return processRanges(editor, [r])[0] }) .getOr(doc.createRange()) } } try { if ((selection = getSel()) && !isRestrictedNode(selection.anchorNode)) { if (selection.rangeCount > 0) { rng = selection.getRangeAt(0) } else { rng = selection.createRange ? selection.createRange() : doc.createRange() } rng = processRanges(editor, [rng])[0] } } catch (ex) {} if (!rng) { rng = doc.createRange ? doc.createRange() : doc.body.createTextRange() } if (rng.setStart && rng.startContainer.nodeType === 9 && rng.collapsed) { elm = dom.getRoot() rng.setStart(elm, 0) rng.setEnd(elm, 0) } if (selectedRange && explicitRange) { if ( tryCompareBoundaryPoints(rng.START_TO_START, rng, selectedRange) === 0 && tryCompareBoundaryPoints(rng.END_TO_END, rng, selectedRange) === 0 ) { rng = explicitRange } else { selectedRange = null explicitRange = null } } return rng } var setRng = function (rng, forward) { var node if (!isValidRange(rng)) { return } var ieRange = isNativeIeSelection(rng) ? rng : null if (ieRange) { explicitRange = null try { ieRange.select() } catch (ex) {} return } var sel = getSel() var evt = editor.fire('SetSelectionRange', { range: rng, forward: forward, }) rng = evt.range if (sel) { explicitRange = rng try { sel.removeAllRanges() sel.addRange(rng) } catch (ex) {} if (forward === false && sel.extend) { sel.collapse(rng.endContainer, rng.endOffset) sel.extend(rng.startContainer, rng.startOffset) } selectedRange = sel.rangeCount > 0 ? sel.getRangeAt(0) : null } if ( !rng.collapsed && rng.startContainer === rng.endContainer && sel.setBaseAndExtent && !Env.ie ) { if (rng.endOffset - rng.startOffset < 2) { if (rng.startContainer.hasChildNodes()) { node = rng.startContainer.childNodes[rng.startOffset] if (node && node.tagName === 'IMG') { sel.setBaseAndExtent( rng.startContainer, rng.startOffset, rng.endContainer, rng.endOffset ) if ( sel.anchorNode !== rng.startContainer || sel.focusNode !== rng.endContainer ) { sel.setBaseAndExtent(node, 0, node, 1) } } } } } editor.fire('AfterSetSelectionRange', { range: rng, forward: forward, }) } var setNode = function (elm) { setContent(dom.getOuterHTML(elm)) return elm } var getNode$1 = function () { return getNode(editor.getBody(), getRng$1()) } var getSelectedBlocks$1 = function (startElm, endElm) { return getSelectedBlocks(dom, getRng$1(), startElm, endElm) } var isForward = function () { var sel = getSel() var anchorNode = sel === null || sel === void 0 ? void 0 : sel.anchorNode var focusNode = sel === null || sel === void 0 ? void 0 : sel.focusNode if ( !sel || !anchorNode || !focusNode || isRestrictedNode(anchorNode) || isRestrictedNode(focusNode) ) { return true } var anchorRange = dom.createRng() anchorRange.setStart(anchorNode, sel.anchorOffset) anchorRange.collapse(true) var focusRange = dom.createRng() focusRange.setStart(focusNode, sel.focusOffset) focusRange.collapse(true) return ( anchorRange.compareBoundaryPoints( anchorRange.START_TO_START, focusRange ) <= 0 ) } var normalize = function () { var rng = getRng$1() var sel = getSel() if (!hasMultipleRanges(sel) && hasAnyRanges(editor)) { var normRng = normalize$2(dom, rng) normRng.each(function (normRng) { setRng(normRng, isForward()) }) return normRng.getOr(rng) } return rng } var selectorChanged = function (selector, callback) { selectorChangedWithUnbind(selector, callback) return exports } var getScrollContainer = function () { var scrollContainer var node = dom.getRoot() while (node && node.nodeName !== 'BODY') { if (node.scrollHeight > node.clientHeight) { scrollContainer = node break } node = node.parentNode } return scrollContainer } var scrollIntoView = function (elm, alignToTop) { if (isNonNullable(elm)) { scrollElementIntoView(editor, elm, alignToTop) } else { scrollRangeIntoView(editor, getRng$1(), alignToTop) } } var placeCaretAt = function (clientX, clientY) { return setRng(fromPoint(clientX, clientY, editor.getDoc())) } var getBoundingClientRect = function () { var rng = getRng$1() return rng.collapsed ? CaretPosition.fromRangeStart(rng).getClientRects()[0] : rng.getBoundingClientRect() } var destroy = function () { win = selectedRange = explicitRange = null controlSelection.destroy() } var exports = { bookmarkManager: null, controlSelection: null, dom: dom, win: win, serializer: serializer, editor: editor, collapse: collapse, setCursorLocation: setCursorLocation, getContent: getContent, setContent: setContent, getBookmark: getBookmark, moveToBookmark: moveToBookmark, select: select$1, isCollapsed: isCollapsed, isForward: isForward, setNode: setNode, getNode: getNode$1, getSel: getSel, setRng: setRng, getRng: getRng$1, getStart: getStart$1, getEnd: getEnd$1, getSelectedBlocks: getSelectedBlocks$1, normalize: normalize, selectorChanged: selectorChanged, selectorChangedWithUnbind: selectorChangedWithUnbind, getScrollContainer: getScrollContainer, scrollIntoView: scrollIntoView, placeCaretAt: placeCaretAt, getBoundingClientRect: getBoundingClientRect, destroy: destroy, } var bookmarkManager = BookmarkManager(exports) var controlSelection = ControlSelection(exports, editor) exports.bookmarkManager = bookmarkManager exports.controlSelection = controlSelection return exports } var removeAttrs = function (node, names) { each$k(names, function (name) { node.attr(name, null) }) } var addFontToSpansFilter = function (domParser, styles, fontSizes) { domParser.addNodeFilter('font', function (nodes) { each$k(nodes, function (node) { var props = styles.parse(node.attr('style')) var color = node.attr('color') var face = node.attr('face') var size = node.attr('size') if (color) { props.color = color } if (face) { props['font-family'] = face } if (size) { props['font-size'] = fontSizes[parseInt(node.attr('size'), 10) - 1] } node.name = 'span' node.attr('style', styles.serialize(props)) removeAttrs(node, ['color', 'face', 'size']) }) }) } var addStrikeToSpanFilter = function (domParser, styles) { domParser.addNodeFilter('strike', function (nodes) { each$k(nodes, function (node) { var props = styles.parse(node.attr('style')) props['text-decoration'] = 'line-through' node.name = 'span' node.attr('style', styles.serialize(props)) }) }) } var addFilters = function (domParser, settings) { var styles = Styles() if (settings.convert_fonts_to_spans) { addFontToSpansFilter( domParser, styles, Tools.explode(settings.font_size_legacy_values) ) } addStrikeToSpanFilter(domParser, styles) } var register$2 = function (domParser, settings) { if (settings.inline_styles) { addFilters(domParser, settings) } } var blobUriToBlob = function (url) { return new promiseObj(function (resolve, reject) { var rejectWithError = function () { reject( 'Cannot convert ' + url + ' to Blob. Resource might not exist or is inaccessible.' ) } try { var xhr_1 = new XMLHttpRequest() xhr_1.open('GET', url, true) xhr_1.responseType = 'blob' xhr_1.onload = function () { if (xhr_1.status === 200) { resolve(xhr_1.response) } else { rejectWithError() } } xhr_1.onerror = rejectWithError xhr_1.send() } catch (ex) { rejectWithError() } }) } var parseDataUri = function (uri) { var type var uriParts = decodeURIComponent(uri).split(',') var matches = /data:([^;]+)/.exec(uriParts[0]) if (matches) { type = matches[1] } return { type: type, data: uriParts[1], } } var buildBlob = function (type, data) { var str try { str = atob(data) } catch (e) { return Optional.none() } var arr = new Uint8Array(str.length) for (var i = 0; i < arr.length; i++) { arr[i] = str.charCodeAt(i) } return Optional.some(new Blob([arr], { type: type })) } var dataUriToBlob = function (uri) { return new promiseObj(function (resolve) { var _a = parseDataUri(uri), type = _a.type, data = _a.data buildBlob(type, data).fold(function () { return resolve(new Blob([])) }, resolve) }) } var uriToBlob = function (url) { if (url.indexOf('blob:') === 0) { return blobUriToBlob(url) } if (url.indexOf('data:') === 0) { return dataUriToBlob(url) } return null } var blobToDataUri = function (blob) { return new promiseObj(function (resolve) { var reader = new FileReader() reader.onloadend = function () { resolve(reader.result) } reader.readAsDataURL(blob) }) } var count$1 = 0 var uniqueId = function (prefix) { return (prefix || 'blobid') + count$1++ } var imageToBlobInfo = function (blobCache, img, resolve, reject) { var base64, blobInfo if (img.src.indexOf('blob:') === 0) { blobInfo = blobCache.getByUri(img.src) if (blobInfo) { resolve({ image: img, blobInfo: blobInfo, }) } else { uriToBlob(img.src).then( function (blob) { blobToDataUri(blob).then(function (dataUri) { base64 = parseDataUri(dataUri).data blobInfo = blobCache.create(uniqueId(), blob, base64) blobCache.add(blobInfo) resolve({ image: img, blobInfo: blobInfo, }) }) }, function (err) { reject(err) } ) } return } var _a = parseDataUri(img.src), data = _a.data, type = _a.type base64 = data blobInfo = blobCache.getByData(base64, type) if (blobInfo) { resolve({ image: img, blobInfo: blobInfo, }) } else { uriToBlob(img.src).then( function (blob) { blobInfo = blobCache.create(uniqueId(), blob, base64) blobCache.add(blobInfo) resolve({ image: img, blobInfo: blobInfo, }) }, function (err) { reject(err) } ) } } var getAllImages = function (elm) { return elm ? from(elm.getElementsByTagName('img')) : [] } var ImageScanner = function (uploadStatus, blobCache) { var cachedPromises = {} var findAll = function (elm, predicate) { if (!predicate) { predicate = always } var images = filter$4(getAllImages(elm), function (img) { var src = img.src if (!Env.fileApi) { return false } if (img.hasAttribute('data-mce-bogus')) { return false } if (img.hasAttribute('data-mce-placeholder')) { return false } if (!src || src === Env.transparentSrc) { return false } if (src.indexOf('blob:') === 0) { return !uploadStatus.isUploaded(src) && predicate(img) } if (src.indexOf('data:') === 0) { return predicate(img) } return false }) var promises = map$3(images, function (img) { if (cachedPromises[img.src] !== undefined) { return new promiseObj(function (resolve) { cachedPromises[img.src].then(function (imageInfo) { if (typeof imageInfo === 'string') { return imageInfo } resolve({ image: img, blobInfo: imageInfo.blobInfo, }) }) }) } var newPromise = new promiseObj(function (resolve, reject) { imageToBlobInfo(blobCache, img, resolve, reject) }) .then(function (result) { delete cachedPromises[result.image.src] return result }) .catch(function (error) { delete cachedPromises[img.src] return error }) cachedPromises[img.src] = newPromise return newPromise }) return promiseObj.all(promises) } return { findAll: findAll } } var paddEmptyNode = function (settings, args, blockElements, node) { var brPreferred = settings.padd_empty_with_br || args.insert if (brPreferred && blockElements[node.name]) { node.empty().append(new AstNode('br', 1)).shortEnded = true } else { node.empty().append(new AstNode('#text', 3)).value = nbsp } } var isPaddedWithNbsp = function (node) { return hasOnlyChild(node, '#text') && node.firstChild.value === nbsp } var hasOnlyChild = function (node, name) { return ( node && node.firstChild && node.firstChild === node.lastChild && node.firstChild.name === name ) } var isPadded = function (schema, node) { var rule = schema.getElementRule(node.name) return rule && rule.paddEmpty } var isEmpty = function (schema, nonEmptyElements, whitespaceElements, node) { return node.isEmpty(nonEmptyElements, whitespaceElements, function (node) { return isPadded(schema, node) }) } var isLineBreakNode = function (node, blockElements) { return node && (has$2(blockElements, node.name) || node.name === 'br') } var isBogusImage = function (img) { return isNonNullable(img.attr('data-mce-bogus')) } var isInternalImageSource = function (img) { return ( img.attr('src') === Env.transparentSrc || isNonNullable(img.attr('data-mce-placeholder')) ) } var isValidDataImg = function (img, settings) { if (settings.images_dataimg_filter) { var imgElem_1 = new Image() imgElem_1.src = img.attr('src') each$j(img.attributes.map, function (value, key) { imgElem_1.setAttribute(key, value) }) return settings.images_dataimg_filter(imgElem_1) } else { return true } } var registerBase64ImageFilter = function (parser, settings) { var blobCache = settings.blob_cache var processImage = function (img) { var inputSrc = img.attr('src') if (isInternalImageSource(img) || isBogusImage(img)) { return } parseDataUri$1(inputSrc) .filter(function () { return isValidDataImg(img, settings) }) .bind(function (_a) { var type = _a.type, data = _a.data return Optional.from(blobCache.getByData(data, type)).orThunk( function () { return buildBlob(type, data).map(function (blob) { var blobInfo = blobCache.create(uniqueId(), blob, data) blobCache.add(blobInfo) return blobInfo }) } ) }) .each(function (blobInfo) { img.attr('src', blobInfo.blobUri()) }) } if (blobCache) { parser.addAttributeFilter('src', function (nodes) { return each$k(nodes, processImage) }) } } var register$1 = function (parser, settings) { var schema = parser.schema if (settings.remove_trailing_brs) { parser.addNodeFilter('br', function (nodes, _, args) { var i var l = nodes.length var node var blockElements = Tools.extend({}, schema.getBlockElements()) var nonEmptyElements = schema.getNonEmptyElements() var parent, lastParent, prev, prevName var whiteSpaceElements = schema.getWhiteSpaceElements() var elementRule, textNode blockElements.body = 1 for (i = 0; i < l; i++) { node = nodes[i] parent = node.parent if (blockElements[node.parent.name] && node === parent.lastChild) { prev = node.prev while (prev) { prevName = prev.name if ( prevName !== 'span' || prev.attr('data-mce-type') !== 'bookmark' ) { if (prevName === 'br') { node = null } break } prev = prev.prev } if (node) { node.remove() if ( isEmpty(schema, nonEmptyElements, whiteSpaceElements, parent) ) { elementRule = schema.getElementRule(parent.name) if (elementRule) { if (elementRule.removeEmpty) { parent.remove() } else if (elementRule.paddEmpty) { paddEmptyNode(settings, args, blockElements, parent) } } } } } else { lastParent = node while ( parent && parent.firstChild === lastParent && parent.lastChild === lastParent ) { lastParent = parent if (blockElements[parent.name]) { break } parent = parent.parent } if (lastParent === parent && settings.padd_empty_with_br !== true) { textNode = new AstNode('#text', 3) textNode.value = nbsp node.replace(textNode) } } } }) } parser.addAttributeFilter('href', function (nodes) { var i = nodes.length var appendRel = function (rel) { var parts = rel.split(' ').filter(function (p) { return p.length > 0 }) return parts.concat(['noopener']).sort().join(' ') } var addNoOpener = function (rel) { var newRel = rel ? Tools.trim(rel) : '' if (!/\b(noopener)\b/g.test(newRel)) { return appendRel(newRel) } else { return newRel } } if (!settings.allow_unsafe_link_target) { while (i--) { var node = nodes[i] if (node.name === 'a' && node.attr('target') === '_blank') { node.attr('rel', addNoOpener(node.attr('rel'))) } } } }) if (!settings.allow_html_in_named_anchor) { parser.addAttributeFilter('id,name', function (nodes) { var i = nodes.length, sibling, prevSibling, parent, node while (i--) { node = nodes[i] if (node.name === 'a' && node.firstChild && !node.attr('href')) { parent = node.parent sibling = node.lastChild do { prevSibling = sibling.prev parent.insert(sibling, node) sibling = prevSibling } while (sibling) } } }) } if (settings.fix_list_elements) { parser.addNodeFilter('ul,ol', function (nodes) { var i = nodes.length, node, parentNode while (i--) { node = nodes[i] parentNode = node.parent if (parentNode.name === 'ul' || parentNode.name === 'ol') { if (node.prev && node.prev.name === 'li') { node.prev.append(node) } else { var li = new AstNode('li', 1) li.attr('style', 'list-style-type: none') node.wrap(li) } } } }) } if (settings.validate && schema.getValidClasses()) { parser.addAttributeFilter('class', function (nodes) { var validClasses = schema.getValidClasses() var i = nodes.length while (i--) { var node = nodes[i] var classList = node.attr('class').split(' ') var classValue = '' for (var ci = 0; ci < classList.length; ci++) { var className = classList[ci] var valid = false var validClassesMap = validClasses['*'] if (validClassesMap && validClassesMap[className]) { valid = true } validClassesMap = validClasses[node.name] if (!valid && validClassesMap && validClassesMap[className]) { valid = true } if (valid) { if (classValue) { classValue += ' ' } classValue += className } } if (!classValue.length) { classValue = null } node.attr('class', classValue) } }) } registerBase64ImageFilter(parser, settings) } var makeMap = Tools.makeMap, each$6 = Tools.each, explode$2 = Tools.explode, extend$4 = Tools.extend var DomParser = function (settings, schema) { if (schema === void 0) { schema = Schema() } var nodeFilters = {} var attributeFilters = [] var matchedNodes = {} var matchedAttributes = {} settings = settings || {} settings.validate = 'validate' in settings ? settings.validate : true settings.root_name = settings.root_name || 'body' var fixInvalidChildren = function (nodes) { var nonSplitableElements = makeMap('tr,td,th,tbody,thead,tfoot,table') var nonEmptyElements = schema.getNonEmptyElements() var whitespaceElements = schema.getWhiteSpaceElements() var textBlockElements = schema.getTextBlockElements() var specialElements = schema.getSpecialElements() var removeOrUnwrapInvalidNode = function (node, originalNodeParent) { if (originalNodeParent === void 0) { originalNodeParent = node.parent } if (specialElements[node.name]) { node.empty().remove() } else { var children = node.children() for ( var _i = 0, children_1 = children; _i < children_1.length; _i++ ) { var childNode = children_1[_i] if (!schema.isValidChild(originalNodeParent.name, childNode.name)) { removeOrUnwrapInvalidNode(childNode, originalNodeParent) } } node.unwrap() } } for (var ni = 0; ni < nodes.length; ni++) { var node = nodes[ni] var parent_1 = void 0, newParent = void 0, tempNode = void 0 if (!node.parent || node.fixed) { continue } if (textBlockElements[node.name] && node.parent.name === 'li') { var sibling = node.next while (sibling) { if (textBlockElements[sibling.name]) { sibling.name = 'li' sibling.fixed = true node.parent.insert(sibling, node.parent) } else { break } sibling = sibling.next } node.unwrap() continue } var parents = [node] for ( parent_1 = node.parent; parent_1 && !schema.isValidChild(parent_1.name, node.name) && !nonSplitableElements[parent_1.name]; parent_1 = parent_1.parent ) { parents.push(parent_1) } if (parent_1 && parents.length > 1) { if (schema.isValidChild(parent_1.name, node.name)) { parents.reverse() newParent = filterNode(parents[0].clone()) var currentNode = newParent for (var i = 0; i < parents.length - 1; i++) { if (schema.isValidChild(currentNode.name, parents[i].name)) { tempNode = filterNode(parents[i].clone()) currentNode.append(tempNode) } else { tempNode = currentNode } for ( var childNode = parents[i].firstChild; childNode && childNode !== parents[i + 1]; ) { var nextNode = childNode.next tempNode.append(childNode) childNode = nextNode } currentNode = tempNode } if ( !isEmpty(schema, nonEmptyElements, whitespaceElements, newParent) ) { parent_1.insert(newParent, parents[0], true) parent_1.insert(node, newParent) } else { parent_1.insert(node, parents[0], true) } parent_1 = parents[0] if ( isEmpty(schema, nonEmptyElements, whitespaceElements, parent_1) || hasOnlyChild(parent_1, 'br') ) { parent_1.empty().remove() } } else { removeOrUnwrapInvalidNode(node) } } else if (node.parent) { if (node.name === 'li') { var sibling = node.prev if (sibling && (sibling.name === 'ul' || sibling.name === 'ol')) { sibling.append(node) continue } sibling = node.next if (sibling && (sibling.name === 'ul' || sibling.name === 'ol')) { sibling.insert(node, sibling.firstChild, true) continue } node.wrap(filterNode(new AstNode('ul', 1))) continue } if ( schema.isValidChild(node.parent.name, 'div') && schema.isValidChild('div', node.name) ) { node.wrap(filterNode(new AstNode('div', 1))) } else { removeOrUnwrapInvalidNode(node) } } } } var filterNode = function (node) { var name = node.name if (name in nodeFilters) { var list = matchedNodes[name] if (list) { list.push(node) } else { matchedNodes[name] = [node] } } var i = attributeFilters.length while (i--) { var attrName = attributeFilters[i].name if (attrName in node.attributes.map) { var list = matchedAttributes[attrName] if (list) { list.push(node) } else { matchedAttributes[attrName] = [node] } } } return node } var addNodeFilter = function (name, callback) { each$6(explode$2(name), function (name) { var list = nodeFilters[name] if (!list) { nodeFilters[name] = list = [] } list.push(callback) }) } var getNodeFilters = function () { var out = [] for (var name_1 in nodeFilters) { if (has$2(nodeFilters, name_1)) { out.push({ name: name_1, callbacks: nodeFilters[name_1], }) } } return out } var addAttributeFilter = function (name, callback) { each$6(explode$2(name), function (name) { var i for (i = 0; i < attributeFilters.length; i++) { if (attributeFilters[i].name === name) { attributeFilters[i].callbacks.push(callback) return } } attributeFilters.push({ name: name, callbacks: [callback], }) }) } var getAttributeFilters = function () { return [].concat(attributeFilters) } var parse = function (html, args) { var nodes, i, l, fi, fl, list, name var invalidChildren = [] var node var getRootBlockName = function (name) { if (name === false) { return '' } else if (name === true) { return 'p' } else { return name } } args = args || {} matchedNodes = {} matchedAttributes = {} var blockElements = extend$4( makeMap('script,style,head,html,body,title,meta,param'), schema.getBlockElements() ) var nonEmptyElements = schema.getNonEmptyElements() var children = schema.children var validate = settings.validate var forcedRootBlockName = 'forced_root_block' in args ? args.forced_root_block : settings.forced_root_block var rootBlockName = getRootBlockName(forcedRootBlockName) var whiteSpaceElements = schema.getWhiteSpaceElements() var startWhiteSpaceRegExp = /^[ \t\r\n]+/ var endWhiteSpaceRegExp = /[ \t\r\n]+$/ var allWhiteSpaceRegExp = /[ \t\r\n]+/g var isAllWhiteSpaceRegExp = /^[ \t\r\n]+$/ var isInWhiteSpacePreservedElement = has$2(whiteSpaceElements, args.context) || has$2(whiteSpaceElements, settings.root_name) var addRootBlocks = function () { var node = rootNode.firstChild, rootBlockNode = null var trim = function (rootBlock) { if (rootBlock) { node = rootBlock.firstChild if (node && node.type === 3) { node.value = node.value.replace(startWhiteSpaceRegExp, '') } node = rootBlock.lastChild if (node && node.type === 3) { node.value = node.value.replace(endWhiteSpaceRegExp, '') } } } if (!schema.isValidChild(rootNode.name, rootBlockName.toLowerCase())) { return } while (node) { var next = node.next if ( node.type === 3 || (node.type === 1 && node.name !== 'p' && !blockElements[node.name] && !node.attr('data-mce-type')) ) { if (!rootBlockNode) { rootBlockNode = createNode(rootBlockName, 1) rootBlockNode.attr(settings.forced_root_block_attrs) rootNode.insert(rootBlockNode, node) rootBlockNode.append(node) } else { rootBlockNode.append(node) } } else { trim(rootBlockNode) rootBlockNode = null } node = next } trim(rootBlockNode) } var createNode = function (name, type) { var node = new AstNode(name, type) var list if (name in nodeFilters) { list = matchedNodes[name] if (list) { list.push(node) } else { matchedNodes[name] = [node] } } return node } var removeWhitespaceBefore = function (node) { var blockElements = schema.getBlockElements() for (var textNode = node.prev; textNode && textNode.type === 3; ) { var textVal = textNode.value.replace(endWhiteSpaceRegExp, '') if (textVal.length > 0) { textNode.value = textVal return } var textNodeNext = textNode.next if (textNodeNext) { if (textNodeNext.type === 3 && textNodeNext.value.length) { textNode = textNode.prev continue } if ( !blockElements[textNodeNext.name] && textNodeNext.name !== 'script' && textNodeNext.name !== 'style' ) { textNode = textNode.prev continue } } var sibling = textNode.prev textNode.remove() textNode = sibling } } var cloneAndExcludeBlocks = function (input) { var output = {} for (var name_2 in input) { if (name_2 !== 'li' && name_2 !== 'p') { output[name_2] = input[name_2] } } return output } var parser = SaxParser( { validate: validate, document: settings.document, allow_html_data_urls: settings.allow_html_data_urls, allow_svg_data_urls: settings.allow_svg_data_urls, allow_script_urls: settings.allow_script_urls, allow_conditional_comments: settings.allow_conditional_comments, preserve_cdata: settings.preserve_cdata, self_closing_elements: cloneAndExcludeBlocks( schema.getSelfClosingElements() ), cdata: function (text) { node.append(createNode('#cdata', 4)).value = text }, text: function (text, raw) { var textNode if (!isInWhiteSpacePreservedElement) { text = text.replace(allWhiteSpaceRegExp, ' ') if (isLineBreakNode(node.lastChild, blockElements)) { text = text.replace(startWhiteSpaceRegExp, '') } } if (text.length !== 0) { textNode = createNode('#text', 3) textNode.raw = !!raw node.append(textNode).value = text } }, comment: function (text) { node.append(createNode('#comment', 8)).value = text }, pi: function (name, text) { node.append(createNode(name, 7)).value = text removeWhitespaceBefore(node) }, doctype: function (text) { var newNode = node.append(createNode('#doctype', 10)) newNode.value = text removeWhitespaceBefore(node) }, start: function (name, attrs, empty) { var elementRule = validate ? schema.getElementRule(name) : {} if (elementRule) { var newNode = createNode(elementRule.outputName || name, 1) newNode.attributes = attrs newNode.shortEnded = empty node.append(newNode) var parent_2 = children[node.name] if ( parent_2 && children[newNode.name] && !parent_2[newNode.name] ) { invalidChildren.push(newNode) } var attrFiltersLen = attributeFilters.length while (attrFiltersLen--) { var attrName = attributeFilters[attrFiltersLen].name if (attrName in attrs.map) { list = matchedAttributes[attrName] if (list) { list.push(newNode) } else { matchedAttributes[attrName] = [newNode] } } } if (blockElements[name]) { removeWhitespaceBefore(newNode) } if (!empty) { node = newNode } if (!isInWhiteSpacePreservedElement && whiteSpaceElements[name]) { isInWhiteSpacePreservedElement = true } } }, end: function (name) { var textNode, text, sibling, tempNode var elementRule = validate ? schema.getElementRule(name) : {} if (elementRule) { if (blockElements[name]) { if (!isInWhiteSpacePreservedElement) { textNode = node.firstChild if (textNode && textNode.type === 3) { text = textNode.value.replace(startWhiteSpaceRegExp, '') if (text.length > 0) { textNode.value = text textNode = textNode.next } else { sibling = textNode.next textNode.remove() textNode = sibling while (textNode && textNode.type === 3) { text = textNode.value sibling = textNode.next if ( text.length === 0 || isAllWhiteSpaceRegExp.test(text) ) { textNode.remove() textNode = sibling } textNode = sibling } } } textNode = node.lastChild if (textNode && textNode.type === 3) { text = textNode.value.replace(endWhiteSpaceRegExp, '') if (text.length > 0) { textNode.value = text textNode = textNode.prev } else { sibling = textNode.prev textNode.remove() textNode = sibling while (textNode && textNode.type === 3) { text = textNode.value sibling = textNode.prev if ( text.length === 0 || isAllWhiteSpaceRegExp.test(text) ) { textNode.remove() textNode = sibling } textNode = sibling } } } } } if (isInWhiteSpacePreservedElement && whiteSpaceElements[name]) { isInWhiteSpacePreservedElement = false } if ( elementRule.removeEmpty && isEmpty(schema, nonEmptyElements, whiteSpaceElements, node) ) { tempNode = node.parent if (blockElements[node.name]) { node.empty().remove() } else { node.unwrap() } node = tempNode return } if ( elementRule.paddEmpty && (isPaddedWithNbsp(node) || isEmpty(schema, nonEmptyElements, whiteSpaceElements, node)) ) { paddEmptyNode(settings, args, blockElements, node) } node = node.parent } }, }, schema ) var rootNode = (node = new AstNode( args.context || settings.root_name, 11 )) parser.parse(html, args.format) if (validate && invalidChildren.length) { if (!args.context) { fixInvalidChildren(invalidChildren) } else { args.invalid = true } } if (rootBlockName && (rootNode.name === 'body' || args.isRootContent)) { addRootBlocks() } if (!args.invalid) { for (name in matchedNodes) { if (!has$2(matchedNodes, name)) { continue } list = nodeFilters[name] nodes = matchedNodes[name] fi = nodes.length while (fi--) { if (!nodes[fi].parent) { nodes.splice(fi, 1) } } for (i = 0, l = list.length; i < l; i++) { list[i](nodes, name, args) } } for (i = 0, l = attributeFilters.length; i < l; i++) { list = attributeFilters[i] if (list.name in matchedAttributes) { nodes = matchedAttributes[list.name] fi = nodes.length while (fi--) { if (!nodes[fi].parent) { nodes.splice(fi, 1) } } for (fi = 0, fl = list.callbacks.length; fi < fl; fi++) { list.callbacks[fi](nodes, list.name, args) } } } } return rootNode } var exports = { schema: schema, addAttributeFilter: addAttributeFilter, getAttributeFilters: getAttributeFilters, addNodeFilter: addNodeFilter, getNodeFilters: getNodeFilters, filterNode: filterNode, parse: parse, } register$1(exports, settings) register$2(exports, settings) return exports } var register = function (htmlParser, settings, dom) { htmlParser.addAttributeFilter('data-mce-tabindex', function (nodes, name) { var i = nodes.length while (i--) { var node = nodes[i] node.attr('tabindex', node.attr('data-mce-tabindex')) node.attr(name, null) } }) htmlParser.addAttributeFilter('src,href,style', function (nodes, name) { var internalName = 'data-mce-' + name var urlConverter = settings.url_converter var urlConverterScope = settings.url_converter_scope var i = nodes.length while (i--) { var node = nodes[i] var value = node.attr(internalName) if (value !== undefined) { node.attr(name, value.length > 0 ? value : null) node.attr(internalName, null) } else { value = node.attr(name) if (name === 'style') { value = dom.serializeStyle(dom.parseStyle(value), node.name) } else if (urlConverter) { value = urlConverter.call(urlConverterScope, value, name, node.name) } node.attr(name, value.length > 0 ? value : null) } } }) htmlParser.addAttributeFilter('class', function (nodes) { var i = nodes.length while (i--) { var node = nodes[i] var value = node.attr('class') if (value) { value = node.attr('class').replace(/(?:^|\s)mce-item-\w+(?!\S)/g, '') node.attr('class', value.length > 0 ? value : null) } } }) htmlParser.addAttributeFilter( 'data-mce-type', function (nodes, name, args) { var i = nodes.length while (i--) { var node = nodes[i] if (node.attr('data-mce-type') === 'bookmark' && !args.cleanup) { var hasChildren = Optional.from(node.firstChild).exists(function ( firstChild ) { return !isZwsp(firstChild.value) }) if (hasChildren) { node.unwrap() } else { node.remove() } } } } ) htmlParser.addNodeFilter('noscript', function (nodes) { var i = nodes.length while (i--) { var node = nodes[i].firstChild if (node) { node.value = Entities.decode(node.value) } } }) htmlParser.addNodeFilter('script,style', function (nodes, name) { var trim = function (value) { return value .replace(/()/g, '\n') .replace(/^[\r\n]*|[\r\n]*$/g, '') .replace( /^\s*(()?|\s*\/\/\s*\]\]>(-->)?|\/\/\s*(-->)?|\]\]>|\/\*\s*-->\s*\*\/|\s*-->\s*)\s*$/g, '' ) } var i = nodes.length while (i--) { var node = nodes[i] var value = node.firstChild ? node.firstChild.value : '' if (name === 'script') { var type = node.attr('type') if (type) { node.attr( 'type', type === 'mce-no/type' ? null : type.replace(/^mce\-/, '') ) } if (settings.element_format === 'xhtml' && value.length > 0) { node.firstChild.value = '// ' } } else { if (settings.element_format === 'xhtml' && value.length > 0) { node.firstChild.value = '' } } } }) htmlParser.addNodeFilter('#comment', function (nodes) { var i = nodes.length while (i--) { var node = nodes[i] if (settings.preserve_cdata && node.value.indexOf('[CDATA[') === 0) { node.name = '#cdata' node.type = 4 node.value = dom.decode(node.value.replace(/^\[CDATA\[|\]\]$/g, '')) } else if (node.value.indexOf('mce:protected ') === 0) { node.name = '#text' node.type = 3 node.raw = true node.value = unescape(node.value).substr(14) } } }) htmlParser.addNodeFilter('xml:namespace,input', function (nodes, name) { var i = nodes.length while (i--) { var node = nodes[i] if (node.type === 7) { node.remove() } else if (node.type === 1) { if (name === 'input' && !node.attr('type')) { node.attr('type', 'text') } } } }) htmlParser.addAttributeFilter('data-mce-type', function (nodes) { each$k(nodes, function (node) { if (node.attr('data-mce-type') === 'format-caret') { if (node.isEmpty(htmlParser.schema.getNonEmptyElements())) { node.remove() } else { node.unwrap() } } }) }) htmlParser.addAttributeFilter( 'data-mce-src,data-mce-href,data-mce-style,' + 'data-mce-selected,data-mce-expando,' + 'data-mce-type,data-mce-resize,data-mce-placeholder', function (nodes, name) { var i = nodes.length while (i--) { nodes[i].attr(name, null) } } ) } var trimTrailingBr = function (rootNode) { var isBr = function (node) { return node && node.name === 'br' } var brNode1 = rootNode.lastChild if (isBr(brNode1)) { var brNode2 = brNode1.prev if (isBr(brNode2)) { brNode1.remove() brNode2.remove() } } } var preProcess = function (editor, node, args) { var oldDoc var dom = editor.dom var clonedNode = node.cloneNode(true) var impl = document.implementation if (impl.createHTMLDocument) { var doc_1 = impl.createHTMLDocument('') Tools.each( clonedNode.nodeName === 'BODY' ? clonedNode.childNodes : [clonedNode], function (node) { doc_1.body.appendChild(doc_1.importNode(node, true)) } ) if (clonedNode.nodeName !== 'BODY') { clonedNode = doc_1.body.firstChild } else { clonedNode = doc_1.body } oldDoc = dom.doc dom.doc = doc_1 } firePreProcess(editor, __assign(__assign({}, args), { node: clonedNode })) if (oldDoc) { dom.doc = oldDoc } return clonedNode } var shouldFireEvent = function (editor, args) { return editor && editor.hasEventListeners('PreProcess') && !args.no_events } var process = function (editor, node, args) { return shouldFireEvent(editor, args) ? preProcess(editor, node, args) : node } var addTempAttr = function (htmlParser, tempAttrs, name) { if (Tools.inArray(tempAttrs, name) === -1) { htmlParser.addAttributeFilter(name, function (nodes, name) { var i = nodes.length while (i--) { nodes[i].attr(name, null) } }) tempAttrs.push(name) } } var postProcess = function (editor, args, content) { if (!args.no_events && editor) { var outArgs = firePostProcess( editor, __assign(__assign({}, args), { content: content }) ) return outArgs.content } else { return content } } var getHtmlFromNode = function (dom, node, args) { var html = trim$2(args.getInner ? node.innerHTML : dom.getOuterHTML(node)) return args.selection || isWsPreserveElement(SugarElement.fromDom(node)) ? html : Tools.trim(html) } var parseHtml = function (htmlParser, html, args) { var parserArgs = args.selection ? __assign({ forced_root_block: false }, args) : args var rootNode = htmlParser.parse(html, parserArgs) trimTrailingBr(rootNode) return rootNode } var serializeNode = function (settings, schema, node) { var htmlSerializer = HtmlSerializer(settings, schema) return htmlSerializer.serialize(node) } var toHtml = function (editor, settings, schema, rootNode, args) { var content = serializeNode(settings, schema, rootNode) return postProcess(editor, args, content) } var DomSerializerImpl = function (settings, editor) { var tempAttrs = ['data-mce-selected'] var dom = editor && editor.dom ? editor.dom : DOMUtils.DOM var schema = editor && editor.schema ? editor.schema : Schema(settings) settings.entity_encoding = settings.entity_encoding || 'named' settings.remove_trailing_brs = 'remove_trailing_brs' in settings ? settings.remove_trailing_brs : true var htmlParser = DomParser(settings, schema) register(htmlParser, settings, dom) var serialize = function (node, parserArgs) { if (parserArgs === void 0) { parserArgs = {} } var args = __assign({ format: 'html' }, parserArgs) var targetNode = process(editor, node, args) var html = getHtmlFromNode(dom, targetNode, args) var rootNode = parseHtml(htmlParser, html, args) return args.format === 'tree' ? rootNode : toHtml(editor, settings, schema, rootNode, args) } return { schema: schema, addNodeFilter: htmlParser.addNodeFilter, addAttributeFilter: htmlParser.addAttributeFilter, serialize: serialize, addRules: schema.addValidElements, setRules: schema.setValidElements, addTempAttr: curry(addTempAttr, htmlParser, tempAttrs), getTempAttrs: constant(tempAttrs), getNodeFilters: htmlParser.getNodeFilters, getAttributeFilters: htmlParser.getAttributeFilters, } } var DomSerializer = function (settings, editor) { var domSerializer = DomSerializerImpl(settings, editor) return { schema: domSerializer.schema, addNodeFilter: domSerializer.addNodeFilter, addAttributeFilter: domSerializer.addAttributeFilter, serialize: domSerializer.serialize, addRules: domSerializer.addRules, setRules: domSerializer.setRules, addTempAttr: domSerializer.addTempAttr, getTempAttrs: domSerializer.getTempAttrs, getNodeFilters: domSerializer.getNodeFilters, getAttributeFilters: domSerializer.getAttributeFilters, } } var defaultFormat = 'html' var getContent = function (editor, args) { if (args === void 0) { args = {} } var format = args.format ? args.format : defaultFormat return getContent$2(editor, args, format) } var setContent = function (editor, content, args) { if (args === void 0) { args = {} } return setContent$2(editor, content, args) } var DOM$7 = DOMUtils.DOM var restoreOriginalStyles = function (editor) { DOM$7.setStyle(editor.id, 'display', editor.orgDisplay) } var safeDestroy = function (x) { return Optional.from(x).each(function (x) { return x.destroy() }) } var clearDomReferences = function (editor) { editor.contentAreaContainer = editor.formElement = editor.container = editor.editorContainer = null editor.bodyElement = editor.contentDocument = editor.contentWindow = null editor.iframeElement = editor.targetElm = null if (editor.selection) { editor.selection = editor.selection.win = editor.selection.dom = editor.selection.dom.doc = null } } var restoreForm = function (editor) { var form = editor.formElement if (form) { if (form._mceOldSubmit) { form.submit = form._mceOldSubmit form._mceOldSubmit = null } DOM$7.unbind(form, 'submit reset', editor.formEventDelegate) } } var remove = function (editor) { if (!editor.removed) { var _selectionOverrides = editor._selectionOverrides, editorUpload = editor.editorUpload var body = editor.getBody() var element = editor.getElement() if (body) { editor.save({ is_removing: true }) } editor.removed = true editor.unbindAllNativeEvents() if (editor.hasHiddenInput && element) { DOM$7.remove(element.nextSibling) } fireRemove(editor) editor.editorManager.remove(editor) if (!editor.inline && body) { restoreOriginalStyles(editor) } fireDetach(editor) DOM$7.remove(editor.getContainer()) safeDestroy(_selectionOverrides) safeDestroy(editorUpload) editor.destroy() } } var destroy = function (editor, automatic) { var selection = editor.selection, dom = editor.dom if (editor.destroyed) { return } if (!automatic && !editor.removed) { editor.remove() return } if (!automatic) { editor.editorManager.off('beforeunload', editor._beforeUnload) if (editor.theme && editor.theme.destroy) { editor.theme.destroy() } safeDestroy(selection) safeDestroy(dom) } restoreForm(editor) clearDomReferences(editor) editor.destroyed = true } var deep = function (old, nu) { var bothObjects = isObject(old) && isObject(nu) return bothObjects ? deepMerge(old, nu) : nu } var baseMerge = function (merger) { return function () { var objects = [] for (var _i = 0; _i < arguments.length; _i++) { objects[_i] = arguments[_i] } if (objects.length === 0) { throw new Error("Can't merge zero objects") } var ret = {} for (var j = 0; j < objects.length; j++) { var curObject = objects[j] for (var key in curObject) { if (has$2(curObject, key)) { ret[key] = merger(ret[key], curObject[key]) } } } return ret } } var deepMerge = baseMerge(deep) var deprecatedSettings = ( 'autoresize_on_init,content_editable_state,convert_fonts_to_spans,inline_styles,padd_empty_with_br,block_elements,' + 'boolean_attributes,editor_deselector,editor_selector,elements,file_browser_callback_types,filepicker_validator_handler,' + 'force_hex_style_colors,force_p_newlines,gecko_spellcheck,images_dataimg_filter,media_scripts,mode,move_caret_before_on_enter_elements,' + 'non_empty_elements,self_closing_elements,short_ended_elements,special,spellchecker_select_languages,spellchecker_whitelist,' + 'tab_focus,table_responsive_width,text_block_elements,text_inline_elements,toolbar_drawer,types,validate,whitespace_elements,' + 'paste_word_valid_elements,paste_retain_style_properties,paste_convert_word_fake_lists' ).split(',') var deprecatedPlugins = 'bbcode,colorpicker,contextmenu,fullpage,legacyoutput,spellchecker,textcolor'.split( ',' ) var movedToPremiumPlugins = 'imagetools,toc'.split(',') var getDeprecatedSettings = function (settings) { var settingNames = filter$4(deprecatedSettings, function (setting) { return has$2(settings, setting) }) var forcedRootBlock = settings.forced_root_block if (forcedRootBlock === false || forcedRootBlock === '') { settingNames.push('forced_root_block (false only)') } return sort(settingNames) } var getDeprecatedPlugins = function (settings) { var plugins = Tools.makeMap(settings.plugins, ' ') var hasPlugin = function (plugin) { return has$2(plugins, plugin) } var pluginNames = __spreadArray( __spreadArray([], filter$4(deprecatedPlugins, hasPlugin), true), bind(movedToPremiumPlugins, function (plugin) { return hasPlugin(plugin) ? [plugin + ' (moving to premium)'] : [] }), true ) return sort(pluginNames) } var logDeprecationsWarning = function (rawSettings, finalSettings) { var deprecatedSettings = getDeprecatedSettings(rawSettings) var deprecatedPlugins = getDeprecatedPlugins(finalSettings) var hasDeprecatedPlugins = deprecatedPlugins.length > 0 var hasDeprecatedSettings = deprecatedSettings.length > 0 var isLegacyMobileTheme = finalSettings.theme === 'mobile' if (hasDeprecatedPlugins || hasDeprecatedSettings || isLegacyMobileTheme) { var listJoiner = '\n- ' var themesMessage = isLegacyMobileTheme ? '\n\nThemes:' + listJoiner + 'mobile' : '' var pluginsMessage = hasDeprecatedPlugins ? '\n\nPlugins:' + listJoiner + deprecatedPlugins.join(listJoiner) : '' var settingsMessage = hasDeprecatedSettings ? '\n\nSettings:' + listJoiner + deprecatedSettings.join(listJoiner) : '' console.warn( 'The following deprecated features are currently enabled, these will be removed in TinyMCE 6.0. ' + 'See https://www.tiny.cloud/docs/release-notes/6.0-upcoming-changes/ for more information.' + themesMessage + pluginsMessage + settingsMessage ) } } var sectionResult = function (sections, settings) { return { sections: constant(sections), settings: constant(settings), } } var deviceDetection = detect().deviceType var isTouch = deviceDetection.isTouch() var isPhone = deviceDetection.isPhone() var isTablet = deviceDetection.isTablet() var legacyMobilePlugins = ['lists', 'autolink', 'autosave'] var defaultTouchSettings = { table_grid: false, object_resizing: false, resize: false, } var normalizePlugins = function (plugins) { var pluginNames = isArray$1(plugins) ? plugins.join(' ') : plugins var trimmedPlugins = map$3( isString$1(pluginNames) ? pluginNames.split(' ') : [], trim$4 ) return filter$4(trimmedPlugins, function (item) { return item.length > 0 }) } var filterLegacyMobilePlugins = function (plugins) { return filter$4(plugins, curry(contains$3, legacyMobilePlugins)) } var extractSections = function (keys, settings) { var result = bifilter(settings, function (value, key) { return contains$3(keys, key) }) return sectionResult(result.t, result.f) } var getSection = function (sectionResult, name, defaults) { if (defaults === void 0) { defaults = {} } var sections = sectionResult.sections() var sectionSettings = get$9(sections, name).getOr({}) return Tools.extend({}, defaults, sectionSettings) } var hasSection = function (sectionResult, name) { return has$2(sectionResult.sections(), name) } var isSectionTheme = function (sectionResult, name, theme) { var section = sectionResult.sections() return hasSection(sectionResult, name) && section[name].theme === theme } var getSectionConfig = function (sectionResult, name) { return hasSection(sectionResult, name) ? sectionResult.sections()[name] : {} } var getToolbarMode = function (settings, defaultVal) { return get$9(settings, 'toolbar_mode') .orThunk(function () { return get$9(settings, 'toolbar_drawer').map(function (val) { return val === false ? 'wrap' : val }) }) .getOr(defaultVal) } var getDefaultSettings = function ( settings, id, documentBaseUrl, isTouch, editor ) { var baseDefaults = { id: id, theme: 'silver', toolbar_mode: getToolbarMode(settings, 'floating'), plugins: '', document_base_url: documentBaseUrl, add_form_submit_trigger: true, submit_patch: true, add_unload_trigger: true, convert_urls: true, relative_urls: true, remove_script_host: true, object_resizing: true, doctype: '', visual: true, font_size_legacy_values: 'xx-small,small,medium,large,x-large,xx-large,300%', forced_root_block: 'p', hidden_input: true, inline_styles: true, convert_fonts_to_spans: true, indent: true, indent_before: 'p,h1,h2,h3,h4,h5,h6,blockquote,div,title,style,pre,script,td,th,ul,ol,li,dl,dt,dd,area,table,thead,' + 'tfoot,tbody,tr,section,summary,article,hgroup,aside,figure,figcaption,option,optgroup,datalist', indent_after: 'p,h1,h2,h3,h4,h5,h6,blockquote,div,title,style,pre,script,td,th,ul,ol,li,dl,dt,dd,area,table,thead,' + 'tfoot,tbody,tr,section,summary,article,hgroup,aside,figure,figcaption,option,optgroup,datalist', entity_encoding: 'named', url_converter: editor.convertURL, url_converter_scope: editor, } return __assign( __assign({}, baseDefaults), isTouch ? defaultTouchSettings : {} ) } var getDefaultMobileSettings = function (mobileSettings, isPhone) { var defaultMobileSettings = { resize: false, toolbar_mode: getToolbarMode(mobileSettings, 'scrolling'), toolbar_sticky: false, } var defaultPhoneSettings = { menubar: false } return __assign( __assign(__assign({}, defaultTouchSettings), defaultMobileSettings), isPhone ? defaultPhoneSettings : {} ) } var getExternalPlugins = function (overrideSettings, settings) { var userDefinedExternalPlugins = settings.external_plugins ? settings.external_plugins : {} if (overrideSettings && overrideSettings.external_plugins) { return Tools.extend( {}, overrideSettings.external_plugins, userDefinedExternalPlugins ) } else { return userDefinedExternalPlugins } } var combinePlugins = function (forcedPlugins, plugins) { return [] .concat(normalizePlugins(forcedPlugins)) .concat(normalizePlugins(plugins)) } var getPlatformPlugins = function ( isMobileDevice, sectionResult, desktopPlugins, mobilePlugins ) { if (isMobileDevice && isSectionTheme(sectionResult, 'mobile', 'mobile')) { return filterLegacyMobilePlugins(mobilePlugins) } else if (isMobileDevice && hasSection(sectionResult, 'mobile')) { return mobilePlugins } else { return desktopPlugins } } var processPlugins = function ( isMobileDevice, sectionResult, defaultOverrideSettings, settings ) { var forcedPlugins = normalizePlugins(defaultOverrideSettings.forced_plugins) var desktopPlugins = normalizePlugins(settings.plugins) var mobileConfig = getSectionConfig(sectionResult, 'mobile') var mobilePlugins = mobileConfig.plugins ? normalizePlugins(mobileConfig.plugins) : desktopPlugins var platformPlugins = getPlatformPlugins( isMobileDevice, sectionResult, desktopPlugins, mobilePlugins ) var combinedPlugins = combinePlugins(forcedPlugins, platformPlugins) if (Env.browser.isIE() && contains$3(combinedPlugins, 'rtc')) { throw new Error('RTC plugin is not supported on IE 11.') } return Tools.extend(settings, { plugins: combinedPlugins.join(' ') }) } var isOnMobile = function (isMobileDevice, sectionResult) { return isMobileDevice && hasSection(sectionResult, 'mobile') } var combineSettings = function ( isMobileDevice, isPhone, defaultSettings, defaultOverrideSettings, settings ) { var defaultDeviceSettings = isMobileDevice ? { mobile: getDefaultMobileSettings(settings.mobile || {}, isPhone) } : {} var sectionResult = extractSections( ['mobile'], deepMerge(defaultDeviceSettings, settings) ) var extendedSettings = Tools.extend( defaultSettings, defaultOverrideSettings, sectionResult.settings(), isOnMobile(isMobileDevice, sectionResult) ? getSection(sectionResult, 'mobile') : {}, { validate: true, external_plugins: getExternalPlugins( defaultOverrideSettings, sectionResult.settings() ), } ) return processPlugins( isMobileDevice, sectionResult, defaultOverrideSettings, extendedSettings ) } var getEditorSettings = function ( editor, id, documentBaseUrl, defaultOverrideSettings, settings ) { var defaultSettings = getDefaultSettings( settings, id, documentBaseUrl, isTouch, editor ) var finalSettings = combineSettings( isPhone || isTablet, isPhone, defaultSettings, defaultOverrideSettings, settings ) if (finalSettings.deprecation_warnings !== false) { logDeprecationsWarning(settings, finalSettings) } return finalSettings } var getFiltered = function (predicate, editor, name) { return Optional.from(editor.settings[name]).filter(predicate) } var getParamObject = function (value) { var output = {} if (typeof value === 'string') { each$k( value.indexOf('=') > 0 ? value.split(/[;,](?![^=;,]*(?:[;,]|$))/) : value.split(','), function (val) { var arr = val.split('=') if (arr.length > 1) { output[Tools.trim(arr[0])] = Tools.trim(arr[1]) } else { output[Tools.trim(arr[0])] = Tools.trim(arr[0]) } } ) } else { output = value } return output } var isArrayOf = function (p) { return function (a) { return isArray$1(a) && forall(a, p) } } var getParam = function (editor, name, defaultVal, type) { var value = name in editor.settings ? editor.settings[name] : defaultVal if (type === 'hash') { return getParamObject(value) } else if (type === 'string') { return getFiltered(isString$1, editor, name).getOr(defaultVal) } else if (type === 'number') { return getFiltered(isNumber, editor, name).getOr(defaultVal) } else if (type === 'boolean') { return getFiltered(isBoolean, editor, name).getOr(defaultVal) } else if (type === 'object') { return getFiltered(isObject, editor, name).getOr(defaultVal) } else if (type === 'array') { return getFiltered(isArray$1, editor, name).getOr(defaultVal) } else if (type === 'string[]') { return getFiltered(isArrayOf(isString$1), editor, name).getOr(defaultVal) } else if (type === 'function') { return getFiltered(isFunction, editor, name).getOr(defaultVal) } else { return value } } var CreateIconManager = function () { var lookup = {} var add = function (id, iconPack) { lookup[id] = iconPack } var get = function (id) { if (lookup[id]) { return lookup[id] } return { icons: {} } } var has = function (id) { return has$2(lookup, id) } return { add: add, get: get, has: has, } } var IconManager = CreateIconManager() var getProp = function (propName, elm) { var rawElm = elm.dom return rawElm[propName] } var getComputedSizeProp = function (propName, elm) { return parseInt(get$5(elm, propName), 10) } var getClientWidth = curry(getProp, 'clientWidth') var getClientHeight = curry(getProp, 'clientHeight') var getMarginTop = curry(getComputedSizeProp, 'margin-top') var getMarginLeft = curry(getComputedSizeProp, 'margin-left') var getBoundingClientRect = function (elm) { return elm.dom.getBoundingClientRect() } var isInsideElementContentArea = function (bodyElm, clientX, clientY) { var clientWidth = getClientWidth(bodyElm) var clientHeight = getClientHeight(bodyElm) return ( clientX >= 0 && clientY >= 0 && clientX <= clientWidth && clientY <= clientHeight ) } var transpose = function (inline, elm, clientX, clientY) { var clientRect = getBoundingClientRect(elm) var deltaX = inline ? clientRect.left + elm.dom.clientLeft + getMarginLeft(elm) : 0 var deltaY = inline ? clientRect.top + elm.dom.clientTop + getMarginTop(elm) : 0 var x = clientX - deltaX var y = clientY - deltaY return { x: x, y: y, } } var isXYInContentArea = function (editor, clientX, clientY) { var bodyElm = SugarElement.fromDom(editor.getBody()) var targetElm = editor.inline ? bodyElm : documentElement(bodyElm) var transposedPoint = transpose(editor.inline, targetElm, clientX, clientY) return isInsideElementContentArea( targetElm, transposedPoint.x, transposedPoint.y ) } var fromDomSafe = function (node) { return Optional.from(node).map(SugarElement.fromDom) } var isEditorAttachedToDom = function (editor) { var rawContainer = editor.inline ? editor.getBody() : editor.getContentAreaContainer() return fromDomSafe(rawContainer).map(inBody).getOr(false) } var NotificationManagerImpl = function () { var unimplemented = function () { throw new Error( 'Theme did not provide a NotificationManager implementation.' ) } return { open: unimplemented, close: unimplemented, reposition: unimplemented, getArgs: unimplemented, } } var NotificationManager = function (editor) { var notifications = [] var getImplementation = function () { var theme = editor.theme return theme && theme.getNotificationManagerImpl ? theme.getNotificationManagerImpl() : NotificationManagerImpl() } var getTopNotification = function () { return Optional.from(notifications[0]) } var isEqual = function (a, b) { return ( a.type === b.type && a.text === b.text && !a.progressBar && !a.timeout && !b.progressBar && !b.timeout ) } var reposition = function () { if (notifications.length > 0) { getImplementation().reposition(notifications) } } var addNotification = function (notification) { notifications.push(notification) } var closeNotification = function (notification) { findIndex$2(notifications, function (otherNotification) { return otherNotification === notification }).each(function (index) { notifications.splice(index, 1) }) } var open = function (spec, fireEvent) { if (fireEvent === void 0) { fireEvent = true } if (editor.removed || !isEditorAttachedToDom(editor)) { return } if (fireEvent) { editor.fire('BeforeOpenNotification', { notification: spec }) } return find$3(notifications, function (notification) { return isEqual(getImplementation().getArgs(notification), spec) }).getOrThunk(function () { editor.editorManager.setActive(editor) var notification = getImplementation().open(spec, function () { closeNotification(notification) reposition() getTopNotification().fold( function () { return editor.focus() }, function (top) { return focus$1(SugarElement.fromDom(top.getEl())) } ) }) addNotification(notification) reposition() editor.fire('OpenNotification', { notification: __assign({}, notification), }) return notification }) } var close = function () { getTopNotification().each(function (notification) { getImplementation().close(notification) closeNotification(notification) reposition() }) } var getNotifications = constant(notifications) var registerEvents = function (editor) { editor.on('SkinLoaded', function () { var serviceMessage = getServiceMessage(editor) if (serviceMessage) { open( { text: serviceMessage, type: 'warning', timeout: 0, }, false ) } reposition() }) editor.on('show ResizeEditor ResizeWindow NodeChange', function () { Delay.requestAnimationFrame(reposition) }) editor.on('remove', function () { each$k(notifications.slice(), function (notification) { getImplementation().close(notification) }) }) } registerEvents(editor) return { open: open, close: close, getNotifications: getNotifications, } } var PluginManager = AddOnManager.PluginManager var ThemeManager = AddOnManager.ThemeManager function WindowManagerImpl() { var unimplemented = function () { throw new Error('Theme did not provide a WindowManager implementation.') } return { open: unimplemented, openUrl: unimplemented, alert: unimplemented, confirm: unimplemented, close: unimplemented, getParams: unimplemented, setParams: unimplemented, } } var WindowManager = function (editor) { var dialogs = [] var getImplementation = function () { var theme = editor.theme return theme && theme.getWindowManagerImpl ? theme.getWindowManagerImpl() : WindowManagerImpl() } var funcBind = function (scope, f) { return function () { var args = [] for (var _i = 0; _i < arguments.length; _i++) { args[_i] = arguments[_i] } return f ? f.apply(scope, args) : undefined } } var fireOpenEvent = function (dialog) { editor.fire('OpenWindow', { dialog: dialog }) } var fireCloseEvent = function (dialog) { editor.fire('CloseWindow', { dialog: dialog }) } var addDialog = function (dialog) { dialogs.push(dialog) fireOpenEvent(dialog) } var closeDialog = function (dialog) { fireCloseEvent(dialog) dialogs = filter$4(dialogs, function (otherDialog) { return otherDialog !== dialog }) if (dialogs.length === 0) { editor.focus() } } var getTopDialog = function () { return Optional.from(dialogs[dialogs.length - 1]) } var storeSelectionAndOpenDialog = function (openDialog) { editor.editorManager.setActive(editor) store(editor) var dialog = openDialog() addDialog(dialog) return dialog } var open = function (args, params) { return storeSelectionAndOpenDialog(function () { return getImplementation().open(args, params, closeDialog) }) } var openUrl = function (args) { return storeSelectionAndOpenDialog(function () { return getImplementation().openUrl(args, closeDialog) }) } var alert = function (message, callback, scope) { var windowManagerImpl = getImplementation() windowManagerImpl.alert( message, funcBind(scope ? scope : windowManagerImpl, callback) ) } var confirm = function (message, callback, scope) { var windowManagerImpl = getImplementation() windowManagerImpl.confirm( message, funcBind(scope ? scope : windowManagerImpl, callback) ) } var close = function () { getTopDialog().each(function (dialog) { getImplementation().close(dialog) closeDialog(dialog) }) } editor.on('remove', function () { each$k(dialogs, function (dialog) { getImplementation().close(dialog) }) }) return { open: open, openUrl: openUrl, alert: alert, confirm: confirm, close: close, } } var displayNotification = function (editor, message) { editor.notificationManager.open({ type: 'error', text: message, }) } var displayError = function (editor, message) { if (editor._skinLoaded) { displayNotification(editor, message) } else { editor.on('SkinLoaded', function () { displayNotification(editor, message) }) } } var uploadError = function (editor, message) { displayError( editor, I18n.translate(['Failed to upload image: {0}', message]) ) } var logError = function (editor, errorType, msg) { fireError(editor, errorType, { message: msg }) console.error(msg) } var createLoadError = function (type, url, name) { return name ? 'Failed to load ' + type + ': ' + name + ' from url ' + url : 'Failed to load ' + type + ' url: ' + url } var pluginLoadError = function (editor, url, name) { logError(editor, 'PluginLoadError', createLoadError('plugin', url, name)) } var iconsLoadError = function (editor, url, name) { logError(editor, 'IconsLoadError', createLoadError('icons', url, name)) } var languageLoadError = function (editor, url, name) { logError( editor, 'LanguageLoadError', createLoadError('language', url, name) ) } var pluginInitError = function (editor, name, err) { var message = I18n.translate(['Failed to initialize plugin: {0}', name]) fireError(editor, 'PluginLoadError', { message: message }) initError(message, err) displayError(editor, message) } var initError = function (message) { var x = [] for (var _i = 1; _i < arguments.length; _i++) { x[_i - 1] = arguments[_i] } var console = window.console if (console) { if (console.error) { console.error.apply(console, __spreadArray([message], x, false)) } else { console.log.apply(console, __spreadArray([message], x, false)) } } } var isContentCssSkinName = function (url) { return /^[a-z0-9\-]+$/i.test(url) } var getContentCssUrls = function (editor) { return transformToUrls(editor, getContentCss(editor)) } var getFontCssUrls = function (editor) { return transformToUrls(editor, getFontCss(editor)) } var transformToUrls = function (editor, cssLinks) { var skinUrl = editor.editorManager.baseURL + '/skins/content' var suffix = editor.editorManager.suffix var contentCssFile = 'content' + suffix + '.css' var inline = editor.inline === true return map$3(cssLinks, function (url) { if (isContentCssSkinName(url) && !inline) { return skinUrl + '/' + url + '/' + contentCssFile } else { return editor.documentBaseURI.toAbsolute(url) } }) } var appendContentCssFromSettings = function (editor) { editor.contentCSS = editor.contentCSS.concat( getContentCssUrls(editor), getFontCssUrls(editor) ) } var UploadStatus = function () { var PENDING = 1, UPLOADED = 2 var blobUriStatuses = {} var createStatus = function (status, resultUri) { return { status: status, resultUri: resultUri, } } var hasBlobUri = function (blobUri) { return blobUri in blobUriStatuses } var getResultUri = function (blobUri) { var result = blobUriStatuses[blobUri] return result ? result.resultUri : null } var isPending = function (blobUri) { return hasBlobUri(blobUri) ? blobUriStatuses[blobUri].status === PENDING : false } var isUploaded = function (blobUri) { return hasBlobUri(blobUri) ? blobUriStatuses[blobUri].status === UPLOADED : false } var markPending = function (blobUri) { blobUriStatuses[blobUri] = createStatus(PENDING, null) } var markUploaded = function (blobUri, resultUri) { blobUriStatuses[blobUri] = createStatus(UPLOADED, resultUri) } var removeFailed = function (blobUri) { delete blobUriStatuses[blobUri] } var destroy = function () { blobUriStatuses = {} } return { hasBlobUri: hasBlobUri, getResultUri: getResultUri, isPending: isPending, isUploaded: isUploaded, markPending: markPending, markUploaded: markUploaded, removeFailed: removeFailed, destroy: destroy, } } var count = 0 var seed = function () { var rnd = function () { return Math.round(Math.random() * 4294967295).toString(36) } var now = new Date().getTime() return 's' + now.toString(36) + rnd() + rnd() + rnd() } var uuid = function (prefix) { return prefix + count++ + seed() } var BlobCache = function () { var cache = [] var mimeToExt = function (mime) { var mimes = { 'image/jpeg': 'jpg', 'image/jpg': 'jpg', 'image/gif': 'gif', 'image/png': 'png', 'image/apng': 'apng', 'image/avif': 'avif', 'image/svg+xml': 'svg', 'image/webp': 'webp', 'image/bmp': 'bmp', 'image/tiff': 'tiff', } return mimes[mime.toLowerCase()] || 'dat' } var create = function (o, blob, base64, name, filename) { if (isString$1(o)) { var id = o return toBlobInfo({ id: id, name: name, filename: filename, blob: blob, base64: base64, }) } else if (isObject(o)) { return toBlobInfo(o) } else { throw new Error('Unknown input type') } } var toBlobInfo = function (o) { if (!o.blob || !o.base64) { throw new Error( 'blob and base64 representations of the image are required for BlobInfo to be created' ) } var id = o.id || uuid('blobid') var name = o.name || id var blob = o.blob return { id: constant(id), name: constant(name), filename: constant(o.filename || name + '.' + mimeToExt(blob.type)), blob: constant(blob), base64: constant(o.base64), blobUri: constant(o.blobUri || URL.createObjectURL(blob)), uri: constant(o.uri), } } var add = function (blobInfo) { if (!get(blobInfo.id())) { cache.push(blobInfo) } } var findFirst = function (predicate) { return find$3(cache, predicate).getOrUndefined() } var get = function (id) { return findFirst(function (cachedBlobInfo) { return cachedBlobInfo.id() === id }) } var getByUri = function (blobUri) { return findFirst(function (blobInfo) { return blobInfo.blobUri() === blobUri }) } var getByData = function (base64, type) { return findFirst(function (blobInfo) { return blobInfo.base64() === base64 && blobInfo.blob().type === type }) } var removeByUri = function (blobUri) { cache = filter$4(cache, function (blobInfo) { if (blobInfo.blobUri() === blobUri) { URL.revokeObjectURL(blobInfo.blobUri()) return false } return true }) } var destroy = function () { each$k(cache, function (cachedBlobInfo) { URL.revokeObjectURL(cachedBlobInfo.blobUri()) }) cache = [] } return { create: create, add: add, get: get, getByUri: getByUri, getByData: getByData, findFirst: findFirst, removeByUri: removeByUri, destroy: destroy, } } var Uploader = function (uploadStatus, settings) { var pendingPromises = {} var pathJoin = function (path1, path2) { if (path1) { return path1.replace(/\/$/, '') + '/' + path2.replace(/^\//, '') } return path2 } var defaultHandler = function (blobInfo, success, failure, progress) { var xhr = new XMLHttpRequest() xhr.open('POST', settings.url) xhr.withCredentials = settings.credentials xhr.upload.onprogress = function (e) { progress((e.loaded / e.total) * 100) } xhr.onerror = function () { failure( 'Image upload failed due to a XHR Transport error. Code: ' + xhr.status ) } xhr.onload = function () { if (xhr.status < 200 || xhr.status >= 300) { failure('HTTP Error: ' + xhr.status) return } var json = JSON.parse(xhr.responseText) if (!json || typeof json.location !== 'string') { failure('Invalid JSON: ' + xhr.responseText) return } success(pathJoin(settings.basePath, json.location)) } var formData = new FormData() formData.append('file', blobInfo.blob(), blobInfo.filename()) xhr.send(formData) } var noUpload = function () { return new promiseObj(function (resolve) { resolve([]) }) } var handlerSuccess = function (blobInfo, url) { return { url: url, blobInfo: blobInfo, status: true, } } var handlerFailure = function (blobInfo, message, options) { return { url: '', blobInfo: blobInfo, status: false, error: { message: message, options: options, }, } } var resolvePending = function (blobUri, result) { Tools.each(pendingPromises[blobUri], function (resolve) { resolve(result) }) delete pendingPromises[blobUri] } var uploadBlobInfo = function (blobInfo, handler, openNotification) { uploadStatus.markPending(blobInfo.blobUri()) return new promiseObj(function (resolve) { var notification, progress try { var closeNotification_1 = function () { if (notification) { notification.close() progress = noop } } var success = function (url) { closeNotification_1() uploadStatus.markUploaded(blobInfo.blobUri(), url) resolvePending(blobInfo.blobUri(), handlerSuccess(blobInfo, url)) resolve(handlerSuccess(blobInfo, url)) } var failure = function (error, options) { var failureOptions = options ? options : {} closeNotification_1() uploadStatus.removeFailed(blobInfo.blobUri()) resolvePending( blobInfo.blobUri(), handlerFailure(blobInfo, error, failureOptions) ) resolve(handlerFailure(blobInfo, error, failureOptions)) } progress = function (percent) { if (percent < 0 || percent > 100) { return } Optional.from(notification) .orThunk(function () { return Optional.from(openNotification).map(apply) }) .each(function (n) { notification = n n.progressBar.value(percent) }) } handler(blobInfo, success, failure, progress) } catch (ex) { resolve(handlerFailure(blobInfo, ex.message, {})) } }) } var isDefaultHandler = function (handler) { return handler === defaultHandler } var pendingUploadBlobInfo = function (blobInfo) { var blobUri = blobInfo.blobUri() return new promiseObj(function (resolve) { pendingPromises[blobUri] = pendingPromises[blobUri] || [] pendingPromises[blobUri].push(resolve) }) } var uploadBlobs = function (blobInfos, openNotification) { blobInfos = Tools.grep(blobInfos, function (blobInfo) { return !uploadStatus.isUploaded(blobInfo.blobUri()) }) return promiseObj.all( Tools.map(blobInfos, function (blobInfo) { return uploadStatus.isPending(blobInfo.blobUri()) ? pendingUploadBlobInfo(blobInfo) : uploadBlobInfo(blobInfo, settings.handler, openNotification) }) ) } var upload = function (blobInfos, openNotification) { return !settings.url && isDefaultHandler(settings.handler) ? noUpload() : uploadBlobs(blobInfos, openNotification) } if (isFunction(settings.handler) === false) { settings.handler = defaultHandler } return { upload: upload } } var openNotification = function (editor) { return function () { return editor.notificationManager.open({ text: editor.translate('Image uploading...'), type: 'info', timeout: -1, progressBar: true, }) } } var createUploader = function (editor, uploadStatus) { return Uploader(uploadStatus, { url: getImageUploadUrl(editor), basePath: getImageUploadBasePath(editor), credentials: getImagesUploadCredentials(editor), handler: getImagesUploadHandler(editor), }) } var ImageUploader = function (editor) { var uploadStatus = UploadStatus() var uploader = createUploader(editor, uploadStatus) return { upload: function (blobInfos, showNotification) { if (showNotification === void 0) { showNotification = true } return uploader.upload( blobInfos, showNotification ? openNotification(editor) : undefined ) }, } } var UploadChangeHandler = function (editor) { var lastChangedLevel = Cell(null) editor.on('change AddUndo', function (e) { lastChangedLevel.set(__assign({}, e.level)) }) var fireIfChanged = function () { var data = editor.undoManager.data last$2(data) .filter(function (level) { return !isEq$1(lastChangedLevel.get(), level) }) .each(function (level) { editor.setDirty(true) editor.fire('change', { level: level, lastLevel: get$a(data, data.length - 2).getOrNull(), }) }) } return { fireIfChanged: fireIfChanged } } var EditorUpload = function (editor) { var blobCache = BlobCache() var uploader, imageScanner var uploadStatus = UploadStatus() var urlFilters = [] var changeHandler = UploadChangeHandler(editor) var aliveGuard = function (callback) { return function (result) { if (editor.selection) { return callback(result) } return [] } } var cacheInvalidator = function (url) { return url + (url.indexOf('?') === -1 ? '?' : '&') + new Date().getTime() } var replaceString = function (content, search, replace) { var index = 0 do { index = content.indexOf(search, index) if (index !== -1) { content = content.substring(0, index) + replace + content.substr(index + search.length) index += replace.length - search.length + 1 } } while (index !== -1) return content } var replaceImageUrl = function (content, targetUrl, replacementUrl) { var replacementString = 'src="' + replacementUrl + '"' + (replacementUrl === Env.transparentSrc ? ' data-mce-placeholder="1"' : '') content = replaceString( content, 'src="' + targetUrl + '"', replacementString ) content = replaceString( content, 'data-mce-src="' + targetUrl + '"', 'data-mce-src="' + replacementUrl + '"' ) return content } var replaceUrlInUndoStack = function (targetUrl, replacementUrl) { each$k(editor.undoManager.data, function (level) { if (level.type === 'fragmented') { level.fragments = map$3(level.fragments, function (fragment) { return replaceImageUrl(fragment, targetUrl, replacementUrl) }) } else { level.content = replaceImageUrl( level.content, targetUrl, replacementUrl ) } }) } var replaceImageUriInView = function (image, resultUri) { var src = editor.convertURL(resultUri, 'src') replaceUrlInUndoStack(image.src, resultUri) editor.$(image).attr({ src: shouldReuseFileName(editor) ? cacheInvalidator(resultUri) : resultUri, 'data-mce-src': src, }) } var uploadImages = function (callback) { if (!uploader) { uploader = createUploader(editor, uploadStatus) } return scanForImages().then( aliveGuard(function (imageInfos) { var blobInfos = map$3(imageInfos, function (imageInfo) { return imageInfo.blobInfo }) return uploader.upload(blobInfos, openNotification(editor)).then( aliveGuard(function (result) { var imagesToRemove = [] var filteredResult = map$3(result, function (uploadInfo, index) { var blobInfo = imageInfos[index].blobInfo var image = imageInfos[index].image if (uploadInfo.status && shouldReplaceBlobUris(editor)) { blobCache.removeByUri(image.src) if (isRtc(editor)); else { replaceImageUriInView(image, uploadInfo.url) } } else if (uploadInfo.error) { if (uploadInfo.error.options.remove) { replaceUrlInUndoStack( image.getAttribute('src'), Env.transparentSrc ) imagesToRemove.push(image) } uploadError(editor, uploadInfo.error.message) } return { element: image, status: uploadInfo.status, uploadUri: uploadInfo.url, blobInfo: blobInfo, } }) if (filteredResult.length > 0) { changeHandler.fireIfChanged() } if (imagesToRemove.length > 0) { if (isRtc(editor)) { console.error( 'Removing images on failed uploads is currently unsupported for RTC' ) } else { editor.undoManager.transact(function () { each$k(imagesToRemove, function (element) { editor.dom.remove(element) blobCache.removeByUri(element.src) }) }) } } if (callback) { callback(filteredResult) } return filteredResult }) ) }) ) } var uploadImagesAuto = function (callback) { if (isAutomaticUploadsEnabled(editor)) { return uploadImages(callback) } } var isValidDataUriImage = function (imgElm) { if ( forall(urlFilters, function (filter) { return filter(imgElm) }) === false ) { return false } if (imgElm.getAttribute('src').indexOf('data:') === 0) { var dataImgFilter = getImagesDataImgFilter(editor) return dataImgFilter(imgElm) } return true } var addFilter = function (filter) { urlFilters.push(filter) } var scanForImages = function () { if (!imageScanner) { imageScanner = ImageScanner(uploadStatus, blobCache) } return imageScanner.findAll(editor.getBody(), isValidDataUriImage).then( aliveGuard(function (result) { result = filter$4(result, function (resultItem) { if (typeof resultItem === 'string') { displayError(editor, resultItem) return false } return true }) if (isRtc(editor)); else { each$k(result, function (resultItem) { replaceUrlInUndoStack( resultItem.image.src, resultItem.blobInfo.blobUri() ) resultItem.image.src = resultItem.blobInfo.blobUri() resultItem.image.removeAttribute('data-mce-src') }) } return result }) ) } var destroy = function () { blobCache.destroy() uploadStatus.destroy() imageScanner = uploader = null } var replaceBlobUris = function (content) { return content.replace(/src="(blob:[^"]+)"/g, function (match, blobUri) { var resultUri = uploadStatus.getResultUri(blobUri) if (resultUri) { return 'src="' + resultUri + '"' } var blobInfo = blobCache.getByUri(blobUri) if (!blobInfo) { blobInfo = foldl( editor.editorManager.get(), function (result, editor) { return ( result || (editor.editorUpload && editor.editorUpload.blobCache.getByUri(blobUri)) ) }, null ) } if (blobInfo) { var blob = blobInfo.blob() return 'src="data:' + blob.type + ';base64,' + blobInfo.base64() + '"' } return match }) } editor.on('SetContent', function () { if (isAutomaticUploadsEnabled(editor)) { uploadImagesAuto() } else { scanForImages() } }) editor.on('RawSaveContent', function (e) { e.content = replaceBlobUris(e.content) }) editor.on('GetContent', function (e) { if (e.source_view || e.format === 'raw' || e.format === 'tree') { return } e.content = replaceBlobUris(e.content) }) editor.on('PostRender', function () { editor.parser.addNodeFilter('img', function (images) { each$k(images, function (img) { var src = img.attr('src') if (blobCache.getByUri(src)) { return } var resultUri = uploadStatus.getResultUri(src) if (resultUri) { img.attr('src', resultUri) } }) }) }) return { blobCache: blobCache, addFilter: addFilter, uploadImages: uploadImages, uploadImagesAuto: uploadImagesAuto, scanForImages: scanForImages, destroy: destroy, } } var get = function (dom) { var formats = { valigntop: [ { selector: 'td,th', styles: { verticalAlign: 'top' }, }, ], valignmiddle: [ { selector: 'td,th', styles: { verticalAlign: 'middle' }, }, ], valignbottom: [ { selector: 'td,th', styles: { verticalAlign: 'bottom' }, }, ], alignleft: [ { selector: 'figure.image', collapsed: false, classes: 'align-left', ceFalseOverride: true, preview: 'font-family font-size', }, { selector: 'figure,p,h1,h2,h3,h4,h5,h6,td,th,tr,div,ul,ol,li', styles: { textAlign: 'left' }, inherit: false, preview: false, defaultBlock: 'div', }, { selector: 'img,table,audio,video', collapsed: false, styles: { float: 'left' }, preview: 'font-family font-size', }, ], aligncenter: [ { selector: 'figure,p,h1,h2,h3,h4,h5,h6,td,th,tr,div,ul,ol,li', styles: { textAlign: 'center' }, inherit: false, preview: 'font-family font-size', defaultBlock: 'div', }, { selector: 'figure.image', collapsed: false, classes: 'align-center', ceFalseOverride: true, preview: 'font-family font-size', }, { selector: 'img,audio,video', collapsed: false, styles: { display: 'block', marginLeft: 'auto', marginRight: 'auto', }, preview: false, }, { selector: 'table', collapsed: false, styles: { marginLeft: 'auto', marginRight: 'auto', }, preview: 'font-family font-size', }, ], alignright: [ { selector: 'figure.image', collapsed: false, classes: 'align-right', ceFalseOverride: true, preview: 'font-family font-size', }, { selector: 'figure,p,h1,h2,h3,h4,h5,h6,td,th,tr,div,ul,ol,li', styles: { textAlign: 'right' }, inherit: false, preview: 'font-family font-size', defaultBlock: 'div', }, { selector: 'img,table,audio,video', collapsed: false, styles: { float: 'right' }, preview: 'font-family font-size', }, ], alignjustify: [ { selector: 'figure,p,h1,h2,h3,h4,h5,h6,td,th,tr,div,ul,ol,li', styles: { textAlign: 'justify' }, inherit: false, defaultBlock: 'div', preview: 'font-family font-size', }, ], bold: [ { inline: 'strong', remove: 'all', preserve_attributes: ['class', 'style'], }, { inline: 'span', styles: { fontWeight: 'bold' }, }, { inline: 'b', remove: 'all', preserve_attributes: ['class', 'style'], }, ], italic: [ { inline: 'em', remove: 'all', preserve_attributes: ['class', 'style'], }, { inline: 'span', styles: { fontStyle: 'italic' }, }, { inline: 'i', remove: 'all', preserve_attributes: ['class', 'style'], }, ], underline: [ { inline: 'span', styles: { textDecoration: 'underline' }, exact: true, }, { inline: 'u', remove: 'all', preserve_attributes: ['class', 'style'], }, ], strikethrough: [ { inline: 'span', styles: { textDecoration: 'line-through' }, exact: true, }, { inline: 'strike', remove: 'all', preserve_attributes: ['class', 'style'], }, { inline: 's', remove: 'all', preserve_attributes: ['class', 'style'], }, ], forecolor: { inline: 'span', styles: { color: '%value' }, links: true, remove_similar: true, clear_child_styles: true, }, hilitecolor: { inline: 'span', styles: { backgroundColor: '%value' }, links: true, remove_similar: true, clear_child_styles: true, }, fontname: { inline: 'span', toggle: false, styles: { fontFamily: '%value' }, clear_child_styles: true, }, fontsize: { inline: 'span', toggle: false, styles: { fontSize: '%value' }, clear_child_styles: true, }, lineheight: { selector: 'h1,h2,h3,h4,h5,h6,p,li,td,th,div', defaultBlock: 'p', styles: { lineHeight: '%value' }, }, fontsize_class: { inline: 'span', attributes: { class: '%value' }, }, blockquote: { block: 'blockquote', wrapper: true, remove: 'all', }, subscript: { inline: 'sub' }, superscript: { inline: 'sup' }, code: { inline: 'code' }, link: { inline: 'a', selector: 'a', remove: 'all', split: true, deep: true, onmatch: function (node, _fmt, _itemName) { return isElement$5(node) && node.hasAttribute('href') }, onformat: function (elm, _fmt, vars) { Tools.each(vars, function (value, key) { dom.setAttrib(elm, key, value) }) }, }, lang: { inline: 'span', clear_child_styles: true, remove_similar: true, attributes: { lang: '%value', 'data-mce-lang': function (vars) { var _a return (_a = vars === null || vars === void 0 ? void 0 : vars.customValue) !== null && _a !== void 0 ? _a : null }, }, }, removeformat: [ { selector: 'b,strong,em,i,font,u,strike,s,sub,sup,dfn,code,samp,kbd,var,cite,mark,q,del,ins,small', remove: 'all', split: true, expand: false, block_expand: true, deep: true, }, { selector: 'span', attributes: ['style', 'class'], remove: 'empty', split: true, expand: false, deep: true, }, { selector: '*', attributes: ['style', 'class'], split: false, expand: false, deep: true, }, ], } Tools.each( 'p h1 h2 h3 h4 h5 h6 div address pre dt dd samp'.split(/\s/), function (name) { formats[name] = { block: name, remove: 'all', } } ) return formats } var FormatRegistry = function (editor) { var formats = {} var get$1 = function (name) { return isNonNullable(name) ? formats[name] : formats } var has = function (name) { return has$2(formats, name) } var register = function (name, format) { if (name) { if (!isString$1(name)) { each$j(name, function (format, name) { register(name, format) }) } else { if (!isArray$1(format)) { format = [format] } each$k(format, function (format) { if (isUndefined(format.deep)) { format.deep = !isSelectorFormat(format) } if (isUndefined(format.split)) { format.split = !isSelectorFormat(format) || isInlineFormat(format) } if ( isUndefined(format.remove) && isSelectorFormat(format) && !isInlineFormat(format) ) { format.remove = 'none' } if (isSelectorFormat(format) && isInlineFormat(format)) { format.mixed = true format.block_expand = true } if (isString$1(format.classes)) { format.classes = format.classes.split(/\s+/) } }) formats[name] = format } } } var unregister = function (name) { if (name && formats[name]) { delete formats[name] } return formats } register(get(editor.dom)) register(getFormats(editor)) return { get: get$1, has: has, register: register, unregister: unregister, } } var each$5 = Tools.each var dom = DOMUtils.DOM var parsedSelectorToHtml = function (ancestry, editor) { var elm, item, fragment var schema = (editor && editor.schema) || Schema({}) var decorate = function (elm, item) { if (item.classes.length) { dom.addClass(elm, item.classes.join(' ')) } dom.setAttribs(elm, item.attrs) } var createElement = function (sItem) { item = typeof sItem === 'string' ? { name: sItem, classes: [], attrs: {}, } : sItem var elm = dom.create(item.name) decorate(elm, item) return elm } var getRequiredParent = function (elm, candidate) { var name = typeof elm !== 'string' ? elm.nodeName.toLowerCase() : elm var elmRule = schema.getElementRule(name) var parentsRequired = elmRule && elmRule.parentsRequired if (parentsRequired && parentsRequired.length) { return candidate && Tools.inArray(parentsRequired, candidate) !== -1 ? candidate : parentsRequired[0] } else { return false } } var wrapInHtml = function (elm, ancestry, siblings) { var parent, parentCandidate var ancestor = ancestry.length > 0 && ancestry[0] var ancestorName = ancestor && ancestor.name var parentRequired = getRequiredParent(elm, ancestorName) if (parentRequired) { if (ancestorName === parentRequired) { parentCandidate = ancestry[0] ancestry = ancestry.slice(1) } else { parentCandidate = parentRequired } } else if (ancestor) { parentCandidate = ancestry[0] ancestry = ancestry.slice(1) } else if (!siblings) { return elm } if (parentCandidate) { parent = createElement(parentCandidate) parent.appendChild(elm) } if (siblings) { if (!parent) { parent = dom.create('div') parent.appendChild(elm) } Tools.each(siblings, function (sibling) { var siblingElm = createElement(sibling) parent.insertBefore(siblingElm, elm) }) } return wrapInHtml( parent, ancestry, parentCandidate && parentCandidate.siblings ) } if (ancestry && ancestry.length) { item = ancestry[0] elm = createElement(item) fragment = dom.create('div') fragment.appendChild(wrapInHtml(elm, ancestry.slice(1), item.siblings)) return fragment } else { return '' } } var parseSelectorItem = function (item) { var tagName var obj = { classes: [], attrs: {}, } item = obj.selector = Tools.trim(item) if (item !== '*') { tagName = item.replace( /(?:([#\.]|::?)([\w\-]+)|(\[)([^\]]+)\]?)/g, function ($0, $1, $2, $3, $4) { switch ($1) { case '#': obj.attrs.id = $2 break case '.': obj.classes.push($2) break case ':': if ( Tools.inArray( 'checked disabled enabled read-only required'.split(' '), $2 ) !== -1 ) { obj.attrs[$2] = $2 } break } if ($3 === '[') { var m = $4.match(/([\w\-]+)(?:\=\"([^\"]+))?/) if (m) { obj.attrs[m[1]] = m[2] } } return '' } ) } obj.name = tagName || 'div' return obj } var parseSelector = function (selector) { if (!selector || typeof selector !== 'string') { return [] } selector = selector.split(/\s*,\s*/)[0] selector = selector.replace(/\s*(~\+|~|\+|>)\s*/g, '$1') return Tools.map( selector.split(/(?:>|\s+(?![^\[\]]+\]))/), function (item) { var siblings = Tools.map(item.split(/(?:~\+|~|\+)/), parseSelectorItem) var obj = siblings.pop() if (siblings.length) { obj.siblings = siblings } return obj } ).reverse() } var getCssText = function (editor, format) { var name, previewFrag var previewCss = '', parentFontSize var previewStyles = getPreviewStyles(editor) if (previewStyles === '') { return '' } var removeVars = function (val) { return val.replace(/%(\w+)/g, '') } if (typeof format === 'string') { format = editor.formatter.get(format) if (!format) { return } format = format[0] } if ('preview' in format) { var previewOpt = get$9(format, 'preview') if (is$1(previewOpt, false)) { return '' } else { previewStyles = previewOpt.getOr(previewStyles) } } name = format.block || format.inline || 'span' var items = parseSelector(format.selector) if (items.length) { if (!items[0].name) { items[0].name = name } name = format.selector previewFrag = parsedSelectorToHtml(items, editor) } else { previewFrag = parsedSelectorToHtml([name], editor) } var previewElm = dom.select(name, previewFrag)[0] || previewFrag.firstChild each$5(format.styles, function (value, name) { var newValue = removeVars(value) if (newValue) { dom.setStyle(previewElm, name, newValue) } }) each$5(format.attributes, function (value, name) { var newValue = removeVars(value) if (newValue) { dom.setAttrib(previewElm, name, newValue) } }) each$5(format.classes, function (value) { var newValue = removeVars(value) if (!dom.hasClass(previewElm, newValue)) { dom.addClass(previewElm, newValue) } }) editor.fire('PreviewFormats') dom.setStyles(previewFrag, { position: 'absolute', left: -65535, }) editor.getBody().appendChild(previewFrag) parentFontSize = dom.getStyle(editor.getBody(), 'fontSize', true) parentFontSize = /px$/.test(parentFontSize) ? parseInt(parentFontSize, 10) : 0 each$5(previewStyles.split(' '), function (name) { var value = dom.getStyle(previewElm, name, true) if ( name === 'background-color' && /transparent|rgba\s*\([^)]+,\s*0\)/.test(value) ) { value = dom.getStyle(editor.getBody(), name, true) if (dom.toHex(value).toLowerCase() === '#ffffff') { return } } if (name === 'color') { if (dom.toHex(value).toLowerCase() === '#000000') { return } } if (name === 'font-size') { if (/em|%$/.test(value)) { if (parentFontSize === 0) { return } var numValue = parseFloat(value) / (/%$/.test(value) ? 100 : 1) value = numValue * parentFontSize + 'px' } } if (name === 'border' && value) { previewCss += 'padding:0 2px;' } previewCss += name + ':' + value + ';' }) editor.fire('AfterPreviewFormats') dom.remove(previewFrag) return previewCss } var setup$h = function (editor) { editor.addShortcut('meta+b', '', 'Bold') editor.addShortcut('meta+i', '', 'Italic') editor.addShortcut('meta+u', '', 'Underline') for (var i = 1; i <= 6; i++) { editor.addShortcut('access+' + i, '', ['FormatBlock', false, 'h' + i]) } editor.addShortcut('access+7', '', ['FormatBlock', false, 'p']) editor.addShortcut('access+8', '', ['FormatBlock', false, 'div']) editor.addShortcut('access+9', '', ['FormatBlock', false, 'address']) } var Formatter = function (editor) { var formats = FormatRegistry(editor) var formatChangeState = Cell(null) setup$h(editor) setup$k(editor) return { get: formats.get, has: formats.has, register: formats.register, unregister: formats.unregister, apply: function (name, vars, node) { applyFormat(editor, name, vars, node) }, remove: function (name, vars, node, similar) { removeFormat(editor, name, vars, node, similar) }, toggle: function (name, vars, node) { toggleFormat(editor, name, vars, node) }, match: function (name, vars, node, similar) { return matchFormat(editor, name, vars, node, similar) }, closest: function (names) { return closestFormat(editor, names) }, matchAll: function (names, vars) { return matchAllFormats(editor, names, vars) }, matchNode: function (node, name, vars, similar) { return matchNodeFormat(editor, node, name, vars, similar) }, canApply: function (name) { return canApplyFormat(editor, name) }, formatChanged: function (formats, callback, similar, vars) { return formatChanged( editor, formatChangeState, formats, callback, similar, vars ) }, getCssText: curry(getCssText, editor), } } var shouldIgnoreCommand = function (cmd) { switch (cmd.toLowerCase()) { case 'undo': case 'redo': case 'mcerepaint': case 'mcefocus': return true default: return false } } var registerEvents = function (editor, undoManager, locks) { var isFirstTypedCharacter = Cell(false) var addNonTypingUndoLevel = function (e) { setTyping(undoManager, false, locks) undoManager.add({}, e) } editor.on('init', function () { undoManager.add() }) editor.on('BeforeExecCommand', function (e) { var cmd = e.command if (!shouldIgnoreCommand(cmd)) { endTyping(undoManager, locks) undoManager.beforeChange() } }) editor.on('ExecCommand', function (e) { var cmd = e.command if (!shouldIgnoreCommand(cmd)) { addNonTypingUndoLevel(e) } }) editor.on('ObjectResizeStart cut', function () { undoManager.beforeChange() }) editor.on('SaveContent ObjectResized blur', addNonTypingUndoLevel) editor.on('dragend', addNonTypingUndoLevel) editor.on('keyup', function (e) { var keyCode = e.keyCode if (e.isDefaultPrevented()) { return } if ( (keyCode >= 33 && keyCode <= 36) || (keyCode >= 37 && keyCode <= 40) || keyCode === 45 || e.ctrlKey ) { addNonTypingUndoLevel() editor.nodeChanged() } if (keyCode === 46 || keyCode === 8) { editor.nodeChanged() } if ( isFirstTypedCharacter.get() && undoManager.typing && isEq$1(createFromEditor(editor), undoManager.data[0]) === false ) { if (editor.isDirty() === false) { editor.setDirty(true) editor.fire('change', { level: undoManager.data[0], lastLevel: null, }) } editor.fire('TypingUndo') isFirstTypedCharacter.set(false) editor.nodeChanged() } }) editor.on('keydown', function (e) { var keyCode = e.keyCode if (e.isDefaultPrevented()) { return } if ( (keyCode >= 33 && keyCode <= 36) || (keyCode >= 37 && keyCode <= 40) || keyCode === 45 ) { if (undoManager.typing) { addNonTypingUndoLevel(e) } return } var modKey = (e.ctrlKey && !e.altKey) || e.metaKey if ( (keyCode < 16 || keyCode > 20) && keyCode !== 224 && keyCode !== 91 && !undoManager.typing && !modKey ) { undoManager.beforeChange() setTyping(undoManager, true, locks) undoManager.add({}, e) isFirstTypedCharacter.set(true) } }) editor.on('mousedown', function (e) { if (undoManager.typing) { addNonTypingUndoLevel(e) } }) var isInsertReplacementText = function (event) { return event.inputType === 'insertReplacementText' } var isInsertTextDataNull = function (event) { return event.inputType === 'insertText' && event.data === null } var isInsertFromPasteOrDrop = function (event) { return ( event.inputType === 'insertFromPaste' || event.inputType === 'insertFromDrop' ) } editor.on('input', function (e) { if ( e.inputType && (isInsertReplacementText(e) || isInsertTextDataNull(e) || isInsertFromPasteOrDrop(e)) ) { addNonTypingUndoLevel(e) } }) editor.on('AddUndo Undo Redo ClearUndos', function (e) { if (!e.isDefaultPrevented()) { editor.nodeChanged() } }) } var addKeyboardShortcuts = function (editor) { editor.addShortcut('meta+z', '', 'Undo') editor.addShortcut('meta+y,meta+shift+z', '', 'Redo') } var UndoManager = function (editor) { var beforeBookmark = value() var locks = Cell(0) var index = Cell(0) var undoManager = { data: [], typing: false, beforeChange: function () { beforeChange(editor, locks, beforeBookmark) }, add: function (level, event) { return addUndoLevel( editor, undoManager, index, locks, beforeBookmark, level, event ) }, undo: function () { return undo(editor, undoManager, locks, index) }, redo: function () { return redo(editor, index, undoManager.data) }, clear: function () { clear(editor, undoManager, index) }, reset: function () { reset(editor, undoManager) }, hasUndo: function () { return hasUndo(editor, undoManager, index) }, hasRedo: function () { return hasRedo(editor, undoManager, index) }, transact: function (callback) { return transact(editor, undoManager, locks, callback) }, ignore: function (callback) { ignore(editor, locks, callback) }, extra: function (callback1, callback2) { extra(editor, undoManager, index, callback1, callback2) }, } if (!isRtc(editor)) { registerEvents(editor, undoManager, locks) } addKeyboardShortcuts(editor) return undoManager } var nonTypingKeycodes = [ 9, 27, VK.HOME, VK.END, 19, 20, 44, 144, 145, 33, 34, 45, 16, 17, 18, 91, 92, 93, VK.DOWN, VK.UP, VK.LEFT, VK.RIGHT, ].concat(Env.browser.isFirefox() ? [224] : []) var placeholderAttr = 'data-mce-placeholder' var isKeyboardEvent = function (e) { return e.type === 'keydown' || e.type === 'keyup' } var isDeleteEvent = function (e) { var keyCode = e.keyCode return keyCode === VK.BACKSPACE || keyCode === VK.DELETE } var isNonTypingKeyboardEvent = function (e) { if (isKeyboardEvent(e)) { var keyCode = e.keyCode return ( !isDeleteEvent(e) && (VK.metaKeyPressed(e) || e.altKey || (keyCode >= 112 && keyCode <= 123) || contains$3(nonTypingKeycodes, keyCode)) ) } else { return false } } var isTypingKeyboardEvent = function (e) { return ( isKeyboardEvent(e) && !(isDeleteEvent(e) || (e.type === 'keyup' && e.keyCode === 229)) ) } var isVisuallyEmpty = function (dom, rootElm, forcedRootBlock) { if (isEmpty$2(SugarElement.fromDom(rootElm), false)) { var isForcedRootBlockFalse = forcedRootBlock === '' var firstElement = rootElm.firstElementChild if (!firstElement) { return true } else if ( dom.getStyle(rootElm.firstElementChild, 'padding-left') || dom.getStyle(rootElm.firstElementChild, 'padding-right') ) { return false } else { return isForcedRootBlockFalse ? !dom.isBlock(firstElement) : forcedRootBlock === firstElement.nodeName.toLowerCase() } } else { return false } } var setup$g = function (editor) { var dom = editor.dom var rootBlock = getForcedRootBlock(editor) var placeholder = getPlaceholder(editor) var updatePlaceholder = function (e, initial) { if (isNonTypingKeyboardEvent(e)) { return } var body = editor.getBody() var showPlaceholder = isTypingKeyboardEvent(e) ? false : isVisuallyEmpty(dom, body, rootBlock) var isPlaceholderShown = dom.getAttrib(body, placeholderAttr) !== '' if (isPlaceholderShown !== showPlaceholder || initial) { dom.setAttrib( body, placeholderAttr, showPlaceholder ? placeholder : null ) dom.setAttrib( body, 'aria-placeholder', showPlaceholder ? placeholder : null ) firePlaceholderToggle(editor, showPlaceholder) editor.on(showPlaceholder ? 'keydown' : 'keyup', updatePlaceholder) editor.off(showPlaceholder ? 'keyup' : 'keydown', updatePlaceholder) } } if (placeholder) { editor.on('init', function (e) { updatePlaceholder(e, true) editor.on('change SetContent ExecCommand', updatePlaceholder) editor.on('paste', function (e) { return Delay.setEditorTimeout(editor, function () { return updatePlaceholder(e) }) }) }) } } var strongRtl = /[\u0591-\u07FF\uFB1D-\uFDFF\uFE70-\uFEFC]/ var hasStrongRtl = function (text) { return strongRtl.test(text) } var isInlineTarget = function (editor, elm) { return is$2(SugarElement.fromDom(elm), getInlineBoundarySelector(editor)) } var isRtl = function (element) { return ( DOMUtils.DOM.getStyle(element, 'direction', true) === 'rtl' || hasStrongRtl(element.textContent) ) } var findInlineParents = function (isInlineTarget, rootNode, pos) { return filter$4( DOMUtils.DOM.getParents(pos.container(), '*', rootNode), isInlineTarget ) } var findRootInline = function (isInlineTarget, rootNode, pos) { var parents = findInlineParents(isInlineTarget, rootNode, pos) return Optional.from(parents[parents.length - 1]) } var hasSameParentBlock = function (rootNode, node1, node2) { var block1 = getParentBlock$2(node1, rootNode) var block2 = getParentBlock$2(node2, rootNode) return block1 && block1 === block2 } var isAtZwsp = function (pos) { return isBeforeInline(pos) || isAfterInline(pos) } var normalizePosition = function (forward, pos) { if (!pos) { return pos } var container = pos.container(), offset = pos.offset() if (forward) { if (isCaretContainerInline(container)) { if (isText$7(container.nextSibling)) { return CaretPosition(container.nextSibling, 0) } else { return CaretPosition.after(container) } } else { return isBeforeInline(pos) ? CaretPosition(container, offset + 1) : pos } } else { if (isCaretContainerInline(container)) { if (isText$7(container.previousSibling)) { return CaretPosition( container.previousSibling, container.previousSibling.data.length ) } else { return CaretPosition.before(container) } } else { return isAfterInline(pos) ? CaretPosition(container, offset - 1) : pos } } } var normalizeForwards = curry(normalizePosition, true) var normalizeBackwards = curry(normalizePosition, false) var isBeforeRoot = function (rootNode) { return function (elm) { return eq(rootNode, SugarElement.fromDom(elm.dom.parentNode)) } } var isTextBlockOrListItem = function (element) { return isTextBlock$2(element) || isListItem(element) } var getParentBlock$1 = function (rootNode, elm) { if (contains$1(rootNode, elm)) { return closest$3(elm, isTextBlockOrListItem, isBeforeRoot(rootNode)) } else { return Optional.none() } } var placeCaretInEmptyBody = function (editor) { var body = editor.getBody() var node = body.firstChild && editor.dom.isBlock(body.firstChild) ? body.firstChild : body editor.selection.setCursorLocation(node, 0) } var paddEmptyBody = function (editor) { if (editor.dom.isEmpty(editor.getBody())) { editor.setContent('') placeCaretInEmptyBody(editor) } } var willDeleteLastPositionInElement = function (forward, fromPos, elm) { return lift2( firstPositionIn(elm), lastPositionIn(elm), function (firstPos, lastPos) { var normalizedFirstPos = normalizePosition(true, firstPos) var normalizedLastPos = normalizePosition(false, lastPos) var normalizedFromPos = normalizePosition(false, fromPos) if (forward) { return nextPosition(elm, normalizedFromPos).exists(function ( nextPos ) { return ( nextPos.isEqual(normalizedLastPos) && fromPos.isEqual(normalizedFirstPos) ) }) } else { return prevPosition(elm, normalizedFromPos).exists(function ( prevPos ) { return ( prevPos.isEqual(normalizedFirstPos) && fromPos.isEqual(normalizedLastPos) ) }) } } ).getOr(true) } var blockPosition = function (block, position) { return { block: block, position: position, } } var blockBoundary = function (from, to) { return { from: from, to: to, } } var getBlockPosition = function (rootNode, pos) { var rootElm = SugarElement.fromDom(rootNode) var containerElm = SugarElement.fromDom(pos.container()) return getParentBlock$1(rootElm, containerElm).map(function (block) { return blockPosition(block, pos) }) } var isDifferentBlocks = function (blockBoundary) { return eq(blockBoundary.from.block, blockBoundary.to.block) === false } var hasSameParent = function (blockBoundary) { return parent(blockBoundary.from.block) .bind(function (parent1) { return parent(blockBoundary.to.block).filter(function (parent2) { return eq(parent1, parent2) }) }) .isSome() } var isEditable$1 = function (blockBoundary) { return ( isContentEditableFalse$b(blockBoundary.from.block.dom) === false && isContentEditableFalse$b(blockBoundary.to.block.dom) === false ) } var skipLastBr = function (rootNode, forward, blockPosition) { if ( isBr$5(blockPosition.position.getNode()) && isEmpty$2(blockPosition.block) === false ) { return positionIn(false, blockPosition.block.dom) .bind(function (lastPositionInBlock) { if (lastPositionInBlock.isEqual(blockPosition.position)) { return fromPosition(forward, rootNode, lastPositionInBlock).bind( function (to) { return getBlockPosition(rootNode, to) } ) } else { return Optional.some(blockPosition) } }) .getOr(blockPosition) } else { return blockPosition } } var readFromRange = function (rootNode, forward, rng) { var fromBlockPos = getBlockPosition( rootNode, CaretPosition.fromRangeStart(rng) ) var toBlockPos = fromBlockPos.bind(function (blockPos) { return fromPosition(forward, rootNode, blockPos.position).bind(function ( to ) { return getBlockPosition(rootNode, to).map(function (blockPos) { return skipLastBr(rootNode, forward, blockPos) }) }) }) return lift2(fromBlockPos, toBlockPos, blockBoundary).filter(function ( blockBoundary ) { return ( isDifferentBlocks(blockBoundary) && hasSameParent(blockBoundary) && isEditable$1(blockBoundary) ) }) } var read$1 = function (rootNode, forward, rng) { return rng.collapsed ? readFromRange(rootNode, forward, rng) : Optional.none() } var getChildrenUntilBlockBoundary = function (block) { var children$1 = children(block) return findIndex$2(children$1, isBlock$2).fold( constant(children$1), function (index) { return children$1.slice(0, index) } ) } var extractChildren = function (block) { var children = getChildrenUntilBlockBoundary(block) each$k(children, remove$7) return children } var removeEmptyRoot = function (rootNode, block) { var parents = parentsAndSelf(block, rootNode) return find$3(parents.reverse(), function (element) { return isEmpty$2(element) }).each(remove$7) } var isEmptyBefore = function (el) { return ( filter$4(prevSiblings(el), function (el) { return !isEmpty$2(el) }).length === 0 ) } var nestedBlockMerge = function ( rootNode, fromBlock, toBlock, insertionPoint ) { if (isEmpty$2(toBlock)) { fillWithPaddingBr(toBlock) return firstPositionIn(toBlock.dom) } if (isEmptyBefore(insertionPoint) && isEmpty$2(fromBlock)) { before$4(insertionPoint, SugarElement.fromTag('br')) } var position = prevPosition( toBlock.dom, CaretPosition.before(insertionPoint.dom) ) each$k(extractChildren(fromBlock), function (child) { before$4(insertionPoint, child) }) removeEmptyRoot(rootNode, fromBlock) return position } var sidelongBlockMerge = function (rootNode, fromBlock, toBlock) { if (isEmpty$2(toBlock)) { remove$7(toBlock) if (isEmpty$2(fromBlock)) { fillWithPaddingBr(fromBlock) } return firstPositionIn(fromBlock.dom) } var position = lastPositionIn(toBlock.dom) each$k(extractChildren(fromBlock), function (child) { append$1(toBlock, child) }) removeEmptyRoot(rootNode, fromBlock) return position } var findInsertionPoint = function (toBlock, block) { var parentsAndSelf$1 = parentsAndSelf(block, toBlock) return Optional.from(parentsAndSelf$1[parentsAndSelf$1.length - 1]) } var getInsertionPoint = function (fromBlock, toBlock) { return contains$1(toBlock, fromBlock) ? findInsertionPoint(toBlock, fromBlock) : Optional.none() } var trimBr = function (first, block) { positionIn(first, block.dom) .map(function (position) { return position.getNode() }) .map(SugarElement.fromDom) .filter(isBr$4) .each(remove$7) } var mergeBlockInto = function (rootNode, fromBlock, toBlock) { trimBr(true, fromBlock) trimBr(false, toBlock) return getInsertionPoint(fromBlock, toBlock).fold( curry(sidelongBlockMerge, rootNode, fromBlock, toBlock), curry(nestedBlockMerge, rootNode, fromBlock, toBlock) ) } var mergeBlocks = function (rootNode, forward, block1, block2) { return forward ? mergeBlockInto(rootNode, block2, block1) : mergeBlockInto(rootNode, block1, block2) } var backspaceDelete$8 = function (editor, forward) { var rootNode = SugarElement.fromDom(editor.getBody()) var position = read$1( rootNode.dom, forward, editor.selection.getRng() ).bind(function (blockBoundary) { return mergeBlocks( rootNode, forward, blockBoundary.from.block, blockBoundary.to.block ) }) position.each(function (pos) { editor.selection.setRng(pos.toRange()) }) return position.isSome() } var deleteRangeMergeBlocks = function (rootNode, selection) { var rng = selection.getRng() return lift2( getParentBlock$1(rootNode, SugarElement.fromDom(rng.startContainer)), getParentBlock$1(rootNode, SugarElement.fromDom(rng.endContainer)), function (block1, block2) { if (eq(block1, block2) === false) { rng.deleteContents() mergeBlocks(rootNode, true, block1, block2).each(function (pos) { selection.setRng(pos.toRange()) }) return true } else { return false } } ).getOr(false) } var isRawNodeInTable = function (root, rawNode) { var node = SugarElement.fromDom(rawNode) var isRoot = curry(eq, root) return ancestor$3(node, isTableCell$4, isRoot).isSome() } var isSelectionInTable = function (root, rng) { return ( isRawNodeInTable(root, rng.startContainer) || isRawNodeInTable(root, rng.endContainer) ) } var isEverythingSelected = function (root, rng) { var noPrevious = prevPosition( root.dom, CaretPosition.fromRangeStart(rng) ).isNone() var noNext = nextPosition( root.dom, CaretPosition.fromRangeEnd(rng) ).isNone() return !isSelectionInTable(root, rng) && noPrevious && noNext } var emptyEditor = function (editor) { editor.setContent('') editor.selection.setCursorLocation() return true } var deleteRange$1 = function (editor) { var rootNode = SugarElement.fromDom(editor.getBody()) var rng = editor.selection.getRng() return isEverythingSelected(rootNode, rng) ? emptyEditor(editor) : deleteRangeMergeBlocks(rootNode, editor.selection) } var backspaceDelete$7 = function (editor, _forward) { return editor.selection.isCollapsed() ? false : deleteRange$1(editor) } var isContentEditableTrue$2 = isContentEditableTrue$4 var isContentEditableFalse$4 = isContentEditableFalse$b var showCaret = function (direction, editor, node, before, scrollIntoView) { return Optional.from( editor._selectionOverrides.showCaret( direction, node, before, scrollIntoView ) ) } var getNodeRange = function (node) { var rng = node.ownerDocument.createRange() rng.selectNode(node) return rng } var selectNode = function (editor, node) { var e = editor.fire('BeforeObjectSelected', { target: node }) if (e.isDefaultPrevented()) { return Optional.none() } return Optional.some(getNodeRange(node)) } var renderCaretAtRange = function (editor, range, scrollIntoView) { var normalizedRange = normalizeRange(1, editor.getBody(), range) var caretPosition = CaretPosition.fromRangeStart(normalizedRange) var caretPositionNode = caretPosition.getNode() if (isInlineFakeCaretTarget(caretPositionNode)) { return showCaret( 1, editor, caretPositionNode, !caretPosition.isAtEnd(), false ) } var caretPositionBeforeNode = caretPosition.getNode(true) if (isInlineFakeCaretTarget(caretPositionBeforeNode)) { return showCaret(1, editor, caretPositionBeforeNode, false, false) } var ceRoot = editor.dom.getParent(caretPosition.getNode(), function (node) { return isContentEditableFalse$4(node) || isContentEditableTrue$2(node) }) if (isInlineFakeCaretTarget(ceRoot)) { return showCaret(1, editor, ceRoot, false, scrollIntoView) } return Optional.none() } var renderRangeCaret = function (editor, range, scrollIntoView) { return range.collapsed ? renderCaretAtRange(editor, range, scrollIntoView).getOr(range) : range } var isBeforeBoundary = function (pos) { return isBeforeContentEditableFalse(pos) || isBeforeMedia(pos) } var isAfterBoundary = function (pos) { return isAfterContentEditableFalse(pos) || isAfterMedia(pos) } var trimEmptyTextNode = function (dom, node) { if (isText$7(node) && node.data.length === 0) { dom.remove(node) } } var deleteContentAndShowCaret = function ( editor, range, node, direction, forward, peekCaretPosition ) { showCaret( direction, editor, peekCaretPosition.getNode(!forward), forward, true ).each(function (caretRange) { if (range.collapsed) { var deleteRange = range.cloneRange() if (forward) { deleteRange.setEnd(caretRange.startContainer, caretRange.startOffset) } else { deleteRange.setStart(caretRange.endContainer, caretRange.endOffset) } deleteRange.deleteContents() } else { range.deleteContents() } editor.selection.setRng(caretRange) }) trimEmptyTextNode(editor.dom, node) return true } var deleteBoundaryText = function (editor, forward) { var range = editor.selection.getRng() if (!isText$7(range.commonAncestorContainer)) { return false } var direction = forward ? HDirection.Forwards : HDirection.Backwards var caretWalker = CaretWalker(editor.getBody()) var getNextPosFn = curry( getVisualCaretPosition, forward ? caretWalker.next : caretWalker.prev ) var isBeforeFn = forward ? isBeforeBoundary : isAfterBoundary var caretPosition = getNormalizedRangeEndPoint( direction, editor.getBody(), range ) var nextCaretPosition = normalizePosition( forward, getNextPosFn(caretPosition) ) if ( !nextCaretPosition || !isMoveInsideSameBlock(caretPosition, nextCaretPosition) ) { return false } else if (isBeforeFn(nextCaretPosition)) { return deleteContentAndShowCaret( editor, range, caretPosition.getNode(), direction, forward, nextCaretPosition ) } var peekCaretPosition = getNextPosFn(nextCaretPosition) if (peekCaretPosition && isBeforeFn(peekCaretPosition)) { if (isMoveInsideSameBlock(nextCaretPosition, peekCaretPosition)) { return deleteContentAndShowCaret( editor, range, caretPosition.getNode(), direction, forward, peekCaretPosition ) } } return false } var backspaceDelete$6 = function (editor, forward) { return deleteBoundaryText(editor, forward) } var isCompoundElement = function (node) { return ( isTableCell$4(SugarElement.fromDom(node)) || isListItem(SugarElement.fromDom(node)) ) } var DeleteAction = Adt.generate([ { remove: ['element'] }, { moveToElement: ['element'] }, { moveToPosition: ['position'] }, ]) var isAtContentEditableBlockCaret = function (forward, from) { var elm = from.getNode(forward === false) var caretLocation = forward ? 'after' : 'before' return ( isElement$5(elm) && elm.getAttribute('data-mce-caret') === caretLocation ) } var isDeleteFromCefDifferentBlocks = function (root, forward, from, to) { var inSameBlock = function (elm) { return ( isInline$1(SugarElement.fromDom(elm)) && !isInSameBlock(from, to, root) ) } return getRelativeCefElm(!forward, from).fold(function () { return getRelativeCefElm(forward, to).fold(never, inSameBlock) }, inSameBlock) } var deleteEmptyBlockOrMoveToCef = function (root, forward, from, to) { var toCefElm = to.getNode(forward === false) return getParentBlock$1( SugarElement.fromDom(root), SugarElement.fromDom(from.getNode()) ) .map(function (blockElm) { return isEmpty$2(blockElm) ? DeleteAction.remove(blockElm.dom) : DeleteAction.moveToElement(toCefElm) }) .orThunk(function () { return Optional.some(DeleteAction.moveToElement(toCefElm)) }) } var findCefPosition = function (root, forward, from) { return fromPosition(forward, root, from).bind(function (to) { if (isCompoundElement(to.getNode())) { return Optional.none() } else if (isDeleteFromCefDifferentBlocks(root, forward, from, to)) { return Optional.none() } else if (forward && isContentEditableFalse$b(to.getNode())) { return deleteEmptyBlockOrMoveToCef(root, forward, from, to) } else if ( forward === false && isContentEditableFalse$b(to.getNode(true)) ) { return deleteEmptyBlockOrMoveToCef(root, forward, from, to) } else if (forward && isAfterContentEditableFalse(from)) { return Optional.some(DeleteAction.moveToPosition(to)) } else if (forward === false && isBeforeContentEditableFalse(from)) { return Optional.some(DeleteAction.moveToPosition(to)) } else { return Optional.none() } }) } var getContentEditableBlockAction = function (forward, elm) { if (forward && isContentEditableFalse$b(elm.nextSibling)) { return Optional.some(DeleteAction.moveToElement(elm.nextSibling)) } else if ( forward === false && isContentEditableFalse$b(elm.previousSibling) ) { return Optional.some(DeleteAction.moveToElement(elm.previousSibling)) } else { return Optional.none() } } var skipMoveToActionFromInlineCefToContent = function ( root, from, deleteAction ) { return deleteAction.fold( function (elm) { return Optional.some(DeleteAction.remove(elm)) }, function (elm) { return Optional.some(DeleteAction.moveToElement(elm)) }, function (to) { if (isInSameBlock(from, to, root)) { return Optional.none() } else { return Optional.some(DeleteAction.moveToPosition(to)) } } ) } var getContentEditableAction = function (root, forward, from) { if (isAtContentEditableBlockCaret(forward, from)) { return getContentEditableBlockAction( forward, from.getNode(forward === false) ).fold(function () { return findCefPosition(root, forward, from) }, Optional.some) } else { return findCefPosition(root, forward, from).bind(function (deleteAction) { return skipMoveToActionFromInlineCefToContent(root, from, deleteAction) }) } } var read = function (root, forward, rng) { var normalizedRange = normalizeRange(forward ? 1 : -1, root, rng) var from = CaretPosition.fromRangeStart(normalizedRange) var rootElement = SugarElement.fromDom(root) if (forward === false && isAfterContentEditableFalse(from)) { return Optional.some(DeleteAction.remove(from.getNode(true))) } else if (forward && isBeforeContentEditableFalse(from)) { return Optional.some(DeleteAction.remove(from.getNode())) } else if ( forward === false && isBeforeContentEditableFalse(from) && isAfterBr(rootElement, from) ) { return findPreviousBr(rootElement, from).map(function (br) { return DeleteAction.remove(br.getNode()) }) } else if ( forward && isAfterContentEditableFalse(from) && isBeforeBr$1(rootElement, from) ) { return findNextBr(rootElement, from).map(function (br) { return DeleteAction.remove(br.getNode()) }) } else { return getContentEditableAction(root, forward, from) } } var deleteElement$1 = function (editor, forward) { return function (element) { editor._selectionOverrides.hideFakeCaret() deleteElement$2(editor, forward, SugarElement.fromDom(element)) return true } } var moveToElement = function (editor, forward) { return function (element) { var pos = forward ? CaretPosition.before(element) : CaretPosition.after(element) editor.selection.setRng(pos.toRange()) return true } } var moveToPosition = function (editor) { return function (pos) { editor.selection.setRng(pos.toRange()) return true } } var getAncestorCe = function (editor, node) { return Optional.from(getContentEditableRoot$1(editor.getBody(), node)) } var backspaceDeleteCaret = function (editor, forward) { var selectedNode = editor.selection.getNode() return getAncestorCe(editor, selectedNode) .filter(isContentEditableFalse$b) .fold(function () { return read( editor.getBody(), forward, editor.selection.getRng() ).exists(function (deleteAction) { return deleteAction.fold( deleteElement$1(editor, forward), moveToElement(editor, forward), moveToPosition(editor) ) }) }, always) } var deleteOffscreenSelection = function (rootElement) { each$k(descendants(rootElement, '.mce-offscreen-selection'), remove$7) } var backspaceDeleteRange = function (editor, forward) { var selectedNode = editor.selection.getNode() if ( isContentEditableFalse$b(selectedNode) && !isTableCell$5(selectedNode) ) { var hasCefAncestor = getAncestorCe( editor, selectedNode.parentNode ).filter(isContentEditableFalse$b) return hasCefAncestor.fold(function () { deleteOffscreenSelection(SugarElement.fromDom(editor.getBody())) deleteElement$2( editor, forward, SugarElement.fromDom(editor.selection.getNode()) ) paddEmptyBody(editor) return true }, always) } return false } var paddEmptyElement = function (editor) { var dom = editor.dom, selection = editor.selection var ceRoot = getContentEditableRoot$1(editor.getBody(), selection.getNode()) if ( isContentEditableTrue$4(ceRoot) && dom.isBlock(ceRoot) && dom.isEmpty(ceRoot) ) { var br = dom.create('br', { 'data-mce-bogus': '1' }) dom.setHTML(ceRoot, '') ceRoot.appendChild(br) selection.setRng(CaretPosition.before(br).toRange()) } return true } var backspaceDelete$5 = function (editor, forward) { if (editor.selection.isCollapsed()) { return backspaceDeleteCaret(editor, forward) } else { return backspaceDeleteRange(editor, forward) } } var deleteCaret$2 = function (editor, forward) { var fromPos = CaretPosition.fromRangeStart(editor.selection.getRng()) return fromPosition(forward, editor.getBody(), fromPos) .filter(function (pos) { return forward ? isBeforeImageBlock(pos) : isAfterImageBlock(pos) }) .bind(function (pos) { return Optional.from( getChildNodeAtRelativeOffset(forward ? 0 : -1, pos) ) }) .exists(function (elm) { editor.selection.select(elm) return true }) } var backspaceDelete$4 = function (editor, forward) { return editor.selection.isCollapsed() ? deleteCaret$2(editor, forward) : false } var isText = isText$7 var startsWithCaretContainer = function (node) { return isText(node) && node.data[0] === ZWSP$1 } var endsWithCaretContainer = function (node) { return isText(node) && node.data[node.data.length - 1] === ZWSP$1 } var createZwsp = function (node) { return node.ownerDocument.createTextNode(ZWSP$1) } var insertBefore = function (node) { if (isText(node.previousSibling)) { if (endsWithCaretContainer(node.previousSibling)) { return node.previousSibling } else { node.previousSibling.appendData(ZWSP$1) return node.previousSibling } } else if (isText(node)) { if (startsWithCaretContainer(node)) { return node } else { node.insertData(0, ZWSP$1) return node } } else { var newNode = createZwsp(node) node.parentNode.insertBefore(newNode, node) return newNode } } var insertAfter = function (node) { if (isText(node.nextSibling)) { if (startsWithCaretContainer(node.nextSibling)) { return node.nextSibling } else { node.nextSibling.insertData(0, ZWSP$1) return node.nextSibling } } else if (isText(node)) { if (endsWithCaretContainer(node)) { return node } else { node.appendData(ZWSP$1) return node } } else { var newNode = createZwsp(node) if (node.nextSibling) { node.parentNode.insertBefore(newNode, node.nextSibling) } else { node.parentNode.appendChild(newNode) } return newNode } } var insertInline = function (before, node) { return before ? insertBefore(node) : insertAfter(node) } var insertInlineBefore = curry(insertInline, true) var insertInlineAfter = curry(insertInline, false) var insertInlinePos = function (pos, before) { if (isText$7(pos.container())) { return insertInline(before, pos.container()) } else { return insertInline(before, pos.getNode()) } } var isPosCaretContainer = function (pos, caret) { var caretNode = caret.get() return ( caretNode && pos.container() === caretNode && isCaretContainerInline(caretNode) ) } var renderCaret = function (caret, location) { return location.fold( function (element) { remove$2(caret.get()) var text = insertInlineBefore(element) caret.set(text) return Optional.some(CaretPosition(text, text.length - 1)) }, function (element) { return firstPositionIn(element).map(function (pos) { if (!isPosCaretContainer(pos, caret)) { remove$2(caret.get()) var text = insertInlinePos(pos, true) caret.set(text) return CaretPosition(text, 1) } else { return CaretPosition(caret.get(), 1) } }) }, function (element) { return lastPositionIn(element).map(function (pos) { if (!isPosCaretContainer(pos, caret)) { remove$2(caret.get()) var text = insertInlinePos(pos, false) caret.set(text) return CaretPosition(text, text.length - 1) } else { return CaretPosition(caret.get(), caret.get().length - 1) } }) }, function (element) { remove$2(caret.get()) var text = insertInlineAfter(element) caret.set(text) return Optional.some(CaretPosition(text, 1)) } ) } var evaluateUntil = function (fns, args) { for (var i = 0; i < fns.length; i++) { var result = fns[i].apply(null, args) if (result.isSome()) { return result } } return Optional.none() } var Location = Adt.generate([ { before: ['element'] }, { start: ['element'] }, { end: ['element'] }, { after: ['element'] }, ]) var rescope$1 = function (rootNode, node) { var parentBlock = getParentBlock$2(node, rootNode) return parentBlock ? parentBlock : rootNode } var before = function (isInlineTarget, rootNode, pos) { var nPos = normalizeForwards(pos) var scope = rescope$1(rootNode, nPos.container()) return findRootInline(isInlineTarget, scope, nPos).fold(function () { return nextPosition(scope, nPos) .bind(curry(findRootInline, isInlineTarget, scope)) .map(function (inline) { return Location.before(inline) }) }, Optional.none) } var isNotInsideFormatCaretContainer = function (rootNode, elm) { return getParentCaretContainer(rootNode, elm) === null } var findInsideRootInline = function (isInlineTarget, rootNode, pos) { return findRootInline(isInlineTarget, rootNode, pos).filter( curry(isNotInsideFormatCaretContainer, rootNode) ) } var start$1 = function (isInlineTarget, rootNode, pos) { var nPos = normalizeBackwards(pos) return findInsideRootInline(isInlineTarget, rootNode, nPos).bind(function ( inline ) { var prevPos = prevPosition(inline, nPos) return prevPos.isNone() ? Optional.some(Location.start(inline)) : Optional.none() }) } var end = function (isInlineTarget, rootNode, pos) { var nPos = normalizeForwards(pos) return findInsideRootInline(isInlineTarget, rootNode, nPos).bind(function ( inline ) { var nextPos = nextPosition(inline, nPos) return nextPos.isNone() ? Optional.some(Location.end(inline)) : Optional.none() }) } var after = function (isInlineTarget, rootNode, pos) { var nPos = normalizeBackwards(pos) var scope = rescope$1(rootNode, nPos.container()) return findRootInline(isInlineTarget, scope, nPos).fold(function () { return prevPosition(scope, nPos) .bind(curry(findRootInline, isInlineTarget, scope)) .map(function (inline) { return Location.after(inline) }) }, Optional.none) } var isValidLocation = function (location) { return isRtl(getElement(location)) === false } var readLocation = function (isInlineTarget, rootNode, pos) { var location = evaluateUntil( [before, start$1, end, after], [isInlineTarget, rootNode, pos] ) return location.filter(isValidLocation) } var getElement = function (location) { return location.fold(identity, identity, identity, identity) } var getName = function (location) { return location.fold( constant('before'), constant('start'), constant('end'), constant('after') ) } var outside = function (location) { return location.fold( Location.before, Location.before, Location.after, Location.after ) } var inside = function (location) { return location.fold( Location.start, Location.start, Location.end, Location.end ) } var isEq = function (location1, location2) { return ( getName(location1) === getName(location2) && getElement(location1) === getElement(location2) ) } var betweenInlines = function ( forward, isInlineTarget, rootNode, from, to, location ) { return lift2( findRootInline(isInlineTarget, rootNode, from), findRootInline(isInlineTarget, rootNode, to), function (fromInline, toInline) { if ( fromInline !== toInline && hasSameParentBlock(rootNode, fromInline, toInline) ) { return Location.after(forward ? fromInline : toInline) } else { return location } } ).getOr(location) } var skipNoMovement = function (fromLocation, toLocation) { return fromLocation.fold(always, function (fromLocation) { return !isEq(fromLocation, toLocation) }) } var findLocationTraverse = function ( forward, isInlineTarget, rootNode, fromLocation, pos ) { var from = normalizePosition(forward, pos) var to = fromPosition(forward, rootNode, from).map( curry(normalizePosition, forward) ) var location = to.fold( function () { return fromLocation.map(outside) }, function (to) { return readLocation(isInlineTarget, rootNode, to) .map( curry(betweenInlines, forward, isInlineTarget, rootNode, from, to) ) .filter(curry(skipNoMovement, fromLocation)) } ) return location.filter(isValidLocation) } var findLocationSimple = function (forward, location) { if (forward) { return location.fold( compose(Optional.some, Location.start), Optional.none, compose(Optional.some, Location.after), Optional.none ) } else { return location.fold( Optional.none, compose(Optional.some, Location.before), Optional.none, compose(Optional.some, Location.end) ) } } var findLocation$1 = function (forward, isInlineTarget, rootNode, pos) { var from = normalizePosition(forward, pos) var fromLocation = readLocation(isInlineTarget, rootNode, from) return readLocation(isInlineTarget, rootNode, from) .bind(curry(findLocationSimple, forward)) .orThunk(function () { return findLocationTraverse( forward, isInlineTarget, rootNode, fromLocation, pos ) }) } curry(findLocation$1, false) curry(findLocation$1, true) var hasSelectionModifyApi = function (editor) { return isFunction(editor.selection.getSel().modify) } var moveRel = function (forward, selection, pos) { var delta = forward ? 1 : -1 selection.setRng( CaretPosition(pos.container(), pos.offset() + delta).toRange() ) selection.getSel().modify('move', forward ? 'forward' : 'backward', 'word') return true } var moveByWord = function (forward, editor) { var rng = editor.selection.getRng() var pos = forward ? CaretPosition.fromRangeEnd(rng) : CaretPosition.fromRangeStart(rng) if (!hasSelectionModifyApi(editor)) { return false } else if (forward && isBeforeInline(pos)) { return moveRel(true, editor.selection, pos) } else if (!forward && isAfterInline(pos)) { return moveRel(false, editor.selection, pos) } else { return false } } var BreakType ;(function (BreakType) { BreakType[(BreakType['Br'] = 0)] = 'Br' BreakType[(BreakType['Block'] = 1)] = 'Block' BreakType[(BreakType['Wrap'] = 2)] = 'Wrap' BreakType[(BreakType['Eol'] = 3)] = 'Eol' })(BreakType || (BreakType = {})) var flip = function (direction, positions) { return direction === HDirection.Backwards ? reverse(positions) : positions } var walk = function (direction, caretWalker, pos) { return direction === HDirection.Forwards ? caretWalker.next(pos) : caretWalker.prev(pos) } var getBreakType = function (scope, direction, currentPos, nextPos) { if (isBr$5(nextPos.getNode(direction === HDirection.Forwards))) { return BreakType.Br } else if (isInSameBlock(currentPos, nextPos) === false) { return BreakType.Block } else { return BreakType.Wrap } } var getPositionsUntil = function (predicate, direction, scope, start) { var caretWalker = CaretWalker(scope) var currentPos = start var positions = [] while (currentPos) { var nextPos = walk(direction, caretWalker, currentPos) if (!nextPos) { break } if (isBr$5(nextPos.getNode(false))) { if (direction === HDirection.Forwards) { return { positions: flip(direction, positions).concat([nextPos]), breakType: BreakType.Br, breakAt: Optional.some(nextPos), } } else { return { positions: flip(direction, positions), breakType: BreakType.Br, breakAt: Optional.some(nextPos), } } } if (!nextPos.isVisible()) { currentPos = nextPos continue } if (predicate(currentPos, nextPos)) { var breakType = getBreakType(scope, direction, currentPos, nextPos) return { positions: flip(direction, positions), breakType: breakType, breakAt: Optional.some(nextPos), } } positions.push(nextPos) currentPos = nextPos } return { positions: flip(direction, positions), breakType: BreakType.Eol, breakAt: Optional.none(), } } var getAdjacentLinePositions = function ( direction, getPositionsUntilBreak, scope, start ) { return getPositionsUntilBreak(scope, start) .breakAt.map(function (pos) { var positions = getPositionsUntilBreak(scope, pos).positions return direction === HDirection.Backwards ? positions.concat(pos) : [pos].concat(positions) }) .getOr([]) } var findClosestHorizontalPositionFromPoint = function (positions, x) { return foldl( positions, function (acc, newPos) { return acc.fold( function () { return Optional.some(newPos) }, function (lastPos) { return lift2( head(lastPos.getClientRects()), head(newPos.getClientRects()), function (lastRect, newRect) { var lastDist = Math.abs(x - lastRect.left) var newDist = Math.abs(x - newRect.left) return newDist <= lastDist ? newPos : lastPos } ).or(acc) } ) }, Optional.none() ) } var findClosestHorizontalPosition = function (positions, pos) { return head(pos.getClientRects()).bind(function (targetRect) { return findClosestHorizontalPositionFromPoint(positions, targetRect.left) }) } var getPositionsUntilPreviousLine = curry( getPositionsUntil, CaretPosition.isAbove, -1 ) var getPositionsUntilNextLine = curry( getPositionsUntil, CaretPosition.isBelow, 1 ) var getPositionsAbove = curry( getAdjacentLinePositions, -1, getPositionsUntilPreviousLine ) var getPositionsBelow = curry( getAdjacentLinePositions, 1, getPositionsUntilNextLine ) var isAtFirstLine = function (scope, pos) { return getPositionsUntilPreviousLine(scope, pos).breakAt.isNone() } var isAtLastLine = function (scope, pos) { return getPositionsUntilNextLine(scope, pos).breakAt.isNone() } var getFirstLinePositions = function (scope) { return firstPositionIn(scope) .map(function (pos) { return [pos].concat(getPositionsUntilNextLine(scope, pos).positions) }) .getOr([]) } var getLastLinePositions = function (scope) { return lastPositionIn(scope) .map(function (pos) { return getPositionsUntilPreviousLine(scope, pos).positions.concat(pos) }) .getOr([]) } var getNodeClientRects = function (node) { var toArrayWithNode = function (clientRects) { return map$3(clientRects, function (rect) { var clientRect = clone(rect) clientRect.node = node return clientRect }) } if (isElement$5(node)) { return toArrayWithNode(node.getClientRects()) } if (isText$7(node)) { var rng = node.ownerDocument.createRange() rng.setStart(node, 0) rng.setEnd(node, node.data.length) return toArrayWithNode(rng.getClientRects()) } } var getClientRects = function (nodes) { return bind(nodes, getNodeClientRects) } var VDirection ;(function (VDirection) { VDirection[(VDirection['Up'] = -1)] = 'Up' VDirection[(VDirection['Down'] = 1)] = 'Down' })(VDirection || (VDirection = {})) var findUntil = function (direction, root, predicateFn, node) { while ( (node = findNode$1(node, direction, isEditableCaretCandidate$1, root)) ) { if (predicateFn(node)) { return } } } var walkUntil$1 = function ( direction, isAboveFn, isBeflowFn, root, predicateFn, caretPosition ) { var line = 0 var result = [] var add = function (node) { var clientRects = getClientRects([node]) if (direction === -1) { clientRects = clientRects.reverse() } for (var i = 0; i < clientRects.length; i++) { var clientRect = clientRects[i] if (isBeflowFn(clientRect, targetClientRect)) { continue } if (result.length > 0 && isAboveFn(clientRect, last$1(result))) { line++ } clientRect.line = line if (predicateFn(clientRect)) { return true } result.push(clientRect) } } var targetClientRect = last$1(caretPosition.getClientRects()) if (!targetClientRect) { return result } var node = caretPosition.getNode() add(node) findUntil(direction, root, add, node) return result } var aboveLineNumber = function (lineNumber, clientRect) { return clientRect.line > lineNumber } var isLineNumber = function (lineNumber, clientRect) { return clientRect.line === lineNumber } var upUntil = curry(walkUntil$1, VDirection.Up, isAbove$1, isBelow$1) var downUntil = curry(walkUntil$1, VDirection.Down, isBelow$1, isAbove$1) var positionsUntil = function (direction, root, predicateFn, node) { var caretWalker = CaretWalker(root) var walkFn var isBelowFn var isAboveFn var caretPosition var result = [] var line = 0 var getClientRect = function (caretPosition) { if (direction === 1) { return last$1(caretPosition.getClientRects()) } return last$1(caretPosition.getClientRects()) } if (direction === 1) { walkFn = caretWalker.next isBelowFn = isBelow$1 isAboveFn = isAbove$1 caretPosition = CaretPosition.after(node) } else { walkFn = caretWalker.prev isBelowFn = isAbove$1 isAboveFn = isBelow$1 caretPosition = CaretPosition.before(node) } var targetClientRect = getClientRect(caretPosition) do { if (!caretPosition.isVisible()) { continue } var rect = getClientRect(caretPosition) if (isAboveFn(rect, targetClientRect)) { continue } if (result.length > 0 && isBelowFn(rect, last$1(result))) { line++ } var clientRect = clone(rect) clientRect.position = caretPosition clientRect.line = line if (predicateFn(clientRect)) { return result } result.push(clientRect) } while ((caretPosition = walkFn(caretPosition))) return result } var isAboveLine = function (lineNumber) { return function (clientRect) { return aboveLineNumber(lineNumber, clientRect) } } var isLine = function (lineNumber) { return function (clientRect) { return isLineNumber(lineNumber, clientRect) } } var isContentEditableFalse$3 = isContentEditableFalse$b var findNode = findNode$1 var distanceToRectLeft = function (clientRect, clientX) { return Math.abs(clientRect.left - clientX) } var distanceToRectRight = function (clientRect, clientX) { return Math.abs(clientRect.right - clientX) } var isInsideX = function (clientX, clientRect) { return clientX >= clientRect.left && clientX <= clientRect.right } var isInsideY = function (clientY, clientRect) { return clientY >= clientRect.top && clientY <= clientRect.bottom } var isNodeClientRect = function (rect) { return hasNonNullableKey(rect, 'node') } var findClosestClientRect = function (clientRects, clientX, allowInside) { if (allowInside === void 0) { allowInside = always } return reduce(clientRects, function (oldClientRect, clientRect) { if (isInsideX(clientX, clientRect)) { return allowInside(clientRect) ? clientRect : oldClientRect } if (isInsideX(clientX, oldClientRect)) { return allowInside(oldClientRect) ? oldClientRect : clientRect } var oldDistance = Math.min( distanceToRectLeft(oldClientRect, clientX), distanceToRectRight(oldClientRect, clientX) ) var newDistance = Math.min( distanceToRectLeft(clientRect, clientX), distanceToRectRight(clientRect, clientX) ) if ( newDistance === oldDistance && isNodeClientRect(clientRect) && isContentEditableFalse$3(clientRect.node) ) { return clientRect } if (newDistance < oldDistance) { return clientRect } return oldClientRect }) } var walkUntil = function ( direction, root, predicateFn, startNode, includeChildren ) { var node = findNode( startNode, direction, isEditableCaretCandidate$1, root, !includeChildren ) do { if (!node || predicateFn(node)) { return } } while ( (node = findNode(node, direction, isEditableCaretCandidate$1, root)) ) } var findLineNodeRects = function (root, targetNodeRect, includeChildren) { if (includeChildren === void 0) { includeChildren = true } var clientRects = [] var collect = function (checkPosFn, node) { var lineRects = filter$4(getClientRects([node]), function (clientRect) { return !checkPosFn(clientRect, targetNodeRect) }) clientRects = clientRects.concat(lineRects) return lineRects.length === 0 } clientRects.push(targetNodeRect) walkUntil( VDirection.Up, root, curry(collect, isAbove$1), targetNodeRect.node, includeChildren ) walkUntil( VDirection.Down, root, curry(collect, isBelow$1), targetNodeRect.node, includeChildren ) return clientRects } var getFakeCaretTargets = function (root) { return filter$4(from(root.getElementsByTagName('*')), isFakeCaretTarget) } var caretInfo = function (clientRect, clientX) { return { node: clientRect.node, before: distanceToRectLeft(clientRect, clientX) < distanceToRectRight(clientRect, clientX), } } var closestFakeCaret = function (root, clientX, clientY) { var fakeTargetNodeRects = getClientRects(getFakeCaretTargets(root)) var targetNodeRects = filter$4( fakeTargetNodeRects, curry(isInsideY, clientY) ) var checkInside = function (clientRect) { return !isTable$3(clientRect.node) && !isMedia$2(clientRect.node) } var closestNodeRect = findClosestClientRect( targetNodeRects, clientX, checkInside ) if (closestNodeRect) { var includeChildren = checkInside(closestNodeRect) closestNodeRect = findClosestClientRect( findLineNodeRects(root, closestNodeRect, includeChildren), clientX, checkInside ) if (closestNodeRect && isFakeCaretTarget(closestNodeRect.node)) { return caretInfo(closestNodeRect, clientX) } } return null } var moveToRange = function (editor, rng) { editor.selection.setRng(rng) scrollRangeIntoView(editor, editor.selection.getRng()) } var renderRangeCaretOpt = function (editor, range, scrollIntoView) { return Optional.some(renderRangeCaret(editor, range, scrollIntoView)) } var moveHorizontally = function ( editor, direction, range, isBefore, isAfter, isElement ) { var forwards = direction === HDirection.Forwards var caretWalker = CaretWalker(editor.getBody()) var getNextPosFn = curry( getVisualCaretPosition, forwards ? caretWalker.next : caretWalker.prev ) var isBeforeFn = forwards ? isBefore : isAfter if (!range.collapsed) { var node = getSelectedNode(range) if (isElement(node)) { return showCaret( direction, editor, node, direction === HDirection.Backwards, false ) } } var caretPosition = getNormalizedRangeEndPoint( direction, editor.getBody(), range ) if (isBeforeFn(caretPosition)) { return selectNode(editor, caretPosition.getNode(!forwards)) } var nextCaretPosition = normalizePosition( forwards, getNextPosFn(caretPosition) ) var rangeIsInContainerBlock = isRangeInCaretContainerBlock(range) if (!nextCaretPosition) { return rangeIsInContainerBlock ? Optional.some(range) : Optional.none() } if (isBeforeFn(nextCaretPosition)) { return showCaret( direction, editor, nextCaretPosition.getNode(!forwards), forwards, false ) } var peekCaretPosition = getNextPosFn(nextCaretPosition) if (peekCaretPosition && isBeforeFn(peekCaretPosition)) { if (isMoveInsideSameBlock(nextCaretPosition, peekCaretPosition)) { return showCaret( direction, editor, peekCaretPosition.getNode(!forwards), forwards, false ) } } if (rangeIsInContainerBlock) { return renderRangeCaretOpt(editor, nextCaretPosition.toRange(), false) } return Optional.none() } var moveVertically = function ( editor, direction, range, isBefore, isAfter, isElement ) { var caretPosition = getNormalizedRangeEndPoint( direction, editor.getBody(), range ) var caretClientRect = last$1(caretPosition.getClientRects()) var forwards = direction === VDirection.Down if (!caretClientRect) { return Optional.none() } var walkerFn = forwards ? downUntil : upUntil var linePositions = walkerFn( editor.getBody(), isAboveLine(1), caretPosition ) var nextLinePositions = filter$4(linePositions, isLine(1)) var clientX = caretClientRect.left var nextLineRect = findClosestClientRect(nextLinePositions, clientX) if (nextLineRect && isElement(nextLineRect.node)) { var dist1 = Math.abs(clientX - nextLineRect.left) var dist2 = Math.abs(clientX - nextLineRect.right) return showCaret( direction, editor, nextLineRect.node, dist1 < dist2, false ) } var currentNode if (isBefore(caretPosition)) { currentNode = caretPosition.getNode() } else if (isAfter(caretPosition)) { currentNode = caretPosition.getNode(true) } else { currentNode = getSelectedNode(range) } if (currentNode) { var caretPositions = positionsUntil( direction, editor.getBody(), isAboveLine(1), currentNode ) var closestNextLineRect = findClosestClientRect( filter$4(caretPositions, isLine(1)), clientX ) if (closestNextLineRect) { return renderRangeCaretOpt( editor, closestNextLineRect.position.toRange(), false ) } closestNextLineRect = last$1(filter$4(caretPositions, isLine(0))) if (closestNextLineRect) { return renderRangeCaretOpt( editor, closestNextLineRect.position.toRange(), false ) } } if (nextLinePositions.length === 0) { return getLineEndPoint(editor, forwards) .filter(forwards ? isAfter : isBefore) .map(function (pos) { return renderRangeCaret(editor, pos.toRange(), false) }) } return Optional.none() } var getLineEndPoint = function (editor, forward) { var rng = editor.selection.getRng() var body = editor.getBody() if (forward) { var from = CaretPosition.fromRangeEnd(rng) var result = getPositionsUntilNextLine(body, from) return last$2(result.positions) } else { var from = CaretPosition.fromRangeStart(rng) var result = getPositionsUntilPreviousLine(body, from) return head(result.positions) } } var moveToLineEndPoint$3 = function (editor, forward, isElementPosition) { return getLineEndPoint(editor, forward) .filter(isElementPosition) .exists(function (pos) { editor.selection.setRng(pos.toRange()) return true }) } var setCaretPosition = function (editor, pos) { var rng = editor.dom.createRng() rng.setStart(pos.container(), pos.offset()) rng.setEnd(pos.container(), pos.offset()) editor.selection.setRng(rng) } var setSelected = function (state, elm) { if (state) { elm.setAttribute('data-mce-selected', 'inline-boundary') } else { elm.removeAttribute('data-mce-selected') } } var renderCaretLocation = function (editor, caret, location) { return renderCaret(caret, location).map(function (pos) { setCaretPosition(editor, pos) return location }) } var findLocation = function (editor, caret, forward) { var rootNode = editor.getBody() var from = CaretPosition.fromRangeStart(editor.selection.getRng()) var isInlineTarget$1 = curry(isInlineTarget, editor) var location = findLocation$1(forward, isInlineTarget$1, rootNode, from) return location.bind(function (location) { return renderCaretLocation(editor, caret, location) }) } var toggleInlines = function (isInlineTarget, dom, elms) { var inlineBoundaries = map$3( descendants( SugarElement.fromDom(dom.getRoot()), '*[data-mce-selected="inline-boundary"]' ), function (e) { return e.dom } ) var selectedInlines = filter$4(inlineBoundaries, isInlineTarget) var targetInlines = filter$4(elms, isInlineTarget) each$k( difference(selectedInlines, targetInlines), curry(setSelected, false) ) each$k(difference(targetInlines, selectedInlines), curry(setSelected, true)) } var safeRemoveCaretContainer = function (editor, caret) { if ( editor.selection.isCollapsed() && editor.composing !== true && caret.get() ) { var pos = CaretPosition.fromRangeStart(editor.selection.getRng()) if (CaretPosition.isTextPosition(pos) && isAtZwsp(pos) === false) { setCaretPosition(editor, removeAndReposition(caret.get(), pos)) caret.set(null) } } } var renderInsideInlineCaret = function (isInlineTarget, editor, caret, elms) { if (editor.selection.isCollapsed()) { var inlines = filter$4(elms, isInlineTarget) each$k(inlines, function (_inline) { var pos = CaretPosition.fromRangeStart(editor.selection.getRng()) readLocation(isInlineTarget, editor.getBody(), pos).bind(function ( location ) { return renderCaretLocation(editor, caret, location) }) }) } } var move$2 = function (editor, caret, forward) { return isInlineBoundariesEnabled(editor) ? findLocation(editor, caret, forward).isSome() : false } var moveWord = function (forward, editor, _caret) { return isInlineBoundariesEnabled(editor) ? moveByWord(forward, editor) : false } var setupSelectedState = function (editor) { var caret = Cell(null) var isInlineTarget$1 = curry(isInlineTarget, editor) editor.on('NodeChange', function (e) { if ( isInlineBoundariesEnabled(editor) && !(Env.browser.isIE() && e.initial) ) { toggleInlines(isInlineTarget$1, editor.dom, e.parents) safeRemoveCaretContainer(editor, caret) renderInsideInlineCaret(isInlineTarget$1, editor, caret, e.parents) } }) return caret } var moveNextWord = curry(moveWord, true) var movePrevWord = curry(moveWord, false) var moveToLineEndPoint$2 = function (editor, forward, caret) { if (isInlineBoundariesEnabled(editor)) { var linePoint = getLineEndPoint(editor, forward).getOrThunk(function () { var rng = editor.selection.getRng() return forward ? CaretPosition.fromRangeEnd(rng) : CaretPosition.fromRangeStart(rng) }) return readLocation( curry(isInlineTarget, editor), editor.getBody(), linePoint ).exists(function (loc) { var outsideLoc = outside(loc) return renderCaret(caret, outsideLoc).exists(function (pos) { setCaretPosition(editor, pos) return true }) }) } else { return false } } var rangeFromPositions = function (from, to) { var range = document.createRange() range.setStart(from.container(), from.offset()) range.setEnd(to.container(), to.offset()) return range } var hasOnlyTwoOrLessPositionsLeft = function (elm) { return lift2( firstPositionIn(elm), lastPositionIn(elm), function (firstPos, lastPos) { var normalizedFirstPos = normalizePosition(true, firstPos) var normalizedLastPos = normalizePosition(false, lastPos) return nextPosition(elm, normalizedFirstPos).forall(function (pos) { return pos.isEqual(normalizedLastPos) }) } ).getOr(true) } var setCaretLocation = function (editor, caret) { return function (location) { return renderCaret(caret, location).exists(function (pos) { setCaretPosition(editor, pos) return true }) } } var deleteFromTo = function (editor, caret, from, to) { var rootNode = editor.getBody() var isInlineTarget$1 = curry(isInlineTarget, editor) editor.undoManager.ignore(function () { editor.selection.setRng(rangeFromPositions(from, to)) editor.execCommand('Delete') readLocation( isInlineTarget$1, rootNode, CaretPosition.fromRangeStart(editor.selection.getRng()) ) .map(inside) .map(setCaretLocation(editor, caret)) }) editor.nodeChanged() } var rescope = function (rootNode, node) { var parentBlock = getParentBlock$2(node, rootNode) return parentBlock ? parentBlock : rootNode } var backspaceDeleteCollapsed = function (editor, caret, forward, from) { var rootNode = rescope(editor.getBody(), from.container()) var isInlineTarget$1 = curry(isInlineTarget, editor) var fromLocation = readLocation(isInlineTarget$1, rootNode, from) return fromLocation .bind(function (location) { if (forward) { return location.fold( constant(Optional.some(inside(location))), Optional.none, constant(Optional.some(outside(location))), Optional.none ) } else { return location.fold( Optional.none, constant(Optional.some(outside(location))), Optional.none, constant(Optional.some(inside(location))) ) } }) .map(setCaretLocation(editor, caret)) .getOrThunk(function () { var toPosition = navigate(forward, rootNode, from) var toLocation = toPosition.bind(function (pos) { return readLocation(isInlineTarget$1, rootNode, pos) }) return lift2(fromLocation, toLocation, function () { return findRootInline(isInlineTarget$1, rootNode, from).exists( function (elm) { if (hasOnlyTwoOrLessPositionsLeft(elm)) { deleteElement$2(editor, forward, SugarElement.fromDom(elm)) return true } else { return false } } ) }) .orThunk(function () { return toLocation.bind(function (_) { return toPosition.map(function (to) { if (forward) { deleteFromTo(editor, caret, from, to) } else { deleteFromTo(editor, caret, to, from) } return true }) }) }) .getOr(false) }) } var backspaceDelete$3 = function (editor, caret, forward) { if (editor.selection.isCollapsed() && isInlineBoundariesEnabled(editor)) { var from = CaretPosition.fromRangeStart(editor.selection.getRng()) return backspaceDeleteCollapsed(editor, caret, forward, from) } return false } var getParentInlines = function (rootElm, startElm) { var parents = parentsAndSelf(startElm, rootElm) return findIndex$2(parents, isBlock$2).fold( constant(parents), function (index) { return parents.slice(0, index) } ) } var hasOnlyOneChild = function (elm) { return childNodesCount(elm) === 1 } var deleteLastPosition = function (forward, editor, target, parentInlines) { var isFormatElement$1 = curry(isFormatElement, editor) var formatNodes = map$3( filter$4(parentInlines, isFormatElement$1), function (elm) { return elm.dom } ) if (formatNodes.length === 0) { deleteElement$2(editor, forward, target) } else { var pos = replaceWithCaretFormat(target.dom, formatNodes) editor.selection.setRng(pos.toRange()) } } var deleteCaret$1 = function (editor, forward) { var rootElm = SugarElement.fromDom(editor.getBody()) var startElm = SugarElement.fromDom(editor.selection.getStart()) var parentInlines = filter$4( getParentInlines(rootElm, startElm), hasOnlyOneChild ) return last$2(parentInlines).exists(function (target) { var fromPos = CaretPosition.fromRangeStart(editor.selection.getRng()) if ( willDeleteLastPositionInElement(forward, fromPos, target.dom) && !isEmptyCaretFormatElement(target) ) { deleteLastPosition(forward, editor, target, parentInlines) return true } else { return false } }) } var backspaceDelete$2 = function (editor, forward) { return editor.selection.isCollapsed() ? deleteCaret$1(editor, forward) : false } var deleteElement = function (editor, forward, element) { editor._selectionOverrides.hideFakeCaret() deleteElement$2(editor, forward, SugarElement.fromDom(element)) return true } var deleteCaret = function (editor, forward) { var isNearMedia = forward ? isBeforeMedia : isAfterMedia var direction = forward ? HDirection.Forwards : HDirection.Backwards var fromPos = getNormalizedRangeEndPoint( direction, editor.getBody(), editor.selection.getRng() ) if (isNearMedia(fromPos)) { return deleteElement(editor, forward, fromPos.getNode(!forward)) } else { return Optional.from(normalizePosition(forward, fromPos)) .filter(function (pos) { return isNearMedia(pos) && isMoveInsideSameBlock(fromPos, pos) }) .exists(function (pos) { return deleteElement(editor, forward, pos.getNode(!forward)) }) } } var deleteRange = function (editor, forward) { var selectedNode = editor.selection.getNode() return isMedia$2(selectedNode) ? deleteElement(editor, forward, selectedNode) : false } var backspaceDelete$1 = function (editor, forward) { return editor.selection.isCollapsed() ? deleteCaret(editor, forward) : deleteRange(editor, forward) } var isEditable = function (target) { return closest$3(target, function (elm) { return ( isContentEditableTrue$4(elm.dom) || isContentEditableFalse$b(elm.dom) ) }).exists(function (elm) { return isContentEditableTrue$4(elm.dom) }) } var parseIndentValue = function (value) { var number = parseInt(value, 10) return isNaN(number) ? 0 : number } var getIndentStyleName = function (useMargin, element) { var indentStyleName = useMargin || isTable$2(element) ? 'margin' : 'padding' var suffix = get$5(element, 'direction') === 'rtl' ? '-right' : '-left' return indentStyleName + suffix } var indentElement = function (dom, command, useMargin, value, unit, element) { var indentStyleName = getIndentStyleName( useMargin, SugarElement.fromDom(element) ) if (command === 'outdent') { var styleValue = Math.max( 0, parseIndentValue(element.style[indentStyleName]) - value ) dom.setStyle( element, indentStyleName, styleValue ? styleValue + unit : '' ) } else { var styleValue = parseIndentValue(element.style[indentStyleName]) + value + unit dom.setStyle(element, indentStyleName, styleValue) } } var validateBlocks = function (editor, blocks) { return forall(blocks, function (block) { var indentStyleName = getIndentStyleName( shouldIndentUseMargin(editor), block ) var intentValue = getRaw(block, indentStyleName) .map(parseIndentValue) .getOr(0) var contentEditable = editor.dom.getContentEditable(block.dom) return contentEditable !== 'false' && intentValue > 0 }) } var canOutdent = function (editor) { var blocks = getBlocksToIndent(editor) return ( !editor.mode.isReadOnly() && (blocks.length > 1 || validateBlocks(editor, blocks)) ) } var isListComponent = function (el) { return isList(el) || isListItem(el) } var parentIsListComponent = function (el) { return parent(el).exists(isListComponent) } var getBlocksToIndent = function (editor) { return filter$4( fromDom$1(editor.selection.getSelectedBlocks()), function (el) { return ( !isListComponent(el) && !parentIsListComponent(el) && isEditable(el) ) } ) } var handle = function (editor, command) { var dom = editor.dom, selection = editor.selection, formatter = editor.formatter var indentation = getIndentation(editor) var indentUnit = /[a-z%]+$/i.exec(indentation)[0] var indentValue = parseInt(indentation, 10) var useMargin = shouldIndentUseMargin(editor) var forcedRootBlock = getForcedRootBlock(editor) if ( !editor.queryCommandState('InsertUnorderedList') && !editor.queryCommandState('InsertOrderedList') ) { if ( forcedRootBlock === '' && !dom.getParent(selection.getNode(), dom.isBlock) ) { formatter.apply('div') } } each$k(getBlocksToIndent(editor), function (block) { indentElement(dom, command, useMargin, indentValue, indentUnit, block.dom) }) } var backspaceDelete = function (editor, _forward) { if (editor.selection.isCollapsed() && canOutdent(editor)) { var dom = editor.dom var rng = editor.selection.getRng() var pos = CaretPosition.fromRangeStart(rng) var block = dom.getParent(rng.startContainer, dom.isBlock) if ( block !== null && isAtStartOfBlock(SugarElement.fromDom(block), pos) ) { handle(editor, 'outdent') return true } } return false } var nativeCommand = function (editor, command) { editor.getDoc().execCommand(command, false, null) } var deleteCommand = function (editor, caret) { if (backspaceDelete(editor)) { return } else if (backspaceDelete$5(editor, false)) { return } else if (backspaceDelete$6(editor, false)) { return } else if (backspaceDelete$3(editor, caret, false)) { return } else if (backspaceDelete$8(editor, false)) { return } else if (backspaceDelete$9(editor)) { return } else if (backspaceDelete$4(editor, false)) { return } else if (backspaceDelete$1(editor, false)) { return } else if (backspaceDelete$7(editor)) { return } else if (backspaceDelete$2(editor, false)) { return } else { nativeCommand(editor, 'Delete') paddEmptyBody(editor) } } var forwardDeleteCommand = function (editor, caret) { if (backspaceDelete$5(editor, true)) { return } else if (backspaceDelete$6(editor, true)) { return } else if (backspaceDelete$3(editor, caret, true)) { return } else if (backspaceDelete$8(editor, true)) { return } else if (backspaceDelete$9(editor)) { return } else if (backspaceDelete$4(editor, true)) { return } else if (backspaceDelete$1(editor, true)) { return } else if (backspaceDelete$7(editor)) { return } else if (backspaceDelete$2(editor, true)) { return } else { nativeCommand(editor, 'ForwardDelete') } } var setup$f = function (editor, caret) { editor.addCommand('delete', function () { deleteCommand(editor, caret) }) editor.addCommand('forwardDelete', function () { forwardDeleteCommand(editor, caret) }) } var SIGNIFICANT_MOVE = 5 var LONGPRESS_DELAY = 400 var getTouch = function (event) { if (event.touches === undefined || event.touches.length !== 1) { return Optional.none() } return Optional.some(event.touches[0]) } var isFarEnough = function (touch, data) { var distX = Math.abs(touch.clientX - data.x) var distY = Math.abs(touch.clientY - data.y) return distX > SIGNIFICANT_MOVE || distY > SIGNIFICANT_MOVE } var setup$e = function (editor) { var startData = value() var longpressFired = Cell(false) var debounceLongpress = last(function (e) { editor.fire('longpress', __assign(__assign({}, e), { type: 'longpress' })) longpressFired.set(true) }, LONGPRESS_DELAY) editor.on( 'touchstart', function (e) { getTouch(e).each(function (touch) { debounceLongpress.cancel() var data = { x: touch.clientX, y: touch.clientY, target: e.target, } debounceLongpress.throttle(e) longpressFired.set(false) startData.set(data) }) }, true ) editor.on( 'touchmove', function (e) { debounceLongpress.cancel() getTouch(e).each(function (touch) { startData.on(function (data) { if (isFarEnough(touch, data)) { startData.clear() longpressFired.set(false) editor.fire('longpresscancel') } }) }) }, true ) editor.on( 'touchend touchcancel', function (e) { debounceLongpress.cancel() if (e.type === 'touchcancel') { return } startData .get() .filter(function (data) { return data.target.isEqualNode(e.target) }) .each(function () { if (longpressFired.get()) { e.preventDefault() } else { editor.fire('tap', __assign(__assign({}, e), { type: 'tap' })) } }) }, true ) } var isBlockElement = function (blockElements, node) { return has$2(blockElements, node.nodeName) } var isValidTarget = function (blockElements, node) { if (isText$7(node)) { return true } else if (isElement$5(node)) { return !isBlockElement(blockElements, node) && !isBookmarkNode$1(node) } else { return false } } var hasBlockParent = function (blockElements, root, node) { return exists( parents(SugarElement.fromDom(node), SugarElement.fromDom(root)), function (elm) { return isBlockElement(blockElements, elm.dom) } ) } var shouldRemoveTextNode = function (blockElements, node) { if (isText$7(node)) { if (node.nodeValue.length === 0) { return true } else if ( /^\s+$/.test(node.nodeValue) && (!node.nextSibling || isBlockElement(blockElements, node.nextSibling)) ) { return true } } return false } var addRootBlocks = function (editor) { var dom = editor.dom, selection = editor.selection var schema = editor.schema, blockElements = schema.getBlockElements() var node = selection.getStart() var rootNode = editor.getBody() var rootBlockNode, tempNode, wrapped var forcedRootBlock = getForcedRootBlock(editor) if (!node || !isElement$5(node) || !forcedRootBlock) { return } var rootNodeName = rootNode.nodeName.toLowerCase() if ( !schema.isValidChild(rootNodeName, forcedRootBlock.toLowerCase()) || hasBlockParent(blockElements, rootNode, node) ) { return } var rng = selection.getRng() var startContainer = rng.startContainer var startOffset = rng.startOffset var endContainer = rng.endContainer var endOffset = rng.endOffset var restoreSelection = hasFocus(editor) node = rootNode.firstChild while (node) { if (isValidTarget(blockElements, node)) { if (shouldRemoveTextNode(blockElements, node)) { tempNode = node node = node.nextSibling dom.remove(tempNode) continue } if (!rootBlockNode) { rootBlockNode = dom.create( forcedRootBlock, getForcedRootBlockAttrs(editor) ) node.parentNode.insertBefore(rootBlockNode, node) wrapped = true } tempNode = node node = node.nextSibling rootBlockNode.appendChild(tempNode) } else { rootBlockNode = null node = node.nextSibling } } if (wrapped && restoreSelection) { rng.setStart(startContainer, startOffset) rng.setEnd(endContainer, endOffset) selection.setRng(rng) editor.nodeChanged() } } var setup$d = function (editor) { if (getForcedRootBlock(editor)) { editor.on('NodeChange', curry(addRootBlocks, editor)) } } var findBlockCaretContainer = function (editor) { return descendant( SugarElement.fromDom(editor.getBody()), '*[data-mce-caret]' ) .map(function (elm) { return elm.dom }) .getOrNull() } var removeIeControlRect = function (editor) { editor.selection.setRng(editor.selection.getRng()) } var showBlockCaretContainer = function (editor, blockCaretContainer) { if (blockCaretContainer.hasAttribute('data-mce-caret')) { showCaretContainerBlock(blockCaretContainer) removeIeControlRect(editor) editor.selection.scrollIntoView(blockCaretContainer) } } var handleBlockContainer = function (editor, e) { var blockCaretContainer = findBlockCaretContainer(editor) if (!blockCaretContainer) { return } if (e.type === 'compositionstart') { e.preventDefault() e.stopPropagation() showBlockCaretContainer(editor, blockCaretContainer) return } if (hasContent(blockCaretContainer)) { showBlockCaretContainer(editor, blockCaretContainer) editor.undoManager.add() } } var setup$c = function (editor) { editor.on('keyup compositionstart', curry(handleBlockContainer, editor)) } var isContentEditableFalse$2 = isContentEditableFalse$b var moveToCeFalseHorizontally = function (direction, editor, range) { return moveHorizontally( editor, direction, range, isBeforeContentEditableFalse, isAfterContentEditableFalse, isContentEditableFalse$2 ) } var moveToCeFalseVertically = function (direction, editor, range) { var isBefore = function (caretPosition) { return ( isBeforeContentEditableFalse(caretPosition) || isBeforeTable(caretPosition) ) } var isAfter = function (caretPosition) { return ( isAfterContentEditableFalse(caretPosition) || isAfterTable(caretPosition) ) } return moveVertically( editor, direction, range, isBefore, isAfter, isContentEditableFalse$2 ) } var createTextBlock = function (editor) { var textBlock = editor.dom.create(getForcedRootBlock(editor)) if (!Env.ie || Env.ie >= 11) { textBlock.innerHTML = '
    ' } return textBlock } var exitPreBlock = function (editor, direction, range) { var caretWalker = CaretWalker(editor.getBody()) var getVisualCaretPosition$1 = curry( getVisualCaretPosition, direction === 1 ? caretWalker.next : caretWalker.prev ) if (range.collapsed && hasForcedRootBlock(editor)) { var pre = editor.dom.getParent(range.startContainer, 'PRE') if (!pre) { return } var caretPos = getVisualCaretPosition$1( CaretPosition.fromRangeStart(range) ) if (!caretPos) { var newBlock = createTextBlock(editor) if (direction === 1) { editor.$(pre).after(newBlock) } else { editor.$(pre).before(newBlock) } editor.selection.select(newBlock, true) editor.selection.collapse() } } } var getHorizontalRange = function (editor, forward) { var direction = forward ? HDirection.Forwards : HDirection.Backwards var range = editor.selection.getRng() return moveToCeFalseHorizontally(direction, editor, range).orThunk( function () { exitPreBlock(editor, direction, range) return Optional.none() } ) } var getVerticalRange = function (editor, down) { var direction = down ? 1 : -1 var range = editor.selection.getRng() return moveToCeFalseVertically(direction, editor, range).orThunk( function () { exitPreBlock(editor, direction, range) return Optional.none() } ) } var moveH$2 = function (editor, forward) { return getHorizontalRange(editor, forward).exists(function (newRange) { moveToRange(editor, newRange) return true }) } var moveV$3 = function (editor, down) { return getVerticalRange(editor, down).exists(function (newRange) { moveToRange(editor, newRange) return true }) } var moveToLineEndPoint$1 = function (editor, forward) { var isCefPosition = forward ? isAfterContentEditableFalse : isBeforeContentEditableFalse return moveToLineEndPoint$3(editor, forward, isCefPosition) } var isTarget = function (node) { return contains$3(['figcaption'], name(node)) } var rangeBefore = function (target) { var rng = document.createRange() rng.setStartBefore(target.dom) rng.setEndBefore(target.dom) return rng } var insertElement = function (root, elm, forward) { if (forward) { append$1(root, elm) } else { prepend(root, elm) } } var insertBr = function (root, forward) { var br = SugarElement.fromTag('br') insertElement(root, br, forward) return rangeBefore(br) } var insertBlock = function (root, forward, blockName, attrs) { var block = SugarElement.fromTag(blockName) var br = SugarElement.fromTag('br') setAll$1(block, attrs) append$1(block, br) insertElement(root, block, forward) return rangeBefore(br) } var insertEmptyLine = function (root, rootBlockName, attrs, forward) { if (rootBlockName === '') { return insertBr(root, forward) } else { return insertBlock(root, forward, rootBlockName, attrs) } } var getClosestTargetBlock = function (pos, root) { var isRoot = curry(eq, root) return closest$3( SugarElement.fromDom(pos.container()), isBlock$2, isRoot ).filter(isTarget) } var isAtFirstOrLastLine = function (root, forward, pos) { return forward ? isAtLastLine(root.dom, pos) : isAtFirstLine(root.dom, pos) } var moveCaretToNewEmptyLine = function (editor, forward) { var root = SugarElement.fromDom(editor.getBody()) var pos = CaretPosition.fromRangeStart(editor.selection.getRng()) var rootBlock = getForcedRootBlock(editor) var rootBlockAttrs = getForcedRootBlockAttrs(editor) return getClosestTargetBlock(pos, root).exists(function () { if (isAtFirstOrLastLine(root, forward, pos)) { var rng = insertEmptyLine(root, rootBlock, rootBlockAttrs, forward) editor.selection.setRng(rng) return true } else { return false } }) } var moveV$2 = function (editor, forward) { if (editor.selection.isCollapsed()) { return moveCaretToNewEmptyLine(editor, forward) } else { return false } } var defaultPatterns = function (patterns) { return map$3(patterns, function (pattern) { return __assign( { shiftKey: false, altKey: false, ctrlKey: false, metaKey: false, keyCode: 0, action: noop, }, pattern ) }) } var matchesEvent = function (pattern, evt) { return ( evt.keyCode === pattern.keyCode && evt.shiftKey === pattern.shiftKey && evt.altKey === pattern.altKey && evt.ctrlKey === pattern.ctrlKey && evt.metaKey === pattern.metaKey ) } var match$1 = function (patterns, evt) { return bind(defaultPatterns(patterns), function (pattern) { return matchesEvent(pattern, evt) ? [pattern] : [] }) } var action = function (f) { var x = [] for (var _i = 1; _i < arguments.length; _i++) { x[_i - 1] = arguments[_i] } return function () { return f.apply(null, x) } } var execute = function (patterns, evt) { return find$3(match$1(patterns, evt), function (pattern) { return pattern.action() }) } var moveH$1 = function (editor, forward) { var direction = forward ? HDirection.Forwards : HDirection.Backwards var range = editor.selection.getRng() return moveHorizontally( editor, direction, range, isBeforeMedia, isAfterMedia, isMedia$2 ).exists(function (newRange) { moveToRange(editor, newRange) return true }) } var moveV$1 = function (editor, down) { var direction = down ? 1 : -1 var range = editor.selection.getRng() return moveVertically( editor, direction, range, isBeforeMedia, isAfterMedia, isMedia$2 ).exists(function (newRange) { moveToRange(editor, newRange) return true }) } var moveToLineEndPoint = function (editor, forward) { var isNearMedia = forward ? isAfterMedia : isBeforeMedia return moveToLineEndPoint$3(editor, forward, isNearMedia) } var deflate = function (rect, delta) { return { left: rect.left - delta, top: rect.top - delta, right: rect.right + delta * 2, bottom: rect.bottom + delta * 2, width: rect.width + delta, height: rect.height + delta, } } var getCorners = function (getYAxisValue, tds) { return bind(tds, function (td) { var rect = deflate(clone(td.getBoundingClientRect()), -1) return [ { x: rect.left, y: getYAxisValue(rect), cell: td, }, { x: rect.right, y: getYAxisValue(rect), cell: td, }, ] }) } var findClosestCorner = function (corners, x, y) { return foldl( corners, function (acc, newCorner) { return acc.fold( function () { return Optional.some(newCorner) }, function (oldCorner) { var oldDist = Math.sqrt( Math.abs(oldCorner.x - x) + Math.abs(oldCorner.y - y) ) var newDist = Math.sqrt( Math.abs(newCorner.x - x) + Math.abs(newCorner.y - y) ) return Optional.some(newDist < oldDist ? newCorner : oldCorner) } ) }, Optional.none() ) } var getClosestCell = function (getYAxisValue, isTargetCorner, table, x, y) { var cells = descendants(SugarElement.fromDom(table), 'td,th,caption').map( function (e) { return e.dom } ) var corners = filter$4(getCorners(getYAxisValue, cells), function (corner) { return isTargetCorner(corner, y) }) return findClosestCorner(corners, x, y).map(function (corner) { return corner.cell }) } var getBottomValue = function (rect) { return rect.bottom } var getTopValue = function (rect) { return rect.top } var isAbove = function (corner, y) { return corner.y < y } var isBelow = function (corner, y) { return corner.y > y } var getClosestCellAbove = curry(getClosestCell, getBottomValue, isAbove) var getClosestCellBelow = curry(getClosestCell, getTopValue, isBelow) var findClosestPositionInAboveCell = function (table, pos) { return head(pos.getClientRects()) .bind(function (rect) { return getClosestCellAbove(table, rect.left, rect.top) }) .bind(function (cell) { return findClosestHorizontalPosition(getLastLinePositions(cell), pos) }) } var findClosestPositionInBelowCell = function (table, pos) { return last$2(pos.getClientRects()) .bind(function (rect) { return getClosestCellBelow(table, rect.left, rect.top) }) .bind(function (cell) { return findClosestHorizontalPosition(getFirstLinePositions(cell), pos) }) } var hasNextBreak = function (getPositionsUntil, scope, lineInfo) { return lineInfo.breakAt.exists(function (breakPos) { return getPositionsUntil(scope, breakPos).breakAt.isSome() }) } var startsWithWrapBreak = function (lineInfo) { return ( lineInfo.breakType === BreakType.Wrap && lineInfo.positions.length === 0 ) } var startsWithBrBreak = function (lineInfo) { return ( lineInfo.breakType === BreakType.Br && lineInfo.positions.length === 1 ) } var isAtTableCellLine = function (getPositionsUntil, scope, pos) { var lineInfo = getPositionsUntil(scope, pos) if ( startsWithWrapBreak(lineInfo) || (!isBr$5(pos.getNode()) && startsWithBrBreak(lineInfo)) ) { return !hasNextBreak(getPositionsUntil, scope, lineInfo) } else { return lineInfo.breakAt.isNone() } } var isAtFirstTableCellLine = curry( isAtTableCellLine, getPositionsUntilPreviousLine ) var isAtLastTableCellLine = curry( isAtTableCellLine, getPositionsUntilNextLine ) var isCaretAtStartOrEndOfTable = function (forward, rng, table) { var caretPos = CaretPosition.fromRangeStart(rng) return positionIn(!forward, table).exists(function (pos) { return pos.isEqual(caretPos) }) } var navigateHorizontally = function (editor, forward, table, _td) { var rng = editor.selection.getRng() var direction = forward ? 1 : -1 if ( isFakeCaretTableBrowser() && isCaretAtStartOrEndOfTable(forward, rng, table) ) { showCaret(direction, editor, table, !forward, false).each(function ( newRng ) { moveToRange(editor, newRng) }) return true } return false } var getClosestAbovePosition = function (root, table, start) { return findClosestPositionInAboveCell(table, start) .orThunk(function () { return head(start.getClientRects()).bind(function (rect) { return findClosestHorizontalPositionFromPoint( getPositionsAbove(root, CaretPosition.before(table)), rect.left ) }) }) .getOr(CaretPosition.before(table)) } var getClosestBelowPosition = function (root, table, start) { return findClosestPositionInBelowCell(table, start) .orThunk(function () { return head(start.getClientRects()).bind(function (rect) { return findClosestHorizontalPositionFromPoint( getPositionsBelow(root, CaretPosition.after(table)), rect.left ) }) }) .getOr(CaretPosition.after(table)) } var getTable = function (previous, pos) { var node = pos.getNode(previous) return isElement$5(node) && node.nodeName === 'TABLE' ? Optional.some(node) : Optional.none() } var renderBlock = function (down, editor, table, pos) { var forcedRootBlock = getForcedRootBlock(editor) if (forcedRootBlock) { editor.undoManager.transact(function () { var element = SugarElement.fromTag(forcedRootBlock) setAll$1(element, getForcedRootBlockAttrs(editor)) append$1(element, SugarElement.fromTag('br')) if (down) { after$3(SugarElement.fromDom(table), element) } else { before$4(SugarElement.fromDom(table), element) } var rng = editor.dom.createRng() rng.setStart(element.dom, 0) rng.setEnd(element.dom, 0) moveToRange(editor, rng) }) } else { moveToRange(editor, pos.toRange()) } } var moveCaret = function (editor, down, pos) { var table = down ? getTable(true, pos) : getTable(false, pos) var last = down === false table.fold( function () { return moveToRange(editor, pos.toRange()) }, function (table) { return positionIn(last, editor.getBody()) .filter(function (lastPos) { return lastPos.isEqual(pos) }) .fold( function () { return moveToRange(editor, pos.toRange()) }, function (_) { return renderBlock(down, editor, table, pos) } ) } ) } var navigateVertically = function (editor, down, table, td) { var rng = editor.selection.getRng() var pos = CaretPosition.fromRangeStart(rng) var root = editor.getBody() if (!down && isAtFirstTableCellLine(td, pos)) { var newPos = getClosestAbovePosition(root, table, pos) moveCaret(editor, down, newPos) return true } else if (down && isAtLastTableCellLine(td, pos)) { var newPos = getClosestBelowPosition(root, table, pos) moveCaret(editor, down, newPos) return true } else { return false } } var move$1 = function (editor, forward, mover) { return Optional.from( editor.dom.getParent(editor.selection.getNode(), 'td,th') ) .bind(function (td) { return Optional.from(editor.dom.getParent(td, 'table')).map(function ( table ) { return mover(editor, forward, table, td) }) }) .getOr(false) } var moveH = function (editor, forward) { return move$1(editor, forward, navigateHorizontally) } var moveV = function (editor, forward) { return move$1(editor, forward, navigateVertically) } var executeKeydownOverride$3 = function (editor, caret, evt) { var os = detect().os execute( [ { keyCode: VK.RIGHT, action: action(moveH$2, editor, true), }, { keyCode: VK.LEFT, action: action(moveH$2, editor, false), }, { keyCode: VK.UP, action: action(moveV$3, editor, false), }, { keyCode: VK.DOWN, action: action(moveV$3, editor, true), }, { keyCode: VK.RIGHT, action: action(moveH, editor, true), }, { keyCode: VK.LEFT, action: action(moveH, editor, false), }, { keyCode: VK.UP, action: action(moveV, editor, false), }, { keyCode: VK.DOWN, action: action(moveV, editor, true), }, { keyCode: VK.RIGHT, action: action(moveH$1, editor, true), }, { keyCode: VK.LEFT, action: action(moveH$1, editor, false), }, { keyCode: VK.UP, action: action(moveV$1, editor, false), }, { keyCode: VK.DOWN, action: action(moveV$1, editor, true), }, { keyCode: VK.RIGHT, action: action(move$2, editor, caret, true), }, { keyCode: VK.LEFT, action: action(move$2, editor, caret, false), }, { keyCode: VK.RIGHT, ctrlKey: !os.isOSX(), altKey: os.isOSX(), action: action(moveNextWord, editor, caret), }, { keyCode: VK.LEFT, ctrlKey: !os.isOSX(), altKey: os.isOSX(), action: action(movePrevWord, editor, caret), }, { keyCode: VK.UP, action: action(moveV$2, editor, false), }, { keyCode: VK.DOWN, action: action(moveV$2, editor, true), }, ], evt ).each(function (_) { evt.preventDefault() }) } var setup$b = function (editor, caret) { editor.on('keydown', function (evt) { if (evt.isDefaultPrevented() === false) { executeKeydownOverride$3(editor, caret, evt) } }) } var executeKeydownOverride$2 = function (editor, caret, evt) { execute( [ { keyCode: VK.BACKSPACE, action: action(backspaceDelete, editor, false), }, { keyCode: VK.BACKSPACE, action: action(backspaceDelete$5, editor, false), }, { keyCode: VK.DELETE, action: action(backspaceDelete$5, editor, true), }, { keyCode: VK.BACKSPACE, action: action(backspaceDelete$6, editor, false), }, { keyCode: VK.DELETE, action: action(backspaceDelete$6, editor, true), }, { keyCode: VK.BACKSPACE, action: action(backspaceDelete$3, editor, caret, false), }, { keyCode: VK.DELETE, action: action(backspaceDelete$3, editor, caret, true), }, { keyCode: VK.BACKSPACE, action: action(backspaceDelete$9, editor, false), }, { keyCode: VK.DELETE, action: action(backspaceDelete$9, editor, true), }, { keyCode: VK.BACKSPACE, action: action(backspaceDelete$4, editor, false), }, { keyCode: VK.DELETE, action: action(backspaceDelete$4, editor, true), }, { keyCode: VK.BACKSPACE, action: action(backspaceDelete$1, editor, false), }, { keyCode: VK.DELETE, action: action(backspaceDelete$1, editor, true), }, { keyCode: VK.BACKSPACE, action: action(backspaceDelete$7, editor, false), }, { keyCode: VK.DELETE, action: action(backspaceDelete$7, editor, true), }, { keyCode: VK.BACKSPACE, action: action(backspaceDelete$8, editor, false), }, { keyCode: VK.DELETE, action: action(backspaceDelete$8, editor, true), }, { keyCode: VK.BACKSPACE, action: action(backspaceDelete$2, editor, false), }, { keyCode: VK.DELETE, action: action(backspaceDelete$2, editor, true), }, ], evt ).each(function (_) { evt.preventDefault() }) } var executeKeyupOverride = function (editor, evt) { execute( [ { keyCode: VK.BACKSPACE, action: action(paddEmptyElement, editor), }, { keyCode: VK.DELETE, action: action(paddEmptyElement, editor), }, ], evt ) } var setup$a = function (editor, caret) { editor.on('keydown', function (evt) { if (evt.isDefaultPrevented() === false) { executeKeydownOverride$2(editor, caret, evt) } }) editor.on('keyup', function (evt) { if (evt.isDefaultPrevented() === false) { executeKeyupOverride(editor, evt) } }) } var firstNonWhiteSpaceNodeSibling = function (node) { while (node) { if ( node.nodeType === 1 || (node.nodeType === 3 && node.data && /[\r\n\s]/.test(node.data)) ) { return node } node = node.nextSibling } } var moveToCaretPosition = function (editor, root) { var node, lastNode = root var dom = editor.dom var moveCaretBeforeOnEnterElementsMap = editor.schema.getMoveCaretBeforeOnEnterElements() if (!root) { return } if (/^(LI|DT|DD)$/.test(root.nodeName)) { var firstChild = firstNonWhiteSpaceNodeSibling(root.firstChild) if (firstChild && /^(UL|OL|DL)$/.test(firstChild.nodeName)) { root.insertBefore(dom.doc.createTextNode(nbsp), root.firstChild) } } var rng = dom.createRng() root.normalize() if (root.hasChildNodes()) { var walker = new DomTreeWalker(root, root) while ((node = walker.current())) { if (isText$7(node)) { rng.setStart(node, 0) rng.setEnd(node, 0) break } if (moveCaretBeforeOnEnterElementsMap[node.nodeName.toLowerCase()]) { rng.setStartBefore(node) rng.setEndBefore(node) break } lastNode = node node = walker.next() } if (!node) { rng.setStart(lastNode, 0) rng.setEnd(lastNode, 0) } } else { if (isBr$5(root)) { if (root.nextSibling && dom.isBlock(root.nextSibling)) { rng.setStartBefore(root) rng.setEndBefore(root) } else { rng.setStartAfter(root) rng.setEndAfter(root) } } else { rng.setStart(root, 0) rng.setEnd(root, 0) } } editor.selection.setRng(rng) scrollRangeIntoView(editor, rng) } var getEditableRoot$1 = function (dom, node) { var root = dom.getRoot() var parent, editableRoot parent = node while (parent !== root && dom.getContentEditable(parent) !== 'false') { if (dom.getContentEditable(parent) === 'true') { editableRoot = parent } parent = parent.parentNode } return parent !== root ? editableRoot : root } var getParentBlock = function (editor) { return Optional.from( editor.dom.getParent(editor.selection.getStart(true), editor.dom.isBlock) ) } var getParentBlockName = function (editor) { return getParentBlock(editor).fold(constant(''), function (parentBlock) { return parentBlock.nodeName.toUpperCase() }) } var isListItemParentBlock = function (editor) { return getParentBlock(editor) .filter(function (elm) { return isListItem(SugarElement.fromDom(elm)) }) .isSome() } var hasFirstChild = function (elm, name) { return elm.firstChild && elm.firstChild.nodeName === name } var isFirstChild = function (elm) { var _a return ( ((_a = elm.parentNode) === null || _a === void 0 ? void 0 : _a.firstChild) === elm ) } var hasParent = function (elm, parentName) { return elm && elm.parentNode && elm.parentNode.nodeName === parentName } var isListBlock = function (elm) { return elm && /^(OL|UL|LI)$/.test(elm.nodeName) } var isNestedList = function (elm) { return isListBlock(elm) && isListBlock(elm.parentNode) } var getContainerBlock = function (containerBlock) { var containerBlockParent = containerBlock.parentNode if (/^(LI|DT|DD)$/.test(containerBlockParent.nodeName)) { return containerBlockParent } return containerBlock } var isFirstOrLastLi = function (containerBlock, parentBlock, first) { var node = containerBlock[first ? 'firstChild' : 'lastChild'] while (node) { if (isElement$5(node)) { break } node = node[first ? 'nextSibling' : 'previousSibling'] } return node === parentBlock } var insert$3 = function ( editor, createNewBlock, containerBlock, parentBlock, newBlockName ) { var dom = editor.dom var rng = editor.selection.getRng() if (containerBlock === editor.getBody()) { return } if (isNestedList(containerBlock)) { newBlockName = 'LI' } var newBlock = newBlockName ? createNewBlock(newBlockName) : dom.create('BR') if ( isFirstOrLastLi(containerBlock, parentBlock, true) && isFirstOrLastLi(containerBlock, parentBlock, false) ) { if (hasParent(containerBlock, 'LI')) { var containerBlockParent = getContainerBlock(containerBlock) dom.insertAfter(newBlock, containerBlockParent) if (isFirstChild(containerBlock)) { dom.remove(containerBlockParent) } else { dom.remove(containerBlock) } } else { dom.replace(newBlock, containerBlock) } } else if (isFirstOrLastLi(containerBlock, parentBlock, true)) { if (hasParent(containerBlock, 'LI')) { dom.insertAfter(newBlock, getContainerBlock(containerBlock)) newBlock.appendChild(dom.doc.createTextNode(' ')) newBlock.appendChild(containerBlock) } else { containerBlock.parentNode.insertBefore(newBlock, containerBlock) } dom.remove(parentBlock) } else if (isFirstOrLastLi(containerBlock, parentBlock, false)) { dom.insertAfter(newBlock, getContainerBlock(containerBlock)) dom.remove(parentBlock) } else { containerBlock = getContainerBlock(containerBlock) var tmpRng = rng.cloneRange() tmpRng.setStartAfter(parentBlock) tmpRng.setEndAfter(containerBlock) var fragment = tmpRng.extractContents() if (newBlockName === 'LI' && hasFirstChild(fragment, 'LI')) { newBlock = fragment.firstChild dom.insertAfter(fragment, containerBlock) } else { dom.insertAfter(fragment, containerBlock) dom.insertAfter(newBlock, containerBlock) } dom.remove(parentBlock) } moveToCaretPosition(editor, newBlock) } var trimZwsp = function (fragment) { each$k( descendants$1(SugarElement.fromDom(fragment), isText$8), function (text) { var rawNode = text.dom rawNode.nodeValue = trim$2(rawNode.nodeValue) } ) } var isEmptyAnchor = function (dom, elm) { return elm && elm.nodeName === 'A' && dom.isEmpty(elm) } var isTableCell = function (node) { return node && /^(TD|TH|CAPTION)$/.test(node.nodeName) } var emptyBlock = function (elm) { elm.innerHTML = '
    ' } var containerAndSiblingName = function (container, nodeName) { return ( container.nodeName === nodeName || (container.previousSibling && container.previousSibling.nodeName === nodeName) ) } var canSplitBlock = function (dom, node) { return ( node && dom.isBlock(node) && !/^(TD|TH|CAPTION|FORM)$/.test(node.nodeName) && !/^(fixed|absolute)/i.test(node.style.position) && dom.getContentEditable(node) !== 'true' ) } var trimInlineElementsOnLeftSideOfBlock = function ( dom, nonEmptyElementsMap, block ) { var node = block var firstChilds = [] var i if (!node) { return } while ((node = node.firstChild)) { if (dom.isBlock(node)) { return } if ( isElement$5(node) && !nonEmptyElementsMap[node.nodeName.toLowerCase()] ) { firstChilds.push(node) } } i = firstChilds.length while (i--) { node = firstChilds[i] if ( !node.hasChildNodes() || (node.firstChild === node.lastChild && node.firstChild.nodeValue === '') ) { dom.remove(node) } else { if (isEmptyAnchor(dom, node)) { dom.remove(node) } } } } var normalizeZwspOffset = function (start, container, offset) { if (isText$7(container) === false) { return offset } else if (start) { return offset === 1 && container.data.charAt(offset - 1) === ZWSP$1 ? 0 : offset } else { return offset === container.data.length - 1 && container.data.charAt(offset) === ZWSP$1 ? container.data.length : offset } } var includeZwspInRange = function (rng) { var newRng = rng.cloneRange() newRng.setStart( rng.startContainer, normalizeZwspOffset(true, rng.startContainer, rng.startOffset) ) newRng.setEnd( rng.endContainer, normalizeZwspOffset(false, rng.endContainer, rng.endOffset) ) return newRng } var trimLeadingLineBreaks = function (node) { do { if (isText$7(node)) { node.nodeValue = node.nodeValue.replace(/^[\r\n]+/, '') } node = node.firstChild } while (node) } var getEditableRoot = function (dom, node) { var root = dom.getRoot() var parent, editableRoot parent = node while (parent !== root && dom.getContentEditable(parent) !== 'false') { if (dom.getContentEditable(parent) === 'true') { editableRoot = parent } parent = parent.parentNode } return parent !== root ? editableRoot : root } var applyAttributes = function (editor, node, forcedRootBlockAttrs) { var dom = editor.dom Optional.from(forcedRootBlockAttrs.style) .map(dom.parseStyle) .each(function (attrStyles) { var currentStyles = getAllRaw(SugarElement.fromDom(node)) var newStyles = __assign(__assign({}, currentStyles), attrStyles) dom.setStyles(node, newStyles) }) var attrClassesOpt = Optional.from(forcedRootBlockAttrs.class).map( function (attrClasses) { return attrClasses.split(/\s+/) } ) var currentClassesOpt = Optional.from(node.className).map(function ( currentClasses ) { return filter$4(currentClasses.split(/\s+/), function (clazz) { return clazz !== '' }) }) lift2( attrClassesOpt, currentClassesOpt, function (attrClasses, currentClasses) { var filteredClasses = filter$4(currentClasses, function (clazz) { return !contains$3(attrClasses, clazz) }) var newClasses = __spreadArray( __spreadArray([], attrClasses, true), filteredClasses, true ) dom.setAttrib(node, 'class', newClasses.join(' ')) } ) var appliedAttrs = ['style', 'class'] var remainingAttrs = filter$3(forcedRootBlockAttrs, function (_, attrs) { return !contains$3(appliedAttrs, attrs) }) dom.setAttribs(node, remainingAttrs) } var setForcedBlockAttrs = function (editor, node) { var forcedRootBlockName = getForcedRootBlock(editor) if ( forcedRootBlockName && forcedRootBlockName.toLowerCase() === node.tagName.toLowerCase() ) { var forcedRootBlockAttrs = getForcedRootBlockAttrs(editor) applyAttributes(editor, node, forcedRootBlockAttrs) } } var wrapSelfAndSiblingsInDefaultBlock = function ( editor, newBlockName, rng, container, offset ) { var newBlock, parentBlock, startNode, node, next, rootBlockName var blockName = newBlockName || 'P' var dom = editor.dom, editableRoot = getEditableRoot(dom, container) parentBlock = dom.getParent(container, dom.isBlock) if (!parentBlock || !canSplitBlock(dom, parentBlock)) { parentBlock = parentBlock || editableRoot if (parentBlock === editor.getBody() || isTableCell(parentBlock)) { rootBlockName = parentBlock.nodeName.toLowerCase() } else { rootBlockName = parentBlock.parentNode.nodeName.toLowerCase() } if (!parentBlock.hasChildNodes()) { newBlock = dom.create(blockName) setForcedBlockAttrs(editor, newBlock) parentBlock.appendChild(newBlock) rng.setStart(newBlock, 0) rng.setEnd(newBlock, 0) return newBlock } node = container while (node.parentNode !== parentBlock) { node = node.parentNode } while (node && !dom.isBlock(node)) { startNode = node node = node.previousSibling } if ( startNode && editor.schema.isValidChild(rootBlockName, blockName.toLowerCase()) ) { newBlock = dom.create(blockName) setForcedBlockAttrs(editor, newBlock) startNode.parentNode.insertBefore(newBlock, startNode) node = startNode while (node && !dom.isBlock(node)) { next = node.nextSibling newBlock.appendChild(node) node = next } rng.setStart(container, offset) rng.setEnd(container, offset) } } return container } var addBrToBlockIfNeeded = function (dom, block) { block.normalize() var lastChild = block.lastChild if ( !lastChild || /^(left|right)$/gi.test(dom.getStyle(lastChild, 'float', true)) ) { dom.add(block, 'br') } } var insert$2 = function (editor, evt) { var tmpRng, container, offset, parentBlock var newBlock, fragment, containerBlock, parentBlockName, newBlockName, isAfterLastNodeInContainer var dom = editor.dom var schema = editor.schema, nonEmptyElementsMap = schema.getNonEmptyElements() var rng = editor.selection.getRng() var createNewBlock = function (name) { var node = container, block, clonedNode, caretNode var textInlineElements = schema.getTextInlineElements() if (name || parentBlockName === 'TABLE' || parentBlockName === 'HR') { block = dom.create(name || newBlockName) } else { block = parentBlock.cloneNode(false) } caretNode = block if (shouldKeepStyles(editor) === false) { dom.setAttrib(block, 'style', null) dom.setAttrib(block, 'class', null) } else { do { if (textInlineElements[node.nodeName]) { if (isCaretNode(node) || isBookmarkNode$1(node)) { continue } clonedNode = node.cloneNode(false) dom.setAttrib(clonedNode, 'id', '') if (block.hasChildNodes()) { clonedNode.appendChild(block.firstChild) block.appendChild(clonedNode) } else { caretNode = clonedNode block.appendChild(clonedNode) } } } while ((node = node.parentNode) && node !== editableRoot) } setForcedBlockAttrs(editor, block) emptyBlock(caretNode) return block } var isCaretAtStartOrEndOfBlock = function (start) { var node, name var normalizedOffset = normalizeZwspOffset(start, container, offset) if ( isText$7(container) && (start ? normalizedOffset > 0 : normalizedOffset < container.nodeValue.length) ) { return false } if ( container.parentNode === parentBlock && isAfterLastNodeInContainer && !start ) { return true } if ( start && isElement$5(container) && container === parentBlock.firstChild ) { return true } if ( containerAndSiblingName(container, 'TABLE') || containerAndSiblingName(container, 'HR') ) { return ( (isAfterLastNodeInContainer && !start) || (!isAfterLastNodeInContainer && start) ) } var walker = new DomTreeWalker(container, parentBlock) if (isText$7(container)) { if (start && normalizedOffset === 0) { walker.prev() } else if (!start && normalizedOffset === container.nodeValue.length) { walker.next() } } while ((node = walker.current())) { if (isElement$5(node)) { if (!node.getAttribute('data-mce-bogus')) { name = node.nodeName.toLowerCase() if (nonEmptyElementsMap[name] && name !== 'br') { return false } } } else if (isText$7(node) && !isWhitespaceText(node.nodeValue)) { return false } if (start) { walker.prev() } else { walker.next() } } return true } var insertNewBlockAfter = function () { if ( /^(H[1-6]|PRE|FIGURE)$/.test(parentBlockName) && containerBlockName !== 'HGROUP' ) { newBlock = createNewBlock(newBlockName) } else { newBlock = createNewBlock() } if ( shouldEndContainerOnEmptyBlock(editor) && canSplitBlock(dom, containerBlock) && dom.isEmpty(parentBlock) ) { newBlock = dom.split(containerBlock, parentBlock) } else { dom.insertAfter(newBlock, parentBlock) } moveToCaretPosition(editor, newBlock) } normalize$2(dom, rng).each(function (normRng) { rng.setStart(normRng.startContainer, normRng.startOffset) rng.setEnd(normRng.endContainer, normRng.endOffset) }) container = rng.startContainer offset = rng.startOffset newBlockName = getForcedRootBlock(editor) var shiftKey = !!(evt && evt.shiftKey) var ctrlKey = !!(evt && evt.ctrlKey) if (isElement$5(container) && container.hasChildNodes()) { isAfterLastNodeInContainer = offset > container.childNodes.length - 1 container = container.childNodes[ Math.min(offset, container.childNodes.length - 1) ] || container if (isAfterLastNodeInContainer && isText$7(container)) { offset = container.nodeValue.length } else { offset = 0 } } var editableRoot = getEditableRoot(dom, container) if (!editableRoot) { return } if ((newBlockName && !shiftKey) || (!newBlockName && shiftKey)) { container = wrapSelfAndSiblingsInDefaultBlock( editor, newBlockName, rng, container, offset ) } parentBlock = dom.getParent(container, dom.isBlock) containerBlock = parentBlock ? dom.getParent(parentBlock.parentNode, dom.isBlock) : null parentBlockName = parentBlock ? parentBlock.nodeName.toUpperCase() : '' var containerBlockName = containerBlock ? containerBlock.nodeName.toUpperCase() : '' if (containerBlockName === 'LI' && !ctrlKey) { parentBlock = containerBlock containerBlock = containerBlock.parentNode parentBlockName = containerBlockName } if (/^(LI|DT|DD)$/.test(parentBlockName)) { if (dom.isEmpty(parentBlock)) { insert$3( editor, createNewBlock, containerBlock, parentBlock, newBlockName ) return } } if (newBlockName && parentBlock === editor.getBody()) { return } newBlockName = newBlockName || 'P' if (isCaretContainerBlock$1(parentBlock)) { newBlock = showCaretContainerBlock(parentBlock) if (dom.isEmpty(parentBlock)) { emptyBlock(parentBlock) } setForcedBlockAttrs(editor, newBlock) moveToCaretPosition(editor, newBlock) } else if (isCaretAtStartOrEndOfBlock()) { insertNewBlockAfter() } else if (isCaretAtStartOrEndOfBlock(true)) { newBlock = parentBlock.parentNode.insertBefore( createNewBlock(), parentBlock ) moveToCaretPosition( editor, containerAndSiblingName(parentBlock, 'HR') ? newBlock : parentBlock ) } else { tmpRng = includeZwspInRange(rng).cloneRange() tmpRng.setEndAfter(parentBlock) fragment = tmpRng.extractContents() trimZwsp(fragment) trimLeadingLineBreaks(fragment) newBlock = fragment.firstChild dom.insertAfter(fragment, parentBlock) trimInlineElementsOnLeftSideOfBlock(dom, nonEmptyElementsMap, newBlock) addBrToBlockIfNeeded(dom, parentBlock) if (dom.isEmpty(parentBlock)) { emptyBlock(parentBlock) } newBlock.normalize() if (dom.isEmpty(newBlock)) { dom.remove(newBlock) insertNewBlockAfter() } else { setForcedBlockAttrs(editor, newBlock) moveToCaretPosition(editor, newBlock) } } dom.setAttrib(newBlock, 'id', '') editor.fire('NewBlock', { newBlock: newBlock }) } var hasRightSideContent = function (schema, container, parentBlock) { var walker = new DomTreeWalker(container, parentBlock) var node var nonEmptyElementsMap = schema.getNonEmptyElements() while ((node = walker.next())) { if (nonEmptyElementsMap[node.nodeName.toLowerCase()] || node.length > 0) { return true } } } var moveSelectionToBr = function (editor, brElm, extraBr) { var rng = editor.dom.createRng() if (!extraBr) { rng.setStartAfter(brElm) rng.setEndAfter(brElm) } else { rng.setStartBefore(brElm) rng.setEndBefore(brElm) } editor.selection.setRng(rng) scrollRangeIntoView(editor, rng) } var insertBrAtCaret = function (editor, evt) { var selection = editor.selection var dom = editor.dom var rng = selection.getRng() var brElm var extraBr normalize$2(dom, rng).each(function (normRng) { rng.setStart(normRng.startContainer, normRng.startOffset) rng.setEnd(normRng.endContainer, normRng.endOffset) }) var offset = rng.startOffset var container = rng.startContainer if (container.nodeType === 1 && container.hasChildNodes()) { var isAfterLastNodeInContainer = offset > container.childNodes.length - 1 container = container.childNodes[ Math.min(offset, container.childNodes.length - 1) ] || container if (isAfterLastNodeInContainer && container.nodeType === 3) { offset = container.nodeValue.length } else { offset = 0 } } var parentBlock = dom.getParent(container, dom.isBlock) var containerBlock = parentBlock ? dom.getParent(parentBlock.parentNode, dom.isBlock) : null var containerBlockName = containerBlock ? containerBlock.nodeName.toUpperCase() : '' var isControlKey = !!(evt && evt.ctrlKey) if (containerBlockName === 'LI' && !isControlKey) { parentBlock = containerBlock } if ( container && container.nodeType === 3 && offset >= container.nodeValue.length ) { if (!hasRightSideContent(editor.schema, container, parentBlock)) { brElm = dom.create('br') rng.insertNode(brElm) rng.setStartAfter(brElm) rng.setEndAfter(brElm) extraBr = true } } brElm = dom.create('br') rangeInsertNode(dom, rng, brElm) moveSelectionToBr(editor, brElm, extraBr) editor.undoManager.add() } var insertBrBefore = function (editor, inline) { var br = SugarElement.fromTag('br') before$4(SugarElement.fromDom(inline), br) editor.undoManager.add() } var insertBrAfter = function (editor, inline) { if (!hasBrAfter(editor.getBody(), inline)) { after$3(SugarElement.fromDom(inline), SugarElement.fromTag('br')) } var br = SugarElement.fromTag('br') after$3(SugarElement.fromDom(inline), br) moveSelectionToBr(editor, br.dom, false) editor.undoManager.add() } var isBeforeBr = function (pos) { return isBr$5(pos.getNode()) } var hasBrAfter = function (rootNode, startNode) { if (isBeforeBr(CaretPosition.after(startNode))) { return true } else { return nextPosition(rootNode, CaretPosition.after(startNode)) .map(function (pos) { return isBr$5(pos.getNode()) }) .getOr(false) } } var isAnchorLink = function (elm) { return elm && elm.nodeName === 'A' && 'href' in elm } var isInsideAnchor = function (location) { return location.fold(never, isAnchorLink, isAnchorLink, never) } var readInlineAnchorLocation = function (editor) { var isInlineTarget$1 = curry(isInlineTarget, editor) var position = CaretPosition.fromRangeStart(editor.selection.getRng()) return readLocation(isInlineTarget$1, editor.getBody(), position).filter( isInsideAnchor ) } var insertBrOutsideAnchor = function (editor, location) { location.fold( noop, curry(insertBrBefore, editor), curry(insertBrAfter, editor), noop ) } var insert$1 = function (editor, evt) { var anchorLocation = readInlineAnchorLocation(editor) if (anchorLocation.isSome()) { anchorLocation.each(curry(insertBrOutsideAnchor, editor)) } else { insertBrAtCaret(editor, evt) } } var matchesSelector = function (editor, selector) { return getParentBlock(editor) .filter(function (parentBlock) { return ( selector.length > 0 && is$2(SugarElement.fromDom(parentBlock), selector) ) }) .isSome() } var shouldInsertBr = function (editor) { return matchesSelector(editor, getBrNewLineSelector(editor)) } var shouldBlockNewLine$1 = function (editor) { return matchesSelector(editor, getNoNewLineSelector(editor)) } var newLineAction = Adt.generate([{ br: [] }, { block: [] }, { none: [] }]) var shouldBlockNewLine = function (editor, _shiftKey) { return shouldBlockNewLine$1(editor) } var isBrMode = function (requiredState) { return function (editor, _shiftKey) { var brMode = getForcedRootBlock(editor) === '' return brMode === requiredState } } var inListBlock = function (requiredState) { return function (editor, _shiftKey) { return isListItemParentBlock(editor) === requiredState } } var inBlock = function (blockName, requiredState) { return function (editor, _shiftKey) { var state = getParentBlockName(editor) === blockName.toUpperCase() return state === requiredState } } var inPreBlock = function (requiredState) { return inBlock('pre', requiredState) } var inSummaryBlock = function () { return inBlock('summary', true) } var shouldPutBrInPre = function (requiredState) { return function (editor, _shiftKey) { return shouldPutBrInPre$1(editor) === requiredState } } var inBrContext = function (editor, _shiftKey) { return shouldInsertBr(editor) } var hasShiftKey = function (_editor, shiftKey) { return shiftKey } var canInsertIntoEditableRoot = function (editor) { var forcedRootBlock = getForcedRootBlock(editor) var rootEditable = getEditableRoot$1( editor.dom, editor.selection.getStart() ) return ( rootEditable && editor.schema.isValidChild( rootEditable.nodeName, forcedRootBlock ? forcedRootBlock : 'P' ) ) } var match = function (predicates, action) { return function (editor, shiftKey) { var isMatch = foldl( predicates, function (res, p) { return res && p(editor, shiftKey) }, true ) return isMatch ? Optional.some(action) : Optional.none() } } var getAction = function (editor, evt) { return evaluateUntil( [ match([shouldBlockNewLine], newLineAction.none()), match([inSummaryBlock()], newLineAction.br()), match( [inPreBlock(true), shouldPutBrInPre(false), hasShiftKey], newLineAction.br() ), match( [inPreBlock(true), shouldPutBrInPre(false)], newLineAction.block() ), match( [inPreBlock(true), shouldPutBrInPre(true), hasShiftKey], newLineAction.block() ), match([inPreBlock(true), shouldPutBrInPre(true)], newLineAction.br()), match([inListBlock(true), hasShiftKey], newLineAction.br()), match([inListBlock(true)], newLineAction.block()), match( [isBrMode(true), hasShiftKey, canInsertIntoEditableRoot], newLineAction.block() ), match([isBrMode(true)], newLineAction.br()), match([inBrContext], newLineAction.br()), match([isBrMode(false), hasShiftKey], newLineAction.br()), match([canInsertIntoEditableRoot], newLineAction.block()), ], [editor, !!(evt && evt.shiftKey)] ).getOr(newLineAction.none()) } var insert = function (editor, evt) { getAction(editor, evt).fold( function () { insert$1(editor, evt) }, function () { insert$2(editor, evt) }, noop ) } var handleEnterKeyEvent = function (editor, event) { if (event.isDefaultPrevented()) { return } event.preventDefault() endTypingLevelIgnoreLocks(editor.undoManager) editor.undoManager.transact(function () { if (editor.selection.isCollapsed() === false) { editor.execCommand('Delete') } insert(editor, event) }) } var setup$9 = function (editor) { editor.on('keydown', function (event) { if (event.keyCode === VK.ENTER) { handleEnterKeyEvent(editor, event) } }) } var executeKeydownOverride$1 = function (editor, caret, evt) { execute( [ { keyCode: VK.END, action: action(moveToLineEndPoint$1, editor, true), }, { keyCode: VK.HOME, action: action(moveToLineEndPoint$1, editor, false), }, { keyCode: VK.END, action: action(moveToLineEndPoint, editor, true), }, { keyCode: VK.HOME, action: action(moveToLineEndPoint, editor, false), }, { keyCode: VK.END, action: action(moveToLineEndPoint$2, editor, true, caret), }, { keyCode: VK.HOME, action: action(moveToLineEndPoint$2, editor, false, caret), }, ], evt ).each(function (_) { evt.preventDefault() }) } var setup$8 = function (editor, caret) { editor.on('keydown', function (evt) { if (evt.isDefaultPrevented() === false) { executeKeydownOverride$1(editor, caret, evt) } }) } var browser = detect().browser var setupIeInput = function (editor) { var keypressThrotter = first(function () { if (!editor.composing) { normalizeNbspsInEditor(editor) } }, 0) if (browser.isIE()) { editor.on('keypress', function (_e) { keypressThrotter.throttle() }) editor.on('remove', function (_e) { keypressThrotter.cancel() }) } } var setup$7 = function (editor) { setupIeInput(editor) editor.on('input', function (e) { if (e.isComposing === false) { normalizeNbspsInEditor(editor) } }) } var platform = detect() var executeKeyupAction = function (editor, caret, evt) { execute( [ { keyCode: VK.PAGE_UP, action: action(moveToLineEndPoint$2, editor, false, caret), }, { keyCode: VK.PAGE_DOWN, action: action(moveToLineEndPoint$2, editor, true, caret), }, ], evt ) } var stopImmediatePropagation = function (e) { return e.stopImmediatePropagation() } var isPageUpDown = function (evt) { return evt.keyCode === VK.PAGE_UP || evt.keyCode === VK.PAGE_DOWN } var setNodeChangeBlocker = function (blocked, editor, block) { if (block && !blocked.get()) { editor.on('NodeChange', stopImmediatePropagation, true) } else if (!block && blocked.get()) { editor.off('NodeChange', stopImmediatePropagation) } blocked.set(block) } var setup$6 = function (editor, caret) { if (platform.os.isOSX()) { return } var blocked = Cell(false) editor.on('keydown', function (evt) { if (isPageUpDown(evt)) { setNodeChangeBlocker(blocked, editor, true) } }) editor.on('keyup', function (evt) { if (evt.isDefaultPrevented() === false) { executeKeyupAction(editor, caret, evt) } if (isPageUpDown(evt) && blocked.get()) { setNodeChangeBlocker(blocked, editor, false) editor.nodeChanged() } }) } var insertTextAtPosition = function (text, pos) { var container = pos.container() var offset = pos.offset() if (isText$7(container)) { container.insertData(offset, text) return Optional.some(CaretPosition(container, offset + text.length)) } else { return getElementFromPosition(pos).map(function (elm) { var textNode = SugarElement.fromText(text) if (pos.isAtEnd()) { after$3(elm, textNode) } else { before$4(elm, textNode) } return CaretPosition(textNode.dom, text.length) }) } } var insertNbspAtPosition = curry(insertTextAtPosition, nbsp) var insertSpaceAtPosition = curry(insertTextAtPosition, ' ') var locationToCaretPosition = function (root) { return function (location) { return location.fold( function (element) { return prevPosition(root.dom, CaretPosition.before(element)) }, function (element) { return firstPositionIn(element) }, function (element) { return lastPositionIn(element) }, function (element) { return nextPosition(root.dom, CaretPosition.after(element)) } ) } } var insertInlineBoundarySpaceOrNbsp = function (root, pos) { return function (checkPos) { return needsToHaveNbsp(root, checkPos) ? insertNbspAtPosition(pos) : insertSpaceAtPosition(pos) } } var setSelection = function (editor) { return function (pos) { editor.selection.setRng(pos.toRange()) editor.nodeChanged() return true } } var insertSpaceOrNbspAtSelection = function (editor) { var pos = CaretPosition.fromRangeStart(editor.selection.getRng()) var root = SugarElement.fromDom(editor.getBody()) if (editor.selection.isCollapsed()) { var isInlineTarget$1 = curry(isInlineTarget, editor) var caretPosition = CaretPosition.fromRangeStart( editor.selection.getRng() ) return readLocation(isInlineTarget$1, editor.getBody(), caretPosition) .bind(locationToCaretPosition(root)) .bind(insertInlineBoundarySpaceOrNbsp(root, pos)) .exists(setSelection(editor)) } else { return false } } var executeKeydownOverride = function (editor, evt) { execute( [ { keyCode: VK.SPACEBAR, action: action(insertSpaceOrNbspAtSelection, editor), }, ], evt ).each(function (_) { evt.preventDefault() }) } var setup$5 = function (editor) { editor.on('keydown', function (evt) { if (evt.isDefaultPrevented() === false) { executeKeydownOverride(editor, evt) } }) } var registerKeyboardOverrides = function (editor) { var caret = setupSelectedState(editor) setup$c(editor) setup$b(editor, caret) setup$a(editor, caret) setup$9(editor) setup$5(editor) setup$7(editor) setup$8(editor, caret) setup$6(editor, caret) return caret } var setup$4 = function (editor) { if (!isRtc(editor)) { return registerKeyboardOverrides(editor) } else { return Cell(null) } } var NodeChange = (function () { function NodeChange(editor) { this.lastPath = [] this.editor = editor var lastRng var self = this if (!('onselectionchange' in editor.getDoc())) { editor.on('NodeChange click mouseup keyup focus', function (e) { var nativeRng = editor.selection.getRng() var fakeRng = { startContainer: nativeRng.startContainer, startOffset: nativeRng.startOffset, endContainer: nativeRng.endContainer, endOffset: nativeRng.endOffset, } if (e.type === 'nodechange' || !isEq$4(fakeRng, lastRng)) { editor.fire('SelectionChange') } lastRng = fakeRng }) } editor.on('contextmenu', function () { editor.fire('SelectionChange') }) editor.on('SelectionChange', function () { var startElm = editor.selection.getStart(true) if (!startElm || (!Env.range && editor.selection.isCollapsed())) { return } if ( hasAnyRanges(editor) && !self.isSameElementPath(startElm) && editor.dom.isChildOf(startElm, editor.getBody()) ) { editor.nodeChanged({ selectionChange: true }) } }) editor.on('mouseup', function (e) { if (!e.isDefaultPrevented() && hasAnyRanges(editor)) { if (editor.selection.getNode().nodeName === 'IMG') { Delay.setEditorTimeout(editor, function () { editor.nodeChanged() }) } else { editor.nodeChanged() } } }) } NodeChange.prototype.nodeChanged = function (args) { var selection = this.editor.selection var node, parents, root if ( this.editor.initialized && selection && !shouldDisableNodeChange(this.editor) && !this.editor.mode.isReadOnly() ) { root = this.editor.getBody() node = selection.getStart(true) || root if ( node.ownerDocument !== this.editor.getDoc() || !this.editor.dom.isChildOf(node, root) ) { node = root } parents = [] this.editor.dom.getParent(node, function (node) { if (node === root) { return true } parents.push(node) }) args = args || {} args.element = node args.parents = parents this.editor.fire('NodeChange', args) } } NodeChange.prototype.isSameElementPath = function (startElm) { var i var currentPath = this.editor .$(startElm) .parentsUntil(this.editor.getBody()) .add(startElm) if (currentPath.length === this.lastPath.length) { for (i = currentPath.length; i >= 0; i--) { if (currentPath[i] !== this.lastPath[i]) { break } } if (i === -1) { this.lastPath = currentPath return true } } this.lastPath = currentPath return false } return NodeChange })() var preventSummaryToggle = function (editor) { editor.on('click', function (e) { if (editor.dom.getParent(e.target, 'details')) { e.preventDefault() } }) } var filterDetails = function (editor) { editor.parser.addNodeFilter('details', function (elms) { each$k(elms, function (details) { details.attr('data-mce-open', details.attr('open')) details.attr('open', 'open') }) }) editor.serializer.addNodeFilter('details', function (elms) { each$k(elms, function (details) { var open = details.attr('data-mce-open') details.attr('open', isString$1(open) ? open : null) details.attr('data-mce-open', null) }) }) } var setup$3 = function (editor) { preventSummaryToggle(editor) filterDetails(editor) } var isTextBlockNode = function (node) { return isElement$5(node) && isTextBlock$2(SugarElement.fromDom(node)) } var normalizeSelection = function (editor) { var rng = editor.selection.getRng() var startPos = CaretPosition.fromRangeStart(rng) var endPos = CaretPosition.fromRangeEnd(rng) if (CaretPosition.isElementPosition(startPos)) { var container = startPos.container() if (isTextBlockNode(container)) { firstPositionIn(container).each(function (pos) { return rng.setStart(pos.container(), pos.offset()) }) } } if (CaretPosition.isElementPosition(endPos)) { var container = startPos.container() if (isTextBlockNode(container)) { lastPositionIn(container).each(function (pos) { return rng.setEnd(pos.container(), pos.offset()) }) } } editor.selection.setRng(normalize(rng)) } var setup$2 = function (editor) { editor.on('click', function (e) { if (e.detail >= 3) { normalizeSelection(editor) } }) } var getAbsolutePosition = function (elm) { var clientRect = elm.getBoundingClientRect() var doc = elm.ownerDocument var docElem = doc.documentElement var win = doc.defaultView return { top: clientRect.top + win.pageYOffset - docElem.clientTop, left: clientRect.left + win.pageXOffset - docElem.clientLeft, } } var getBodyPosition = function (editor) { return editor.inline ? getAbsolutePosition(editor.getBody()) : { left: 0, top: 0, } } var getScrollPosition = function (editor) { var body = editor.getBody() return editor.inline ? { left: body.scrollLeft, top: body.scrollTop, } : { left: 0, top: 0, } } var getBodyScroll = function (editor) { var body = editor.getBody(), docElm = editor.getDoc().documentElement var inlineScroll = { left: body.scrollLeft, top: body.scrollTop, } var iframeScroll = { left: body.scrollLeft || docElm.scrollLeft, top: body.scrollTop || docElm.scrollTop, } return editor.inline ? inlineScroll : iframeScroll } var getMousePosition = function (editor, event) { if (event.target.ownerDocument !== editor.getDoc()) { var iframePosition = getAbsolutePosition(editor.getContentAreaContainer()) var scrollPosition = getBodyScroll(editor) return { left: event.pageX - iframePosition.left + scrollPosition.left, top: event.pageY - iframePosition.top + scrollPosition.top, } } return { left: event.pageX, top: event.pageY, } } var calculatePosition = function ( bodyPosition, scrollPosition, mousePosition ) { return { pageX: mousePosition.left - bodyPosition.left + scrollPosition.left, pageY: mousePosition.top - bodyPosition.top + scrollPosition.top, } } var calc = function (editor, event) { return calculatePosition( getBodyPosition(editor), getScrollPosition(editor), getMousePosition(editor, event) ) } var isContentEditableFalse$1 = isContentEditableFalse$b, isContentEditableTrue$1 = isContentEditableTrue$4 var isDraggable = function (rootElm, elm) { return isContentEditableFalse$1(elm) && elm !== rootElm } var isValidDropTarget = function (editor, targetElement, dragElement) { if ( targetElement === dragElement || editor.dom.isChildOf(targetElement, dragElement) ) { return false } return !isContentEditableFalse$1(targetElement) } var cloneElement = function (elm) { var cloneElm = elm.cloneNode(true) cloneElm.removeAttribute('data-mce-selected') return cloneElm } var createGhost = function (editor, elm, width, height) { var dom = editor.dom var clonedElm = elm.cloneNode(true) dom.setStyles(clonedElm, { width: width, height: height, }) dom.setAttrib(clonedElm, 'data-mce-selected', null) var ghostElm = dom.create('div', { class: 'mce-drag-container', 'data-mce-bogus': 'all', unselectable: 'on', contenteditable: 'false', }) dom.setStyles(ghostElm, { position: 'absolute', opacity: 0.5, overflow: 'hidden', border: 0, padding: 0, margin: 0, width: width, height: height, }) dom.setStyles(clonedElm, { margin: 0, boxSizing: 'border-box', }) ghostElm.appendChild(clonedElm) return ghostElm } var appendGhostToBody = function (ghostElm, bodyElm) { if (ghostElm.parentNode !== bodyElm) { bodyElm.appendChild(ghostElm) } } var moveGhost = function (ghostElm, position, width, height, maxX, maxY) { var overflowX = 0, overflowY = 0 ghostElm.style.left = position.pageX + 'px' ghostElm.style.top = position.pageY + 'px' if (position.pageX + width > maxX) { overflowX = position.pageX + width - maxX } if (position.pageY + height > maxY) { overflowY = position.pageY + height - maxY } ghostElm.style.width = width - overflowX + 'px' ghostElm.style.height = height - overflowY + 'px' } var removeElement = function (elm) { if (elm && elm.parentNode) { elm.parentNode.removeChild(elm) } } var isLeftMouseButtonPressed = function (e) { return e.button === 0 } var applyRelPos = function (state, position) { return { pageX: position.pageX - state.relX, pageY: position.pageY + 5, } } var start = function (state, editor) { return function (e) { if (isLeftMouseButtonPressed(e)) { var ceElm = find$3( editor.dom.getParents(e.target), or(isContentEditableFalse$1, isContentEditableTrue$1) ).getOr(null) if (isDraggable(editor.getBody(), ceElm)) { var elmPos = editor.dom.getPos(ceElm) var bodyElm = editor.getBody() var docElm = editor.getDoc().documentElement state.set({ element: ceElm, dragging: false, screenX: e.screenX, screenY: e.screenY, maxX: (editor.inline ? bodyElm.scrollWidth : docElm.offsetWidth) - 2, maxY: (editor.inline ? bodyElm.scrollHeight : docElm.offsetHeight) - 2, relX: e.pageX - elmPos.x, relY: e.pageY - elmPos.y, width: ceElm.offsetWidth, height: ceElm.offsetHeight, ghost: createGhost( editor, ceElm, ceElm.offsetWidth, ceElm.offsetHeight ), }) } } } } var move = function (state, editor) { var throttledPlaceCaretAt = Delay.throttle(function (clientX, clientY) { editor._selectionOverrides.hideFakeCaret() editor.selection.placeCaretAt(clientX, clientY) }, 0) editor.on('remove', throttledPlaceCaretAt.stop) return function (e) { return state.on(function (state) { var movement = Math.max( Math.abs(e.screenX - state.screenX), Math.abs(e.screenY - state.screenY) ) if (!state.dragging && movement > 10) { var args = editor.fire('dragstart', { target: state.element }) if (args.isDefaultPrevented()) { return } state.dragging = true editor.focus() } if (state.dragging) { var targetPos = applyRelPos(state, calc(editor, e)) appendGhostToBody(state.ghost, editor.getBody()) moveGhost( state.ghost, targetPos, state.width, state.height, state.maxX, state.maxY ) throttledPlaceCaretAt(e.clientX, e.clientY) } }) } } var getRawTarget = function (selection) { var rng = selection.getSel().getRangeAt(0) var startContainer = rng.startContainer return startContainer.nodeType === 3 ? startContainer.parentNode : startContainer } var drop = function (state, editor) { return function (e) { state.on(function (state) { if (state.dragging) { if ( isValidDropTarget( editor, getRawTarget(editor.selection), state.element ) ) { var targetClone_1 = cloneElement(state.element) var args = editor.fire('drop', { clientX: e.clientX, clientY: e.clientY, }) if (!args.isDefaultPrevented()) { editor.undoManager.transact(function () { removeElement(state.element) editor.insertContent(editor.dom.getOuterHTML(targetClone_1)) editor._selectionOverrides.hideFakeCaret() }) } } editor.fire('dragend') } }) removeDragState(state) } } var stop = function (state, editor) { return function () { state.on(function (state) { if (state.dragging) { editor.fire('dragend') } }) removeDragState(state) } } var removeDragState = function (state) { state.on(function (state) { removeElement(state.ghost) }) state.clear() } var bindFakeDragEvents = function (editor) { var state = value() var pageDom = DOMUtils.DOM var rootDocument = document var dragStartHandler = start(state, editor) var dragHandler = move(state, editor) var dropHandler = drop(state, editor) var dragEndHandler = stop(state, editor) editor.on('mousedown', dragStartHandler) editor.on('mousemove', dragHandler) editor.on('mouseup', dropHandler) pageDom.bind(rootDocument, 'mousemove', dragHandler) pageDom.bind(rootDocument, 'mouseup', dragEndHandler) editor.on('remove', function () { pageDom.unbind(rootDocument, 'mousemove', dragHandler) pageDom.unbind(rootDocument, 'mouseup', dragEndHandler) }) editor.on('keydown', function (e) { if (e.keyCode === VK.ESC) { dragEndHandler() } }) } var blockIeDrop = function (editor) { editor.on('drop', function (e) { var realTarget = typeof e.clientX !== 'undefined' ? editor.getDoc().elementFromPoint(e.clientX, e.clientY) : null if ( isContentEditableFalse$1(realTarget) || editor.dom.getContentEditableParent(realTarget) === 'false' ) { e.preventDefault() } }) } var blockUnsupportedFileDrop = function (editor) { var preventFileDrop = function (e) { if (!e.isDefaultPrevented()) { var dataTransfer = e.dataTransfer if ( dataTransfer && (contains$3(dataTransfer.types, 'Files') || dataTransfer.files.length > 0) ) { e.preventDefault() if (e.type === 'drop') { displayError(editor, 'Dropped file type is not supported') } } } } var preventFileDropIfUIElement = function (e) { if (isUIElement(editor, e.target)) { preventFileDrop(e) } } var setup = function () { var pageDom = DOMUtils.DOM var dom = editor.dom var doc = document var editorRoot = editor.inline ? editor.getBody() : editor.getDoc() var eventNames = ['drop', 'dragover'] each$k(eventNames, function (name) { pageDom.bind(doc, name, preventFileDropIfUIElement) dom.bind(editorRoot, name, preventFileDrop) }) editor.on('remove', function () { each$k(eventNames, function (name) { pageDom.unbind(doc, name, preventFileDropIfUIElement) dom.unbind(editorRoot, name, preventFileDrop) }) }) } editor.on('init', function () { Delay.setEditorTimeout(editor, setup, 0) }) } var init$2 = function (editor) { bindFakeDragEvents(editor) blockIeDrop(editor) if (shouldBlockUnsupportedDrop(editor)) { blockUnsupportedFileDrop(editor) } } var setup$1 = function (editor) { var renderFocusCaret = first(function () { if ( !editor.removed && editor.getBody().contains(document.activeElement) ) { var rng = editor.selection.getRng() if (rng.collapsed) { var caretRange = renderRangeCaret(editor, rng, false) editor.selection.setRng(caretRange) } } }, 0) editor.on('focus', function () { renderFocusCaret.throttle() }) editor.on('blur', function () { renderFocusCaret.cancel() }) } var setup = function (editor) { editor.on('init', function () { editor.on('focusin', function (e) { var target = e.target if (isMedia$2(target)) { var ceRoot = getContentEditableRoot$1(editor.getBody(), target) var node = isContentEditableFalse$b(ceRoot) ? ceRoot : target if (editor.selection.getNode() !== node) { selectNode(editor, node).each(function (rng) { return editor.selection.setRng(rng) }) } } }) }) } var isContentEditableTrue = isContentEditableTrue$4 var isContentEditableFalse = isContentEditableFalse$b var getContentEditableRoot = function (editor, node) { return getContentEditableRoot$1(editor.getBody(), node) } var SelectionOverrides = function (editor) { var selection = editor.selection, dom = editor.dom var isBlock = dom.isBlock var rootNode = editor.getBody() var fakeCaret = FakeCaret(editor, rootNode, isBlock, function () { return hasFocus(editor) }) var realSelectionId = 'sel-' + dom.uniqueId() var elementSelectionAttr = 'data-mce-selected' var selectedElement var isFakeSelectionElement = function (node) { return dom.hasClass(node, 'mce-offscreen-selection') } var isFakeSelectionTargetElement = function (node) { return ( node !== rootNode && (isContentEditableFalse(node) || isMedia$2(node)) && dom.isChildOf(node, rootNode) ) } var isNearFakeSelectionElement = function (pos) { return ( isBeforeContentEditableFalse(pos) || isAfterContentEditableFalse(pos) || isBeforeMedia(pos) || isAfterMedia(pos) ) } var getRealSelectionElement = function () { var container = dom.get(realSelectionId) return container ? container.getElementsByTagName('*')[0] : container } var setRange = function (range) { if (range) { selection.setRng(range) } } var getRange = selection.getRng var showCaret = function (direction, node, before, scrollIntoView) { if (scrollIntoView === void 0) { scrollIntoView = true } var e = editor.fire('ShowCaret', { target: node, direction: direction, before: before, }) if (e.isDefaultPrevented()) { return null } if (scrollIntoView) { selection.scrollIntoView(node, direction === -1) } return fakeCaret.show(before, node) } var showBlockCaretContainer = function (blockCaretContainer) { if (blockCaretContainer.hasAttribute('data-mce-caret')) { showCaretContainerBlock(blockCaretContainer) setRange(getRange()) selection.scrollIntoView(blockCaretContainer) } } var registerEvents = function () { editor.on('mouseup', function (e) { var range = getRange() if ( range.collapsed && isXYInContentArea(editor, e.clientX, e.clientY) ) { renderCaretAtRange(editor, range, false).each(setRange) } }) editor.on('click', function (e) { var contentEditableRoot = getContentEditableRoot(editor, e.target) if (contentEditableRoot) { if (isContentEditableFalse(contentEditableRoot)) { e.preventDefault() editor.focus() } if (isContentEditableTrue(contentEditableRoot)) { if (dom.isChildOf(contentEditableRoot, selection.getNode())) { removeElementSelection() } } } }) editor.on('blur NewBlock', removeElementSelection) editor.on('ResizeWindow FullscreenStateChanged', fakeCaret.reposition) var hasNormalCaretPosition = function (elm) { var start = elm.firstChild if (isNullable(start)) { return false } var startPos = CaretPosition.before(start) if (isBr$5(startPos.getNode()) && elm.childNodes.length === 1) { return !isNearFakeSelectionElement(startPos) } else { var caretWalker = CaretWalker(elm) var newPos = caretWalker.next(startPos) return newPos && !isNearFakeSelectionElement(newPos) } } var isInSameBlock = function (node1, node2) { var block1 = dom.getParent(node1, isBlock) var block2 = dom.getParent(node2, isBlock) return block1 === block2 } var hasBetterMouseTarget = function (targetNode, caretNode) { var targetBlock = dom.getParent(targetNode, isBlock) var caretBlock = dom.getParent(caretNode, isBlock) if (isNullable(targetBlock)) { return false } if ( targetNode !== caretBlock && dom.isChildOf(targetBlock, caretBlock) && isContentEditableFalse( getContentEditableRoot(editor, targetBlock) ) === false ) { return true } return ( !dom.isChildOf(caretBlock, targetBlock) && !isInSameBlock(targetBlock, caretBlock) && hasNormalCaretPosition(targetBlock) ) } editor.on( 'tap', function (e) { var targetElm = e.target var contentEditableRoot = getContentEditableRoot(editor, targetElm) if (isContentEditableFalse(contentEditableRoot)) { e.preventDefault() selectNode(editor, contentEditableRoot).each(setElementSelection) } else if (isFakeSelectionTargetElement(targetElm)) { selectNode(editor, targetElm).each(setElementSelection) } }, true ) editor.on('mousedown', function (e) { var targetElm = e.target if ( targetElm !== rootNode && targetElm.nodeName !== 'HTML' && !dom.isChildOf(targetElm, rootNode) ) { return } if (isXYInContentArea(editor, e.clientX, e.clientY) === false) { return } var contentEditableRoot = getContentEditableRoot(editor, targetElm) if (contentEditableRoot) { if (isContentEditableFalse(contentEditableRoot)) { e.preventDefault() selectNode(editor, contentEditableRoot).each(setElementSelection) } else { removeElementSelection() if ( !(isContentEditableTrue(contentEditableRoot) && e.shiftKey) && !isXYWithinRange(e.clientX, e.clientY, selection.getRng()) ) { hideFakeCaret() selection.placeCaretAt(e.clientX, e.clientY) } } } else if (isFakeSelectionTargetElement(targetElm)) { selectNode(editor, targetElm).each(setElementSelection) } else if (isFakeCaretTarget(targetElm) === false) { removeElementSelection() hideFakeCaret() var fakeCaretInfo = closestFakeCaret(rootNode, e.clientX, e.clientY) if (fakeCaretInfo) { if (!hasBetterMouseTarget(targetElm, fakeCaretInfo.node)) { e.preventDefault() var range = showCaret( 1, fakeCaretInfo.node, fakeCaretInfo.before, false ) setRange(range) editor.getBody().focus() } } } }) editor.on('keypress', function (e) { if (VK.modifierPressed(e)) { return } if (isContentEditableFalse(selection.getNode())) { e.preventDefault() } }) editor.on('GetSelectionRange', function (e) { var rng = e.range if (selectedElement) { if (!selectedElement.parentNode) { selectedElement = null return } rng = rng.cloneRange() rng.selectNode(selectedElement) e.range = rng } }) editor.on('SetSelectionRange', function (e) { e.range = normalizeShortEndedElementSelection(e.range) var rng = setElementSelection(e.range, e.forward) if (rng) { e.range = rng } }) var isPasteBin = function (node) { return node.id === 'mcepastebin' } editor.on('AfterSetSelectionRange', function (e) { var rng = e.range var parentNode = rng.startContainer.parentNode if (!isRangeInCaretContainer(rng) && !isPasteBin(parentNode)) { hideFakeCaret() } if (!isFakeSelectionElement(parentNode)) { removeElementSelection() } }) editor.on('copy', function (e) { var clipboardData = e.clipboardData if (!e.isDefaultPrevented() && e.clipboardData && !Env.ie) { var realSelectionElement = getRealSelectionElement() if (realSelectionElement) { e.preventDefault() clipboardData.clearData() clipboardData.setData('text/html', realSelectionElement.outerHTML) clipboardData.setData( 'text/plain', realSelectionElement.outerText || realSelectionElement.innerText ) } } }) init$2(editor) setup$1(editor) setup(editor) } var isWithinCaretContainer = function (node) { return ( isCaretContainer$2(node) || startsWithCaretContainer$1(node) || endsWithCaretContainer$1(node) ) } var isRangeInCaretContainer = function (rng) { return ( isWithinCaretContainer(rng.startContainer) || isWithinCaretContainer(rng.endContainer) ) } var normalizeShortEndedElementSelection = function (rng) { var shortEndedElements = editor.schema.getShortEndedElements() var newRng = dom.createRng() var startContainer = rng.startContainer var startOffset = rng.startOffset var endContainer = rng.endContainer var endOffset = rng.endOffset if (has$2(shortEndedElements, startContainer.nodeName.toLowerCase())) { if (startOffset === 0) { newRng.setStartBefore(startContainer) } else { newRng.setStartAfter(startContainer) } } else { newRng.setStart(startContainer, startOffset) } if (has$2(shortEndedElements, endContainer.nodeName.toLowerCase())) { if (endOffset === 0) { newRng.setEndBefore(endContainer) } else { newRng.setEndAfter(endContainer) } } else { newRng.setEnd(endContainer, endOffset) } return newRng } var setupOffscreenSelection = function ( node, targetClone, origTargetClone ) { var $ = editor.$ var $realSelectionContainer = descendant( SugarElement.fromDom(editor.getBody()), '#' + realSelectionId ).fold( function () { return $([]) }, function (elm) { return $([elm.dom]) } ) if ($realSelectionContainer.length === 0) { $realSelectionContainer = $( '
    ' ).attr('id', realSelectionId) $realSelectionContainer.appendTo(editor.getBody()) } var newRange = dom.createRng() if (targetClone === origTargetClone && Env.ie) { $realSelectionContainer .empty() .append('

    \xA0

    ') .append(targetClone) newRange.setStartAfter($realSelectionContainer[0].firstChild.firstChild) newRange.setEndAfter(targetClone) } else { $realSelectionContainer .empty() .append(nbsp) .append(targetClone) .append(nbsp) newRange.setStart($realSelectionContainer[0].firstChild, 1) newRange.setEnd($realSelectionContainer[0].lastChild, 0) } $realSelectionContainer.css({ top: dom.getPos(node, editor.getBody()).y }) $realSelectionContainer[0].focus() var sel = selection.getSel() sel.removeAllRanges() sel.addRange(newRange) return newRange } var selectElement = function (elm) { var targetClone = elm.cloneNode(true) var e = editor.fire('ObjectSelected', { target: elm, targetClone: targetClone, }) if (e.isDefaultPrevented()) { return null } var range = setupOffscreenSelection(elm, e.targetClone, targetClone) var nodeElm = SugarElement.fromDom(elm) each$k( descendants( SugarElement.fromDom(editor.getBody()), '*[data-mce-selected]' ), function (elm) { if (!eq(nodeElm, elm)) { remove$6(elm, elementSelectionAttr) } } ) if (!dom.getAttrib(elm, elementSelectionAttr)) { elm.setAttribute(elementSelectionAttr, '1') } selectedElement = elm hideFakeCaret() return range } var setElementSelection = function (range, forward) { if (!range) { return null } if (range.collapsed) { if (!isRangeInCaretContainer(range)) { var dir = forward ? 1 : -1 var caretPosition = getNormalizedRangeEndPoint(dir, rootNode, range) var beforeNode = caretPosition.getNode(!forward) if (isFakeCaretTarget(beforeNode)) { return showCaret( dir, beforeNode, forward ? !caretPosition.isAtEnd() : false, false ) } var afterNode = caretPosition.getNode(forward) if (isFakeCaretTarget(afterNode)) { return showCaret( dir, afterNode, forward ? false : !caretPosition.isAtEnd(), false ) } } return null } var startContainer = range.startContainer var startOffset = range.startOffset var endOffset = range.endOffset if ( startContainer.nodeType === 3 && startOffset === 0 && isContentEditableFalse(startContainer.parentNode) ) { startContainer = startContainer.parentNode startOffset = dom.nodeIndex(startContainer) startContainer = startContainer.parentNode } if (startContainer.nodeType !== 1) { return null } if ( endOffset === startOffset + 1 && startContainer === range.endContainer ) { var node = startContainer.childNodes[startOffset] if (isFakeSelectionTargetElement(node)) { return selectElement(node) } } return null } var removeElementSelection = function () { if (selectedElement) { selectedElement.removeAttribute(elementSelectionAttr) } descendant( SugarElement.fromDom(editor.getBody()), '#' + realSelectionId ).each(remove$7) selectedElement = null } var destroy = function () { fakeCaret.destroy() selectedElement = null } var hideFakeCaret = function () { fakeCaret.hide() } if (Env.ceFalse && !isRtc(editor)) { registerEvents() } return { showCaret: showCaret, showBlockCaretContainer: showBlockCaretContainer, hideFakeCaret: hideFakeCaret, destroy: destroy, } } var Quirks = function (editor) { var each = Tools.each var BACKSPACE = VK.BACKSPACE, DELETE = VK.DELETE, dom = editor.dom, selection = editor.selection, parser = editor.parser var isGecko = Env.gecko, isIE = Env.ie, isWebKit = Env.webkit var mceInternalUrlPrefix = 'data:text/mce-internal,' var mceInternalDataType = isIE ? 'Text' : 'URL' var setEditorCommandState = function (cmd, state) { try { editor.getDoc().execCommand(cmd, false, state) } catch (ex) {} } var isDefaultPrevented = function (e) { return e.isDefaultPrevented() } var setMceInternalContent = function (e) { var selectionHtml, internalContent if (e.dataTransfer) { if (editor.selection.isCollapsed() && e.target.tagName === 'IMG') { selection.select(e.target) } selectionHtml = editor.selection.getContent() if (selectionHtml.length > 0) { internalContent = mceInternalUrlPrefix + escape(editor.id) + ',' + escape(selectionHtml) e.dataTransfer.setData(mceInternalDataType, internalContent) } } } var getMceInternalContent = function (e) { var internalContent if (e.dataTransfer) { internalContent = e.dataTransfer.getData(mceInternalDataType) if ( internalContent && internalContent.indexOf(mceInternalUrlPrefix) >= 0 ) { internalContent = internalContent .substr(mceInternalUrlPrefix.length) .split(',') return { id: unescape(internalContent[0]), html: unescape(internalContent[1]), } } } return null } var insertClipboardContents = function (content, internal) { if (editor.queryCommandSupported('mceInsertClipboardContent')) { editor.execCommand('mceInsertClipboardContent', false, { content: content, internal: internal, }) } else { editor.execCommand('mceInsertContent', false, content) } } var emptyEditorWhenDeleting = function () { var serializeRng = function (rng) { var body = dom.create('body') var contents = rng.cloneContents() body.appendChild(contents) return selection.serializer.serialize(body, { format: 'html' }) } var allContentsSelected = function (rng) { var selection = serializeRng(rng) var allRng = dom.createRng() allRng.selectNode(editor.getBody()) var allSelection = serializeRng(allRng) return selection === allSelection } editor.on('keydown', function (e) { var keyCode = e.keyCode var isCollapsed, body if ( !isDefaultPrevented(e) && (keyCode === DELETE || keyCode === BACKSPACE) ) { isCollapsed = editor.selection.isCollapsed() body = editor.getBody() if (isCollapsed && !dom.isEmpty(body)) { return } if (!isCollapsed && !allContentsSelected(editor.selection.getRng())) { return } e.preventDefault() editor.setContent('') if (body.firstChild && dom.isBlock(body.firstChild)) { editor.selection.setCursorLocation(body.firstChild, 0) } else { editor.selection.setCursorLocation(body, 0) } editor.nodeChanged() } }) } var selectAll = function () { editor.shortcuts.add('meta+a', null, 'SelectAll') } var documentElementEditingFocus = function () { if (!editor.inline) { dom.bind(editor.getDoc(), 'mousedown mouseup', function (e) { var rng if (e.target === editor.getDoc().documentElement) { rng = selection.getRng() editor.getBody().focus() if (e.type === 'mousedown') { if (isCaretContainer$2(rng.startContainer)) { return } selection.placeCaretAt(e.clientX, e.clientY) } else { selection.setRng(rng) } } }) } } var removeHrOnBackspace = function () { editor.on('keydown', function (e) { if (!isDefaultPrevented(e) && e.keyCode === BACKSPACE) { if (!editor.getBody().getElementsByTagName('hr').length) { return } if (selection.isCollapsed() && selection.getRng().startOffset === 0) { var node = selection.getNode() var previousSibling = node.previousSibling if (node.nodeName === 'HR') { dom.remove(node) e.preventDefault() return } if ( previousSibling && previousSibling.nodeName && previousSibling.nodeName.toLowerCase() === 'hr' ) { dom.remove(previousSibling) e.preventDefault() } } } }) } var focusBody = function () { if (!Range.prototype.getClientRects) { editor.on('mousedown', function (e) { if (!isDefaultPrevented(e) && e.target.nodeName === 'HTML') { var body_1 = editor.getBody() body_1.blur() Delay.setEditorTimeout(editor, function () { body_1.focus() }) } }) } } var selectControlElements = function () { editor.on('click', function (e) { var target = e.target if ( /^(IMG|HR)$/.test(target.nodeName) && dom.getContentEditableParent(target) !== 'false' ) { e.preventDefault() editor.selection.select(target) editor.nodeChanged() } if ( target.nodeName === 'A' && dom.hasClass(target, 'mce-item-anchor') ) { e.preventDefault() selection.select(target) } }) } var removeStylesWhenDeletingAcrossBlockElements = function () { var getAttributeApplyFunction = function () { var template = dom.getAttribs(selection.getStart().cloneNode(false)) return function () { var target = selection.getStart() if (target !== editor.getBody()) { dom.setAttrib(target, 'style', null) each(template, function (attr) { target.setAttributeNode(attr.cloneNode(true)) }) } } } var isSelectionAcrossElements = function () { return ( !selection.isCollapsed() && dom.getParent(selection.getStart(), dom.isBlock) !== dom.getParent(selection.getEnd(), dom.isBlock) ) } editor.on('keypress', function (e) { var applyAttributes if ( !isDefaultPrevented(e) && (e.keyCode === 8 || e.keyCode === 46) && isSelectionAcrossElements() ) { applyAttributes = getAttributeApplyFunction() editor.getDoc().execCommand('delete', false, null) applyAttributes() e.preventDefault() return false } }) dom.bind(editor.getDoc(), 'cut', function (e) { var applyAttributes if (!isDefaultPrevented(e) && isSelectionAcrossElements()) { applyAttributes = getAttributeApplyFunction() Delay.setEditorTimeout(editor, function () { applyAttributes() }) } }) } var disableBackspaceIntoATable = function () { editor.on('keydown', function (e) { if (!isDefaultPrevented(e) && e.keyCode === BACKSPACE) { if (selection.isCollapsed() && selection.getRng().startOffset === 0) { var previousSibling = selection.getNode().previousSibling if ( previousSibling && previousSibling.nodeName && previousSibling.nodeName.toLowerCase() === 'table' ) { e.preventDefault() return false } } } }) } var removeBlockQuoteOnBackSpace = function () { editor.on('keydown', function (e) { var rng, parent if (isDefaultPrevented(e) || e.keyCode !== VK.BACKSPACE) { return } rng = selection.getRng() var container = rng.startContainer var offset = rng.startOffset var root = dom.getRoot() parent = container if (!rng.collapsed || offset !== 0) { return } while ( parent && parent.parentNode && parent.parentNode.firstChild === parent && parent.parentNode !== root ) { parent = parent.parentNode } if (parent.tagName === 'BLOCKQUOTE') { editor.formatter.toggle('blockquote', null, parent) rng = dom.createRng() rng.setStart(container, 0) rng.setEnd(container, 0) selection.setRng(rng) } }) } var setGeckoEditingOptions = function () { var setOpts = function () { setEditorCommandState('StyleWithCSS', false) setEditorCommandState('enableInlineTableEditing', false) if (!getObjectResizing(editor)) { setEditorCommandState('enableObjectResizing', false) } } if (!isReadOnly$1(editor)) { editor.on('BeforeExecCommand mousedown', setOpts) } } var addBrAfterLastLinks = function () { var fixLinks = function () { each(dom.select('a'), function (node) { var parentNode = node.parentNode var root = dom.getRoot() if (parentNode.lastChild === node) { while (parentNode && !dom.isBlock(parentNode)) { if ( parentNode.parentNode.lastChild !== parentNode || parentNode === root ) { return } parentNode = parentNode.parentNode } dom.add(parentNode, 'br', { 'data-mce-bogus': 1 }) } }) } editor.on('SetContent ExecCommand', function (e) { if (e.type === 'setcontent' || e.command === 'mceInsertLink') { fixLinks() } }) } var setDefaultBlockType = function () { if (getForcedRootBlock(editor)) { editor.on('init', function () { setEditorCommandState( 'DefaultParagraphSeparator', getForcedRootBlock(editor) ) }) } } var normalizeSelection = function () { editor.on( 'keyup focusin mouseup', function (e) { if (!VK.modifierPressed(e)) { selection.normalize() } }, true ) } var showBrokenImageIcon = function () { editor.contentStyles.push( 'img:-moz-broken {' + '-moz-force-broken-image-icon:1;' + 'min-width:24px;' + 'min-height:24px' + '}' ) } var restoreFocusOnKeyDown = function () { if (!editor.inline) { editor.on('keydown', function () { if (document.activeElement === document.body) { editor.getWin().focus() } }) } } var bodyHeight = function () { if (!editor.inline) { editor.contentStyles.push('body {min-height: 150px}') editor.on('click', function (e) { var rng if (e.target.nodeName === 'HTML') { if (Env.ie > 11) { editor.getBody().focus() return } rng = editor.selection.getRng() editor.getBody().focus() editor.selection.setRng(rng) editor.selection.normalize() editor.nodeChanged() } }) } } var blockCmdArrowNavigation = function () { if (Env.mac) { editor.on('keydown', function (e) { if ( VK.metaKeyPressed(e) && !e.shiftKey && (e.keyCode === 37 || e.keyCode === 39) ) { e.preventDefault() var selection_1 = editor.selection.getSel() selection_1.modify( 'move', e.keyCode === 37 ? 'backward' : 'forward', 'lineboundary' ) } }) } } var disableAutoUrlDetect = function () { setEditorCommandState('AutoUrlDetect', false) } var tapLinksAndImages = function () { editor.on('click', function (e) { var elm = e.target do { if (elm.tagName === 'A') { e.preventDefault() return } } while ((elm = elm.parentNode)) }) editor.contentStyles.push( '.mce-content-body {-webkit-touch-callout: none}' ) } var blockFormSubmitInsideEditor = function () { editor.on('init', function () { editor.dom.bind(editor.getBody(), 'submit', function (e) { e.preventDefault() }) }) } var removeAppleInterchangeBrs = function () { parser.addNodeFilter('br', function (nodes) { var i = nodes.length while (i--) { if (nodes[i].attr('class') === 'Apple-interchange-newline') { nodes[i].remove() } } }) } var ieInternalDragAndDrop = function () { editor.on('dragstart', function (e) { setMceInternalContent(e) }) editor.on('drop', function (e) { if (!isDefaultPrevented(e)) { var internalContent = getMceInternalContent(e) if (internalContent && internalContent.id !== editor.id) { e.preventDefault() var rng = fromPoint(e.x, e.y, editor.getDoc()) selection.setRng(rng) insertClipboardContents(internalContent.html, true) } } }) } var refreshContentEditable = noop var isHidden = function () { if (!isGecko || editor.removed) { return false } var sel = editor.selection.getSel() return !sel || !sel.rangeCount || sel.rangeCount === 0 } var setupRtc = function () { if (isWebKit) { documentElementEditingFocus() selectControlElements() blockFormSubmitInsideEditor() selectAll() if (Env.iOS) { restoreFocusOnKeyDown() bodyHeight() tapLinksAndImages() } } if (isGecko) { focusBody() setGeckoEditingOptions() showBrokenImageIcon() blockCmdArrowNavigation() } } var setup = function () { removeBlockQuoteOnBackSpace() emptyEditorWhenDeleting() if (!Env.windowsPhone) { normalizeSelection() } if (isWebKit) { documentElementEditingFocus() selectControlElements() setDefaultBlockType() blockFormSubmitInsideEditor() disableBackspaceIntoATable() removeAppleInterchangeBrs() if (Env.iOS) { restoreFocusOnKeyDown() bodyHeight() tapLinksAndImages() } else { selectAll() } } if (Env.ie >= 11) { bodyHeight() disableBackspaceIntoATable() } if (Env.ie) { selectAll() disableAutoUrlDetect() ieInternalDragAndDrop() } if (isGecko) { removeHrOnBackspace() focusBody() removeStylesWhenDeletingAcrossBlockElements() setGeckoEditingOptions() addBrAfterLastLinks() showBrokenImageIcon() blockCmdArrowNavigation() disableBackspaceIntoATable() } } if (isRtc(editor)) { setupRtc() } else { setup() } return { refreshContentEditable: refreshContentEditable, isHidden: isHidden, } } var DOM$6 = DOMUtils.DOM var appendStyle = function (editor, text) { var body = SugarElement.fromDom(editor.getBody()) var container = getStyleContainer(getRootNode(body)) var style = SugarElement.fromTag('style') set$1(style, 'type', 'text/css') append$1(style, SugarElement.fromText(text)) append$1(container, style) editor.on('remove', function () { remove$7(style) }) } var getRootName = function (editor) { return editor.inline ? editor.getElement().nodeName.toLowerCase() : undefined } var removeUndefined = function (obj) { return filter$3(obj, function (v) { return isUndefined(v) === false }) } var mkParserSettings = function (editor) { var settings = editor.settings var blobCache = editor.editorUpload.blobCache return removeUndefined({ allow_conditional_comments: settings.allow_conditional_comments, allow_html_data_urls: settings.allow_html_data_urls, allow_svg_data_urls: settings.allow_svg_data_urls, allow_html_in_named_anchor: settings.allow_html_in_named_anchor, allow_script_urls: settings.allow_script_urls, allow_unsafe_link_target: settings.allow_unsafe_link_target, convert_fonts_to_spans: settings.convert_fonts_to_spans, fix_list_elements: settings.fix_list_elements, font_size_legacy_values: settings.font_size_legacy_values, forced_root_block: settings.forced_root_block, forced_root_block_attrs: settings.forced_root_block_attrs, padd_empty_with_br: settings.padd_empty_with_br, preserve_cdata: settings.preserve_cdata, remove_trailing_brs: settings.remove_trailing_brs, inline_styles: settings.inline_styles, root_name: getRootName(editor), validate: true, blob_cache: blobCache, document: editor.getDoc(), images_dataimg_filter: settings.images_dataimg_filter, }) } var mkSerializerSettings = function (editor) { var settings = editor.settings return __assign( __assign({}, mkParserSettings(editor)), removeUndefined({ url_converter: settings.url_converter, url_converter_scope: settings.url_converter_scope, element_format: settings.element_format, entities: settings.entities, entity_encoding: settings.entity_encoding, indent: settings.indent, indent_after: settings.indent_after, indent_before: settings.indent_before, block_elements: settings.block_elements, boolean_attributes: settings.boolean_attributes, custom_elements: settings.custom_elements, extended_valid_elements: settings.extended_valid_elements, invalid_elements: settings.invalid_elements, invalid_styles: settings.invalid_styles, move_caret_before_on_enter_elements: settings.move_caret_before_on_enter_elements, non_empty_elements: settings.non_empty_elements, schema: settings.schema, self_closing_elements: settings.self_closing_elements, short_ended_elements: settings.short_ended_elements, special: settings.special, text_block_elements: settings.text_block_elements, text_inline_elements: settings.text_inline_elements, valid_children: settings.valid_children, valid_classes: settings.valid_classes, valid_elements: settings.valid_elements, valid_styles: settings.valid_styles, verify_html: settings.verify_html, whitespace_elements: settings.whitespace_elements, }) ) } var createParser = function (editor) { var parser = DomParser(mkParserSettings(editor), editor.schema) parser.addAttributeFilter( 'src,href,style,tabindex', function (nodes, name) { var i = nodes.length, node, value var dom = editor.dom var internalName = 'data-mce-' + name while (i--) { node = nodes[i] value = node.attr(name) if (value && !node.attr(internalName)) { if (value.indexOf('data:') === 0 || value.indexOf('blob:') === 0) { continue } if (name === 'style') { value = dom.serializeStyle(dom.parseStyle(value), node.name) if (!value.length) { value = null } node.attr(internalName, value) node.attr(name, value) } else if (name === 'tabindex') { node.attr(internalName, value) node.attr(name, null) } else { node.attr(internalName, editor.convertURL(value, name, node.name)) } } } } ) parser.addNodeFilter('script', function (nodes) { var i = nodes.length while (i--) { var node = nodes[i] var type = node.attr('type') || 'no/type' if (type.indexOf('mce-') !== 0) { node.attr('type', 'mce-' + type) } } }) if (editor.settings.preserve_cdata) { parser.addNodeFilter('#cdata', function (nodes) { var i = nodes.length while (i--) { var node = nodes[i] node.type = 8 node.name = '#comment' node.value = '[CDATA[' + editor.dom.encode(node.value) + ']]' } }) } parser.addNodeFilter('p,h1,h2,h3,h4,h5,h6,div', function (nodes) { var i = nodes.length var nonEmptyElements = editor.schema.getNonEmptyElements() while (i--) { var node = nodes[i] if (node.isEmpty(nonEmptyElements) && node.getAll('br').length === 0) { node.append(new AstNode('br', 1)).shortEnded = true } } }) return parser } var autoFocus = function (editor) { if (editor.settings.auto_focus) { Delay.setEditorTimeout( editor, function () { var focusEditor if (editor.settings.auto_focus === true) { focusEditor = editor } else { focusEditor = editor.editorManager.get(editor.settings.auto_focus) } if (!focusEditor.destroyed) { focusEditor.focus() } }, 100 ) } } var moveSelectionToFirstCaretPosition = function (editor) { var root = editor.dom.getRoot() if ( !editor.inline && (!hasAnyRanges(editor) || editor.selection.getStart(true) === root) ) { firstPositionIn(root).each(function (pos) { var node = pos.getNode() var caretPos = isTable$3(node) ? firstPositionIn(node).getOr(pos) : pos if (Env.browser.isIE()) { storeNative(editor, caretPos.toRange()) } else { editor.selection.setRng(caretPos.toRange()) } }) } } var initEditor = function (editor) { editor.bindPendingEventDelegates() editor.initialized = true fireInit(editor) editor.focus(true) moveSelectionToFirstCaretPosition(editor) editor.nodeChanged({ initial: true }) editor.execCallback('init_instance_callback', editor) autoFocus(editor) } var getStyleSheetLoader$1 = function (editor) { return editor.inline ? editor.ui.styleSheetLoader : editor.dom.styleSheetLoader } var makeStylesheetLoadingPromises = function (editor, css, framedFonts) { var promises = [ new promiseObj(function (resolve, reject) { return getStyleSheetLoader$1(editor).loadAll(css, resolve, reject) }), ] if (editor.inline) { return promises } else { return promises.concat([ new promiseObj(function (resolve, reject) { return editor.ui.styleSheetLoader.loadAll( framedFonts, resolve, reject ) }), ]) } } var loadContentCss = function (editor) { var styleSheetLoader = getStyleSheetLoader$1(editor) var fontCss = getFontCss(editor) var css = editor.contentCSS var removeCss = function () { styleSheetLoader.unloadAll(css) if (!editor.inline) { editor.ui.styleSheetLoader.unloadAll(fontCss) } } var loaded = function () { if (editor.removed) { removeCss() } else { editor.on('remove', removeCss) } } if (editor.contentStyles.length > 0) { var contentCssText_1 = '' Tools.each(editor.contentStyles, function (style) { contentCssText_1 += style + '\r\n' }) editor.dom.addStyle(contentCssText_1) } var allStylesheets = promiseObj .all(makeStylesheetLoadingPromises(editor, css, fontCss)) .then(loaded) .catch(loaded) if (editor.settings.content_style) { appendStyle(editor, editor.settings.content_style) } return allStylesheets } var preInit = function (editor) { var settings = editor.settings, doc = editor.getDoc(), body = editor.getBody() firePreInit(editor) if (!settings.browser_spellcheck && !settings.gecko_spellcheck) { doc.body.spellcheck = false DOM$6.setAttrib(body, 'spellcheck', 'false') } editor.quirks = Quirks(editor) firePostRender(editor) var directionality = getDirectionality(editor) if (directionality !== undefined) { body.dir = directionality } if (settings.protect) { editor.on('BeforeSetContent', function (e) { Tools.each(settings.protect, function (pattern) { e.content = e.content.replace(pattern, function (str) { return '' }) }) }) } editor.on('SetContent', function () { editor.addVisual(editor.getBody()) }) editor.on('compositionstart compositionend', function (e) { editor.composing = e.type === 'compositionstart' }) } var loadInitialContent = function (editor) { if (!isRtc(editor)) { editor.load({ initial: true, format: 'html', }) } editor.startContent = editor.getContent({ format: 'raw' }) } var initEditorWithInitialContent = function (editor) { if (editor.removed !== true) { loadInitialContent(editor) initEditor(editor) } } var initContentBody = function (editor, skipWrite) { var settings = editor.settings var targetElm = editor.getElement() var doc = editor.getDoc() if (!settings.inline) { editor.getElement().style.visibility = editor.orgVisibility } if (!skipWrite && !editor.inline) { doc.open() doc.write(editor.iframeHTML) doc.close() } if (editor.inline) { DOM$6.addClass(targetElm, 'mce-content-body') editor.contentDocument = doc = document editor.contentWindow = window editor.bodyElement = targetElm editor.contentAreaContainer = targetElm } var body = editor.getBody() body.disabled = true editor.readonly = !!settings.readonly if (!editor.readonly) { if ( editor.inline && DOM$6.getStyle(body, 'position', true) === 'static' ) { body.style.position = 'relative' } body.contentEditable = editor.getParam('content_editable_state', true) } body.disabled = false editor.editorUpload = EditorUpload(editor) editor.schema = Schema(settings) editor.dom = DOMUtils(doc, { keep_values: true, url_converter: editor.convertURL, url_converter_scope: editor, hex_colors: settings.force_hex_style_colors, update_styles: true, root_element: editor.inline ? editor.getBody() : null, collect: function () { return editor.inline }, schema: editor.schema, contentCssCors: shouldUseContentCssCors(editor), referrerPolicy: getReferrerPolicy(editor), onSetAttrib: function (e) { editor.fire('SetAttrib', e) }, }) editor.parser = createParser(editor) editor.serializer = DomSerializer(mkSerializerSettings(editor), editor) editor.selection = EditorSelection( editor.dom, editor.getWin(), editor.serializer, editor ) editor.annotator = Annotator(editor) editor.formatter = Formatter(editor) editor.undoManager = UndoManager(editor) editor._nodeChangeDispatcher = new NodeChange(editor) editor._selectionOverrides = SelectionOverrides(editor) setup$e(editor) setup$3(editor) if (!isRtc(editor)) { setup$2(editor) } var caret = setup$4(editor) setup$f(editor, caret) setup$d(editor) setup$g(editor) var setupRtcThunk = setup$i(editor) preInit(editor) setupRtcThunk.fold( function () { loadContentCss(editor).then(function () { return initEditorWithInitialContent(editor) }) }, function (setupRtc) { editor.setProgressState(true) loadContentCss(editor).then(function () { setupRtc().then( function (_rtcMode) { editor.setProgressState(false) initEditorWithInitialContent(editor) }, function (err) { editor.notificationManager.open({ type: 'error', text: String(err), }) initEditorWithInitialContent(editor) } ) }) } ) } var DOM$5 = DOMUtils.DOM var relaxDomain = function (editor, ifr) { if (document.domain !== window.location.hostname && Env.browser.isIE()) { var bodyUuid = uuid('mce') editor[bodyUuid] = function () { initContentBody(editor) } var domainRelaxUrl = 'javascript:(function(){' + 'document.open();document.domain="' + document.domain + '";' + 'var ed = window.parent.tinymce.get("' + editor.id + '");document.write(ed.iframeHTML);' + 'document.close();ed.' + bodyUuid + '(true);})()' DOM$5.setAttrib(ifr, 'src', domainRelaxUrl) return true } return false } var createIframeElement = function (id, title, height, customAttrs) { var iframe = SugarElement.fromTag('iframe') setAll$1(iframe, customAttrs) setAll$1(iframe, { id: id + '_ifr', frameBorder: '0', allowTransparency: 'true', title: title, }) add$1(iframe, 'tox-edit-area__iframe') return iframe } var getIframeHtml = function (editor) { var iframeHTML = getDocType(editor) + '' if (getDocumentBaseUrl(editor) !== editor.documentBaseUrl) { iframeHTML += '' } iframeHTML += '' var bodyId = getBodyId(editor) var bodyClass = getBodyClass(editor) var translatedAriaText = editor.translate(getIframeAriaText(editor)) if (getContentSecurityPolicy(editor)) { iframeHTML += '' } iframeHTML += '' + ('') + '
    ' + '' return iframeHTML } var createIframe = function (editor, o) { var iframeTitle = editor.translate('Rich Text Area') var ifr = createIframeElement( editor.id, iframeTitle, o.height, getIframeAttrs(editor) ).dom ifr.onload = function () { ifr.onload = null editor.fire('load') } var isDomainRelaxed = relaxDomain(editor, ifr) editor.contentAreaContainer = o.iframeContainer editor.iframeElement = ifr editor.iframeHTML = getIframeHtml(editor) DOM$5.add(o.iframeContainer, ifr) return isDomainRelaxed } var init$1 = function (editor, boxInfo) { var isDomainRelaxed = createIframe(editor, boxInfo) if (boxInfo.editorContainer) { DOM$5.get(boxInfo.editorContainer).style.display = editor.orgDisplay editor.hidden = DOM$5.isHidden(boxInfo.editorContainer) } editor.getElement().style.display = 'none' DOM$5.setAttrib(editor.id, 'aria-hidden', 'true') if (!isDomainRelaxed) { initContentBody(editor) } } var DOM$4 = DOMUtils.DOM var initPlugin = function (editor, initializedPlugins, plugin) { var Plugin = PluginManager.get(plugin) var pluginUrl = PluginManager.urls[plugin] || editor.documentBaseUrl.replace(/\/$/, '') plugin = Tools.trim(plugin) if (Plugin && Tools.inArray(initializedPlugins, plugin) === -1) { Tools.each(PluginManager.dependencies(plugin), function (dep) { initPlugin(editor, initializedPlugins, dep) }) if (editor.plugins[plugin]) { return } try { var pluginInstance = new Plugin(editor, pluginUrl, editor.$) editor.plugins[plugin] = pluginInstance if (pluginInstance.init) { pluginInstance.init(editor, pluginUrl) initializedPlugins.push(plugin) } } catch (e) { pluginInitError(editor, plugin, e) } } } var trimLegacyPrefix = function (name) { return name.replace(/^\-/, '') } var initPlugins = function (editor) { var initializedPlugins = [] Tools.each(getPlugins(editor).split(/[ ,]/), function (name) { initPlugin(editor, initializedPlugins, trimLegacyPrefix(name)) }) } var initIcons = function (editor) { var iconPackName = Tools.trim(getIconPackName(editor)) var currentIcons = editor.ui.registry.getAll().icons var loadIcons = __assign( __assign({}, IconManager.get('default').icons), IconManager.get(iconPackName).icons ) each$j(loadIcons, function (svgData, icon) { if (!has$2(currentIcons, icon)) { editor.ui.registry.addIcon(icon, svgData) } }) } var initTheme = function (editor) { var theme = getTheme(editor) if (isString$1(theme)) { editor.settings.theme = trimLegacyPrefix(theme) var Theme = ThemeManager.get(theme) editor.theme = new Theme(editor, ThemeManager.urls[theme]) if (editor.theme.init) { editor.theme.init( editor, ThemeManager.urls[theme] || editor.documentBaseUrl.replace(/\/$/, ''), editor.$ ) } } else { editor.theme = {} } } var renderFromLoadedTheme = function (editor) { return editor.theme.renderUI() } var renderFromThemeFunc = function (editor) { var elm = editor.getElement() var theme = getTheme(editor) var info = theme(editor, elm) if (info.editorContainer.nodeType) { info.editorContainer.id = info.editorContainer.id || editor.id + '_parent' } if (info.iframeContainer && info.iframeContainer.nodeType) { info.iframeContainer.id = info.iframeContainer.id || editor.id + '_iframecontainer' } info.height = info.iframeHeight ? info.iframeHeight : elm.offsetHeight return info } var createThemeFalseResult = function (element) { return { editorContainer: element, iframeContainer: element, api: {}, } } var renderThemeFalseIframe = function (targetElement) { var iframeContainer = DOM$4.create('div') DOM$4.insertAfter(iframeContainer, targetElement) return createThemeFalseResult(iframeContainer) } var renderThemeFalse = function (editor) { var targetElement = editor.getElement() return editor.inline ? createThemeFalseResult(null) : renderThemeFalseIframe(targetElement) } var renderThemeUi = function (editor) { var elm = editor.getElement() editor.orgDisplay = elm.style.display if (isString$1(getTheme(editor))) { return renderFromLoadedTheme(editor) } else if (isFunction(getTheme(editor))) { return renderFromThemeFunc(editor) } else { return renderThemeFalse(editor) } } var augmentEditorUiApi = function (editor, api) { var uiApiFacade = { show: Optional.from(api.show).getOr(noop), hide: Optional.from(api.hide).getOr(noop), disable: Optional.from(api.disable).getOr(noop), isDisabled: Optional.from(api.isDisabled).getOr(never), enable: function () { if (!editor.mode.isReadOnly()) { Optional.from(api.enable).map(call) } }, } editor.ui = __assign(__assign({}, editor.ui), uiApiFacade) } var init = function (editor) { editor.fire('ScriptsLoaded') initIcons(editor) initTheme(editor) initPlugins(editor) var renderInfo = renderThemeUi(editor) augmentEditorUiApi(editor, Optional.from(renderInfo.api).getOr({})) var boxInfo = { editorContainer: renderInfo.editorContainer, iframeContainer: renderInfo.iframeContainer, } editor.editorContainer = boxInfo.editorContainer ? boxInfo.editorContainer : null appendContentCssFromSettings(editor) if (editor.inline) { return initContentBody(editor) } else { return init$1(editor, boxInfo) } } var DOM$3 = DOMUtils.DOM var hasSkipLoadPrefix = function (name) { return name.charAt(0) === '-' } var loadLanguage = function (scriptLoader, editor) { var languageCode = getLanguageCode(editor) var languageUrl = getLanguageUrl(editor) if (I18n.hasCode(languageCode) === false && languageCode !== 'en') { var url_1 = languageUrl !== '' ? languageUrl : editor.editorManager.baseURL + '/langs/' + languageCode + '.js' scriptLoader.add(url_1, noop, undefined, function () { languageLoadError(editor, url_1, languageCode) }) } } var loadTheme = function (scriptLoader, editor, suffix, callback) { var theme = getTheme(editor) if (isString$1(theme)) { if (!hasSkipLoadPrefix(theme) && !has$2(ThemeManager.urls, theme)) { var themeUrl = getThemeUrl(editor) if (themeUrl) { ThemeManager.load(theme, editor.documentBaseURI.toAbsolute(themeUrl)) } else { ThemeManager.load( theme, 'themes/' + theme + '/theme' + suffix + '.js' ) } } scriptLoader.loadQueue(function () { ThemeManager.waitFor(theme, callback) }) } else { callback() } } var getIconsUrlMetaFromUrl = function (editor) { return Optional.from(getIconsUrl(editor)) .filter(function (url) { return url.length > 0 }) .map(function (url) { return { url: url, name: Optional.none(), } }) } var getIconsUrlMetaFromName = function (editor, name, suffix) { return Optional.from(name) .filter(function (name) { return name.length > 0 && !IconManager.has(name) }) .map(function (name) { return { url: editor.editorManager.baseURL + '/icons/' + name + '/icons' + suffix + '.js', name: Optional.some(name), } }) } var loadIcons = function (scriptLoader, editor, suffix) { var defaultIconsUrl = getIconsUrlMetaFromName(editor, 'default', suffix) var customIconsUrl = getIconsUrlMetaFromUrl(editor).orThunk(function () { return getIconsUrlMetaFromName(editor, getIconPackName(editor), '') }) each$k(cat([defaultIconsUrl, customIconsUrl]), function (urlMeta) { scriptLoader.add(urlMeta.url, noop, undefined, function () { iconsLoadError(editor, urlMeta.url, urlMeta.name.getOrUndefined()) }) }) } var loadPlugins = function (editor, suffix) { Tools.each(getExternalPlugins$1(editor), function (url, name) { PluginManager.load(name, url, noop, undefined, function () { pluginLoadError(editor, url, name) }) editor.settings.plugins += ' ' + name }) Tools.each(getPlugins(editor).split(/[ ,]/), function (plugin) { plugin = Tools.trim(plugin) if (plugin && !PluginManager.urls[plugin]) { if (hasSkipLoadPrefix(plugin)) { plugin = plugin.substr(1, plugin.length) var dependencies = PluginManager.dependencies(plugin) Tools.each(dependencies, function (depPlugin) { var defaultSettings = { prefix: 'plugins/', resource: depPlugin, suffix: '/plugin' + suffix + '.js', } var dep = PluginManager.createUrl(defaultSettings, depPlugin) PluginManager.load(dep.resource, dep, noop, undefined, function () { pluginLoadError( editor, dep.prefix + dep.resource + dep.suffix, dep.resource ) }) }) } else { var url_2 = { prefix: 'plugins/', resource: plugin, suffix: '/plugin' + suffix + '.js', } PluginManager.load(plugin, url_2, noop, undefined, function () { pluginLoadError( editor, url_2.prefix + url_2.resource + url_2.suffix, plugin ) }) } } }) } var loadScripts = function (editor, suffix) { var scriptLoader = ScriptLoader.ScriptLoader loadTheme(scriptLoader, editor, suffix, function () { loadLanguage(scriptLoader, editor) loadIcons(scriptLoader, editor, suffix) loadPlugins(editor, suffix) scriptLoader.loadQueue( function () { if (!editor.removed) { init(editor) } }, editor, function () { if (!editor.removed) { init(editor) } } ) }) } var getStyleSheetLoader = function (element, editor) { return instance.forElement(element, { contentCssCors: hasContentCssCors(editor), referrerPolicy: getReferrerPolicy(editor), }) } var render = function (editor) { var id = editor.id I18n.setCode(getLanguageCode(editor)) var readyHandler = function () { DOM$3.unbind(window, 'ready', readyHandler) editor.render() } if (!EventUtils.Event.domLoaded) { DOM$3.bind(window, 'ready', readyHandler) return } if (!editor.getElement()) { return } if (!Env.contentEditable) { return } var element = SugarElement.fromDom(editor.getElement()) var snapshot = clone$3(element) editor.on('remove', function () { eachr(element.dom.attributes, function (attr) { return remove$6(element, attr.name) }) setAll$1(element, snapshot) }) editor.ui.styleSheetLoader = getStyleSheetLoader(element, editor) if (!isInline(editor)) { editor.orgVisibility = editor.getElement().style.visibility editor.getElement().style.visibility = 'hidden' } else { editor.inline = true } var form = editor.getElement().form || DOM$3.getParent(id, 'form') if (form) { editor.formElement = form if (hasHiddenInput(editor) && !isTextareaOrInput(editor.getElement())) { DOM$3.insertAfter( DOM$3.create('input', { type: 'hidden', name: id, }), id ) editor.hasHiddenInput = true } editor.formEventDelegate = function (e) { editor.fire(e.type, e) } DOM$3.bind(form, 'submit reset', editor.formEventDelegate) editor.on('reset', function () { editor.resetContent() }) if ( shouldPatchSubmit(editor) && !form.submit.nodeType && !form.submit.length && !form._mceOldSubmit ) { form._mceOldSubmit = form.submit form.submit = function () { editor.editorManager.triggerSave() editor.setDirty(false) return form._mceOldSubmit(form) } } } editor.windowManager = WindowManager(editor) editor.notificationManager = NotificationManager(editor) if (isEncodingXml(editor)) { editor.on('GetContent', function (e) { if (e.save) { e.content = DOM$3.encode(e.content) } }) } if (shouldAddFormSubmitTrigger(editor)) { editor.on('submit', function () { if (editor.initialized) { editor.save() } }) } if (shouldAddUnloadTrigger(editor)) { editor._beforeUnload = function () { if (editor.initialized && !editor.destroyed && !editor.isHidden()) { editor.save({ format: 'raw', no_events: true, set_dirty: false, }) } } editor.editorManager.on('BeforeUnload', editor._beforeUnload) } editor.editorManager.add(editor) loadScripts(editor, editor.suffix) } var addVisual = function (editor, elm) { return addVisual$1(editor, elm) } var legacyPropNames = { 'font-size': 'size', 'font-family': 'face', } var getSpecifiedFontProp = function (propName, rootElm, elm) { var getProperty = function (elm) { return getRaw(elm, propName).orThunk(function () { if (name(elm) === 'font') { return get$9(legacyPropNames, propName).bind(function ( legacyPropName ) { return getOpt(elm, legacyPropName) }) } else { return Optional.none() } }) } var isRoot = function (elm) { return eq(SugarElement.fromDom(rootElm), elm) } return closest$1( SugarElement.fromDom(elm), function (elm) { return getProperty(elm) }, isRoot ) } var normalizeFontFamily = function (fontFamily) { return fontFamily.replace(/[\'\"\\]/g, '').replace(/,\s+/g, ',') } var getComputedFontProp = function (propName, elm) { return Optional.from(DOMUtils.DOM.getStyle(elm, propName, true)) } var getFontProp = function (propName) { return function (rootElm, elm) { return Optional.from(elm) .map(SugarElement.fromDom) .filter(isElement$6) .bind(function (element) { return getSpecifiedFontProp(propName, rootElm, element.dom).or( getComputedFontProp(propName, element.dom) ) }) .getOr('') } } var getFontSize = getFontProp('font-size') var getFontFamily = compose(normalizeFontFamily, getFontProp('font-family')) var findFirstCaretElement = function (editor) { return firstPositionIn(editor.getBody()).map(function (caret) { var container = caret.container() return isText$7(container) ? container.parentNode : container }) } var getCaretElement = function (editor) { return Optional.from(editor.selection.getRng()).bind(function (rng) { var root = editor.getBody() var atStartOfNode = rng.startContainer === root && rng.startOffset === 0 return atStartOfNode ? Optional.none() : Optional.from(editor.selection.getStart(true)) }) } var bindRange = function (editor, binder) { return getCaretElement(editor) .orThunk(curry(findFirstCaretElement, editor)) .map(SugarElement.fromDom) .filter(isElement$6) .bind(binder) } var mapRange = function (editor, mapper) { return bindRange(editor, compose1(Optional.some, mapper)) } var fromFontSizeNumber = function (editor, value) { if (/^[0-9.]+$/.test(value)) { var fontSizeNumber = parseInt(value, 10) if (fontSizeNumber >= 1 && fontSizeNumber <= 7) { var fontSizes = getFontStyleValues(editor) var fontClasses = getFontSizeClasses(editor) if (fontClasses) { return fontClasses[fontSizeNumber - 1] || value } else { return fontSizes[fontSizeNumber - 1] || value } } else { return value } } else { return value } } var normalizeFontNames = function (font) { var fonts = font.split(/\s*,\s*/) return map$3(fonts, function (font) { if ( font.indexOf(' ') !== -1 && !(startsWith(font, '"') || startsWith(font, "'")) ) { return "'" + font + "'" } else { return font } }).join(',') } var fontNameAction = function (editor, value) { var font = fromFontSizeNumber(editor, value) editor.formatter.toggle('fontname', { value: normalizeFontNames(font) }) editor.nodeChanged() } var fontNameQuery = function (editor) { return mapRange(editor, function (elm) { return getFontFamily(editor.getBody(), elm.dom) }).getOr('') } var fontSizeAction = function (editor, value) { editor.formatter.toggle('fontsize', { value: fromFontSizeNumber(editor, value), }) editor.nodeChanged() } var fontSizeQuery = function (editor) { return mapRange(editor, function (elm) { return getFontSize(editor.getBody(), elm.dom) }).getOr('') } var lineHeightQuery = function (editor) { return mapRange(editor, function (elm) { var root = SugarElement.fromDom(editor.getBody()) var specifiedStyle = closest$1( elm, function (elm) { return getRaw(elm, 'line-height') }, curry(eq, root) ) var computedStyle = function () { var lineHeight = parseFloat(get$5(elm, 'line-height')) var fontSize = parseFloat(get$5(elm, 'font-size')) return String(lineHeight / fontSize) } return specifiedStyle.getOrThunk(computedStyle) }).getOr('') } var lineHeightAction = function (editor, lineHeight) { editor.formatter.toggle('lineheight', { value: String(lineHeight) }) editor.nodeChanged() } var processValue = function (value) { if (typeof value !== 'string') { var details = Tools.extend( { paste: value.paste, data: { paste: value.paste }, }, value ) return { content: value.content, details: details, } } return { content: value, details: {}, } } var insertAtCaret = function (editor, value) { var result = processValue(value) insertContent(editor, result.content, result.details) } var each$4 = Tools.each var map = Tools.map, inArray = Tools.inArray var EditorCommands = (function () { function EditorCommands(editor) { this.commands = { state: {}, exec: {}, value: {}, } this.editor = editor this.setupCommands(editor) } EditorCommands.prototype.execCommand = function (command, ui, value, args) { var func, state = false var self = this if (self.editor.removed) { return } if (command.toLowerCase() !== 'mcefocus') { if ( !/^(mceAddUndoLevel|mceEndUndoLevel|mceBeginUndoLevel|mceRepaint)$/.test( command ) && (!args || !args.skip_focus) ) { self.editor.focus() } else { restore(self.editor) } } args = self.editor.fire('BeforeExecCommand', { command: command, ui: ui, value: value, }) if (args.isDefaultPrevented()) { return false } var customCommand = command.toLowerCase() if ((func = self.commands.exec[customCommand])) { func(customCommand, ui, value) self.editor.fire('ExecCommand', { command: command, ui: ui, value: value, }) return true } each$4(this.editor.plugins, function (p) { if (p.execCommand && p.execCommand(command, ui, value)) { self.editor.fire('ExecCommand', { command: command, ui: ui, value: value, }) state = true return false } }) if (state) { return state } if ( self.editor.theme && self.editor.theme.execCommand && self.editor.theme.execCommand(command, ui, value) ) { self.editor.fire('ExecCommand', { command: command, ui: ui, value: value, }) return true } try { state = self.editor.getDoc().execCommand(command, ui, value) } catch (ex) {} if (state) { self.editor.fire('ExecCommand', { command: command, ui: ui, value: value, }) return true } return false } EditorCommands.prototype.queryCommandState = function (command) { var func if (this.editor.quirks.isHidden() || this.editor.removed) { return } command = command.toLowerCase() if ((func = this.commands.state[command])) { return func(command) } try { return this.editor.getDoc().queryCommandState(command) } catch (ex) {} return false } EditorCommands.prototype.queryCommandValue = function (command) { var func if (this.editor.quirks.isHidden() || this.editor.removed) { return } command = command.toLowerCase() if ((func = this.commands.value[command])) { return func(command) } try { return this.editor.getDoc().queryCommandValue(command) } catch (ex) {} } EditorCommands.prototype.addCommands = function (commandList, type) { if (type === void 0) { type = 'exec' } var self = this each$4(commandList, function (callback, command) { each$4(command.toLowerCase().split(','), function (command) { self.commands[type][command] = callback }) }) } EditorCommands.prototype.addCommand = function (command, callback, scope) { var _this = this command = command.toLowerCase() this.commands.exec[command] = function (command, ui, value, args) { return callback.call(scope || _this.editor, ui, value, args) } } EditorCommands.prototype.queryCommandSupported = function (command) { command = command.toLowerCase() if (this.commands.exec[command]) { return true } try { return this.editor.getDoc().queryCommandSupported(command) } catch (ex) {} return false } EditorCommands.prototype.addQueryStateHandler = function ( command, callback, scope ) { var _this = this command = command.toLowerCase() this.commands.state[command] = function () { return callback.call(scope || _this.editor) } } EditorCommands.prototype.addQueryValueHandler = function ( command, callback, scope ) { var _this = this command = command.toLowerCase() this.commands.value[command] = function () { return callback.call(scope || _this.editor) } } EditorCommands.prototype.hasCustomCommand = function (command) { command = command.toLowerCase() return !!this.commands.exec[command] } EditorCommands.prototype.execNativeCommand = function (command, ui, value) { if (ui === undefined) { ui = false } if (value === undefined) { value = null } return this.editor.getDoc().execCommand(command, ui, value) } EditorCommands.prototype.isFormatMatch = function (name) { return this.editor.formatter.match(name) } EditorCommands.prototype.toggleFormat = function (name, value) { this.editor.formatter.toggle(name, value) this.editor.nodeChanged() } EditorCommands.prototype.storeSelection = function (type) { this.selectionBookmark = this.editor.selection.getBookmark(type) } EditorCommands.prototype.restoreSelection = function () { this.editor.selection.moveToBookmark(this.selectionBookmark) } EditorCommands.prototype.setupCommands = function (editor) { var self = this this.addCommands({ 'mceResetDesignMode,mceBeginUndoLevel': noop, 'mceEndUndoLevel,mceAddUndoLevel': function () { editor.undoManager.add() }, mceFocus: function (_command, _ui, value) { focus(editor, value) }, 'Cut,Copy,Paste': function (command) { var doc = editor.getDoc() var failed try { self.execNativeCommand(command) } catch (ex) { failed = true } if (command === 'paste' && !doc.queryCommandEnabled(command)) { failed = true } if (failed || !doc.queryCommandSupported(command)) { var msg = editor.translate( "Your browser doesn't support direct access to the clipboard. " + 'Please use the Ctrl+X/C/V keyboard shortcuts instead.' ) if (Env.mac) { msg = msg.replace(/Ctrl\+/g, '\u2318+') } editor.notificationManager.open({ text: msg, type: 'error', }) } }, unlink: function () { if (editor.selection.isCollapsed()) { var elm = editor.dom.getParent(editor.selection.getStart(), 'a') if (elm) { editor.dom.remove(elm, true) } return } editor.formatter.remove('link') }, 'JustifyLeft,JustifyCenter,JustifyRight,JustifyFull,JustifyNone': function (command) { var align = command.substring(7) if (align === 'full') { align = 'justify' } each$4('left,center,right,justify'.split(','), function (name) { if (align !== name) { editor.formatter.remove('align' + name) } }) if (align !== 'none') { self.toggleFormat('align' + align) } }, 'InsertUnorderedList,InsertOrderedList': function (command) { var listParent self.execNativeCommand(command) var listElm = editor.dom.getParent( editor.selection.getNode(), 'ol,ul' ) if (listElm) { listParent = listElm.parentNode if (/^(H[1-6]|P|ADDRESS|PRE)$/.test(listParent.nodeName)) { self.storeSelection() editor.dom.split(listParent, listElm) self.restoreSelection() } } }, 'Bold,Italic,Underline,Strikethrough,Superscript,Subscript': function ( command ) { self.toggleFormat(command) }, 'ForeColor,HiliteColor': function (command, ui, value) { self.toggleFormat(command, { value: value }) }, FontName: function (command, ui, value) { fontNameAction(editor, value) }, FontSize: function (command, ui, value) { fontSizeAction(editor, value) }, LineHeight: function (command, ui, value) { lineHeightAction(editor, value) }, Lang: function (command, ui, lang) { self.toggleFormat(command, { value: lang.code, customValue: lang.customCode, }) }, RemoveFormat: function (command) { editor.formatter.remove(command) }, mceBlockQuote: function () { self.toggleFormat('blockquote') }, FormatBlock: function (command, ui, value) { return self.toggleFormat(value || 'p') }, mceCleanup: function () { var bookmark = editor.selection.getBookmark() editor.setContent(editor.getContent()) editor.selection.moveToBookmark(bookmark) }, mceRemoveNode: function (command, ui, value) { var node = value || editor.selection.getNode() if (node !== editor.getBody()) { self.storeSelection() editor.dom.remove(node, true) self.restoreSelection() } }, mceSelectNodeDepth: function (command, ui, value) { var counter = 0 editor.dom.getParent( editor.selection.getNode(), function (node) { if (node.nodeType === 1 && counter++ === value) { editor.selection.select(node) return false } }, editor.getBody() ) }, mceSelectNode: function (command, ui, value) { editor.selection.select(value) }, mceInsertContent: function (command, ui, value) { insertAtCaret(editor, value) }, mceInsertRawHTML: function (command, ui, value) { editor.selection.setContent('tiny_mce_marker') var content = editor.getContent() editor.setContent( content.replace(/tiny_mce_marker/g, function () { return value }) ) }, mceInsertNewLine: function (command, ui, value) { insert(editor, value) }, mceToggleFormat: function (command, ui, value) { self.toggleFormat(value) }, mceSetContent: function (command, ui, value) { editor.setContent(value) }, 'Indent,Outdent': function (command) { handle(editor, command) }, mceRepaint: noop, InsertHorizontalRule: function () { editor.execCommand('mceInsertContent', false, '
    ') }, mceToggleVisualAid: function () { editor.hasVisual = !editor.hasVisual editor.addVisual() }, mceReplaceContent: function (command, ui, value) { editor.execCommand( 'mceInsertContent', false, value.replace( /\{\$selection\}/g, editor.selection.getContent({ format: 'text' }) ) ) }, mceInsertLink: function (command, ui, value) { if (typeof value === 'string') { value = { href: value } } var anchor = editor.dom.getParent(editor.selection.getNode(), 'a') value.href = value.href.replace(/ /g, '%20') if (!anchor || !value.href) { editor.formatter.remove('link') } if (value.href) { editor.formatter.apply('link', value, anchor) } }, selectAll: function () { var editingHost = editor.dom.getParent( editor.selection.getStart(), isContentEditableTrue$4 ) if (editingHost) { var rng = editor.dom.createRng() rng.selectNodeContents(editingHost) editor.selection.setRng(rng) } }, mceNewDocument: function () { editor.setContent('') }, InsertLineBreak: function (command, ui, value) { insert$1(editor, value) return true }, }) var alignStates = function (name) { return function () { var selection = editor.selection var nodes = selection.isCollapsed() ? [editor.dom.getParent(selection.getNode(), editor.dom.isBlock)] : selection.getSelectedBlocks() var matches = map(nodes, function (node) { return !!editor.formatter.matchNode(node, name) }) return inArray(matches, true) !== -1 } } self.addCommands( { JustifyLeft: alignStates('alignleft'), JustifyCenter: alignStates('aligncenter'), JustifyRight: alignStates('alignright'), JustifyFull: alignStates('alignjustify'), 'Bold,Italic,Underline,Strikethrough,Superscript,Subscript': function (command) { return self.isFormatMatch(command) }, mceBlockQuote: function () { return self.isFormatMatch('blockquote') }, Outdent: function () { return canOutdent(editor) }, 'InsertUnorderedList,InsertOrderedList': function (command) { var list = editor.dom.getParent(editor.selection.getNode(), 'ul,ol') return ( list && ((command === 'insertunorderedlist' && list.tagName === 'UL') || (command === 'insertorderedlist' && list.tagName === 'OL')) ) }, }, 'state' ) self.addCommands({ Undo: function () { editor.undoManager.undo() }, Redo: function () { editor.undoManager.redo() }, }) self.addQueryValueHandler( 'FontName', function () { return fontNameQuery(editor) }, this ) self.addQueryValueHandler( 'FontSize', function () { return fontSizeQuery(editor) }, this ) self.addQueryValueHandler( 'LineHeight', function () { return lineHeightQuery(editor) }, this ) } return EditorCommands })() var internalContentEditableAttr = 'data-mce-contenteditable' var toggleClass = function (elm, cls, state) { if (has(elm, cls) && state === false) { remove$3(elm, cls) } else if (state) { add$1(elm, cls) } } var setEditorCommandState = function (editor, cmd, state) { try { editor.getDoc().execCommand(cmd, false, String(state)) } catch (ex) {} } var setContentEditable = function (elm, state) { elm.dom.contentEditable = state ? 'true' : 'false' } var switchOffContentEditableTrue = function (elm) { each$k(descendants(elm, '*[contenteditable="true"]'), function (elm) { set$1(elm, internalContentEditableAttr, 'true') setContentEditable(elm, false) }) } var switchOnContentEditableTrue = function (elm) { each$k( descendants(elm, '*[' + internalContentEditableAttr + '="true"]'), function (elm) { remove$6(elm, internalContentEditableAttr) setContentEditable(elm, true) } ) } var removeFakeSelection = function (editor) { Optional.from(editor.selection.getNode()).each(function (elm) { elm.removeAttribute('data-mce-selected') }) } var restoreFakeSelection = function (editor) { editor.selection.setRng(editor.selection.getRng()) } var toggleReadOnly = function (editor, state) { var body = SugarElement.fromDom(editor.getBody()) toggleClass(body, 'mce-content-readonly', state) if (state) { editor.selection.controlSelection.hideResizeRect() editor._selectionOverrides.hideFakeCaret() removeFakeSelection(editor) editor.readonly = true setContentEditable(body, false) switchOffContentEditableTrue(body) } else { editor.readonly = false setContentEditable(body, true) switchOnContentEditableTrue(body) setEditorCommandState(editor, 'StyleWithCSS', false) setEditorCommandState(editor, 'enableInlineTableEditing', false) setEditorCommandState(editor, 'enableObjectResizing', false) if (hasEditorOrUiFocus(editor)) { editor.focus() } restoreFakeSelection(editor) editor.nodeChanged() } } var isReadOnly = function (editor) { return editor.readonly } var registerFilters = function (editor) { editor.parser.addAttributeFilter('contenteditable', function (nodes) { if (isReadOnly(editor)) { each$k(nodes, function (node) { node.attr(internalContentEditableAttr, node.attr('contenteditable')) node.attr('contenteditable', 'false') }) } }) editor.serializer.addAttributeFilter( internalContentEditableAttr, function (nodes) { if (isReadOnly(editor)) { each$k(nodes, function (node) { node.attr('contenteditable', node.attr(internalContentEditableAttr)) }) } } ) editor.serializer.addTempAttr(internalContentEditableAttr) } var registerReadOnlyContentFilters = function (editor) { if (editor.serializer) { registerFilters(editor) } else { editor.on('PreInit', function () { registerFilters(editor) }) } } var isClickEvent = function (e) { return e.type === 'click' } var getAnchorHrefOpt = function (editor, elm) { var isRoot = function (elm) { return eq(elm, SugarElement.fromDom(editor.getBody())) } return closest$2(elm, 'a', isRoot).bind(function (a) { return getOpt(a, 'href') }) } var processReadonlyEvents = function (editor, e) { if (isClickEvent(e) && !VK.metaKeyPressed(e)) { var elm = SugarElement.fromDom(e.target) getAnchorHrefOpt(editor, elm).each(function (href) { e.preventDefault() if (/^#/.test(href)) { var targetEl = editor.dom.select( href + ',[name="' + removeLeading(href, '#') + '"]' ) if (targetEl.length) { editor.selection.scrollIntoView(targetEl[0], true) } } else { window.open( href, '_blank', 'rel=noopener noreferrer,menubar=yes,toolbar=yes,location=yes,status=yes,resizable=yes,scrollbars=yes' ) } }) } } var registerReadOnlySelectionBlockers = function (editor) { editor.on('ShowCaret', function (e) { if (isReadOnly(editor)) { e.preventDefault() } }) editor.on('ObjectSelected', function (e) { if (isReadOnly(editor)) { e.preventDefault() } }) } var nativeEvents = Tools.makeMap( 'focus blur focusin focusout click dblclick mousedown mouseup mousemove mouseover beforepaste paste cut copy selectionchange ' + 'mouseout mouseenter mouseleave wheel keydown keypress keyup input beforeinput contextmenu dragstart dragend dragover ' + 'draggesture dragdrop drop drag submit ' + 'compositionstart compositionend compositionupdate touchstart touchmove touchend touchcancel', ' ' ) var EventDispatcher = (function () { function EventDispatcher(settings) { this.bindings = {} this.settings = settings || {} this.scope = this.settings.scope || this this.toggleEvent = this.settings.toggleEvent || never } EventDispatcher.isNative = function (name) { return !!nativeEvents[name.toLowerCase()] } EventDispatcher.prototype.fire = function (name, args) { var lcName = name.toLowerCase() var event = normalize$3(lcName, args || {}, this.scope) if (this.settings.beforeFire) { this.settings.beforeFire(event) } var handlers = this.bindings[lcName] if (handlers) { for (var i = 0, l = handlers.length; i < l; i++) { var callback = handlers[i] if (callback.removed) { continue } if (callback.once) { this.off(lcName, callback.func) } if (event.isImmediatePropagationStopped()) { return event } if (callback.func.call(this.scope, event) === false) { event.preventDefault() return event } } } return event } EventDispatcher.prototype.on = function (name, callback, prepend, extra) { if (callback === false) { callback = never } if (callback) { var wrappedCallback = { func: callback, removed: false, } if (extra) { Tools.extend(wrappedCallback, extra) } var names = name.toLowerCase().split(' ') var i = names.length while (i--) { var currentName = names[i] var handlers = this.bindings[currentName] if (!handlers) { handlers = [] this.toggleEvent(currentName, true) } if (prepend) { handlers = __spreadArray([wrappedCallback], handlers, true) } else { handlers = __spreadArray( __spreadArray([], handlers, true), [wrappedCallback], false ) } this.bindings[currentName] = handlers } } return this } EventDispatcher.prototype.off = function (name, callback) { var _this = this if (name) { var names = name.toLowerCase().split(' ') var i = names.length while (i--) { var currentName = names[i] var handlers = this.bindings[currentName] if (!currentName) { each$j(this.bindings, function (_value, bindingName) { _this.toggleEvent(bindingName, false) delete _this.bindings[bindingName] }) return this } if (handlers) { if (!callback) { handlers.length = 0 } else { var filteredHandlers = partition(handlers, function (handler) { return handler.func === callback }) handlers = filteredHandlers.fail this.bindings[currentName] = handlers each$k(filteredHandlers.pass, function (handler) { handler.removed = true }) } if (!handlers.length) { this.toggleEvent(name, false) delete this.bindings[currentName] } } } } else { each$j(this.bindings, function (_value, name) { _this.toggleEvent(name, false) }) this.bindings = {} } return this } EventDispatcher.prototype.once = function (name, callback, prepend) { return this.on(name, callback, prepend, { once: true }) } EventDispatcher.prototype.has = function (name) { name = name.toLowerCase() return !(!this.bindings[name] || this.bindings[name].length === 0) } return EventDispatcher })() var getEventDispatcher = function (obj) { if (!obj._eventDispatcher) { obj._eventDispatcher = new EventDispatcher({ scope: obj, toggleEvent: function (name, state) { if (EventDispatcher.isNative(name) && obj.toggleNativeEvent) { obj.toggleNativeEvent(name, state) } }, }) } return obj._eventDispatcher } var Observable = { fire: function (name, args, bubble) { var self = this if (self.removed && name !== 'remove' && name !== 'detach') { return args } var dispatcherArgs = getEventDispatcher(self).fire(name, args) if (bubble !== false && self.parent) { var parent_1 = self.parent() while (parent_1 && !dispatcherArgs.isPropagationStopped()) { parent_1.fire(name, dispatcherArgs, false) parent_1 = parent_1.parent() } } return dispatcherArgs }, on: function (name, callback, prepend) { return getEventDispatcher(this).on(name, callback, prepend) }, off: function (name, callback) { return getEventDispatcher(this).off(name, callback) }, once: function (name, callback) { return getEventDispatcher(this).once(name, callback) }, hasEventListeners: function (name) { return getEventDispatcher(this).has(name) }, } var DOM$2 = DOMUtils.DOM var customEventRootDelegates var getEventTarget = function (editor, eventName) { if (eventName === 'selectionchange') { return editor.getDoc() } if ( !editor.inline && /^mouse|touch|click|contextmenu|drop|dragover|dragend/.test(eventName) ) { return editor.getDoc().documentElement } var eventRoot = getEventRoot(editor) if (eventRoot) { if (!editor.eventRoot) { editor.eventRoot = DOM$2.select(eventRoot)[0] } return editor.eventRoot } return editor.getBody() } var isListening = function (editor) { return !editor.hidden && !isReadOnly(editor) } var fireEvent = function (editor, eventName, e) { if (isListening(editor)) { editor.fire(eventName, e) } else if (isReadOnly(editor)) { processReadonlyEvents(editor, e) } } var bindEventDelegate = function (editor, eventName) { var delegate if (!editor.delegates) { editor.delegates = {} } if (editor.delegates[eventName] || editor.removed) { return } var eventRootElm = getEventTarget(editor, eventName) if (getEventRoot(editor)) { if (!customEventRootDelegates) { customEventRootDelegates = {} editor.editorManager.on('removeEditor', function () { if (!editor.editorManager.activeEditor) { if (customEventRootDelegates) { each$j(customEventRootDelegates, function (_value, name) { editor.dom.unbind(getEventTarget(editor, name)) }) customEventRootDelegates = null } } }) } if (customEventRootDelegates[eventName]) { return } delegate = function (e) { var target = e.target var editors = editor.editorManager.get() var i = editors.length while (i--) { var body = editors[i].getBody() if (body === target || DOM$2.isChildOf(target, body)) { fireEvent(editors[i], eventName, e) } } } customEventRootDelegates[eventName] = delegate DOM$2.bind(eventRootElm, eventName, delegate) } else { delegate = function (e) { fireEvent(editor, eventName, e) } DOM$2.bind(eventRootElm, eventName, delegate) editor.delegates[eventName] = delegate } } var EditorObservable = __assign(__assign({}, Observable), { bindPendingEventDelegates: function () { var self = this Tools.each(self._pendingNativeEvents, function (name) { bindEventDelegate(self, name) }) }, toggleNativeEvent: function (name, state) { var self = this if (name === 'focus' || name === 'blur') { return } if (self.removed) { return } if (state) { if (self.initialized) { bindEventDelegate(self, name) } else { if (!self._pendingNativeEvents) { self._pendingNativeEvents = [name] } else { self._pendingNativeEvents.push(name) } } } else if (self.initialized) { self.dom.unbind(getEventTarget(self, name), name, self.delegates[name]) delete self.delegates[name] } }, unbindAllNativeEvents: function () { var self = this var body = self.getBody() var dom = self.dom if (self.delegates) { each$j(self.delegates, function (value, name) { self.dom.unbind(getEventTarget(self, name), name, value) }) delete self.delegates } if (!self.inline && body && dom) { body.onload = null dom.unbind(self.getWin()) dom.unbind(self.getDoc()) } if (dom) { dom.unbind(body) dom.unbind(self.getContainer()) } }, }) var defaultModes = ['design', 'readonly'] var switchToMode = function (editor, activeMode, availableModes, mode) { var oldMode = availableModes[activeMode.get()] var newMode = availableModes[mode] try { newMode.activate() } catch (e) { console.error('problem while activating editor mode ' + mode + ':', e) return } oldMode.deactivate() if (oldMode.editorReadOnly !== newMode.editorReadOnly) { toggleReadOnly(editor, newMode.editorReadOnly) } activeMode.set(mode) fireSwitchMode(editor, mode) } var setMode = function (editor, availableModes, activeMode, mode) { if (mode === activeMode.get()) { return } else if (!has$2(availableModes, mode)) { throw new Error("Editor mode '" + mode + "' is invalid") } if (editor.initialized) { switchToMode(editor, activeMode, availableModes, mode) } else { editor.on('init', function () { return switchToMode(editor, activeMode, availableModes, mode) }) } } var registerMode = function (availableModes, mode, api) { var _a if (contains$3(defaultModes, mode)) { throw new Error('Cannot override default mode ' + mode) } return __assign( __assign({}, availableModes), ((_a = {}), (_a[mode] = __assign(__assign({}, api), { deactivate: function () { try { api.deactivate() } catch (e) { console.error( 'problem while deactivating editor mode ' + mode + ':', e ) } }, })), _a) ) } var create$4 = function (editor) { var activeMode = Cell('design') var availableModes = Cell({ design: { activate: noop, deactivate: noop, editorReadOnly: false, }, readonly: { activate: noop, deactivate: noop, editorReadOnly: true, }, }) registerReadOnlyContentFilters(editor) registerReadOnlySelectionBlockers(editor) return { isReadOnly: function () { return isReadOnly(editor) }, set: function (mode) { return setMode(editor, availableModes.get(), activeMode, mode) }, get: function () { return activeMode.get() }, register: function (mode, api) { availableModes.set(registerMode(availableModes.get(), mode, api)) }, } } var each$3 = Tools.each, explode$1 = Tools.explode var keyCodeLookup = { f1: 112, f2: 113, f3: 114, f4: 115, f5: 116, f6: 117, f7: 118, f8: 119, f9: 120, f10: 121, f11: 122, f12: 123, } var modifierNames = Tools.makeMap('alt,ctrl,shift,meta,access') var parseShortcut = function (pattern) { var key var shortcut = {} each$3(explode$1(pattern.toLowerCase(), '+'), function (value) { if (value in modifierNames) { shortcut[value] = true } else { if (/^[0-9]{2,}$/.test(value)) { shortcut.keyCode = parseInt(value, 10) } else { shortcut.charCode = value.charCodeAt(0) shortcut.keyCode = keyCodeLookup[value] || value.toUpperCase().charCodeAt(0) } } }) var id = [shortcut.keyCode] for (key in modifierNames) { if (shortcut[key]) { id.push(key) } else { shortcut[key] = false } } shortcut.id = id.join(',') if (shortcut.access) { shortcut.alt = true if (Env.mac) { shortcut.ctrl = true } else { shortcut.shift = true } } if (shortcut.meta) { if (Env.mac) { shortcut.meta = true } else { shortcut.ctrl = true shortcut.meta = false } } return shortcut } var Shortcuts = (function () { function Shortcuts(editor) { this.shortcuts = {} this.pendingPatterns = [] this.editor = editor var self = this editor.on('keyup keypress keydown', function (e) { if ( (self.hasModifier(e) || self.isFunctionKey(e)) && !e.isDefaultPrevented() ) { each$3(self.shortcuts, function (shortcut) { if (self.matchShortcut(e, shortcut)) { self.pendingPatterns = shortcut.subpatterns.slice(0) if (e.type === 'keydown') { self.executeShortcutAction(shortcut) } return true } }) if (self.matchShortcut(e, self.pendingPatterns[0])) { if (self.pendingPatterns.length === 1) { if (e.type === 'keydown') { self.executeShortcutAction(self.pendingPatterns[0]) } } self.pendingPatterns.shift() } } }) } Shortcuts.prototype.add = function (pattern, desc, cmdFunc, scope) { var self = this var func = self.normalizeCommandFunc(cmdFunc) each$3(explode$1(Tools.trim(pattern)), function (pattern) { var shortcut = self.createShortcut(pattern, desc, func, scope) self.shortcuts[shortcut.id] = shortcut }) return true } Shortcuts.prototype.remove = function (pattern) { var shortcut = this.createShortcut(pattern) if (this.shortcuts[shortcut.id]) { delete this.shortcuts[shortcut.id] return true } return false } Shortcuts.prototype.normalizeCommandFunc = function (cmdFunc) { var self = this var cmd = cmdFunc if (typeof cmd === 'string') { return function () { self.editor.execCommand(cmd, false, null) } } else if (Tools.isArray(cmd)) { return function () { self.editor.execCommand(cmd[0], cmd[1], cmd[2]) } } else { return cmd } } Shortcuts.prototype.createShortcut = function ( pattern, desc, cmdFunc, scope ) { var shortcuts = Tools.map(explode$1(pattern, '>'), parseShortcut) shortcuts[shortcuts.length - 1] = Tools.extend( shortcuts[shortcuts.length - 1], { func: cmdFunc, scope: scope || this.editor, } ) return Tools.extend(shortcuts[0], { desc: this.editor.translate(desc), subpatterns: shortcuts.slice(1), }) } Shortcuts.prototype.hasModifier = function (e) { return e.altKey || e.ctrlKey || e.metaKey } Shortcuts.prototype.isFunctionKey = function (e) { return e.type === 'keydown' && e.keyCode >= 112 && e.keyCode <= 123 } Shortcuts.prototype.matchShortcut = function (e, shortcut) { if (!shortcut) { return false } if (shortcut.ctrl !== e.ctrlKey || shortcut.meta !== e.metaKey) { return false } if (shortcut.alt !== e.altKey || shortcut.shift !== e.shiftKey) { return false } if ( e.keyCode === shortcut.keyCode || (e.charCode && e.charCode === shortcut.charCode) ) { e.preventDefault() return true } return false } Shortcuts.prototype.executeShortcutAction = function (shortcut) { return shortcut.func ? shortcut.func.call(shortcut.scope) : null } return Shortcuts })() var create$3 = function () { var buttons = {} var menuItems = {} var popups = {} var icons = {} var contextMenus = {} var contextToolbars = {} var sidebars = {} var add = function (collection, type) { return function (name, spec) { return (collection[name.toLowerCase()] = __assign(__assign({}, spec), { type: type, })) } } var addIcon = function (name, svgData) { return (icons[name.toLowerCase()] = svgData) } return { addButton: add(buttons, 'button'), addGroupToolbarButton: add(buttons, 'grouptoolbarbutton'), addToggleButton: add(buttons, 'togglebutton'), addMenuButton: add(buttons, 'menubutton'), addSplitButton: add(buttons, 'splitbutton'), addMenuItem: add(menuItems, 'menuitem'), addNestedMenuItem: add(menuItems, 'nestedmenuitem'), addToggleMenuItem: add(menuItems, 'togglemenuitem'), addAutocompleter: add(popups, 'autocompleter'), addContextMenu: add(contextMenus, 'contextmenu'), addContextToolbar: add(contextToolbars, 'contexttoolbar'), addContextForm: add(contextToolbars, 'contextform'), addSidebar: add(sidebars, 'sidebar'), addIcon: addIcon, getAll: function () { return { buttons: buttons, menuItems: menuItems, icons: icons, popups: popups, contextMenus: contextMenus, contextToolbars: contextToolbars, sidebars: sidebars, } }, } } var registry = function () { var bridge = create$3() return { addAutocompleter: bridge.addAutocompleter, addButton: bridge.addButton, addContextForm: bridge.addContextForm, addContextMenu: bridge.addContextMenu, addContextToolbar: bridge.addContextToolbar, addIcon: bridge.addIcon, addMenuButton: bridge.addMenuButton, addMenuItem: bridge.addMenuItem, addNestedMenuItem: bridge.addNestedMenuItem, addSidebar: bridge.addSidebar, addSplitButton: bridge.addSplitButton, addToggleButton: bridge.addToggleButton, addGroupToolbarButton: bridge.addGroupToolbarButton, addToggleMenuItem: bridge.addToggleMenuItem, getAll: bridge.getAll, } } var DOM$1 = DOMUtils.DOM var extend$3 = Tools.extend, each$2 = Tools.each var resolve = Tools.resolve var ie = Env.ie var Editor = (function () { function Editor(id, settings, editorManager) { var _this = this this.plugins = {} this.contentCSS = [] this.contentStyles = [] this.loadedCSS = {} this.isNotDirty = false this.editorManager = editorManager this.documentBaseUrl = editorManager.documentBaseURL extend$3(this, EditorObservable) this.settings = getEditorSettings( this, id, this.documentBaseUrl, editorManager.defaultSettings, settings ) if (this.settings.suffix) { editorManager.suffix = this.settings.suffix } this.suffix = editorManager.suffix if (this.settings.base_url) { editorManager._setBaseUrl(this.settings.base_url) } this.baseUri = editorManager.baseURI if (this.settings.referrer_policy) { ScriptLoader.ScriptLoader._setReferrerPolicy( this.settings.referrer_policy ) DOMUtils.DOM.styleSheetLoader._setReferrerPolicy( this.settings.referrer_policy ) } AddOnManager.languageLoad = this.settings.language_load AddOnManager.baseURL = editorManager.baseURL this.id = id this.setDirty(false) this.documentBaseURI = new URI(this.settings.document_base_url, { base_uri: this.baseUri, }) this.baseURI = this.baseUri this.inline = !!this.settings.inline this.shortcuts = new Shortcuts(this) this.editorCommands = new EditorCommands(this) if (this.settings.cache_suffix) { Env.cacheSuffix = this.settings.cache_suffix.replace(/^[\?\&]+/, '') } this.ui = { registry: registry(), styleSheetLoader: undefined, show: noop, hide: noop, enable: noop, disable: noop, isDisabled: never, } var self = this var modeInstance = create$4(self) this.mode = modeInstance this.setMode = modeInstance.set editorManager.fire('SetupEditor', { editor: this }) this.execCallback('setup', this) this.$ = DomQuery.overrideDefaults(function () { return { context: _this.inline ? _this.getBody() : _this.getDoc(), element: _this.getBody(), } }) } Editor.prototype.render = function () { render(this) } Editor.prototype.focus = function (skipFocus) { this.execCommand('mceFocus', false, skipFocus) } Editor.prototype.hasFocus = function () { return hasFocus(this) } Editor.prototype.execCallback = function (name) { var x = [] for (var _i = 1; _i < arguments.length; _i++) { x[_i - 1] = arguments[_i] } var self = this var callback = self.settings[name], scope if (!callback) { return } if (self.callbackLookup && (scope = self.callbackLookup[name])) { callback = scope.func scope = scope.scope } if (typeof callback === 'string') { scope = callback.replace(/\.\w+$/, '') scope = scope ? resolve(scope) : 0 callback = resolve(callback) self.callbackLookup = self.callbackLookup || {} self.callbackLookup[name] = { func: callback, scope: scope, } } return callback.apply(scope || self, x) } Editor.prototype.translate = function (text) { return I18n.translate(text) } Editor.prototype.getParam = function (name, defaultVal, type) { return getParam(this, name, defaultVal, type) } Editor.prototype.hasPlugin = function (name, loaded) { var hasPlugin = contains$3(getPlugins(this).split(/[ ,]/), name) if (hasPlugin) { return loaded ? PluginManager.get(name) !== undefined : true } else { return false } } Editor.prototype.nodeChanged = function (args) { this._nodeChangeDispatcher.nodeChanged(args) } Editor.prototype.addCommand = function (name, callback, scope) { this.editorCommands.addCommand(name, callback, scope) } Editor.prototype.addQueryStateHandler = function (name, callback, scope) { this.editorCommands.addQueryStateHandler(name, callback, scope) } Editor.prototype.addQueryValueHandler = function (name, callback, scope) { this.editorCommands.addQueryValueHandler(name, callback, scope) } Editor.prototype.addShortcut = function (pattern, desc, cmdFunc, scope) { this.shortcuts.add(pattern, desc, cmdFunc, scope) } Editor.prototype.execCommand = function (cmd, ui, value, args) { return this.editorCommands.execCommand(cmd, ui, value, args) } Editor.prototype.queryCommandState = function (cmd) { return this.editorCommands.queryCommandState(cmd) } Editor.prototype.queryCommandValue = function (cmd) { return this.editorCommands.queryCommandValue(cmd) } Editor.prototype.queryCommandSupported = function (cmd) { return this.editorCommands.queryCommandSupported(cmd) } Editor.prototype.show = function () { var self = this if (self.hidden) { self.hidden = false if (self.inline) { self.getBody().contentEditable = 'true' } else { DOM$1.show(self.getContainer()) DOM$1.hide(self.id) } self.load() self.fire('show') } } Editor.prototype.hide = function () { var self = this, doc = self.getDoc() if (!self.hidden) { if (ie && doc && !self.inline) { doc.execCommand('SelectAll') } self.save() if (self.inline) { self.getBody().contentEditable = 'false' if (self === self.editorManager.focusedEditor) { self.editorManager.focusedEditor = null } } else { DOM$1.hide(self.getContainer()) DOM$1.setStyle(self.id, 'display', self.orgDisplay) } self.hidden = true self.fire('hide') } } Editor.prototype.isHidden = function () { return !!this.hidden } Editor.prototype.setProgressState = function (state, time) { this.fire('ProgressState', { state: state, time: time, }) } Editor.prototype.load = function (args) { var self = this var elm = self.getElement(), html if (self.removed) { return '' } if (elm) { args = args || {} args.load = true var value = isTextareaOrInput(elm) ? elm.value : elm.innerHTML html = self.setContent(value, args) args.element = elm if (!args.no_events) { self.fire('LoadContent', args) } args.element = elm = null return html } } Editor.prototype.save = function (args) { var self = this var elm = self.getElement(), html, form if (!elm || !self.initialized || self.removed) { return } args = args || {} args.save = true args.element = elm html = args.content = self.getContent(args) if (!args.no_events) { self.fire('SaveContent', args) } if (args.format === 'raw') { self.fire('RawSaveContent', args) } html = args.content if (!isTextareaOrInput(elm)) { if (args.is_removing || !self.inline) { elm.innerHTML = html } if ((form = DOM$1.getParent(self.id, 'form'))) { each$2(form.elements, function (elm) { if (elm.name === self.id) { elm.value = html return false } }) } } else { elm.value = html } args.element = elm = null if (args.set_dirty !== false) { self.setDirty(false) } return html } Editor.prototype.setContent = function (content, args) { return setContent(this, content, args) } Editor.prototype.getContent = function (args) { return getContent(this, args) } Editor.prototype.insertContent = function (content, args) { if (args) { content = extend$3({ content: content }, args) } this.execCommand('mceInsertContent', false, content) } Editor.prototype.resetContent = function (initialContent) { if (initialContent === undefined) { setContent(this, this.startContent, { format: 'raw' }) } else { setContent(this, initialContent) } this.undoManager.reset() this.setDirty(false) this.nodeChanged() } Editor.prototype.isDirty = function () { return !this.isNotDirty } Editor.prototype.setDirty = function (state) { var oldState = !this.isNotDirty this.isNotDirty = !state if (state && state !== oldState) { this.fire('dirty') } } Editor.prototype.getContainer = function () { var self = this if (!self.container) { self.container = DOM$1.get(self.editorContainer || self.id + '_parent') } return self.container } Editor.prototype.getContentAreaContainer = function () { return this.contentAreaContainer } Editor.prototype.getElement = function () { if (!this.targetElm) { this.targetElm = DOM$1.get(this.id) } return this.targetElm } Editor.prototype.getWin = function () { var self = this var elm if (!self.contentWindow) { elm = self.iframeElement if (elm) { self.contentWindow = elm.contentWindow } } return self.contentWindow } Editor.prototype.getDoc = function () { var self = this var win if (!self.contentDocument) { win = self.getWin() if (win) { self.contentDocument = win.document } } return self.contentDocument } Editor.prototype.getBody = function () { var doc = this.getDoc() return this.bodyElement || (doc ? doc.body : null) } Editor.prototype.convertURL = function (url, name, elm) { var self = this, settings = self.settings if (settings.urlconverter_callback) { return self.execCallback('urlconverter_callback', url, elm, true, name) } if ( !settings.convert_urls || (elm && elm.nodeName === 'LINK') || url.indexOf('file:') === 0 || url.length === 0 ) { return url } if (settings.relative_urls) { return self.documentBaseURI.toRelative(url) } url = self.documentBaseURI.toAbsolute(url, settings.remove_script_host) return url } Editor.prototype.addVisual = function (elm) { addVisual(this, elm) } Editor.prototype.remove = function () { remove(this) } Editor.prototype.destroy = function (automatic) { destroy(this, automatic) } Editor.prototype.uploadImages = function (callback) { return this.editorUpload.uploadImages(callback) } Editor.prototype._scanForImages = function () { return this.editorUpload.scanForImages() } Editor.prototype.addButton = function () { throw new Error( 'editor.addButton has been removed in tinymce 5x, use editor.ui.registry.addButton or editor.ui.registry.addToggleButton or editor.ui.registry.addSplitButton instead' ) } Editor.prototype.addSidebar = function () { throw new Error( 'editor.addSidebar has been removed in tinymce 5x, use editor.ui.registry.addSidebar instead' ) } Editor.prototype.addMenuItem = function () { throw new Error( 'editor.addMenuItem has been removed in tinymce 5x, use editor.ui.registry.addMenuItem instead' ) } Editor.prototype.addContextToolbar = function () { throw new Error( 'editor.addContextToolbar has been removed in tinymce 5x, use editor.ui.registry.addContextToolbar instead' ) } return Editor })() var DOM = DOMUtils.DOM var explode = Tools.explode, each$1 = Tools.each, extend$2 = Tools.extend var instanceCounter = 0, boundGlobalEvents = false var beforeUnloadDelegate var legacyEditors = [] var editors = [] var isValidLegacyKey = function (id) { return id !== 'length' } var globalEventDelegate = function (e) { var type = e.type each$1(EditorManager.get(), function (editor) { switch (type) { case 'scroll': editor.fire('ScrollWindow', e) break case 'resize': editor.fire('ResizeWindow', e) break } }) } var toggleGlobalEvents = function (state) { if (state !== boundGlobalEvents) { if (state) { DomQuery(window).on('resize scroll', globalEventDelegate) } else { DomQuery(window).off('resize scroll', globalEventDelegate) } boundGlobalEvents = state } } var removeEditorFromList = function (targetEditor) { var oldEditors = editors delete legacyEditors[targetEditor.id] for (var i = 0; i < legacyEditors.length; i++) { if (legacyEditors[i] === targetEditor) { legacyEditors.splice(i, 1) break } } editors = filter$4(editors, function (editor) { return targetEditor !== editor }) if (EditorManager.activeEditor === targetEditor) { EditorManager.activeEditor = editors.length > 0 ? editors[0] : null } if (EditorManager.focusedEditor === targetEditor) { EditorManager.focusedEditor = null } return oldEditors.length !== editors.length } var purgeDestroyedEditor = function (editor) { if ( editor && editor.initialized && !(editor.getContainer() || editor.getBody()).parentNode ) { removeEditorFromList(editor) editor.unbindAllNativeEvents() editor.destroy(true) editor.removed = true editor = null } return editor } var isQuirksMode = document.compatMode !== 'CSS1Compat' var EditorManager = __assign(__assign({}, Observable), { baseURI: null, baseURL: null, defaultSettings: {}, documentBaseURL: null, suffix: null, $: DomQuery, majorVersion: '5', minorVersion: '10.2', releaseDate: '2021-11-17', editors: legacyEditors, i18n: I18n, activeEditor: null, focusedEditor: null, settings: {}, setup: function () { var self = this var baseURL, documentBaseURL, suffix = '' documentBaseURL = URI.getDocumentBaseUrl(document.location) if (/^[^:]+:\/\/\/?[^\/]+\//.test(documentBaseURL)) { documentBaseURL = documentBaseURL .replace(/[\?#].*$/, '') .replace(/[\/\\][^\/]+$/, '') if (!/[\/\\]$/.test(documentBaseURL)) { documentBaseURL += '/' } } var preInit = window.tinymce || window.tinyMCEPreInit if (preInit) { baseURL = preInit.base || preInit.baseURL suffix = preInit.suffix } else { var scripts = document.getElementsByTagName('script') for (var i = 0; i < scripts.length; i++) { var src = scripts[i].src || '' if (src === '') { continue } var srcScript = src.substring(src.lastIndexOf('/')) if (/tinymce(\.full|\.jquery|)(\.min|\.dev|)\.js/.test(src)) { if (srcScript.indexOf('.min') !== -1) { suffix = '.min' } baseURL = src.substring(0, src.lastIndexOf('/')) break } } if (!baseURL && document.currentScript) { var src = document.currentScript.src if (src.indexOf('.min') !== -1) { suffix = '.min' } baseURL = src.substring(0, src.lastIndexOf('/')) } } self.baseURL = new URI(documentBaseURL).toAbsolute(baseURL) self.documentBaseURL = documentBaseURL self.baseURI = new URI(self.baseURL) self.suffix = suffix setup$l(self) }, overrideDefaults: function (defaultSettings) { var baseUrl = defaultSettings.base_url if (baseUrl) { this._setBaseUrl(baseUrl) } var suffix = defaultSettings.suffix if (defaultSettings.suffix) { this.suffix = suffix } this.defaultSettings = defaultSettings var pluginBaseUrls = defaultSettings.plugin_base_urls if (pluginBaseUrls !== undefined) { each$j(pluginBaseUrls, function (pluginBaseUrl, pluginName) { AddOnManager.PluginManager.urls[pluginName] = pluginBaseUrl }) } }, init: function (settings) { var self = this var result var invalidInlineTargets = Tools.makeMap( 'area base basefont br col frame hr img input isindex link meta param embed source wbr track ' + 'colgroup option table tbody tfoot thead tr th td script noscript style textarea video audio iframe object menu', ' ' ) var isInvalidInlineTarget = function (settings, elm) { return ( settings.inline && elm.tagName.toLowerCase() in invalidInlineTargets ) } var createId = function (elm) { var id = elm.id if (!id) { id = get$9(elm, 'name') .filter(function (name) { return !DOM.get(name) }) .getOrThunk(DOM.uniqueId) elm.setAttribute('id', id) } return id } var execCallback = function (name) { var callback = settings[name] if (!callback) { return } return callback.apply(self, []) } var hasClass = function (elm, className) { return className.constructor === RegExp ? className.test(elm.className) : DOM.hasClass(elm, className) } var findTargets = function (settings) { var targets = [] if (Env.browser.isIE() && Env.browser.version.major < 11) { initError( 'TinyMCE does not support the browser you are using. For a list of supported' + ' browsers please see: https://www.tinymce.com/docs/get-started/system-requirements/' ) return [] } else if (isQuirksMode) { initError( 'Failed to initialize the editor as the document is not in standards mode. ' + 'TinyMCE requires standards mode.' ) return [] } if (settings.types) { each$1(settings.types, function (type) { targets = targets.concat(DOM.select(type.selector)) }) return targets } else if (settings.selector) { return DOM.select(settings.selector) } else if (settings.target) { return [settings.target] } switch (settings.mode) { case 'exact': var l = settings.elements || '' if (l.length > 0) { each$1(explode(l), function (id) { var elm = DOM.get(id) if (elm) { targets.push(elm) } else { each$1(document.forms, function (f) { each$1(f.elements, function (e) { if (e.name === id) { id = 'mce_editor_' + instanceCounter++ DOM.setAttrib(e, 'id', id) targets.push(e) } }) }) } }) } break case 'textareas': case 'specific_textareas': each$1(DOM.select('textarea'), function (elm) { if ( settings.editor_deselector && hasClass(elm, settings.editor_deselector) ) { return } if ( !settings.editor_selector || hasClass(elm, settings.editor_selector) ) { targets.push(elm) } }) break } return targets } var provideResults = function (editors) { result = editors } var initEditors = function () { var initCount = 0 var editors = [] var targets var createEditor = function (id, settings, targetElm) { var editor = new Editor(id, settings, self) editors.push(editor) editor.on('init', function () { if (++initCount === targets.length) { provideResults(editors) } }) editor.targetElm = editor.targetElm || targetElm editor.render() } DOM.unbind(window, 'ready', initEditors) execCallback('onpageload') targets = DomQuery.unique(findTargets(settings)) if (settings.types) { each$1(settings.types, function (type) { Tools.each(targets, function (elm) { if (DOM.is(elm, type.selector)) { createEditor(createId(elm), extend$2({}, settings, type), elm) return false } return true }) }) return } Tools.each(targets, function (elm) { purgeDestroyedEditor(self.get(elm.id)) }) targets = Tools.grep(targets, function (elm) { return !self.get(elm.id) }) if (targets.length === 0) { provideResults([]) } else { each$1(targets, function (elm) { if (isInvalidInlineTarget(settings, elm)) { initError( 'Could not initialize inline editor on invalid inline target element', elm ) } else { createEditor(createId(elm), settings, elm) } }) } } self.settings = settings DOM.bind(window, 'ready', initEditors) return new promiseObj(function (resolve) { if (result) { resolve(result) } else { provideResults = function (editors) { resolve(editors) } } }) }, get: function (id) { if (arguments.length === 0) { return editors.slice(0) } else if (isString$1(id)) { return find$3(editors, function (editor) { return editor.id === id }).getOr(null) } else if (isNumber(id)) { return editors[id] ? editors[id] : null } else { return null } }, add: function (editor) { var self = this var existingEditor = legacyEditors[editor.id] if (existingEditor === editor) { return editor } if (self.get(editor.id) === null) { if (isValidLegacyKey(editor.id)) { legacyEditors[editor.id] = editor } legacyEditors.push(editor) editors.push(editor) } toggleGlobalEvents(true) self.activeEditor = editor self.fire('AddEditor', { editor: editor }) if (!beforeUnloadDelegate) { beforeUnloadDelegate = function (e) { var event = self.fire('BeforeUnload') if (event.returnValue) { e.preventDefault() e.returnValue = event.returnValue return event.returnValue } } window.addEventListener('beforeunload', beforeUnloadDelegate) } return editor }, createEditor: function (id, settings) { return this.add(new Editor(id, settings, this)) }, remove: function (selector) { var self = this var i, editor if (!selector) { for (i = editors.length - 1; i >= 0; i--) { self.remove(editors[i]) } return } if (isString$1(selector)) { each$1(DOM.select(selector), function (elm) { editor = self.get(elm.id) if (editor) { self.remove(editor) } }) return } editor = selector if (isNull(self.get(editor.id))) { return null } if (removeEditorFromList(editor)) { self.fire('RemoveEditor', { editor: editor }) } if (editors.length === 0) { window.removeEventListener('beforeunload', beforeUnloadDelegate) } editor.remove() toggleGlobalEvents(editors.length > 0) return editor }, execCommand: function (cmd, ui, value) { var self = this, editor = self.get(value) switch (cmd) { case 'mceAddEditor': if (!self.get(value)) { new Editor(value, self.settings, self).render() } return true case 'mceRemoveEditor': if (editor) { editor.remove() } return true case 'mceToggleEditor': if (!editor) { self.execCommand('mceAddEditor', false, value) return true } if (editor.isHidden()) { editor.show() } else { editor.hide() } return true } if (self.activeEditor) { return self.activeEditor.execCommand(cmd, ui, value) } return false }, triggerSave: function () { each$1(editors, function (editor) { editor.save() }) }, addI18n: function (code, items) { I18n.add(code, items) }, translate: function (text) { return I18n.translate(text) }, setActive: function (editor) { var activeEditor = this.activeEditor if (this.activeEditor !== editor) { if (activeEditor) { activeEditor.fire('deactivate', { relatedTarget: editor }) } editor.fire('activate', { relatedTarget: activeEditor }) } this.activeEditor = editor }, _setBaseUrl: function (baseUrl) { this.baseURL = new URI(this.documentBaseURL).toAbsolute( baseUrl.replace(/\/+$/, '') ) this.baseURI = new URI(this.baseURL) }, }) EditorManager.setup() var min$1 = Math.min, max$1 = Math.max, round$1 = Math.round var relativePosition = function (rect, targetRect, rel) { var x = targetRect.x var y = targetRect.y var w = rect.w var h = rect.h var targetW = targetRect.w var targetH = targetRect.h var relChars = (rel || '').split('') if (relChars[0] === 'b') { y += targetH } if (relChars[1] === 'r') { x += targetW } if (relChars[0] === 'c') { y += round$1(targetH / 2) } if (relChars[1] === 'c') { x += round$1(targetW / 2) } if (relChars[3] === 'b') { y -= h } if (relChars[4] === 'r') { x -= w } if (relChars[3] === 'c') { y -= round$1(h / 2) } if (relChars[4] === 'c') { x -= round$1(w / 2) } return create$2(x, y, w, h) } var findBestRelativePosition = function ( rect, targetRect, constrainRect, rels ) { var pos, i for (i = 0; i < rels.length; i++) { pos = relativePosition(rect, targetRect, rels[i]) if ( pos.x >= constrainRect.x && pos.x + pos.w <= constrainRect.w + constrainRect.x && pos.y >= constrainRect.y && pos.y + pos.h <= constrainRect.h + constrainRect.y ) { return rels[i] } } return null } var inflate = function (rect, w, h) { return create$2(rect.x - w, rect.y - h, rect.w + w * 2, rect.h + h * 2) } var intersect = function (rect, cropRect) { var x1 = max$1(rect.x, cropRect.x) var y1 = max$1(rect.y, cropRect.y) var x2 = min$1(rect.x + rect.w, cropRect.x + cropRect.w) var y2 = min$1(rect.y + rect.h, cropRect.y + cropRect.h) if (x2 - x1 < 0 || y2 - y1 < 0) { return null } return create$2(x1, y1, x2 - x1, y2 - y1) } var clamp = function (rect, clampRect, fixedSize) { var x1 = rect.x var y1 = rect.y var x2 = rect.x + rect.w var y2 = rect.y + rect.h var cx2 = clampRect.x + clampRect.w var cy2 = clampRect.y + clampRect.h var underflowX1 = max$1(0, clampRect.x - x1) var underflowY1 = max$1(0, clampRect.y - y1) var overflowX2 = max$1(0, x2 - cx2) var overflowY2 = max$1(0, y2 - cy2) x1 += underflowX1 y1 += underflowY1 if (fixedSize) { x2 += underflowX1 y2 += underflowY1 x1 -= overflowX2 y1 -= overflowY2 } x2 -= overflowX2 y2 -= overflowY2 return create$2(x1, y1, x2 - x1, y2 - y1) } var create$2 = function (x, y, w, h) { return { x: x, y: y, w: w, h: h, } } var fromClientRect = function (clientRect) { return create$2( clientRect.left, clientRect.top, clientRect.width, clientRect.height ) } var Rect = { inflate: inflate, relativePosition: relativePosition, findBestRelativePosition: findBestRelativePosition, intersect: intersect, clamp: clamp, create: create$2, fromClientRect: fromClientRect, } var awaiter = function (resolveCb, rejectCb, timeout) { if (timeout === void 0) { timeout = 1000 } var done = false var timer = null var complete = function (completer) { return function () { var args = [] for (var _i = 0; _i < arguments.length; _i++) { args[_i] = arguments[_i] } if (!done) { done = true if (timer !== null) { clearTimeout(timer) timer = null } completer.apply(null, args) } } } var resolve = complete(resolveCb) var reject = complete(rejectCb) var start = function () { var args = [] for (var _i = 0; _i < arguments.length; _i++) { args[_i] = arguments[_i] } if (!done && timer === null) { timer = setTimeout(function () { return reject.apply(null, args) }, timeout) } } return { start: start, resolve: resolve, reject: reject, } } var create$1 = function () { var tasks = {} var resultFns = {} var load = function (id, url) { var loadErrMsg = 'Script at URL "' + url + '" failed to load' var runErrMsg = 'Script at URL "' + url + '" did not call `tinymce.Resource.add(\'' + id + "', data)` within 1 second" if (tasks[id] !== undefined) { return tasks[id] } else { var task = new promiseObj(function (resolve, reject) { var waiter = awaiter(resolve, reject) resultFns[id] = waiter.resolve ScriptLoader.ScriptLoader.loadScript( url, function () { return waiter.start(runErrMsg) }, function () { return waiter.reject(loadErrMsg) } ) }) tasks[id] = task return task } } var add = function (id, data) { if (resultFns[id] !== undefined) { resultFns[id](data) delete resultFns[id] } tasks[id] = promiseObj.resolve(data) } return { load: load, add: add, } } var Resource = create$1() var each = Tools.each, extend$1 = Tools.extend var extendClass, initializing var Class = function () {} Class.extend = extendClass = function (props) { var self = this var _super = self.prototype var Class = function () { var i, mixins, mixin var self = this if (!initializing) { if (self.init) { self.init.apply(self, arguments) } mixins = self.Mixins if (mixins) { i = mixins.length while (i--) { mixin = mixins[i] if (mixin.init) { mixin.init.apply(self, arguments) } } } } } var dummy = function () { return this } var createMethod = function (name, fn) { return function () { var self = this var tmp = self._super self._super = _super[name] var ret = fn.apply(self, arguments) self._super = tmp return ret } } initializing = true var prototype = new self() initializing = false if (props.Mixins) { each(props.Mixins, function (mixin) { for (var name_1 in mixin) { if (name_1 !== 'init') { props[name_1] = mixin[name_1] } } }) if (_super.Mixins) { props.Mixins = _super.Mixins.concat(props.Mixins) } } if (props.Methods) { each(props.Methods.split(','), function (name) { props[name] = dummy }) } if (props.Properties) { each(props.Properties.split(','), function (name) { var fieldName = '_' + name props[name] = function (value) { var self = this if (value !== undefined) { self[fieldName] = value return self } return self[fieldName] } }) } if (props.Statics) { each(props.Statics, function (func, name) { Class[name] = func }) } if (props.Defaults && _super.Defaults) { props.Defaults = extend$1({}, _super.Defaults, props.Defaults) } each$j(props, function (member, name) { if (typeof member === 'function' && _super[name]) { prototype[name] = createMethod(name, member) } else { prototype[name] = member } }) Class.prototype = prototype Class.constructor = Class Class.extend = extendClass return Class } var min = Math.min, max = Math.max, round = Math.round var Color = function (value) { var self = {} var r = 0, g = 0, b = 0 var rgb2hsv = function (r, g, b) { var h, s, v h = 0 s = 0 v = 0 r = r / 255 g = g / 255 b = b / 255 var minRGB = min(r, min(g, b)) var maxRGB = max(r, max(g, b)) if (minRGB === maxRGB) { v = minRGB return { h: 0, s: 0, v: v * 100, } } var d = r === minRGB ? g - b : b === minRGB ? r - g : b - r h = r === minRGB ? 3 : b === minRGB ? 1 : 5 h = 60 * (h - d / (maxRGB - minRGB)) s = (maxRGB - minRGB) / maxRGB v = maxRGB return { h: round(h), s: round(s * 100), v: round(v * 100), } } var hsvToRgb = function (hue, saturation, brightness) { hue = (parseInt(hue, 10) || 0) % 360 saturation = parseInt(saturation, 10) / 100 brightness = parseInt(brightness, 10) / 100 saturation = max(0, min(saturation, 1)) brightness = max(0, min(brightness, 1)) if (saturation === 0) { r = g = b = round(255 * brightness) return } var side = hue / 60 var chroma = brightness * saturation var x = chroma * (1 - Math.abs((side % 2) - 1)) var match = brightness - chroma switch (Math.floor(side)) { case 0: r = chroma g = x b = 0 break case 1: r = x g = chroma b = 0 break case 2: r = 0 g = chroma b = x break case 3: r = 0 g = x b = chroma break case 4: r = x g = 0 b = chroma break case 5: r = chroma g = 0 b = x break default: r = g = b = 0 } r = round(255 * (r + match)) g = round(255 * (g + match)) b = round(255 * (b + match)) } var toHex = function () { var hex = function (val) { val = parseInt(val, 10).toString(16) return val.length > 1 ? val : '0' + val } return '#' + hex(r) + hex(g) + hex(b) } var toRgb = function () { return { r: r, g: g, b: b, } } var toHsv = function () { return rgb2hsv(r, g, b) } var parse = function (value) { var matches if (typeof value === 'object') { if ('r' in value) { r = value.r g = value.g b = value.b } else if ('v' in value) { hsvToRgb(value.h, value.s, value.v) } } else { if ( (matches = /rgb\s*\(\s*([0-9]+)\s*,\s*([0-9]+)\s*,\s*([0-9]+)[^\)]*\)/gi.exec( value )) ) { r = parseInt(matches[1], 10) g = parseInt(matches[2], 10) b = parseInt(matches[3], 10) } else if ( (matches = /#([0-F]{2})([0-F]{2})([0-F]{2})/gi.exec(value)) ) { r = parseInt(matches[1], 16) g = parseInt(matches[2], 16) b = parseInt(matches[3], 16) } else if ((matches = /#([0-F])([0-F])([0-F])/gi.exec(value))) { r = parseInt(matches[1] + matches[1], 16) g = parseInt(matches[2] + matches[2], 16) b = parseInt(matches[3] + matches[3], 16) } } r = r < 0 ? 0 : r > 255 ? 255 : r g = g < 0 ? 0 : g > 255 ? 255 : g b = b < 0 ? 0 : b > 255 ? 255 : b return self } if (value) { parse(value) } self.toRgb = toRgb self.toHsv = toHsv self.toHex = toHex self.parse = parse return self } var serialize = function (obj) { var data = JSON.stringify(obj) if (!isString$1(data)) { return data } return data.replace(/[\u0080-\uFFFF]/g, function (match) { var hexCode = match.charCodeAt(0).toString(16) return '\\u' + '0000'.substring(hexCode.length) + hexCode }) } var JSONUtils = { serialize: serialize, parse: function (text) { try { return JSON.parse(text) } catch (ex) {} }, } var JSONP = { callbacks: {}, count: 0, send: function (settings) { var self = this, dom = DOMUtils.DOM, count = settings.count !== undefined ? settings.count : self.count var id = 'tinymce_jsonp_' + count self.callbacks[count] = function (json) { dom.remove(id) delete self.callbacks[count] settings.callback(json) } dom.add(dom.doc.body, 'script', { id: id, src: settings.url, type: 'text/javascript', }) self.count++ }, } var XHR = __assign(__assign({}, Observable), { send: function (settings) { var xhr, count = 0 var ready = function () { if (!settings.async || xhr.readyState === 4 || count++ > 10000) { if (settings.success && count < 10000 && xhr.status === 200) { settings.success.call( settings.success_scope, '' + xhr.responseText, xhr, settings ) } else if (settings.error) { settings.error.call( settings.error_scope, count > 10000 ? 'TIMED_OUT' : 'GENERAL', xhr, settings ) } xhr = null } else { Delay.setTimeout(ready, 10) } } settings.scope = settings.scope || this settings.success_scope = settings.success_scope || settings.scope settings.error_scope = settings.error_scope || settings.scope settings.async = settings.async !== false settings.data = settings.data || '' XHR.fire('beforeInitialize', { settings: settings }) xhr = new XMLHttpRequest() if (xhr.overrideMimeType) { xhr.overrideMimeType(settings.content_type) } xhr.open( settings.type || (settings.data ? 'POST' : 'GET'), settings.url, settings.async ) if (settings.crossDomain) { xhr.withCredentials = true } if (settings.content_type) { xhr.setRequestHeader('Content-Type', settings.content_type) } if (settings.requestheaders) { Tools.each(settings.requestheaders, function (header) { xhr.setRequestHeader(header.key, header.value) }) } xhr.setRequestHeader('X-Requested-With', 'XMLHttpRequest') xhr = XHR.fire('beforeSend', { xhr: xhr, settings: settings, }).xhr xhr.send(settings.data) if (!settings.async) { return ready() } Delay.setTimeout(ready, 10) }, }) var extend = Tools.extend var JSONRequest = (function () { function JSONRequest(settings) { this.settings = extend({}, settings) this.count = 0 } JSONRequest.sendRPC = function (o) { return new JSONRequest().send(o) } JSONRequest.prototype.send = function (args) { var ecb = args.error, scb = args.success var xhrArgs = extend(this.settings, args) xhrArgs.success = function (c, x) { c = JSONUtils.parse(c) if (typeof c === 'undefined') { c = { error: 'JSON Parse error.' } } if (c.error) { ecb.call(xhrArgs.error_scope || xhrArgs.scope, c.error, x) } else { scb.call(xhrArgs.success_scope || xhrArgs.scope, c.result) } } xhrArgs.error = function (ty, x) { if (ecb) { ecb.call(xhrArgs.error_scope || xhrArgs.scope, ty, x) } } xhrArgs.data = JSONUtils.serialize({ id: args.id || 'c' + this.count++, method: args.method, params: args.params, }) xhrArgs.content_type = 'application/json' XHR.send(xhrArgs) } return JSONRequest })() var create = function () { return (function () { var data = {} var keys = [] var storage = { getItem: function (key) { var item = data[key] return item ? item : null }, setItem: function (key, value) { keys.push(key) data[key] = String(value) }, key: function (index) { return keys[index] }, removeItem: function (key) { keys = keys.filter(function (k) { return k === key }) delete data[key] }, clear: function () { keys = [] data = {} }, length: 0, } Object.defineProperty(storage, 'length', { get: function () { return keys.length }, configurable: false, enumerable: false, }) return storage })() } var localStorage try { var test = '__storage_test__' localStorage = window.localStorage localStorage.setItem(test, test) localStorage.removeItem(test) } catch (e) { localStorage = create() } var LocalStorage = localStorage var publicApi = { geom: { Rect: Rect }, util: { Promise: promiseObj, Delay: Delay, Tools: Tools, VK: VK, URI: URI, Class: Class, EventDispatcher: EventDispatcher, Observable: Observable, I18n: I18n, XHR: XHR, JSON: JSONUtils, JSONRequest: JSONRequest, JSONP: JSONP, LocalStorage: LocalStorage, Color: Color, ImageUploader: ImageUploader, }, dom: { EventUtils: EventUtils, Sizzle: Sizzle, DomQuery: DomQuery, TreeWalker: DomTreeWalker, TextSeeker: TextSeeker, DOMUtils: DOMUtils, ScriptLoader: ScriptLoader, RangeUtils: RangeUtils, Serializer: DomSerializer, StyleSheetLoader: StyleSheetLoader, ControlSelection: ControlSelection, BookmarkManager: BookmarkManager, Selection: EditorSelection, Event: EventUtils.Event, }, html: { Styles: Styles, Entities: Entities, Node: AstNode, Schema: Schema, SaxParser: SaxParser, DomParser: DomParser, Writer: Writer, Serializer: HtmlSerializer, }, Env: Env, AddOnManager: AddOnManager, Annotator: Annotator, Formatter: Formatter, UndoManager: UndoManager, EditorCommands: EditorCommands, WindowManager: WindowManager, NotificationManager: NotificationManager, EditorObservable: EditorObservable, Shortcuts: Shortcuts, Editor: Editor, FocusManager: FocusManager, EditorManager: EditorManager, DOM: DOMUtils.DOM, ScriptLoader: ScriptLoader.ScriptLoader, PluginManager: PluginManager, ThemeManager: ThemeManager, IconManager: IconManager, Resource: Resource, trim: Tools.trim, isArray: Tools.isArray, is: Tools.is, toArray: Tools.toArray, makeMap: Tools.makeMap, each: Tools.each, map: Tools.map, grep: Tools.grep, inArray: Tools.inArray, extend: Tools.extend, create: Tools.create, walk: Tools.walk, createNS: Tools.createNS, resolve: Tools.resolve, explode: Tools.explode, _addCacheSuffix: Tools._addCacheSuffix, isOpera: Env.opera, isWebKit: Env.webkit, isIE: Env.ie, isGecko: Env.gecko, isMac: Env.mac, } var tinymce = Tools.extend(EditorManager, publicApi) var exportToModuleLoaders = function (tinymce) { if (typeof module === 'object') { try { module.exports = tinymce } catch (_) {} } } var exportToWindowGlobal = function (tinymce) { window.tinymce = tinymce window.tinyMCE = tinymce } exportToWindowGlobal(tinymce) exportToModuleLoaders(tinymce) })()