You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

13131 lines
428 KiB

/**
* 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 __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 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 = isType$1('string');
var isObject = isType$1('object');
var isArray = 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$1 = 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$1 = function (f) {
return f();
};
var never = constant$1(false);
var always = constant$1(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$1(null),
getOrUndefined: constant$1(undefined),
or: id,
orThunk: call,
map: none,
each: noop,
bind: none,
exists: never,
forall: always,
filter: function () {
return none();
},
toArray: function () {
return [];
},
toString: constant$1('none()')
};
return me;
}();
var some = function (a) {
var constant_a = constant$1(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 = function (value) {
return value === null || value === undefined ? NONE : some(value);
};
var Optional = {
some: some,
none: none,
from: 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$1(isiPad),
isiPhone: constant$1(isiPhone),
isTablet: constant$1(isTablet),
isPhone: constant$1(isPhone),
isTouch: constant$1(isTouch),
isAndroid: os.isAndroid,
isiOS: os.isiOS,
isWebView: constant$1(iOSwebview),
isDesktop: constant$1(isDesktop)
};
};
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 contains$1 = 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$2 = 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$1 = 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 filter$2 = 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$1(xs, function (x, i) {
acc = f(acc, x, i);
});
return acc;
};
var findUntil = 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$2 = function (xs, pred) {
return findUntil(xs, pred, never);
};
var findIndex$1 = 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(xs[i])) {
throw new Error('Arr.flatten item ' + i + ' was not an array, input: ' + xs);
}
nativePush.apply(r, xs[i]);
}
return r;
};
var bind$3 = function (xs, f) {
return flatten(map$2(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$2(a1, function (x) {
return !contains$1(a2, x);
});
};
var pure$2 = function (x) {
return [x];
};
var sort = function (xs, comparator) {
var copy = nativeSlice.call(xs, 0);
copy.sort(comparator);
return copy;
};
var get$d = function (xs, i) {
return i >= 0 && i < xs.length ? Optional.some(xs[i]) : Optional.none();
};
var head = function (xs) {
return get$d(xs, 0);
};
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 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$1 = 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$8(group(1), group(2));
};
var detect$4 = function (versionRegexes, agent) {
var cleanedAgent = String(agent).toLowerCase();
if (versionRegexes.length === 0) {
return unknown$3();
}
return find$1(versionRegexes, cleanedAgent);
};
var unknown$3 = function () {
return nu$8(0, 0);
};
var nu$8 = function (major, minor) {
return {
major: major,
minor: minor
};
};
var Version = {
nu: nu$8,
detect: detect$4,
unknown: unknown$3
};
var detectBrowser$1 = function (browsers, userAgentData) {
return findMap(userAgentData.brands, function (uaBrand) {
var lcBrand = uaBrand.brand.toLowerCase();
return find$2(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$3 = function (candidates, userAgent) {
var agent = String(userAgent).toLowerCase();
return find$2(candidates, function (candidate) {
return candidate.search(agent);
});
};
var detectBrowser = function (browsers, userAgent) {
return detect$3(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$3(oses, userAgent).map(function (os) {
var version = Version.detect(os.versionRegexes, userAgent);
return {
current: os.name,
version: version
};
});
};
var checkRange = function (str, substr, start) {
return substr === '' || str.length >= substr.length && str.substr(start, start + substr.length) === substr;
};
var supplant = function (str, obj) {
var isStringOrNumber = function (a) {
var t = typeof a;
return t === 'string' || t === 'number';
};
return str.replace(/\$\{([^{}]*)\}/g, function (fullMatch, key) {
var value = obj[key];
return isStringOrNumber(value) ? value.toString() : fullMatch;
});
};
var contains = function (str, substr) {
return str.indexOf(substr) !== -1;
};
var endsWith = function (str, suffix) {
return checkRange(str, suffix, str.length - suffix.length);
};
var blank = function (r) {
return function (s) {
return s.replace(r, '');
};
};
var trim = blank(/^\s+|\s+$/g);
var normalVersionRegex = /.*?version\/\ ?([0-9]+)\.([0-9]+).*/;
var checkContains = function (target) {
return function (uastring) {
return contains(uastring, target);
};
};
var browsers = [
{
name: 'Edge',
versionRegexes: [/.*?edge\/ ?([0-9]+)\.([0-9]+)$/],
search: function (uastring) {
return contains(uastring, 'edge/') && contains(uastring, 'chrome') && contains(uastring, 'safari') && contains(uastring, 'applewebkit');
}
},
{
name: 'Chrome',
brand: 'Chromium',
versionRegexes: [
/.*?chrome\/([0-9]+)\.([0-9]+).*/,
normalVersionRegex
],
search: function (uastring) {
return contains(uastring, 'chrome') && !contains(uastring, 'chromeframe');
}
},
{
name: 'IE',
versionRegexes: [
/.*?msie\ ?([0-9]+)\.([0-9]+).*/,
/.*?rv:([0-9]+)\.([0-9]+).*/
],
search: function (uastring) {
return contains(uastring, 'msie') || contains(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(uastring, 'safari') || contains(uastring, 'mobile/')) && contains(uastring, 'applewebkit');
}
}
];
var oses = [
{
name: 'Windows',
search: checkContains('win'),
versionRegexes: [/.*?windows\ nt\ ?([0-9]+)\.([0-9]+).*/]
},
{
name: 'iOS',
search: function (uastring) {
return contains(uastring, 'iphone') || contains(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$1(browsers),
oses: constant$1(oses)
};
var edge = 'Edge';
var chrome = 'Chrome';
var ie = 'IE';
var opera = 'Opera';
var firefox = 'Firefox';
var safari = 'Safari';
var unknown$2 = function () {
return nu$7({
current: undefined,
version: Version.unknown()
});
};
var nu$7 = 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),
isOpera: isBrowser(opera),
isFirefox: isBrowser(firefox),
isSafari: isBrowser(safari)
};
};
var Browser = {
unknown: unknown$2,
nu: nu$7,
edge: constant$1(edge),
chrome: constant$1(chrome),
ie: constant$1(ie),
opera: constant$1(opera),
firefox: constant$1(firefox),
safari: constant$1(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$1 = function () {
return nu$6({
current: undefined,
version: Version.unknown()
});
};
var nu$6 = 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$1,
nu: nu$6,
windows: constant$1(windows),
ios: constant$1(ios),
android: constant$1(android),
linux: constant$1(linux),
osx: constant$1(osx),
solaris: constant$1(solaris),
freebsd: constant$1(freebsd),
chromeos: constant$1(chromeos)
};
var detect$2 = 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$2 };
var mediaMatch = function (query) {
return window.matchMedia(query).matches;
};
var platform$1 = cached(function () {
return PlatformDetection.detect(navigator.userAgent, Optional.from(navigator.userAgentData), mediaMatch);
});
var detect$1 = function () {
return platform$1();
};
var constant = constant$1;
var touchstart = constant('touchstart');
var touchmove = constant('touchmove');
var touchend = constant('touchend');
var mousedown = constant('mousedown');
var mousemove = constant('mousemove');
var mouseup = constant('mouseup');
var mouseover = constant('mouseover');
var keydown = constant('keydown');
var keyup = constant('keyup');
var input$1 = constant('input');
var change = constant('change');
var click = constant('click');
var transitionend = constant('transitionend');
var selectstart = constant('selectstart');
var prefixName = function (name) {
return constant$1('alloy.' + name);
};
var alloy = { tap: prefixName('tap') };
var focus$4 = prefixName('focus');
var postBlur = prefixName('blur.post');
var postPaste = prefixName('paste.post');
var receive$1 = prefixName('receive');
var execute$5 = prefixName('execute');
var focusItem = prefixName('focus.item');
var tap = alloy.tap;
var longpress = prefixName('longpress');
var systemInit = prefixName('system.init');
var attachedToDom = prefixName('system.attached');
var detachedFromDom = prefixName('system.detached');
var focusShifted = prefixName('focusmanager.shifted');
var highlight$1 = prefixName('highlight');
var dehighlight$1 = prefixName('dehighlight');
var emit = function (component, event) {
dispatchWith(component, component.element, event, {});
};
var emitWith = function (component, event, properties) {
dispatchWith(component, component.element, event, properties);
};
var emitExecute = function (component) {
emit(component, execute$5());
};
var dispatch = function (component, target, event) {
dispatchWith(component, target, event, {});
};
var dispatchWith = function (component, target, event, properties) {
var data = __assign({ target: target }, properties);
component.getSystem().triggerEvent(event, target, data);
};
var dispatchEvent = function (component, target, event, simulatedEvent) {
component.getSystem().triggerEvent(event, target, simulatedEvent.event);
};
var dispatchFocus = function (component, target) {
component.getSystem().triggerFocus(target, component.element);
};
var DOCUMENT = 9;
var DOCUMENT_FRAGMENT = 11;
var ELEMENT = 1;
var TEXT = 3;
var fromHtml$2 = 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(div.childNodes[0]);
};
var fromTag = function (tag, scope) {
var doc = scope || document;
var node = doc.createElement(tag);
return fromDom(node);
};
var fromText = function (text, scope) {
var doc = scope || document;
var node = doc.createTextNode(text);
return fromDom(node);
};
var fromDom = function (node) {
if (node === null || node === undefined) {
throw new Error('Node cannot be null or undefined');
}
return { dom: node };
};
var fromPoint = function (docElm, x, y) {
return Optional.from(docElm.dom.elementFromPoint(x, y)).map(fromDom);
};
var SugarElement = {
fromHtml: fromHtml$2,
fromTag: fromTag,
fromText: fromText,
fromDom: fromDom,
fromPoint: fromPoint
};
var is$1 = 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$2 = function (selector, scope) {
var base = scope === undefined ? document : scope.dom;
return bypassSelector(base) ? [] : map$2(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;
};
typeof window !== 'undefined' ? window : Function('return this;')();
var name$1 = 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 isElement = isType(ELEMENT);
var isText = isType(TEXT);
var isDocument = isType(DOCUMENT);
var isDocumentFragment = isType(DOCUMENT_FRAGMENT);
var owner$2 = function (element) {
return SugarElement.fromDom(element.dom.ownerDocument);
};
var documentOrOwner = function (dos) {
return isDocument(dos) ? dos : owner$2(dos);
};
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 = 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$2 = function (element) {
var filterSelf = function (elements) {
return filter$2(elements, function (x) {
return !eq(element, x);
});
};
return parent(element).map(children).map(filterSelf).getOr([]);
};
var nextSibling = function (element) {
return Optional.from(element.dom.nextSibling).map(SugarElement.fromDom);
};
var children = function (element) {
return map$2(element.dom.childNodes, SugarElement.fromDom);
};
var child = function (element, index) {
var cs = element.dom.childNodes;
return Optional.from(cs[index]).map(SugarElement.fromDom);
};
var firstChild = function (element) {
return child(element, 0);
};
var before$1 = function (marker, element) {
var parent$1 = parent(marker);
parent$1.each(function (v) {
v.dom.insertBefore(element.dom, marker.dom);
});
};
var after$2 = function (marker, element) {
var sibling = nextSibling(marker);
sibling.fold(function () {
var parent$1 = parent(marker);
parent$1.each(function (v) {
append$2(v, element);
});
}, function (v) {
before$1(v, element);
});
};
var prepend$1 = function (parent, element) {
var firstChild$1 = firstChild(parent);
firstChild$1.fold(function () {
append$2(parent, element);
}, function (v) {
parent.dom.insertBefore(element.dom, v.dom);
});
};
var append$2 = function (parent, element) {
parent.dom.appendChild(element.dom);
};
var appendAt = function (parent, element, index) {
child(parent, index).fold(function () {
append$2(parent, element);
}, function (v) {
before$1(v, element);
});
};
var append$1 = function (parent, elements) {
each$1(elements, function (x) {
append$2(parent, x);
});
};
var empty = function (element) {
element.dom.textContent = '';
each$1(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 isShadowRoot = function (dos) {
return isDocumentFragment(dos) && isNonNullable(dos.dom.host);
};
var supported = isFunction(Element.prototype.attachShadow) && isFunction(Node.prototype.getRootNode);
var isSupported$1 = constant$1(supported);
var getRootNode = supported ? function (e) {
return SugarElement.fromDom(e.dom.getRootNode());
} : documentOrOwner;
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(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 inBody = function (element) {
var dom = isText(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 body = function () {
return getBody(SugarElement.fromDom(document));
};
var getBody = function (doc) {
var b = doc.dom.body;
if (b === null || b === undefined) {
throw new Error('Body is not available yet');
}
return SugarElement.fromDom(b);
};
var fireDetaching = function (component) {
emit(component, detachedFromDom());
var children = component.components();
each$1(children, fireDetaching);
};
var fireAttaching = function (component) {
var children = component.components();
each$1(children, fireAttaching);
emit(component, attachedToDom());
};
var attach$1 = function (parent, child) {
append$2(parent.element, child.element);
};
var detachChildren = function (component) {
each$1(component.components(), function (childComp) {
return remove$7(childComp.element);
});
empty(component.element);
component.syncComponents();
};
var replaceChildren = function (component, newChildren) {
var subs = component.components();
detachChildren(component);
var deleted = difference(subs, newChildren);
each$1(deleted, function (comp) {
fireDetaching(comp);
component.getSystem().removeFromWorld(comp);
});
each$1(newChildren, function (childComp) {
if (!childComp.getSystem().isConnected()) {
component.getSystem().addToWorld(childComp);
attach$1(component, childComp);
if (inBody(component.element)) {
fireAttaching(childComp);
}
} else {
attach$1(component, childComp);
}
component.syncComponents();
});
};
var attach = function (parent, child) {
attachWith(parent, child, append$2);
};
var attachWith = function (parent, child, insertion) {
parent.getSystem().addToWorld(child);
insertion(parent.element, child.element);
if (inBody(parent.element)) {
fireAttaching(child);
}
parent.syncComponents();
};
var doDetach = function (component) {
fireDetaching(component);
remove$7(component.element);
component.getSystem().removeFromWorld(component);
};
var detach = function (component) {
var parent$1 = parent(component.element).bind(function (p) {
return component.getSystem().getByDom(p).toOptional();
});
doDetach(component);
parent$1.each(function (p) {
p.syncComponents();
});
};
var attachSystemAfter = function (element, guiSystem) {
attachSystemWith(element, guiSystem, after$2);
};
var attachSystemWith = function (element, guiSystem, inserter) {
inserter(element, guiSystem.element);
var children$1 = children(guiSystem.element);
each$1(children$1, function (child) {
guiSystem.getByDom(child).each(fireAttaching);
});
};
var detachSystem = function (guiSystem) {
var children$1 = children(guiSystem.element);
each$1(children$1, function (child) {
guiSystem.getByDom(child).each(fireDetaching);
});
remove$7(guiSystem.element);
};
var keys = Object.keys;
var hasOwnProperty = Object.hasOwnProperty;
var each = 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$1 = function (obj, f) {
return tupleMap(obj, function (x, i) {
return {
k: i,
v: f(x, i)
};
});
};
var tupleMap = function (obj, f) {
var r = {};
each(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(obj, function (x, i) {
(pred(x, i) ? onTrue : onFalse)(x, i);
});
return r;
};
var filter$1 = function (obj, pred) {
var t = {};
internalFilter(obj, pred, objAcc(t), noop);
return t;
};
var mapToArray = function (obj, f) {
var r = [];
each(obj, function (value, name) {
r.push(f(value, name));
});
return r;
};
var find = function (obj, pred) {
var props = keys(obj);
for (var k = 0, len = props.length; k < len; k++) {
var i = props[k];
var x = obj[i];
if (pred(x, i, obj)) {
return Optional.some(x);
}
}
return Optional.none();
};
var values = function (obj) {
return mapToArray(obj, identity);
};
var get$c = function (obj, key) {
return has$2(obj, key) ? Optional.from(obj[key]) : Optional.none();
};
var has$2 = function (obj, key) {
return hasOwnProperty.call(obj, key);
};
var hasNonNullableKey = function (obj, key) {
return has$2(obj, key) && obj[key] !== undefined && obj[key] !== null;
};
var rawSet = function (dom, key, value) {
if (isString(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$8 = function (element, key, value) {
rawSet(element.dom, key, value);
};
var setAll$1 = function (element, attrs) {
var dom = element.dom;
each(attrs, function (v, k) {
rawSet(dom, k, v);
});
};
var get$b = function (element, key) {
var v = element.dom.getAttribute(key);
return v === null ? undefined : v;
};
var getOpt = function (element, key) {
return Optional.from(get$b(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 read$2 = function (element, attr) {
var value = get$b(element, attr);
return value === undefined || value === '' ? [] : value.split(' ');
};
var add$3 = function (element, attr, id) {
var old = read$2(element, attr);
var nu = old.concat([id]);
set$8(element, attr, nu.join(' '));
return true;
};
var remove$5 = function (element, attr, id) {
var nu = filter$2(read$2(element, attr), function (v) {
return v !== id;
});
if (nu.length > 0) {
set$8(element, attr, nu.join(' '));
} else {
remove$6(element, attr);
}
return false;
};
var supports = function (element) {
return element.dom.classList !== undefined;
};
var get$a = function (element) {
return read$2(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$a(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 swap = function (element, addCls, removeCls) {
remove$3(element, removeCls);
add$1(element, addCls);
};
var toAlpha = function (component, swapConfig, _swapState) {
swap(component.element, swapConfig.alpha, swapConfig.omega);
};
var toOmega = function (component, swapConfig, _swapState) {
swap(component.element, swapConfig.omega, swapConfig.alpha);
};
var clear$1 = function (component, swapConfig, _swapState) {
remove$3(component.element, swapConfig.alpha);
remove$3(component.element, swapConfig.omega);
};
var isAlpha = function (component, swapConfig, _swapState) {
return has(component.element, swapConfig.alpha);
};
var isOmega = function (component, swapConfig, _swapState) {
return has(component.element, swapConfig.omega);
};
var SwapApis = /*#__PURE__*/Object.freeze({
__proto__: null,
toAlpha: toAlpha,
toOmega: toOmega,
isAlpha: isAlpha,
isOmega: isOmega,
clear: clear$1
});
var value$2 = function (o) {
var or = function (_opt) {
return value$2(o);
};
var orThunk = function (_f) {
return value$2(o);
};
var map = function (f) {
return value$2(f(o));
};
var mapError = function (_f) {
return value$2(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$1(o),
getOrThunk: constant$1(o),
getOrDie: constant$1(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$2);
};
var Result = {
value: value$2,
error: error,
fromOption: fromOption
};
var SimpleResultType;
(function (SimpleResultType) {
SimpleResultType[SimpleResultType['Error'] = 0] = 'Error';
SimpleResultType[SimpleResultType['Value'] = 1] = 'Value';
}(SimpleResultType || (SimpleResultType = {})));
var fold$1 = function (res, onError, onValue) {
return res.stype === SimpleResultType.Error ? onError(res.serror) : onValue(res.svalue);
};
var partition$1 = function (results) {
var values = [];
var errors = [];
each$1(results, function (obj) {
fold$1(obj, function (err) {
return errors.push(err);
}, function (val) {
return values.push(val);
});
});
return {
values: values,
errors: errors
};
};
var mapError = function (res, f) {
if (res.stype === SimpleResultType.Error) {
return {
stype: SimpleResultType.Error,
serror: f(res.serror)
};
} else {
return res;
}
};
var map = function (res, f) {
if (res.stype === SimpleResultType.Value) {
return {
stype: SimpleResultType.Value,
svalue: f(res.svalue)
};
} else {
return res;
}
};
var bind$2 = function (res, f) {
if (res.stype === SimpleResultType.Value) {
return f(res.svalue);
} else {
return res;
}
};
var bindError = function (res, f) {
if (res.stype === SimpleResultType.Error) {
return f(res.serror);
} else {
return res;
}
};
var svalue = function (v) {
return {
stype: SimpleResultType.Value,
svalue: v
};
};
var serror = function (e) {
return {
stype: SimpleResultType.Error,
serror: e
};
};
var toResult$1 = function (res) {
return fold$1(res, Result.error, Result.value);
};
var fromResult = function (res) {
return res.fold(serror, svalue);
};
var SimpleResult = {
fromResult: fromResult,
toResult: toResult$1,
svalue: svalue,
partition: partition$1,
serror: serror,
bind: bind$2,
bindError: bindError,
map: map,
mapError: mapError,
fold: fold$1
};
var field$3 = function (key, newKey, presence, prop) {
return {
tag: 'field',
key: key,
newKey: newKey,
presence: presence,
prop: prop
};
};
var customField$1 = function (newKey, instantiator) {
return {
tag: 'custom',
newKey: newKey,
instantiator: instantiator
};
};
var fold = function (value, ifField, ifCustom) {
switch (value.tag) {
case 'field':
return ifField(value.key, value.newKey, value.presence, value.prop);
case 'custom':
return ifCustom(value.newKey, value.instantiator);
}
};
var shallow$1 = function (old, nu) {
return nu;
};
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 merge$1 = baseMerge(shallow$1);
var required$2 = function () {
return {
tag: 'required',
process: {}
};
};
var defaultedThunk = function (fallbackThunk) {
return {
tag: 'defaultedThunk',
process: fallbackThunk
};
};
var defaulted$1 = function (fallback) {
return defaultedThunk(constant$1(fallback));
};
var asOption = function () {
return {
tag: 'option',
process: {}
};
};
var mergeWithThunk = function (baseThunk) {
return {
tag: 'mergeWithThunk',
process: baseThunk
};
};
var mergeWith = function (base) {
return mergeWithThunk(constant$1(base));
};
var mergeValues$1 = function (values, base) {
return values.length > 0 ? SimpleResult.svalue(deepMerge(base, merge$1.apply(undefined, values))) : SimpleResult.svalue(base);
};
var mergeErrors$1 = function (errors) {
return compose(SimpleResult.serror, flatten)(errors);
};
var consolidateObj = function (objects, base) {
var partition = SimpleResult.partition(objects);
return partition.errors.length > 0 ? mergeErrors$1(partition.errors) : mergeValues$1(partition.values, base);
};
var consolidateArr = function (objects) {
var partitions = SimpleResult.partition(objects);
return partitions.errors.length > 0 ? mergeErrors$1(partitions.errors) : SimpleResult.svalue(partitions.values);
};
var ResultCombine = {
consolidateObj: consolidateObj,
consolidateArr: consolidateArr
};
var formatObj = function (input) {
return isObject(input) && keys(input).length > 100 ? ' removed due to size' : JSON.stringify(input, null, 2);
};
var formatErrors = function (errors) {
var es = errors.length > 10 ? errors.slice(0, 10).concat([{
path: [],
getErrorInfo: constant$1('... (only showing first ten failures)')
}]) : errors;
return map$2(es, function (e) {
return 'Failed path: (' + e.path.join(' > ') + ')\n' + e.getErrorInfo();
});
};
var nu$5 = function (path, getErrorInfo) {
return SimpleResult.serror([{
path: path,
getErrorInfo: getErrorInfo
}]);
};
var missingRequired = function (path, key, obj) {
return nu$5(path, function () {
return 'Could not find valid *required* value for "' + key + '" in ' + formatObj(obj);
});
};
var missingKey = function (path, key) {
return nu$5(path, function () {
return 'Choice schema did not contain choice key: "' + key + '"';
});
};
var missingBranch = function (path, branches, branch) {
return nu$5(path, function () {
return 'The chosen schema: "' + branch + '" did not exist in branches: ' + formatObj(branches);
});
};
var unsupportedFields = function (path, unsupported) {
return nu$5(path, function () {
return 'There are unsupported fields: [' + unsupported.join(', ') + '] specified';
});
};
var custom = function (path, err) {
return nu$5(path, constant$1(err));
};
var value$1 = function (validator) {
var extract = function (path, val) {
return SimpleResult.bindError(validator(val), function (err) {
return custom(path, err);
});
};
var toString = constant$1('val');
return {
extract: extract,
toString: toString
};
};
var anyValue$1 = value$1(SimpleResult.svalue);
var requiredAccess = function (path, obj, key, bundle) {
return get$c(obj, key).fold(function () {
return missingRequired(path, key, obj);
}, bundle);
};
var fallbackAccess = function (obj, key, fallback, bundle) {
var v = get$c(obj, key).getOrThunk(function () {
return fallback(obj);
});
return bundle(v);
};
var optionAccess = function (obj, key, bundle) {
return bundle(get$c(obj, key));
};
var optionDefaultedAccess = function (obj, key, fallback, bundle) {
var opt = get$c(obj, key).map(function (val) {
return val === true ? fallback(obj) : val;
});
return bundle(opt);
};
var extractField = function (field, path, obj, key, prop) {
var bundle = function (av) {
return prop.extract(path.concat([key]), av);
};
var bundleAsOption = function (optValue) {
return optValue.fold(function () {
return SimpleResult.svalue(Optional.none());
}, function (ov) {
var result = prop.extract(path.concat([key]), ov);
return SimpleResult.map(result, Optional.some);
});
};
switch (field.tag) {
case 'required':
return requiredAccess(path, obj, key, bundle);
case 'defaultedThunk':
return fallbackAccess(obj, key, field.process, bundle);
case 'option':
return optionAccess(obj, key, bundleAsOption);
case 'defaultedOptionThunk':
return optionDefaultedAccess(obj, key, field.process, bundleAsOption);
case 'mergeWithThunk': {
return fallbackAccess(obj, key, constant$1({}), function (v) {
var result = deepMerge(field.process(obj), v);
return bundle(result);
});
}
}
};
var extractFields = function (path, obj, fields) {
var success = {};
var errors = [];
for (var _i = 0, fields_1 = fields; _i < fields_1.length; _i++) {
var field = fields_1[_i];
fold(field, function (key, newKey, presence, prop) {
var result = extractField(presence, path, obj, key, prop);
SimpleResult.fold(result, function (err) {
errors.push.apply(errors, err);
}, function (res) {
success[newKey] = res;
});
}, function (newKey, instantiator) {
success[newKey] = instantiator(obj);
});
}
return errors.length > 0 ? SimpleResult.serror(errors) : SimpleResult.svalue(success);
};
var getSetKeys = function (obj) {
return keys(filter$1(obj, isNonNullable));
};
var objOfOnly = function (fields) {
var delegate = objOf(fields);
var fieldNames = foldr(fields, function (acc, value) {
return fold(value, function (key) {
var _a;
return deepMerge(acc, (_a = {}, _a[key] = true, _a));
}, constant$1(acc));
}, {});
var extract = function (path, o) {
var keys = isBoolean(o) ? [] : getSetKeys(o);
var extra = filter$2(keys, function (k) {
return !hasNonNullableKey(fieldNames, k);
});
return extra.length === 0 ? delegate.extract(path, o) : unsupportedFields(path, extra);
};
return {
extract: extract,
toString: delegate.toString
};
};
var objOf = function (values) {
var extract = function (path, o) {
return extractFields(path, o, values);
};
var toString = function () {
var fieldStrings = map$2(values, function (value) {
return fold(value, function (key, _okey, _presence, prop) {
return key + ' -> ' + prop.toString();
}, function (newKey, _instantiator) {
return 'state(' + newKey + ')';
});
});
return 'obj{\n' + fieldStrings.join('\n') + '}';
};
return {
extract: extract,
toString: toString
};
};
var arrOf = function (prop) {
var extract = function (path, array) {
var results = map$2(array, function (a, i) {
return prop.extract(path.concat(['[' + i + ']']), a);
});
return ResultCombine.consolidateArr(results);
};
var toString = function () {
return 'array(' + prop.toString() + ')';
};
return {
extract: extract,
toString: toString
};
};
var setOf$1 = function (validator, prop) {
var validateKeys = function (path, keys) {
return arrOf(value$1(validator)).extract(path, keys);
};
var extract = function (path, o) {
var keys$1 = keys(o);
var validatedKeys = validateKeys(path, keys$1);
return SimpleResult.bind(validatedKeys, function (validKeys) {
var schema = map$2(validKeys, function (vk) {
return field$3(vk, vk, required$2(), prop);
});
return objOf(schema).extract(path, o);
});
};
var toString = function () {
return 'setOf(' + prop.toString() + ')';
};
return {
extract: extract,
toString: toString
};
};
var anyValue = constant$1(anyValue$1);
var typedValue = function (validator, expectedType) {
return value$1(function (a) {
var actualType = typeof a;
return validator(a) ? SimpleResult.svalue(a) : SimpleResult.serror('Expected type: ' + expectedType + ' but got: ' + actualType);
});
};
var functionProcessor = typedValue(isFunction, 'function');
var chooseFrom = function (path, input, branches, ch) {
var fields = get$c(branches, ch);
return fields.fold(function () {
return missingBranch(path, branches, ch);
}, function (vp) {
return vp.extract(path.concat(['branch: ' + ch]), input);
});
};
var choose$2 = function (key, branches) {
var extract = function (path, input) {
var choice = get$c(input, key);
return choice.fold(function () {
return missingKey(path, key);
}, function (chosen) {
return chooseFrom(path, input, branches, chosen);
});
};
var toString = function () {
return 'chooseOn(' + key + '). Possible values: ' + keys(branches);
};
return {
extract: extract,
toString: toString
};
};
var valueOf = function (validator) {
return value$1(function (v) {
return validator(v).fold(SimpleResult.serror, SimpleResult.svalue);
});
};
var setOf = function (validator, prop) {
return setOf$1(function (v) {
return SimpleResult.fromResult(validator(v));
}, prop);
};
var extractValue = function (label, prop, obj) {
var res = prop.extract([label], obj);
return SimpleResult.mapError(res, function (errs) {
return {
input: obj,
errors: errs
};
});
};
var asRaw = function (label, prop, obj) {
return SimpleResult.toResult(extractValue(label, prop, obj));
};
var getOrDie = function (extraction) {
return extraction.fold(function (errInfo) {
throw new Error(formatError(errInfo));
}, identity);
};
var asRawOrDie$1 = function (label, prop, obj) {
return getOrDie(asRaw(label, prop, obj));
};
var formatError = function (errInfo) {
return 'Errors: \n' + formatErrors(errInfo.errors).join('\n') + '\n\nInput object: ' + formatObj(errInfo.input);
};
var choose$1 = function (key, branches) {
return choose$2(key, map$1(branches, objOf));
};
var field$2 = field$3;
var customField = customField$1;
var required$1 = function (key) {
return field$2(key, key, required$2(), anyValue());
};
var requiredOf = function (key, schema) {
return field$2(key, key, required$2(), schema);
};
var forbid = function (key, message) {
return field$2(key, key, asOption(), value$1(function (_v) {
return SimpleResult.serror('The field: ' + key + ' is forbidden. ' + message);
}));
};
var requiredObjOf = function (key, objSchema) {
return field$2(key, key, required$2(), objOf(objSchema));
};
var option = function (key) {
return field$2(key, key, asOption(), anyValue());
};
var optionOf = function (key, schema) {
return field$2(key, key, asOption(), schema);
};
var optionObjOf = function (key, objSchema) {
return optionOf(key, objOf(objSchema));
};
var optionObjOfOnly = function (key, objSchema) {
return optionOf(key, objOfOnly(objSchema));
};
var defaulted = function (key, fallback) {
return field$2(key, key, defaulted$1(fallback), anyValue());
};
var defaultedOf = function (key, fallback, schema) {
return field$2(key, key, defaulted$1(fallback), schema);
};
var defaultedFunction = function (key, fallback) {
return defaultedOf(key, fallback, functionProcessor);
};
var defaultedObjOf = function (key, fallback, objSchema) {
return defaultedOf(key, fallback, objOf(objSchema));
};
var SwapSchema = [
required$1('alpha'),
required$1('omega')
];
var generate$5 = function (cases) {
if (!isArray(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$1(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(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$1(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$5 };
Adt.generate([
{
bothErrors: [
'error1',
'error2'
]
},
{
firstError: [
'error1',
'value2'
]
},
{
secondError: [
'value1',
'error2'
]
},
{
bothValues: [
'value1',
'value2'
]
}
]);
var partition = function (results) {
var errors = [];
var values = [];
each$1(results, function (result) {
result.fold(function (err) {
errors.push(err);
}, function (value) {
values.push(value);
});
});
return {
errors: errors,
values: values
};
};
var exclude$1 = function (obj, fields) {
var r = {};
each(obj, function (v, k) {
if (!contains$1(fields, k)) {
r[k] = v;
}
});
return r;
};
var wrap$1 = function (key, value) {
var _a;
return _a = {}, _a[key] = value, _a;
};
var wrapAll$1 = function (keyvalues) {
var r = {};
each$1(keyvalues, function (kv) {
r[kv.key] = kv.value;
});
return r;
};
var exclude = function (obj, fields) {
return exclude$1(obj, fields);
};
var wrap = function (key, value) {
return wrap$1(key, value);
};
var wrapAll = function (keyvalues) {
return wrapAll$1(keyvalues);
};
var mergeValues = function (values, base) {
return values.length === 0 ? Result.value(base) : Result.value(deepMerge(base, merge$1.apply(undefined, values)));
};
var mergeErrors = function (errors) {
return Result.error(flatten(errors));
};
var consolidate = function (objs, base) {
var partitions = partition(objs);
return partitions.errors.length > 0 ? mergeErrors(partitions.errors) : mergeValues(partitions.values, base);
};
var is = 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 sequence = function (arr) {
var r = [];
for (var i = 0; i < arr.length; i++) {
var x = arr[i];
if (x.isSome()) {
r.push(x.getOrDie());
} else {
return Optional.none();
}
}
return Optional.some(r);
};
var lift2 = function (oa, ob, f) {
return oa.isSome() && ob.isSome() ? Optional.some(f(oa.getOrDie(), ob.getOrDie())) : Optional.none();
};
var someIf = function (b, a) {
return b ? Optional.some(a) : Optional.none();
};
var ensureIsRoot = function (isRoot) {
return isFunction(isRoot) ? isRoot : never;
};
var ancestor$2 = 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$3 = function (scope, transform, isRoot) {
var current = transform(scope);
var stop = ensureIsRoot(isRoot);
return current.orThunk(function () {
return stop(scope) ? Optional.none() : ancestor$2(scope, transform, stop);
});
};
var isSource = function (component, simulatedEvent) {
return eq(component.element, simulatedEvent.event.target);
};
var defaultEventHandler = {
can: always,
abort: never,
run: noop
};
var nu$4 = function (parts) {
if (!hasNonNullableKey(parts, 'can') && !hasNonNullableKey(parts, 'abort') && !hasNonNullableKey(parts, 'run')) {
throw new Error('EventHandler defined by: ' + JSON.stringify(parts, null, 2) + ' does not have can, abort, or run!');
}
return __assign(__assign({}, defaultEventHandler), parts);
};
var all$1 = function (handlers, f) {
return function () {
var args = [];
for (var _i = 0; _i < arguments.length; _i++) {
args[_i] = arguments[_i];
}
return foldl(handlers, function (acc, handler) {
return acc && f(handler).apply(undefined, args);
}, true);
};
};
var any = function (handlers, f) {
return function () {
var args = [];
for (var _i = 0; _i < arguments.length; _i++) {
args[_i] = arguments[_i];
}
return foldl(handlers, function (acc, handler) {
return acc || f(handler).apply(undefined, args);
}, false);
};
};
var read$1 = function (handler) {
return isFunction(handler) ? {
can: always,
abort: never,
run: handler
} : handler;
};
var fuse$1 = function (handlers) {
var can = all$1(handlers, function (handler) {
return handler.can;
});
var abort = any(handlers, function (handler) {
return handler.abort;
});
var run = function () {
var args = [];
for (var _i = 0; _i < arguments.length; _i++) {
args[_i] = arguments[_i];
}
each$1(handlers, function (handler) {
handler.run.apply(undefined, args);
});
};
return {
can: can,
abort: abort,
run: run
};
};
var derive$3 = function (configs) {
return wrapAll(configs);
};
var abort = function (name, predicate) {
return {
key: name,
value: nu$4({ abort: predicate })
};
};
var can = function (name, predicate) {
return {
key: name,
value: nu$4({ can: predicate })
};
};
var run = function (name, handler) {
return {
key: name,
value: nu$4({ run: handler })
};
};
var runActionExtra = function (name, action, extra) {
return {
key: name,
value: nu$4({
run: function (component, simulatedEvent) {
action.apply(undefined, [
component,
simulatedEvent
].concat(extra));
}
})
};
};
var runOnName = function (name) {
return function (handler) {
return run(name, handler);
};
};
var runOnSourceName = function (name) {
return function (handler) {
return {
key: name,
value: nu$4({
run: function (component, simulatedEvent) {
if (isSource(component, simulatedEvent)) {
handler(component, simulatedEvent);
}
}
})
};
};
};
var redirectToUid = function (name, uid) {
return run(name, function (component, simulatedEvent) {
component.getSystem().getByUid(uid).each(function (redirectee) {
dispatchEvent(redirectee, redirectee.element, name, simulatedEvent);
});
});
};
var redirectToPart = function (name, detail, partName) {
var uid = detail.partUids[partName];
return redirectToUid(name, uid);
};
var cutter = function (name) {
return run(name, function (component, simulatedEvent) {
simulatedEvent.cut();
});
};
var stopper = function (name) {
return run(name, function (component, simulatedEvent) {
simulatedEvent.stop();
});
};
var runOnSource = function (name, f) {
return runOnSourceName(name)(f);
};
var runOnAttached = runOnSourceName(attachedToDom());
var runOnDetached = runOnSourceName(detachedFromDom());
var runOnInit = runOnSourceName(systemInit());
var runOnExecute = runOnName(execute$5());
var markAsBehaviourApi = function (f, apiName, apiFunction) {
var delegate = apiFunction.toString();
var endIndex = delegate.indexOf(')') + 1;
var openBracketIndex = delegate.indexOf('(');
var parameters = delegate.substring(openBracketIndex + 1, endIndex - 1).split(/,\s*/);
f.toFunctionAnnotation = function () {
return {
name: apiName,
parameters: cleanParameters(parameters.slice(0, 1).concat(parameters.slice(3)))
};
};
return f;
};
var cleanParameters = function (parameters) {
return map$2(parameters, function (p) {
return endsWith(p, '/*') ? p.substring(0, p.length - '/*'.length) : p;
});
};
var markAsExtraApi = function (f, extraName) {
var delegate = f.toString();
var endIndex = delegate.indexOf(')') + 1;
var openBracketIndex = delegate.indexOf('(');
var parameters = delegate.substring(openBracketIndex + 1, endIndex - 1).split(/,\s*/);
f.toFunctionAnnotation = function () {
return {
name: extraName,
parameters: cleanParameters(parameters)
};
};
return f;
};
var markAsSketchApi = function (f, apiFunction) {
var delegate = apiFunction.toString();
var endIndex = delegate.indexOf(')') + 1;
var openBracketIndex = delegate.indexOf('(');
var parameters = delegate.substring(openBracketIndex + 1, endIndex - 1).split(/,\s*/);
f.toFunctionAnnotation = function () {
return {
name: 'OVERRIDE',
parameters: cleanParameters(parameters.slice(1))
};
};
return f;
};
var nu$3 = function (s) {
return {
classes: isUndefined(s.classes) ? [] : s.classes,
attributes: isUndefined(s.attributes) ? {} : s.attributes,
styles: isUndefined(s.styles) ? {} : s.styles
};
};
var merge = function (defnA, mod) {
return __assign(__assign({}, defnA), {
attributes: __assign(__assign({}, defnA.attributes), mod.attributes),
styles: __assign(__assign({}, defnA.styles), mod.styles),
classes: defnA.classes.concat(mod.classes)
});
};
var executeEvent = function (bConfig, bState, executor) {
return runOnExecute(function (component) {
executor(component, bConfig, bState);
});
};
var loadEvent = function (bConfig, bState, f) {
return runOnInit(function (component, _simulatedEvent) {
f(component, bConfig, bState);
});
};
var create$6 = function (schema, name, active, apis, extra, state) {
var configSchema = objOfOnly(schema);
var schemaSchema = optionObjOf(name, [optionObjOfOnly('config', schema)]);
return doCreate(configSchema, schemaSchema, name, active, apis, extra, state);
};
var createModes$1 = function (modes, name, active, apis, extra, state) {
var configSchema = modes;
var schemaSchema = optionObjOf(name, [optionOf('config', modes)]);
return doCreate(configSchema, schemaSchema, name, active, apis, extra, state);
};
var wrapApi = function (bName, apiFunction, apiName) {
var f = function (component) {
var rest = [];
for (var _i = 1; _i < arguments.length; _i++) {
rest[_i - 1] = arguments[_i];
}
var args = [component].concat(rest);
return component.config({ name: constant$1(bName) }).fold(function () {
throw new Error('We could not find any behaviour configuration for: ' + bName + '. Using API: ' + apiName);
}, function (info) {
var rest = Array.prototype.slice.call(args, 1);
return apiFunction.apply(undefined, [
component,
info.config,
info.state
].concat(rest));
});
};
return markAsBehaviourApi(f, apiName, apiFunction);
};
var revokeBehaviour = function (name) {
return {
key: name,
value: undefined
};
};
var doCreate = function (configSchema, schemaSchema, name, active, apis, extra, state) {
var getConfig = function (info) {
return hasNonNullableKey(info, name) ? info[name]() : Optional.none();
};
var wrappedApis = map$1(apis, function (apiF, apiName) {
return wrapApi(name, apiF, apiName);
});
var wrappedExtra = map$1(extra, function (extraF, extraName) {
return markAsExtraApi(extraF, extraName);
});
var me = __assign(__assign(__assign({}, wrappedExtra), wrappedApis), {
revoke: curry(revokeBehaviour, name),
config: function (spec) {
var prepared = asRawOrDie$1(name + '-config', configSchema, spec);
return {
key: name,
value: {
config: prepared,
me: me,
configAsRaw: cached(function () {
return asRawOrDie$1(name + '-config', configSchema, spec);
}),
initialConfig: spec,
state: state
}
};
},
schema: constant$1(schemaSchema),
exhibit: function (info, base) {
return lift2(getConfig(info), get$c(active, 'exhibit'), function (behaviourInfo, exhibitor) {
return exhibitor(base, behaviourInfo.config, behaviourInfo.state);
}).getOrThunk(function () {
return nu$3({});
});
},
name: constant$1(name),
handlers: function (info) {
return getConfig(info).map(function (behaviourInfo) {
var getEvents = get$c(active, 'events').getOr(function () {
return {};
});
return getEvents(behaviourInfo.config, behaviourInfo.state);
}).getOr({});
}
});
return me;
};
var NoState = {
init: function () {
return nu$2({ readState: constant$1('No State required') });
}
};
var nu$2 = function (spec) {
return spec;
};
var derive$2 = function (capabilities) {
return wrapAll(capabilities);
};
var simpleSchema = objOfOnly([
required$1('fields'),
required$1('name'),
defaulted('active', {}),
defaulted('apis', {}),
defaulted('state', NoState),
defaulted('extra', {})
]);
var create$5 = function (data) {
var value = asRawOrDie$1('Creating behaviour: ' + data.name, simpleSchema, data);
return create$6(value.fields, value.name, value.active, value.apis, value.extra, value.state);
};
var modeSchema = objOfOnly([
required$1('branchKey'),
required$1('branches'),
required$1('name'),
defaulted('active', {}),
defaulted('apis', {}),
defaulted('state', NoState),
defaulted('extra', {})
]);
var createModes = function (data) {
var value = asRawOrDie$1('Creating behaviour: ' + data.name, modeSchema, data);
return createModes$1(choose$1(value.branchKey, value.branches), value.name, value.active, value.apis, value.extra, value.state);
};
var revoke = constant$1(undefined);
var Swapping = create$5({
fields: SwapSchema,
name: 'swapping',
apis: SwapApis
});
var Cell = function (initial) {
var value = initial;
var get = function () {
return value;
};
var set = function (v) {
value = v;
};
return {
get: get,
set: set
};
};
var getDocument = function () {
return SugarElement.fromDom(document);
};
var focus$3 = function (element) {
return element.dom.focus();
};
var blur$1 = function (element) {
return element.dom.blur();
};
var hasFocus = 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 global$5 = tinymce.util.Tools.resolve('tinymce.dom.DOMUtils');
var global$4 = tinymce.util.Tools.resolve('tinymce.ThemeManager');
var openLink = function (target) {
var link = document.createElement('a');
link.target = '_blank';
link.href = target.href;
link.rel = 'noreferrer noopener';
var nuEvt = document.createEvent('MouseEvents');
nuEvt.initMouseEvent('click', true, true, window, 0, 0, 0, 0, 0, false, false, false, false, 0, null);
document.body.appendChild(link);
link.dispatchEvent(nuEvt);
document.body.removeChild(link);
};
var DefaultStyleFormats = [
{
title: 'Headings',
items: [
{
title: 'Heading 1',
format: 'h1'
},
{
title: 'Heading 2',
format: 'h2'
},
{
title: 'Heading 3',
format: 'h3'
},
{
title: 'Heading 4',
format: 'h4'
},
{
title: 'Heading 5',
format: 'h5'
},
{
title: 'Heading 6',
format: 'h6'
}
]
},
{
title: 'Inline',
items: [
{
title: 'Bold',
icon: 'bold',
format: 'bold'
},
{
title: 'Italic',
icon: 'italic',
format: 'italic'
},
{
title: 'Underline',
icon: 'underline',
format: 'underline'
},
{
title: 'Strikethrough',
icon: 'strikethrough',
format: 'strikethrough'
},
{
title: 'Superscript',
icon: 'superscript',
format: 'superscript'
},
{
title: 'Subscript',
icon: 'subscript',
format: 'subscript'
},
{
title: 'Code',
icon: 'code',
format: 'code'
}
]
},
{
title: 'Blocks',
items: [
{
title: 'Paragraph',
format: 'p'
},
{
title: 'Blockquote',
format: 'blockquote'
},
{
title: 'Div',
format: 'div'
},
{
title: 'Pre',
format: 'pre'
}
]
},
{
title: 'Alignment',
items: [
{
title: 'Left',
icon: 'alignleft',
format: 'alignleft'
},
{
title: 'Center',
icon: 'aligncenter',
format: 'aligncenter'
},
{
title: 'Right',
icon: 'alignright',
format: 'alignright'
},
{
title: 'Justify',
icon: 'alignjustify',
format: 'alignjustify'
}
]
}
];
var defaults = [
'undo',
'bold',
'italic',
'link',
'image',
'bullist',
'styleselect'
];
var isSkinDisabled = function (editor) {
return editor.getParam('skin') === false;
};
var readOnlyOnInit = function (_editor) {
return false;
};
var getToolbar = function (editor) {
return editor.getParam('toolbar', defaults, 'array');
};
var getStyleFormats = function (editor) {
return editor.getParam('style_formats', DefaultStyleFormats, 'array');
};
var getSkinUrl = function (editor) {
return editor.getParam('skin_url');
};
var formatChanged = 'formatChanged';
var orientationChanged = 'orientationChanged';
var dropupDismissed = 'dropupDismissed';
var fromHtml$1 = function (html, scope) {
var doc = scope || document;
var div = doc.createElement('div');
div.innerHTML = html;
return children(SugarElement.fromDom(div));
};
var get$9 = function (element) {
return element.dom.innerHTML;
};
var set$7 = function (element, content) {
var owner = owner$2(element);
var docDom = owner.dom;
var fragment = SugarElement.fromDom(docDom.createDocumentFragment());
var contentElements = fromHtml$1(content, docDom);
append$1(fragment, contentElements);
empty(element);
append$2(element, fragment);
};
var getOuter = function (element) {
var container = SugarElement.fromTag('div');
var clone = SugarElement.fromDom(element.dom.cloneNode(true));
append$2(container, clone);
return get$9(container);
};
var clone = function (original, isDeep) {
return SugarElement.fromDom(original.dom.cloneNode(isDeep));
};
var shallow = function (original) {
return clone(original, false);
};
var getHtml = function (element) {
if (isShadowRoot(element)) {
return '#shadow-root';
} else {
var clone = shallow(element);
return getOuter(clone);
}
};
var element = function (elem) {
return getHtml(elem);
};
var chooseChannels = function (channels, message) {
return message.universal ? channels : filter$2(channels, function (ch) {
return contains$1(message.channels, ch);
});
};
var events$a = function (receiveConfig) {
return derive$3([run(receive$1(), function (component, message) {
var channelMap = receiveConfig.channels;
var channels = keys(channelMap);
var receivingData = message;
var targetChannels = chooseChannels(channels, receivingData);
each$1(targetChannels, function (ch) {
var channelInfo = channelMap[ch];
var channelSchema = channelInfo.schema;
var data = asRawOrDie$1('channel[' + ch + '] data\nReceiver: ' + element(component.element), channelSchema, receivingData.data);
channelInfo.onReceive(component, data);
});
})]);
};
var ActiveReceiving = /*#__PURE__*/Object.freeze({
__proto__: null,
events: events$a
});
var unknown = 'unknown';
var EventConfiguration;
(function (EventConfiguration) {
EventConfiguration[EventConfiguration['STOP'] = 0] = 'STOP';
EventConfiguration[EventConfiguration['NORMAL'] = 1] = 'NORMAL';
EventConfiguration[EventConfiguration['LOGGING'] = 2] = 'LOGGING';
}(EventConfiguration || (EventConfiguration = {})));
var eventConfig = Cell({});
var makeEventLogger = function (eventName, initialTarget) {
var sequence = [];
var startTime = new Date().getTime();
return {
logEventCut: function (_name, target, purpose) {
sequence.push({
outcome: 'cut',
target: target,
purpose: purpose
});
},
logEventStopped: function (_name, target, purpose) {
sequence.push({
outcome: 'stopped',
target: target,
purpose: purpose
});
},
logNoParent: function (_name, target, purpose) {
sequence.push({
outcome: 'no-parent',
target: target,
purpose: purpose
});
},
logEventNoHandlers: function (_name, target) {
sequence.push({
outcome: 'no-handlers-left',
target: target
});
},
logEventResponse: function (_name, target, purpose) {
sequence.push({
outcome: 'response',
purpose: purpose,
target: target
});
},
write: function () {
var finishTime = new Date().getTime();
if (contains$1([
'mousemove',
'mouseover',
'mouseout',
systemInit()
], eventName)) {
return;
}
console.log(eventName, {
event: eventName,
time: finishTime - startTime,
target: initialTarget.dom,
sequence: map$2(sequence, function (s) {
if (!contains$1([
'cut',
'stopped',
'response'
], s.outcome)) {
return s.outcome;
} else {
return '{' + s.purpose + '} ' + s.outcome + ' at (' + element(s.target) + ')';
}
})
});
}
};
};
var processEvent = function (eventName, initialTarget, f) {
var status = get$c(eventConfig.get(), eventName).orThunk(function () {
var patterns = keys(eventConfig.get());
return findMap(patterns, function (p) {
return eventName.indexOf(p) > -1 ? Optional.some(eventConfig.get()[p]) : Optional.none();
});
}).getOr(EventConfiguration.NORMAL);
switch (status) {
case EventConfiguration.NORMAL:
return f(noLogger());
case EventConfiguration.LOGGING: {
var logger = makeEventLogger(eventName, initialTarget);
var output = f(logger);
logger.write();
return output;
}
case EventConfiguration.STOP:
return true;
}
};
var path = [
'alloy/data/Fields',
'alloy/debugging/Debugging'
];
var getTrace = function () {
var err = new Error();
if (err.stack !== undefined) {
var lines = err.stack.split('\n');
return find$2(lines, function (line) {
return line.indexOf('alloy') > 0 && !exists(path, function (p) {
return line.indexOf(p) > -1;
});
}).getOr(unknown);
} else {
return unknown;
}
};
var ignoreEvent = {
logEventCut: noop,
logEventStopped: noop,
logNoParent: noop,
logEventNoHandlers: noop,
logEventResponse: noop,
write: noop
};
var monitorEvent = function (eventName, initialTarget, f) {
return processEvent(eventName, initialTarget, f);
};
var noLogger = constant$1(ignoreEvent);
var menuFields = constant$1([
required$1('menu'),
required$1('selectedMenu')
]);
var itemFields = constant$1([
required$1('item'),
required$1('selectedItem')
]);
constant$1(objOf(itemFields().concat(menuFields())));
var itemSchema$1 = constant$1(objOf(itemFields()));
var _initSize = requiredObjOf('initSize', [
required$1('numColumns'),
required$1('numRows')
]);
var itemMarkers = function () {
return requiredOf('markers', itemSchema$1());
};
var tieredMenuMarkers = function () {
return requiredObjOf('markers', [required$1('backgroundMenu')].concat(menuFields()).concat(itemFields()));
};
var markers = function (required) {
return requiredObjOf('markers', map$2(required, required$1));
};
var onPresenceHandler = function (label, fieldName, presence) {
getTrace();
return field$2(fieldName, fieldName, presence, valueOf(function (f) {
return Result.value(function () {
var args = [];
for (var _i = 0; _i < arguments.length; _i++) {
args[_i] = arguments[_i];
}
return f.apply(undefined, args);
});
}));
};
var onHandler = function (fieldName) {
return onPresenceHandler('onHandler', fieldName, defaulted$1(noop));
};
var onKeyboardHandler = function (fieldName) {
return onPresenceHandler('onKeyboardHandler', fieldName, defaulted$1(Optional.none));
};
var onStrictHandler = function (fieldName) {
return onPresenceHandler('onHandler', fieldName, required$2());
};
var onStrictKeyboardHandler = function (fieldName) {
return onPresenceHandler('onKeyboardHandler', fieldName, required$2());
};
var output = function (name, value) {
return customField(name, constant$1(value));
};
var snapshot = function (name) {
return customField(name, identity);
};
var initSize = constant$1(_initSize);
var ReceivingSchema = [requiredOf('channels', setOf(Result.value, objOfOnly([
onStrictHandler('onReceive'),
defaulted('schema', anyValue())
])))];
var Receiving = create$5({
fields: ReceivingSchema,
name: 'receiving',
active: ActiveReceiving
});
var SetupBehaviourCellState = function (initialState) {
var init = function () {
var cell = Cell(initialState);
var get = function () {
return cell.get();
};
var set = function (newState) {
return cell.set(newState);
};
var clear = function () {
return cell.set(initialState);
};
var readState = function () {
return cell.get();
};
return {
get: get,
set: set,
clear: clear,
readState: readState
};
};
return { init: init };
};
var updateAriaState = function (component, toggleConfig, toggleState) {
var ariaInfo = toggleConfig.aria;
ariaInfo.update(component, ariaInfo, toggleState.get());
};
var updateClass = function (component, toggleConfig, toggleState) {
toggleConfig.toggleClass.each(function (toggleClass) {
if (toggleState.get()) {
add$1(component.element, toggleClass);
} else {
remove$3(component.element, toggleClass);
}
});
};
var toggle = function (component, toggleConfig, toggleState) {
set$6(component, toggleConfig, toggleState, !toggleState.get());
};
var on$1 = function (component, toggleConfig, toggleState) {
toggleState.set(true);
updateClass(component, toggleConfig, toggleState);
updateAriaState(component, toggleConfig, toggleState);
};
var off = function (component, toggleConfig, toggleState) {
toggleState.set(false);
updateClass(component, toggleConfig, toggleState);
updateAriaState(component, toggleConfig, toggleState);
};
var set$6 = function (component, toggleConfig, toggleState, state) {
var action = state ? on$1 : off;
action(component, toggleConfig, toggleState);
};
var isOn = function (component, toggleConfig, toggleState) {
return toggleState.get();
};
var onLoad$5 = function (component, toggleConfig, toggleState) {
set$6(component, toggleConfig, toggleState, toggleConfig.selected);
};
var ToggleApis = /*#__PURE__*/Object.freeze({
__proto__: null,
onLoad: onLoad$5,
toggle: toggle,
isOn: isOn,
on: on$1,
off: off,
set: set$6
});
var exhibit$5 = function () {
return nu$3({});
};
var events$9 = function (toggleConfig, toggleState) {
var execute = executeEvent(toggleConfig, toggleState, toggle);
var load = loadEvent(toggleConfig, toggleState, onLoad$5);
return derive$3(flatten([
toggleConfig.toggleOnExecute ? [execute] : [],
[load]
]));
};
var ActiveToggle = /*#__PURE__*/Object.freeze({
__proto__: null,
exhibit: exhibit$5,
events: events$9
});
var updatePressed = function (component, ariaInfo, status) {
set$8(component.element, 'aria-pressed', status);
if (ariaInfo.syncWithExpanded) {
updateExpanded(component, ariaInfo, status);
}
};
var updateSelected = function (component, ariaInfo, status) {
set$8(component.element, 'aria-selected', status);
};
var updateChecked = function (component, ariaInfo, status) {
set$8(component.element, 'aria-checked', status);
};
var updateExpanded = function (component, ariaInfo, status) {
set$8(component.element, 'aria-expanded', status);
};
var ToggleSchema = [
defaulted('selected', false),
option('toggleClass'),
defaulted('toggleOnExecute', true),
defaultedOf('aria', { mode: 'none' }, choose$1('mode', {
pressed: [
defaulted('syncWithExpanded', false),
output('update', updatePressed)
],
checked: [output('update', updateChecked)],
expanded: [output('update', updateExpanded)],
selected: [output('update', updateSelected)],
none: [output('update', noop)]
}))
];
var Toggling = create$5({
fields: ToggleSchema,
name: 'toggling',
active: ActiveToggle,
apis: ToggleApis,
state: SetupBehaviourCellState(false)
});
var format = function (command, update) {
return Receiving.config({
channels: wrap(formatChanged, {
onReceive: function (button, data) {
if (data.command === command) {
update(button, data.state);
}
}
})
});
};
var orientation = function (onReceive) {
return Receiving.config({ channels: wrap(orientationChanged, { onReceive: onReceive }) });
};
var receive = function (channel, onReceive) {
return {
key: channel,
value: { onReceive: onReceive }
};
};
var prefix$2 = 'tinymce-mobile';
var resolve = function (p) {
return prefix$2 + '-' + p;
};
var pointerEvents = function () {
var onClick = function (component, simulatedEvent) {
simulatedEvent.stop();
emitExecute(component);
};
return [
run(click(), onClick),
run(tap(), onClick),
cutter(touchstart()),
cutter(mousedown())
];
};
var events$8 = function (optAction) {
var executeHandler = function (action) {
return runOnExecute(function (component, simulatedEvent) {
action(component);
simulatedEvent.stop();
});
};
return derive$3(flatten([
optAction.map(executeHandler).toArray(),
pointerEvents()
]));
};
var focus$2 = function (component, focusConfig) {
if (!focusConfig.ignore) {
focus$3(component.element);
focusConfig.onFocus(component);
}
};
var blur = function (component, focusConfig) {
if (!focusConfig.ignore) {
blur$1(component.element);
}
};
var isFocused = function (component) {
return hasFocus(component.element);
};
var FocusApis = /*#__PURE__*/Object.freeze({
__proto__: null,
focus: focus$2,
blur: blur,
isFocused: isFocused
});
var exhibit$4 = function (base, focusConfig) {
var mod = focusConfig.ignore ? {} : { attributes: { tabindex: '-1' } };
return nu$3(mod);
};
var events$7 = function (focusConfig) {
return derive$3([run(focus$4(), function (component, simulatedEvent) {
focus$2(component, focusConfig);
simulatedEvent.stop();
})].concat(focusConfig.stopMousedown ? [run(mousedown(), function (_, simulatedEvent) {
simulatedEvent.event.prevent();
})] : []));
};
var ActiveFocus = /*#__PURE__*/Object.freeze({
__proto__: null,
exhibit: exhibit$4,
events: events$7
});
var FocusSchema = [
onHandler('onFocus'),
defaulted('stopMousedown', false),
defaulted('ignore', false)
];
var Focusing = create$5({
fields: FocusSchema,
name: 'focusing',
active: ActiveFocus,
apis: FocusApis
});
var isSupported = function (dom) {
return dom.style !== undefined && isFunction(dom.style.getPropertyValue);
};
var internalSet = function (dom, property, value) {
if (!isString(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 internalRemove = function (dom, property) {
if (isSupported(dom)) {
dom.style.removeProperty(property);
}
};
var set$5 = function (element, property, value) {
var dom = element.dom;
internalSet(dom, property, value);
};
var setAll = function (element, css) {
var dom = element.dom;
each(css, function (v, k) {
internalSet(dom, k, v);
});
};
var get$8 = 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 remove$2 = function (element, property) {
var dom = element.dom;
internalRemove(dom, property);
if (is(getOpt(element, 'style').map(trim), '')) {
remove$6(element, 'style');
}
};
var reflow = function (e) {
return e.dom.offsetWidth;
};
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$8(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$8(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$3 = Dimension('height', function (element) {
var dom = element.dom;
return inBody(element) ? dom.getBoundingClientRect().height : dom.offsetHeight;
});
var get$7 = function (element) {
return api$3.get(element);
};
var ancestors$1 = function (scope, predicate, isRoot) {
return filter$2(parents(scope, isRoot), predicate);
};
var siblings$1 = function (scope, predicate) {
return filter$2(siblings$2(scope), predicate);
};
var all = function (selector) {
return all$2(selector);
};
var ancestors = function (scope, selector, isRoot) {
return ancestors$1(scope, function (e) {
return is$1(e, selector);
}, isRoot);
};
var siblings = function (scope, selector) {
return siblings$1(scope, function (e) {
return is$1(e, selector);
});
};
var descendants = function (scope, selector) {
return all$2(selector, scope);
};
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$1 = 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$2 = function (scope, predicate, isRoot) {
var is = function (s, test) {
return test(s);
};
return ClosestOrAncestor(is, ancestor$1, scope, predicate, isRoot);
};
var descendant$1 = function (scope, predicate) {
var descend = function (node) {
for (var i = 0; i < node.childNodes.length; i++) {
var child_1 = SugarElement.fromDom(node.childNodes[i]);
if (predicate(child_1)) {
return Optional.some(child_1);
}
var res = descend(node.childNodes[i]);
if (res.isSome()) {
return res;
}
}
return Optional.none();
};
return descend(scope.dom);
};
var first$1 = function (selector) {
return one(selector);
};
var ancestor = function (scope, selector, isRoot) {
return ancestor$1(scope, function (e) {
return is$1(e, selector);
}, isRoot);
};
var descendant = function (scope, selector) {
return one(selector, scope);
};
var closest$1 = function (scope, selector, isRoot) {
var is = function (element, selector) {
return is$1(element, selector);
};
return ClosestOrAncestor(is, ancestor, scope, selector, isRoot);
};
var BACKSPACE = [8];
var TAB = [9];
var ENTER = [13];
var ESCAPE = [27];
var SPACE = [32];
var LEFT = [37];
var UP = [38];
var RIGHT = [39];
var DOWN = [40];
var cyclePrev = function (values, index, predicate) {
var before = reverse(values.slice(0, index));
var after = reverse(values.slice(index + 1));
return find$2(before.concat(after), predicate);
};
var tryPrev = function (values, index, predicate) {
var before = reverse(values.slice(0, index));
return find$2(before, predicate);
};
var cycleNext = function (values, index, predicate) {
var before = values.slice(0, index);
var after = values.slice(index + 1);
return find$2(after.concat(before), predicate);
};
var tryNext = function (values, index, predicate) {
var after = values.slice(index + 1);
return find$2(after, predicate);
};
var inSet = function (keys) {
return function (event) {
var raw = event.raw;
return contains$1(keys, raw.which);
};
};
var and = function (preds) {
return function (event) {
return forall(preds, function (pred) {
return pred(event);
});
};
};
var isShift = function (event) {
var raw = event.raw;
return raw.shiftKey === true;
};
var isControl = function (event) {
var raw = event.raw;
return raw.ctrlKey === true;
};
var isNotShift = not(isShift);
var rule = function (matches, action) {
return {
matches: matches,
classification: action
};
};
var choose = function (transitions, event) {
var transition = find$2(transitions, function (t) {
return t.matches(event);
});
return transition.map(function (t) {
return t.classification;
});
};
var cycleBy = function (value, delta, min, max) {
var r = value + delta;
if (r > max) {
return min;
} else if (r < min) {
return max;
} else {
return r;
}
};
var clamp = function (value, min, max) {
return Math.min(Math.max(value, min), max);
};
var dehighlightAllExcept = function (component, hConfig, hState, skip) {
var highlighted = descendants(component.element, '.' + hConfig.highlightClass);
each$1(highlighted, function (h) {
if (!exists(skip, function (skipComp) {
return skipComp.element === h;
})) {
remove$3(h, hConfig.highlightClass);
component.getSystem().getByDom(h).each(function (target) {
hConfig.onDehighlight(component, target);
emit(target, dehighlight$1());
});
}
});
};
var dehighlightAll = function (component, hConfig, hState) {
return dehighlightAllExcept(component, hConfig, hState, []);
};
var dehighlight = function (component, hConfig, hState, target) {
if (isHighlighted(component, hConfig, hState, target)) {
remove$3(target.element, hConfig.highlightClass);
hConfig.onDehighlight(component, target);
emit(target, dehighlight$1());
}
};
var highlight = function (component, hConfig, hState, target) {
dehighlightAllExcept(component, hConfig, hState, [target]);
if (!isHighlighted(component, hConfig, hState, target)) {
add$1(target.element, hConfig.highlightClass);
hConfig.onHighlight(component, target);
emit(target, highlight$1());
}
};
var highlightFirst = function (component, hConfig, hState) {
getFirst(component, hConfig).each(function (firstComp) {
highlight(component, hConfig, hState, firstComp);
});
};
var highlightLast = function (component, hConfig, hState) {
getLast(component, hConfig).each(function (lastComp) {
highlight(component, hConfig, hState, lastComp);
});
};
var highlightAt = function (component, hConfig, hState, index) {
getByIndex(component, hConfig, hState, index).fold(function (err) {
throw err;
}, function (firstComp) {
highlight(component, hConfig, hState, firstComp);
});
};
var highlightBy = function (component, hConfig, hState, predicate) {
var candidates = getCandidates(component, hConfig);
var targetComp = find$2(candidates, predicate);
targetComp.each(function (c) {
highlight(component, hConfig, hState, c);
});
};
var isHighlighted = function (component, hConfig, hState, queryTarget) {
return has(queryTarget.element, hConfig.highlightClass);
};
var getHighlighted = function (component, hConfig, _hState) {
return descendant(component.element, '.' + hConfig.highlightClass).bind(function (e) {
return component.getSystem().getByDom(e).toOptional();
});
};
var getByIndex = function (component, hConfig, hState, index) {
var items = descendants(component.element, '.' + hConfig.itemClass);
return Optional.from(items[index]).fold(function () {
return Result.error(new Error('No element found with index ' + index));
}, component.getSystem().getByDom);
};
var getFirst = function (component, hConfig, _hState) {
return descendant(component.element, '.' + hConfig.itemClass).bind(function (e) {
return component.getSystem().getByDom(e).toOptional();
});
};
var getLast = function (component, hConfig, _hState) {
var items = descendants(component.element, '.' + hConfig.itemClass);
var last = items.length > 0 ? Optional.some(items[items.length - 1]) : Optional.none();
return last.bind(function (c) {
return component.getSystem().getByDom(c).toOptional();
});
};
var getDelta = function (component, hConfig, hState, delta) {
var items = descendants(component.element, '.' + hConfig.itemClass);
var current = findIndex$1(items, function (item) {
return has(item, hConfig.highlightClass);
});
return current.bind(function (selected) {
var dest = cycleBy(selected, delta, 0, items.length - 1);
return component.getSystem().getByDom(items[dest]).toOptional();
});
};
var getPrevious = function (component, hConfig, hState) {
return getDelta(component, hConfig, hState, -1);
};
var getNext = function (component, hConfig, hState) {
return getDelta(component, hConfig, hState, +1);
};
var getCandidates = function (component, hConfig, _hState) {
var items = descendants(component.element, '.' + hConfig.itemClass);
return cat(map$2(items, function (i) {
return component.getSystem().getByDom(i).toOptional();
}));
};
var HighlightApis = /*#__PURE__*/Object.freeze({
__proto__: null,
dehighlightAll: dehighlightAll,
dehighlight: dehighlight,
highlight: highlight,
highlightFirst: highlightFirst,
highlightLast: highlightLast,
highlightAt: highlightAt,
highlightBy: highlightBy,
isHighlighted: isHighlighted,
getHighlighted: getHighlighted,
getFirst: getFirst,
getLast: getLast,
getPrevious: getPrevious,
getNext: getNext,
getCandidates: getCandidates
});
var HighlightSchema = [
required$1('highlightClass'),
required$1('itemClass'),
onHandler('onHighlight'),
onHandler('onDehighlight')
];
var Highlighting = create$5({
fields: HighlightSchema,
name: 'highlighting',
apis: HighlightApis
});
var reportFocusShifting = function (component, prevFocus, newFocus) {
var noChange = prevFocus.exists(function (p) {
return newFocus.exists(function (n) {
return eq(n, p);
});
});
if (!noChange) {
emitWith(component, focusShifted(), {
prevFocus: prevFocus,
newFocus: newFocus
});
}
};
var dom$2 = function () {
var get = function (component) {
return search(component.element);
};
var set = function (component, focusee) {
var prevFocus = get(component);
component.getSystem().triggerFocus(focusee, component.element);
var newFocus = get(component);
reportFocusShifting(component, prevFocus, newFocus);
};
return {
get: get,
set: set
};
};
var highlights = function () {
var get = function (component) {
return Highlighting.getHighlighted(component).map(function (item) {
return item.element;
});
};
var set = function (component, element) {
var prevFocus = get(component);
component.getSystem().getByDom(element).fold(noop, function (item) {
Highlighting.highlight(component, item);
});
var newFocus = get(component);
reportFocusShifting(component, prevFocus, newFocus);
};
return {
get: get,
set: set
};
};
var FocusInsideModes;
(function (FocusInsideModes) {
FocusInsideModes['OnFocusMode'] = 'onFocus';
FocusInsideModes['OnEnterOrSpaceMode'] = 'onEnterOrSpace';
FocusInsideModes['OnApiMode'] = 'onApi';
}(FocusInsideModes || (FocusInsideModes = {})));
var typical = function (infoSchema, stateInit, getKeydownRules, getKeyupRules, optFocusIn) {
var schema = function () {
return infoSchema.concat([
defaulted('focusManager', dom$2()),
defaultedOf('focusInside', 'onFocus', valueOf(function (val) {
return contains$1([
'onFocus',
'onEnterOrSpace',
'onApi'
], val) ? Result.value(val) : Result.error('Invalid value for focusInside');
})),
output('handler', me),
output('state', stateInit),
output('sendFocusIn', optFocusIn)
]);
};
var processKey = function (component, simulatedEvent, getRules, keyingConfig, keyingState) {
var rules = getRules(component, simulatedEvent, keyingConfig, keyingState);
return choose(rules, simulatedEvent.event).bind(function (rule) {
return rule(component, simulatedEvent, keyingConfig, keyingState);
});
};
var toEvents = function (keyingConfig, keyingState) {
var onFocusHandler = keyingConfig.focusInside !== FocusInsideModes.OnFocusMode ? Optional.none() : optFocusIn(keyingConfig).map(function (focusIn) {
return run(focus$4(), function (component, simulatedEvent) {
focusIn(component, keyingConfig, keyingState);
simulatedEvent.stop();
});
});
var tryGoInsideComponent = function (component, simulatedEvent) {
var isEnterOrSpace = inSet(SPACE.concat(ENTER))(simulatedEvent.event);
if (keyingConfig.focusInside === FocusInsideModes.OnEnterOrSpaceMode && isEnterOrSpace && isSource(component, simulatedEvent)) {
optFocusIn(keyingConfig).each(function (focusIn) {
focusIn(component, keyingConfig, keyingState);
simulatedEvent.stop();
});
}
};
var keyboardEvents = [
run(keydown(), function (component, simulatedEvent) {
processKey(component, simulatedEvent, getKeydownRules, keyingConfig, keyingState).fold(function () {
tryGoInsideComponent(component, simulatedEvent);
}, function (_) {
simulatedEvent.stop();
});
}),
run(keyup(), function (component, simulatedEvent) {
processKey(component, simulatedEvent, getKeyupRules, keyingConfig, keyingState).each(function (_) {
simulatedEvent.stop();
});
})
];
return derive$3(onFocusHandler.toArray().concat(keyboardEvents));
};
var me = {
schema: schema,
processKey: processKey,
toEvents: toEvents
};
return me;
};
var create$4 = function (cyclicField) {
var schema = [
option('onEscape'),
option('onEnter'),
defaulted('selector', '[data-alloy-tabstop="true"]:not(:disabled)'),
defaulted('firstTabstop', 0),
defaulted('useTabstopAt', always),
option('visibilitySelector')
].concat([cyclicField]);
var isVisible = function (tabbingConfig, element) {
var target = tabbingConfig.visibilitySelector.bind(function (sel) {
return closest$1(element, sel);
}).getOr(element);
return get$7(target) > 0;
};
var findInitial = function (component, tabbingConfig) {
var tabstops = descendants(component.element, tabbingConfig.selector);
var visibles = filter$2(tabstops, function (elem) {
return isVisible(tabbingConfig, elem);
});
return Optional.from(visibles[tabbingConfig.firstTabstop]);
};
var findCurrent = function (component, tabbingConfig) {
return tabbingConfig.focusManager.get(component).bind(function (elem) {
return closest$1(elem, tabbingConfig.selector);
});
};
var isTabstop = function (tabbingConfig, element) {
return isVisible(tabbingConfig, element) && tabbingConfig.useTabstopAt(element);
};
var focusIn = function (component, tabbingConfig, _tabbingState) {
findInitial(component, tabbingConfig).each(function (target) {
tabbingConfig.focusManager.set(component, target);
});
};
var goFromTabstop = function (component, tabstops, stopIndex, tabbingConfig, cycle) {
return cycle(tabstops, stopIndex, function (elem) {
return isTabstop(tabbingConfig, elem);
}).fold(function () {
return tabbingConfig.cyclic ? Optional.some(true) : Optional.none();
}, function (target) {
tabbingConfig.focusManager.set(component, target);
return Optional.some(true);
});
};
var go = function (component, _simulatedEvent, tabbingConfig, cycle) {
var tabstops = descendants(component.element, tabbingConfig.selector);
return findCurrent(component, tabbingConfig).bind(function (tabstop) {
var optStopIndex = findIndex$1(tabstops, curry(eq, tabstop));
return optStopIndex.bind(function (stopIndex) {
return goFromTabstop(component, tabstops, stopIndex, tabbingConfig, cycle);
});
});
};
var goBackwards = function (component, simulatedEvent, tabbingConfig) {
var navigate = tabbingConfig.cyclic ? cyclePrev : tryPrev;
return go(component, simulatedEvent, tabbingConfig, navigate);
};
var goForwards = function (component, simulatedEvent, tabbingConfig) {
var navigate = tabbingConfig.cyclic ? cycleNext : tryNext;
return go(component, simulatedEvent, tabbingConfig, navigate);
};
var execute = function (component, simulatedEvent, tabbingConfig) {
return tabbingConfig.onEnter.bind(function (f) {
return f(component, simulatedEvent);
});
};
var exit = function (component, simulatedEvent, tabbingConfig) {
return tabbingConfig.onEscape.bind(function (f) {
return f(component, simulatedEvent);
});
};
var getKeydownRules = constant$1([
rule(and([
isShift,
inSet(TAB)
]), goBackwards),
rule(inSet(TAB), goForwards),
rule(inSet(ESCAPE), exit),
rule(and([
isNotShift,
inSet(ENTER)
]), execute)
]);
var getKeyupRules = constant$1([]);
return typical(schema, NoState.init, getKeydownRules, getKeyupRules, function () {
return Optional.some(focusIn);
});
};
var AcyclicType = create$4(customField('cyclic', never));
var CyclicType = create$4(customField('cyclic', always));
var inside = function (target) {
return name$1(target) === 'input' && get$b(target, 'type') !== 'radio' || name$1(target) === 'textarea';
};
var doDefaultExecute = function (component, _simulatedEvent, focused) {
dispatch(component, focused, execute$5());
return Optional.some(true);
};
var defaultExecute = function (component, simulatedEvent, focused) {
var isComplex = inside(focused) && inSet(SPACE)(simulatedEvent.event);
return isComplex ? Optional.none() : doDefaultExecute(component, simulatedEvent, focused);
};
var stopEventForFirefox = function (_component, _simulatedEvent) {
return Optional.some(true);
};
var schema$f = [
defaulted('execute', defaultExecute),
defaulted('useSpace', false),
defaulted('useEnter', true),
defaulted('useControlEnter', false),
defaulted('useDown', false)
];
var execute$4 = function (component, simulatedEvent, executeConfig) {
return executeConfig.execute(component, simulatedEvent, component.element);
};
var getKeydownRules$5 = function (component, _simulatedEvent, executeConfig, _executeState) {
var spaceExec = executeConfig.useSpace && !inside(component.element) ? SPACE : [];
var enterExec = executeConfig.useEnter ? ENTER : [];
var downExec = executeConfig.useDown ? DOWN : [];
var execKeys = spaceExec.concat(enterExec).concat(downExec);
return [rule(inSet(execKeys), execute$4)].concat(executeConfig.useControlEnter ? [rule(and([
isControl,
inSet(ENTER)
]), execute$4)] : []);
};
var getKeyupRules$5 = function (component, _simulatedEvent, executeConfig, _executeState) {
return executeConfig.useSpace && !inside(component.element) ? [rule(inSet(SPACE), stopEventForFirefox)] : [];
};
var ExecutionType = typical(schema$f, NoState.init, getKeydownRules$5, getKeyupRules$5, function () {
return Optional.none();
});
var singleton$1 = 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 destroyable = function () {
return singleton$1(function (s) {
return s.destroy();
});
};
var api$2 = function () {
var subject = destroyable();
var run = function (f) {
return subject.get().each(f);
};
return __assign(__assign({}, subject), { run: run });
};
var value = function () {
var subject = singleton$1(noop);
var on = function (f) {
return subject.get().each(f);
};
return __assign(__assign({}, subject), { on: on });
};
var flatgrid$1 = function () {
var dimensions = value();
var setGridSize = function (numRows, numColumns) {
dimensions.set({
numRows: numRows,
numColumns: numColumns
});
};
var getNumRows = function () {
return dimensions.get().map(function (d) {
return d.numRows;
});
};
var getNumColumns = function () {
return dimensions.get().map(function (d) {
return d.numColumns;
});
};
return nu$2({
readState: function () {
return dimensions.get().map(function (d) {
return {
numRows: String(d.numRows),
numColumns: String(d.numColumns)
};
}).getOr({
numRows: '?',
numColumns: '?'
});
},
setGridSize: setGridSize,
getNumRows: getNumRows,
getNumColumns: getNumColumns
});
};
var init$5 = function (spec) {
return spec.state(spec);
};
var KeyingState = /*#__PURE__*/Object.freeze({
__proto__: null,
flatgrid: flatgrid$1,
init: init$5
});
var onDirection = function (isLtr, isRtl) {
return function (element) {
return getDirection(element) === 'rtl' ? isRtl : isLtr;
};
};
var getDirection = function (element) {
return get$8(element, 'direction') === 'rtl' ? 'rtl' : 'ltr';
};
var useH = function (movement) {
return function (component, simulatedEvent, config, state) {
var move = movement(component.element);
return use(move, component, simulatedEvent, config, state);
};
};
var west = function (moveLeft, moveRight) {
var movement = onDirection(moveLeft, moveRight);
return useH(movement);
};
var east = function (moveLeft, moveRight) {
var movement = onDirection(moveRight, moveLeft);
return useH(movement);
};
var useV = function (move) {
return function (component, simulatedEvent, config, state) {
return use(move, component, simulatedEvent, config, state);
};
};
var use = function (move, component, simulatedEvent, config, state) {
var outcome = config.focusManager.get(component).bind(function (focused) {
return move(component.element, focused, config, state);
});
return outcome.map(function (newFocus) {
config.focusManager.set(component, newFocus);
return true;
});
};
var north = useV;
var south = useV;
var move$1 = useV;
var isHidden = function (dom) {
return dom.offsetWidth <= 0 && dom.offsetHeight <= 0;
};
var isVisible = function (element) {
return !isHidden(element.dom);
};
var locate = function (candidates, predicate) {
return findIndex$1(candidates, predicate).map(function (index) {
return {
index: index,
candidates: candidates
};
});
};
var locateVisible = function (container, current, selector) {
var predicate = function (x) {
return eq(x, current);
};
var candidates = descendants(container, selector);
var visible = filter$2(candidates, isVisible);
return locate(visible, predicate);
};
var findIndex = function (elements, target) {
return findIndex$1(elements, function (elem) {
return eq(target, elem);
});
};
var withGrid = function (values, index, numCols, f) {
var oldRow = Math.floor(index / numCols);
var oldColumn = index % numCols;
return f(oldRow, oldColumn).bind(function (address) {
var newIndex = address.row * numCols + address.column;
return newIndex >= 0 && newIndex < values.length ? Optional.some(values[newIndex]) : Optional.none();
});
};
var cycleHorizontal$1 = function (values, index, numRows, numCols, delta) {
return withGrid(values, index, numCols, function (oldRow, oldColumn) {
var onLastRow = oldRow === numRows - 1;
var colsInRow = onLastRow ? values.length - oldRow * numCols : numCols;
var newColumn = cycleBy(oldColumn, delta, 0, colsInRow - 1);
return Optional.some({
row: oldRow,
column: newColumn
});
});
};
var cycleVertical$1 = function (values, index, numRows, numCols, delta) {
return withGrid(values, index, numCols, function (oldRow, oldColumn) {
var newRow = cycleBy(oldRow, delta, 0, numRows - 1);
var onLastRow = newRow === numRows - 1;
var colsInRow = onLastRow ? values.length - newRow * numCols : numCols;
var newCol = clamp(oldColumn, 0, colsInRow - 1);
return Optional.some({
row: newRow,
column: newCol
});
});
};
var cycleRight$1 = function (values, index, numRows, numCols) {
return cycleHorizontal$1(values, index, numRows, numCols, +1);
};
var cycleLeft$1 = function (values, index, numRows, numCols) {
return cycleHorizontal$1(values, index, numRows, numCols, -1);
};
var cycleUp$1 = function (values, index, numRows, numCols) {
return cycleVertical$1(values, index, numRows, numCols, -1);
};
var cycleDown$1 = function (values, index, numRows, numCols) {
return cycleVertical$1(values, index, numRows, numCols, +1);
};
var schema$e = [
required$1('selector'),
defaulted('execute', defaultExecute),
onKeyboardHandler('onEscape'),
defaulted('captureTab', false),
initSize()
];
var focusIn$3 = function (component, gridConfig, _gridState) {
descendant(component.element, gridConfig.selector).each(function (first) {
gridConfig.focusManager.set(component, first);
});
};
var findCurrent$1 = function (component, gridConfig) {
return gridConfig.focusManager.get(component).bind(function (elem) {
return closest$1(elem, gridConfig.selector);
});
};
var execute$3 = function (component, simulatedEvent, gridConfig, _gridState) {
return findCurrent$1(component, gridConfig).bind(function (focused) {
return gridConfig.execute(component, simulatedEvent, focused);
});
};
var doMove$2 = function (cycle) {
return function (element, focused, gridConfig, gridState) {
return locateVisible(element, focused, gridConfig.selector).bind(function (identified) {
return cycle(identified.candidates, identified.index, gridState.getNumRows().getOr(gridConfig.initSize.numRows), gridState.getNumColumns().getOr(gridConfig.initSize.numColumns));
});
};
};
var handleTab = function (_component, _simulatedEvent, gridConfig) {
return gridConfig.captureTab ? Optional.some(true) : Optional.none();
};
var doEscape$1 = function (component, simulatedEvent, gridConfig) {
return gridConfig.onEscape(component, simulatedEvent);
};
var moveLeft$3 = doMove$2(cycleLeft$1);
var moveRight$3 = doMove$2(cycleRight$1);
var moveNorth$1 = doMove$2(cycleUp$1);
var moveSouth$1 = doMove$2(cycleDown$1);
var getKeydownRules$4 = constant$1([
rule(inSet(LEFT), west(moveLeft$3, moveRight$3)),
rule(inSet(RIGHT), east(moveLeft$3, moveRight$3)),
rule(inSet(UP), north(moveNorth$1)),
rule(inSet(DOWN), south(moveSouth$1)),
rule(and([
isShift,
inSet(TAB)
]), handleTab),
rule(and([
isNotShift,
inSet(TAB)
]), handleTab),
rule(inSet(ESCAPE), doEscape$1),
rule(inSet(SPACE.concat(ENTER)), execute$3)
]);
var getKeyupRules$4 = constant$1([rule(inSet(SPACE), stopEventForFirefox)]);
var FlatgridType = typical(schema$e, flatgrid$1, getKeydownRules$4, getKeyupRules$4, function () {
return Optional.some(focusIn$3);
});
var horizontal = function (container, selector, current, delta) {
var isDisabledButton = function (candidate) {
return name$1(candidate) === 'button' && get$b(candidate, 'disabled') === 'disabled';
};
var tryCycle = function (initial, index, candidates) {
var newIndex = cycleBy(index, delta, 0, candidates.length - 1);
if (newIndex === initial) {
return Optional.none();
} else {
return isDisabledButton(candidates[newIndex]) ? tryCycle(initial, newIndex, candidates) : Optional.from(candidates[newIndex]);
}
};
return locateVisible(container, current, selector).bind(function (identified) {
var index = identified.index;
var candidates = identified.candidates;
return tryCycle(index, index, candidates);
});
};
var schema$d = [
required$1('selector'),
defaulted('getInitial', Optional.none),
defaulted('execute', defaultExecute),
onKeyboardHandler('onEscape'),
defaulted('executeOnMove', false),
defaulted('allowVertical', true)
];
var findCurrent = function (component, flowConfig) {
return flowConfig.focusManager.get(component).bind(function (elem) {
return closest$1(elem, flowConfig.selector);
});
};
var execute$2 = function (component, simulatedEvent, flowConfig) {
return findCurrent(component, flowConfig).bind(function (focused) {
return flowConfig.execute(component, simulatedEvent, focused);
});
};
var focusIn$2 = function (component, flowConfig, _state) {
flowConfig.getInitial(component).orThunk(function () {
return descendant(component.element, flowConfig.selector);
}).each(function (first) {
flowConfig.focusManager.set(component, first);
});
};
var moveLeft$2 = function (element, focused, info) {
return horizontal(element, info.selector, focused, -1);
};
var moveRight$2 = function (element, focused, info) {
return horizontal(element, info.selector, focused, +1);
};
var doMove$1 = function (movement) {
return function (component, simulatedEvent, flowConfig, flowState) {
return movement(component, simulatedEvent, flowConfig, flowState).bind(function () {
return flowConfig.executeOnMove ? execute$2(component, simulatedEvent, flowConfig) : Optional.some(true);
});
};
};
var doEscape = function (component, simulatedEvent, flowConfig) {
return flowConfig.onEscape(component, simulatedEvent);
};
var getKeydownRules$3 = function (_component, _se, flowConfig, _flowState) {
var westMovers = LEFT.concat(flowConfig.allowVertical ? UP : []);
var eastMovers = RIGHT.concat(flowConfig.allowVertical ? DOWN : []);
return [
rule(inSet(westMovers), doMove$1(west(moveLeft$2, moveRight$2))),
rule(inSet(eastMovers), doMove$1(east(moveLeft$2, moveRight$2))),
rule(inSet(ENTER), execute$2),
rule(inSet(SPACE), execute$2),
rule(inSet(ESCAPE), doEscape)
];
};
var getKeyupRules$3 = constant$1([rule(inSet(SPACE), stopEventForFirefox)]);
var FlowType = typical(schema$d, NoState.init, getKeydownRules$3, getKeyupRules$3, function () {
return Optional.some(focusIn$2);
});
var toCell = function (matrix, rowIndex, columnIndex) {
return Optional.from(matrix[rowIndex]).bind(function (row) {
return Optional.from(row[columnIndex]).map(function (cell) {
return {
rowIndex: rowIndex,
columnIndex: columnIndex,
cell: cell
};
});
});
};
var cycleHorizontal = function (matrix, rowIndex, startCol, deltaCol) {
var row = matrix[rowIndex];
var colsInRow = row.length;
var newColIndex = cycleBy(startCol, deltaCol, 0, colsInRow - 1);
return toCell(matrix, rowIndex, newColIndex);
};
var cycleVertical = function (matrix, colIndex, startRow, deltaRow) {
var nextRowIndex = cycleBy(startRow, deltaRow, 0, matrix.length - 1);
var colsInNextRow = matrix[nextRowIndex].length;
var nextColIndex = clamp(colIndex, 0, colsInNextRow - 1);
return toCell(matrix, nextRowIndex, nextColIndex);
};
var moveHorizontal = function (matrix, rowIndex, startCol, deltaCol) {
var row = matrix[rowIndex];
var colsInRow = row.length;
var newColIndex = clamp(startCol + deltaCol, 0, colsInRow - 1);
return toCell(matrix, rowIndex, newColIndex);
};
var moveVertical = function (matrix, colIndex, startRow, deltaRow) {
var nextRowIndex = clamp(startRow + deltaRow, 0, matrix.length - 1);
var colsInNextRow = matrix[nextRowIndex].length;
var nextColIndex = clamp(colIndex, 0, colsInNextRow - 1);
return toCell(matrix, nextRowIndex, nextColIndex);
};
var cycleRight = function (matrix, startRow, startCol) {
return cycleHorizontal(matrix, startRow, startCol, +1);
};
var cycleLeft = function (matrix, startRow, startCol) {
return cycleHorizontal(matrix, startRow, startCol, -1);
};
var cycleUp = function (matrix, startRow, startCol) {
return cycleVertical(matrix, startCol, startRow, -1);
};
var cycleDown = function (matrix, startRow, startCol) {
return cycleVertical(matrix, startCol, startRow, +1);
};
var moveLeft$1 = function (matrix, startRow, startCol) {
return moveHorizontal(matrix, startRow, startCol, -1);
};
var moveRight$1 = function (matrix, startRow, startCol) {
return moveHorizontal(matrix, startRow, startCol, +1);
};
var moveUp$1 = function (matrix, startRow, startCol) {
return moveVertical(matrix, startCol, startRow, -1);
};
var moveDown$1 = function (matrix, startRow, startCol) {
return moveVertical(matrix, startCol, startRow, +1);
};
var schema$c = [
requiredObjOf('selectors', [
required$1('row'),
required$1('cell')
]),
defaulted('cycles', true),
defaulted('previousSelector', Optional.none),
defaulted('execute', defaultExecute)
];
var focusIn$1 = function (component, matrixConfig, _state) {
var focused = matrixConfig.previousSelector(component).orThunk(function () {
var selectors = matrixConfig.selectors;
return descendant(component.element, selectors.cell);
});
focused.each(function (cell) {
matrixConfig.focusManager.set(component, cell);
});
};
var execute$1 = function (component, simulatedEvent, matrixConfig) {
return search(component.element).bind(function (focused) {
return matrixConfig.execute(component, simulatedEvent, focused);
});
};
var toMatrix = function (rows, matrixConfig) {
return map$2(rows, function (row) {
return descendants(row, matrixConfig.selectors.cell);
});
};
var doMove = function (ifCycle, ifMove) {
return function (element, focused, matrixConfig) {
var move = matrixConfig.cycles ? ifCycle : ifMove;
return closest$1(focused, matrixConfig.selectors.row).bind(function (inRow) {
var cellsInRow = descendants(inRow, matrixConfig.selectors.cell);
return findIndex(cellsInRow, focused).bind(function (colIndex) {
var allRows = descendants(element, matrixConfig.selectors.row);
return findIndex(allRows, inRow).bind(function (rowIndex) {
var matrix = toMatrix(allRows, matrixConfig);
return move(matrix, rowIndex, colIndex).map(function (next) {
return next.cell;
});
});
});
});
};
};
var moveLeft = doMove(cycleLeft, moveLeft$1);
var moveRight = doMove(cycleRight, moveRight$1);
var moveNorth = doMove(cycleUp, moveUp$1);
var moveSouth = doMove(cycleDown, moveDown$1);
var getKeydownRules$2 = constant$1([
rule(inSet(LEFT), west(moveLeft, moveRight)),
rule(inSet(RIGHT), east(moveLeft, moveRight)),
rule(inSet(UP), north(moveNorth)),
rule(inSet(DOWN), south(moveSouth)),
rule(inSet(SPACE.concat(ENTER)), execute$1)
]);
var getKeyupRules$2 = constant$1([rule(inSet(SPACE), stopEventForFirefox)]);
var MatrixType = typical(schema$c, NoState.init, getKeydownRules$2, getKeyupRules$2, function () {
return Optional.some(focusIn$1);
});
var schema$b = [
required$1('selector'),
defaulted('execute', defaultExecute),
defaulted('moveOnTab', false)
];
var execute = function (component, simulatedEvent, menuConfig) {
return menuConfig.focusManager.get(component).bind(function (focused) {
return menuConfig.execute(component, simulatedEvent, focused);
});
};
var focusIn = function (component, menuConfig, _state) {
descendant(component.element, menuConfig.selector).each(function (first) {
menuConfig.focusManager.set(component, first);
});
};
var moveUp = function (element, focused, info) {
return horizontal(element, info.selector, focused, -1);
};
var moveDown = function (element, focused, info) {
return horizontal(element, info.selector, focused, +1);
};
var fireShiftTab = function (component, simulatedEvent, menuConfig, menuState) {
return menuConfig.moveOnTab ? move$1(moveUp)(component, simulatedEvent, menuConfig, menuState) : Optional.none();
};
var fireTab = function (component, simulatedEvent, menuConfig, menuState) {
return menuConfig.moveOnTab ? move$1(moveDown)(component, simulatedEvent, menuConfig, menuState) : Optional.none();
};
var getKeydownRules$1 = constant$1([
rule(inSet(UP), move$1(moveUp)),
rule(inSet(DOWN), move$1(moveDown)),
rule(and([
isShift,
inSet(TAB)
]), fireShiftTab),
rule(and([
isNotShift,
inSet(TAB)
]), fireTab),
rule(inSet(ENTER), execute),
rule(inSet(SPACE), execute)
]);
var getKeyupRules$1 = constant$1([rule(inSet(SPACE), stopEventForFirefox)]);
var MenuType = typical(schema$b, NoState.init, getKeydownRules$1, getKeyupRules$1, function () {
return Optional.some(focusIn);
});
var schema$a = [
onKeyboardHandler('onSpace'),
onKeyboardHandler('onEnter'),
onKeyboardHandler('onShiftEnter'),
onKeyboardHandler('onLeft'),
onKeyboardHandler('onRight'),
onKeyboardHandler('onTab'),
onKeyboardHandler('onShiftTab'),
onKeyboardHandler('onUp'),
onKeyboardHandler('onDown'),
onKeyboardHandler('onEscape'),
defaulted('stopSpaceKeyup', false),
option('focusIn')
];
var getKeydownRules = function (component, simulatedEvent, specialInfo) {
return [
rule(inSet(SPACE), specialInfo.onSpace),
rule(and([
isNotShift,
inSet(ENTER)
]), specialInfo.onEnter),
rule(and([
isShift,
inSet(ENTER)
]), specialInfo.onShiftEnter),
rule(and([
isShift,
inSet(TAB)
]), specialInfo.onShiftTab),
rule(and([
isNotShift,
inSet(TAB)
]), specialInfo.onTab),
rule(inSet(UP), specialInfo.onUp),
rule(inSet(DOWN), specialInfo.onDown),
rule(inSet(LEFT), specialInfo.onLeft),
rule(inSet(RIGHT), specialInfo.onRight),
rule(inSet(SPACE), specialInfo.onSpace),
rule(inSet(ESCAPE), specialInfo.onEscape)
];
};
var getKeyupRules = function (component, simulatedEvent, specialInfo) {
return specialInfo.stopSpaceKeyup ? [rule(inSet(SPACE), stopEventForFirefox)] : [];
};
var SpecialType = typical(schema$a, NoState.init, getKeydownRules, getKeyupRules, function (specialInfo) {
return specialInfo.focusIn;
});
var acyclic = AcyclicType.schema();
var cyclic = CyclicType.schema();
var flow = FlowType.schema();
var flatgrid = FlatgridType.schema();
var matrix = MatrixType.schema();
var execution = ExecutionType.schema();
var menu = MenuType.schema();
var special = SpecialType.schema();
var KeyboardBranches = /*#__PURE__*/Object.freeze({
__proto__: null,
acyclic: acyclic,
cyclic: cyclic,
flow: flow,
flatgrid: flatgrid,
matrix: matrix,
execution: execution,
menu: menu,
special: special
});
var isFlatgridState = function (keyState) {
return hasNonNullableKey(keyState, 'setGridSize');
};
var Keying = createModes({
branchKey: 'mode',
branches: KeyboardBranches,
name: 'keying',
active: {
events: function (keyingConfig, keyingState) {
var handler = keyingConfig.handler;
return handler.toEvents(keyingConfig, keyingState);
}
},
apis: {
focusIn: function (component, keyConfig, keyState) {
keyConfig.sendFocusIn(keyConfig).fold(function () {
component.getSystem().triggerFocus(component.element, component.element);
}, function (sendFocusIn) {
sendFocusIn(component, keyConfig, keyState);
});
},
setGridSize: function (component, keyConfig, keyState, numRows, numColumns) {
if (!isFlatgridState(keyState)) {
console.error('Layout does not support setGridSize');
} else {
keyState.setGridSize(numRows, numColumns);
}
}
},
state: KeyingState
});
var field$1 = function (name, forbidden) {
return defaultedObjOf(name, {}, map$2(forbidden, function (f) {
return forbid(f.name(), 'Cannot configure ' + f.name() + ' for ' + name);
}).concat([customField('dump', identity)]));
};
var get$6 = function (data) {
return data.dump;
};
var augment = function (data, original) {
return __assign(__assign({}, derive$2(original)), data.dump);
};
var SketchBehaviours = {
field: field$1,
augment: augment,
get: get$6
};
var _placeholder = 'placeholder';
var adt$5 = Adt.generate([
{
single: [
'required',
'valueThunk'
]
},
{
multiple: [
'required',
'valueThunks'
]
}
]);
var isSubstituted = function (spec) {
return has$2(spec, 'uiType');
};
var subPlaceholder = function (owner, detail, compSpec, placeholders) {
if (owner.exists(function (o) {
return o !== compSpec.owner;
})) {
return adt$5.single(true, constant$1(compSpec));
}
return get$c(placeholders, compSpec.name).fold(function () {
throw new Error('Unknown placeholder component: ' + compSpec.name + '\nKnown: [' + keys(placeholders) + ']\nNamespace: ' + owner.getOr('none') + '\nSpec: ' + JSON.stringify(compSpec, null, 2));
}, function (newSpec) {
return newSpec.replace();
});
};
var scan = function (owner, detail, compSpec, placeholders) {
if (isSubstituted(compSpec) && compSpec.uiType === _placeholder) {
return subPlaceholder(owner, detail, compSpec, placeholders);
} else {
return adt$5.single(false, constant$1(compSpec));
}
};
var substitute = function (owner, detail, compSpec, placeholders) {
var base = scan(owner, detail, compSpec, placeholders);
return base.fold(function (req, valueThunk) {
var value = isSubstituted(compSpec) ? valueThunk(detail, compSpec.config, compSpec.validated) : valueThunk(detail);
var childSpecs = get$c(value, 'components').getOr([]);
var substituted = bind$3(childSpecs, function (c) {
return substitute(owner, detail, c, placeholders);
});
return [__assign(__assign({}, value), { components: substituted })];
}, function (req, valuesThunk) {
if (isSubstituted(compSpec)) {
var values = valuesThunk(detail, compSpec.config, compSpec.validated);
var preprocessor = compSpec.validated.preprocess.getOr(identity);
return preprocessor(values);
} else {
return valuesThunk(detail);
}
});
};
var substituteAll = function (owner, detail, components, placeholders) {
return bind$3(components, function (c) {
return substitute(owner, detail, c, placeholders);
});
};
var oneReplace = function (label, replacements) {
var called = false;
var used = function () {
return called;
};
var replace = function () {
if (called) {
throw new Error('Trying to use the same placeholder more than once: ' + label);
}
called = true;
return replacements;
};
var required = function () {
return replacements.fold(function (req, _) {
return req;
}, function (req, _) {
return req;
});
};
return {
name: constant$1(label),
required: required,
used: used,
replace: replace
};
};
var substitutePlaces = function (owner, detail, components, placeholders) {
var ps = map$1(placeholders, function (ph, name) {
return oneReplace(name, ph);
});
var outcome = substituteAll(owner, detail, components, ps);
each(ps, function (p) {
if (p.used() === false && p.required()) {
throw new Error('Placeholder: ' + p.name() + ' was not found in components list\nNamespace: ' + owner.getOr('none') + '\nComponents: ' + JSON.stringify(detail.components, null, 2));
}
});
return outcome;
};
var single$2 = adt$5.single;
var multiple = adt$5.multiple;
var placeholder = constant$1(_placeholder);
var unique = 0;
var generate$4 = 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 adt$4 = Adt.generate([
{ required: ['data'] },
{ external: ['data'] },
{ optional: ['data'] },
{ group: ['data'] }
]);
var fFactory = defaulted('factory', { sketch: identity });
var fSchema = defaulted('schema', []);
var fName = required$1('name');
var fPname = field$2('pname', 'pname', defaultedThunk(function (typeSpec) {
return '<alloy.' + generate$4(typeSpec.name) + '>';
}), anyValue());
var fGroupSchema = customField('schema', function () {
return [option('preprocess')];
});
var fDefaults = defaulted('defaults', constant$1({}));
var fOverrides = defaulted('overrides', constant$1({}));
var requiredSpec = objOf([
fFactory,
fSchema,
fName,
fPname,
fDefaults,
fOverrides
]);
var externalSpec = objOf([
fFactory,
fSchema,
fName,
fDefaults,
fOverrides
]);
var optionalSpec = objOf([
fFactory,
fSchema,
fName,
fPname,
fDefaults,
fOverrides
]);
var groupSpec = objOf([
fFactory,
fGroupSchema,
fName,
required$1('unit'),
fPname,
fDefaults,
fOverrides
]);
var asNamedPart = function (part) {
return part.fold(Optional.some, Optional.none, Optional.some, Optional.some);
};
var name = function (part) {
var get = function (data) {
return data.name;
};
return part.fold(get, get, get, get);
};
var convert$1 = function (adtConstructor, partSchema) {
return function (spec) {
var data = asRawOrDie$1('Converting part type', partSchema, spec);
return adtConstructor(data);
};
};
var required = convert$1(adt$4.required, requiredSpec);
convert$1(adt$4.external, externalSpec);
var optional = convert$1(adt$4.optional, optionalSpec);
var group = convert$1(adt$4.group, groupSpec);
var original = constant$1('entirety');
var combine$2 = function (detail, data, partSpec, partValidated) {
return deepMerge(data.defaults(detail, partSpec, partValidated), partSpec, { uid: detail.partUids[data.name] }, data.overrides(detail, partSpec, partValidated));
};
var subs = function (owner, detail, parts) {
var internals = {};
var externals = {};
each$1(parts, function (part) {
part.fold(function (data) {
internals[data.pname] = single$2(true, function (detail, partSpec, partValidated) {
return data.factory.sketch(combine$2(detail, data, partSpec, partValidated));
});
}, function (data) {
var partSpec = detail.parts[data.name];
externals[data.name] = constant$1(data.factory.sketch(combine$2(detail, data, partSpec[original()]), partSpec));
}, function (data) {
internals[data.pname] = single$2(false, function (detail, partSpec, partValidated) {
return data.factory.sketch(combine$2(detail, data, partSpec, partValidated));
});
}, function (data) {
internals[data.pname] = multiple(true, function (detail, _partSpec, _partValidated) {
var units = detail[data.name];
return map$2(units, function (u) {
return data.factory.sketch(deepMerge(data.defaults(detail, u, _partValidated), u, data.overrides(detail, u)));
});
});
});
});
return {
internals: constant$1(internals),
externals: constant$1(externals)
};
};
var generate$3 = function (owner, parts) {
var r = {};
each$1(parts, function (part) {
asNamedPart(part).each(function (np) {
var g = doGenerateOne(owner, np.pname);
r[np.name] = function (config) {
var validated = asRawOrDie$1('Part: ' + np.name + ' in ' + owner, objOf(np.schema), config);
return __assign(__assign({}, g), {
config: config,
validated: validated
});
};
});
});
return r;
};
var doGenerateOne = function (owner, pname) {
return {
uiType: placeholder(),
owner: owner,
name: pname
};
};
var generateOne = function (owner, pname, config) {
return {
uiType: placeholder(),
owner: owner,
name: pname,
config: config,
validated: {}
};
};
var schemas = function (parts) {
return bind$3(parts, function (part) {
return part.fold(Optional.none, Optional.some, Optional.none, Optional.none).map(function (data) {
return requiredObjOf(data.name, data.schema.concat([snapshot(original())]));
}).toArray();
});
};
var names = function (parts) {
return map$2(parts, name);
};
var substitutes = function (owner, detail, parts) {
return subs(owner, detail, parts);
};
var components = function (owner, detail, internals) {
return substitutePlaces(Optional.some(owner), detail, detail.components, internals);
};
var getPart = function (component, detail, partKey) {
var uid = detail.partUids[partKey];
return component.getSystem().getByUid(uid).toOptional();
};
var getPartOrDie = function (component, detail, partKey) {
return getPart(component, detail, partKey).getOrDie('Could not find part: ' + partKey);
};
var getAllParts = function (component, detail) {
var system = component.getSystem();
return map$1(detail.partUids, function (pUid, _k) {
return constant$1(system.getByUid(pUid));
});
};
var defaultUids = function (baseUid, partTypes) {
var partNames = names(partTypes);
return wrapAll(map$2(partNames, function (pn) {
return {
key: pn,
value: baseUid + '-' + pn
};
}));
};
var defaultUidsSchema = function (partTypes) {
return field$2('partUids', 'partUids', mergeWithThunk(function (spec) {
return defaultUids(spec.uid, partTypes);
}), anyValue());
};
var premadeTag = generate$4('alloy-premade');
var premade$1 = function (comp) {
return wrap(premadeTag, comp);
};
var getPremade = function (spec) {
return get$c(spec, premadeTag);
};
var makeApi = function (f) {
return markAsSketchApi(function (component) {
var rest = [];
for (var _i = 1; _i < arguments.length; _i++) {
rest[_i - 1] = arguments[_i];
}
return f.apply(void 0, __spreadArray([
component.getApis(),
component
], rest, false));
}, f);
};
var prefix$1 = constant$1('alloy-id-');
var idAttr$1 = constant$1('data-alloy-id');
var prefix = prefix$1();
var idAttr = idAttr$1();
var write = function (label, elem) {
var id = generate$4(prefix + label);
writeOnly(elem, id);
return id;
};
var writeOnly = function (elem, uid) {
Object.defineProperty(elem.dom, idAttr, {
value: uid,
writable: true
});
};
var read = function (elem) {
var id = isElement(elem) ? elem.dom[idAttr] : null;
return Optional.from(id);
};
var generate$2 = function (prefix) {
return generate$4(prefix);
};
var base = function (partSchemas, partUidsSchemas) {
var ps = partSchemas.length > 0 ? [requiredObjOf('parts', partSchemas)] : [];
return ps.concat([
required$1('uid'),
defaulted('dom', {}),
defaulted('components', []),
snapshot('originalSpec'),
defaulted('debug.sketcher', {})
]).concat(partUidsSchemas);
};
var asRawOrDie = function (label, schema, spec, partSchemas, partUidsSchemas) {
var baseS = base(partSchemas, partUidsSchemas);
return asRawOrDie$1(label + ' [SpecSchema]', objOfOnly(baseS.concat(schema)), spec);
};
var single$1 = function (owner, schema, factory, spec) {
var specWithUid = supplyUid(spec);
var detail = asRawOrDie(owner, schema, specWithUid, [], []);
return factory(detail, specWithUid);
};
var composite$1 = function (owner, schema, partTypes, factory, spec) {
var specWithUid = supplyUid(spec);
var partSchemas = schemas(partTypes);
var partUidsSchema = defaultUidsSchema(partTypes);
var detail = asRawOrDie(owner, schema, specWithUid, partSchemas, [partUidsSchema]);
var subs = substitutes(owner, detail, partTypes);
var components$1 = components(owner, detail, subs.internals());
return factory(detail, components$1, specWithUid, subs.externals());
};
var hasUid = function (spec) {
return has$2(spec, 'uid');
};
var supplyUid = function (spec) {
return hasUid(spec) ? spec : __assign(__assign({}, spec), { uid: generate$2('uid') });
};
var isSketchSpec$1 = function (spec) {
return spec.uid !== undefined;
};
var singleSchema = objOfOnly([
required$1('name'),
required$1('factory'),
required$1('configFields'),
defaulted('apis', {}),
defaulted('extraApis', {})
]);
var compositeSchema = objOfOnly([
required$1('name'),
required$1('factory'),
required$1('configFields'),
required$1('partFields'),
defaulted('apis', {}),
defaulted('extraApis', {})
]);
var single = function (rawConfig) {
var config = asRawOrDie$1('Sketcher for ' + rawConfig.name, singleSchema, rawConfig);
var sketch = function (spec) {
return single$1(config.name, config.configFields, config.factory, spec);
};
var apis = map$1(config.apis, makeApi);
var extraApis = map$1(config.extraApis, function (f, k) {
return markAsExtraApi(f, k);
});
return __assign(__assign({
name: config.name,
configFields: config.configFields,
sketch: sketch
}, apis), extraApis);
};
var composite = function (rawConfig) {
var config = asRawOrDie$1('Sketcher for ' + rawConfig.name, compositeSchema, rawConfig);
var sketch = function (spec) {
return composite$1(config.name, config.configFields, config.partFields, config.factory, spec);
};
var parts = generate$3(config.name, config.partFields);
var apis = map$1(config.apis, makeApi);
var extraApis = map$1(config.extraApis, function (f, k) {
return markAsExtraApi(f, k);
});
return __assign(__assign({
name: config.name,
partFields: config.partFields,
configFields: config.configFields,
sketch: sketch,
parts: parts
}, apis), extraApis);
};
var factory$5 = function (detail) {
var events = events$8(detail.action);
var tag = detail.dom.tag;
var lookupAttr = function (attr) {
return get$c(detail.dom, 'attributes').bind(function (attrs) {
return get$c(attrs, attr);
});
};
var getModAttributes = function () {
if (tag === 'button') {
var type = lookupAttr('type').getOr('button');
var roleAttrs = lookupAttr('role').map(function (role) {
return { role: role };
}).getOr({});
return __assign({ type: type }, roleAttrs);
} else {
var role = lookupAttr('role').getOr('button');
return { role: role };
}
};
return {
uid: detail.uid,
dom: detail.dom,
components: detail.components,
events: events,
behaviours: SketchBehaviours.augment(detail.buttonBehaviours, [
Focusing.config({}),
Keying.config({
mode: 'execution',
useSpace: true,
useEnter: true
})
]),
domModification: { attributes: getModAttributes() },
eventOrder: detail.eventOrder
};
};
var Button = single({
name: 'Button',
factory: factory$5,
configFields: [
defaulted('uid', undefined),
required$1('dom'),
defaulted('components', []),
SketchBehaviours.field('buttonBehaviours', [
Focusing,
Keying
]),
option('action'),
option('role'),
defaulted('eventOrder', {})
]
});
var exhibit$3 = function () {
return nu$3({
styles: {
'-webkit-user-select': 'none',
'user-select': 'none',
'-ms-user-select': 'none',
'-moz-user-select': '-moz-none'
},
attributes: { unselectable: 'on' }
});
};
var events$6 = function () {
return derive$3([abort(selectstart(), always)]);
};
var ActiveUnselecting = /*#__PURE__*/Object.freeze({
__proto__: null,
events: events$6,
exhibit: exhibit$3
});
var Unselecting = create$5({
fields: [],
name: 'unselecting',
active: ActiveUnselecting
});
var getAttrs$1 = function (elem) {
var attributes = elem.dom.attributes !== undefined ? elem.dom.attributes : [];
return foldl(attributes, function (b, attr) {
var _a;
if (attr.name === 'class') {
return b;
} else {
return __assign(__assign({}, b), (_a = {}, _a[attr.name] = attr.value, _a));
}
}, {});
};
var getClasses = function (elem) {
return Array.prototype.slice.call(elem.dom.classList, 0);
};
var fromHtml = function (html) {
var elem = SugarElement.fromHtml(html);
var children$1 = children(elem);
var attrs = getAttrs$1(elem);
var classes = getClasses(elem);
var contents = children$1.length === 0 ? {} : { innerHtml: get$9(elem) };
return __assign({
tag: name$1(elem),
classes: classes,
attributes: attrs
}, contents);
};
var dom$1 = function (rawHtml) {
var html = supplant(rawHtml, { prefix: prefix$2 });
return fromHtml(html);
};
var spec = function (rawHtml) {
return { dom: dom$1(rawHtml) };
};
var forToolbarCommand = function (editor, command) {
return forToolbar(command, function () {
editor.execCommand(command);
}, {}, editor);
};
var getToggleBehaviours = function (command) {
return derive$2([
Toggling.config({
toggleClass: resolve('toolbar-button-selected'),
toggleOnExecute: false,
aria: { mode: 'pressed' }
}),
format(command, function (button, status) {
var toggle = status ? Toggling.on : Toggling.off;
toggle(button);
})
]);
};
var forToolbarStateCommand = function (editor, command) {
var extraBehaviours = getToggleBehaviours(command);
return forToolbar(command, function () {
editor.execCommand(command);
}, extraBehaviours, editor);
};
var forToolbarStateAction = function (editor, clazz, command, action) {
var extraBehaviours = getToggleBehaviours(command);
return forToolbar(clazz, action, extraBehaviours, editor);
};
var getToolbarIconButton = function (clazz, editor) {
var icons = editor.ui.registry.getAll().icons;
var optOxideIcon = Optional.from(icons[clazz]);
return optOxideIcon.fold(function () {
return dom$1('<span class="${prefix}-toolbar-button ${prefix}-toolbar-group-item ${prefix}-icon-' + clazz + ' ${prefix}-icon"></span>');
}, function (icon) {
return dom$1('<span class="${prefix}-toolbar-button ${prefix}-toolbar-group-item">' + icon + '</span>');
});
};
var forToolbar = function (clazz, action, extraBehaviours, editor) {
return Button.sketch({
dom: getToolbarIconButton(clazz, editor),
action: action,
buttonBehaviours: deepMerge(derive$2([Unselecting.config({})]), extraBehaviours)
});
};
var labelPart = optional({
schema: [required$1('dom')],
name: 'label'
});
var edgePart = function (name) {
return optional({
name: '' + name + '-edge',
overrides: function (detail) {
var action = detail.model.manager.edgeActions[name];
return action.fold(function () {
return {};
}, function (a) {
return {
events: derive$3([
runActionExtra(touchstart(), function (comp, se, d) {
return a(comp, d);
}, [detail]),
runActionExtra(mousedown(), function (comp, se, d) {
return a(comp, d);
}, [detail]),
runActionExtra(mousemove(), function (comp, se, det) {
if (det.mouseIsDown.get()) {
a(comp, det);
}
}, [detail])
])
};
});
}
});
};
var tlEdgePart = edgePart('top-left');
var tedgePart = edgePart('top');
var trEdgePart = edgePart('top-right');
var redgePart = edgePart('right');
var brEdgePart = edgePart('bottom-right');
var bedgePart = edgePart('bottom');
var blEdgePart = edgePart('bottom-left');
var ledgePart = edgePart('left');
var thumbPart = required({
name: 'thumb',
defaults: constant$1({ dom: { styles: { position: 'absolute' } } }),
overrides: function (detail) {
return {
events: derive$3([
redirectToPart(touchstart(), detail, 'spectrum'),
redirectToPart(touchmove(), detail, 'spectrum'),
redirectToPart(touchend(), detail, 'spectrum'),
redirectToPart(mousedown(), detail, 'spectrum'),
redirectToPart(mousemove(), detail, 'spectrum'),
redirectToPart(mouseup(), detail, 'spectrum')
])
};
}
});
var spectrumPart = required({
schema: [customField('mouseIsDown', function () {
return Cell(false);
})],
name: 'spectrum',
overrides: function (detail) {
var modelDetail = detail.model;
var model = modelDetail.manager;
var setValueFrom = function (component, simulatedEvent) {
return model.getValueFromEvent(simulatedEvent).map(function (value) {
return model.setValueFrom(component, detail, value);
});
};
return {
behaviours: derive$2([
Keying.config({
mode: 'special',
onLeft: function (spectrum) {
return model.onLeft(spectrum, detail);
},
onRight: function (spectrum) {
return model.onRight(spectrum, detail);
},
onUp: function (spectrum) {
return model.onUp(spectrum, detail);
},
onDown: function (spectrum) {
return model.onDown(spectrum, detail);
}
}),
Focusing.config({})
]),
events: derive$3([
run(touchstart(), setValueFrom),
run(touchmove(), setValueFrom),
run(mousedown(), setValueFrom),
run(mousemove(), function (spectrum, se) {
if (detail.mouseIsDown.get()) {
setValueFrom(spectrum, se);
}
})
])
};
}
});
var SliderParts = [
labelPart,
ledgePart,
redgePart,
tedgePart,
bedgePart,
tlEdgePart,
trEdgePart,
blEdgePart,
brEdgePart,
thumbPart,
spectrumPart
];
var onLoad$4 = function (component, repConfig, repState) {
repConfig.store.manager.onLoad(component, repConfig, repState);
};
var onUnload$2 = function (component, repConfig, repState) {
repConfig.store.manager.onUnload(component, repConfig, repState);
};
var setValue$3 = function (component, repConfig, repState, data) {
repConfig.store.manager.setValue(component, repConfig, repState, data);
};
var getValue$4 = function (component, repConfig, repState) {
return repConfig.store.manager.getValue(component, repConfig, repState);
};
var getState$1 = function (component, repConfig, repState) {
return repState;
};
var RepresentApis = /*#__PURE__*/Object.freeze({
__proto__: null,
onLoad: onLoad$4,
onUnload: onUnload$2,
setValue: setValue$3,
getValue: getValue$4,
getState: getState$1
});
var events$5 = function (repConfig, repState) {
var es = repConfig.resetOnDom ? [
runOnAttached(function (comp, _se) {
onLoad$4(comp, repConfig, repState);
}),
runOnDetached(function (comp, _se) {
onUnload$2(comp, repConfig, repState);
})
] : [loadEvent(repConfig, repState, onLoad$4)];
return derive$3(es);
};
var ActiveRepresenting = /*#__PURE__*/Object.freeze({
__proto__: null,
events: events$5
});
var memory = function () {
var data = Cell(null);
var readState = function () {
return {
mode: 'memory',
value: data.get()
};
};
var isNotSet = function () {
return data.get() === null;
};
var clear = function () {
data.set(null);
};
return nu$2({
set: data.set,
get: data.get,
isNotSet: isNotSet,
clear: clear,
readState: readState
});
};
var manual = function () {
var readState = noop;
return nu$2({ readState: readState });
};
var dataset = function () {
var dataByValue = Cell({});
var dataByText = Cell({});
var readState = function () {
return {
mode: 'dataset',
dataByValue: dataByValue.get(),
dataByText: dataByText.get()
};
};
var clear = function () {
dataByValue.set({});
dataByText.set({});
};
var lookup = function (itemString) {
return get$c(dataByValue.get(), itemString).orThunk(function () {
return get$c(dataByText.get(), itemString);
});
};
var update = function (items) {
var currentDataByValue = dataByValue.get();
var currentDataByText = dataByText.get();
var newDataByValue = {};
var newDataByText = {};
each$1(items, function (item) {
newDataByValue[item.value] = item;
get$c(item, 'meta').each(function (meta) {
get$c(meta, 'text').each(function (text) {
newDataByText[text] = item;
});
});
});
dataByValue.set(__assign(__assign({}, currentDataByValue), newDataByValue));
dataByText.set(__assign(__assign({}, currentDataByText), newDataByText));
};
return nu$2({
readState: readState,
lookup: lookup,
update: update,
clear: clear
});
};
var init$4 = function (spec) {
return spec.store.manager.state(spec);
};
var RepresentState = /*#__PURE__*/Object.freeze({
__proto__: null,
memory: memory,
dataset: dataset,
manual: manual,
init: init$4
});
var setValue$2 = function (component, repConfig, repState, data) {
var store = repConfig.store;
repState.update([data]);
store.setValue(component, data);
repConfig.onSetValue(component, data);
};
var getValue$3 = function (component, repConfig, repState) {
var store = repConfig.store;
var key = store.getDataKey(component);
return repState.lookup(key).getOrThunk(function () {
return store.getFallbackEntry(key);
});
};
var onLoad$3 = function (component, repConfig, repState) {
var store = repConfig.store;
store.initialValue.each(function (data) {
setValue$2(component, repConfig, repState, data);
});
};
var onUnload$1 = function (component, repConfig, repState) {
repState.clear();
};
var DatasetStore = [
option('initialValue'),
required$1('getFallbackEntry'),
required$1('getDataKey'),
required$1('setValue'),
output('manager', {
setValue: setValue$2,
getValue: getValue$3,
onLoad: onLoad$3,
onUnload: onUnload$1,
state: dataset
})
];
var getValue$2 = function (component, repConfig, _repState) {
return repConfig.store.getValue(component);
};
var setValue$1 = function (component, repConfig, _repState, data) {
repConfig.store.setValue(component, data);
repConfig.onSetValue(component, data);
};
var onLoad$2 = function (component, repConfig, _repState) {
repConfig.store.initialValue.each(function (data) {
repConfig.store.setValue(component, data);
});
};
var ManualStore = [
required$1('getValue'),
defaulted('setValue', noop),
option('initialValue'),
output('manager', {
setValue: setValue$1,
getValue: getValue$2,
onLoad: onLoad$2,
onUnload: noop,
state: NoState.init
})
];
var setValue = function (component, repConfig, repState, data) {
repState.set(data);
repConfig.onSetValue(component, data);
};
var getValue$1 = function (component, repConfig, repState) {
return repState.get();
};
var onLoad$1 = function (component, repConfig, repState) {
repConfig.store.initialValue.each(function (initVal) {
if (repState.isNotSet()) {
repState.set(initVal);
}
});
};
var onUnload = function (component, repConfig, repState) {
repState.clear();
};
var MemoryStore = [
option('initialValue'),
output('manager', {
setValue: setValue,
getValue: getValue$1,
onLoad: onLoad$1,
onUnload: onUnload,
state: memory
})
];
var RepresentSchema = [
defaultedOf('store', { mode: 'memory' }, choose$1('mode', {
memory: MemoryStore,
manual: ManualStore,
dataset: DatasetStore
})),
onHandler('onSetValue'),
defaulted('resetOnDom', false)
];
var Representing = create$5({
fields: RepresentSchema,
name: 'representing',
active: ActiveRepresenting,
apis: RepresentApis,
extra: {
setValueFrom: function (component, source) {
var value = Representing.getValue(source);
Representing.setValue(component, value);
}
},
state: RepresentState
});
var api$1 = Dimension('width', function (element) {
return element.dom.offsetWidth;
});
var set$4 = function (element, h) {
return api$1.set(element, h);
};
var get$5 = function (element) {
return api$1.get(element);
};
var r$1 = function (left, top) {
var translate = function (x, y) {
return r$1(left + x, top + y);
};
return {
left: left,
top: top,
translate: translate
};
};
var SugarPosition = r$1;
var _sliderChangeEvent = 'slider.change.value';
var sliderChangeEvent = constant$1(_sliderChangeEvent);
var isTouchEvent = function (evt) {
return evt.type.indexOf('touch') !== -1;
};
var getEventSource = function (simulatedEvent) {
var evt = simulatedEvent.event.raw;
if (isTouchEvent(evt)) {
var touchEvent = evt;
return touchEvent.touches !== undefined && touchEvent.touches.length === 1 ? Optional.some(touchEvent.touches[0]).map(function (t) {
return SugarPosition(t.clientX, t.clientY);
}) : Optional.none();
} else {
var mouseEvent = evt;
return mouseEvent.clientX !== undefined ? Optional.some(mouseEvent).map(function (me) {
return SugarPosition(me.clientX, me.clientY);
}) : Optional.none();
}
};
var t = 'top', r = 'right', b = 'bottom', l = 'left';
var minX = function (detail) {
return detail.model.minX;
};
var minY = function (detail) {
return detail.model.minY;
};
var min1X = function (detail) {
return detail.model.minX - 1;
};
var min1Y = function (detail) {
return detail.model.minY - 1;
};
var maxX = function (detail) {
return detail.model.maxX;
};
var maxY = function (detail) {
return detail.model.maxY;
};
var max1X = function (detail) {
return detail.model.maxX + 1;
};
var max1Y = function (detail) {
return detail.model.maxY + 1;
};
var range$1 = function (detail, max, min) {
return max(detail) - min(detail);
};
var xRange = function (detail) {
return range$1(detail, maxX, minX);
};
var yRange = function (detail) {
return range$1(detail, maxY, minY);
};
var halfX = function (detail) {
return xRange(detail) / 2;
};
var halfY = function (detail) {
return yRange(detail) / 2;
};
var step = function (detail) {
return detail.stepSize;
};
var snap = function (detail) {
return detail.snapToGrid;
};
var snapStart = function (detail) {
return detail.snapStart;
};
var rounded = function (detail) {
return detail.rounded;
};
var hasEdge = function (detail, edgeName) {
return detail[edgeName + '-edge'] !== undefined;
};
var hasLEdge = function (detail) {
return hasEdge(detail, l);
};
var hasREdge = function (detail) {
return hasEdge(detail, r);
};
var hasTEdge = function (detail) {
return hasEdge(detail, t);
};
var hasBEdge = function (detail) {
return hasEdge(detail, b);
};
var currentValue = function (detail) {
return detail.model.value.get();
};
var xValue = function (x) {
return { x: x };
};
var yValue = function (y) {
return { y: y };
};
var xyValue = function (x, y) {
return {
x: x,
y: y
};
};
var fireSliderChange$3 = function (component, value) {
emitWith(component, sliderChangeEvent(), { value: value });
};
var setToTLEdgeXY = function (edge, detail) {
fireSliderChange$3(edge, xyValue(min1X(detail), min1Y(detail)));
};
var setToTEdge = function (edge, detail) {
fireSliderChange$3(edge, yValue(min1Y(detail)));
};
var setToTEdgeXY = function (edge, detail) {
fireSliderChange$3(edge, xyValue(halfX(detail), min1Y(detail)));
};
var setToTREdgeXY = function (edge, detail) {
fireSliderChange$3(edge, xyValue(max1X(detail), min1Y(detail)));
};
var setToREdge = function (edge, detail) {
fireSliderChange$3(edge, xValue(max1X(detail)));
};
var setToREdgeXY = function (edge, detail) {
fireSliderChange$3(edge, xyValue(max1X(detail), halfY(detail)));
};
var setToBREdgeXY = function (edge, detail) {
fireSliderChange$3(edge, xyValue(max1X(detail), max1Y(detail)));
};
var setToBEdge = function (edge, detail) {
fireSliderChange$3(edge, yValue(max1Y(detail)));
};
var setToBEdgeXY = function (edge, detail) {
fireSliderChange$3(edge, xyValue(halfX(detail), max1Y(detail)));
};
var setToBLEdgeXY = function (edge, detail) {
fireSliderChange$3(edge, xyValue(min1X(detail), max1Y(detail)));
};
var setToLEdge = function (edge, detail) {
fireSliderChange$3(edge, xValue(min1X(detail)));
};
var setToLEdgeXY = function (edge, detail) {
fireSliderChange$3(edge, xyValue(min1X(detail), halfY(detail)));
};
var reduceBy = function (value, min, max, step) {
if (value < min) {
return value;
} else if (value > max) {
return max;
} else if (value === min) {
return min - 1;
} else {
return Math.max(min, value - step);
}
};
var increaseBy = function (value, min, max, step) {
if (value > max) {
return value;
} else if (value < min) {
return min;
} else if (value === max) {
return max + 1;
} else {
return Math.min(max, value + step);
}
};
var capValue = function (value, min, max) {
return Math.max(min, Math.min(max, value));
};
var snapValueOf = function (value, min, max, step, snapStart) {
return snapStart.fold(function () {
var initValue = value - min;
var extraValue = Math.round(initValue / step) * step;
return capValue(min + extraValue, min - 1, max + 1);
}, function (start) {
var remainder = (value - start) % step;
var adjustment = Math.round(remainder / step);
var rawSteps = Math.floor((value - start) / step);
var maxSteps = Math.floor((max - start) / step);
var numSteps = Math.min(maxSteps, rawSteps + adjustment);
var r = start + numSteps * step;
return Math.max(start, r);
});
};
var findOffsetOf = function (value, min, max) {
return Math.min(max, Math.max(value, min)) - min;
};
var findValueOf = function (args) {
var min = args.min, max = args.max, range = args.range, value = args.value, step = args.step, snap = args.snap, snapStart = args.snapStart, rounded = args.rounded, hasMinEdge = args.hasMinEdge, hasMaxEdge = args.hasMaxEdge, minBound = args.minBound, maxBound = args.maxBound, screenRange = args.screenRange;
var capMin = hasMinEdge ? min - 1 : min;
var capMax = hasMaxEdge ? max + 1 : max;
if (value < minBound) {
return capMin;
} else if (value > maxBound) {
return capMax;
} else {
var offset = findOffsetOf(value, minBound, maxBound);
var newValue = capValue(offset / screenRange * range + min, capMin, capMax);
if (snap && newValue >= min && newValue <= max) {
return snapValueOf(newValue, min, max, step, snapStart);
} else if (rounded) {
return Math.round(newValue);
} else {
return newValue;
}
}
};
var findOffsetOfValue$2 = function (args) {
var min = args.min, max = args.max, range = args.range, value = args.value, hasMinEdge = args.hasMinEdge, hasMaxEdge = args.hasMaxEdge, maxBound = args.maxBound, maxOffset = args.maxOffset, centerMinEdge = args.centerMinEdge, centerMaxEdge = args.centerMaxEdge;
if (value < min) {
return hasMinEdge ? 0 : centerMinEdge;
} else if (value > max) {
return hasMaxEdge ? maxBound : centerMaxEdge;
} else {
return (value - min) / range * maxOffset;
}
};
var top = 'top', right = 'right', bottom = 'bottom', left = 'left', width = 'width', height = 'height';
var getBounds$1 = function (component) {
return component.element.dom.getBoundingClientRect();
};
var getBoundsProperty = function (bounds, property) {
return bounds[property];
};
var getMinXBounds = function (component) {
var bounds = getBounds$1(component);
return getBoundsProperty(bounds, left);
};
var getMaxXBounds = function (component) {
var bounds = getBounds$1(component);
return getBoundsProperty(bounds, right);
};
var getMinYBounds = function (component) {
var bounds = getBounds$1(component);
return getBoundsProperty(bounds, top);
};
var getMaxYBounds = function (component) {
var bounds = getBounds$1(component);
return getBoundsProperty(bounds, bottom);
};
var getXScreenRange = function (component) {
var bounds = getBounds$1(component);
return getBoundsProperty(bounds, width);
};
var getYScreenRange = function (component) {
var bounds = getBounds$1(component);
return getBoundsProperty(bounds, height);
};
var getCenterOffsetOf = function (componentMinEdge, componentMaxEdge, spectrumMinEdge) {
return (componentMinEdge + componentMaxEdge) / 2 - spectrumMinEdge;
};
var getXCenterOffSetOf = function (component, spectrum) {
var componentBounds = getBounds$1(component);
var spectrumBounds = getBounds$1(spectrum);
var componentMinEdge = getBoundsProperty(componentBounds, left);
var componentMaxEdge = getBoundsProperty(componentBounds, right);
var spectrumMinEdge = getBoundsProperty(spectrumBounds, left);
return getCenterOffsetOf(componentMinEdge, componentMaxEdge, spectrumMinEdge);
};
var getYCenterOffSetOf = function (component, spectrum) {
var componentBounds = getBounds$1(component);
var spectrumBounds = getBounds$1(spectrum);
var componentMinEdge = getBoundsProperty(componentBounds, top);
var componentMaxEdge = getBoundsProperty(componentBounds, bottom);
var spectrumMinEdge = getBoundsProperty(spectrumBounds, top);
return getCenterOffsetOf(componentMinEdge, componentMaxEdge, spectrumMinEdge);
};
var fireSliderChange$2 = function (spectrum, value) {
emitWith(spectrum, sliderChangeEvent(), { value: value });
};
var sliderValue$2 = function (x) {
return { x: x };
};
var findValueOfOffset$1 = function (spectrum, detail, left) {
var args = {
min: minX(detail),
max: maxX(detail),
range: xRange(detail),
value: left,
step: step(detail),
snap: snap(detail),
snapStart: snapStart(detail),
rounded: rounded(detail),
hasMinEdge: hasLEdge(detail),
hasMaxEdge: hasREdge(detail),
minBound: getMinXBounds(spectrum),
maxBound: getMaxXBounds(spectrum),
screenRange: getXScreenRange(spectrum)
};
return findValueOf(args);
};
var setValueFrom$2 = function (spectrum, detail, value) {
var xValue = findValueOfOffset$1(spectrum, detail, value);
var sliderVal = sliderValue$2(xValue);
fireSliderChange$2(spectrum, sliderVal);
return xValue;
};
var setToMin$2 = function (spectrum, detail) {
var min = minX(detail);
fireSliderChange$2(spectrum, sliderValue$2(min));
};
var setToMax$2 = function (spectrum, detail) {
var max = maxX(detail);
fireSliderChange$2(spectrum, sliderValue$2(max));
};
var moveBy$2 = function (direction, spectrum, detail) {
var f = direction > 0 ? increaseBy : reduceBy;
var xValue = f(currentValue(detail).x, minX(detail), maxX(detail), step(detail));
fireSliderChange$2(spectrum, sliderValue$2(xValue));
return Optional.some(xValue);
};
var handleMovement$2 = function (direction) {
return function (spectrum, detail) {
return moveBy$2(direction, spectrum, detail).map(always);
};
};
var getValueFromEvent$2 = function (simulatedEvent) {
var pos = getEventSource(simulatedEvent);
return pos.map(function (p) {
return p.left;
});
};
var findOffsetOfValue$1 = function (spectrum, detail, value, minEdge, maxEdge) {
var minOffset = 0;
var maxOffset = getXScreenRange(spectrum);
var centerMinEdge = minEdge.bind(function (edge) {
return Optional.some(getXCenterOffSetOf(edge, spectrum));
}).getOr(minOffset);
var centerMaxEdge = maxEdge.bind(function (edge) {
return Optional.some(getXCenterOffSetOf(edge, spectrum));
}).getOr(maxOffset);
var args = {
min: minX(detail),
max: maxX(detail),
range: xRange(detail),
value: value,
hasMinEdge: hasLEdge(detail),
hasMaxEdge: hasREdge(detail),
minBound: getMinXBounds(spectrum),
minOffset: minOffset,
maxBound: getMaxXBounds(spectrum),
maxOffset: maxOffset,
centerMinEdge: centerMinEdge,
centerMaxEdge: centerMaxEdge
};
return findOffsetOfValue$2(args);
};
var findPositionOfValue$1 = function (slider, spectrum, value, minEdge, maxEdge, detail) {
var offset = findOffsetOfValue$1(spectrum, detail, value, minEdge, maxEdge);
return getMinXBounds(spectrum) - getMinXBounds(slider) + offset;
};
var setPositionFromValue$2 = function (slider, thumb, detail, edges) {
var value = currentValue(detail);
var pos = findPositionOfValue$1(slider, edges.getSpectrum(slider), value.x, edges.getLeftEdge(slider), edges.getRightEdge(slider), detail);
var thumbRadius = get$5(thumb.element) / 2;
set$5(thumb.element, 'left', pos - thumbRadius + 'px');
};
var onLeft$2 = handleMovement$2(-1);
var onRight$2 = handleMovement$2(1);
var onUp$2 = Optional.none;
var onDown$2 = Optional.none;
var edgeActions$2 = {
'top-left': Optional.none(),
'top': Optional.none(),
'top-right': Optional.none(),
'right': Optional.some(setToREdge),
'bottom-right': Optional.none(),
'bottom': Optional.none(),
'bottom-left': Optional.none(),
'left': Optional.some(setToLEdge)
};
var HorizontalModel = /*#__PURE__*/Object.freeze({
__proto__: null,
setValueFrom: setValueFrom$2,
setToMin: setToMin$2,
setToMax: setToMax$2,
findValueOfOffset: findValueOfOffset$1,
getValueFromEvent: getValueFromEvent$2,
findPositionOfValue: findPositionOfValue$1,
setPositionFromValue: setPositionFromValue$2,
onLeft: onLeft$2,
onRight: onRight$2,
onUp: onUp$2,
onDown: onDown$2,
edgeActions: edgeActions$2
});
var fireSliderChange$1 = function (spectrum, value) {
emitWith(spectrum, sliderChangeEvent(), { value: value });
};
var sliderValue$1 = function (y) {
return { y: y };
};
var findValueOfOffset = function (spectrum, detail, top) {
var args = {
min: minY(detail),
max: maxY(detail),
range: yRange(detail),
value: top,
step: step(detail),
snap: snap(detail),
snapStart: snapStart(detail),
rounded: rounded(detail),
hasMinEdge: hasTEdge(detail),
hasMaxEdge: hasBEdge(detail),
minBound: getMinYBounds(spectrum),
maxBound: getMaxYBounds(spectrum),
screenRange: getYScreenRange(spectrum)
};
return findValueOf(args);
};
var setValueFrom$1 = function (spectrum, detail, value) {
var yValue = findValueOfOffset(spectrum, detail, value);
var sliderVal = sliderValue$1(yValue);
fireSliderChange$1(spectrum, sliderVal);
return yValue;
};
var setToMin$1 = function (spectrum, detail) {
var min = minY(detail);
fireSliderChange$1(spectrum, sliderValue$1(min));
};
var setToMax$1 = function (spectrum, detail) {
var max = maxY(detail);
fireSliderChange$1(spectrum, sliderValue$1(max));
};
var moveBy$1 = function (direction, spectrum, detail) {
var f = direction > 0 ? increaseBy : reduceBy;
var yValue = f(currentValue(detail).y, minY(detail), maxY(detail), step(detail));
fireSliderChange$1(spectrum, sliderValue$1(yValue));
return Optional.some(yValue);
};
var handleMovement$1 = function (direction) {
return function (spectrum, detail) {
return moveBy$1(direction, spectrum, detail).map(always);
};
};
var getValueFromEvent$1 = function (simulatedEvent) {
var pos = getEventSource(simulatedEvent);
return pos.map(function (p) {
return p.top;
});
};
var findOffsetOfValue = function (spectrum, detail, value, minEdge, maxEdge) {
var minOffset = 0;
var maxOffset = getYScreenRange(spectrum);
var centerMinEdge = minEdge.bind(function (edge) {
return Optional.some(getYCenterOffSetOf(edge, spectrum));
}).getOr(minOffset);
var centerMaxEdge = maxEdge.bind(function (edge) {
return Optional.some(getYCenterOffSetOf(edge, spectrum));
}).getOr(maxOffset);
var args = {
min: minY(detail),
max: maxY(detail),
range: yRange(detail),
value: value,
hasMinEdge: hasTEdge(detail),
hasMaxEdge: hasBEdge(detail),
minBound: getMinYBounds(spectrum),
minOffset: minOffset,
maxBound: getMaxYBounds(spectrum),
maxOffset: maxOffset,
centerMinEdge: centerMinEdge,
centerMaxEdge: centerMaxEdge
};
return findOffsetOfValue$2(args);
};
var findPositionOfValue = function (slider, spectrum, value, minEdge, maxEdge, detail) {
var offset = findOffsetOfValue(spectrum, detail, value, minEdge, maxEdge);
return getMinYBounds(spectrum) - getMinYBounds(slider) + offset;
};
var setPositionFromValue$1 = function (slider, thumb, detail, edges) {
var value = currentValue(detail);
var pos = findPositionOfValue(slider, edges.getSpectrum(slider), value.y, edges.getTopEdge(slider), edges.getBottomEdge(slider), detail);
var thumbRadius = get$7(thumb.element) / 2;
set$5(thumb.element, 'top', pos - thumbRadius + 'px');
};
var onLeft$1 = Optional.none;
var onRight$1 = Optional.none;
var onUp$1 = handleMovement$1(-1);
var onDown$1 = handleMovement$1(1);
var edgeActions$1 = {
'top-left': Optional.none(),
'top': Optional.some(setToTEdge),
'top-right': Optional.none(),
'right': Optional.none(),
'bottom-right': Optional.none(),
'bottom': Optional.some(setToBEdge),
'bottom-left': Optional.none(),
'left': Optional.none()
};
var VerticalModel = /*#__PURE__*/Object.freeze({
__proto__: null,
setValueFrom: setValueFrom$1,
setToMin: setToMin$1,
setToMax: setToMax$1,
findValueOfOffset: findValueOfOffset,
getValueFromEvent: getValueFromEvent$1,
findPositionOfValue: findPositionOfValue,
setPositionFromValue: setPositionFromValue$1,
onLeft: onLeft$1,
onRight: onRight$1,
onUp: onUp$1,
onDown: onDown$1,
edgeActions: edgeActions$1
});
var fireSliderChange = function (spectrum, value) {
emitWith(spectrum, sliderChangeEvent(), { value: value });
};
var sliderValue = function (x, y) {
return {
x: x,
y: y
};
};
var setValueFrom = function (spectrum, detail, value) {
var xValue = findValueOfOffset$1(spectrum, detail, value.left);
var yValue = findValueOfOffset(spectrum, detail, value.top);
var val = sliderValue(xValue, yValue);
fireSliderChange(spectrum, val);
return val;
};
var moveBy = function (direction, isVerticalMovement, spectrum, detail) {
var f = direction > 0 ? increaseBy : reduceBy;
var xValue = isVerticalMovement ? currentValue(detail).x : f(currentValue(detail).x, minX(detail), maxX(detail), step(detail));
var yValue = !isVerticalMovement ? currentValue(detail).y : f(currentValue(detail).y, minY(detail), maxY(detail), step(detail));
fireSliderChange(spectrum, sliderValue(xValue, yValue));
return Optional.some(xValue);
};
var handleMovement = function (direction, isVerticalMovement) {
return function (spectrum, detail) {
return moveBy(direction, isVerticalMovement, spectrum, detail).map(always);
};
};
var setToMin = function (spectrum, detail) {
var mX = minX(detail);
var mY = minY(detail);
fireSliderChange(spectrum, sliderValue(mX, mY));
};
var setToMax = function (spectrum, detail) {
var mX = maxX(detail);
var mY = maxY(detail);
fireSliderChange(spectrum, sliderValue(mX, mY));
};
var getValueFromEvent = function (simulatedEvent) {
return getEventSource(simulatedEvent);
};
var setPositionFromValue = function (slider, thumb, detail, edges) {
var value = currentValue(detail);
var xPos = findPositionOfValue$1(slider, edges.getSpectrum(slider), value.x, edges.getLeftEdge(slider), edges.getRightEdge(slider), detail);
var yPos = findPositionOfValue(slider, edges.getSpectrum(slider), value.y, edges.getTopEdge(slider), edges.getBottomEdge(slider), detail);
var thumbXRadius = get$5(thumb.element) / 2;
var thumbYRadius = get$7(thumb.element) / 2;
set$5(thumb.element, 'left', xPos - thumbXRadius + 'px');
set$5(thumb.element, 'top', yPos - thumbYRadius + 'px');
};
var onLeft = handleMovement(-1, false);
var onRight = handleMovement(1, false);
var onUp = handleMovement(-1, true);
var onDown = handleMovement(1, true);
var edgeActions = {
'top-left': Optional.some(setToTLEdgeXY),
'top': Optional.some(setToTEdgeXY),
'top-right': Optional.some(setToTREdgeXY),
'right': Optional.some(setToREdgeXY),
'bottom-right': Optional.some(setToBREdgeXY),
'bottom': Optional.some(setToBEdgeXY),
'bottom-left': Optional.some(setToBLEdgeXY),
'left': Optional.some(setToLEdgeXY)
};
var TwoDModel = /*#__PURE__*/Object.freeze({
__proto__: null,
setValueFrom: setValueFrom,
setToMin: setToMin,
setToMax: setToMax,
getValueFromEvent: getValueFromEvent,
setPositionFromValue: setPositionFromValue,
onLeft: onLeft,
onRight: onRight,
onUp: onUp,
onDown: onDown,
edgeActions: edgeActions
});
var SliderSchema = [
defaulted('stepSize', 1),
defaulted('onChange', noop),
defaulted('onChoose', noop),
defaulted('onInit', noop),
defaulted('onDragStart', noop),
defaulted('onDragEnd', noop),
defaulted('snapToGrid', false),
defaulted('rounded', true),
option('snapStart'),
requiredOf('model', choose$1('mode', {
x: [
defaulted('minX', 0),
defaulted('maxX', 100),
customField('value', function (spec) {
return Cell(spec.mode.minX);
}),
required$1('getInitialValue'),
output('manager', HorizontalModel)
],
y: [
defaulted('minY', 0),
defaulted('maxY', 100),
customField('value', function (spec) {
return Cell(spec.mode.minY);
}),
required$1('getInitialValue'),
output('manager', VerticalModel)
],
xy: [
defaulted('minX', 0),
defaulted('maxX', 100),
defaulted('minY', 0),
defaulted('maxY', 100),
customField('value', function (spec) {
return Cell({
x: spec.mode.minX,
y: spec.mode.minY
});
}),
required$1('getInitialValue'),
output('manager', TwoDModel)
]
})),
field$1('sliderBehaviours', [
Keying,
Representing
]),
customField('mouseIsDown', function () {
return Cell(false);
})
];
var mouseReleased = constant$1('mouse.released');
var sketch$9 = function (detail, components, _spec, _externals) {
var _a;
var getThumb = function (component) {
return getPartOrDie(component, detail, 'thumb');
};
var getSpectrum = function (component) {
return getPartOrDie(component, detail, 'spectrum');
};
var getLeftEdge = function (component) {
return getPart(component, detail, 'left-edge');
};
var getRightEdge = function (component) {
return getPart(component, detail, 'right-edge');
};
var getTopEdge = function (component) {
return getPart(component, detail, 'top-edge');
};
var getBottomEdge = function (component) {
return getPart(component, detail, 'bottom-edge');
};
var modelDetail = detail.model;
var model = modelDetail.manager;
var refresh = function (slider, thumb) {
model.setPositionFromValue(slider, thumb, detail, {
getLeftEdge: getLeftEdge,
getRightEdge: getRightEdge,
getTopEdge: getTopEdge,
getBottomEdge: getBottomEdge,
getSpectrum: getSpectrum
});
};
var setValue = function (slider, newValue) {
modelDetail.value.set(newValue);
var thumb = getThumb(slider);
refresh(slider, thumb);
};
var changeValue = function (slider, newValue) {
setValue(slider, newValue);
var thumb = getThumb(slider);
detail.onChange(slider, thumb, newValue);
return Optional.some(true);
};
var resetToMin = function (slider) {
model.setToMin(slider, detail);
};
var resetToMax = function (slider) {
model.setToMax(slider, detail);
};
var choose = function (slider) {
var fireOnChoose = function () {
getPart(slider, detail, 'thumb').each(function (thumb) {
var value = modelDetail.value.get();
detail.onChoose(slider, thumb, value);
});
};
var wasDown = detail.mouseIsDown.get();
detail.mouseIsDown.set(false);
if (wasDown) {
fireOnChoose();
}
};
var onDragStart = function (slider, simulatedEvent) {
simulatedEvent.stop();
detail.mouseIsDown.set(true);
detail.onDragStart(slider, getThumb(slider));
};
var onDragEnd = function (slider, simulatedEvent) {
simulatedEvent.stop();
detail.onDragEnd(slider, getThumb(slider));
choose(slider);
};
return {
uid: detail.uid,
dom: detail.dom,
components: components,
behaviours: augment(detail.sliderBehaviours, [
Keying.config({
mode: 'special',
focusIn: function (slider) {
return getPart(slider, detail, 'spectrum').map(Keying.focusIn).map(always);
}
}),
Representing.config({
store: {
mode: 'manual',
getValue: function (_) {
return modelDetail.value.get();
}
}
}),
Receiving.config({ channels: (_a = {}, _a[mouseReleased()] = { onReceive: choose }, _a) })
]),
events: derive$3([
run(sliderChangeEvent(), function (slider, simulatedEvent) {
changeValue(slider, simulatedEvent.event.value);
}),
runOnAttached(function (slider, _simulatedEvent) {
var getInitial = modelDetail.getInitialValue();
modelDetail.value.set(getInitial);
var thumb = getThumb(slider);
refresh(slider, thumb);
var spectrum = getSpectrum(slider);
detail.onInit(slider, thumb, spectrum, modelDetail.value.get());
}),
run(touchstart(), onDragStart),
run(touchend(), onDragEnd),
run(mousedown(), onDragStart),
run(mouseup(), onDragEnd)
]),
apis: {
resetToMin: resetToMin,
resetToMax: resetToMax,
setValue: setValue,
refresh: refresh
},
domModification: { styles: { position: 'relative' } }
};
};
var Slider = composite({
name: 'Slider',
configFields: SliderSchema,
partFields: SliderParts,
factory: sketch$9,
apis: {
setValue: function (apis, slider, value) {
apis.setValue(slider, value);
},
resetToMin: function (apis, slider) {
apis.resetToMin(slider);
},
resetToMax: function (apis, slider) {
apis.resetToMax(slider);
},
refresh: function (apis, slider) {
apis.refresh(slider);
}
}
});
var button = function (realm, clazz, makeItems, editor) {
return forToolbar(clazz, function () {
var items = makeItems();
realm.setContextToolbar([{
label: clazz + ' group',
items: items
}]);
}, {}, editor);
};
var BLACK = -1;
var makeSlider$1 = function (spec$1) {
var getColor = function (hue) {
if (hue < 0) {
return 'black';
} else if (hue > 360) {
return 'white';
} else {
return 'hsl(' + hue + ', 100%, 50%)';
}
};
var onInit = function (slider, thumb, spectrum, value) {
var color = getColor(value.x());
set$5(thumb.element, 'background-color', color);
};
var onChange = function (slider, thumb, value) {
var color = getColor(value.x());
set$5(thumb.element, 'background-color', color);
spec$1.onChange(slider, thumb, color);
};
return Slider.sketch({
dom: dom$1('<div class="${prefix}-slider ${prefix}-hue-slider-container"></div>'),
components: [
Slider.parts['left-edge'](spec('<div class="${prefix}-hue-slider-black"></div>')),
Slider.parts.spectrum({
dom: dom$1('<div class="${prefix}-slider-gradient-container"></div>'),
components: [spec('<div class="${prefix}-slider-gradient"></div>')],
behaviours: derive$2([Toggling.config({ toggleClass: resolve('thumb-active') })])
}),
Slider.parts['right-edge'](spec('<div class="${prefix}-hue-slider-white"></div>')),
Slider.parts.thumb({
dom: dom$1('<div class="${prefix}-slider-thumb"></div>'),
behaviours: derive$2([Toggling.config({ toggleClass: resolve('thumb-active') })])
})
],
onChange: onChange,
onDragStart: function (slider, thumb) {
Toggling.on(thumb);
},
onDragEnd: function (slider, thumb) {
Toggling.off(thumb);
},
onInit: onInit,
stepSize: 10,
model: {
mode: 'x',
minX: 0,
maxX: 360,
getInitialValue: function () {
return { x: spec$1.getInitialValue() };
}
},
sliderBehaviours: derive$2([orientation(Slider.refresh)])
});
};
var makeItems$1 = function (spec) {
return [makeSlider$1(spec)];
};
var sketch$8 = function (realm, editor) {
var spec = {
onChange: function (slider, thumb, color) {
editor.undoManager.transact(function () {
editor.formatter.apply('forecolor', { value: color });
editor.nodeChanged();
});
},
getInitialValue: constant$1(BLACK)
};
return button(realm, 'color-levels', function () {
return makeItems$1(spec);
}, editor);
};
var candidatesArray = [
'9px',
'10px',
'11px',
'12px',
'14px',
'16px',
'18px',
'20px',
'24px',
'32px',
'36px'
];
var defaultSize = 'medium';
var defaultIndex = 2;
var indexToSize = function (index) {
return Optional.from(candidatesArray[index]);
};
var sizeToIndex = function (size) {
return findIndex$1(candidatesArray, function (v) {
return v === size;
});
};
var getRawOrComputed = function (isRoot, rawStart) {
var optStart = isElement(rawStart) ? Optional.some(rawStart) : parent(rawStart).filter(isElement);
return optStart.map(function (start) {
var inline = closest$2(start, function (elem) {
return getRaw(elem, 'font-size').isSome();
}, isRoot).bind(function (elem) {
return getRaw(elem, 'font-size');
});
return inline.getOrThunk(function () {
return get$8(start, 'font-size');
});
}).getOr('');
};
var getSize = function (editor) {
var node = editor.selection.getStart();
var elem = SugarElement.fromDom(node);
var root = SugarElement.fromDom(editor.getBody());
var isRoot = function (e) {
return eq(root, e);
};
var elemSize = getRawOrComputed(isRoot, elem);
return find$2(candidatesArray, function (size) {
return elemSize === size;
}).getOr(defaultSize);
};
var applySize = function (editor, value) {
var currentValue = getSize(editor);
if (currentValue !== value) {
editor.execCommand('fontSize', false, value);
}
};
var get$4 = function (editor) {
var size = getSize(editor);
return sizeToIndex(size).getOr(defaultIndex);
};
var apply = function (editor, index) {
indexToSize(index).each(function (size) {
applySize(editor, size);
});
};
var candidates = constant$1(candidatesArray);
var schema$9 = objOfOnly([
required$1('getInitialValue'),
required$1('onChange'),
required$1('category'),
required$1('sizes')
]);
var sketch$7 = function (rawSpec) {
var spec$1 = asRawOrDie$1('SizeSlider', schema$9, rawSpec);
var isValidValue = function (valueIndex) {
return valueIndex >= 0 && valueIndex < spec$1.sizes.length;
};
var onChange = function (slider, thumb, valueIndex) {
var index = valueIndex.x();
if (isValidValue(index)) {
spec$1.onChange(index);
}
};
return Slider.sketch({
dom: {
tag: 'div',
classes: [
resolve('slider-' + spec$1.category + '-size-container'),
resolve('slider'),
resolve('slider-size-container')
]
},
onChange: onChange,
onDragStart: function (slider, thumb) {
Toggling.on(thumb);
},
onDragEnd: function (slider, thumb) {
Toggling.off(thumb);
},
model: {
mode: 'x',
minX: 0,
maxX: spec$1.sizes.length - 1,
getInitialValue: function () {
return { x: spec$1.getInitialValue() };
}
},
stepSize: 1,
snapToGrid: true,
sliderBehaviours: derive$2([orientation(Slider.refresh)]),
components: [
Slider.parts.spectrum({
dom: dom$1('<div class="${prefix}-slider-size-container"></div>'),
components: [spec('<div class="${prefix}-slider-size-line"></div>')]
}),
Slider.parts.thumb({
dom: dom$1('<div class="${prefix}-slider-thumb"></div>'),
behaviours: derive$2([Toggling.config({ toggleClass: resolve('thumb-active') })])
})
]
});
};
var sizes = candidates();
var makeSlider = function (spec) {
return sketch$7({
onChange: spec.onChange,
sizes: sizes,
category: 'font',
getInitialValue: spec.getInitialValue
});
};
var makeItems = function (spec$1) {
return [
spec('<span class="${prefix}-toolbar-button ${prefix}-icon-small-font ${prefix}-icon"></span>'),
makeSlider(spec$1),
spec('<span class="${prefix}-toolbar-button ${prefix}-icon-large-font ${prefix}-icon"></span>')
];
};
var sketch$6 = function (realm, editor) {
var spec = {
onChange: function (value) {
apply(editor, value);
},
getInitialValue: function () {
return get$4(editor);
}
};
return button(realm, 'font-size', function () {
return makeItems(spec);
}, editor);
};
var record = function (spec) {
var uid = isSketchSpec$1(spec) && hasNonNullableKey(spec, 'uid') ? spec.uid : generate$2('memento');
var get = function (anyInSystem) {
return anyInSystem.getSystem().getByUid(uid).getOrDie();
};
var getOpt = function (anyInSystem) {
return anyInSystem.getSystem().getByUid(uid).toOptional();
};
var asSpec = function () {
return __assign(__assign({}, spec), { uid: uid });
};
return {
get: get,
getOpt: getOpt,
asSpec: asSpec
};
};
var exports$1 = {}, module = { 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));
var Promise$1 = module.exports.boltExport;
var blobToDataUri = function (blob) {
return new Promise$1(function (resolve) {
var reader = new FileReader();
reader.onloadend = function () {
resolve(reader.result);
};
reader.readAsDataURL(blob);
});
};
var blobToBase64$1 = function (blob) {
return blobToDataUri(blob).then(function (dataUri) {
return dataUri.split(',')[1];
});
};
var blobToBase64 = function (blob) {
return blobToBase64$1(blob);
};
var addImage = function (editor, blob) {
blobToBase64(blob).then(function (base64) {
editor.undoManager.transact(function () {
var cache = editor.editorUpload.blobCache;
var info = cache.create(generate$4('mceu'), blob, base64);
cache.add(info);
var img = editor.dom.createHTML('img', { src: info.blobUri() });
editor.insertContent(img);
});
});
};
var extractBlob = function (simulatedEvent) {
var event = simulatedEvent.event.raw;
var files = event.target.files || event.dataTransfer.files;
return Optional.from(files[0]);
};
var sketch$5 = function (editor) {
var pickerDom = {
tag: 'input',
attributes: {
accept: 'image/*',
type: 'file',
title: ''
},
styles: {
visibility: 'hidden',
position: 'absolute'
}
};
var memPicker = record({
dom: pickerDom,
events: derive$3([
cutter(click()),
run(change(), function (picker, simulatedEvent) {
extractBlob(simulatedEvent).each(function (blob) {
addImage(editor, blob);
});
})
])
});
return Button.sketch({
dom: getToolbarIconButton('image', editor),
components: [memPicker.asSpec()],
action: function (button) {
var picker = memPicker.get(button);
picker.element.dom.click();
}
});
};
var get$3 = function (element) {
return element.dom.textContent;
};
var set$3 = function (element, value) {
element.dom.textContent = value;
};
var isNotEmpty = function (val) {
return val.length > 0;
};
var defaultToEmpty = function (str) {
return str === undefined || str === null ? '' : str;
};
var noLink = function (editor) {
var text = editor.selection.getContent({ format: 'text' });
return {
url: '',
text: text,
title: '',
target: '',
link: Optional.none()
};
};
var fromLink = function (link) {
var text = get$3(link);
var url = get$b(link, 'href');
var title = get$b(link, 'title');
var target = get$b(link, 'target');
return {
url: defaultToEmpty(url),
text: text !== url ? defaultToEmpty(text) : '',
title: defaultToEmpty(title),
target: defaultToEmpty(target),
link: Optional.some(link)
};
};
var getInfo = function (editor) {
return query(editor).fold(function () {
return noLink(editor);
}, function (link) {
return fromLink(link);
});
};
var wasSimple = function (link) {
var prevHref = get$b(link, 'href');
var prevText = get$3(link);
return prevHref === prevText;
};
var getTextToApply = function (link, url, info) {
return info.text.toOptional().filter(isNotEmpty).fold(function () {
return wasSimple(link) ? Optional.some(url) : Optional.none();
}, Optional.some);
};
var unlinkIfRequired = function (editor, info) {
var activeLink = info.link.bind(identity);
activeLink.each(function (_link) {
editor.execCommand('unlink');
});
};
var getAttrs = function (url, info) {
var attrs = {};
attrs.href = url;
info.title.toOptional().filter(isNotEmpty).each(function (title) {
attrs.title = title;
});
info.target.toOptional().filter(isNotEmpty).each(function (target) {
attrs.target = target;
});
return attrs;
};
var applyInfo = function (editor, info) {
info.url.toOptional().filter(isNotEmpty).fold(function () {
unlinkIfRequired(editor, info);
}, function (url) {
var attrs = getAttrs(url, info);
var activeLink = info.link.bind(identity);
activeLink.fold(function () {
var text = info.text.toOptional().filter(isNotEmpty).getOr(url);
editor.insertContent(editor.dom.createHTML('a', attrs, editor.dom.encode(text)));
}, function (link) {
var text = getTextToApply(link, url, info);
setAll$1(link, attrs);
text.each(function (newText) {
set$3(link, newText);
});
});
});
};
var query = function (editor) {
var start = SugarElement.fromDom(editor.selection.getStart());
return closest$1(start, 'a');
};
var platform = detect$1();
var preserve$1 = function (f, editor) {
var rng = editor.selection.getRng();
f();
editor.selection.setRng(rng);
};
var forAndroid = function (editor, f) {
var wrapper = platform.os.isAndroid() ? preserve$1 : apply$1;
wrapper(f, editor);
};
var events$4 = function (name, eventHandlers) {
var events = derive$3(eventHandlers);
return create$5({
fields: [required$1('enabled')],
name: name,
active: { events: constant$1(events) }
});
};
var config = function (name, eventHandlers) {
var me = events$4(name, eventHandlers);
return {
key: name,
value: {
config: {},
me: me,
configAsRaw: constant$1({}),
initialConfig: {},
state: NoState
}
};
};
var getCurrent = function (component, composeConfig, _composeState) {
return composeConfig.find(component);
};
var ComposeApis = /*#__PURE__*/Object.freeze({
__proto__: null,
getCurrent: getCurrent
});
var ComposeSchema = [required$1('find')];
var Composing = create$5({
fields: ComposeSchema,
name: 'composing',
apis: ComposeApis
});
var factory$4 = function (detail) {
var _a = detail.dom, attributes = _a.attributes, domWithoutAttributes = __rest(_a, ['attributes']);
return {
uid: detail.uid,
dom: __assign({
tag: 'div',
attributes: __assign({ role: 'presentation' }, attributes)
}, domWithoutAttributes),
components: detail.components,
behaviours: get$6(detail.containerBehaviours),
events: detail.events,
domModification: detail.domModification,
eventOrder: detail.eventOrder
};
};
var Container = single({
name: 'Container',
factory: factory$4,
configFields: [
defaulted('components', []),
field$1('containerBehaviours', []),
defaulted('events', {}),
defaulted('domModification', {}),
defaulted('eventOrder', {})
]
});
var factory$3 = function (detail) {
return {
uid: detail.uid,
dom: detail.dom,
behaviours: SketchBehaviours.augment(detail.dataBehaviours, [
Representing.config({
store: {
mode: 'memory',
initialValue: detail.getInitialValue()
}
}),
Composing.config({ find: Optional.some })
]),
events: derive$3([runOnAttached(function (component, _simulatedEvent) {
Representing.setValue(component, detail.getInitialValue());
})])
};
};
var DataField = single({
name: 'DataField',
factory: factory$3,
configFields: [
required$1('uid'),
required$1('dom'),
required$1('getInitialValue'),
SketchBehaviours.field('dataBehaviours', [
Representing,
Composing
])
]
});
var get$2 = function (element) {
return element.dom.value;
};
var set$2 = function (element, value) {
if (value === undefined) {
throw new Error('Value.set was undefined');
}
element.dom.value = value;
};
var schema$8 = constant$1([
option('data'),
defaulted('inputAttributes', {}),
defaulted('inputStyles', {}),
defaulted('tag', 'input'),
defaulted('inputClasses', []),
onHandler('onSetValue'),
defaulted('styles', {}),
defaulted('eventOrder', {}),
field$1('inputBehaviours', [
Representing,
Focusing
]),
defaulted('selectOnFocus', true)
]);
var focusBehaviours = function (detail) {
return derive$2([Focusing.config({
onFocus: !detail.selectOnFocus ? noop : function (component) {
var input = component.element;
var value = get$2(input);
input.dom.setSelectionRange(0, value.length);
}
})]);
};
var behaviours = function (detail) {
return __assign(__assign({}, focusBehaviours(detail)), augment(detail.inputBehaviours, [Representing.config({
store: __assign(__assign({ mode: 'manual' }, detail.data.map(function (data) {
return { initialValue: data };
}).getOr({})), {
getValue: function (input) {
return get$2(input.element);
},
setValue: function (input, data) {
var current = get$2(input.element);
if (current !== data) {
set$2(input.element, data);
}
}
}),
onSetValue: detail.onSetValue
})]));
};
var dom = function (detail) {
return {
tag: detail.tag,
attributes: __assign({ type: 'text' }, detail.inputAttributes),
styles: detail.inputStyles,
classes: detail.inputClasses
};
};
var factory$2 = function (detail, _spec) {
return {
uid: detail.uid,
dom: dom(detail),
components: [],
behaviours: behaviours(detail),
eventOrder: detail.eventOrder
};
};
var Input = single({
name: 'Input',
configFields: schema$8(),
factory: factory$2
});
var exhibit$2 = function (base, tabConfig) {
return nu$3({
attributes: wrapAll([{
key: tabConfig.tabAttr,
value: 'true'
}])
});
};
var ActiveTabstopping = /*#__PURE__*/Object.freeze({
__proto__: null,
exhibit: exhibit$2
});
var TabstopSchema = [defaulted('tabAttr', 'data-alloy-tabstop')];
var Tabstopping = create$5({
fields: TabstopSchema,
name: 'tabstopping',
active: ActiveTabstopping
});
var global$3 = tinymce.util.Tools.resolve('tinymce.util.I18n');
var clearInputBehaviour = 'input-clearing';
var field = function (name, placeholder) {
var inputSpec = record(Input.sketch({
inputAttributes: { placeholder: global$3.translate(placeholder) },
onSetValue: function (input, _data) {
emit(input, input$1());
},
inputBehaviours: derive$2([
Composing.config({ find: Optional.some }),
Tabstopping.config({}),
Keying.config({ mode: 'execution' })
]),
selectOnFocus: false
}));
var buttonSpec = record(Button.sketch({
dom: dom$1('<button class="${prefix}-input-container-x ${prefix}-icon-cancel-circle ${prefix}-icon"></button>'),
action: function (button) {
var input = inputSpec.get(button);
Representing.setValue(input, '');
}
}));
return {
name: name,
spec: Container.sketch({
dom: dom$1('<div class="${prefix}-input-container"></div>'),
components: [
inputSpec.asSpec(),
buttonSpec.asSpec()
],
containerBehaviours: derive$2([
Toggling.config({ toggleClass: resolve('input-container-empty') }),
Composing.config({
find: function (comp) {
return Optional.some(inputSpec.get(comp));
}
}),
config(clearInputBehaviour, [run(input$1(), function (iContainer) {
var input = inputSpec.get(iContainer);
var val = Representing.getValue(input);
var f = val.length > 0 ? Toggling.off : Toggling.on;
f(iContainer);
})])
])
})
};
};
var hidden = function (name) {
return {
name: name,
spec: DataField.sketch({
dom: {
tag: 'span',
styles: { display: 'none' }
},
getInitialValue: function () {
return Optional.none();
}
})
};
};
var nativeDisabled = [
'input',
'button',
'textarea',
'select'
];
var onLoad = function (component, disableConfig, disableState) {
var f = disableConfig.disabled() ? disable : enable;
f(component, disableConfig);
};
var hasNative = function (component, config) {
return config.useNative === true && contains$1(nativeDisabled, name$1(component.element));
};
var nativeIsDisabled = function (component) {
return has$1(component.element, 'disabled');
};
var nativeDisable = function (component) {
set$8(component.element, 'disabled', 'disabled');
};
var nativeEnable = function (component) {
remove$6(component.element, 'disabled');
};
var ariaIsDisabled = function (component) {
return get$b(component.element, 'aria-disabled') === 'true';
};
var ariaDisable = function (component) {
set$8(component.element, 'aria-disabled', 'true');
};
var ariaEnable = function (component) {
set$8(component.element, 'aria-disabled', 'false');
};
var disable = function (component, disableConfig, _disableState) {
disableConfig.disableClass.each(function (disableClass) {
add$1(component.element, disableClass);
});
var f = hasNative(component, disableConfig) ? nativeDisable : ariaDisable;
f(component);
disableConfig.onDisabled(component);
};
var enable = function (component, disableConfig, _disableState) {
disableConfig.disableClass.each(function (disableClass) {
remove$3(component.element, disableClass);
});
var f = hasNative(component, disableConfig) ? nativeEnable : ariaEnable;
f(component);
disableConfig.onEnabled(component);
};
var isDisabled = function (component, disableConfig) {
return hasNative(component, disableConfig) ? nativeIsDisabled(component) : ariaIsDisabled(component);
};
var set$1 = function (component, disableConfig, disableState, disabled) {
var f = disabled ? disable : enable;
f(component, disableConfig);
};
var DisableApis = /*#__PURE__*/Object.freeze({
__proto__: null,
enable: enable,
disable: disable,
isDisabled: isDisabled,
onLoad: onLoad,
set: set$1
});
var exhibit$1 = function (base, disableConfig) {
return nu$3({ classes: disableConfig.disabled() ? disableConfig.disableClass.toArray() : [] });
};
var events$3 = function (disableConfig, disableState) {
return derive$3([
abort(execute$5(), function (component, _simulatedEvent) {
return isDisabled(component, disableConfig);
}),
loadEvent(disableConfig, disableState, onLoad)
]);
};
var ActiveDisable = /*#__PURE__*/Object.freeze({
__proto__: null,
exhibit: exhibit$1,
events: events$3
});
var DisableSchema = [
defaultedFunction('disabled', never),
defaulted('useNative', true),
option('disableClass'),
onHandler('onDisabled'),
onHandler('onEnabled')
];
var Disabling = create$5({
fields: DisableSchema,
name: 'disabling',
active: ActiveDisable,
apis: DisableApis
});
var owner$1 = 'form';
var schema$7 = [field$1('formBehaviours', [Representing])];
var getPartName = function (name) {
return '<alloy.field.' + name + '>';
};
var sketch$4 = function (fSpec) {
var parts = function () {
var record = [];
var field = function (name, config) {
record.push(name);
return generateOne(owner$1, getPartName(name), config);
};
return {
field: field,
record: constant$1(record)
};
}();
var spec = fSpec(parts);
var partNames = parts.record();
var fieldParts = map$2(partNames, function (n) {
return required({
name: n,
pname: getPartName(n)
});
});
return composite$1(owner$1, schema$7, fieldParts, make$4, spec);
};
var toResult = function (o, e) {
return o.fold(function () {
return Result.error(e);
}, Result.value);
};
var make$4 = function (detail, components) {
return {
uid: detail.uid,
dom: detail.dom,
components: components,
behaviours: augment(detail.formBehaviours, [Representing.config({
store: {
mode: 'manual',
getValue: function (form) {
var resPs = getAllParts(form, detail);
return map$1(resPs, function (resPThunk, pName) {
return resPThunk().bind(function (v) {
var opt = Composing.getCurrent(v);
return toResult(opt, new Error('Cannot find a current component to extract the value from for form part \'' + pName + '\': ' + element(v.element)));
}).map(Representing.getValue);
});
},
setValue: function (form, values) {
each(values, function (newValue, key) {
getPart(form, detail, key).each(function (wrapper) {
Composing.getCurrent(wrapper).each(function (field) {
Representing.setValue(field, newValue);
});
});
});
}
}
})]),
apis: {
getField: function (form, key) {
return getPart(form, detail, key).bind(Composing.getCurrent);
}
}
};
};
var Form = {
getField: makeApi(function (apis, component, key) {
return apis.getField(component, key);
}),
sketch: sketch$4
};
var SWIPING_LEFT = 1;
var SWIPING_RIGHT = -1;
var SWIPING_NONE = 0;
var init$3 = function (xValue) {
return {
xValue: xValue,
points: []
};
};
var move = function (model, xValue) {
if (xValue === model.xValue) {
return model;
}
var currentDirection = xValue - model.xValue > 0 ? SWIPING_LEFT : SWIPING_RIGHT;
var newPoint = {
direction: currentDirection,
xValue: xValue
};
var priorPoints = function () {
if (model.points.length === 0) {
return [];
} else {
var prev = model.points[model.points.length - 1];
return prev.direction === currentDirection ? model.points.slice(0, model.points.length - 1) : model.points;
}
}();
return {
xValue: xValue,
points: priorPoints.concat([newPoint])
};
};
var complete = function (model) {
if (model.points.length === 0) {
return SWIPING_NONE;
} else {
var firstDirection = model.points[0].direction;
var lastDirection = model.points[model.points.length - 1].direction;
return firstDirection === SWIPING_RIGHT && lastDirection === SWIPING_RIGHT ? SWIPING_RIGHT : firstDirection === SWIPING_LEFT && lastDirection === SWIPING_LEFT ? SWIPING_LEFT : SWIPING_NONE;
}
};
var sketch$3 = function (rawSpec) {
var navigateEvent = 'navigateEvent';
var wrapperAdhocEvents = 'serializer-wrapper-events';
var formAdhocEvents = 'form-events';
var schema = objOf([
required$1('fields'),
defaulted('maxFieldIndex', rawSpec.fields.length - 1),
required$1('onExecute'),
required$1('getInitialValue'),
customField('state', function () {
return {
dialogSwipeState: value(),
currentScreen: Cell(0)
};
})
]);
var spec$1 = asRawOrDie$1('SerialisedDialog', schema, rawSpec);
var navigationButton = function (direction, directionName, enabled) {
return Button.sketch({
dom: dom$1('<span class="${prefix}-icon-' + directionName + ' ${prefix}-icon"></span>'),
action: function (button) {
emitWith(button, navigateEvent, { direction: direction });
},
buttonBehaviours: derive$2([Disabling.config({
disableClass: resolve('toolbar-navigation-disabled'),
disabled: function () {
return !enabled;
}
})])
});
};
var reposition = function (dialog, message) {
descendant(dialog.element, '.' + resolve('serialised-dialog-chain')).each(function (parent) {
set$5(parent, 'left', -spec$1.state.currentScreen.get() * message.width + 'px');
});
};
var navigate = function (dialog, direction) {
var screens = descendants(dialog.element, '.' + resolve('serialised-dialog-screen'));
descendant(dialog.element, '.' + resolve('serialised-dialog-chain')).each(function (parent) {
if (spec$1.state.currentScreen.get() + direction >= 0 && spec$1.state.currentScreen.get() + direction < screens.length) {
getRaw(parent, 'left').each(function (left) {
var currentLeft = parseInt(left, 10);
var w = get$5(screens[0]);
set$5(parent, 'left', currentLeft - direction * w + 'px');
});
spec$1.state.currentScreen.set(spec$1.state.currentScreen.get() + direction);
}
});
};
var focusInput = function (dialog) {
var inputs = descendants(dialog.element, 'input');
var optInput = Optional.from(inputs[spec$1.state.currentScreen.get()]);
optInput.each(function (input) {
dialog.getSystem().getByDom(input).each(function (inputComp) {
dispatchFocus(dialog, inputComp.element);
});
});
var dotitems = memDots.get(dialog);
Highlighting.highlightAt(dotitems, spec$1.state.currentScreen.get());
};
var resetState = function () {
spec$1.state.currentScreen.set(0);
spec$1.state.dialogSwipeState.clear();
};
var memForm = record(Form.sketch(function (parts) {
return {
dom: dom$1('<div class="${prefix}-serialised-dialog"></div>'),
components: [Container.sketch({
dom: dom$1('<div class="${prefix}-serialised-dialog-chain" style="left: 0px; position: absolute;"></div>'),
components: map$2(spec$1.fields, function (field, i) {
return i <= spec$1.maxFieldIndex ? Container.sketch({
dom: dom$1('<div class="${prefix}-serialised-dialog-screen"></div>'),
components: [
navigationButton(-1, 'previous', i > 0),
parts.field(field.name, field.spec),
navigationButton(+1, 'next', i < spec$1.maxFieldIndex)
]
}) : parts.field(field.name, field.spec);
})
})],
formBehaviours: derive$2([
orientation(function (dialog, message) {
reposition(dialog, message);
}),
Keying.config({
mode: 'special',
focusIn: function (dialog, _specialInfo) {
focusInput(dialog);
},
onTab: function (dialog, _specialInfo) {
navigate(dialog, +1);
return Optional.some(true);
},
onShiftTab: function (dialog, _specialInfo) {
navigate(dialog, -1);
return Optional.some(true);
}
}),
config(formAdhocEvents, [
runOnAttached(function (dialog, _simulatedEvent) {
resetState();
var dotitems = memDots.get(dialog);
Highlighting.highlightFirst(dotitems);
spec$1.getInitialValue(dialog).each(function (v) {
Representing.setValue(dialog, v);
});
}),
runOnExecute(spec$1.onExecute),
run(transitionend(), function (dialog, simulatedEvent) {
var event = simulatedEvent.event;
if (event.raw.propertyName === 'left') {
focusInput(dialog);
}
}),
run(navigateEvent, function (dialog, simulatedEvent) {
var event = simulatedEvent.event;
var direction = event.direction;
navigate(dialog, direction);
})
])
])
};
}));
var memDots = record({
dom: dom$1('<div class="${prefix}-dot-container"></div>'),
behaviours: derive$2([Highlighting.config({
highlightClass: resolve('dot-active'),
itemClass: resolve('dot-item')
})]),
components: bind$3(spec$1.fields, function (_f, i) {
return i <= spec$1.maxFieldIndex ? [spec('<div class="${prefix}-dot-item ${prefix}-icon-full-dot ${prefix}-icon"></div>')] : [];
})
});
return {
dom: dom$1('<div class="${prefix}-serializer-wrapper"></div>'),
components: [
memForm.asSpec(),
memDots.asSpec()
],
behaviours: derive$2([
Keying.config({
mode: 'special',
focusIn: function (wrapper) {
var form = memForm.get(wrapper);
Keying.focusIn(form);
}
}),
config(wrapperAdhocEvents, [
run(touchstart(), function (_wrapper, simulatedEvent) {
var event = simulatedEvent.event;
spec$1.state.dialogSwipeState.set(init$3(event.raw.touches[0].clientX));
}),
run(touchmove(), function (_wrapper, simulatedEvent) {
var event = simulatedEvent.event;
spec$1.state.dialogSwipeState.on(function (state) {
simulatedEvent.event.prevent();
spec$1.state.dialogSwipeState.set(move(state, event.raw.touches[0].clientX));
});
}),
run(touchend(), function (wrapper, _simulatedEvent) {
spec$1.state.dialogSwipeState.on(function (state) {
var dialog = memForm.get(wrapper);
var direction = -1 * complete(state);
navigate(dialog, direction);
});
})
])
])
};
};
var getGroups = cached(function (realm, editor) {
return [{
label: 'the link group',
items: [sketch$3({
fields: [
field('url', 'Type or paste URL'),
field('text', 'Link text'),
field('title', 'Link title'),
field('target', 'Link target'),
hidden('link')
],
maxFieldIndex: [
'url',
'text',
'title',
'target'
].length - 1,
getInitialValue: function () {
return Optional.some(getInfo(editor));
},
onExecute: function (dialog, _simulatedEvent) {
var info = Representing.getValue(dialog);
applyInfo(editor, info);
realm.restoreToolbar();
editor.focus();
}
})]
}];
});
var sketch$2 = function (realm, editor) {
return forToolbarStateAction(editor, 'link', 'link', function () {
var groups = getGroups(realm, editor);
realm.setContextToolbar(groups);
forAndroid(editor, function () {
realm.focusToolbar();
});
query(editor).each(function (link) {
editor.selection.select(link.dom);
});
});
};
var isRecursive = function (component, originator, target) {
return eq(originator, component.element) && !eq(originator, target);
};
var events$2 = derive$3([can(focus$4(), function (component, simulatedEvent) {
var event = simulatedEvent.event;
var originator = event.originator;
var target = event.target;
if (isRecursive(component, originator, target)) {
console.warn(focus$4() + ' did not get interpreted by the desired target. ' + '\nOriginator: ' + element(originator) + '\nTarget: ' + element(target) + '\nCheck the ' + focus$4() + ' event handlers');
return false;
} else {
return true;
}
})]);
var DefaultEvents = /*#__PURE__*/Object.freeze({
__proto__: null,
events: events$2
});
var make$3 = identity;
var NoContextApi = function (getComp) {
var getMessage = function (event) {
return 'The component must be in a context to execute: ' + event + (getComp ? '\n' + element(getComp().element) + ' is not in context.' : '');
};
var fail = function (event) {
return function () {
throw new Error(getMessage(event));
};
};
var warn = function (event) {
return function () {
console.warn(getMessage(event));
};
};
return {
debugInfo: constant$1('fake'),
triggerEvent: warn('triggerEvent'),
triggerFocus: warn('triggerFocus'),
triggerEscape: warn('triggerEscape'),
broadcast: warn('broadcast'),
broadcastOn: warn('broadcastOn'),
broadcastEvent: warn('broadcastEvent'),
build: fail('build'),
addToWorld: fail('addToWorld'),
removeFromWorld: fail('removeFromWorld'),
addToGui: fail('addToGui'),
removeFromGui: fail('removeFromGui'),
getByUid: fail('getByUid'),
getByDom: fail('getByDom'),
isConnected: never
};
};
var singleton = NoContextApi();
var generateFrom$1 = function (spec, all) {
var schema = map$2(all, function (a) {
return optionObjOf(a.name(), [
required$1('config'),
defaulted('state', NoState)
]);
});
var validated = asRaw('component.behaviours', objOf(schema), spec.behaviours).fold(function (errInfo) {
throw new Error(formatError(errInfo) + '\nComplete spec:\n' + JSON.stringify(spec, null, 2));
}, identity);
return {
list: all,
data: map$1(validated, function (optBlobThunk) {
var output = optBlobThunk.map(function (blob) {
return {
config: blob.config,
state: blob.state.init(blob.config)
};
});
return constant$1(output);
})
};
};
var getBehaviours$1 = function (bData) {
return bData.list;
};
var getData = function (bData) {
return bData.data;
};
var byInnerKey = function (data, tuple) {
var r = {};
each(data, function (detail, key) {
each(detail, function (value, indexKey) {
var chain = get$c(r, indexKey).getOr([]);
r[indexKey] = chain.concat([tuple(key, value)]);
});
});
return r;
};
var combine$1 = function (info, baseMod, behaviours, base) {
var modsByBehaviour = __assign({}, baseMod);
each$1(behaviours, function (behaviour) {
modsByBehaviour[behaviour.name()] = behaviour.exhibit(info, base);
});
var byAspect = byInnerKey(modsByBehaviour, function (name, modification) {
return {
name: name,
modification: modification
};
});
var combineObjects = function (objects) {
return foldr(objects, function (b, a) {
return __assign(__assign({}, a.modification), b);
}, {});
};
var combinedClasses = foldr(byAspect.classes, function (b, a) {
return a.modification.concat(b);
}, []);
var combinedAttributes = combineObjects(byAspect.attributes);
var combinedStyles = combineObjects(byAspect.styles);
return nu$3({
classes: combinedClasses,
attributes: combinedAttributes,
styles: combinedStyles
});
};
var sortKeys = function (label, keyName, array, order) {
try {
var sorted = sort(array, function (a, b) {
var aKey = a[keyName];
var bKey = b[keyName];
var aIndex = order.indexOf(aKey);
var bIndex = order.indexOf(bKey);
if (aIndex === -1) {
throw new Error('The ordering for ' + label + ' does not have an entry for ' + aKey + '.\nOrder specified: ' + JSON.stringify(order, null, 2));
}
if (bIndex === -1) {
throw new Error('The ordering for ' + label + ' does not have an entry for ' + bKey + '.\nOrder specified: ' + JSON.stringify(order, null, 2));
}
if (aIndex < bIndex) {
return -1;
} else if (bIndex < aIndex) {
return 1;
} else {
return 0;
}
});
return Result.value(sorted);
} catch (err) {
return Result.error([err]);
}
};
var uncurried = function (handler, purpose) {
return {
handler: handler,
purpose: purpose
};
};
var curried = function (handler, purpose) {
return {
cHandler: handler,
purpose: purpose
};
};
var curryArgs = function (descHandler, extraArgs) {
return curried(curry.apply(undefined, [descHandler.handler].concat(extraArgs)), descHandler.purpose);
};
var getCurried = function (descHandler) {
return descHandler.cHandler;
};
var behaviourTuple = function (name, handler) {
return {
name: name,
handler: handler
};
};
var nameToHandlers = function (behaviours, info) {
var r = {};
each$1(behaviours, function (behaviour) {
r[behaviour.name()] = behaviour.handlers(info);
});
return r;
};
var groupByEvents = function (info, behaviours, base) {
var behaviourEvents = __assign(__assign({}, base), nameToHandlers(behaviours, info));
return byInnerKey(behaviourEvents, behaviourTuple);
};
var combine = function (info, eventOrder, behaviours, base) {
var byEventName = groupByEvents(info, behaviours, base);
return combineGroups(byEventName, eventOrder);
};
var assemble = function (rawHandler) {
var handler = read$1(rawHandler);
return function (component, simulatedEvent) {
var rest = [];
for (var _i = 2; _i < arguments.length; _i++) {
rest[_i - 2] = arguments[_i];
}
var args = [
component,
simulatedEvent
].concat(rest);
if (handler.abort.apply(undefined, args)) {
simulatedEvent.stop();
} else if (handler.can.apply(undefined, args)) {
handler.run.apply(undefined, args);
}
};
};
var missingOrderError = function (eventName, tuples) {
return Result.error(['The event (' + eventName + ') has more than one behaviour that listens to it.\nWhen this occurs, you must ' + 'specify an event ordering for the behaviours in your spec (e.g. [ "listing", "toggling" ]).\nThe behaviours that ' + 'can trigger it are: ' + JSON.stringify(map$2(tuples, function (c) {
return c.name;
}), null, 2)]);
};
var fuse = function (tuples, eventOrder, eventName) {
var order = eventOrder[eventName];
if (!order) {
return missingOrderError(eventName, tuples);
} else {
return sortKeys('Event: ' + eventName, 'name', tuples, order).map(function (sortedTuples) {
var handlers = map$2(sortedTuples, function (tuple) {
return tuple.handler;
});
return fuse$1(handlers);
});
}
};
var combineGroups = function (byEventName, eventOrder) {
var r = mapToArray(byEventName, function (tuples, eventName) {
var combined = tuples.length === 1 ? Result.value(tuples[0].handler) : fuse(tuples, eventOrder, eventName);
return combined.map(function (handler) {
var assembled = assemble(handler);
var purpose = tuples.length > 1 ? filter$2(eventOrder[eventName], function (o) {
return exists(tuples, function (t) {
return t.name === o;
});
}).join(' > ') : tuples[0].name;
return wrap(eventName, uncurried(assembled, purpose));
});
});
return consolidate(r, {});
};
var _a;
var baseBehaviour = 'alloy.base.behaviour';
var schema$6 = objOf([
field$2('dom', 'dom', required$2(), objOf([
required$1('tag'),
defaulted('styles', {}),
defaulted('classes', []),
defaulted('attributes', {}),
option('value'),
option('innerHtml')
])),
required$1('components'),
required$1('uid'),
defaulted('events', {}),
defaulted('apis', {}),
field$2('eventOrder', 'eventOrder', mergeWith((_a = {}, _a[execute$5()] = [
'disabling',
baseBehaviour,
'toggling',
'typeaheadevents'
], _a[focus$4()] = [
baseBehaviour,
'focusing',
'keying'
], _a[systemInit()] = [
baseBehaviour,
'disabling',
'toggling',
'representing'
], _a[input$1()] = [
baseBehaviour,
'representing',
'streaming',
'invalidating'
], _a[detachedFromDom()] = [
baseBehaviour,
'representing',
'item-events',
'tooltipping'
], _a[mousedown()] = [
'focusing',
baseBehaviour,
'item-type-events'
], _a[touchstart()] = [
'focusing',
baseBehaviour,
'item-type-events'
], _a[mouseover()] = [
'item-type-events',
'tooltipping'
], _a[receive$1()] = [
'receiving',
'reflecting',
'tooltipping'
], _a)), anyValue()),
option('domModification')
]);
var toInfo = function (spec) {
return asRaw('custom.definition', schema$6, spec);
};
var toDefinition = function (detail) {
return __assign(__assign({}, detail.dom), {
uid: detail.uid,
domChildren: map$2(detail.components, function (comp) {
return comp.element;
})
});
};
var toModification = function (detail) {
return detail.domModification.fold(function () {
return nu$3({});
}, nu$3);
};
var toEvents = function (info) {
return info.events;
};
var add = function (element, classes) {
each$1(classes, function (x) {
add$1(element, x);
});
};
var remove$1 = function (element, classes) {
each$1(classes, function (x) {
remove$3(element, x);
});
};
var renderToDom = function (definition) {
var subject = SugarElement.fromTag(definition.tag);
setAll$1(subject, definition.attributes);
add(subject, definition.classes);
setAll(subject, definition.styles);
definition.innerHtml.each(function (html) {
return set$7(subject, html);
});
var children = definition.domChildren;
append$1(subject, children);
definition.value.each(function (value) {
set$2(subject, value);
});
if (!definition.uid) {
debugger;
}
writeOnly(subject, definition.uid);
return subject;
};
var getBehaviours = function (spec) {
var behaviours = get$c(spec, 'behaviours').getOr({});
return bind$3(keys(behaviours), function (name) {
var behaviour = behaviours[name];
return isNonNullable(behaviour) ? [behaviour.me] : [];
});
};
var generateFrom = function (spec, all) {
return generateFrom$1(spec, all);
};
var generate$1 = function (spec) {
var all = getBehaviours(spec);
return generateFrom(spec, all);
};
var getDomDefinition = function (info, bList, bData) {
var definition = toDefinition(info);
var infoModification = toModification(info);
var baseModification = { 'alloy.base.modification': infoModification };
var modification = bList.length > 0 ? combine$1(bData, baseModification, bList, definition) : infoModification;
return merge(definition, modification);
};
var getEvents = function (info, bList, bData) {
var baseEvents = { 'alloy.base.behaviour': toEvents(info) };
return combine(bData, info.eventOrder, bList, baseEvents).getOrDie();
};
var build$2 = function (spec) {
var getMe = function () {
return me;
};
var systemApi = Cell(singleton);
var info = getOrDie(toInfo(spec));
var bBlob = generate$1(spec);
var bList = getBehaviours$1(bBlob);
var bData = getData(bBlob);
var modDefinition = getDomDefinition(info, bList, bData);
var item = renderToDom(modDefinition);
var events = getEvents(info, bList, bData);
var subcomponents = Cell(info.components);
var connect = function (newApi) {
systemApi.set(newApi);
};
var disconnect = function () {
systemApi.set(NoContextApi(getMe));
};
var syncComponents = function () {
var children$1 = children(item);
var subs = bind$3(children$1, function (child) {
return systemApi.get().getByDom(child).fold(function () {
return [];
}, pure$2);
});
subcomponents.set(subs);
};
var config = function (behaviour) {
var b = bData;
var f = isFunction(b[behaviour.name()]) ? b[behaviour.name()] : function () {
throw new Error('Could not find ' + behaviour.name() + ' in ' + JSON.stringify(spec, null, 2));
};
return f();
};
var hasConfigured = function (behaviour) {
return isFunction(bData[behaviour.name()]);
};
var getApis = function () {
return info.apis;
};
var readState = function (behaviourName) {
return bData[behaviourName]().map(function (b) {
return b.state.readState();
}).getOr('not enabled');
};
var me = {
uid: spec.uid,
getSystem: systemApi.get,
config: config,
hasConfigured: hasConfigured,
spec: spec,
readState: readState,
getApis: getApis,
connect: connect,
disconnect: disconnect,
element: item,
syncComponents: syncComponents,
components: subcomponents.get,
events: events
};
return me;
};
var buildSubcomponents = function (spec) {
var components = get$c(spec, 'components').getOr([]);
return map$2(components, build$1);
};
var buildFromSpec = function (userSpec) {
var _a = make$3(userSpec), specEvents = _a.events, spec = __rest(_a, ['events']);
var components = buildSubcomponents(spec);
var completeSpec = __assign(__assign({}, spec), {
events: __assign(__assign({}, DefaultEvents), specEvents),
components: components
});
return Result.value(build$2(completeSpec));
};
var text = function (textContent) {
var element = SugarElement.fromText(textContent);
return external({ element: element });
};
var external = function (spec) {
var extSpec = asRawOrDie$1('external.component', objOfOnly([
required$1('element'),
option('uid')
]), spec);
var systemApi = Cell(NoContextApi());
var connect = function (newApi) {
systemApi.set(newApi);
};
var disconnect = function () {
systemApi.set(NoContextApi(function () {
return me;
}));
};
var uid = extSpec.uid.getOrThunk(function () {
return generate$2('external');
});
writeOnly(extSpec.element, uid);
var me = {
uid: uid,
getSystem: systemApi.get,
config: Optional.none,
hasConfigured: never,
connect: connect,
disconnect: disconnect,
getApis: function () {
return {};
},
element: extSpec.element,
spec: spec,
readState: constant$1('No state'),
syncComponents: noop,
components: constant$1([]),
events: {}
};
return premade$1(me);
};
var uids = generate$2;
var isSketchSpec = function (spec) {
return has$2(spec, 'uid');
};
var build$1 = function (spec) {
return getPremade(spec).getOrThunk(function () {
var userSpecWithUid = isSketchSpec(spec) ? spec : __assign({ uid: uids('') }, spec);
return buildFromSpec(userSpecWithUid).getOrDie();
});
};
var premade = premade$1;
var hoverEvent = 'alloy.item-hover';
var focusEvent = 'alloy.item-focus';
var onHover = function (item) {
if (search(item.element).isNone() || Focusing.isFocused(item)) {
if (!Focusing.isFocused(item)) {
Focusing.focus(item);
}
emitWith(item, hoverEvent, { item: item });
}
};
var onFocus = function (item) {
emitWith(item, focusEvent, { item: item });
};
var hover = constant$1(hoverEvent);
var focus$1 = constant$1(focusEvent);
var builder$2 = function (detail) {
return {
dom: detail.dom,
domModification: __assign(__assign({}, detail.domModification), { attributes: __assign(__assign(__assign({ 'role': detail.toggling.isSome() ? 'menuitemcheckbox' : 'menuitem' }, detail.domModification.attributes), { 'aria-haspopup': detail.hasSubmenu }), detail.hasSubmenu ? { 'aria-expanded': false } : {}) }),
behaviours: SketchBehaviours.augment(detail.itemBehaviours, [
detail.toggling.fold(Toggling.revoke, function (tConfig) {
return Toggling.config(__assign({ aria: { mode: 'checked' } }, tConfig));
}),
Focusing.config({
ignore: detail.ignoreFocus,
stopMousedown: detail.ignoreFocus,
onFocus: function (component) {
onFocus(component);
}
}),
Keying.config({ mode: 'execution' }),
Representing.config({
store: {
mode: 'memory',
initialValue: detail.data
}
}),
config('item-type-events', __spreadArray(__spreadArray([], pointerEvents(), true), [
run(mouseover(), onHover),
run(focusItem(), Focusing.focus)
], false))
]),
components: detail.components,
eventOrder: detail.eventOrder
};
};
var schema$5 = [
required$1('data'),
required$1('components'),
required$1('dom'),
defaulted('hasSubmenu', false),
option('toggling'),
SketchBehaviours.field('itemBehaviours', [
Toggling,
Focusing,
Keying,
Representing
]),
defaulted('ignoreFocus', false),
defaulted('domModification', {}),
output('builder', builder$2),
defaulted('eventOrder', {})
];
var builder$1 = function (detail) {
return {
dom: detail.dom,
components: detail.components,
events: derive$3([stopper(focusItem())])
};
};
var schema$4 = [
required$1('dom'),
required$1('components'),
output('builder', builder$1)
];
var owner = constant$1('item-widget');
var parts$3 = constant$1([required({
name: 'widget',
overrides: function (detail) {
return {
behaviours: derive$2([Representing.config({
store: {
mode: 'manual',
getValue: function (_component) {
return detail.data;
},
setValue: noop
}
})])
};
}
})]);
var builder = function (detail) {
var subs = substitutes(owner(), detail, parts$3());
var components$1 = components(owner(), detail, subs.internals());
var focusWidget = function (component) {
return getPart(component, detail, 'widget').map(function (widget) {
Keying.focusIn(widget);
return widget;
});
};
var onHorizontalArrow = function (component, simulatedEvent) {
return inside(simulatedEvent.event.target) ? Optional.none() : function () {
if (detail.autofocus) {
simulatedEvent.setSource(component.element);
return Optional.none();
} else {
return Optional.none();
}
}();
};
return {
dom: detail.dom,
components: components$1,
domModification: detail.domModification,
events: derive$3([
runOnExecute(function (component, simulatedEvent) {
focusWidget(component).each(function (_widget) {
simulatedEvent.stop();
});
}),
run(mouseover(), onHover),
run(focusItem(), function (component, _simulatedEvent) {
if (detail.autofocus) {
focusWidget(component);
} else {
Focusing.focus(component);
}
})
]),
behaviours: SketchBehaviours.augment(detail.widgetBehaviours, [
Representing.config({
store: {
mode: 'memory',
initialValue: detail.data
}
}),
Focusing.config({
ignore: detail.ignoreFocus,
onFocus: function (component) {
onFocus(component);
}
}),
Keying.config({
mode: 'special',
focusIn: detail.autofocus ? function (component) {
focusWidget(component);
} : revoke(),
onLeft: onHorizontalArrow,
onRight: onHorizontalArrow,
onEscape: function (component, simulatedEvent) {
if (!Focusing.isFocused(component) && !detail.autofocus) {
Focusing.focus(component);
return Optional.some(true);
} else if (detail.autofocus) {
simulatedEvent.setSource(component.element);
return Optional.none();
} else {
return Optional.none();
}
}
})
])
};
};
var schema$3 = [
required$1('uid'),
required$1('data'),
required$1('components'),
required$1('dom'),
defaulted('autofocus', false),
defaulted('ignoreFocus', false),
SketchBehaviours.field('widgetBehaviours', [
Representing,
Focusing,
Keying
]),
defaulted('domModification', {}),
defaultUidsSchema(parts$3()),
output('builder', builder)
];
var itemSchema = choose$1('type', {
widget: schema$3,
item: schema$5,
separator: schema$4
});
var configureGrid = function (detail, movementInfo) {
return {
mode: 'flatgrid',
selector: '.' + detail.markers.item,
initSize: {
numColumns: movementInfo.initSize.numColumns,
numRows: movementInfo.initSize.numRows
},
focusManager: detail.focusManager
};
};
var configureMatrix = function (detail, movementInfo) {
return {
mode: 'matrix',
selectors: {
row: movementInfo.rowSelector,
cell: '.' + detail.markers.item
},
focusManager: detail.focusManager
};
};
var configureMenu = function (detail, movementInfo) {
return {
mode: 'menu',
selector: '.' + detail.markers.item,
moveOnTab: movementInfo.moveOnTab,
focusManager: detail.focusManager
};
};
var parts$2 = constant$1([group({
factory: {
sketch: function (spec) {
var itemInfo = asRawOrDie$1('menu.spec item', itemSchema, spec);
return itemInfo.builder(itemInfo);
}
},
name: 'items',
unit: 'item',
defaults: function (detail, u) {
return has$2(u, 'uid') ? u : __assign(__assign({}, u), { uid: generate$2('item') });
},
overrides: function (detail, u) {
return {
type: u.type,
ignoreFocus: detail.fakeFocus,
domModification: { classes: [detail.markers.item] }
};
}
})]);
var schema$2 = constant$1([
required$1('value'),
required$1('items'),
required$1('dom'),
required$1('components'),
defaulted('eventOrder', {}),
field$1('menuBehaviours', [
Highlighting,
Representing,
Composing,
Keying
]),
defaultedOf('movement', {
mode: 'menu',
moveOnTab: true
}, choose$1('mode', {
grid: [
initSize(),
output('config', configureGrid)
],
matrix: [
output('config', configureMatrix),
required$1('rowSelector')
],
menu: [
defaulted('moveOnTab', true),
output('config', configureMenu)
]
})),
itemMarkers(),
defaulted('fakeFocus', false),
defaulted('focusManager', dom$2()),
onHandler('onHighlight')
]);
var focus = constant$1('alloy.menu-focus');
var make$2 = function (detail, components, _spec, _externals) {
return {
uid: detail.uid,
dom: detail.dom,
markers: detail.markers,
behaviours: augment(detail.menuBehaviours, [
Highlighting.config({
highlightClass: detail.markers.selectedItem,
itemClass: detail.markers.item,
onHighlight: detail.onHighlight
}),
Representing.config({
store: {
mode: 'memory',
initialValue: detail.value
}
}),
Composing.config({ find: Optional.some }),
Keying.config(detail.movement.config(detail, detail.movement))
]),
events: derive$3([
run(focus$1(), function (menu, simulatedEvent) {
var event = simulatedEvent.event;
menu.getSystem().getByDom(event.target).each(function (item) {
Highlighting.highlight(menu, item);
simulatedEvent.stop();
emitWith(menu, focus(), {
menu: menu,
item: item
});
});
}),
run(hover(), function (menu, simulatedEvent) {
var item = simulatedEvent.event.item;
Highlighting.highlight(menu, item);
})
]),
components: components,
eventOrder: detail.eventOrder,
domModification: { attributes: { role: 'menu' } }
};
};
var Menu = composite({
name: 'Menu',
configFields: schema$2(),
partFields: parts$2(),
factory: make$2
});
var preserve = function (f, container) {
var dos = getRootNode(container);
var refocus = active(dos).bind(function (focused) {
var hasFocus = function (elem) {
return eq(focused, elem);
};
return hasFocus(container) ? Optional.some(container) : descendant$1(container, hasFocus);
});
var result = f(container);
refocus.each(function (oldFocus) {
active(dos).filter(function (newFocus) {
return eq(newFocus, oldFocus);
}).fold(function () {
focus$3(oldFocus);
}, noop);
});
return result;
};
var set = function (component, replaceConfig, replaceState, data) {
preserve(function () {
var newChildren = map$2(data, component.getSystem().build);
replaceChildren(component, newChildren);
}, component.element);
};
var insert = function (component, replaceConfig, insertion, childSpec) {
var child = component.getSystem().build(childSpec);
attachWith(component, child, insertion);
};
var append = function (component, replaceConfig, replaceState, appendee) {
insert(component, replaceConfig, append$2, appendee);
};
var prepend = function (component, replaceConfig, replaceState, prependee) {
insert(component, replaceConfig, prepend$1, prependee);
};
var remove = function (component, replaceConfig, replaceState, removee) {
var children = contents(component);
var foundChild = find$2(children, function (child) {
return eq(removee.element, child.element);
});
foundChild.each(detach);
};
var contents = function (component, _replaceConfig) {
return component.components();
};
var replaceAt = function (component, replaceConfig, replaceState, replaceeIndex, replacer) {
var children = contents(component);
return Optional.from(children[replaceeIndex]).map(function (replacee) {
remove(component, replaceConfig, replaceState, replacee);
replacer.each(function (r) {
insert(component, replaceConfig, function (p, c) {
appendAt(p, c, replaceeIndex);
}, r);
});
return replacee;
});
};
var replaceBy = function (component, replaceConfig, replaceState, replaceePred, replacer) {
var children = contents(component);
return findIndex$1(children, replaceePred).bind(function (replaceeIndex) {
return replaceAt(component, replaceConfig, replaceState, replaceeIndex, replacer);
});
};
var ReplaceApis = /*#__PURE__*/Object.freeze({
__proto__: null,
append: append,
prepend: prepend,
remove: remove,
replaceAt: replaceAt,
replaceBy: replaceBy,
set: set,
contents: contents
});
var Replacing = create$5({
fields: [],
name: 'replacing',
apis: ReplaceApis
});
var transpose = function (obj) {
return tupleMap(obj, function (v, k) {
return {
k: v,
v: k
};
});
};
var trace = function (items, byItem, byMenu, finish) {
return get$c(byMenu, finish).bind(function (triggerItem) {
return get$c(items, triggerItem).bind(function (triggerMenu) {
var rest = trace(items, byItem, byMenu, triggerMenu);
return Optional.some([triggerMenu].concat(rest));
});
}).getOr([]);
};
var generate = function (menus, expansions) {
var items = {};
each(menus, function (menuItems, menu) {
each$1(menuItems, function (item) {
items[item] = menu;
});
});
var byItem = expansions;
var byMenu = transpose(expansions);
var menuPaths = map$1(byMenu, function (_triggerItem, submenu) {
return [submenu].concat(trace(items, byItem, byMenu, submenu));
});
return map$1(items, function (menu) {
return get$c(menuPaths, menu).getOr([menu]);
});
};
var init$2 = function () {
var expansions = Cell({});
var menus = Cell({});
var paths = Cell({});
var primary = value();
var directory = Cell({});
var clear = function () {
expansions.set({});
menus.set({});
paths.set({});
primary.clear();
};
var isClear = function () {
return primary.get().isNone();
};
var setMenuBuilt = function (menuName, built) {
var _a;
menus.set(__assign(__assign({}, menus.get()), (_a = {}, _a[menuName] = {
type: 'prepared',
menu: built
}, _a)));
};
var setContents = function (sPrimary, sMenus, sExpansions, dir) {
primary.set(sPrimary);
expansions.set(sExpansions);
menus.set(sMenus);
directory.set(dir);
var sPaths = generate(dir, sExpansions);
paths.set(sPaths);
};
var getTriggeringItem = function (menuValue) {
return find(expansions.get(), function (v, _k) {
return v === menuValue;
});
};
var getTriggerData = function (menuValue, getItemByValue, path) {
return getPreparedMenu(menuValue).bind(function (menu) {
return getTriggeringItem(menuValue).bind(function (triggeringItemValue) {
return getItemByValue(triggeringItemValue).map(function (triggeredItem) {
return {
triggeredMenu: menu,
triggeringItem: triggeredItem,
triggeringPath: path
};
});
});
});
};
var getTriggeringPath = function (itemValue, getItemByValue) {
var extraPath = filter$2(lookupItem(itemValue).toArray(), function (menuValue) {
return getPreparedMenu(menuValue).isSome();
});
return get$c(paths.get(), itemValue).bind(function (path) {
var revPath = reverse(extraPath.concat(path));
var triggers = bind$3(revPath, function (menuValue, menuIndex) {
return getTriggerData(menuValue, getItemByValue, revPath.slice(0, menuIndex + 1)).fold(function () {
return is(primary.get(), menuValue) ? [] : [Optional.none()];
}, function (data) {
return [Optional.some(data)];
});
});
return sequence(triggers);
});
};
var expand = function (itemValue) {
return get$c(expansions.get(), itemValue).map(function (menu) {
var current = get$c(paths.get(), itemValue).getOr([]);
return [menu].concat(current);
});
};
var collapse = function (itemValue) {
return get$c(paths.get(), itemValue).bind(function (path) {
return path.length > 1 ? Optional.some(path.slice(1)) : Optional.none();
});
};
var refresh = function (itemValue) {
return get$c(paths.get(), itemValue);
};
var getPreparedMenu = function (menuValue) {
return lookupMenu(menuValue).bind(extractPreparedMenu);
};
var lookupMenu = function (menuValue) {
return get$c(menus.get(), menuValue);
};
var lookupItem = function (itemValue) {
return get$c(expansions.get(), itemValue);
};
var otherMenus = function (path) {
var menuValues = directory.get();
return difference(keys(menuValues), path);
};
var getPrimary = function () {
return primary.get().bind(getPreparedMenu);
};
var getMenus = function () {
return menus.get();
};
return {
setMenuBuilt: setMenuBuilt,
setContents: setContents,
expand: expand,
refresh: refresh,
collapse: collapse,
lookupMenu: lookupMenu,
lookupItem: lookupItem,
otherMenus: otherMenus,
getPrimary: getPrimary,
getMenus: getMenus,
clear: clear,
isClear: isClear,
getTriggeringPath: getTriggeringPath
};
};
var extractPreparedMenu = function (prep) {
return prep.type === 'prepared' ? Optional.some(prep.menu) : Optional.none();
};
var LayeredState = {
init: init$2,
extractPreparedMenu: extractPreparedMenu
};
var make$1 = function (detail, _rawUiSpec) {
var submenuParentItems = value();
var buildMenus = function (container, primaryName, menus) {
return map$1(menus, function (spec, name) {
var makeSketch = function () {
return Menu.sketch(__assign(__assign({}, spec), {
value: name,
markers: detail.markers,
fakeFocus: detail.fakeFocus,
onHighlight: detail.onHighlight,
focusManager: detail.fakeFocus ? highlights() : dom$2()
}));
};
return name === primaryName ? {
type: 'prepared',
menu: container.getSystem().build(makeSketch())
} : {
type: 'notbuilt',
nbMenu: makeSketch
};
});
};
var layeredState = LayeredState.init();
var setup = function (container) {
var componentMap = buildMenus(container, detail.data.primary, detail.data.menus);
var directory = toDirectory();
layeredState.setContents(detail.data.primary, componentMap, detail.data.expansions, directory);
return layeredState.getPrimary();
};
var getItemValue = function (item) {
return Representing.getValue(item).value;
};
var getItemByValue = function (_container, menus, itemValue) {
return findMap(menus, function (menu) {
if (!menu.getSystem().isConnected()) {
return Optional.none();
}
var candidates = Highlighting.getCandidates(menu);
return find$2(candidates, function (c) {
return getItemValue(c) === itemValue;
});
});
};
var toDirectory = function (_container) {
return map$1(detail.data.menus, function (data, _menuName) {
return bind$3(data.items, function (item) {
return item.type === 'separator' ? [] : [item.data.value];
});
});
};
var setActiveMenu = function (container, menu) {
Highlighting.highlight(container, menu);
Highlighting.getHighlighted(menu).orThunk(function () {
return Highlighting.getFirst(menu);
}).each(function (item) {
dispatch(container, item.element, focusItem());
});
};
var getMenus = function (state, menuValues) {
return cat(map$2(menuValues, function (mv) {
return state.lookupMenu(mv).bind(function (prep) {
return prep.type === 'prepared' ? Optional.some(prep.menu) : Optional.none();
});
}));
};
var closeOthers = function (container, state, path) {
var others = getMenus(state, state.otherMenus(path));
each$1(others, function (o) {
remove$1(o.element, [detail.markers.backgroundMenu]);
if (!detail.stayInDom) {
Replacing.remove(container, o);
}
});
};
var getSubmenuParents = function (container) {
return submenuParentItems.get().getOrThunk(function () {
var r = {};
var items = descendants(container.element, '.' + detail.markers.item);
var parentItems = filter$2(items, function (i) {
return get$b(i, 'aria-haspopup') === 'true';
});
each$1(parentItems, function (i) {
container.getSystem().getByDom(i).each(function (itemComp) {
var key = getItemValue(itemComp);
r[key] = itemComp;
});
});
submenuParentItems.set(r);
return r;
});
};
var updateAriaExpansions = function (container, path) {
var parentItems = getSubmenuParents(container);
each(parentItems, function (v, k) {
var expanded = contains$1(path, k);
set$8(v.element, 'aria-expanded', expanded);
});
};
var updateMenuPath = function (container, state, path) {
return Optional.from(path[0]).bind(function (latestMenuName) {
return state.lookupMenu(latestMenuName).bind(function (menuPrep) {
if (menuPrep.type === 'notbuilt') {
return Optional.none();
} else {
var activeMenu = menuPrep.menu;
var rest = getMenus(state, path.slice(1));
each$1(rest, function (r) {
add$1(r.element, detail.markers.backgroundMenu);
});
if (!inBody(activeMenu.element)) {
Replacing.append(container, premade(activeMenu));
}
remove$1(activeMenu.element, [detail.markers.backgroundMenu]);
setActiveMenu(container, activeMenu);
closeOthers(container, state, path);
return Optional.some(activeMenu);
}
});
});
};
var ExpandHighlightDecision;
(function (ExpandHighlightDecision) {
ExpandHighlightDecision[ExpandHighlightDecision['HighlightSubmenu'] = 0] = 'HighlightSubmenu';
ExpandHighlightDecision[ExpandHighlightDecision['HighlightParent'] = 1] = 'HighlightParent';
}(ExpandHighlightDecision || (ExpandHighlightDecision = {})));
var buildIfRequired = function (container, menuName, menuPrep) {
if (menuPrep.type === 'notbuilt') {
var menu = container.getSystem().build(menuPrep.nbMenu());
layeredState.setMenuBuilt(menuName, menu);
return menu;
} else {
return menuPrep.menu;
}
};
var expandRight = function (container, item, decision) {
if (decision === void 0) {
decision = ExpandHighlightDecision.HighlightSubmenu;
}
if (item.hasConfigured(Disabling) && Disabling.isDisabled(item)) {
return Optional.some(item);
} else {
var value = getItemValue(item);
return layeredState.expand(value).bind(function (path) {
updateAriaExpansions(container, path);
return Optional.from(path[0]).bind(function (menuName) {
return layeredState.lookupMenu(menuName).bind(function (activeMenuPrep) {
var activeMenu = buildIfRequired(container, menuName, activeMenuPrep);
if (!inBody(activeMenu.element)) {
Replacing.append(container, premade(activeMenu));
}
detail.onOpenSubmenu(container, item, activeMenu, reverse(path));
if (decision === ExpandHighlightDecision.HighlightSubmenu) {
Highlighting.highlightFirst(activeMenu);
return updateMenuPath(container, layeredState, path);
} else {
Highlighting.dehighlightAll(activeMenu);
return Optional.some(item);
}
});
});
});
}
};
var collapseLeft = function (container, item) {
var value = getItemValue(item);
return layeredState.collapse(value).bind(function (path) {
updateAriaExpansions(container, path);
return updateMenuPath(container, layeredState, path).map(function (activeMenu) {
detail.onCollapseMenu(container, item, activeMenu);
return activeMenu;
});
});
};
var updateView = function (container, item) {
var value = getItemValue(item);
return layeredState.refresh(value).bind(function (path) {
updateAriaExpansions(container, path);
return updateMenuPath(container, layeredState, path);
});
};
var onRight = function (container, item) {
return inside(item.element) ? Optional.none() : expandRight(container, item, ExpandHighlightDecision.HighlightSubmenu);
};
var onLeft = function (container, item) {
return inside(item.element) ? Optional.none() : collapseLeft(container, item);
};
var onEscape = function (container, item) {
return collapseLeft(container, item).orThunk(function () {
return detail.onEscape(container, item).map(function () {
return container;
});
});
};
var keyOnItem = function (f) {
return function (container, simulatedEvent) {
return closest$1(simulatedEvent.getSource(), '.' + detail.markers.item).bind(function (target) {
return container.getSystem().getByDom(target).toOptional().bind(function (item) {
return f(container, item).map(always);
});
});
};
};
var events = derive$3([
run(focus(), function (sandbox, simulatedEvent) {
var item = simulatedEvent.event.item;
layeredState.lookupItem(getItemValue(item)).each(function () {
var menu = simulatedEvent.event.menu;
Highlighting.highlight(sandbox, menu);
var value = getItemValue(simulatedEvent.event.item);
layeredState.refresh(value).each(function (path) {
return closeOthers(sandbox, layeredState, path);
});
});
}),
runOnExecute(function (component, simulatedEvent) {
var target = simulatedEvent.event.target;
component.getSystem().getByDom(target).each(function (item) {
var itemValue = getItemValue(item);
if (itemValue.indexOf('collapse-item') === 0) {
collapseLeft(component, item);
}
expandRight(component, item, ExpandHighlightDecision.HighlightSubmenu).fold(function () {
detail.onExecute(component, item);
}, noop);
});
}),
runOnAttached(function (container, _simulatedEvent) {
setup(container).each(function (primary) {
Replacing.append(container, premade(primary));
detail.onOpenMenu(container, primary);
if (detail.highlightImmediately) {
setActiveMenu(container, primary);
}
});
})
].concat(detail.navigateOnHover ? [run(hover(), function (sandbox, simulatedEvent) {
var item = simulatedEvent.event.item;
updateView(sandbox, item);
expandRight(sandbox, item, ExpandHighlightDecision.HighlightParent);
detail.onHover(sandbox, item);
})] : []));
var getActiveItem = function (container) {
return Highlighting.getHighlighted(container).bind(Highlighting.getHighlighted);
};
var collapseMenuApi = function (container) {
getActiveItem(container).each(function (currentItem) {
collapseLeft(container, currentItem);
});
};
var highlightPrimary = function (container) {
layeredState.getPrimary().each(function (primary) {
setActiveMenu(container, primary);
});
};
var extractMenuFromContainer = function (container) {
return Optional.from(container.components()[0]).filter(function (comp) {
return get$b(comp.element, 'role') === 'menu';
});
};
var repositionMenus = function (container) {
var maybeActivePrimary = layeredState.getPrimary().bind(function (primary) {
return getActiveItem(container).bind(function (currentItem) {
var itemValue = getItemValue(currentItem);
var allMenus = values(layeredState.getMenus());
var preparedMenus = cat(map$2(allMenus, LayeredState.extractPreparedMenu));
return layeredState.getTriggeringPath(itemValue, function (v) {
return getItemByValue(container, preparedMenus, v);
});
}).map(function (triggeringPath) {
return {
primary: primary,
triggeringPath: triggeringPath
};
});
});
maybeActivePrimary.fold(function () {
extractMenuFromContainer(container).each(function (primaryMenu) {
detail.onRepositionMenu(container, primaryMenu, []);
});
}, function (_a) {
var primary = _a.primary, triggeringPath = _a.triggeringPath;
detail.onRepositionMenu(container, primary, triggeringPath);
});
};
var apis = {
collapseMenu: collapseMenuApi,
highlightPrimary: highlightPrimary,
repositionMenus: repositionMenus
};
return {
uid: detail.uid,
dom: detail.dom,
markers: detail.markers,
behaviours: augment(detail.tmenuBehaviours, [
Keying.config({
mode: 'special',
onRight: keyOnItem(onRight),
onLeft: keyOnItem(onLeft),
onEscape: keyOnItem(onEscape),
focusIn: function (container, _keyInfo) {
layeredState.getPrimary().each(function (primary) {
dispatch(container, primary.element, focusItem());
});
}
}),
Highlighting.config({
highlightClass: detail.markers.selectedMenu,
itemClass: detail.markers.menu
}),
Composing.config({
find: function (container) {
return Highlighting.getHighlighted(container);
}
}),
Replacing.config({})
]),
eventOrder: detail.eventOrder,
apis: apis,
events: events
};
};
var collapseItem$1 = constant$1('collapse-item');
var tieredData = function (primary, menus, expansions) {
return {
primary: primary,
menus: menus,
expansions: expansions
};
};
var singleData = function (name, menu) {
return {
primary: name,
menus: wrap(name, menu),
expansions: {}
};
};
var collapseItem = function (text) {
return {
value: generate$4(collapseItem$1()),
meta: { text: text }
};
};
var tieredMenu = single({
name: 'TieredMenu',
configFields: [
onStrictKeyboardHandler('onExecute'),
onStrictKeyboardHandler('onEscape'),
onStrictHandler('onOpenMenu'),
onStrictHandler('onOpenSubmenu'),
onHandler('onRepositionMenu'),
onHandler('onCollapseMenu'),
defaulted('highlightImmediately', true),
requiredObjOf('data', [
required$1('primary'),
required$1('menus'),
required$1('expansions')
]),
defaulted('fakeFocus', false),
onHandler('onHighlight'),
onHandler('onHover'),
tieredMenuMarkers(),
required$1('dom'),
defaulted('navigateOnHover', true),
defaulted('stayInDom', false),
field$1('tmenuBehaviours', [
Keying,
Highlighting,
Composing,
Replacing
]),
defaulted('eventOrder', {})
],
apis: {
collapseMenu: function (apis, tmenu) {
apis.collapseMenu(tmenu);
},
highlightPrimary: function (apis, tmenu) {
apis.highlightPrimary(tmenu);
},
repositionMenus: function (apis, tmenu) {
apis.repositionMenus(tmenu);
}
},
factory: make$1,
extraApis: {
tieredData: tieredData,
singleData: singleData,
collapseItem: collapseItem
}
});
var findRoute = function (component, transConfig, transState, route) {
return get$c(transConfig.routes, route.start).bind(function (sConfig) {
return get$c(sConfig, route.destination);
});
};
var getTransition = function (comp, transConfig, transState) {
var route = getCurrentRoute(comp, transConfig);
return route.bind(function (r) {
return getTransitionOf(comp, transConfig, transState, r);
});
};
var getTransitionOf = function (comp, transConfig, transState, route) {
return findRoute(comp, transConfig, transState, route).bind(function (r) {
return r.transition.map(function (t) {
return {
transition: t,
route: r
};
});
});
};
var disableTransition = function (comp, transConfig, transState) {
getTransition(comp, transConfig, transState).each(function (routeTransition) {
var t = routeTransition.transition;
remove$3(comp.element, t.transitionClass);
remove$6(comp.element, transConfig.destinationAttr);
});
};
var getNewRoute = function (comp, transConfig, transState, destination) {
return {
start: get$b(comp.element, transConfig.stateAttr),
destination: destination
};
};
var getCurrentRoute = function (comp, transConfig, _transState) {
var el = comp.element;
return getOpt(el, transConfig.destinationAttr).map(function (destination) {
return {
start: get$b(comp.element, transConfig.stateAttr),
destination: destination
};
});
};
var jumpTo = function (comp, transConfig, transState, destination) {
disableTransition(comp, transConfig, transState);
if (has$1(comp.element, transConfig.stateAttr) && get$b(comp.element, transConfig.stateAttr) !== destination) {
transConfig.onFinish(comp, destination);
}
set$8(comp.element, transConfig.stateAttr, destination);
};
var fasttrack = function (comp, transConfig, _transState, _destination) {
if (has$1(comp.element, transConfig.destinationAttr)) {
getOpt(comp.element, transConfig.destinationAttr).each(function (destination) {
set$8(comp.element, transConfig.stateAttr, destination);
});
remove$6(comp.element, transConfig.destinationAttr);
}
};
var progressTo = function (comp, transConfig, transState, destination) {
fasttrack(comp, transConfig);
var route = getNewRoute(comp, transConfig, transState, destination);
getTransitionOf(comp, transConfig, transState, route).fold(function () {
jumpTo(comp, transConfig, transState, destination);
}, function (routeTransition) {
disableTransition(comp, transConfig, transState);
var t = routeTransition.transition;
add$1(comp.element, t.transitionClass);
set$8(comp.element, transConfig.destinationAttr, destination);
});
};
var getState = function (comp, transConfig, _transState) {
return getOpt(comp.element, transConfig.stateAttr);
};
var TransitionApis = /*#__PURE__*/Object.freeze({
__proto__: null,
findRoute: findRoute,
disableTransition: disableTransition,
getCurrentRoute: getCurrentRoute,
jumpTo: jumpTo,
progressTo: progressTo,
getState: getState
});
var events$1 = function (transConfig, transState) {
return derive$3([
run(transitionend(), function (component, simulatedEvent) {
var raw = simulatedEvent.event.raw;
getCurrentRoute(component, transConfig).each(function (route) {
findRoute(component, transConfig, transState, route).each(function (rInfo) {
rInfo.transition.each(function (rTransition) {
if (raw.propertyName === rTransition.property) {
jumpTo(component, transConfig, transState, route.destination);
transConfig.onTransition(component, route);
}
});
});
});
}),
runOnAttached(function (comp, _se) {
jumpTo(comp, transConfig, transState, transConfig.initialState);
})
]);
};
var ActiveTransitioning = /*#__PURE__*/Object.freeze({
__proto__: null,
events: events$1
});
var TransitionSchema = [
defaulted('destinationAttr', 'data-transitioning-destination'),
defaulted('stateAttr', 'data-transitioning-state'),
required$1('initialState'),
onHandler('onTransition'),
onHandler('onFinish'),
requiredOf('routes', setOf(Result.value, setOf(Result.value, objOfOnly([optionObjOfOnly('transition', [
required$1('property'),
required$1('transitionClass')
])]))))
];
var createRoutes = function (routes) {
var r = {};
each(routes, function (v, k) {
var waypoints = k.split('<->');
r[waypoints[0]] = wrap(waypoints[1], v);
r[waypoints[1]] = wrap(waypoints[0], v);
});
return r;
};
var createBistate = function (first, second, transitions) {
return wrapAll([
{
key: first,
value: wrap(second, transitions)
},
{
key: second,
value: wrap(first, transitions)
}
]);
};
var createTristate = function (first, second, third, transitions) {
return wrapAll([
{
key: first,
value: wrapAll([
{
key: second,
value: transitions
},
{
key: third,
value: transitions
}
])
},
{
key: second,
value: wrapAll([
{
key: first,
value: transitions
},
{
key: third,
value: transitions
}
])
},
{
key: third,
value: wrapAll([
{
key: first,
value: transitions
},
{
key: second,
value: transitions
}
])
}
]);
};
var Transitioning = create$5({
fields: TransitionSchema,
name: 'transitioning',
active: ActiveTransitioning,
apis: TransitionApis,
extra: {
createRoutes: createRoutes,
createBistate: createBistate,
createTristate: createTristate
}
});
var scrollableStyle = resolve('scrollable');
var register$2 = function (element) {
add$1(element, scrollableStyle);
};
var deregister = function (element) {
remove$3(element, scrollableStyle);
};
var scrollable = scrollableStyle;
var getValue = function (item) {
return get$c(item, 'format').getOr(item.title);
};
var convert = function (formats, memMenuThunk) {
var mainMenu = makeMenu('Styles', [].concat(map$2(formats.items, function (k) {
return makeItem(getValue(k), k.title, k.isSelected(), k.getPreview(), hasNonNullableKey(formats.expansions, getValue(k)));
})), memMenuThunk, false);
var submenus = map$1(formats.menus, function (menuItems, menuName) {
var items = map$2(menuItems, function (item) {
return makeItem(getValue(item), item.title, item.isSelected !== undefined ? item.isSelected() : false, item.getPreview !== undefined ? item.getPreview() : '', hasNonNullableKey(formats.expansions, getValue(item)));
});
return makeMenu(menuName, items, memMenuThunk, true);
});
var menus = deepMerge(submenus, wrap('styles', mainMenu));
var tmenu = tieredMenu.tieredData('styles', menus, formats.expansions);
return { tmenu: tmenu };
};
var makeItem = function (value, text, selected, preview, isMenu) {
return {
data: {
value: value,
text: text
},
type: 'item',
dom: {
tag: 'div',
classes: isMenu ? [resolve('styles-item-is-menu')] : []
},
toggling: {
toggleOnExecute: false,
toggleClass: resolve('format-matches'),
selected: selected
},
itemBehaviours: derive$2(isMenu ? [] : [format(value, function (comp, status) {
var toggle = status ? Toggling.on : Toggling.off;
toggle(comp);
})]),
components: [{
dom: {
tag: 'div',
attributes: { style: preview },
innerHtml: text
}
}]
};
};
var makeMenu = function (value, items, memMenuThunk, collapsable) {
return {
value: value,
dom: { tag: 'div' },
components: [
Button.sketch({
dom: {
tag: 'div',
classes: [resolve('styles-collapser')]
},
components: collapsable ? [
{
dom: {
tag: 'span',
classes: [resolve('styles-collapse-icon')]
}
},
text(value)
] : [text(value)],
action: function (item) {
if (collapsable) {
var comp = memMenuThunk().get(item);
tieredMenu.collapseMenu(comp);
}
}
}),
{
dom: {
tag: 'div',
classes: [resolve('styles-menu-items-container')]
},
components: [Menu.parts.items({})],
behaviours: derive$2([config('adhoc-scrollable-menu', [
runOnAttached(function (component, _simulatedEvent) {
set$5(component.element, 'overflow-y', 'auto');
set$5(component.element, '-webkit-overflow-scrolling', 'touch');
register$2(component.element);
}),
runOnDetached(function (component) {
remove$2(component.element, 'overflow-y');
remove$2(component.element, '-webkit-overflow-scrolling');
deregister(component.element);
})
])])
}
],
items: items,
menuBehaviours: derive$2([Transitioning.config({
initialState: 'after',
routes: Transitioning.createTristate('before', 'current', 'after', {
transition: {
property: 'transform',
transitionClass: 'transitioning'
}
})
})])
};
};
var sketch$1 = function (settings) {
var dataset = convert(settings.formats, function () {
return memMenu;
});
var memMenu = record(tieredMenu.sketch({
dom: {
tag: 'div',
classes: [resolve('styles-menu')]
},
components: [],
fakeFocus: true,
stayInDom: true,
onExecute: function (_tmenu, item) {
var v = Representing.getValue(item);
settings.handle(item, v.value);
return Optional.none();
},
onEscape: function () {
return Optional.none();
},
onOpenMenu: function (container, menu) {
var w = get$5(container.element);
set$4(menu.element, w);
Transitioning.jumpTo(menu, 'current');
},
onOpenSubmenu: function (container, item, submenu) {
var w = get$5(container.element);
var menu = ancestor(item.element, '[role="menu"]').getOrDie('hacky');
var menuComp = container.getSystem().getByDom(menu).getOrDie();
set$4(submenu.element, w);
Transitioning.progressTo(menuComp, 'before');
Transitioning.jumpTo(submenu, 'after');
Transitioning.progressTo(submenu, 'current');
},
onCollapseMenu: function (container, item, menu) {
var submenu = ancestor(item.element, '[role="menu"]').getOrDie('hacky');
var submenuComp = container.getSystem().getByDom(submenu).getOrDie();
Transitioning.progressTo(submenuComp, 'after');
Transitioning.progressTo(menu, 'current');
},
navigateOnHover: false,
highlightImmediately: true,
data: dataset.tmenu,
markers: {
backgroundMenu: resolve('styles-background-menu'),
menu: resolve('styles-menu'),
selectedMenu: resolve('styles-selected-menu'),
item: resolve('styles-item'),
selectedItem: resolve('styles-selected-item')
}
}));
return memMenu.asSpec();
};
var getFromExpandingItem = function (item) {
var newItem = deepMerge(exclude(item, ['items']), { menu: true });
var rest = expand(item.items);
var newMenus = deepMerge(rest.menus, wrap(item.title, rest.items));
var newExpansions = deepMerge(rest.expansions, wrap(item.title, item.title));
return {
item: newItem,
menus: newMenus,
expansions: newExpansions
};
};
var getFromItem = function (item) {
return hasNonNullableKey(item, 'items') ? getFromExpandingItem(item) : {
item: item,
menus: {},
expansions: {}
};
};
var expand = function (items) {
return foldr(items, function (acc, item) {
var newData = getFromItem(item);
return {
menus: deepMerge(acc.menus, newData.menus),
items: [newData.item].concat(acc.items),
expansions: deepMerge(acc.expansions, newData.expansions)
};
}, {
menus: {},
expansions: {},
items: []
});
};
var register$1 = function (editor) {
var isSelectedFor = function (format) {
return function () {
return editor.formatter.match(format);
};
};
var getPreview = function (format) {
return function () {
return editor.formatter.getCssText(format);
};
};
var enrichSupported = function (item) {
return deepMerge(item, {
isSelected: isSelectedFor(item.format),
getPreview: getPreview(item.format)
});
};
var enrichMenu = function (item) {
return deepMerge(item, {
isSelected: never,
getPreview: constant$1('')
});
};
var enrichCustom = function (item) {
var formatName = generate$4(item.title);
var newItem = deepMerge(item, {
format: formatName,
isSelected: isSelectedFor(formatName),
getPreview: getPreview(formatName)
});
editor.formatter.register(formatName, newItem);
return newItem;
};
var doEnrich = function (items) {
return map$2(items, function (item) {
if (hasNonNullableKey(item, 'items')) {
var newItems = doEnrich(item.items);
return deepMerge(enrichMenu(item), { items: newItems });
} else if (hasNonNullableKey(item, 'format')) {
return enrichSupported(item);
} else {
return enrichCustom(item);
}
});
};
return doEnrich(getStyleFormats(editor));
};
var prune = function (editor, formats) {
var doPrune = function (items) {
return bind$3(items, function (item) {
if (item.items !== undefined) {
var newItems = doPrune(item.items);
return newItems.length > 0 ? [item] : [];
} else {
var keep = hasNonNullableKey(item, 'format') ? editor.formatter.canApply(item.format) : true;
return keep ? [item] : [];
}
});
};
var prunedItems = doPrune(formats);
return expand(prunedItems);
};
var ui = function (editor, formats, onDone) {
var pruned = prune(editor, formats);
return sketch$1({
formats: pruned,
handle: function (item, value) {
editor.undoManager.transact(function () {
if (Toggling.isOn(item)) {
editor.formatter.remove(value);
} else {
editor.formatter.apply(value);
}
});
onDone();
}
});
};
var extract = function (rawToolbar) {
var toolbar = rawToolbar.replace(/\|/g, ' ').trim();
return toolbar.length > 0 ? toolbar.split(/\s+/) : [];
};
var identifyFromArray = function (toolbar) {
return bind$3(toolbar, function (item) {
return isArray(item) ? identifyFromArray(item) : extract(item);
});
};
var identify = function (editor) {
var toolbar = getToolbar(editor);
return isArray(toolbar) ? identifyFromArray(toolbar) : extract(toolbar);
};
var setup$3 = function (realm, editor) {
var commandSketch = function (name) {
return function () {
return forToolbarCommand(editor, name);
};
};
var stateCommandSketch = function (name) {
return function () {
return forToolbarStateCommand(editor, name);
};
};
var actionSketch = function (name, query, action) {
return function () {
return forToolbarStateAction(editor, name, query, action);
};
};
var undo = commandSketch('undo');
var redo = commandSketch('redo');
var bold = stateCommandSketch('bold');
var italic = stateCommandSketch('italic');
var underline = stateCommandSketch('underline');
var removeformat = commandSketch('removeformat');
var link = function () {
return sketch$2(realm, editor);
};
var unlink = actionSketch('unlink', 'link', function () {
editor.execCommand('unlink', null, false);
});
var image = function () {
return sketch$5(editor);
};
var bullist = actionSketch('unordered-list', 'ul', function () {
editor.execCommand('InsertUnorderedList', null, false);
});
var numlist = actionSketch('ordered-list', 'ol', function () {
editor.execCommand('InsertOrderedList', null, false);
});
var fontsizeselect = function () {
return sketch$6(realm, editor);
};
var forecolor = function () {
return sketch$8(realm, editor);
};
var styleFormats = register$1(editor);
var styleFormatsMenu = function () {
return ui(editor, styleFormats, function () {
editor.fire('scrollIntoView');
});
};
var styleselect = function () {
return forToolbar('style-formats', function (button) {
editor.fire('toReading');
realm.dropup.appear(styleFormatsMenu, Toggling.on, button);
}, derive$2([
Toggling.config({
toggleClass: resolve('toolbar-button-selected'),
toggleOnExecute: false,
aria: { mode: 'pressed' }
}),
Receiving.config({
channels: wrapAll([
receive(orientationChanged, Toggling.off),
receive(dropupDismissed, Toggling.off)
])
})
]), editor);
};
var feature = function (prereq, sketch) {
return {
isSupported: function () {
var buttons = editor.ui.registry.getAll().buttons;
return prereq.forall(function (p) {
return hasNonNullableKey(buttons, p);
});
},
sketch: sketch
};
};
return {
undo: feature(Optional.none(), undo),
redo: feature(Optional.none(), redo),
bold: feature(Optional.none(), bold),
italic: feature(Optional.none(), italic),
underline: feature(Optional.none(), underline),
removeformat: feature(Optional.none(), removeformat),
link: feature(Optional.none(), link),
unlink: feature(Optional.none(), unlink),
image: feature(Optional.none(), image),
bullist: feature(Optional.some('bullist'), bullist),
numlist: feature(Optional.some('numlist'), numlist),
fontsizeselect: feature(Optional.none(), fontsizeselect),
forecolor: feature(Optional.none(), forecolor),
styleselect: feature(Optional.none(), styleselect)
};
};
var detect = function (editor, features) {
var itemNames = identify(editor);
var present = {};
return bind$3(itemNames, function (iName) {
var r = !hasNonNullableKey(present, iName) && hasNonNullableKey(features, iName) && features[iName].isSupported() ? [features[iName].sketch()] : [];
present[iName] = true;
return r;
});
};
var mkEvent = function (target, x, y, stop, prevent, kill, raw) {
return {
target: target,
x: x,
y: y,
stop: stop,
prevent: prevent,
kill: kill,
raw: raw
};
};
var fromRawEvent = function (rawEvent) {
var target = SugarElement.fromDom(getOriginalEventTarget(rawEvent).getOr(rawEvent.target));
var stop = function () {
return rawEvent.stopPropagation();
};
var prevent = function () {
return rawEvent.preventDefault();
};
var kill = compose(prevent, stop);
return mkEvent(target, rawEvent.clientX, rawEvent.clientY, stop, prevent, kill, rawEvent);
};
var handle = function (filter, handler) {
return function (rawEvent) {
if (filter(rawEvent)) {
handler(fromRawEvent(rawEvent));
}
};
};
var binder = function (element, event, filter, handler, useCapture) {
var wrapped = handle(filter, handler);
element.dom.addEventListener(event, wrapped, useCapture);
return { unbind: curry(unbind, element, event, wrapped, useCapture) };
};
var bind$1 = function (element, event, filter, handler) {
return binder(element, event, filter, handler, false);
};
var capture$1 = function (element, event, filter, handler) {
return binder(element, event, filter, handler, true);
};
var unbind = function (element, event, handler, useCapture) {
element.dom.removeEventListener(event, handler, useCapture);
};
var filter = always;
var bind = function (element, event, handler) {
return bind$1(element, event, filter, handler);
};
var capture = function (element, event, handler) {
return capture$1(element, event, filter, handler);
};
var global$2 = tinymce.util.Tools.resolve('tinymce.util.Delay');
var INTERVAL = 50;
var INSURANCE = 1000 / INTERVAL;
var get$1 = function (outerWindow) {
var isPortrait = outerWindow.matchMedia('(orientation: portrait)').matches;
return { isPortrait: constant$1(isPortrait) };
};
var getActualWidth = function (outerWindow) {
var isIos = detect$1().os.isiOS();
var isPortrait = get$1(outerWindow).isPortrait();
return isIos && !isPortrait ? outerWindow.screen.height : outerWindow.screen.width;
};
var onChange = function (outerWindow, listeners) {
var win = SugarElement.fromDom(outerWindow);
var poller = null;
var change = function () {
global$2.clearInterval(poller);
var orientation = get$1(outerWindow);
listeners.onChange(orientation);
onAdjustment(function () {
listeners.onReady(orientation);
});
};
var orientationHandle = bind(win, 'orientationchange', change);
var onAdjustment = function (f) {
global$2.clearInterval(poller);
var flag = outerWindow.innerHeight;
var insurance = 0;
poller = global$2.setInterval(function () {
if (flag !== outerWindow.innerHeight) {
global$2.clearInterval(poller);
f(Optional.some(outerWindow.innerHeight));
} else if (insurance > INSURANCE) {
global$2.clearInterval(poller);
f(Optional.none());
}
insurance++;
}, INTERVAL);
};
var destroy = function () {
orientationHandle.unbind();
};
return {
onAdjustment: onAdjustment,
destroy: destroy
};
};
var setStart = function (rng, situ) {
situ.fold(function (e) {
rng.setStartBefore(e.dom);
}, function (e, o) {
rng.setStart(e.dom, o);
}, function (e) {
rng.setStartAfter(e.dom);
});
};
var setFinish = function (rng, situ) {
situ.fold(function (e) {
rng.setEndBefore(e.dom);
}, function (e, o) {
rng.setEnd(e.dom, o);
}, function (e) {
rng.setEndAfter(e.dom);
});
};
var relativeToNative = function (win, startSitu, finishSitu) {
var range = win.document.createRange();
setStart(range, startSitu);
setFinish(range, finishSitu);
return range;
};
var exactToNative = function (win, start, soffset, finish, foffset) {
var rng = win.document.createRange();
rng.setStart(start.dom, soffset);
rng.setEnd(finish.dom, foffset);
return rng;
};
var toRect$1 = function (rect) {
return {
left: rect.left,
top: rect.top,
right: rect.right,
bottom: rect.bottom,
width: rect.width,
height: rect.height
};
};
var getFirstRect$1 = function (rng) {
var rects = rng.getClientRects();
var rect = rects.length > 0 ? rects[0] : rng.getBoundingClientRect();
return rect.width > 0 || rect.height > 0 ? Optional.some(rect).map(toRect$1) : Optional.none();
};
var adt$3 = Adt.generate([
{
ltr: [
'start',
'soffset',
'finish',
'foffset'
]
},
{
rtl: [
'start',
'soffset',
'finish',
'foffset'
]
}
]);
var fromRange = function (win, type, range) {
return type(SugarElement.fromDom(range.startContainer), range.startOffset, SugarElement.fromDom(range.endContainer), range.endOffset);
};
var getRanges = function (win, selection) {
return selection.match({
domRange: function (rng) {
return {
ltr: constant$1(rng),
rtl: Optional.none
};
},
relative: function (startSitu, finishSitu) {
return {
ltr: cached(function () {
return relativeToNative(win, startSitu, finishSitu);
}),
rtl: cached(function () {
return Optional.some(relativeToNative(win, finishSitu, startSitu));
})
};
},
exact: function (start, soffset, finish, foffset) {
return {
ltr: cached(function () {
return exactToNative(win, start, soffset, finish, foffset);
}),
rtl: cached(function () {
return Optional.some(exactToNative(win, finish, foffset, start, soffset));
})
};
}
});
};
var doDiagnose = function (win, ranges) {
var rng = ranges.ltr();
if (rng.collapsed) {
var reversed = ranges.rtl().filter(function (rev) {
return rev.collapsed === false;
});
return reversed.map(function (rev) {
return adt$3.rtl(SugarElement.fromDom(rev.endContainer), rev.endOffset, SugarElement.fromDom(rev.startContainer), rev.startOffset);
}).getOrThunk(function () {
return fromRange(win, adt$3.ltr, rng);
});
} else {
return fromRange(win, adt$3.ltr, rng);
}
};
var diagnose = function (win, selection) {
var ranges = getRanges(win, selection);
return doDiagnose(win, ranges);
};
var asLtrRange = function (win, selection) {
var diagnosis = diagnose(win, selection);
return diagnosis.match({
ltr: function (start, soffset, finish, foffset) {
var rng = win.document.createRange();
rng.setStart(start.dom, soffset);
rng.setEnd(finish.dom, foffset);
return rng;
},
rtl: function (start, soffset, finish, foffset) {
var rng = win.document.createRange();
rng.setStart(finish.dom, foffset);
rng.setEnd(start.dom, soffset);
return rng;
}
});
};
adt$3.ltr;
adt$3.rtl;
var create$3 = function (start, soffset, finish, foffset) {
return {
start: start,
soffset: soffset,
finish: finish,
foffset: foffset
};
};
var SimRange = { create: create$3 };
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 = NodeValue(isText, 'text');
var getOption = function (element) {
return api.getOption(element);
};
var getEnd = function (element) {
return name$1(element) === 'img' ? 1 : getOption(element).fold(function () {
return children(element).length;
}, function (v) {
return v.length;
});
};
var adt$2 = Adt.generate([
{ before: ['element'] },
{
on: [
'element',
'offset'
]
},
{ after: ['element'] }
]);
var cata = function (subject, onBefore, onOn, onAfter) {
return subject.fold(onBefore, onOn, onAfter);
};
var getStart$1 = function (situ) {
return situ.fold(identity, identity, identity);
};
var before = adt$2.before;
var on = adt$2.on;
var after$1 = adt$2.after;
var Situ = {
before: before,
on: on,
after: after$1,
cata: cata,
getStart: getStart$1
};
var adt$1 = Adt.generate([
{ domRange: ['rng'] },
{
relative: [
'startSitu',
'finishSitu'
]
},
{
exact: [
'start',
'soffset',
'finish',
'foffset'
]
}
]);
var exactFromRange = function (simRange) {
return adt$1.exact(simRange.start, simRange.soffset, simRange.finish, simRange.foffset);
};
var getStart = 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$1.domRange;
var relative = adt$1.relative;
var exact = adt$1.exact;
var getWin$1 = function (selection) {
var start = getStart(selection);
return defaultView(start);
};
var range = SimRange.create;
var SimSelection = {
domRange: domRange,
relative: relative,
exact: exact,
exactFromRange: exactFromRange,
getWin: getWin$1,
range: range
};
var beforeSpecial = function (element, offset) {
var name = name$1(element);
if ('input' === name) {
return Situ.after(element);
} else if (!contains$1([
'br',
'img'
], name)) {
return Situ.on(element, offset);
} else {
return offset === 0 ? Situ.before(element) : Situ.after(element);
}
};
var preprocessExact = function (start, soffset, finish, foffset) {
var startSitu = beforeSpecial(start, soffset);
var finishSitu = beforeSpecial(finish, foffset);
return SimSelection.relative(startSitu, finishSitu);
};
var makeRange = function (start, soffset, finish, foffset) {
var doc = owner$2(start);
var rng = doc.dom.createRange();
rng.setStart(start.dom, soffset);
rng.setEnd(finish.dom, foffset);
return rng;
};
var after = function (start, soffset, finish, foffset) {
var r = makeRange(start, soffset, finish, foffset);
var same = eq(start, finish) && soffset === foffset;
return r.collapsed && !same;
};
var getNativeSelection = function (win) {
return Optional.from(win.getSelection());
};
var doSetNativeRange = function (win, rng) {
getNativeSelection(win).each(function (selection) {
selection.removeAllRanges();
selection.addRange(rng);
});
};
var doSetRange = function (win, start, soffset, finish, foffset) {
var rng = exactToNative(win, start, soffset, finish, foffset);
doSetNativeRange(win, rng);
};
var setLegacyRtlRange = function (win, selection, start, soffset, finish, foffset) {
selection.collapse(start.dom, soffset);
selection.extend(finish.dom, foffset);
};
var setRangeFromRelative = function (win, relative) {
return diagnose(win, relative).match({
ltr: function (start, soffset, finish, foffset) {
doSetRange(win, start, soffset, finish, foffset);
},
rtl: function (start, soffset, finish, foffset) {
getNativeSelection(win).each(function (selection) {
if (selection.setBaseAndExtent) {
selection.setBaseAndExtent(start.dom, soffset, finish.dom, foffset);
} else if (selection.extend) {
try {
setLegacyRtlRange(win, selection, start, soffset, finish, foffset);
} catch (e) {
doSetRange(win, finish, foffset, start, soffset);
}
} else {
doSetRange(win, finish, foffset, start, soffset);
}
});
}
});
};
var setExact = function (win, start, soffset, finish, foffset) {
var relative = preprocessExact(start, soffset, finish, foffset);
setRangeFromRelative(win, relative);
};
var readRange = function (selection) {
if (selection.rangeCount > 0) {
var firstRng = selection.getRangeAt(0);
var lastRng = selection.getRangeAt(selection.rangeCount - 1);
return Optional.some(SimRange.create(SugarElement.fromDom(firstRng.startContainer), firstRng.startOffset, SugarElement.fromDom(lastRng.endContainer), lastRng.endOffset));
} else {
return Optional.none();
}
};
var doGetExact = function (selection) {
if (selection.anchorNode === null || selection.focusNode === null) {
return readRange(selection);
} else {
var anchor = SugarElement.fromDom(selection.anchorNode);
var focus_1 = SugarElement.fromDom(selection.focusNode);
return after(anchor, selection.anchorOffset, focus_1, selection.focusOffset) ? Optional.some(SimRange.create(anchor, selection.anchorOffset, focus_1, selection.focusOffset)) : readRange(selection);
}
};
var getExact = function (win) {
return getNativeSelection(win).filter(function (sel) {
return sel.rangeCount > 0;
}).bind(doGetExact);
};
var get = function (win) {
return getExact(win).map(function (range) {
return SimSelection.exact(range.start, range.soffset, range.finish, range.foffset);
});
};
var getFirstRect = function (win, selection) {
var rng = asLtrRange(win, selection);
return getFirstRect$1(rng);
};
var clear = function (win) {
getNativeSelection(win).each(function (selection) {
return selection.removeAllRanges();
});
};
var getBodyFromFrame = function (frame) {
return Optional.some(SugarElement.fromDom(frame.dom.contentWindow.document.body));
};
var getDocFromFrame = function (frame) {
return Optional.some(SugarElement.fromDom(frame.dom.contentWindow.document));
};
var getWinFromFrame = function (frame) {
return Optional.from(frame.dom.contentWindow);
};
var getSelectionFromFrame = function (frame) {
var optWin = getWinFromFrame(frame);
return optWin.bind(getExact);
};
var getFrame = function (editor) {
return editor.getFrame();
};
var getOrDerive = function (name, f) {
return function (editor) {
var g = editor[name].getOrThunk(function () {
var frame = getFrame(editor);
return function () {
return f(frame);
};
});
return g();
};
};
var getOrListen = function (editor, doc, name, type) {
return editor[name].getOrThunk(function () {
return function (handler) {
return bind(doc, type, handler);
};
});
};
var getActiveApi = function (editor) {
var frame = getFrame(editor);
var tryFallbackBox = function (win) {
var isCollapsed = function (sel) {
return eq(sel.start, sel.finish) && sel.soffset === sel.foffset;
};
var toStartRect = function (sel) {
var rect = sel.start.dom.getBoundingClientRect();
return rect.width > 0 || rect.height > 0 ? Optional.some(rect) : Optional.none();
};
return getExact(win).filter(isCollapsed).bind(toStartRect);
};
return getBodyFromFrame(frame).bind(function (body) {
return getDocFromFrame(frame).bind(function (doc) {
return getWinFromFrame(frame).map(function (win) {
var html = SugarElement.fromDom(doc.dom.documentElement);
var getCursorBox = editor.getCursorBox.getOrThunk(function () {
return function () {
return get(win).bind(function (sel) {
return getFirstRect(win, sel).orThunk(function () {
return tryFallbackBox(win);
});
});
};
});
var setSelection = editor.setSelection.getOrThunk(function () {
return function (start, soffset, finish, foffset) {
setExact(win, start, soffset, finish, foffset);
};
});
var clearSelection = editor.clearSelection.getOrThunk(function () {
return function () {
clear(win);
};
});
return {
body: body,
doc: doc,
win: win,
html: html,
getSelection: curry(getSelectionFromFrame, frame),
setSelection: setSelection,
clearSelection: clearSelection,
frame: frame,
onKeyup: getOrListen(editor, doc, 'onKeyup', 'keyup'),
onNodeChanged: getOrListen(editor, doc, 'onNodeChanged', 'SelectionChange'),
onDomChanged: editor.onDomChanged,
onScrollToCursor: editor.onScrollToCursor,
onScrollToElement: editor.onScrollToElement,
onToReading: editor.onToReading,
onToEditing: editor.onToEditing,
onToolbarScrollStart: editor.onToolbarScrollStart,
onTouchContent: editor.onTouchContent,
onTapContent: editor.onTapContent,
onTouchToolstrip: editor.onTouchToolstrip,
getCursorBox: getCursorBox
};
});
});
});
};
var getWin = getOrDerive('getWin', getWinFromFrame);
var tag = function () {
var head = first$1('head').getOrDie();
var nu = function () {
var meta = SugarElement.fromTag('meta');
set$8(meta, 'name', 'viewport');
append$2(head, meta);
return meta;
};
var element = first$1('meta[name="viewport"]').getOrThunk(nu);
var backup = get$b(element, 'content');
var maximize = function () {
set$8(element, 'content', 'width=device-width, initial-scale=1.0, user-scalable=no, maximum-scale=1.0');
};
var restore = function () {
if (backup !== undefined && backup !== null && backup.length > 0) {
set$8(element, 'content', backup);
} else {
set$8(element, 'content', 'user-scalable=yes');
}
};
return {
maximize: maximize,
restore: restore
};
};
var attr = 'data-ephox-mobile-fullscreen-style';
var siblingStyles = 'display:none!important;';
var ancestorPosition = 'position:absolute!important;';
var ancestorStyles = 'top:0!important;left:0!important;margin:0!important;padding:0!important;width:100%!important;height:100%!important;overflow:visible!important;';
var bgFallback = 'background-color:rgb(255,255,255)!important;';
var isAndroid = detect$1().os.isAndroid();
var matchColor = function (editorBody) {
var color = get$8(editorBody, 'background-color');
return color !== undefined && color !== '' ? 'background-color:' + color + '!important' : bgFallback;
};
var clobberStyles = function (container, editorBody) {
var gatherSiblings = function (element) {
return siblings(element, '*');
};
var clobber = function (clobberStyle) {
return function (element) {
var styles = get$b(element, 'style');
var backup = styles === undefined ? 'no-styles' : styles.trim();
if (backup === clobberStyle) {
return;
} else {
set$8(element, attr, backup);
set$8(element, 'style', clobberStyle);
}
};
};
var ancestors$1 = ancestors(container, '*');
var siblings$1 = bind$3(ancestors$1, gatherSiblings);
var bgColor = matchColor(editorBody);
each$1(siblings$1, clobber(siblingStyles));
each$1(ancestors$1, clobber(ancestorPosition + ancestorStyles + bgColor));
var containerStyles = isAndroid === true ? '' : ancestorPosition;
clobber(containerStyles + ancestorStyles + bgColor)(container);
};
var restoreStyles = function () {
var clobberedEls = all('[' + attr + ']');
each$1(clobberedEls, function (element) {
var restore = get$b(element, attr);
if (restore !== 'no-styles') {
set$8(element, 'style', restore);
} else {
remove$6(element, 'style');
}
remove$6(element, attr);
});
};
var DelayedFunction = function (fun, delay) {
var ref = null;
var schedule = function () {
var args = [];
for (var _i = 0; _i < arguments.length; _i++) {
args[_i] = arguments[_i];
}
ref = setTimeout(function () {
fun.apply(null, args);
ref = null;
}, delay);
};
var cancel = function () {
if (ref !== null) {
clearTimeout(ref);
ref = null;
}
};
return {
cancel: cancel,
schedule: schedule
};
};
var SIGNIFICANT_MOVE = 5;
var LONGPRESS_DELAY = 400;
var getTouch = function (event) {
var raw = event.raw;
if (raw.touches === undefined || raw.touches.length !== 1) {
return Optional.none();
}
return Optional.some(raw.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 monitor$1 = function (settings) {
var startData = value();
var longpressFired = Cell(false);
var longpress$1 = DelayedFunction(function (event) {
settings.triggerEvent(longpress(), event);
longpressFired.set(true);
}, LONGPRESS_DELAY);
var handleTouchstart = function (event) {
getTouch(event).each(function (touch) {
longpress$1.cancel();
var data = {
x: touch.clientX,
y: touch.clientY,
target: event.target
};
longpress$1.schedule(event);
longpressFired.set(false);
startData.set(data);
});
return Optional.none();
};
var handleTouchmove = function (event) {
longpress$1.cancel();
getTouch(event).each(function (touch) {
startData.on(function (data) {
if (isFarEnough(touch, data)) {
startData.clear();
}
});
});
return Optional.none();
};
var handleTouchend = function (event) {
longpress$1.cancel();
var isSame = function (data) {
return eq(data.target, event.target);
};
return startData.get().filter(isSame).map(function (_data) {
if (longpressFired.get()) {
event.prevent();
return false;
} else {
return settings.triggerEvent(tap(), event);
}
});
};
var handlers = wrapAll([
{
key: touchstart(),
value: handleTouchstart
},
{
key: touchmove(),
value: handleTouchmove
},
{
key: touchend(),
value: handleTouchend
}
]);
var fireIfReady = function (event, type) {
return get$c(handlers, type).bind(function (handler) {
return handler(event);
});
};
return { fireIfReady: fireIfReady };
};
var monitor = function (editorApi) {
var tapEvent = monitor$1({
triggerEvent: function (type, evt) {
editorApi.onTapContent(evt);
}
});
var onTouchend = function () {
return bind(editorApi.body, 'touchend', function (evt) {
tapEvent.fireIfReady(evt, 'touchend');
});
};
var onTouchmove = function () {
return bind(editorApi.body, 'touchmove', function (evt) {
tapEvent.fireIfReady(evt, 'touchmove');
});
};
var fireTouchstart = function (evt) {
tapEvent.fireIfReady(evt, 'touchstart');
};
return {
fireTouchstart: fireTouchstart,
onTouchend: onTouchend,
onTouchmove: onTouchmove
};
};
var isAndroid6 = detect$1().os.version.major >= 6;
var initEvents$1 = function (editorApi, toolstrip, alloy) {
var tapping = monitor(editorApi);
var outerDoc = owner$2(toolstrip);
var isRanged = function (sel) {
return !eq(sel.start, sel.finish) || sel.soffset !== sel.foffset;
};
var hasRangeInUi = function () {
return active(outerDoc).filter(function (input) {
return name$1(input) === 'input';
}).exists(function (input) {
return input.dom.selectionStart !== input.dom.selectionEnd;
});
};
var updateMargin = function () {
var rangeInContent = editorApi.doc.dom.hasFocus() && editorApi.getSelection().exists(isRanged);
alloy.getByDom(toolstrip).each((rangeInContent || hasRangeInUi()) === true ? Toggling.on : Toggling.off);
};
var listeners = [
bind(editorApi.body, 'touchstart', function (evt) {
editorApi.onTouchContent();
tapping.fireTouchstart(evt);
}),
tapping.onTouchmove(),
tapping.onTouchend(),
bind(toolstrip, 'touchstart', function (_evt) {
editorApi.onTouchToolstrip();
}),
editorApi.onToReading(function () {
blur$1(editorApi.body);
}),
editorApi.onToEditing(noop),
editorApi.onScrollToCursor(function (tinyEvent) {
tinyEvent.preventDefault();
editorApi.getCursorBox().each(function (bounds) {
var cWin = editorApi.win;
var isOutside = bounds.top > cWin.innerHeight || bounds.bottom > cWin.innerHeight;
var cScrollBy = isOutside ? bounds.bottom - cWin.innerHeight + 50 : 0;
if (cScrollBy !== 0) {
cWin.scrollTo(cWin.pageXOffset, cWin.pageYOffset + cScrollBy);
}
});
})
].concat(isAndroid6 === true ? [] : [
bind(SugarElement.fromDom(editorApi.win), 'blur', function () {
alloy.getByDom(toolstrip).each(Toggling.off);
}),
bind(outerDoc, 'select', updateMargin),
bind(editorApi.doc, 'selectionchange', updateMargin)
]);
var destroy = function () {
each$1(listeners, function (l) {
l.unbind();
});
};
return { destroy: destroy };
};
var safeParse = function (element, attribute) {
var parsed = parseInt(get$b(element, attribute), 10);
return isNaN(parsed) ? 0 : parsed;
};
var COLLAPSED_WIDTH = 2;
var collapsedRect = function (rect) {
return __assign(__assign({}, rect), { width: COLLAPSED_WIDTH });
};
var toRect = function (rawRect) {
return {
left: rawRect.left,
top: rawRect.top,
right: rawRect.right,
bottom: rawRect.bottom,
width: rawRect.width,
height: rawRect.height
};
};
var getRectsFromRange = function (range) {
if (!range.collapsed) {
return map$2(range.getClientRects(), toRect);
} else {
var start_1 = SugarElement.fromDom(range.startContainer);
return parent(start_1).bind(function (parent) {
var selection = SimSelection.exact(start_1, range.startOffset, parent, getEnd(parent));
var optRect = getFirstRect(range.startContainer.ownerDocument.defaultView, selection);
return optRect.map(collapsedRect).map(pure$2);
}).getOr([]);
}
};
var getRectangles = function (cWin) {
var sel = cWin.getSelection();
return sel !== undefined && sel.rangeCount > 0 ? getRectsFromRange(sel.getRangeAt(0)) : [];
};
var autocompleteHack = function () {
return function (f) {
global$2.setTimeout(function () {
f();
}, 0);
};
};
var resume$1 = function (cWin) {
cWin.focus();
var iBody = SugarElement.fromDom(cWin.document.body);
var inInput = active().exists(function (elem) {
return contains$1([
'input',
'textarea'
], name$1(elem));
});
var transaction = inInput ? autocompleteHack() : apply$1;
transaction(function () {
active().each(blur$1);
focus$3(iBody);
});
};
var EXTRA_SPACING = 50;
var data = 'data-' + resolve('last-outer-height');
var setLastHeight = function (cBody, value) {
set$8(cBody, data, value);
};
var getLastHeight = function (cBody) {
return safeParse(cBody, data);
};
var getBoundsFrom = function (rect) {
return {
top: rect.top,
bottom: rect.top + rect.height
};
};
var getBounds = function (cWin) {
var rects = getRectangles(cWin);
return rects.length > 0 ? Optional.some(rects[0]).map(getBoundsFrom) : Optional.none();
};
var findDelta = function (outerWindow, cBody) {
var last = getLastHeight(cBody);
var current = outerWindow.innerHeight;
return last > current ? Optional.some(last - current) : Optional.none();
};
var calculate = function (cWin, bounds, delta) {
var isOutside = bounds.top > cWin.innerHeight || bounds.bottom > cWin.innerHeight;
return isOutside ? Math.min(delta, bounds.bottom - cWin.innerHeight + EXTRA_SPACING) : 0;
};
var setup$2 = function (outerWindow, cWin) {
var cBody = SugarElement.fromDom(cWin.document.body);
var toEditing = function () {
resume$1(cWin);
};
var onResize = bind(SugarElement.fromDom(outerWindow), 'resize', function () {
findDelta(outerWindow, cBody).each(function (delta) {
getBounds(cWin).each(function (bounds) {
var cScrollBy = calculate(cWin, bounds, delta);
if (cScrollBy !== 0) {
cWin.scrollTo(cWin.pageXOffset, cWin.pageYOffset + cScrollBy);
}
});
});
setLastHeight(cBody, outerWindow.innerHeight);
});
setLastHeight(cBody, outerWindow.innerHeight);
var destroy = function () {
onResize.unbind();
};
return {
toEditing: toEditing,
destroy: destroy
};
};
var create$2 = function (platform, mask) {
var meta = tag();
var androidApi = api$2();
var androidEvents = api$2();
var enter = function () {
mask.hide();
add$1(platform.container, resolve('fullscreen-maximized'));
add$1(platform.container, resolve('android-maximized'));
meta.maximize();
add$1(platform.body, resolve('android-scroll-reload'));
androidApi.set(setup$2(platform.win, getWin(platform.editor).getOrDie('no')));
getActiveApi(platform.editor).each(function (editorApi) {
clobberStyles(platform.container, editorApi.body);
androidEvents.set(initEvents$1(editorApi, platform.toolstrip, platform.alloy));
});
};
var exit = function () {
meta.restore();
mask.show();
remove$3(platform.container, resolve('fullscreen-maximized'));
remove$3(platform.container, resolve('android-maximized'));
restoreStyles();
remove$3(platform.body, resolve('android-scroll-reload'));
androidEvents.clear();
androidApi.clear();
};
return {
enter: enter,
exit: exit
};
};
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 sketch = function (onView, _translate) {
var memIcon = record(Container.sketch({
dom: dom$1('<div aria-hidden="true" class="${prefix}-mask-tap-icon"></div>'),
containerBehaviours: derive$2([Toggling.config({
toggleClass: resolve('mask-tap-icon-selected'),
toggleOnExecute: false
})])
}));
var onViewThrottle = first(onView, 200);
return Container.sketch({
dom: dom$1('<div class="${prefix}-disabled-mask"></div>'),
components: [Container.sketch({
dom: dom$1('<div class="${prefix}-content-container"></div>'),
components: [Button.sketch({
dom: dom$1('<div class="${prefix}-content-tap-section"></div>'),
components: [memIcon.asSpec()],
action: function (_button) {
onViewThrottle.throttle();
},
buttonBehaviours: derive$2([Toggling.config({ toggleClass: resolve('mask-tap-icon-selected') })])
})]
})]
});
};
var unbindNoop = constant$1({ unbind: noop });
var MobileSchema = objOf([
requiredObjOf('editor', [
required$1('getFrame'),
option('getBody'),
option('getDoc'),
option('getWin'),
option('getSelection'),
option('setSelection'),
option('clearSelection'),
option('cursorSaver'),
option('onKeyup'),
option('onNodeChanged'),
option('getCursorBox'),
required$1('onDomChanged'),
defaulted('onTouchContent', noop),
defaulted('onTapContent', noop),
defaulted('onTouchToolstrip', noop),
defaulted('onScrollToCursor', unbindNoop),
defaulted('onScrollToElement', unbindNoop),
defaulted('onToEditing', unbindNoop),
defaulted('onToReading', unbindNoop),
defaulted('onToolbarScrollStart', identity)
]),
required$1('socket'),
required$1('toolstrip'),
required$1('dropup'),
required$1('toolbar'),
required$1('container'),
required$1('alloy'),
customField('win', function (spec) {
return owner$2(spec.socket).dom.defaultView;
}),
customField('body', function (spec) {
return SugarElement.fromDom(spec.socket.dom.ownerDocument.body);
}),
defaulted('translate', identity),
defaulted('setReadOnly', noop),
defaulted('readOnlyOnInit', always)
]);
var produce$1 = function (raw) {
var mobile = asRawOrDie$1('Getting AndroidWebapp schema', MobileSchema, raw);
set$5(mobile.toolstrip, 'width', '100%');
var onTap = function () {
mobile.setReadOnly(mobile.readOnlyOnInit());
mode.enter();
};
var mask = build$1(sketch(onTap, mobile.translate));
mobile.alloy.add(mask);
var maskApi = {
show: function () {
mobile.alloy.add(mask);
},
hide: function () {
mobile.alloy.remove(mask);
}
};
append$2(mobile.container, mask.element);
var mode = create$2(mobile, maskApi);
return {
setReadOnly: mobile.setReadOnly,
refreshStructure: noop,
enter: mode.enter,
exit: mode.exit,
destroy: noop
};
};
var schema$1 = constant$1([
required$1('dom'),
defaulted('shell', true),
field$1('toolbarBehaviours', [Replacing])
]);
var enhanceGroups = function () {
return { behaviours: derive$2([Replacing.config({})]) };
};
var parts$1 = constant$1([optional({
name: 'groups',
overrides: enhanceGroups
})]);
var factory$1 = function (detail, components, _spec, _externals) {
var setGroups = function (toolbar, groups) {
getGroupContainer(toolbar).fold(function () {
console.error('Toolbar was defined to not be a shell, but no groups container was specified in components');
throw new Error('Toolbar was defined to not be a shell, but no groups container was specified in components');
}, function (container) {
Replacing.set(container, groups);
});
};
var getGroupContainer = function (component) {
return detail.shell ? Optional.some(component) : getPart(component, detail, 'groups');
};
var extra = detail.shell ? {
behaviours: [Replacing.config({})],
components: []
} : {
behaviours: [],
components: components
};
return {
uid: detail.uid,
dom: detail.dom,
components: extra.components,
behaviours: augment(detail.toolbarBehaviours, extra.behaviours),
apis: { setGroups: setGroups },
domModification: { attributes: { role: 'group' } }
};
};
var Toolbar = composite({
name: 'Toolbar',
configFields: schema$1(),
partFields: parts$1(),
factory: factory$1,
apis: {
setGroups: function (apis, toolbar, groups) {
apis.setGroups(toolbar, groups);
}
}
});
var schema = constant$1([
required$1('items'),
markers(['itemSelector']),
field$1('tgroupBehaviours', [Keying])
]);
var parts = constant$1([group({
name: 'items',
unit: 'item'
})]);
var factory = function (detail, components, _spec, _externals) {
return {
uid: detail.uid,
dom: detail.dom,
components: components,
behaviours: augment(detail.tgroupBehaviours, [Keying.config({
mode: 'flow',
selector: detail.markers.itemSelector
})]),
domModification: { attributes: { role: 'toolbar' } }
};
};
var ToolbarGroup = composite({
name: 'ToolbarGroup',
configFields: schema(),
partFields: parts(),
factory: factory
});
var dataHorizontal = 'data-' + resolve('horizontal-scroll');
var canScrollVertically = function (container) {
container.dom.scrollTop = 1;
var result = container.dom.scrollTop !== 0;
container.dom.scrollTop = 0;
return result;
};
var canScrollHorizontally = function (container) {
container.dom.scrollLeft = 1;
var result = container.dom.scrollLeft !== 0;
container.dom.scrollLeft = 0;
return result;
};
var hasVerticalScroll = function (container) {
return container.dom.scrollTop > 0 || canScrollVertically(container);
};
var hasHorizontalScroll = function (container) {
return container.dom.scrollLeft > 0 || canScrollHorizontally(container);
};
var markAsHorizontal = function (container) {
set$8(container, dataHorizontal, 'true');
};
var hasScroll = function (container) {
return get$b(container, dataHorizontal) === 'true' ? hasHorizontalScroll(container) : hasVerticalScroll(container);
};
var exclusive = function (scope, selector) {
return bind(scope, 'touchmove', function (event) {
closest$1(event.target, selector).filter(hasScroll).fold(function () {
event.prevent();
}, noop);
});
};
var ScrollingToolbar = function () {
var makeGroup = function (gSpec) {
var scrollClass = gSpec.scrollable === true ? '${prefix}-toolbar-scrollable-group' : '';
return {
dom: dom$1('<div aria-label="' + gSpec.label + '" class="${prefix}-toolbar-group ' + scrollClass + '"></div>'),
tgroupBehaviours: derive$2([config('adhoc-scrollable-toolbar', gSpec.scrollable === true ? [runOnInit(function (component, _simulatedEvent) {
set$5(component.element, 'overflow-x', 'auto');
markAsHorizontal(component.element);
register$2(component.element);
})] : [])]),
components: [Container.sketch({ components: [ToolbarGroup.parts.items({})] })],
markers: { itemSelector: '.' + resolve('toolbar-group-item') },
items: gSpec.items
};
};
var toolbar = build$1(Toolbar.sketch({
dom: dom$1('<div class="${prefix}-toolbar"></div>'),
components: [Toolbar.parts.groups({})],
toolbarBehaviours: derive$2([
Toggling.config({
toggleClass: resolve('context-toolbar'),
toggleOnExecute: false,
aria: { mode: 'none' }
}),
Keying.config({ mode: 'cyclic' })
]),
shell: true
}));
var wrapper = build$1(Container.sketch({
dom: { classes: [resolve('toolstrip')] },
components: [premade(toolbar)],
containerBehaviours: derive$2([Toggling.config({
toggleClass: resolve('android-selection-context-toolbar'),
toggleOnExecute: false
})])
}));
var resetGroups = function () {
Toolbar.setGroups(toolbar, initGroups.get());
Toggling.off(toolbar);
};
var initGroups = Cell([]);
var setGroups = function (gs) {
initGroups.set(gs);
resetGroups();
};
var createGroups = function (gs) {
return map$2(gs, compose(ToolbarGroup.sketch, makeGroup));
};
var refresh = function () {
};
var setContextToolbar = function (gs) {
Toggling.on(toolbar);
Toolbar.setGroups(toolbar, gs);
};
var restoreToolbar = function () {
if (Toggling.isOn(toolbar)) {
resetGroups();
}
};
var focus = function () {
Keying.focusIn(toolbar);
};
return {
wrapper: wrapper,
toolbar: toolbar,
createGroups: createGroups,
setGroups: setGroups,
setContextToolbar: setContextToolbar,
restoreToolbar: restoreToolbar,
refresh: refresh,
focus: focus
};
};
var makeEditSwitch = function (webapp) {
return build$1(Button.sketch({
dom: dom$1('<div class="${prefix}-mask-edit-icon ${prefix}-icon"></div>'),
action: function () {
webapp.run(function (w) {
w.setReadOnly(false);
});
}
}));
};
var makeSocket = function () {
return build$1(Container.sketch({
dom: dom$1('<div class="${prefix}-editor-socket"></div>'),
components: [],
containerBehaviours: derive$2([Replacing.config({})])
}));
};
var showEdit = function (socket, switchToEdit) {
Replacing.append(socket, premade(switchToEdit));
};
var hideEdit = function (socket, switchToEdit) {
Replacing.remove(socket, switchToEdit);
};
var updateMode = function (socket, switchToEdit, readOnly, root) {
var swap = readOnly === true ? Swapping.toAlpha : Swapping.toOmega;
swap(root);
var f = readOnly ? showEdit : hideEdit;
f(socket, switchToEdit);
};
var getAnimationRoot = function (component, slideConfig) {
return slideConfig.getAnimationRoot.fold(function () {
return component.element;
}, function (get) {
return get(component);
});
};
var getDimensionProperty = function (slideConfig) {
return slideConfig.dimension.property;
};
var getDimension = function (slideConfig, elem) {
return slideConfig.dimension.getDimension(elem);
};
var disableTransitions = function (component, slideConfig) {
var root = getAnimationRoot(component, slideConfig);
remove$1(root, [
slideConfig.shrinkingClass,
slideConfig.growingClass
]);
};
var setShrunk = function (component, slideConfig) {
remove$3(component.element, slideConfig.openClass);
add$1(component.element, slideConfig.closedClass);
set$5(component.element, getDimensionProperty(slideConfig), '0px');
reflow(component.element);
};
var setGrown = function (component, slideConfig) {
remove$3(component.element, slideConfig.closedClass);
add$1(component.element, slideConfig.openClass);
remove$2(component.element, getDimensionProperty(slideConfig));
};
var doImmediateShrink = function (component, slideConfig, slideState, _calculatedSize) {
slideState.setCollapsed();
set$5(component.element, getDimensionProperty(slideConfig), getDimension(slideConfig, component.element));
reflow(component.element);
disableTransitions(component, slideConfig);
setShrunk(component, slideConfig);
slideConfig.onStartShrink(component);
slideConfig.onShrunk(component);
};
var doStartShrink = function (component, slideConfig, slideState, calculatedSize) {
var size = calculatedSize.getOrThunk(function () {
return getDimension(slideConfig, component.element);
});
slideState.setCollapsed();
set$5(component.element, getDimensionProperty(slideConfig), size);
reflow(component.element);
var root = getAnimationRoot(component, slideConfig);
remove$3(root, slideConfig.growingClass);
add$1(root, slideConfig.shrinkingClass);
setShrunk(component, slideConfig);
slideConfig.onStartShrink(component);
};
var doStartSmartShrink = function (component, slideConfig, slideState) {
var size = getDimension(slideConfig, component.element);
var shrinker = size === '0px' ? doImmediateShrink : doStartShrink;
shrinker(component, slideConfig, slideState, Optional.some(size));
};
var doStartGrow = function (component, slideConfig, slideState) {
var root = getAnimationRoot(component, slideConfig);
var wasShrinking = has(root, slideConfig.shrinkingClass);
var beforeSize = getDimension(slideConfig, component.element);
setGrown(component, slideConfig);
var fullSize = getDimension(slideConfig, component.element);
var startPartialGrow = function () {
set$5(component.element, getDimensionProperty(slideConfig), beforeSize);
reflow(component.element);
};
var startCompleteGrow = function () {
setShrunk(component, slideConfig);
};
var setStartSize = wasShrinking ? startPartialGrow : startCompleteGrow;
setStartSize();
remove$3(root, slideConfig.shrinkingClass);
add$1(root, slideConfig.growingClass);
setGrown(component, slideConfig);
set$5(component.element, getDimensionProperty(slideConfig), fullSize);
slideState.setExpanded();
slideConfig.onStartGrow(component);
};
var refresh$1 = function (component, slideConfig, slideState) {
if (slideState.isExpanded()) {
remove$2(component.element, getDimensionProperty(slideConfig));
var fullSize = getDimension(slideConfig, component.element);
set$5(component.element, getDimensionProperty(slideConfig), fullSize);
}
};
var grow = function (component, slideConfig, slideState) {
if (!slideState.isExpanded()) {
doStartGrow(component, slideConfig, slideState);
}
};
var shrink = function (component, slideConfig, slideState) {
if (slideState.isExpanded()) {
doStartSmartShrink(component, slideConfig, slideState);
}
};
var immediateShrink = function (component, slideConfig, slideState) {
if (slideState.isExpanded()) {
doImmediateShrink(component, slideConfig, slideState);
}
};
var hasGrown = function (component, slideConfig, slideState) {
return slideState.isExpanded();
};
var hasShrunk = function (component, slideConfig, slideState) {
return slideState.isCollapsed();
};
var isGrowing = function (component, slideConfig, _slideState) {
var root = getAnimationRoot(component, slideConfig);
return has(root, slideConfig.growingClass) === true;
};
var isShrinking = function (component, slideConfig, _slideState) {
var root = getAnimationRoot(component, slideConfig);
return has(root, slideConfig.shrinkingClass) === true;
};
var isTransitioning = function (component, slideConfig, slideState) {
return isGrowing(component, slideConfig) || isShrinking(component, slideConfig);
};
var toggleGrow = function (component, slideConfig, slideState) {
var f = slideState.isExpanded() ? doStartSmartShrink : doStartGrow;
f(component, slideConfig, slideState);
};
var SlidingApis = /*#__PURE__*/Object.freeze({
__proto__: null,
refresh: refresh$1,
grow: grow,
shrink: shrink,
immediateShrink: immediateShrink,
hasGrown: hasGrown,
hasShrunk: hasShrunk,
isGrowing: isGrowing,
isShrinking: isShrinking,
isTransitioning: isTransitioning,
toggleGrow: toggleGrow,
disableTransitions: disableTransitions
});
var exhibit = function (base, slideConfig, _slideState) {
var expanded = slideConfig.expanded;
return expanded ? nu$3({
classes: [slideConfig.openClass],
styles: {}
}) : nu$3({
classes: [slideConfig.closedClass],
styles: wrap(slideConfig.dimension.property, '0px')
});
};
var events = function (slideConfig, slideState) {
return derive$3([runOnSource(transitionend(), function (component, simulatedEvent) {
var raw = simulatedEvent.event.raw;
if (raw.propertyName === slideConfig.dimension.property) {
disableTransitions(component, slideConfig);
if (slideState.isExpanded()) {
remove$2(component.element, slideConfig.dimension.property);
}
var notify = slideState.isExpanded() ? slideConfig.onGrown : slideConfig.onShrunk;
notify(component);
}
})]);
};
var ActiveSliding = /*#__PURE__*/Object.freeze({
__proto__: null,
exhibit: exhibit,
events: events
});
var SlidingSchema = [
required$1('closedClass'),
required$1('openClass'),
required$1('shrinkingClass'),
required$1('growingClass'),
option('getAnimationRoot'),
onHandler('onShrunk'),
onHandler('onStartShrink'),
onHandler('onGrown'),
onHandler('onStartGrow'),
defaulted('expanded', false),
requiredOf('dimension', choose$1('property', {
width: [
output('property', 'width'),
output('getDimension', function (elem) {
return get$5(elem) + 'px';
})
],
height: [
output('property', 'height'),
output('getDimension', function (elem) {
return get$7(elem) + 'px';
})
]
}))
];
var init$1 = function (spec) {
var state = Cell(spec.expanded);
var readState = function () {
return 'expanded: ' + state.get();
};
return nu$2({
isExpanded: function () {
return state.get() === true;
},
isCollapsed: function () {
return state.get() === false;
},
setCollapsed: curry(state.set, false),
setExpanded: curry(state.set, true),
readState: readState
});
};
var SlidingState = /*#__PURE__*/Object.freeze({
__proto__: null,
init: init$1
});
var Sliding = create$5({
fields: SlidingSchema,
name: 'sliding',
active: ActiveSliding,
apis: SlidingApis,
state: SlidingState
});
var build = function (refresh, scrollIntoView) {
var dropup = build$1(Container.sketch({
dom: {
tag: 'div',
classes: [resolve('dropup')]
},
components: [],
containerBehaviours: derive$2([
Replacing.config({}),
Sliding.config({
closedClass: resolve('dropup-closed'),
openClass: resolve('dropup-open'),
shrinkingClass: resolve('dropup-shrinking'),
growingClass: resolve('dropup-growing'),
dimension: { property: 'height' },
onShrunk: function (component) {
refresh();
scrollIntoView();
Replacing.set(component, []);
},
onGrown: function (_component) {
refresh();
scrollIntoView();
}
}),
orientation(function (_component, _data) {
disappear(noop);
})
])
}));
var appear = function (menu, update, component) {
if (Sliding.hasShrunk(dropup) === true && Sliding.isTransitioning(dropup) === false) {
window.requestAnimationFrame(function () {
update(component);
Replacing.set(dropup, [menu()]);
Sliding.grow(dropup);
});
}
};
var disappear = function (onReadyToShrink) {
window.requestAnimationFrame(function () {
onReadyToShrink();
Sliding.shrink(dropup);
});
};
return {
appear: appear,
disappear: disappear,
component: dropup,
element: dropup.element
};
};
var closest = function (scope, selector, isRoot) {
return closest$1(scope, selector, isRoot).isSome();
};
var isDangerous = function (event) {
var keyEv = event.raw;
return keyEv.which === BACKSPACE[0] && !contains$1([
'input',
'textarea'
], name$1(event.target)) && !closest(event.target, '[contenteditable="true"]');
};
var isFirefox = function () {
return detect$1().browser.isFirefox();
};
var bindFocus = function (container, handler) {
if (isFirefox()) {
return capture(container, 'focus', handler);
} else {
return bind(container, 'focusin', handler);
}
};
var bindBlur = function (container, handler) {
if (isFirefox()) {
return capture(container, 'blur', handler);
} else {
return bind(container, 'focusout', handler);
}
};
var setup$1 = function (container, rawSettings) {
var settings = __assign({ stopBackspace: true }, rawSettings);
var pointerEvents = [
'touchstart',
'touchmove',
'touchend',
'touchcancel',
'gesturestart',
'mousedown',
'mouseup',
'mouseover',
'mousemove',
'mouseout',
'click'
];
var tapEvent = monitor$1(settings);
var simpleEvents = map$2(pointerEvents.concat([
'selectstart',
'input',
'contextmenu',
'change',
'transitionend',
'transitioncancel',
'drag',
'dragstart',
'dragend',
'dragenter',
'dragleave',
'dragover',
'drop',
'keyup'
]), function (type) {
return bind(container, type, function (event) {
tapEvent.fireIfReady(event, type).each(function (tapStopped) {
if (tapStopped) {
event.kill();
}
});
var stopped = settings.triggerEvent(type, event);
if (stopped) {
event.kill();
}
});
});
var pasteTimeout = value();
var onPaste = bind(container, 'paste', function (event) {
tapEvent.fireIfReady(event, 'paste').each(function (tapStopped) {
if (tapStopped) {
event.kill();
}
});
var stopped = settings.triggerEvent('paste', event);
if (stopped) {
event.kill();
}
pasteTimeout.set(setTimeout(function () {
settings.triggerEvent(postPaste(), event);
}, 0));
});
var onKeydown = bind(container, 'keydown', function (event) {
var stopped = settings.triggerEvent('keydown', event);
if (stopped) {
event.kill();
} else if (settings.stopBackspace && isDangerous(event)) {
event.prevent();
}
});
var onFocusIn = bindFocus(container, function (event) {
var stopped = settings.triggerEvent('focusin', event);
if (stopped) {
event.kill();
}
});
var focusoutTimeout = value();
var onFocusOut = bindBlur(container, function (event) {
var stopped = settings.triggerEvent('focusout', event);
if (stopped) {
event.kill();
}
focusoutTimeout.set(setTimeout(function () {
settings.triggerEvent(postBlur(), event);
}, 0));
});
var unbind = function () {
each$1(simpleEvents, function (e) {
e.unbind();
});
onKeydown.unbind();
onFocusIn.unbind();
onFocusOut.unbind();
onPaste.unbind();
pasteTimeout.on(clearTimeout);
focusoutTimeout.on(clearTimeout);
};
return { unbind: unbind };
};
var derive$1 = function (rawEvent, rawTarget) {
var source = get$c(rawEvent, 'target').getOr(rawTarget);
return Cell(source);
};
var fromSource = function (event, source) {
var stopper = Cell(false);
var cutter = Cell(false);
var stop = function () {
stopper.set(true);
};
var cut = function () {
cutter.set(true);
};
return {
stop: stop,
cut: cut,
isStopped: stopper.get,
isCut: cutter.get,
event: event,
setSource: source.set,
getSource: source.get
};
};
var fromExternal = function (event) {
var stopper = Cell(false);
var stop = function () {
stopper.set(true);
};
return {
stop: stop,
cut: noop,
isStopped: stopper.get,
isCut: never,
event: event,
setSource: die('Cannot set source of a broadcasted event'),
getSource: die('Cannot get source of a broadcasted event')
};
};
var adt = Adt.generate([
{ stopped: [] },
{ resume: ['element'] },
{ complete: [] }
]);
var doTriggerHandler = function (lookup, eventType, rawEvent, target, source, logger) {
var handler = lookup(eventType, target);
var simulatedEvent = fromSource(rawEvent, source);
return handler.fold(function () {
logger.logEventNoHandlers(eventType, target);
return adt.complete();
}, function (handlerInfo) {
var descHandler = handlerInfo.descHandler;
var eventHandler = getCurried(descHandler);
eventHandler(simulatedEvent);
if (simulatedEvent.isStopped()) {
logger.logEventStopped(eventType, handlerInfo.element, descHandler.purpose);
return adt.stopped();
} else if (simulatedEvent.isCut()) {
logger.logEventCut(eventType, handlerInfo.element, descHandler.purpose);
return adt.complete();
} else {
return parent(handlerInfo.element).fold(function () {
logger.logNoParent(eventType, handlerInfo.element, descHandler.purpose);
return adt.complete();
}, function (parent) {
logger.logEventResponse(eventType, handlerInfo.element, descHandler.purpose);
return adt.resume(parent);
});
}
});
};
var doTriggerOnUntilStopped = function (lookup, eventType, rawEvent, rawTarget, source, logger) {
return doTriggerHandler(lookup, eventType, rawEvent, rawTarget, source, logger).fold(always, function (parent) {
return doTriggerOnUntilStopped(lookup, eventType, rawEvent, parent, source, logger);
}, never);
};
var triggerHandler = function (lookup, eventType, rawEvent, target, logger) {
var source = derive$1(rawEvent, target);
return doTriggerHandler(lookup, eventType, rawEvent, target, source, logger);
};
var broadcast = function (listeners, rawEvent, _logger) {
var simulatedEvent = fromExternal(rawEvent);
each$1(listeners, function (listener) {
var descHandler = listener.descHandler;
var handler = getCurried(descHandler);
handler(simulatedEvent);
});
return simulatedEvent.isStopped();
};
var triggerUntilStopped = function (lookup, eventType, rawEvent, logger) {
return triggerOnUntilStopped(lookup, eventType, rawEvent, rawEvent.target, logger);
};
var triggerOnUntilStopped = function (lookup, eventType, rawEvent, rawTarget, logger) {
var source = derive$1(rawEvent, rawTarget);
return doTriggerOnUntilStopped(lookup, eventType, rawEvent, rawTarget, source, logger);
};
var eventHandler = function (element, descHandler) {
return {
element: element,
descHandler: descHandler
};
};
var broadcastHandler = function (id, handler) {
return {
id: id,
descHandler: handler
};
};
var EventRegistry = function () {
var registry = {};
var registerId = function (extraArgs, id, events) {
each(events, function (v, k) {
var handlers = registry[k] !== undefined ? registry[k] : {};
handlers[id] = curryArgs(v, extraArgs);
registry[k] = handlers;
});
};
var findHandler = function (handlers, elem) {
return read(elem).bind(function (id) {
return get$c(handlers, id);
}).map(function (descHandler) {
return eventHandler(elem, descHandler);
});
};
var filterByType = function (type) {
return get$c(registry, type).map(function (handlers) {
return mapToArray(handlers, function (f, id) {
return broadcastHandler(id, f);
});
}).getOr([]);
};
var find = function (isAboveRoot, type, target) {
return get$c(registry, type).bind(function (handlers) {
return closest$3(target, function (elem) {
return findHandler(handlers, elem);
}, isAboveRoot);
});
};
var unregisterId = function (id) {
each(registry, function (handlersById, _eventName) {
if (has$2(handlersById, id)) {
delete handlersById[id];
}
});
};
return {
registerId: registerId,
unregisterId: unregisterId,
filterByType: filterByType,
find: find
};
};
var Registry = function () {
var events = EventRegistry();
var components = {};
var readOrTag = function (component) {
var elem = component.element;
return read(elem).getOrThunk(function () {
return write('uid-', component.element);
});
};
var failOnDuplicate = function (component, tagId) {
var conflict = components[tagId];
if (conflict === component) {
unregister(component);
} else {
throw new Error('The tagId "' + tagId + '" is already used by: ' + element(conflict.element) + '\nCannot use it for: ' + element(component.element) + '\n' + 'The conflicting element is' + (inBody(conflict.element) ? ' ' : ' not ') + 'already in the DOM');
}
};
var register = function (component) {
var tagId = readOrTag(component);
if (hasNonNullableKey(components, tagId)) {
failOnDuplicate(component, tagId);
}
var extraArgs = [component];
events.registerId(extraArgs, tagId, component.events);
components[tagId] = component;
};
var unregister = function (component) {
read(component.element).each(function (tagId) {
delete components[tagId];
events.unregisterId(tagId);
});
};
var filter = function (type) {
return events.filterByType(type);
};
var find = function (isAboveRoot, type, target) {
return events.find(isAboveRoot, type, target);
};
var getById = function (id) {
return get$c(components, id);
};
return {
find: find,
filter: filter,
register: register,
unregister: unregister,
getById: getById
};
};
var takeover$1 = function (root) {
var isAboveRoot = function (el) {
return parent(root.element).fold(always, function (parent) {
return eq(el, parent);
});
};
var registry = Registry();
var lookup = function (eventName, target) {
return registry.find(isAboveRoot, eventName, target);
};
var domEvents = setup$1(root.element, {
triggerEvent: function (eventName, event) {
return monitorEvent(eventName, event.target, function (logger) {
return triggerUntilStopped(lookup, eventName, event, logger);
});
}
});
var systemApi = {
debugInfo: constant$1('real'),
triggerEvent: function (eventName, target, data) {
monitorEvent(eventName, target, function (logger) {
return triggerOnUntilStopped(lookup, eventName, data, target, logger);
});
},
triggerFocus: function (target, originator) {
read(target).fold(function () {
focus$3(target);
}, function (_alloyId) {
monitorEvent(focus$4(), target, function (logger) {
triggerHandler(lookup, focus$4(), {
originator: originator,
kill: noop,
prevent: noop,
target: target
}, target, logger);
return false;
});
});
},
triggerEscape: function (comp, simulatedEvent) {
systemApi.triggerEvent('keydown', comp.element, simulatedEvent.event);
},
getByUid: function (uid) {
return getByUid(uid);
},
getByDom: function (elem) {
return getByDom(elem);
},
build: build$1,
addToGui: function (c) {
add(c);
},
removeFromGui: function (c) {
remove(c);
},
addToWorld: function (c) {
addToWorld(c);
},
removeFromWorld: function (c) {
removeFromWorld(c);
},
broadcast: function (message) {
broadcast$1(message);
},
broadcastOn: function (channels, message) {
broadcastOn(channels, message);
},
broadcastEvent: function (eventName, event) {
broadcastEvent(eventName, event);
},
isConnected: always
};
var addToWorld = function (component) {
component.connect(systemApi);
if (!isText(component.element)) {
registry.register(component);
each$1(component.components(), addToWorld);
systemApi.triggerEvent(systemInit(), component.element, { target: component.element });
}
};
var removeFromWorld = function (component) {
if (!isText(component.element)) {
each$1(component.components(), removeFromWorld);
registry.unregister(component);
}
component.disconnect();
};
var add = function (component) {
attach(root, component);
};
var remove = function (component) {
detach(component);
};
var destroy = function () {
domEvents.unbind();
remove$7(root.element);
};
var broadcastData = function (data) {
var receivers = registry.filter(receive$1());
each$1(receivers, function (receiver) {
var descHandler = receiver.descHandler;
var handler = getCurried(descHandler);
handler(data);
});
};
var broadcast$1 = function (message) {
broadcastData({
universal: true,
data: message
});
};
var broadcastOn = function (channels, message) {
broadcastData({
universal: false,
channels: channels,
data: message
});
};
var broadcastEvent = function (eventName, event) {
var listeners = registry.filter(eventName);
return broadcast(listeners, event);
};
var getByUid = function (uid) {
return registry.getById(uid).fold(function () {
return Result.error(new Error('Could not find component with uid: "' + uid + '" in system.'));
}, Result.value);
};
var getByDom = function (elem) {
var uid = read(elem).getOr('not found');
return getByUid(uid);
};
addToWorld(root);
return {
root: root,
element: root.element,
destroy: destroy,
add: add,
remove: remove,
getByUid: getByUid,
getByDom: getByDom,
addToWorld: addToWorld,
removeFromWorld: removeFromWorld,
broadcast: broadcast$1,
broadcastOn: broadcastOn,
broadcastEvent: broadcastEvent
};
};
var READ_ONLY_MODE_CLASS = resolve('readonly-mode');
var EDIT_MODE_CLASS = resolve('edit-mode');
function OuterContainer (spec) {
var root = build$1(Container.sketch({
dom: { classes: [resolve('outer-container')].concat(spec.classes) },
containerBehaviours: derive$2([Swapping.config({
alpha: READ_ONLY_MODE_CLASS,
omega: EDIT_MODE_CLASS
})])
}));
return takeover$1(root);
}
function AndroidRealm (scrollIntoView) {
var alloy = OuterContainer({ classes: [resolve('android-container')] });
var toolbar = ScrollingToolbar();
var webapp = api$2();
var switchToEdit = makeEditSwitch(webapp);
var socket = makeSocket();
var dropup = build(noop, scrollIntoView);
alloy.add(toolbar.wrapper);
alloy.add(socket);
alloy.add(dropup.component);
var setToolbarGroups = function (rawGroups) {
var groups = toolbar.createGroups(rawGroups);
toolbar.setGroups(groups);
};
var setContextToolbar = function (rawGroups) {
var groups = toolbar.createGroups(rawGroups);
toolbar.setContextToolbar(groups);
};
var focusToolbar = function () {
toolbar.focus();
};
var restoreToolbar = function () {
toolbar.restoreToolbar();
};
var init = function (spec) {
webapp.set(produce$1(spec));
};
var exit = function () {
webapp.run(function (w) {
w.exit();
Replacing.remove(socket, switchToEdit);
});
};
var updateMode$1 = function (readOnly) {
updateMode(socket, switchToEdit, readOnly, alloy.root);
};
return {
system: alloy,
element: alloy.element,
init: init,
exit: exit,
setToolbarGroups: setToolbarGroups,
setContextToolbar: setContextToolbar,
focusToolbar: focusToolbar,
restoreToolbar: restoreToolbar,
updateMode: updateMode$1,
socket: socket,
dropup: dropup
};
}
var input = function (parent, operation) {
var input = SugarElement.fromTag('input');
setAll(input, {
opacity: '0',
position: 'absolute',
top: '-1000px',
left: '-1000px'
});
append$2(parent, input);
focus$3(input);
operation(input);
remove$7(input);
};
var refresh = function (winScope) {
var sel = winScope.getSelection();
if (sel.rangeCount > 0) {
var br = sel.getRangeAt(0);
var r = winScope.document.createRange();
r.setStart(br.startContainer, br.startOffset);
r.setEnd(br.endContainer, br.endOffset);
sel.removeAllRanges();
sel.addRange(r);
}
};
var resume = function (cWin, frame) {
active().each(function (active) {
if (!eq(active, frame)) {
blur$1(active);
}
});
cWin.focus();
focus$3(SugarElement.fromDom(cWin.document.body));
refresh(cWin);
};
var stubborn = function (outerBody, cWin, page, frame) {
var toEditing = function () {
resume(cWin, frame);
};
var toReading = function () {
input(outerBody, blur$1);
};
var captureInput = bind(page, 'keydown', function (evt) {
if (!contains$1([
'input',
'textarea'
], name$1(evt.target))) {
toEditing();
}
});
var onToolbarTouch = noop;
var destroy = function () {
captureInput.unbind();
};
return {
toReading: toReading,
toEditing: toEditing,
onToolbarTouch: onToolbarTouch,
destroy: destroy
};
};
var initEvents = function (editorApi, iosApi, toolstrip, socket, _dropup) {
var saveSelectionFirst = function () {
iosApi.run(function (api) {
api.highlightSelection();
});
};
var refreshIosSelection = function () {
iosApi.run(function (api) {
api.refreshSelection();
});
};
var scrollToY = function (yTop, height) {
var y = yTop - socket.dom.scrollTop;
iosApi.run(function (api) {
api.scrollIntoView(y, y + height);
});
};
var scrollToElement = function (_target) {
scrollToY(iosApi, socket);
};
var scrollToCursor = function () {
editorApi.getCursorBox().each(function (box) {
scrollToY(box.top, box.height);
});
};
var clearSelection = function () {
iosApi.run(function (api) {
api.clearSelection();
});
};
var clearAndRefresh = function () {
clearSelection();
refreshThrottle.throttle();
};
var refreshView = function () {
scrollToCursor();
iosApi.run(function (api) {
api.syncHeight();
});
};
var reposition = function () {
var toolbarHeight = get$7(toolstrip);
iosApi.run(function (api) {
api.setViewportOffset(toolbarHeight);
});
refreshIosSelection();
refreshView();
};
var toEditing = function () {
iosApi.run(function (api) {
api.toEditing();
});
};
var toReading = function () {
iosApi.run(function (api) {
api.toReading();
});
};
var onToolbarTouch = function (event) {
iosApi.run(function (api) {
api.onToolbarTouch(event);
});
};
var tapping = monitor(editorApi);
var refreshThrottle = last(refreshView, 300);
var listeners = [
editorApi.onKeyup(clearAndRefresh),
editorApi.onNodeChanged(refreshIosSelection),
editorApi.onDomChanged(refreshThrottle.throttle),
editorApi.onDomChanged(refreshIosSelection),
editorApi.onScrollToCursor(function (tinyEvent) {
tinyEvent.preventDefault();
refreshThrottle.throttle();
}),
editorApi.onScrollToElement(function (event) {
scrollToElement(event.element);
}),
editorApi.onToEditing(toEditing),
editorApi.onToReading(toReading),
bind(editorApi.doc, 'touchend', function (touchEvent) {
if (eq(editorApi.html, touchEvent.target) || eq(editorApi.body, touchEvent.target)) ;
}),
bind(toolstrip, 'transitionend', function (transitionEvent) {
if (transitionEvent.raw.propertyName === 'height') {
reposition();
}
}),
capture(toolstrip, 'touchstart', function (touchEvent) {
saveSelectionFirst();
onToolbarTouch(touchEvent);
editorApi.onTouchToolstrip();
}),
bind(editorApi.body, 'touchstart', function (evt) {
clearSelection();
editorApi.onTouchContent();
tapping.fireTouchstart(evt);
}),
tapping.onTouchmove(),
tapping.onTouchend(),
bind(editorApi.body, 'click', function (event) {
event.kill();
}),
bind(toolstrip, 'touchmove', function () {
editorApi.onToolbarScrollStart();
})
];
var destroy = function () {
each$1(listeners, function (l) {
l.unbind();
});
};
return { destroy: destroy };
};
function FakeSelection (win, frame) {
var doc = win.document;
var container = SugarElement.fromTag('div');
add$1(container, resolve('unfocused-selections'));
append$2(SugarElement.fromDom(doc.documentElement), container);
var onTouch = bind(container, 'touchstart', function (event) {
event.prevent();
resume(win, frame);
clear();
});
var make = function (rectangle) {
var span = SugarElement.fromTag('span');
add(span, [
resolve('layer-editor'),
resolve('unfocused-selection')
]);
setAll(span, {
left: rectangle.left + 'px',
top: rectangle.top + 'px',
width: rectangle.width + 'px',
height: rectangle.height + 'px'
});
return span;
};
var update = function () {
clear();
var rectangles = getRectangles(win);
var spans = map$2(rectangles, make);
append$1(container, spans);
};
var clear = function () {
empty(container);
};
var destroy = function () {
onTouch.unbind();
remove$7(container);
};
var isActive = function () {
return children(container).length > 0;
};
return {
update: update,
isActive: isActive,
destroy: destroy,
clear: clear
};
}
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$1(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 adjust = function (value, destination, amount) {
if (Math.abs(value - destination) <= amount) {
return Optional.none();
} else if (value < destination) {
return Optional.some(value + amount);
} else {
return Optional.some(value - amount);
}
};
var create$1 = function () {
var interval = null;
var animate = function (getCurrent, destination, amount, increment, doFinish, rate) {
var finished = false;
var finish = function (v) {
finished = true;
doFinish(v);
};
global$2.clearInterval(interval);
var abort = function (v) {
global$2.clearInterval(interval);
finish(v);
};
interval = global$2.setInterval(function () {
var value = getCurrent();
adjust(value, destination, amount).fold(function () {
global$2.clearInterval(interval);
finish(destination);
}, function (s) {
increment(s, abort);
if (!finished) {
var newValue = getCurrent();
if (newValue !== s || Math.abs(newValue - destination) > Math.abs(value - destination)) {
global$2.clearInterval(interval);
finish(destination);
}
}
});
}, rate);
};
return { animate: animate };
};
var findDevice = function (deviceWidth, deviceHeight) {
var devices = [
{
width: 320,
height: 480,
keyboard: {
portrait: 300,
landscape: 240
}
},
{
width: 320,
height: 568,
keyboard: {
portrait: 300,
landscape: 240
}
},
{
width: 375,
height: 667,
keyboard: {
portrait: 305,
landscape: 240
}
},
{
width: 414,
height: 736,
keyboard: {
portrait: 320,
landscape: 240
}
},
{
width: 768,
height: 1024,
keyboard: {
portrait: 320,
landscape: 400
}
},
{
width: 1024,
height: 1366,
keyboard: {
portrait: 380,
landscape: 460
}
}
];
return findMap(devices, function (device) {
return someIf(deviceWidth <= device.width && deviceHeight <= device.height, device.keyboard);
}).getOr({
portrait: deviceHeight / 5,
landscape: deviceWidth / 4
});
};
var softKeyboardLimits = function (outerWindow) {
return findDevice(outerWindow.screen.width, outerWindow.screen.height);
};
var accountableKeyboardHeight = function (outerWindow) {
var portrait = get$1(outerWindow).isPortrait();
var limits = softKeyboardLimits(outerWindow);
var keyboard = portrait ? limits.portrait : limits.landscape;
var visualScreenHeight = portrait ? outerWindow.screen.height : outerWindow.screen.width;
return visualScreenHeight - outerWindow.innerHeight > keyboard ? 0 : keyboard;
};
var getGreenzone = function (socket, dropup) {
var outerWindow = owner$2(socket).dom.defaultView;
var viewportHeight = get$7(socket) + get$7(dropup);
var acc = accountableKeyboardHeight(outerWindow);
return viewportHeight - acc;
};
var updatePadding = function (contentBody, socket, dropup) {
var greenzoneHeight = getGreenzone(socket, dropup);
var deltaHeight = get$7(socket) + get$7(dropup) - greenzoneHeight;
set$5(contentBody, 'padding-bottom', deltaHeight + 'px');
};
var fixture = Adt.generate([
{
fixed: [
'element',
'property',
'offsetY'
]
},
{
scroller: [
'element',
'offsetY'
]
}
]);
var yFixedData = 'data-' + resolve('position-y-fixed');
var yFixedProperty = 'data-' + resolve('y-property');
var yScrollingData = 'data-' + resolve('scrolling');
var windowSizeData = 'data-' + resolve('last-window-height');
var getYFixedData = function (element) {
return safeParse(element, yFixedData);
};
var getYFixedProperty = function (element) {
return get$b(element, yFixedProperty);
};
var getLastWindowSize = function (element) {
return safeParse(element, windowSizeData);
};
var classifyFixed = function (element, offsetY) {
var prop = getYFixedProperty(element);
return fixture.fixed(element, prop, offsetY);
};
var classifyScrolling = function (element, offsetY) {
return fixture.scroller(element, offsetY);
};
var classify = function (element) {
var offsetY = getYFixedData(element);
var classifier = get$b(element, yScrollingData) === 'true' ? classifyScrolling : classifyFixed;
return classifier(element, offsetY);
};
var findFixtures = function (container) {
var candidates = descendants(container, '[' + yFixedData + ']');
return map$2(candidates, classify);
};
var takeoverToolbar = function (toolbar) {
var oldToolbarStyle = get$b(toolbar, 'style');
setAll(toolbar, {
position: 'absolute',
top: '0px'
});
set$8(toolbar, yFixedData, '0px');
set$8(toolbar, yFixedProperty, 'top');
var restore = function () {
set$8(toolbar, 'style', oldToolbarStyle || '');
remove$6(toolbar, yFixedData);
remove$6(toolbar, yFixedProperty);
};
return { restore: restore };
};
var takeoverViewport = function (toolbarHeight, height, viewport) {
var oldViewportStyle = get$b(viewport, 'style');
register$2(viewport);
setAll(viewport, {
position: 'absolute',
height: height + 'px',
width: '100%',
top: toolbarHeight + 'px'
});
set$8(viewport, yFixedData, toolbarHeight + 'px');
set$8(viewport, yScrollingData, 'true');
set$8(viewport, yFixedProperty, 'top');
var restore = function () {
deregister(viewport);
set$8(viewport, 'style', oldViewportStyle || '');
remove$6(viewport, yFixedData);
remove$6(viewport, yScrollingData);
remove$6(viewport, yFixedProperty);
};
return { restore: restore };
};
var takeoverDropup = function (dropup) {
var oldDropupStyle = get$b(dropup, 'style');
setAll(dropup, {
position: 'absolute',
bottom: '0px'
});
set$8(dropup, yFixedData, '0px');
set$8(dropup, yFixedProperty, 'bottom');
var restore = function () {
set$8(dropup, 'style', oldDropupStyle || '');
remove$6(dropup, yFixedData);
remove$6(dropup, yFixedProperty);
};
return { restore: restore };
};
var deriveViewportHeight = function (viewport, toolbarHeight, dropupHeight) {
var outerWindow = owner$2(viewport).dom.defaultView;
var winH = outerWindow.innerHeight;
set$8(viewport, windowSizeData, winH + 'px');
return winH - toolbarHeight - dropupHeight;
};
var takeover = function (viewport, contentBody, toolbar, dropup) {
var outerWindow = owner$2(viewport).dom.defaultView;
var toolbarSetup = takeoverToolbar(toolbar);
var toolbarHeight = get$7(toolbar);
var dropupHeight = get$7(dropup);
var viewportHeight = deriveViewportHeight(viewport, toolbarHeight, dropupHeight);
var viewportSetup = takeoverViewport(toolbarHeight, viewportHeight, viewport);
var dropupSetup = takeoverDropup(dropup);
var isActive = true;
var restore = function () {
isActive = false;
toolbarSetup.restore();
viewportSetup.restore();
dropupSetup.restore();
};
var isExpanding = function () {
var currentWinHeight = outerWindow.innerHeight;
var lastWinHeight = getLastWindowSize(viewport);
return currentWinHeight > lastWinHeight;
};
var refresh = function () {
if (isActive) {
var newToolbarHeight = get$7(toolbar);
var dropupHeight_1 = get$7(dropup);
var newHeight = deriveViewportHeight(viewport, newToolbarHeight, dropupHeight_1);
set$8(viewport, yFixedData, newToolbarHeight + 'px');
set$5(viewport, 'height', newHeight + 'px');
updatePadding(contentBody, viewport, dropup);
}
};
var setViewportOffset = function (newYOffset) {
var offsetPx = newYOffset + 'px';
set$8(viewport, yFixedData, offsetPx);
refresh();
};
updatePadding(contentBody, viewport, dropup);
return {
setViewportOffset: setViewportOffset,
isExpanding: isExpanding,
isShrinking: not(isExpanding),
refresh: refresh,
restore: restore
};
};
var animator = create$1();
var ANIMATION_STEP = 15;
var NUM_TOP_ANIMATION_FRAMES = 10;
var ANIMATION_RATE = 10;
var lastScroll = 'data-' + resolve('last-scroll-top');
var getTop = function (element) {
var raw = getRaw(element, 'top').getOr('0');
return parseInt(raw, 10);
};
var getScrollTop = function (element) {
return parseInt(element.dom.scrollTop, 10);
};
var moveScrollAndTop = function (element, destination, finalTop) {
return Future.nu(function (callback) {
var getCurrent = curry(getScrollTop, element);
var update = function (newScroll) {
element.dom.scrollTop = newScroll;
set$5(element, 'top', getTop(element) + ANIMATION_STEP + 'px');
};
var finish = function () {
element.dom.scrollTop = destination;
set$5(element, 'top', finalTop + 'px');
callback(destination);
};
animator.animate(getCurrent, destination, ANIMATION_STEP, update, finish, ANIMATION_RATE);
});
};
var moveOnlyScroll = function (element, destination) {
return Future.nu(function (callback) {
var getCurrent = curry(getScrollTop, element);
set$8(element, lastScroll, getCurrent());
var update = function (newScroll, abort) {
var previous = safeParse(element, lastScroll);
if (previous !== element.dom.scrollTop) {
abort(element.dom.scrollTop);
} else {
element.dom.scrollTop = newScroll;
set$8(element, lastScroll, newScroll);
}
};
var finish = function () {
element.dom.scrollTop = destination;
set$8(element, lastScroll, destination);
callback(destination);
};
var distance = Math.abs(destination - getCurrent());
var step = Math.ceil(distance / NUM_TOP_ANIMATION_FRAMES);
animator.animate(getCurrent, destination, step, update, finish, ANIMATION_RATE);
});
};
var moveOnlyTop = function (element, destination) {
return Future.nu(function (callback) {
var getCurrent = curry(getTop, element);
var update = function (newTop) {
set$5(element, 'top', newTop + 'px');
};
var finish = function () {
update(destination);
callback(destination);
};
var distance = Math.abs(destination - getCurrent());
var step = Math.ceil(distance / NUM_TOP_ANIMATION_FRAMES);
animator.animate(getCurrent, destination, step, update, finish, ANIMATION_RATE);
});
};
var updateTop = function (element, amount) {
var newTop = amount + getYFixedData(element) + 'px';
set$5(element, 'top', newTop);
};
var moveWindowScroll = function (toolbar, viewport, destY) {
var outerWindow = owner$2(toolbar).dom.defaultView;
return Future.nu(function (callback) {
updateTop(toolbar, destY);
updateTop(viewport, destY);
outerWindow.scrollTo(0, destY);
callback(destY);
});
};
function BackgroundActivity (doAction) {
var action = Cell(LazyValue.pure({}));
var start = function (value) {
var future = LazyValue.nu(function (callback) {
return doAction(value).get(callback);
});
action.set(future);
};
var idle = function (g) {
action.get().get(function () {
g();
});
};
return {
start: start,
idle: idle
};
}
var scrollIntoView = function (cWin, socket, dropup, top, bottom) {
var greenzone = getGreenzone(socket, dropup);
var refreshCursor = curry(refresh, cWin);
if (top > greenzone || bottom > greenzone) {
moveOnlyScroll(socket, socket.dom.scrollTop - greenzone + bottom).get(refreshCursor);
} else if (top < 0) {
moveOnlyScroll(socket, socket.dom.scrollTop + top).get(refreshCursor);
} else ;
};
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$1(asyncValues, function (asyncValue, i) {
asyncValue.get(cb(i));
});
}
});
};
var par = function (futures) {
return par$1(futures, Future.nu);
};
var updateFixed = function (element, property, winY, offsetY) {
var destination = winY + offsetY;
set$5(element, property, destination + 'px');
return Future.pure(offsetY);
};
var updateScrollingFixed = function (element, winY, offsetY) {
var destTop = winY + offsetY;
var oldProp = getRaw(element, 'top').getOr(offsetY);
var delta = destTop - parseInt(oldProp, 10);
var destScroll = element.dom.scrollTop + delta;
return moveScrollAndTop(element, destScroll, destTop);
};
var updateFixture = function (fixture, winY) {
return fixture.fold(function (element, property, offsetY) {
return updateFixed(element, property, winY, offsetY);
}, function (element, offsetY) {
return updateScrollingFixed(element, winY, offsetY);
});
};
var updatePositions = function (container, winY) {
var fixtures = findFixtures(container);
var updates = map$2(fixtures, function (fixture) {
return updateFixture(fixture, winY);
});
return par(updates);
};
var VIEW_MARGIN = 5;
var register = function (toolstrip, socket, container, outerWindow, structure, cWin) {
var scroller = BackgroundActivity(function (y) {
return moveWindowScroll(toolstrip, socket, y);
});
var scrollBounds = function () {
var rects = getRectangles(cWin);
return Optional.from(rects[0]).bind(function (rect) {
var viewTop = rect.top - socket.dom.scrollTop;
var outside = viewTop > outerWindow.innerHeight + VIEW_MARGIN || viewTop < -VIEW_MARGIN;
return outside ? Optional.some({
top: viewTop,
bottom: viewTop + rect.height
}) : Optional.none();
});
};
var scrollThrottle = last(function () {
scroller.idle(function () {
updatePositions(container, outerWindow.pageYOffset).get(function () {
var extraScroll = scrollBounds();
extraScroll.each(function (extra) {
socket.dom.scrollTop = socket.dom.scrollTop + extra.top;
});
scroller.start(0);
structure.refresh();
});
});
}, 1000);
var onScroll = bind(SugarElement.fromDom(outerWindow), 'scroll', function () {
if (outerWindow.pageYOffset < 0) {
return;
}
scrollThrottle.throttle();
});
updatePositions(container, outerWindow.pageYOffset).get(identity);
return { unbind: onScroll.unbind };
};
var setup = function (bag) {
var cWin = bag.cWin;
var ceBody = bag.ceBody;
var socket = bag.socket;
var toolstrip = bag.toolstrip;
var contentElement = bag.contentElement;
var keyboardType = bag.keyboardType;
var outerWindow = bag.outerWindow;
var dropup = bag.dropup;
var outerBody = bag.outerBody;
var structure = takeover(socket, ceBody, toolstrip, dropup);
var keyboardModel = keyboardType(outerBody, cWin, body(), contentElement);
var toEditing = function () {
keyboardModel.toEditing();
clearSelection();
};
var toReading = function () {
keyboardModel.toReading();
};
var onToolbarTouch = function (_event) {
keyboardModel.onToolbarTouch();
};
var onOrientation = onChange(outerWindow, {
onChange: noop,
onReady: structure.refresh
});
onOrientation.onAdjustment(function () {
structure.refresh();
});
var onResize = bind(SugarElement.fromDom(outerWindow), 'resize', function () {
if (structure.isExpanding()) {
structure.refresh();
}
});
var onScroll = register(toolstrip, socket, outerBody, outerWindow, structure, cWin);
var unfocusedSelection = FakeSelection(cWin, contentElement);
var refreshSelection = function () {
if (unfocusedSelection.isActive()) {
unfocusedSelection.update();
}
};
var highlightSelection = function () {
unfocusedSelection.update();
};
var clearSelection = function () {
unfocusedSelection.clear();
};
var scrollIntoView$1 = function (top, bottom) {
scrollIntoView(cWin, socket, dropup, top, bottom);
};
var syncHeight = function () {
set$5(contentElement, 'height', contentElement.dom.contentWindow.document.body.scrollHeight + 'px');
};
var setViewportOffset = function (newYOffset) {
structure.setViewportOffset(newYOffset);
moveOnlyTop(socket, newYOffset).get(identity);
};
var destroy = function () {
structure.restore();
onOrientation.destroy();
onScroll.unbind();
onResize.unbind();
keyboardModel.destroy();
unfocusedSelection.destroy();
input(body(), blur$1);
};
return {
toEditing: toEditing,
toReading: toReading,
onToolbarTouch: onToolbarTouch,
refreshSelection: refreshSelection,
clearSelection: clearSelection,
highlightSelection: highlightSelection,
scrollIntoView: scrollIntoView$1,
updateToolbarPadding: noop,
setViewportOffset: setViewportOffset,
syncHeight: syncHeight,
refreshStructure: structure.refresh,
destroy: destroy
};
};
var create = function (platform, mask) {
var meta = tag();
var priorState = value();
var scrollEvents = value();
var iosApi = api$2();
var iosEvents = api$2();
var enter = function () {
mask.hide();
var doc = SugarElement.fromDom(document);
getActiveApi(platform.editor).each(function (editorApi) {
priorState.set({
socketHeight: getRaw(platform.socket, 'height'),
iframeHeight: getRaw(editorApi.frame, 'height'),
outerScroll: document.body.scrollTop
});
scrollEvents.set({ exclusives: exclusive(doc, '.' + scrollable) });
add$1(platform.container, resolve('fullscreen-maximized'));
clobberStyles(platform.container, editorApi.body);
meta.maximize();
set$5(platform.socket, 'overflow', 'scroll');
set$5(platform.socket, '-webkit-overflow-scrolling', 'touch');
focus$3(editorApi.body);
iosApi.set(setup({
cWin: editorApi.win,
ceBody: editorApi.body,
socket: platform.socket,
toolstrip: platform.toolstrip,
dropup: platform.dropup.element,
contentElement: editorApi.frame,
outerBody: platform.body,
outerWindow: platform.win,
keyboardType: stubborn
}));
iosApi.run(function (api) {
api.syncHeight();
});
iosEvents.set(initEvents(editorApi, iosApi, platform.toolstrip, platform.socket, platform.dropup));
});
};
var exit = function () {
meta.restore();
iosEvents.clear();
iosApi.clear();
mask.show();
priorState.on(function (s) {
s.socketHeight.each(function (h) {
set$5(platform.socket, 'height', h);
});
s.iframeHeight.each(function (h) {
set$5(platform.editor.getFrame(), 'height', h);
});
document.body.scrollTop = s.scrollTop;
});
priorState.clear();
scrollEvents.on(function (s) {
s.exclusives.unbind();
});
scrollEvents.clear();
remove$3(platform.container, resolve('fullscreen-maximized'));
restoreStyles();
deregister(platform.toolbar);
remove$2(platform.socket, 'overflow');
remove$2(platform.socket, '-webkit-overflow-scrolling');
blur$1(platform.editor.getFrame());
getActiveApi(platform.editor).each(function (editorApi) {
editorApi.clearSelection();
});
};
var refreshStructure = function () {
iosApi.run(function (api) {
api.refreshStructure();
});
};
return {
enter: enter,
refreshStructure: refreshStructure,
exit: exit
};
};
var produce = function (raw) {
var mobile = asRawOrDie$1('Getting IosWebapp schema', MobileSchema, raw);
set$5(mobile.toolstrip, 'width', '100%');
set$5(mobile.container, 'position', 'relative');
var onView = function () {
mobile.setReadOnly(mobile.readOnlyOnInit());
mode.enter();
};
var mask = build$1(sketch(onView, mobile.translate));
mobile.alloy.add(mask);
var maskApi = {
show: function () {
mobile.alloy.add(mask);
},
hide: function () {
mobile.alloy.remove(mask);
}
};
var mode = create(mobile, maskApi);
return {
setReadOnly: mobile.setReadOnly,
refreshStructure: mode.refreshStructure,
enter: mode.enter,
exit: mode.exit,
destroy: noop
};
};
function IosRealm (scrollIntoView) {
var alloy = OuterContainer({ classes: [resolve('ios-container')] });
var toolbar = ScrollingToolbar();
var webapp = api$2();
var switchToEdit = makeEditSwitch(webapp);
var socket = makeSocket();
var dropup = build(function () {
webapp.run(function (w) {
w.refreshStructure();
});
}, scrollIntoView);
alloy.add(toolbar.wrapper);
alloy.add(socket);
alloy.add(dropup.component);
var setToolbarGroups = function (rawGroups) {
var groups = toolbar.createGroups(rawGroups);
toolbar.setGroups(groups);
};
var setContextToolbar = function (rawGroups) {
var groups = toolbar.createGroups(rawGroups);
toolbar.setContextToolbar(groups);
};
var focusToolbar = function () {
toolbar.focus();
};
var restoreToolbar = function () {
toolbar.restoreToolbar();
};
var init = function (spec) {
webapp.set(produce(spec));
};
var exit = function () {
webapp.run(function (w) {
Replacing.remove(socket, switchToEdit);
w.exit();
});
};
var updateMode$1 = function (readOnly) {
updateMode(socket, switchToEdit, readOnly, alloy.root);
};
return {
system: alloy,
element: alloy.element,
init: init,
exit: exit,
setToolbarGroups: setToolbarGroups,
setContextToolbar: setContextToolbar,
focusToolbar: focusToolbar,
restoreToolbar: restoreToolbar,
updateMode: updateMode$1,
socket: socket,
dropup: dropup
};
}
var global$1 = tinymce.util.Tools.resolve('tinymce.EditorManager');
var derive = function (editor) {
var base = Optional.from(getSkinUrl(editor)).getOrThunk(function () {
return global$1.baseURL + '/skins/ui/oxide';
});
return {
content: base + '/content.mobile.min.css',
ui: base + '/skin.mobile.min.css'
};
};
var fireChange = function (realm, command, state) {
realm.system.broadcastOn([formatChanged], {
command: command,
state: state
});
};
var init = function (realm, editor) {
var allFormats = keys(editor.formatter.get());
each$1(allFormats, function (command) {
editor.formatter.formatChanged(command, function (state) {
fireChange(realm, command, state);
});
});
each$1([
'ul',
'ol'
], function (command) {
editor.selection.selectorChanged(command, function (state, _data) {
fireChange(realm, command, state);
});
});
};
var fireSkinLoaded = function (editor) {
return function () {
var done = function () {
editor._skinLoaded = true;
editor.fire('SkinLoaded');
};
if (editor.initialized) {
done();
} else {
editor.on('init', done);
}
};
};
var READING = 'toReading';
var EDITING = 'toEditing';
var renderMobileTheme = function (editor) {
var renderUI = function () {
var targetNode = editor.getElement();
var cssUrls = derive(editor);
if (isSkinDisabled(editor) === false) {
var styleSheetLoader_1 = global$5.DOM.styleSheetLoader;
editor.contentCSS.push(cssUrls.content);
styleSheetLoader_1.load(cssUrls.ui, fireSkinLoaded(editor));
editor.on('remove', function () {
return styleSheetLoader_1.unload(cssUrls.ui);
});
} else {
fireSkinLoaded(editor)();
}
var doScrollIntoView = function () {
editor.fire('ScrollIntoView');
};
var realm = detect$1().os.isAndroid() ? AndroidRealm(doScrollIntoView) : IosRealm(doScrollIntoView);
var original = SugarElement.fromDom(targetNode);
attachSystemAfter(original, realm.system);
var findFocusIn = function (elem) {
return search(elem).bind(function (focused) {
return realm.system.getByDom(focused).toOptional();
});
};
var outerWindow = targetNode.ownerDocument.defaultView;
var orientation = onChange(outerWindow, {
onChange: function () {
var alloy = realm.system;
alloy.broadcastOn([orientationChanged], { width: getActualWidth(outerWindow) });
},
onReady: noop
});
var setReadOnly = function (dynamicGroup, readOnlyGroups, mainGroups, ro) {
if (ro === false) {
editor.selection.collapse();
}
var toolbars = configureToolbar(dynamicGroup, readOnlyGroups, mainGroups);
realm.setToolbarGroups(ro === true ? toolbars.readOnly : toolbars.main);
editor.setMode(ro === true ? 'readonly' : 'design');
editor.fire(ro === true ? READING : EDITING);
realm.updateMode(ro);
};
var configureToolbar = function (dynamicGroup, readOnlyGroups, mainGroups) {
var dynamic = dynamicGroup.get();
var toolbars = {
readOnly: dynamic.backToMask.concat(readOnlyGroups.get()),
main: dynamic.backToMask.concat(mainGroups.get())
};
return toolbars;
};
var bindHandler = function (label, handler) {
editor.on(label, handler);
return {
unbind: function () {
editor.off(label);
}
};
};
editor.on('init', function () {
realm.init({
editor: {
getFrame: function () {
return SugarElement.fromDom(editor.contentAreaContainer.querySelector('iframe'));
},
onDomChanged: function () {
return { unbind: noop };
},
onToReading: function (handler) {
return bindHandler(READING, handler);
},
onToEditing: function (handler) {
return bindHandler(EDITING, handler);
},
onScrollToCursor: function (handler) {
editor.on('ScrollIntoView', function (tinyEvent) {
handler(tinyEvent);
});
var unbind = function () {
editor.off('ScrollIntoView');
orientation.destroy();
};
return { unbind: unbind };
},
onTouchToolstrip: function () {
hideDropup();
},
onTouchContent: function () {
var toolbar = SugarElement.fromDom(editor.editorContainer.querySelector('.' + resolve('toolbar')));
findFocusIn(toolbar).each(emitExecute);
realm.restoreToolbar();
hideDropup();
},
onTapContent: function (evt) {
var target = evt.target;
if (name$1(target) === 'img') {
editor.selection.select(target.dom);
evt.kill();
} else if (name$1(target) === 'a') {
var component = realm.system.getByDom(SugarElement.fromDom(editor.editorContainer));
component.each(function (container) {
if (Swapping.isAlpha(container)) {
openLink(target.dom);
}
});
}
}
},
container: SugarElement.fromDom(editor.editorContainer),
socket: SugarElement.fromDom(editor.contentAreaContainer),
toolstrip: SugarElement.fromDom(editor.editorContainer.querySelector('.' + resolve('toolstrip'))),
toolbar: SugarElement.fromDom(editor.editorContainer.querySelector('.' + resolve('toolbar'))),
dropup: realm.dropup,
alloy: realm.system,
translate: noop,
setReadOnly: function (ro) {
setReadOnly(dynamicGroup, readOnlyGroups, mainGroups, ro);
},
readOnlyOnInit: function () {
return readOnlyOnInit();
}
});
var hideDropup = function () {
realm.dropup.disappear(function () {
realm.system.broadcastOn([dropupDismissed], {});
});
};
var backToMaskGroup = {
label: 'The first group',
scrollable: false,
items: [forToolbar('back', function () {
editor.selection.collapse();
realm.exit();
}, {}, editor)]
};
var backToReadOnlyGroup = {
label: 'Back to read only',
scrollable: false,
items: [forToolbar('readonly-back', function () {
setReadOnly(dynamicGroup, readOnlyGroups, mainGroups, true);
}, {}, editor)]
};
var readOnlyGroup = {
label: 'The read only mode group',
scrollable: true,
items: []
};
var features = setup$3(realm, editor);
var items = detect(editor, features);
var actionGroup = {
label: 'the action group',
scrollable: true,
items: items
};
var extraGroup = {
label: 'The extra group',
scrollable: false,
items: []
};
var mainGroups = Cell([
actionGroup,
extraGroup
]);
var readOnlyGroups = Cell([
readOnlyGroup,
extraGroup
]);
var dynamicGroup = Cell({
backToMask: [backToMaskGroup],
backToReadOnly: [backToReadOnlyGroup]
});
init(realm, editor);
});
editor.on('remove', function () {
realm.exit();
});
editor.on('detach', function () {
detachSystem(realm.system);
realm.system.destroy();
});
return {
iframeContainer: realm.socket.element.dom,
editorContainer: realm.element.dom
};
};
return {
getNotificationManagerImpl: function () {
return {
open: constant$1({
progressBar: { value: noop },
close: noop,
text: noop,
getEl: constant$1(null),
moveTo: noop,
moveRel: noop,
settings: {}
}),
close: noop,
reposition: noop,
getArgs: constant$1({})
};
},
renderUI: renderUI
};
};
function Theme () {
global$4.add('mobile', renderMobileTheme);
}
Theme();
}());