diff --git a/dev/src/App.svelte b/dev/src/App.svelte index e1726c1..1bfd405 100644 --- a/dev/src/App.svelte +++ b/dev/src/App.svelte @@ -32,7 +32,7 @@ closeOnCallback: true, }, }, - containerClassName: useCustomTooltipClass ? 'tooltip' : null, + containerClassName: useCustomTooltipClass ? `tooltip tooltip-${tooltipPosition}` : null, animated: animateTooltip, animationEnterClassName: useCustomAnimationEnterClass ? 'tooltip-enter' : null, animationLeaveClassName: useCustomAnimationLeaveClass ? 'tooltip-leave' : null, @@ -194,23 +194,36 @@ } :global(.tooltip::after) { - content: ''; - position: absolute; - top: 100%; - left: 50%; - margin-left: -5px; - border-width: 5px; - border-style: solid; - border-color: #ee7008 transparent transparent transparent; - } - - :global(.tooltip-enter) { - animation: fadeIn 0.2s linear forwards; - } - - :global(.tooltip-leave) { - animation: fadeOut 0.2s linear forwards; - } + content: ''; + position: absolute; + margin-left: -5px; + border-width: 5px; + border-style: solid; + } + + :global(.tooltip-top::after) { + bottom: -10px; + left: 50%; + border-color: #ee7008 transparent transparent transparent; + } + + :global(.tooltip-bottom::after) { + top: -10px; + left: 50%; + border-color: transparent transparent #ee7008 transparent; + } + + :global(.tooltip-left::after) { + top: calc(50% - 5px); + right: -10px; + border-color: transparent transparent transparent #ee7008; + } + + :global(.tooltip-right::after) { + top: calc(50% - 5px); + left: -5px; + border-color: transparent #ee7008 transparent transparent; + } @keyframes fadeIn { from { diff --git a/public/build/bundle.css b/public/build/bundle.css new file mode 100644 index 0000000..b0bd20c --- /dev/null +++ b/public/build/bundle.css @@ -0,0 +1 @@ +main.svelte-1sosalq.svelte-1sosalq{position:relative;display:flex;justify-content:center;height:100%;padding:1rem}.container.svelte-1sosalq.svelte-1sosalq{display:flex;flex-direction:column;align-items:center;justify-content:center;row-gap:3rem}.container__settings-open.svelte-1sosalq.svelte-1sosalq{position:absolute;bottom:1rem}@media screen and (min-width: 576px){.container__settings-open.svelte-1sosalq.svelte-1sosalq{display:none}}.settings__container.svelte-1sosalq.svelte-1sosalq{position:absolute;top:0;left:0;overflow:hidden auto;height:100%;background-color:#eee;visibility:var(--settingsVisibility)}@media screen and (min-width: 576px){.settings__container.svelte-1sosalq.svelte-1sosalq{position:relative;height:auto;visibility:visible}}.settings__settings-close.svelte-1sosalq.svelte-1sosalq{position:absolute;top:1rem;right:1rem}@media screen and (min-width: 576px){.settings__settings-close.svelte-1sosalq.svelte-1sosalq{display:none}}.settings__form.svelte-1sosalq.svelte-1sosalq{display:flex;flex-direction:column;align-items:center;height:100%;padding:1rem}.settings__form.svelte-1sosalq fieldset.svelte-1sosalq{width:100%;border:none}.settings__form.svelte-1sosalq label.svelte-1sosalq{display:flex;align-items:center;justify-content:space-between;column-gap:1rem}.settings__form.svelte-1sosalq input.svelte-1sosalq{margin:0}.settings__form.svelte-1sosalq input[type='checkbox'].svelte-1sosalq{padding:0}.target.svelte-1sosalq.svelte-1sosalq{width:10rem;height:3rem;background-color:white;color:black;display:flex;align-items:center;justify-content:center;box-shadow:0 0 5px 0 rgba(0, 0, 0, 0.5)}.target.svelte-1sosalq.svelte-1sosalq:hover{cursor:pointer;background-color:black;color:white}.tooltip__content.svelte-1sosalq.svelte-1sosalq{background-color:yellow;color:black}.tooltip{position:absolute;z-index:9999;max-width:120px;background-color:#ee7008;color:#fff;text-align:center;border-radius:6px;padding:0.5rem}.tooltip::after{content:'';position:absolute;top:100%;left:50%;margin-left:-5px;border-width:5px;border-style:solid;border-color:#ee7008 transparent transparent transparent}.tooltip-enter{animation:svelte-1sosalq-fadeIn 0.2s linear forwards}.tooltip-leave{animation:svelte-1sosalq-fadeOut 0.2s linear forwards}@keyframes svelte-1sosalq-fadeIn{from{opacity:0;transform:translateX(50px)}to{opacity:1;transform:translateX(0)}}@keyframes svelte-1sosalq-fadeOut{to{opacity:0;transform:translateX(-50px)}} \ No newline at end of file diff --git a/public/build/bundle.js b/public/build/bundle.js new file mode 100644 index 0000000..1fdb6e7 --- /dev/null +++ b/public/build/bundle.js @@ -0,0 +1,1484 @@ +;(function (l, r) { + if (!l || l.getElementById('livereloadscript')) return + r = l.createElement('script') + r.async = 1 + r.src = '//' + (self.location.host || 'localhost').split(':')[0] + ':35730/livereload.js?snipver=1' + r.id = 'livereloadscript' + l.getElementsByTagName('head')[0].appendChild(r) +})(self.document) +var app = (function () { + 'use strict' + + function noop() {} + function add_location(element, file, line, column, char) { + element.__svelte_meta = { + loc: { file, line, column, char }, + } + } + function run(fn) { + return fn() + } + function blank_object() { + return Object.create(null) + } + function run_all(fns) { + fns.forEach(run) + } + function is_function(thing) { + return typeof thing === 'function' + } + function safe_not_equal(a, b) { + return a != a ? b == b : a !== b || (a && typeof a === 'object') || typeof a === 'function' + } + function is_empty(obj) { + return Object.keys(obj).length === 0 + } + function action_destroyer(action_result) { + return action_result && is_function(action_result.destroy) ? action_result.destroy : noop + } + function append(target, node) { + target.appendChild(node) + } + function insert(target, node, anchor) { + target.insertBefore(node, anchor || null) + } + function detach(node) { + node.parentNode.removeChild(node) + } + function element(name) { + return document.createElement(name) + } + function text(data) { + return document.createTextNode(data) + } + function space() { + return text(' ') + } + function listen(node, event, handler, options) { + node.addEventListener(event, handler, options) + return () => node.removeEventListener(event, handler, options) + } + function attr(node, attribute, value) { + if (value == null) node.removeAttribute(attribute) + else if (node.getAttribute(attribute) !== value) node.setAttribute(attribute, value) + } + function to_number(value) { + return value === '' ? null : +value + } + function children(element) { + return Array.from(element.childNodes) + } + function set_input_value(input, value) { + input.value = value == null ? '' : value + } + function set_style(node, key, value, important) { + node.style.setProperty(key, value, important ? 'important' : '') + } + function select_option(select, value) { + for (let i = 0; i < select.options.length; i += 1) { + const option = select.options[i] + if (option.__value === value) { + option.selected = true + return + } + } + select.selectedIndex = -1 // no option should be selected + } + function select_value(select) { + const selected_option = select.querySelector(':checked') || select.options[0] + return selected_option && selected_option.__value + } + function custom_event(type, detail, bubbles = false) { + const e = document.createEvent('CustomEvent') + e.initCustomEvent(type, bubbles, false, detail) + return e + } + + let current_component + function set_current_component(component) { + current_component = component + } + + const dirty_components = [] + const binding_callbacks = [] + const render_callbacks = [] + const flush_callbacks = [] + const resolved_promise = Promise.resolve() + let update_scheduled = false + function schedule_update() { + if (!update_scheduled) { + update_scheduled = true + resolved_promise.then(flush) + } + } + function add_render_callback(fn) { + render_callbacks.push(fn) + } + let flushing = false + const seen_callbacks = new Set() + function flush() { + if (flushing) return + flushing = true + do { + // first, call beforeUpdate functions + // and update components + for (let i = 0; i < dirty_components.length; i += 1) { + const component = dirty_components[i] + set_current_component(component) + update(component.$$) + } + set_current_component(null) + dirty_components.length = 0 + while (binding_callbacks.length) binding_callbacks.pop()() + // then, once components are updated, call + // afterUpdate functions. This may cause + // subsequent updates... + for (let i = 0; i < render_callbacks.length; i += 1) { + const callback = render_callbacks[i] + if (!seen_callbacks.has(callback)) { + // ...so guard against infinite loops + seen_callbacks.add(callback) + callback() + } + } + render_callbacks.length = 0 + } while (dirty_components.length) + while (flush_callbacks.length) { + flush_callbacks.pop()() + } + update_scheduled = false + flushing = false + seen_callbacks.clear() + } + function update($$) { + if ($$.fragment !== null) { + $$.update() + run_all($$.before_update) + const dirty = $$.dirty + $$.dirty = [-1] + $$.fragment && $$.fragment.p($$.ctx, dirty) + $$.after_update.forEach(add_render_callback) + } + } + const outroing = new Set() + function transition_in(block, local) { + if (block && block.i) { + outroing.delete(block) + block.i(local) + } + } + + const globals = typeof window !== 'undefined' ? window : typeof globalThis !== 'undefined' ? globalThis : global + function mount_component(component, target, anchor, customElement) { + const { fragment, on_mount, on_destroy, after_update } = component.$$ + fragment && fragment.m(target, anchor) + if (!customElement) { + // onMount happens before the initial afterUpdate + add_render_callback(() => { + const new_on_destroy = on_mount.map(run).filter(is_function) + if (on_destroy) { + on_destroy.push(...new_on_destroy) + } else { + // Edge case - component was destroyed immediately, + // most likely as a result of a binding initialising + run_all(new_on_destroy) + } + component.$$.on_mount = [] + }) + } + after_update.forEach(add_render_callback) + } + function destroy_component(component, detaching) { + const $$ = component.$$ + if ($$.fragment !== null) { + run_all($$.on_destroy) + $$.fragment && $$.fragment.d(detaching) + // TODO null out other refs, including component.$$ (but need to + // preserve final state?) + $$.on_destroy = $$.fragment = null + $$.ctx = [] + } + } + function make_dirty(component, i) { + if (component.$$.dirty[0] === -1) { + dirty_components.push(component) + schedule_update() + component.$$.dirty.fill(0) + } + component.$$.dirty[(i / 31) | 0] |= 1 << i % 31 + } + function init(component, options, instance, create_fragment, not_equal, props, append_styles, dirty = [-1]) { + const parent_component = current_component + set_current_component(component) + const $$ = (component.$$ = { + fragment: null, + ctx: null, + // state + props, + update: noop, + not_equal, + bound: blank_object(), + // lifecycle + on_mount: [], + on_destroy: [], + on_disconnect: [], + before_update: [], + after_update: [], + context: new Map(options.context || (parent_component ? parent_component.$$.context : [])), + // everything else + callbacks: blank_object(), + dirty, + skip_bound: false, + root: options.target || parent_component.$$.root, + }) + append_styles && append_styles($$.root) + let ready = false + $$.ctx = instance + ? instance(component, options.props || {}, (i, ret, ...rest) => { + const value = rest.length ? rest[0] : ret + if ($$.ctx && not_equal($$.ctx[i], ($$.ctx[i] = value))) { + if (!$$.skip_bound && $$.bound[i]) $$.bound[i](value) + if (ready) make_dirty(component, i) + } + return ret + }) + : [] + $$.update() + ready = true + run_all($$.before_update) + // `false` as a special case of no DOM component + $$.fragment = create_fragment ? create_fragment($$.ctx) : false + if (options.target) { + if (options.hydrate) { + const nodes = children(options.target) + // eslint-disable-next-line @typescript-eslint/no-non-null-assertion + $$.fragment && $$.fragment.l(nodes) + nodes.forEach(detach) + } else { + // eslint-disable-next-line @typescript-eslint/no-non-null-assertion + $$.fragment && $$.fragment.c() + } + if (options.intro) transition_in(component.$$.fragment) + mount_component(component, options.target, options.anchor, options.customElement) + flush() + } + set_current_component(parent_component) + } + /** + * Base class for Svelte components. Used when dev=false. + */ + class SvelteComponent { + $destroy() { + destroy_component(this, 1) + this.$destroy = noop + } + $on(type, callback) { + const callbacks = this.$$.callbacks[type] || (this.$$.callbacks[type] = []) + callbacks.push(callback) + return () => { + const index = callbacks.indexOf(callback) + if (index !== -1) callbacks.splice(index, 1) + } + } + $set($$props) { + if (this.$$set && !is_empty($$props)) { + this.$$.skip_bound = true + this.$$set($$props) + this.$$.skip_bound = false + } + } + } + + function dispatch_dev(type, detail) { + document.dispatchEvent(custom_event(type, Object.assign({ version: '3.44.0' }, detail), true)) + } + function append_dev(target, node) { + dispatch_dev('SvelteDOMInsert', { target, node }) + append(target, node) + } + function insert_dev(target, node, anchor) { + dispatch_dev('SvelteDOMInsert', { target, node, anchor }) + insert(target, node, anchor) + } + function detach_dev(node) { + dispatch_dev('SvelteDOMRemove', { node }) + detach(node) + } + function listen_dev(node, event, handler, options, has_prevent_default, has_stop_propagation) { + const modifiers = options === true ? ['capture'] : options ? Array.from(Object.keys(options)) : [] + if (has_prevent_default) modifiers.push('preventDefault') + if (has_stop_propagation) modifiers.push('stopPropagation') + dispatch_dev('SvelteDOMAddEventListener', { node, event, handler, modifiers }) + const dispose = listen(node, event, handler, options) + return () => { + dispatch_dev('SvelteDOMRemoveEventListener', { node, event, handler, modifiers }) + dispose() + } + } + function attr_dev(node, attribute, value) { + attr(node, attribute, value) + if (value == null) dispatch_dev('SvelteDOMRemoveAttribute', { node, attribute }) + else dispatch_dev('SvelteDOMSetAttribute', { node, attribute, value }) + } + function validate_slots(name, slot, keys) { + for (const slot_key of Object.keys(slot)) { + if (!~keys.indexOf(slot_key)) { + console.warn(`<${name}> received an unexpected slot "${slot_key}".`) + } + } + } + /** + * Base class for Svelte components with some minor dev-enhancements. Used when dev=true. + */ + class SvelteComponentDev extends SvelteComponent { + constructor(options) { + if (!options || (!options.target && !options.$$inline)) { + throw new Error("'target' is a required option") + } + super() + } + $destroy() { + super.$destroy() + this.$destroy = () => { + console.warn('Component was already destroyed') // eslint-disable-line no-console + } + } + $capture_state() {} + $inject_state() {} + } + + var t = function (t, e) { + ;(null == e || e > t.length) && (e = t.length) + for (var n = 0, o = new Array(e); n < e; n++) o[n] = t[n] + return o + }, + e = function (e) { + if (Array.isArray(e)) return t(e) + }, + n = function (e, n) { + if (e) { + if ('string' == typeof e) return t(e, n) + var o = Object.prototype.toString.call(e).slice(8, -1) + return ( + 'Object' === o && e.constructor && (o = e.constructor.name), + 'Map' === o || 'Set' === o + ? Array.from(e) + : 'Arguments' === o || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(o) + ? t(e, n) + : void 0 + ) + } + }, + o = function (t) { + return ( + e(t) || + (function (t) { + if ('undefined' != typeof Symbol && Symbol.iterator in Object(t)) return Array.from(t) + })(t) || + n(t) || + (function () { + throw new TypeError( + 'Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.' + ) + })() + ) + } + function i(t, e) { + for (var n = 0; n < e.length; n++) { + var o = e[n] + ;(o.enumerable = o.enumerable || !1), + (o.configurable = !0), + 'value' in o && (o.writable = !0), + Object.defineProperty(t, o.key, o) + } + } + var a = function (t, e, n) { + return ( + e in t + ? Object.defineProperty(t, e, { value: n, enumerable: !0, configurable: !0, writable: !0 }) + : (t[e] = n), + t + ) + }, + r = function (t) { + return 1 === (null == t ? void 0 : t.nodeType) + } + function s(t, e) { + var n + if ('undefined' == typeof Symbol || null == t[Symbol.iterator]) { + if ( + Array.isArray(t) || + (n = (function (t, e) { + if (t) { + if ('string' == typeof t) return l(t, e) + var n = Object.prototype.toString.call(t).slice(8, -1) + return ( + 'Object' === n && t.constructor && (n = t.constructor.name), + 'Map' === n || 'Set' === n + ? Array.from(t) + : 'Arguments' === n || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n) + ? l(t, e) + : void 0 + ) + } + })(t)) || + (e && t && 'number' == typeof t.length) + ) { + n && (t = n) + var o = 0, + i = function () {} + return { + s: i, + n: function () { + return o >= t.length ? { done: !0 } : { done: !1, value: t[o++] } + }, + e: function (t) { + throw t + }, + f: i, + } + } + throw new TypeError( + 'Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.' + ) + } + var a, + r = !0, + s = !1 + return { + s: function () { + n = t[Symbol.iterator]() + }, + n: function () { + var t = n.next() + return (r = t.done), t + }, + e: function (t) { + ;(s = !0), (a = t) + }, + f: function () { + try { + r || null == n.return || n.return() + } finally { + if (s) throw a + } + }, + } + } + function l(t, e) { + ;(null == e || e > t.length) && (e = t.length) + for (var n = 0, o = new Array(e); n < e; n++) o[n] = t[n] + return o + } + var c = (function () { + function t() { + ;(function (t, e) { + if (!(t instanceof e)) throw new TypeError('Cannot call a class as a function') + })(this, t), + a(this, '_observer', null) + } + return ( + (function (t, e, n) { + e && i(t.prototype, e), n && i(t, n) + })(t, [ + { + key: 'wait', + value: function (e) { + var n = this, + i = arguments.length > 1 && void 0 !== arguments[1] ? arguments[1] : null, + a = arguments.length > 2 && void 0 !== arguments[2] ? arguments[2] : {}, + l = a.events, + c = void 0 === l ? t.EVENTS : l, + h = a.timeout, + u = void 0 === h ? 0 : h, + d = a.attributeFilter, + p = void 0 === d ? void 0 : d, + m = a.onError, + v = void 0 === m ? void 0 : m + return ( + this.clear(), + new Promise(function (a, l) { + var h = r(e) ? e : document.querySelector(e) + h && c.includes(t.EXIST) && (i ? i(h, t.EXIST) : a({ node: h, event: t.EXIST })), + u > 0 && + (n._timeout = setTimeout(function () { + n.clear() + var t = new Error( + '[TIMEOUT]: Element ' + .concat(e, ' cannot be found after ') + .concat(u, 'ms') + ) + i ? null == v || v(t) : l(t) + }, u)), + (n._observer = new MutationObserver(function (n) { + n.forEach(function (n) { + var l, + h = n.type, + u = n.target, + d = n.addedNodes, + p = n.removedNodes, + m = n.attributeName, + v = n.oldValue + if ('childList' === h && (c.includes(t.ADD) || c.includes(t.REMOVE))) { + var y, + f = s( + [].concat( + o(c.includes(t.ADD) ? Array.from(d) : []), + o(c.includes(t.REMOVE) ? Array.from(p) : []) + ) + ) + try { + for (f.s(); !(y = f.n()).done; ) { + var b, + g = y.value + ;(g === e || + (!r(e) && + null !== (b = g.matches) && + void 0 !== b && + b.call(g, e))) && + (i + ? i(g, Array.from(d).includes(g) ? t.ADD : t.REMOVE) + : a({ + node: g, + event: Array.from(d).includes(g) + ? t.ADD + : t.REMOVE, + })) + } + } catch (t) { + f.e(t) + } finally { + f.f() + } + } + 'attributes' === h && + c.includes(t.CHANGE) && + (u === e || + (!r(e) && + null !== (l = u.matches) && + void 0 !== l && + l.call(u, e))) && + (i + ? i(u, t.CHANGE, { attributeName: m, oldValue: v }) + : a({ + node: u, + event: t.CHANGE, + options: { attributeName: m, oldValue: v }, + })) + }) + })), + n._observer.observe(document.documentElement, { + subtree: !0, + childList: c.includes(t.ADD) || c.includes(t.REMOVE), + attributes: c.includes(t.CHANGE), + attributeOldValue: c.includes(t.CHANGE), + attributeFilter: p, + }) + }) + ) + }, + }, + { + key: 'clear', + value: function () { + var t + null === (t = this._observer) || void 0 === t || t.disconnect(), clearTimeout(this._timeout) + }, + }, + ]), + t + ) + })() + a(c, 'EXIST', 'DOMObserver_exist'), + a(c, 'ADD', 'DOMObserver_add'), + a(c, 'REMOVE', 'DOMObserver_remove'), + a(c, 'CHANGE', 'DOMObserver_change'), + a(c, 'EVENTS', [c.EXIST, c.ADD, c.REMOVE, c.CHANGE]) + class h { + static get GAP() { + return 10 + } + static #t = [] + #e = null + #n = [] + #o = 0 + #i = 0 + #a = null + #r = null + #s = null + #l = null + #c = null + #h = null + #u = null + #d = null + #p = !1 + #m = null + #v = null + #y = !1 + #f = null + #b = null + static destroy() { + h.#t.forEach((t) => { + t.destroy() + }), + (h.#t = []) + } + constructor(t, e, n, o, i, a, r, s, l, u, d, p, m) { + ;(this.#c = t), + (this.#h = e), + (this.#u = n), + (this.#p = o || !1), + (this.#d = i), + (this.#m = a), + (this.#v = r || 'top'), + (this.#y = s || !1), + (this.#f = l || '__tooltip-enter'), + (this.#b = u || '__tooltip-leave'), + (this.#o = d || 0), + (this.#i = p || 0), + (this.#e = new c()), + (this.#c.title = ''), + this.#c.setAttribute('style', 'position: relative'), + this.#g(), + this.#r.classList.add(this.#m || '__tooltip', `__tooltip-${this.#v}`), + m ? this.#E() : this.#T(), + h.#t.push(this) + } + update(t, e, n, o, i, a, r, s, l, c, h, u) { + const d = e !== this.#u || t !== this.#h, + p = i !== this.#m, + m = this.#v, + v = a !== this.#v, + y = u && this.#s, + f = !u && !this.#s + ;(this.#h = t), + (this.#u = e), + (this.#p = n || !1), + (this.#d = o), + (this.#m = i), + (this.#v = a || 'top'), + (this.#y = r || !1), + (this.#f = s || '__tooltip-enter'), + (this.#b = l || '__tooltip-leave'), + (this.#o = c || 0), + (this.#i = h || 0), + d && (this.#C(), this.#g()), + (p || d) && this.#r.classList.add(this.#m || '__tooltip'), + (v || p || d) && + (this.#r.classList.remove(`__tooltip-${m}`), this.#r.classList.add(`__tooltip-${this.#v}`)), + y ? this.#E() : f && this.#T() + } + destroy() { + var t + this.#C(), this.#E(), this.#A(), null === (t = this.#e) || void 0 === t || t.clear(), (this.#e = null) + } + #T() { + ;(this.#s = this.#_.bind(this)), + (this.#l = this.#D.bind(this)), + this.#c.addEventListener('mouseenter', this.#s), + this.#c.addEventListener('mouseleave', this.#l) + } + #E() { + this.#c.removeEventListener('mouseenter', this.#s), + this.#c.removeEventListener('mouseleave', this.#l), + (this.#s = null), + (this.#l = null) + } + #g() { + if (((this.#r = document.createElement('div')), this.#u)) + this.#e.wait(this.#u, null, { events: [c.EXIST, c.ADD] }).then(({ node: t }) => { + const e = this.#p ? t.cloneNode(!0) : t + this.#r.appendChild(e) + }) + else if (this.#h) { + const t = document.createTextNode(this.#h) + this.#r.appendChild(t) + } + } + #N() { + const { width: t, height: e } = this.#c.getBoundingClientRect(), + { width: n, height: o } = this.#r.getBoundingClientRect() + switch (this.#v) { + case 'left': + ;(this.#r.style.top = (-(o - e) >> 1) + 'px'), + (this.#r.style.left = -n - h.GAP + 'px'), + (this.#r.style.bottom = null), + (this.#r.style.right = null) + break + case 'right': + ;(this.#r.style.top = (-(o - e) >> 1) + 'px'), + (this.#r.style.right = -n - h.GAP + 'px'), + (this.#r.style.bottom = null), + (this.#r.style.left = null) + break + case 'bottom': + ;(this.#r.style.left = (-(n - t) >> 1) + 'px'), + (this.#r.style.bottom = -o - h.GAP + 'px'), + (this.#r.style.right = null), + (this.#r.style.top = null) + break + default: + ;(this.#r.style.left = (-(n - t) >> 1) + 'px'), + (this.#r.style.top = -o - h.GAP + 'px'), + (this.#r.style.right = null), + (this.#r.style.bottom = null) + } + } + async #w() { + this.#y && (await this.#S(1)), + this.#c.appendChild(this.#r), + this.#e.wait(this.#r, null, { events: [c.EXIST, c.ADD] }).then(() => { + this.#N() + }), + this.#d && + Object.entries(this.#d).forEach( + ([t, { eventType: e, callback: n, callbackParams: o, closeOnCallback: i }]) => { + const a = '*' === t ? this.#r : this.#r.querySelector(t) + if (a) { + const t = (t) => { + null == n || n.apply(null, [...o, t]), i && this.#C() + } + a.addEventListener(e, t), this.#n.push({ trigger: a, eventType: e, listener: t }) + } + } + ) + } + async #C() { + this.#y && (await this.#S(0)), + this.#r.remove(), + this.#n.forEach(({ trigger: t, eventType: e, listener: n }) => t.removeEventListener(e, n)), + (this.#n = []) + } + #L(t) { + return ( + this.#A(), + new Promise( + (e) => + (this.#a = setTimeout(() => { + this.#A(), e() + }, t)) + ) + ) + } + #A() { + clearTimeout(this.#a), (this.#a = null) + } + #S(t) { + return new Promise((e) => { + let n, o + if (1 === t) (n = this.#f), (o = this.#b) + else (n = this.#b), (o = this.#f) + this.#r.classList.add(n), this.#r.classList.remove(o), 1 === t && e() + const i = () => { + this.#r.removeEventListener('animationend', i), this.#r.classList.remove(n), e() + } + this.#r.addEventListener('animationend', i) + }) + } + async #_() { + await this.#L(this.#o), await this.#w() + } + async #D() { + await this.#L(this.#i), await this.#C() + } + } + !(function (t, e) { + void 0 === e && (e = {}) + var n = e.insertAt + if (t && 'undefined' != typeof document) { + var o = document.head || document.getElementsByTagName('head')[0], + i = document.createElement('style') + ;(i.type = 'text/css'), + 'top' === n && o.firstChild ? o.insertBefore(i, o.firstChild) : o.appendChild(i), + i.styleSheet ? (i.styleSheet.cssText = t) : i.appendChild(document.createTextNode(t)) + } + })( + ".__tooltip {\n\tposition: absolute;\n\tz-index: 9999;\n\tmax-width: 100%;\n\tbackground-color: black;\n\tcolor: white;\n\ttext-align: center;\n\tborder-radius: 6px;\n\tpadding: 0.5rem;\n}\n\n.__tooltip::after {\n\tcontent: '';\n\tposition: absolute;\n\tmargin-left: -5px;\n\tborder-width: 5px;\n\tborder-style: solid;\n}\n\n.__tooltip-top::after {\n\tbottom: -10px;\n\tleft: 50%;\n\tborder-color: black transparent transparent transparent;\n}\n\n.__tooltip-bottom::after {\n\ttop: -10px;\n\tleft: 50%;\n\tborder-color: transparent transparent black transparent;\n}\n\n.__tooltip-left::after {\n\ttop: calc(50% - 5px);\n\tright: -10px;\n\tborder-color: transparent transparent transparent black;\n}\n\n.__tooltip-right::after {\n\ttop: calc(50% - 5px);\n\tleft: -5px;\n\tborder-color: transparent black transparent transparent;\n}\n\n.__tooltip-enter {\n\tanimation: fadeIn 0.2s linear forwards;\n}\n\n.__tooltip-leave {\n\tanimation: fadeOut 0.2s linear forwards;\n}\n\n@keyframes fadeIn {\n\tfrom {\n\t\topacity: 0;\n\t}\n\tto {\n\t\topacity: 1;\n\t}\n}\n@keyframes fadeOut {\n\tfrom {\n\t\topacity: 1;\n\t}\n\tto {\n\t\topacity: 0;\n\t}\n}\n" + ) + var useTooltip = ( + t, + { + content: e, + contentSelector: n, + contentClone: o, + contentActions: i, + containerClassName: a, + position: r, + animated: s, + animationEnterClassName: l, + animationLeaveClassName: c, + enterDelay: u, + leaveDelay: d, + disabled: p, + } + ) => { + const m = new h(t, e, n, o, i, a, r, s, l, c, u, d, p) + return { + update: ({ + content: t, + contentSelector: e, + contentClone: n, + contentActions: o, + containerClassName: i, + position: a, + animated: r, + animationEnterClassName: s, + animationLeaveClassName: l, + enterDelay: c, + leaveDelay: h, + disabled: u, + }) => m.update(t, e, n, o, i, a, r, s, l, c, h, u), + destroy: () => m.destroy(), + } + } + + /* src\App.svelte generated by Svelte v3.44.0 */ + + const { console: console_1 } = globals + const file = 'src\\App.svelte' + + function create_fragment(ctx) { + let main + let div2 + let div0 + let useTooltip_action + let t1 + let button0 + let t3 + let div1 + let button1 + let t5 + let form + let h1 + let t7 + let fieldset0 + let label0 + let t8 + let span + let t9 + let i + let t11 + let strong + let t13 + let t14 + let fieldset1 + let label1 + let t15 + let input0 + let t16 + let fieldset2 + let label2 + let t17 + let input1 + let t18 + let fieldset3 + let label3 + let t19 + let select + let option0 + let option1 + let option2 + let option3 + let t24 + let fieldset4 + let label4 + let t25 + let input2 + let t26 + let fieldset5 + let label5 + let t27 + let input3 + let t28 + let fieldset6 + let label6 + let t29 + let input4 + let t30 + let fieldset7 + let label7 + let t31 + let input5 + let t32 + let fieldset8 + let label8 + let t33 + let input6 + let t34 + let fieldset9 + let label9 + let t35 + let input7 + let mounted + let dispose + + const block = { + c: function create() { + main = element('main') + div2 = element('div') + div0 = element('div') + div0.textContent = 'Hover me' + t1 = space() + button0 = element('button') + button0.textContent = 'Settings' + t3 = space() + div1 = element('div') + button1 = element('button') + button1.textContent = 'Close' + t5 = space() + form = element('form') + h1 = element('h1') + h1.textContent = 'Settings' + t7 = space() + fieldset0 = element('fieldset') + label0 = element('label') + t8 = text('Default Tooltip Content:\r\n ') + span = element('span') + t9 = text("Hi! I'm a ") + i = element('i') + i.textContent = 'fancy' + t11 = space() + strong = element('strong') + strong.textContent = 'tooltip' + t13 = text('!') + t14 = space() + fieldset1 = element('fieldset') + label1 = element('label') + t15 = text('Tooltip Text Content:\r\n ') + input0 = element('input') + t16 = space() + fieldset2 = element('fieldset') + label2 = element('label') + t17 = text('Use Custom Tooltip Class:\r\n ') + input1 = element('input') + t18 = space() + fieldset3 = element('fieldset') + label3 = element('label') + t19 = text('Tooltip Position:\r\n ') + select = element('select') + option0 = element('option') + option0.textContent = 'Left' + option1 = element('option') + option1.textContent = 'Right' + option2 = element('option') + option2.textContent = 'Top' + option3 = element('option') + option3.textContent = 'Bottom' + t24 = space() + fieldset4 = element('fieldset') + label4 = element('label') + t25 = text('Animate tooltip:\r\n ') + input2 = element('input') + t26 = space() + fieldset5 = element('fieldset') + label5 = element('label') + t27 = text('Use Custom Tooltip Animation Enter Class:\r\n ') + input3 = element('input') + t28 = space() + fieldset6 = element('fieldset') + label6 = element('label') + t29 = text('Use Custom Tooltip Animation Leave Class:\r\n ') + input4 = element('input') + t30 = space() + fieldset7 = element('fieldset') + label7 = element('label') + t31 = text('Tooltip Enter Delay (ms):\r\n ') + input5 = element('input') + t32 = space() + fieldset8 = element('fieldset') + label8 = element('label') + t33 = text('Tooltip Leave Delay (ms):\r\n ') + input6 = element('input') + t34 = space() + fieldset9 = element('fieldset') + label9 = element('label') + t35 = text('Disable Tooltip:\r\n ') + input7 = element('input') + attr_dev(div0, 'class', 'target svelte-1sosalq') + add_location(div0, file, 30, 8, 700) + attr_dev(button0, 'class', 'container__settings-open svelte-1sosalq') + add_location(button0, file, 56, 8, 1556) + attr_dev(button1, 'class', 'settings__settings-close svelte-1sosalq') + add_location(button1, file, 58, 12, 1753) + add_location(h1, file, 60, 16, 1902) + add_location(i, file, 64, 87, 2138) + add_location(strong, file, 64, 100, 2151) + attr_dev(span, 'id', 'tooltip__content') + attr_dev(span, 'class', 'tooltip__content svelte-1sosalq') + add_location(span, file, 64, 24, 2075) + attr_dev(label0, 'for', 'tooltip__content') + attr_dev(label0, 'class', 'svelte-1sosalq') + add_location(label0, file, 62, 20, 1969) + attr_dev(fieldset0, 'class', 'svelte-1sosalq') + add_location(fieldset0, file, 61, 16, 1937) + attr_dev(input0, 'type', 'text') + attr_dev(input0, 'class', 'svelte-1sosalq') + add_location(input0, file, 70, 24, 2372) + attr_dev(label1, 'class', 'svelte-1sosalq') + add_location(label1, file, 68, 20, 2292) + attr_dev(fieldset1, 'class', 'svelte-1sosalq') + add_location(fieldset1, file, 67, 16, 2260) + attr_dev(input1, 'type', 'checkbox') + attr_dev(input1, 'class', 'svelte-1sosalq') + add_location(input1, file, 76, 24, 2617) + attr_dev(label2, 'class', 'svelte-1sosalq') + add_location(label2, file, 74, 20, 2533) + attr_dev(fieldset2, 'class', 'svelte-1sosalq') + add_location(fieldset2, file, 73, 16, 2501) + option0.__value = 'left' + option0.value = option0.__value + add_location(option0, file, 83, 28, 2930) + option1.__value = 'right' + option1.value = option1.__value + add_location(option1, file, 84, 28, 2994) + option2.__value = 'top' + option2.value = option2.__value + add_location(option2, file, 85, 28, 3060) + option3.__value = 'bottom' + option3.value = option3.__value + add_location(option3, file, 86, 28, 3122) + if (/*tooltipPosition*/ ctx[3] === void 0) + add_render_callback(() => /*select_change_handler*/ ctx[15].call(select)) + add_location(select, file, 82, 24, 2863) + attr_dev(label3, 'class', 'svelte-1sosalq') + add_location(label3, file, 80, 20, 2787) + attr_dev(fieldset3, 'class', 'svelte-1sosalq') + add_location(fieldset3, file, 79, 16, 2755) + attr_dev(input2, 'type', 'checkbox') + attr_dev(input2, 'class', 'svelte-1sosalq') + add_location(input2, file, 93, 24, 3379) + attr_dev(label4, 'class', 'svelte-1sosalq') + add_location(label4, file, 91, 20, 3304) + attr_dev(fieldset4, 'class', 'svelte-1sosalq') + add_location(fieldset4, file, 90, 16, 3272) + attr_dev(input3, 'type', 'checkbox') + attr_dev(input3, 'class', 'svelte-1sosalq') + add_location(input3, file, 99, 24, 3642) + attr_dev(label5, 'class', 'svelte-1sosalq') + add_location(label5, file, 97, 20, 3542) + attr_dev(fieldset5, 'class', 'svelte-1sosalq') + add_location(fieldset5, file, 96, 16, 3510) + attr_dev(input4, 'type', 'checkbox') + attr_dev(input4, 'class', 'svelte-1sosalq') + add_location(input4, file, 105, 24, 3919) + attr_dev(label6, 'class', 'svelte-1sosalq') + add_location(label6, file, 103, 20, 3819) + attr_dev(fieldset6, 'class', 'svelte-1sosalq') + add_location(fieldset6, file, 102, 16, 3787) + attr_dev(input5, 'type', 'number') + attr_dev(input5, 'step', 100) + attr_dev(input5, 'min', 0) + attr_dev(input5, 'class', 'svelte-1sosalq') + add_location(input5, file, 111, 24, 4180) + attr_dev(label7, 'class', 'svelte-1sosalq') + add_location(label7, file, 109, 20, 4096) + attr_dev(fieldset7, 'class', 'svelte-1sosalq') + add_location(fieldset7, file, 108, 16, 4064) + attr_dev(input6, 'type', 'number') + attr_dev(input6, 'step', 100) + attr_dev(input6, 'min', 0) + attr_dev(input6, 'class', 'svelte-1sosalq') + add_location(input6, file, 117, 24, 4445) + attr_dev(label8, 'class', 'svelte-1sosalq') + add_location(label8, file, 115, 20, 4361) + attr_dev(fieldset8, 'class', 'svelte-1sosalq') + add_location(fieldset8, file, 114, 16, 4329) + attr_dev(input7, 'type', 'checkbox') + attr_dev(input7, 'class', 'svelte-1sosalq') + add_location(input7, file, 123, 24, 4701) + attr_dev(label9, 'class', 'svelte-1sosalq') + add_location(label9, file, 121, 20, 4626) + attr_dev(fieldset9, 'class', 'svelte-1sosalq') + add_location(fieldset9, file, 120, 16, 4594) + attr_dev(form, 'class', 'settings__form svelte-1sosalq') + add_location(form, file, 59, 12, 1855) + attr_dev(div1, 'class', 'settings__container svelte-1sosalq') + set_style(div1, '--settingsVisibility', /*settingsVisibility*/ ctx[0]) + add_location(div1, file, 57, 8, 1656) + attr_dev(div2, 'class', 'container svelte-1sosalq') + add_location(div2, file, 29, 4, 667) + attr_dev(main, 'class', 'svelte-1sosalq') + add_location(main, file, 28, 0, 655) + }, + l: function claim(nodes) { + throw new Error( + 'options.hydrate only works if the component was compiled with the `hydratable: true` option' + ) + }, + m: function mount(target, anchor) { + insert_dev(target, main, anchor) + append_dev(main, div2) + append_dev(div2, div0) + append_dev(div2, t1) + append_dev(div2, button0) + append_dev(div2, t3) + append_dev(div2, div1) + append_dev(div1, button1) + append_dev(div1, t5) + append_dev(div1, form) + append_dev(form, h1) + append_dev(form, t7) + append_dev(form, fieldset0) + append_dev(fieldset0, label0) + append_dev(label0, t8) + append_dev(label0, span) + append_dev(span, t9) + append_dev(span, i) + append_dev(span, t11) + append_dev(span, strong) + append_dev(span, t13) + append_dev(form, t14) + append_dev(form, fieldset1) + append_dev(fieldset1, label1) + append_dev(label1, t15) + append_dev(label1, input0) + set_input_value(input0, /*tooltipTextContent*/ ctx[1]) + append_dev(form, t16) + append_dev(form, fieldset2) + append_dev(fieldset2, label2) + append_dev(label2, t17) + append_dev(label2, input1) + input1.checked = /*useCustomTooltipClass*/ ctx[2] + append_dev(form, t18) + append_dev(form, fieldset3) + append_dev(fieldset3, label3) + append_dev(label3, t19) + append_dev(label3, select) + append_dev(select, option0) + append_dev(select, option1) + append_dev(select, option2) + append_dev(select, option3) + select_option(select, /*tooltipPosition*/ ctx[3]) + append_dev(form, t24) + append_dev(form, fieldset4) + append_dev(fieldset4, label4) + append_dev(label4, t25) + append_dev(label4, input2) + input2.checked = /*animateTooltip*/ ctx[5] + append_dev(form, t26) + append_dev(form, fieldset5) + append_dev(fieldset5, label5) + append_dev(label5, t27) + append_dev(label5, input3) + input3.checked = /*useCustomAnimationEnterClass*/ ctx[6] + append_dev(form, t28) + append_dev(form, fieldset6) + append_dev(fieldset6, label6) + append_dev(label6, t29) + append_dev(label6, input4) + input4.checked = /*useCustomAnimationLeaveClass*/ ctx[7] + append_dev(form, t30) + append_dev(form, fieldset7) + append_dev(fieldset7, label7) + append_dev(label7, t31) + append_dev(label7, input5) + set_input_value(input5, /*tooltipEnterDelay*/ ctx[8]) + append_dev(form, t32) + append_dev(form, fieldset8) + append_dev(fieldset8, label8) + append_dev(label8, t33) + append_dev(label8, input6) + set_input_value(input6, /*tooltipLeaveDelay*/ ctx[9]) + append_dev(form, t34) + append_dev(form, fieldset9) + append_dev(fieldset9, label9) + append_dev(label9, t35) + append_dev(label9, input7) + input7.checked = /*isTooltipDisabled*/ ctx[4] + + if (!mounted) { + dispose = [ + action_destroyer( + (useTooltip_action = useTooltip.call(null, div0, { + position: /*tooltipPosition*/ ctx[3], + content: /*tooltipTextContent*/ ctx[1], + contentSelector: !(/*tooltipTextContent*/ ctx[1]?.length) ? '.tooltip__content' : null, + contentClone: true, + contentActions: { + '*': { + eventType: 'click', + callback: /*_onTooltipClick*/ ctx[10], + callbackParams: ['ok'], + closeOnCallback: true, + }, + }, + containerClassName: /*useCustomTooltipClass*/ ctx[2] ? 'tooltip' : null, + animated: /*animateTooltip*/ ctx[5], + animationEnterClassName: /*useCustomAnimationEnterClass*/ ctx[6] + ? 'tooltip-enter' + : null, + animationLeaveClassName: /*useCustomAnimationLeaveClass*/ ctx[7] + ? 'tooltip-leave' + : null, + enterDelay: /*tooltipEnterDelay*/ ctx[8], + leaveDelay: /*tooltipLeaveDelay*/ ctx[9], + disabled: /*isTooltipDisabled*/ ctx[4], + })) + ), + listen_dev(button0, 'click', /*_onSettingsOpenClick*/ ctx[11], false, false, false), + listen_dev(button1, 'click', /*_onSettingsCloseClick*/ ctx[12], false, false, false), + listen_dev(input0, 'input', /*input0_input_handler*/ ctx[13]), + listen_dev(input1, 'change', /*input1_change_handler*/ ctx[14]), + listen_dev(select, 'change', /*select_change_handler*/ ctx[15]), + listen_dev(input2, 'change', /*input2_change_handler*/ ctx[16]), + listen_dev(input3, 'change', /*input3_change_handler*/ ctx[17]), + listen_dev(input4, 'change', /*input4_change_handler*/ ctx[18]), + listen_dev(input5, 'input', /*input5_input_handler*/ ctx[19]), + listen_dev(input6, 'input', /*input6_input_handler*/ ctx[20]), + listen_dev(input7, 'change', /*input7_change_handler*/ ctx[21]), + ] + + mounted = true + } + }, + p: function update(ctx, [dirty]) { + if ( + useTooltip_action && + is_function(useTooltip_action.update) && + dirty & + /*tooltipPosition, tooltipTextContent, useCustomTooltipClass, animateTooltip, useCustomAnimationEnterClass, useCustomAnimationLeaveClass, tooltipEnterDelay, tooltipLeaveDelay, isTooltipDisabled*/ 1022 + ) + useTooltip_action.update.call(null, { + position: /*tooltipPosition*/ ctx[3], + content: /*tooltipTextContent*/ ctx[1], + contentSelector: !(/*tooltipTextContent*/ ctx[1]?.length) ? '.tooltip__content' : null, + contentClone: true, + contentActions: { + '*': { + eventType: 'click', + callback: /*_onTooltipClick*/ ctx[10], + callbackParams: ['ok'], + closeOnCallback: true, + }, + }, + containerClassName: /*useCustomTooltipClass*/ ctx[2] ? 'tooltip' : null, + animated: /*animateTooltip*/ ctx[5], + animationEnterClassName: /*useCustomAnimationEnterClass*/ ctx[6] ? 'tooltip-enter' : null, + animationLeaveClassName: /*useCustomAnimationLeaveClass*/ ctx[7] ? 'tooltip-leave' : null, + enterDelay: /*tooltipEnterDelay*/ ctx[8], + leaveDelay: /*tooltipLeaveDelay*/ ctx[9], + disabled: /*isTooltipDisabled*/ ctx[4], + }) + + if (dirty & /*tooltipTextContent*/ 2 && input0.value !== /*tooltipTextContent*/ ctx[1]) { + set_input_value(input0, /*tooltipTextContent*/ ctx[1]) + } + + if (dirty & /*useCustomTooltipClass*/ 4) { + input1.checked = /*useCustomTooltipClass*/ ctx[2] + } + + if (dirty & /*tooltipPosition*/ 8) { + select_option(select, /*tooltipPosition*/ ctx[3]) + } + + if (dirty & /*animateTooltip*/ 32) { + input2.checked = /*animateTooltip*/ ctx[5] + } + + if (dirty & /*useCustomAnimationEnterClass*/ 64) { + input3.checked = /*useCustomAnimationEnterClass*/ ctx[6] + } + + if (dirty & /*useCustomAnimationLeaveClass*/ 128) { + input4.checked = /*useCustomAnimationLeaveClass*/ ctx[7] + } + + if (dirty & /*tooltipEnterDelay*/ 256 && to_number(input5.value) !== /*tooltipEnterDelay*/ ctx[8]) { + set_input_value(input5, /*tooltipEnterDelay*/ ctx[8]) + } + + if (dirty & /*tooltipLeaveDelay*/ 512 && to_number(input6.value) !== /*tooltipLeaveDelay*/ ctx[9]) { + set_input_value(input6, /*tooltipLeaveDelay*/ ctx[9]) + } + + if (dirty & /*isTooltipDisabled*/ 16) { + input7.checked = /*isTooltipDisabled*/ ctx[4] + } + + if (dirty & /*settingsVisibility*/ 1) { + set_style(div1, '--settingsVisibility', /*settingsVisibility*/ ctx[0]) + } + }, + i: noop, + o: noop, + d: function destroy(detaching) { + if (detaching) detach_dev(main) + mounted = false + run_all(dispose) + }, + } + + dispatch_dev('SvelteRegisterBlock', { + block, + id: create_fragment.name, + type: 'component', + source: '', + ctx, + }) + + return block + } + + function instance($$self, $$props, $$invalidate) { + let { $$slots: slots = {}, $$scope } = $$props + validate_slots('App', slots, []) + let settingsVisibility = 'hidden' + let tooltipTextContent = null + let useCustomTooltipClass = false + let tooltipPosition = 'top' + let isTooltipDisabled = false + let animateTooltip = false + let useCustomAnimationEnterClass = false + let useCustomAnimationLeaveClass = false + let tooltipEnterDelay = 200 + let tooltipLeaveDelay = 200 + + const _onTooltipClick = (arg) => { + console.log(arg) + } + + const _onSettingsOpenClick = () => { + $$invalidate(0, (settingsVisibility = 'visible')) + } + + const _onSettingsCloseClick = () => { + $$invalidate(0, (settingsVisibility = 'hidden')) + } + + const writable_props = [] + + Object.keys($$props).forEach((key) => { + if (!~writable_props.indexOf(key) && key.slice(0, 2) !== '$$' && key !== 'slot') + console_1.warn(` was created with unknown prop '${key}'`) + }) + + function input0_input_handler() { + tooltipTextContent = this.value + $$invalidate(1, tooltipTextContent) + } + + function input1_change_handler() { + useCustomTooltipClass = this.checked + $$invalidate(2, useCustomTooltipClass) + } + + function select_change_handler() { + tooltipPosition = select_value(this) + $$invalidate(3, tooltipPosition) + } + + function input2_change_handler() { + animateTooltip = this.checked + $$invalidate(5, animateTooltip) + } + + function input3_change_handler() { + useCustomAnimationEnterClass = this.checked + $$invalidate(6, useCustomAnimationEnterClass) + } + + function input4_change_handler() { + useCustomAnimationLeaveClass = this.checked + $$invalidate(7, useCustomAnimationLeaveClass) + } + + function input5_input_handler() { + tooltipEnterDelay = to_number(this.value) + $$invalidate(8, tooltipEnterDelay) + } + + function input6_input_handler() { + tooltipLeaveDelay = to_number(this.value) + $$invalidate(9, tooltipLeaveDelay) + } + + function input7_change_handler() { + isTooltipDisabled = this.checked + $$invalidate(4, isTooltipDisabled) + } + + $$self.$capture_state = () => ({ + useTooltip, + settingsVisibility, + tooltipTextContent, + useCustomTooltipClass, + tooltipPosition, + isTooltipDisabled, + animateTooltip, + useCustomAnimationEnterClass, + useCustomAnimationLeaveClass, + tooltipEnterDelay, + tooltipLeaveDelay, + _onTooltipClick, + _onSettingsOpenClick, + _onSettingsCloseClick, + }) + + $$self.$inject_state = ($$props) => { + if ('settingsVisibility' in $$props) $$invalidate(0, (settingsVisibility = $$props.settingsVisibility)) + if ('tooltipTextContent' in $$props) $$invalidate(1, (tooltipTextContent = $$props.tooltipTextContent)) + if ('useCustomTooltipClass' in $$props) + $$invalidate(2, (useCustomTooltipClass = $$props.useCustomTooltipClass)) + if ('tooltipPosition' in $$props) $$invalidate(3, (tooltipPosition = $$props.tooltipPosition)) + if ('isTooltipDisabled' in $$props) $$invalidate(4, (isTooltipDisabled = $$props.isTooltipDisabled)) + if ('animateTooltip' in $$props) $$invalidate(5, (animateTooltip = $$props.animateTooltip)) + if ('useCustomAnimationEnterClass' in $$props) + $$invalidate(6, (useCustomAnimationEnterClass = $$props.useCustomAnimationEnterClass)) + if ('useCustomAnimationLeaveClass' in $$props) + $$invalidate(7, (useCustomAnimationLeaveClass = $$props.useCustomAnimationLeaveClass)) + if ('tooltipEnterDelay' in $$props) $$invalidate(8, (tooltipEnterDelay = $$props.tooltipEnterDelay)) + if ('tooltipLeaveDelay' in $$props) $$invalidate(9, (tooltipLeaveDelay = $$props.tooltipLeaveDelay)) + } + + if ($$props && '$$inject' in $$props) { + $$self.$inject_state($$props.$$inject) + } + + return [ + settingsVisibility, + tooltipTextContent, + useCustomTooltipClass, + tooltipPosition, + isTooltipDisabled, + animateTooltip, + useCustomAnimationEnterClass, + useCustomAnimationLeaveClass, + tooltipEnterDelay, + tooltipLeaveDelay, + _onTooltipClick, + _onSettingsOpenClick, + _onSettingsCloseClick, + input0_input_handler, + input1_change_handler, + select_change_handler, + input2_change_handler, + input3_change_handler, + input4_change_handler, + input5_input_handler, + input6_input_handler, + input7_change_handler, + ] + } + + class App extends SvelteComponentDev { + constructor(options) { + super(options) + init(this, options, instance, create_fragment, safe_not_equal, {}) + + dispatch_dev('SvelteRegisterComponent', { + component: this, + tagName: 'App', + options, + id: create_fragment.name, + }) + } + } + + const app = new App({ + target: document.body, + }) + + return app +})() +//# sourceMappingURL=bundle.js.map diff --git a/public/build/bundle.js.map b/public/build/bundle.js.map new file mode 100644 index 0000000..545e74e --- /dev/null +++ b/public/build/bundle.js.map @@ -0,0 +1 @@ +{"version":3,"file":"bundle.js","sources":["../../node_modules/svelte/internal/index.mjs","../../node_modules/@untemps/svelte-use-tooltip/dist/index.js","../../src/App.svelte","../../src/main.js"],"sourcesContent":["function noop() { }\nconst identity = x => x;\nfunction assign(tar, src) {\n // @ts-ignore\n for (const k in src)\n tar[k] = src[k];\n return tar;\n}\nfunction is_promise(value) {\n return value && typeof value === 'object' && typeof value.then === 'function';\n}\nfunction add_location(element, file, line, column, char) {\n element.__svelte_meta = {\n loc: { file, line, column, char }\n };\n}\nfunction run(fn) {\n return fn();\n}\nfunction blank_object() {\n return Object.create(null);\n}\nfunction run_all(fns) {\n fns.forEach(run);\n}\nfunction is_function(thing) {\n return typeof thing === 'function';\n}\nfunction safe_not_equal(a, b) {\n return a != a ? b == b : a !== b || ((a && typeof a === 'object') || typeof a === 'function');\n}\nlet src_url_equal_anchor;\nfunction src_url_equal(element_src, url) {\n if (!src_url_equal_anchor) {\n src_url_equal_anchor = document.createElement('a');\n }\n src_url_equal_anchor.href = url;\n return element_src === src_url_equal_anchor.href;\n}\nfunction not_equal(a, b) {\n return a != a ? b == b : a !== b;\n}\nfunction is_empty(obj) {\n return Object.keys(obj).length === 0;\n}\nfunction validate_store(store, name) {\n if (store != null && typeof store.subscribe !== 'function') {\n throw new Error(`'${name}' is not a store with a 'subscribe' method`);\n }\n}\nfunction subscribe(store, ...callbacks) {\n if (store == null) {\n return noop;\n }\n const unsub = store.subscribe(...callbacks);\n return unsub.unsubscribe ? () => unsub.unsubscribe() : unsub;\n}\nfunction get_store_value(store) {\n let value;\n subscribe(store, _ => value = _)();\n return value;\n}\nfunction component_subscribe(component, store, callback) {\n component.$$.on_destroy.push(subscribe(store, callback));\n}\nfunction create_slot(definition, ctx, $$scope, fn) {\n if (definition) {\n const slot_ctx = get_slot_context(definition, ctx, $$scope, fn);\n return definition[0](slot_ctx);\n }\n}\nfunction get_slot_context(definition, ctx, $$scope, fn) {\n return definition[1] && fn\n ? assign($$scope.ctx.slice(), definition[1](fn(ctx)))\n : $$scope.ctx;\n}\nfunction get_slot_changes(definition, $$scope, dirty, fn) {\n if (definition[2] && fn) {\n const lets = definition[2](fn(dirty));\n if ($$scope.dirty === undefined) {\n return lets;\n }\n if (typeof lets === 'object') {\n const merged = [];\n const len = Math.max($$scope.dirty.length, lets.length);\n for (let i = 0; i < len; i += 1) {\n merged[i] = $$scope.dirty[i] | lets[i];\n }\n return merged;\n }\n return $$scope.dirty | lets;\n }\n return $$scope.dirty;\n}\nfunction update_slot_base(slot, slot_definition, ctx, $$scope, slot_changes, get_slot_context_fn) {\n if (slot_changes) {\n const slot_context = get_slot_context(slot_definition, ctx, $$scope, get_slot_context_fn);\n slot.p(slot_context, slot_changes);\n }\n}\nfunction update_slot(slot, slot_definition, ctx, $$scope, dirty, get_slot_changes_fn, get_slot_context_fn) {\n const slot_changes = get_slot_changes(slot_definition, $$scope, dirty, get_slot_changes_fn);\n update_slot_base(slot, slot_definition, ctx, $$scope, slot_changes, get_slot_context_fn);\n}\nfunction get_all_dirty_from_scope($$scope) {\n if ($$scope.ctx.length > 32) {\n const dirty = [];\n const length = $$scope.ctx.length / 32;\n for (let i = 0; i < length; i++) {\n dirty[i] = -1;\n }\n return dirty;\n }\n return -1;\n}\nfunction exclude_internal_props(props) {\n const result = {};\n for (const k in props)\n if (k[0] !== '$')\n result[k] = props[k];\n return result;\n}\nfunction compute_rest_props(props, keys) {\n const rest = {};\n keys = new Set(keys);\n for (const k in props)\n if (!keys.has(k) && k[0] !== '$')\n rest[k] = props[k];\n return rest;\n}\nfunction compute_slots(slots) {\n const result = {};\n for (const key in slots) {\n result[key] = true;\n }\n return result;\n}\nfunction once(fn) {\n let ran = false;\n return function (...args) {\n if (ran)\n return;\n ran = true;\n fn.call(this, ...args);\n };\n}\nfunction null_to_empty(value) {\n return value == null ? '' : value;\n}\nfunction set_store_value(store, ret, value) {\n store.set(value);\n return ret;\n}\nconst has_prop = (obj, prop) => Object.prototype.hasOwnProperty.call(obj, prop);\nfunction action_destroyer(action_result) {\n return action_result && is_function(action_result.destroy) ? action_result.destroy : noop;\n}\n\nconst is_client = typeof window !== 'undefined';\nlet now = is_client\n ? () => window.performance.now()\n : () => Date.now();\nlet raf = is_client ? cb => requestAnimationFrame(cb) : noop;\n// used internally for testing\nfunction set_now(fn) {\n now = fn;\n}\nfunction set_raf(fn) {\n raf = fn;\n}\n\nconst tasks = new Set();\nfunction run_tasks(now) {\n tasks.forEach(task => {\n if (!task.c(now)) {\n tasks.delete(task);\n task.f();\n }\n });\n if (tasks.size !== 0)\n raf(run_tasks);\n}\n/**\n * For testing purposes only!\n */\nfunction clear_loops() {\n tasks.clear();\n}\n/**\n * Creates a new task that runs on each raf frame\n * until it returns a falsy value or is aborted\n */\nfunction loop(callback) {\n let task;\n if (tasks.size === 0)\n raf(run_tasks);\n return {\n promise: new Promise(fulfill => {\n tasks.add(task = { c: callback, f: fulfill });\n }),\n abort() {\n tasks.delete(task);\n }\n };\n}\n\n// Track which nodes are claimed during hydration. Unclaimed nodes can then be removed from the DOM\n// at the end of hydration without touching the remaining nodes.\nlet is_hydrating = false;\nfunction start_hydrating() {\n is_hydrating = true;\n}\nfunction end_hydrating() {\n is_hydrating = false;\n}\nfunction upper_bound(low, high, key, value) {\n // Return first index of value larger than input value in the range [low, high)\n while (low < high) {\n const mid = low + ((high - low) >> 1);\n if (key(mid) <= value) {\n low = mid + 1;\n }\n else {\n high = mid;\n }\n }\n return low;\n}\nfunction init_hydrate(target) {\n if (target.hydrate_init)\n return;\n target.hydrate_init = true;\n // We know that all children have claim_order values since the unclaimed have been detached if target is not \n let children = target.childNodes;\n // If target is , there may be children without claim_order\n if (target.nodeName === 'HEAD') {\n const myChildren = [];\n for (let i = 0; i < children.length; i++) {\n const node = children[i];\n if (node.claim_order !== undefined) {\n myChildren.push(node);\n }\n }\n children = myChildren;\n }\n /*\n * Reorder claimed children optimally.\n * We can reorder claimed children optimally by finding the longest subsequence of\n * nodes that are already claimed in order and only moving the rest. The longest\n * subsequence subsequence of nodes that are claimed in order can be found by\n * computing the longest increasing subsequence of .claim_order values.\n *\n * This algorithm is optimal in generating the least amount of reorder operations\n * possible.\n *\n * Proof:\n * We know that, given a set of reordering operations, the nodes that do not move\n * always form an increasing subsequence, since they do not move among each other\n * meaning that they must be already ordered among each other. Thus, the maximal\n * set of nodes that do not move form a longest increasing subsequence.\n */\n // Compute longest increasing subsequence\n // m: subsequence length j => index k of smallest value that ends an increasing subsequence of length j\n const m = new Int32Array(children.length + 1);\n // Predecessor indices + 1\n const p = new Int32Array(children.length);\n m[0] = -1;\n let longest = 0;\n for (let i = 0; i < children.length; i++) {\n const current = children[i].claim_order;\n // Find the largest subsequence length such that it ends in a value less than our current value\n // upper_bound returns first greater value, so we subtract one\n // with fast path for when we are on the current longest subsequence\n const seqLen = ((longest > 0 && children[m[longest]].claim_order <= current) ? longest + 1 : upper_bound(1, longest, idx => children[m[idx]].claim_order, current)) - 1;\n p[i] = m[seqLen] + 1;\n const newLen = seqLen + 1;\n // We can guarantee that current is the smallest value. Otherwise, we would have generated a longer sequence.\n m[newLen] = i;\n longest = Math.max(newLen, longest);\n }\n // The longest increasing subsequence of nodes (initially reversed)\n const lis = [];\n // The rest of the nodes, nodes that will be moved\n const toMove = [];\n let last = children.length - 1;\n for (let cur = m[longest] + 1; cur != 0; cur = p[cur - 1]) {\n lis.push(children[cur - 1]);\n for (; last >= cur; last--) {\n toMove.push(children[last]);\n }\n last--;\n }\n for (; last >= 0; last--) {\n toMove.push(children[last]);\n }\n lis.reverse();\n // We sort the nodes being moved to guarantee that their insertion order matches the claim order\n toMove.sort((a, b) => a.claim_order - b.claim_order);\n // Finally, we move the nodes\n for (let i = 0, j = 0; i < toMove.length; i++) {\n while (j < lis.length && toMove[i].claim_order >= lis[j].claim_order) {\n j++;\n }\n const anchor = j < lis.length ? lis[j] : null;\n target.insertBefore(toMove[i], anchor);\n }\n}\nfunction append(target, node) {\n target.appendChild(node);\n}\nfunction append_styles(target, style_sheet_id, styles) {\n const append_styles_to = get_root_for_style(target);\n if (!append_styles_to.getElementById(style_sheet_id)) {\n const style = element('style');\n style.id = style_sheet_id;\n style.textContent = styles;\n append_stylesheet(append_styles_to, style);\n }\n}\nfunction get_root_for_style(node) {\n if (!node)\n return document;\n const root = node.getRootNode ? node.getRootNode() : node.ownerDocument;\n if (root && root.host) {\n return root;\n }\n return node.ownerDocument;\n}\nfunction append_empty_stylesheet(node) {\n const style_element = element('style');\n append_stylesheet(get_root_for_style(node), style_element);\n return style_element;\n}\nfunction append_stylesheet(node, style) {\n append(node.head || node, style);\n}\nfunction append_hydration(target, node) {\n if (is_hydrating) {\n init_hydrate(target);\n if ((target.actual_end_child === undefined) || ((target.actual_end_child !== null) && (target.actual_end_child.parentElement !== target))) {\n target.actual_end_child = target.firstChild;\n }\n // Skip nodes of undefined ordering\n while ((target.actual_end_child !== null) && (target.actual_end_child.claim_order === undefined)) {\n target.actual_end_child = target.actual_end_child.nextSibling;\n }\n if (node !== target.actual_end_child) {\n // We only insert if the ordering of this node should be modified or the parent node is not target\n if (node.claim_order !== undefined || node.parentNode !== target) {\n target.insertBefore(node, target.actual_end_child);\n }\n }\n else {\n target.actual_end_child = node.nextSibling;\n }\n }\n else if (node.parentNode !== target || node.nextSibling !== null) {\n target.appendChild(node);\n }\n}\nfunction insert(target, node, anchor) {\n target.insertBefore(node, anchor || null);\n}\nfunction insert_hydration(target, node, anchor) {\n if (is_hydrating && !anchor) {\n append_hydration(target, node);\n }\n else if (node.parentNode !== target || node.nextSibling != anchor) {\n target.insertBefore(node, anchor || null);\n }\n}\nfunction detach(node) {\n node.parentNode.removeChild(node);\n}\nfunction destroy_each(iterations, detaching) {\n for (let i = 0; i < iterations.length; i += 1) {\n if (iterations[i])\n iterations[i].d(detaching);\n }\n}\nfunction element(name) {\n return document.createElement(name);\n}\nfunction element_is(name, is) {\n return document.createElement(name, { is });\n}\nfunction object_without_properties(obj, exclude) {\n const target = {};\n for (const k in obj) {\n if (has_prop(obj, k)\n // @ts-ignore\n && exclude.indexOf(k) === -1) {\n // @ts-ignore\n target[k] = obj[k];\n }\n }\n return target;\n}\nfunction svg_element(name) {\n return document.createElementNS('http://www.w3.org/2000/svg', name);\n}\nfunction text(data) {\n return document.createTextNode(data);\n}\nfunction space() {\n return text(' ');\n}\nfunction empty() {\n return text('');\n}\nfunction listen(node, event, handler, options) {\n node.addEventListener(event, handler, options);\n return () => node.removeEventListener(event, handler, options);\n}\nfunction prevent_default(fn) {\n return function (event) {\n event.preventDefault();\n // @ts-ignore\n return fn.call(this, event);\n };\n}\nfunction stop_propagation(fn) {\n return function (event) {\n event.stopPropagation();\n // @ts-ignore\n return fn.call(this, event);\n };\n}\nfunction self(fn) {\n return function (event) {\n // @ts-ignore\n if (event.target === this)\n fn.call(this, event);\n };\n}\nfunction trusted(fn) {\n return function (event) {\n // @ts-ignore\n if (event.isTrusted)\n fn.call(this, event);\n };\n}\nfunction attr(node, attribute, value) {\n if (value == null)\n node.removeAttribute(attribute);\n else if (node.getAttribute(attribute) !== value)\n node.setAttribute(attribute, value);\n}\nfunction set_attributes(node, attributes) {\n // @ts-ignore\n const descriptors = Object.getOwnPropertyDescriptors(node.__proto__);\n for (const key in attributes) {\n if (attributes[key] == null) {\n node.removeAttribute(key);\n }\n else if (key === 'style') {\n node.style.cssText = attributes[key];\n }\n else if (key === '__value') {\n node.value = node[key] = attributes[key];\n }\n else if (descriptors[key] && descriptors[key].set) {\n node[key] = attributes[key];\n }\n else {\n attr(node, key, attributes[key]);\n }\n }\n}\nfunction set_svg_attributes(node, attributes) {\n for (const key in attributes) {\n attr(node, key, attributes[key]);\n }\n}\nfunction set_custom_element_data(node, prop, value) {\n if (prop in node) {\n node[prop] = typeof node[prop] === 'boolean' && value === '' ? true : value;\n }\n else {\n attr(node, prop, value);\n }\n}\nfunction xlink_attr(node, attribute, value) {\n node.setAttributeNS('http://www.w3.org/1999/xlink', attribute, value);\n}\nfunction get_binding_group_value(group, __value, checked) {\n const value = new Set();\n for (let i = 0; i < group.length; i += 1) {\n if (group[i].checked)\n value.add(group[i].__value);\n }\n if (!checked) {\n value.delete(__value);\n }\n return Array.from(value);\n}\nfunction to_number(value) {\n return value === '' ? null : +value;\n}\nfunction time_ranges_to_array(ranges) {\n const array = [];\n for (let i = 0; i < ranges.length; i += 1) {\n array.push({ start: ranges.start(i), end: ranges.end(i) });\n }\n return array;\n}\nfunction children(element) {\n return Array.from(element.childNodes);\n}\nfunction init_claim_info(nodes) {\n if (nodes.claim_info === undefined) {\n nodes.claim_info = { last_index: 0, total_claimed: 0 };\n }\n}\nfunction claim_node(nodes, predicate, processNode, createNode, dontUpdateLastIndex = false) {\n // Try to find nodes in an order such that we lengthen the longest increasing subsequence\n init_claim_info(nodes);\n const resultNode = (() => {\n // We first try to find an element after the previous one\n for (let i = nodes.claim_info.last_index; i < nodes.length; i++) {\n const node = nodes[i];\n if (predicate(node)) {\n const replacement = processNode(node);\n if (replacement === undefined) {\n nodes.splice(i, 1);\n }\n else {\n nodes[i] = replacement;\n }\n if (!dontUpdateLastIndex) {\n nodes.claim_info.last_index = i;\n }\n return node;\n }\n }\n // Otherwise, we try to find one before\n // We iterate in reverse so that we don't go too far back\n for (let i = nodes.claim_info.last_index - 1; i >= 0; i--) {\n const node = nodes[i];\n if (predicate(node)) {\n const replacement = processNode(node);\n if (replacement === undefined) {\n nodes.splice(i, 1);\n }\n else {\n nodes[i] = replacement;\n }\n if (!dontUpdateLastIndex) {\n nodes.claim_info.last_index = i;\n }\n else if (replacement === undefined) {\n // Since we spliced before the last_index, we decrease it\n nodes.claim_info.last_index--;\n }\n return node;\n }\n }\n // If we can't find any matching node, we create a new one\n return createNode();\n })();\n resultNode.claim_order = nodes.claim_info.total_claimed;\n nodes.claim_info.total_claimed += 1;\n return resultNode;\n}\nfunction claim_element_base(nodes, name, attributes, create_element) {\n return claim_node(nodes, (node) => node.nodeName === name, (node) => {\n const remove = [];\n for (let j = 0; j < node.attributes.length; j++) {\n const attribute = node.attributes[j];\n if (!attributes[attribute.name]) {\n remove.push(attribute.name);\n }\n }\n remove.forEach(v => node.removeAttribute(v));\n return undefined;\n }, () => create_element(name));\n}\nfunction claim_element(nodes, name, attributes) {\n return claim_element_base(nodes, name, attributes, element);\n}\nfunction claim_svg_element(nodes, name, attributes) {\n return claim_element_base(nodes, name, attributes, svg_element);\n}\nfunction claim_text(nodes, data) {\n return claim_node(nodes, (node) => node.nodeType === 3, (node) => {\n const dataStr = '' + data;\n if (node.data.startsWith(dataStr)) {\n if (node.data.length !== dataStr.length) {\n return node.splitText(dataStr.length);\n }\n }\n else {\n node.data = dataStr;\n }\n }, () => text(data), true // Text nodes should not update last index since it is likely not worth it to eliminate an increasing subsequence of actual elements\n );\n}\nfunction claim_space(nodes) {\n return claim_text(nodes, ' ');\n}\nfunction find_comment(nodes, text, start) {\n for (let i = start; i < nodes.length; i += 1) {\n const node = nodes[i];\n if (node.nodeType === 8 /* comment node */ && node.textContent.trim() === text) {\n return i;\n }\n }\n return nodes.length;\n}\nfunction claim_html_tag(nodes) {\n // find html opening tag\n const start_index = find_comment(nodes, 'HTML_TAG_START', 0);\n const end_index = find_comment(nodes, 'HTML_TAG_END', start_index);\n if (start_index === end_index) {\n return new HtmlTagHydration();\n }\n init_claim_info(nodes);\n const html_tag_nodes = nodes.splice(start_index, end_index + 1);\n detach(html_tag_nodes[0]);\n detach(html_tag_nodes[html_tag_nodes.length - 1]);\n const claimed_nodes = html_tag_nodes.slice(1, html_tag_nodes.length - 1);\n for (const n of claimed_nodes) {\n n.claim_order = nodes.claim_info.total_claimed;\n nodes.claim_info.total_claimed += 1;\n }\n return new HtmlTagHydration(claimed_nodes);\n}\nfunction set_data(text, data) {\n data = '' + data;\n if (text.wholeText !== data)\n text.data = data;\n}\nfunction set_input_value(input, value) {\n input.value = value == null ? '' : value;\n}\nfunction set_input_type(input, type) {\n try {\n input.type = type;\n }\n catch (e) {\n // do nothing\n }\n}\nfunction set_style(node, key, value, important) {\n node.style.setProperty(key, value, important ? 'important' : '');\n}\nfunction select_option(select, value) {\n for (let i = 0; i < select.options.length; i += 1) {\n const option = select.options[i];\n if (option.__value === value) {\n option.selected = true;\n return;\n }\n }\n select.selectedIndex = -1; // no option should be selected\n}\nfunction select_options(select, value) {\n for (let i = 0; i < select.options.length; i += 1) {\n const option = select.options[i];\n option.selected = ~value.indexOf(option.__value);\n }\n}\nfunction select_value(select) {\n const selected_option = select.querySelector(':checked') || select.options[0];\n return selected_option && selected_option.__value;\n}\nfunction select_multiple_value(select) {\n return [].map.call(select.querySelectorAll(':checked'), option => option.__value);\n}\n// unfortunately this can't be a constant as that wouldn't be tree-shakeable\n// so we cache the result instead\nlet crossorigin;\nfunction is_crossorigin() {\n if (crossorigin === undefined) {\n crossorigin = false;\n try {\n if (typeof window !== 'undefined' && window.parent) {\n void window.parent.document;\n }\n }\n catch (error) {\n crossorigin = true;\n }\n }\n return crossorigin;\n}\nfunction add_resize_listener(node, fn) {\n const computed_style = getComputedStyle(node);\n if (computed_style.position === 'static') {\n node.style.position = 'relative';\n }\n const iframe = element('iframe');\n iframe.setAttribute('style', 'display: block; position: absolute; top: 0; left: 0; width: 100%; height: 100%; ' +\n 'overflow: hidden; border: 0; opacity: 0; pointer-events: none; z-index: -1;');\n iframe.setAttribute('aria-hidden', 'true');\n iframe.tabIndex = -1;\n const crossorigin = is_crossorigin();\n let unsubscribe;\n if (crossorigin) {\n iframe.src = \"data:text/html,\";\n unsubscribe = listen(window, 'message', (event) => {\n if (event.source === iframe.contentWindow)\n fn();\n });\n }\n else {\n iframe.src = 'about:blank';\n iframe.onload = () => {\n unsubscribe = listen(iframe.contentWindow, 'resize', fn);\n };\n }\n append(node, iframe);\n return () => {\n if (crossorigin) {\n unsubscribe();\n }\n else if (unsubscribe && iframe.contentWindow) {\n unsubscribe();\n }\n detach(iframe);\n };\n}\nfunction toggle_class(element, name, toggle) {\n element.classList[toggle ? 'add' : 'remove'](name);\n}\nfunction custom_event(type, detail, bubbles = false) {\n const e = document.createEvent('CustomEvent');\n e.initCustomEvent(type, bubbles, false, detail);\n return e;\n}\nfunction query_selector_all(selector, parent = document.body) {\n return Array.from(parent.querySelectorAll(selector));\n}\nclass HtmlTag {\n constructor() {\n this.e = this.n = null;\n }\n c(html) {\n this.h(html);\n }\n m(html, target, anchor = null) {\n if (!this.e) {\n this.e = element(target.nodeName);\n this.t = target;\n this.c(html);\n }\n this.i(anchor);\n }\n h(html) {\n this.e.innerHTML = html;\n this.n = Array.from(this.e.childNodes);\n }\n i(anchor) {\n for (let i = 0; i < this.n.length; i += 1) {\n insert(this.t, this.n[i], anchor);\n }\n }\n p(html) {\n this.d();\n this.h(html);\n this.i(this.a);\n }\n d() {\n this.n.forEach(detach);\n }\n}\nclass HtmlTagHydration extends HtmlTag {\n constructor(claimed_nodes) {\n super();\n this.e = this.n = null;\n this.l = claimed_nodes;\n }\n c(html) {\n if (this.l) {\n this.n = this.l;\n }\n else {\n super.c(html);\n }\n }\n i(anchor) {\n for (let i = 0; i < this.n.length; i += 1) {\n insert_hydration(this.t, this.n[i], anchor);\n }\n }\n}\nfunction attribute_to_object(attributes) {\n const result = {};\n for (const attribute of attributes) {\n result[attribute.name] = attribute.value;\n }\n return result;\n}\nfunction get_custom_elements_slots(element) {\n const result = {};\n element.childNodes.forEach((node) => {\n result[node.slot || 'default'] = true;\n });\n return result;\n}\n\nconst active_docs = new Set();\nlet active = 0;\n// https://github.com/darkskyapp/string-hash/blob/master/index.js\nfunction hash(str) {\n let hash = 5381;\n let i = str.length;\n while (i--)\n hash = ((hash << 5) - hash) ^ str.charCodeAt(i);\n return hash >>> 0;\n}\nfunction create_rule(node, a, b, duration, delay, ease, fn, uid = 0) {\n const step = 16.666 / duration;\n let keyframes = '{\\n';\n for (let p = 0; p <= 1; p += step) {\n const t = a + (b - a) * ease(p);\n keyframes += p * 100 + `%{${fn(t, 1 - t)}}\\n`;\n }\n const rule = keyframes + `100% {${fn(b, 1 - b)}}\\n}`;\n const name = `__svelte_${hash(rule)}_${uid}`;\n const doc = get_root_for_style(node);\n active_docs.add(doc);\n const stylesheet = doc.__svelte_stylesheet || (doc.__svelte_stylesheet = append_empty_stylesheet(node).sheet);\n const current_rules = doc.__svelte_rules || (doc.__svelte_rules = {});\n if (!current_rules[name]) {\n current_rules[name] = true;\n stylesheet.insertRule(`@keyframes ${name} ${rule}`, stylesheet.cssRules.length);\n }\n const animation = node.style.animation || '';\n node.style.animation = `${animation ? `${animation}, ` : ''}${name} ${duration}ms linear ${delay}ms 1 both`;\n active += 1;\n return name;\n}\nfunction delete_rule(node, name) {\n const previous = (node.style.animation || '').split(', ');\n const next = previous.filter(name\n ? anim => anim.indexOf(name) < 0 // remove specific animation\n : anim => anim.indexOf('__svelte') === -1 // remove all Svelte animations\n );\n const deleted = previous.length - next.length;\n if (deleted) {\n node.style.animation = next.join(', ');\n active -= deleted;\n if (!active)\n clear_rules();\n }\n}\nfunction clear_rules() {\n raf(() => {\n if (active)\n return;\n active_docs.forEach(doc => {\n const stylesheet = doc.__svelte_stylesheet;\n let i = stylesheet.cssRules.length;\n while (i--)\n stylesheet.deleteRule(i);\n doc.__svelte_rules = {};\n });\n active_docs.clear();\n });\n}\n\nfunction create_animation(node, from, fn, params) {\n if (!from)\n return noop;\n const to = node.getBoundingClientRect();\n if (from.left === to.left && from.right === to.right && from.top === to.top && from.bottom === to.bottom)\n return noop;\n const { delay = 0, duration = 300, easing = identity, \n // @ts-ignore todo: should this be separated from destructuring? Or start/end added to public api and documentation?\n start: start_time = now() + delay, \n // @ts-ignore todo:\n end = start_time + duration, tick = noop, css } = fn(node, { from, to }, params);\n let running = true;\n let started = false;\n let name;\n function start() {\n if (css) {\n name = create_rule(node, 0, 1, duration, delay, easing, css);\n }\n if (!delay) {\n started = true;\n }\n }\n function stop() {\n if (css)\n delete_rule(node, name);\n running = false;\n }\n loop(now => {\n if (!started && now >= start_time) {\n started = true;\n }\n if (started && now >= end) {\n tick(1, 0);\n stop();\n }\n if (!running) {\n return false;\n }\n if (started) {\n const p = now - start_time;\n const t = 0 + 1 * easing(p / duration);\n tick(t, 1 - t);\n }\n return true;\n });\n start();\n tick(0, 1);\n return stop;\n}\nfunction fix_position(node) {\n const style = getComputedStyle(node);\n if (style.position !== 'absolute' && style.position !== 'fixed') {\n const { width, height } = style;\n const a = node.getBoundingClientRect();\n node.style.position = 'absolute';\n node.style.width = width;\n node.style.height = height;\n add_transform(node, a);\n }\n}\nfunction add_transform(node, a) {\n const b = node.getBoundingClientRect();\n if (a.left !== b.left || a.top !== b.top) {\n const style = getComputedStyle(node);\n const transform = style.transform === 'none' ? '' : style.transform;\n node.style.transform = `${transform} translate(${a.left - b.left}px, ${a.top - b.top}px)`;\n }\n}\n\nlet current_component;\nfunction set_current_component(component) {\n current_component = component;\n}\nfunction get_current_component() {\n if (!current_component)\n throw new Error('Function called outside component initialization');\n return current_component;\n}\nfunction beforeUpdate(fn) {\n get_current_component().$$.before_update.push(fn);\n}\nfunction onMount(fn) {\n get_current_component().$$.on_mount.push(fn);\n}\nfunction afterUpdate(fn) {\n get_current_component().$$.after_update.push(fn);\n}\nfunction onDestroy(fn) {\n get_current_component().$$.on_destroy.push(fn);\n}\nfunction createEventDispatcher() {\n const component = get_current_component();\n return (type, detail) => {\n const callbacks = component.$$.callbacks[type];\n if (callbacks) {\n // TODO are there situations where events could be dispatched\n // in a server (non-DOM) environment?\n const event = custom_event(type, detail);\n callbacks.slice().forEach(fn => {\n fn.call(component, event);\n });\n }\n };\n}\nfunction setContext(key, context) {\n get_current_component().$$.context.set(key, context);\n}\nfunction getContext(key) {\n return get_current_component().$$.context.get(key);\n}\nfunction getAllContexts() {\n return get_current_component().$$.context;\n}\nfunction hasContext(key) {\n return get_current_component().$$.context.has(key);\n}\n// TODO figure out if we still want to support\n// shorthand events, or if we want to implement\n// a real bubbling mechanism\nfunction bubble(component, event) {\n const callbacks = component.$$.callbacks[event.type];\n if (callbacks) {\n // @ts-ignore\n callbacks.slice().forEach(fn => fn.call(this, event));\n }\n}\n\nconst dirty_components = [];\nconst intros = { enabled: false };\nconst binding_callbacks = [];\nconst render_callbacks = [];\nconst flush_callbacks = [];\nconst resolved_promise = Promise.resolve();\nlet update_scheduled = false;\nfunction schedule_update() {\n if (!update_scheduled) {\n update_scheduled = true;\n resolved_promise.then(flush);\n }\n}\nfunction tick() {\n schedule_update();\n return resolved_promise;\n}\nfunction add_render_callback(fn) {\n render_callbacks.push(fn);\n}\nfunction add_flush_callback(fn) {\n flush_callbacks.push(fn);\n}\nlet flushing = false;\nconst seen_callbacks = new Set();\nfunction flush() {\n if (flushing)\n return;\n flushing = true;\n do {\n // first, call beforeUpdate functions\n // and update components\n for (let i = 0; i < dirty_components.length; i += 1) {\n const component = dirty_components[i];\n set_current_component(component);\n update(component.$$);\n }\n set_current_component(null);\n dirty_components.length = 0;\n while (binding_callbacks.length)\n binding_callbacks.pop()();\n // then, once components are updated, call\n // afterUpdate functions. This may cause\n // subsequent updates...\n for (let i = 0; i < render_callbacks.length; i += 1) {\n const callback = render_callbacks[i];\n if (!seen_callbacks.has(callback)) {\n // ...so guard against infinite loops\n seen_callbacks.add(callback);\n callback();\n }\n }\n render_callbacks.length = 0;\n } while (dirty_components.length);\n while (flush_callbacks.length) {\n flush_callbacks.pop()();\n }\n update_scheduled = false;\n flushing = false;\n seen_callbacks.clear();\n}\nfunction update($$) {\n if ($$.fragment !== null) {\n $$.update();\n run_all($$.before_update);\n const dirty = $$.dirty;\n $$.dirty = [-1];\n $$.fragment && $$.fragment.p($$.ctx, dirty);\n $$.after_update.forEach(add_render_callback);\n }\n}\n\nlet promise;\nfunction wait() {\n if (!promise) {\n promise = Promise.resolve();\n promise.then(() => {\n promise = null;\n });\n }\n return promise;\n}\nfunction dispatch(node, direction, kind) {\n node.dispatchEvent(custom_event(`${direction ? 'intro' : 'outro'}${kind}`));\n}\nconst outroing = new Set();\nlet outros;\nfunction group_outros() {\n outros = {\n r: 0,\n c: [],\n p: outros // parent group\n };\n}\nfunction check_outros() {\n if (!outros.r) {\n run_all(outros.c);\n }\n outros = outros.p;\n}\nfunction transition_in(block, local) {\n if (block && block.i) {\n outroing.delete(block);\n block.i(local);\n }\n}\nfunction transition_out(block, local, detach, callback) {\n if (block && block.o) {\n if (outroing.has(block))\n return;\n outroing.add(block);\n outros.c.push(() => {\n outroing.delete(block);\n if (callback) {\n if (detach)\n block.d(1);\n callback();\n }\n });\n block.o(local);\n }\n}\nconst null_transition = { duration: 0 };\nfunction create_in_transition(node, fn, params) {\n let config = fn(node, params);\n let running = false;\n let animation_name;\n let task;\n let uid = 0;\n function cleanup() {\n if (animation_name)\n delete_rule(node, animation_name);\n }\n function go() {\n const { delay = 0, duration = 300, easing = identity, tick = noop, css } = config || null_transition;\n if (css)\n animation_name = create_rule(node, 0, 1, duration, delay, easing, css, uid++);\n tick(0, 1);\n const start_time = now() + delay;\n const end_time = start_time + duration;\n if (task)\n task.abort();\n running = true;\n add_render_callback(() => dispatch(node, true, 'start'));\n task = loop(now => {\n if (running) {\n if (now >= end_time) {\n tick(1, 0);\n dispatch(node, true, 'end');\n cleanup();\n return running = false;\n }\n if (now >= start_time) {\n const t = easing((now - start_time) / duration);\n tick(t, 1 - t);\n }\n }\n return running;\n });\n }\n let started = false;\n return {\n start() {\n if (started)\n return;\n started = true;\n delete_rule(node);\n if (is_function(config)) {\n config = config();\n wait().then(go);\n }\n else {\n go();\n }\n },\n invalidate() {\n started = false;\n },\n end() {\n if (running) {\n cleanup();\n running = false;\n }\n }\n };\n}\nfunction create_out_transition(node, fn, params) {\n let config = fn(node, params);\n let running = true;\n let animation_name;\n const group = outros;\n group.r += 1;\n function go() {\n const { delay = 0, duration = 300, easing = identity, tick = noop, css } = config || null_transition;\n if (css)\n animation_name = create_rule(node, 1, 0, duration, delay, easing, css);\n const start_time = now() + delay;\n const end_time = start_time + duration;\n add_render_callback(() => dispatch(node, false, 'start'));\n loop(now => {\n if (running) {\n if (now >= end_time) {\n tick(0, 1);\n dispatch(node, false, 'end');\n if (!--group.r) {\n // this will result in `end()` being called,\n // so we don't need to clean up here\n run_all(group.c);\n }\n return false;\n }\n if (now >= start_time) {\n const t = easing((now - start_time) / duration);\n tick(1 - t, t);\n }\n }\n return running;\n });\n }\n if (is_function(config)) {\n wait().then(() => {\n // @ts-ignore\n config = config();\n go();\n });\n }\n else {\n go();\n }\n return {\n end(reset) {\n if (reset && config.tick) {\n config.tick(1, 0);\n }\n if (running) {\n if (animation_name)\n delete_rule(node, animation_name);\n running = false;\n }\n }\n };\n}\nfunction create_bidirectional_transition(node, fn, params, intro) {\n let config = fn(node, params);\n let t = intro ? 0 : 1;\n let running_program = null;\n let pending_program = null;\n let animation_name = null;\n function clear_animation() {\n if (animation_name)\n delete_rule(node, animation_name);\n }\n function init(program, duration) {\n const d = (program.b - t);\n duration *= Math.abs(d);\n return {\n a: t,\n b: program.b,\n d,\n duration,\n start: program.start,\n end: program.start + duration,\n group: program.group\n };\n }\n function go(b) {\n const { delay = 0, duration = 300, easing = identity, tick = noop, css } = config || null_transition;\n const program = {\n start: now() + delay,\n b\n };\n if (!b) {\n // @ts-ignore todo: improve typings\n program.group = outros;\n outros.r += 1;\n }\n if (running_program || pending_program) {\n pending_program = program;\n }\n else {\n // if this is an intro, and there's a delay, we need to do\n // an initial tick and/or apply CSS animation immediately\n if (css) {\n clear_animation();\n animation_name = create_rule(node, t, b, duration, delay, easing, css);\n }\n if (b)\n tick(0, 1);\n running_program = init(program, duration);\n add_render_callback(() => dispatch(node, b, 'start'));\n loop(now => {\n if (pending_program && now > pending_program.start) {\n running_program = init(pending_program, duration);\n pending_program = null;\n dispatch(node, running_program.b, 'start');\n if (css) {\n clear_animation();\n animation_name = create_rule(node, t, running_program.b, running_program.duration, 0, easing, config.css);\n }\n }\n if (running_program) {\n if (now >= running_program.end) {\n tick(t = running_program.b, 1 - t);\n dispatch(node, running_program.b, 'end');\n if (!pending_program) {\n // we're done\n if (running_program.b) {\n // intro — we can tidy up immediately\n clear_animation();\n }\n else {\n // outro — needs to be coordinated\n if (!--running_program.group.r)\n run_all(running_program.group.c);\n }\n }\n running_program = null;\n }\n else if (now >= running_program.start) {\n const p = now - running_program.start;\n t = running_program.a + running_program.d * easing(p / running_program.duration);\n tick(t, 1 - t);\n }\n }\n return !!(running_program || pending_program);\n });\n }\n }\n return {\n run(b) {\n if (is_function(config)) {\n wait().then(() => {\n // @ts-ignore\n config = config();\n go(b);\n });\n }\n else {\n go(b);\n }\n },\n end() {\n clear_animation();\n running_program = pending_program = null;\n }\n };\n}\n\nfunction handle_promise(promise, info) {\n const token = info.token = {};\n function update(type, index, key, value) {\n if (info.token !== token)\n return;\n info.resolved = value;\n let child_ctx = info.ctx;\n if (key !== undefined) {\n child_ctx = child_ctx.slice();\n child_ctx[key] = value;\n }\n const block = type && (info.current = type)(child_ctx);\n let needs_flush = false;\n if (info.block) {\n if (info.blocks) {\n info.blocks.forEach((block, i) => {\n if (i !== index && block) {\n group_outros();\n transition_out(block, 1, 1, () => {\n if (info.blocks[i] === block) {\n info.blocks[i] = null;\n }\n });\n check_outros();\n }\n });\n }\n else {\n info.block.d(1);\n }\n block.c();\n transition_in(block, 1);\n block.m(info.mount(), info.anchor);\n needs_flush = true;\n }\n info.block = block;\n if (info.blocks)\n info.blocks[index] = block;\n if (needs_flush) {\n flush();\n }\n }\n if (is_promise(promise)) {\n const current_component = get_current_component();\n promise.then(value => {\n set_current_component(current_component);\n update(info.then, 1, info.value, value);\n set_current_component(null);\n }, error => {\n set_current_component(current_component);\n update(info.catch, 2, info.error, error);\n set_current_component(null);\n if (!info.hasCatch) {\n throw error;\n }\n });\n // if we previously had a then/catch block, destroy it\n if (info.current !== info.pending) {\n update(info.pending, 0);\n return true;\n }\n }\n else {\n if (info.current !== info.then) {\n update(info.then, 1, info.value, promise);\n return true;\n }\n info.resolved = promise;\n }\n}\nfunction update_await_block_branch(info, ctx, dirty) {\n const child_ctx = ctx.slice();\n const { resolved } = info;\n if (info.current === info.then) {\n child_ctx[info.value] = resolved;\n }\n if (info.current === info.catch) {\n child_ctx[info.error] = resolved;\n }\n info.block.p(child_ctx, dirty);\n}\n\nconst globals = (typeof window !== 'undefined'\n ? window\n : typeof globalThis !== 'undefined'\n ? globalThis\n : global);\n\nfunction destroy_block(block, lookup) {\n block.d(1);\n lookup.delete(block.key);\n}\nfunction outro_and_destroy_block(block, lookup) {\n transition_out(block, 1, 1, () => {\n lookup.delete(block.key);\n });\n}\nfunction fix_and_destroy_block(block, lookup) {\n block.f();\n destroy_block(block, lookup);\n}\nfunction fix_and_outro_and_destroy_block(block, lookup) {\n block.f();\n outro_and_destroy_block(block, lookup);\n}\nfunction update_keyed_each(old_blocks, dirty, get_key, dynamic, ctx, list, lookup, node, destroy, create_each_block, next, get_context) {\n let o = old_blocks.length;\n let n = list.length;\n let i = o;\n const old_indexes = {};\n while (i--)\n old_indexes[old_blocks[i].key] = i;\n const new_blocks = [];\n const new_lookup = new Map();\n const deltas = new Map();\n i = n;\n while (i--) {\n const child_ctx = get_context(ctx, list, i);\n const key = get_key(child_ctx);\n let block = lookup.get(key);\n if (!block) {\n block = create_each_block(key, child_ctx);\n block.c();\n }\n else if (dynamic) {\n block.p(child_ctx, dirty);\n }\n new_lookup.set(key, new_blocks[i] = block);\n if (key in old_indexes)\n deltas.set(key, Math.abs(i - old_indexes[key]));\n }\n const will_move = new Set();\n const did_move = new Set();\n function insert(block) {\n transition_in(block, 1);\n block.m(node, next);\n lookup.set(block.key, block);\n next = block.first;\n n--;\n }\n while (o && n) {\n const new_block = new_blocks[n - 1];\n const old_block = old_blocks[o - 1];\n const new_key = new_block.key;\n const old_key = old_block.key;\n if (new_block === old_block) {\n // do nothing\n next = new_block.first;\n o--;\n n--;\n }\n else if (!new_lookup.has(old_key)) {\n // remove old block\n destroy(old_block, lookup);\n o--;\n }\n else if (!lookup.has(new_key) || will_move.has(new_key)) {\n insert(new_block);\n }\n else if (did_move.has(old_key)) {\n o--;\n }\n else if (deltas.get(new_key) > deltas.get(old_key)) {\n did_move.add(new_key);\n insert(new_block);\n }\n else {\n will_move.add(old_key);\n o--;\n }\n }\n while (o--) {\n const old_block = old_blocks[o];\n if (!new_lookup.has(old_block.key))\n destroy(old_block, lookup);\n }\n while (n)\n insert(new_blocks[n - 1]);\n return new_blocks;\n}\nfunction validate_each_keys(ctx, list, get_context, get_key) {\n const keys = new Set();\n for (let i = 0; i < list.length; i++) {\n const key = get_key(get_context(ctx, list, i));\n if (keys.has(key)) {\n throw new Error('Cannot have duplicate keys in a keyed each');\n }\n keys.add(key);\n }\n}\n\nfunction get_spread_update(levels, updates) {\n const update = {};\n const to_null_out = {};\n const accounted_for = { $$scope: 1 };\n let i = levels.length;\n while (i--) {\n const o = levels[i];\n const n = updates[i];\n if (n) {\n for (const key in o) {\n if (!(key in n))\n to_null_out[key] = 1;\n }\n for (const key in n) {\n if (!accounted_for[key]) {\n update[key] = n[key];\n accounted_for[key] = 1;\n }\n }\n levels[i] = n;\n }\n else {\n for (const key in o) {\n accounted_for[key] = 1;\n }\n }\n }\n for (const key in to_null_out) {\n if (!(key in update))\n update[key] = undefined;\n }\n return update;\n}\nfunction get_spread_object(spread_props) {\n return typeof spread_props === 'object' && spread_props !== null ? spread_props : {};\n}\n\n// source: https://html.spec.whatwg.org/multipage/indices.html\nconst boolean_attributes = new Set([\n 'allowfullscreen',\n 'allowpaymentrequest',\n 'async',\n 'autofocus',\n 'autoplay',\n 'checked',\n 'controls',\n 'default',\n 'defer',\n 'disabled',\n 'formnovalidate',\n 'hidden',\n 'ismap',\n 'loop',\n 'multiple',\n 'muted',\n 'nomodule',\n 'novalidate',\n 'open',\n 'playsinline',\n 'readonly',\n 'required',\n 'reversed',\n 'selected'\n]);\n\nconst invalid_attribute_name_character = /[\\s'\">/=\\u{FDD0}-\\u{FDEF}\\u{FFFE}\\u{FFFF}\\u{1FFFE}\\u{1FFFF}\\u{2FFFE}\\u{2FFFF}\\u{3FFFE}\\u{3FFFF}\\u{4FFFE}\\u{4FFFF}\\u{5FFFE}\\u{5FFFF}\\u{6FFFE}\\u{6FFFF}\\u{7FFFE}\\u{7FFFF}\\u{8FFFE}\\u{8FFFF}\\u{9FFFE}\\u{9FFFF}\\u{AFFFE}\\u{AFFFF}\\u{BFFFE}\\u{BFFFF}\\u{CFFFE}\\u{CFFFF}\\u{DFFFE}\\u{DFFFF}\\u{EFFFE}\\u{EFFFF}\\u{FFFFE}\\u{FFFFF}\\u{10FFFE}\\u{10FFFF}]/u;\n// https://html.spec.whatwg.org/multipage/syntax.html#attributes-2\n// https://infra.spec.whatwg.org/#noncharacter\nfunction spread(args, classes_to_add) {\n const attributes = Object.assign({}, ...args);\n if (classes_to_add) {\n if (attributes.class == null) {\n attributes.class = classes_to_add;\n }\n else {\n attributes.class += ' ' + classes_to_add;\n }\n }\n let str = '';\n Object.keys(attributes).forEach(name => {\n if (invalid_attribute_name_character.test(name))\n return;\n const value = attributes[name];\n if (value === true)\n str += ' ' + name;\n else if (boolean_attributes.has(name.toLowerCase())) {\n if (value)\n str += ' ' + name;\n }\n else if (value != null) {\n str += ` ${name}=\"${value}\"`;\n }\n });\n return str;\n}\nconst escaped = {\n '\"': '"',\n \"'\": ''',\n '&': '&',\n '<': '<',\n '>': '>'\n};\nfunction escape(html) {\n return String(html).replace(/[\"'&<>]/g, match => escaped[match]);\n}\nfunction escape_attribute_value(value) {\n return typeof value === 'string' ? escape(value) : value;\n}\nfunction escape_object(obj) {\n const result = {};\n for (const key in obj) {\n result[key] = escape_attribute_value(obj[key]);\n }\n return result;\n}\nfunction each(items, fn) {\n let str = '';\n for (let i = 0; i < items.length; i += 1) {\n str += fn(items[i], i);\n }\n return str;\n}\nconst missing_component = {\n $$render: () => ''\n};\nfunction validate_component(component, name) {\n if (!component || !component.$$render) {\n if (name === 'svelte:component')\n name += ' this={...}';\n throw new Error(`<${name}> is not a valid SSR component. You may need to review your build config to ensure that dependencies are compiled, rather than imported as pre-compiled modules`);\n }\n return component;\n}\nfunction debug(file, line, column, values) {\n console.log(`{@debug} ${file ? file + ' ' : ''}(${line}:${column})`); // eslint-disable-line no-console\n console.log(values); // eslint-disable-line no-console\n return '';\n}\nlet on_destroy;\nfunction create_ssr_component(fn) {\n function $$render(result, props, bindings, slots, context) {\n const parent_component = current_component;\n const $$ = {\n on_destroy,\n context: new Map(context || (parent_component ? parent_component.$$.context : [])),\n // these will be immediately discarded\n on_mount: [],\n before_update: [],\n after_update: [],\n callbacks: blank_object()\n };\n set_current_component({ $$ });\n const html = fn(result, props, bindings, slots);\n set_current_component(parent_component);\n return html;\n }\n return {\n render: (props = {}, { $$slots = {}, context = new Map() } = {}) => {\n on_destroy = [];\n const result = { title: '', head: '', css: new Set() };\n const html = $$render(result, props, {}, $$slots, context);\n run_all(on_destroy);\n return {\n html,\n css: {\n code: Array.from(result.css).map(css => css.code).join('\\n'),\n map: null // TODO\n },\n head: result.title + result.head\n };\n },\n $$render\n };\n}\nfunction add_attribute(name, value, boolean) {\n if (value == null || (boolean && !value))\n return '';\n return ` ${name}${value === true ? '' : `=${typeof value === 'string' ? JSON.stringify(escape(value)) : `\"${value}\"`}`}`;\n}\nfunction add_classes(classes) {\n return classes ? ` class=\"${classes}\"` : '';\n}\n\nfunction bind(component, name, callback) {\n const index = component.$$.props[name];\n if (index !== undefined) {\n component.$$.bound[index] = callback;\n callback(component.$$.ctx[index]);\n }\n}\nfunction create_component(block) {\n block && block.c();\n}\nfunction claim_component(block, parent_nodes) {\n block && block.l(parent_nodes);\n}\nfunction mount_component(component, target, anchor, customElement) {\n const { fragment, on_mount, on_destroy, after_update } = component.$$;\n fragment && fragment.m(target, anchor);\n if (!customElement) {\n // onMount happens before the initial afterUpdate\n add_render_callback(() => {\n const new_on_destroy = on_mount.map(run).filter(is_function);\n if (on_destroy) {\n on_destroy.push(...new_on_destroy);\n }\n else {\n // Edge case - component was destroyed immediately,\n // most likely as a result of a binding initialising\n run_all(new_on_destroy);\n }\n component.$$.on_mount = [];\n });\n }\n after_update.forEach(add_render_callback);\n}\nfunction destroy_component(component, detaching) {\n const $$ = component.$$;\n if ($$.fragment !== null) {\n run_all($$.on_destroy);\n $$.fragment && $$.fragment.d(detaching);\n // TODO null out other refs, including component.$$ (but need to\n // preserve final state?)\n $$.on_destroy = $$.fragment = null;\n $$.ctx = [];\n }\n}\nfunction make_dirty(component, i) {\n if (component.$$.dirty[0] === -1) {\n dirty_components.push(component);\n schedule_update();\n component.$$.dirty.fill(0);\n }\n component.$$.dirty[(i / 31) | 0] |= (1 << (i % 31));\n}\nfunction init(component, options, instance, create_fragment, not_equal, props, append_styles, dirty = [-1]) {\n const parent_component = current_component;\n set_current_component(component);\n const $$ = component.$$ = {\n fragment: null,\n ctx: null,\n // state\n props,\n update: noop,\n not_equal,\n bound: blank_object(),\n // lifecycle\n on_mount: [],\n on_destroy: [],\n on_disconnect: [],\n before_update: [],\n after_update: [],\n context: new Map(options.context || (parent_component ? parent_component.$$.context : [])),\n // everything else\n callbacks: blank_object(),\n dirty,\n skip_bound: false,\n root: options.target || parent_component.$$.root\n };\n append_styles && append_styles($$.root);\n let ready = false;\n $$.ctx = instance\n ? instance(component, options.props || {}, (i, ret, ...rest) => {\n const value = rest.length ? rest[0] : ret;\n if ($$.ctx && not_equal($$.ctx[i], $$.ctx[i] = value)) {\n if (!$$.skip_bound && $$.bound[i])\n $$.bound[i](value);\n if (ready)\n make_dirty(component, i);\n }\n return ret;\n })\n : [];\n $$.update();\n ready = true;\n run_all($$.before_update);\n // `false` as a special case of no DOM component\n $$.fragment = create_fragment ? create_fragment($$.ctx) : false;\n if (options.target) {\n if (options.hydrate) {\n start_hydrating();\n const nodes = children(options.target);\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n $$.fragment && $$.fragment.l(nodes);\n nodes.forEach(detach);\n }\n else {\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n $$.fragment && $$.fragment.c();\n }\n if (options.intro)\n transition_in(component.$$.fragment);\n mount_component(component, options.target, options.anchor, options.customElement);\n end_hydrating();\n flush();\n }\n set_current_component(parent_component);\n}\nlet SvelteElement;\nif (typeof HTMLElement === 'function') {\n SvelteElement = class extends HTMLElement {\n constructor() {\n super();\n this.attachShadow({ mode: 'open' });\n }\n connectedCallback() {\n const { on_mount } = this.$$;\n this.$$.on_disconnect = on_mount.map(run).filter(is_function);\n // @ts-ignore todo: improve typings\n for (const key in this.$$.slotted) {\n // @ts-ignore todo: improve typings\n this.appendChild(this.$$.slotted[key]);\n }\n }\n attributeChangedCallback(attr, _oldValue, newValue) {\n this[attr] = newValue;\n }\n disconnectedCallback() {\n run_all(this.$$.on_disconnect);\n }\n $destroy() {\n destroy_component(this, 1);\n this.$destroy = noop;\n }\n $on(type, callback) {\n // TODO should this delegate to addEventListener?\n const callbacks = (this.$$.callbacks[type] || (this.$$.callbacks[type] = []));\n callbacks.push(callback);\n return () => {\n const index = callbacks.indexOf(callback);\n if (index !== -1)\n callbacks.splice(index, 1);\n };\n }\n $set($$props) {\n if (this.$$set && !is_empty($$props)) {\n this.$$.skip_bound = true;\n this.$$set($$props);\n this.$$.skip_bound = false;\n }\n }\n };\n}\n/**\n * Base class for Svelte components. Used when dev=false.\n */\nclass SvelteComponent {\n $destroy() {\n destroy_component(this, 1);\n this.$destroy = noop;\n }\n $on(type, callback) {\n const callbacks = (this.$$.callbacks[type] || (this.$$.callbacks[type] = []));\n callbacks.push(callback);\n return () => {\n const index = callbacks.indexOf(callback);\n if (index !== -1)\n callbacks.splice(index, 1);\n };\n }\n $set($$props) {\n if (this.$$set && !is_empty($$props)) {\n this.$$.skip_bound = true;\n this.$$set($$props);\n this.$$.skip_bound = false;\n }\n }\n}\n\nfunction dispatch_dev(type, detail) {\n document.dispatchEvent(custom_event(type, Object.assign({ version: '3.44.0' }, detail), true));\n}\nfunction append_dev(target, node) {\n dispatch_dev('SvelteDOMInsert', { target, node });\n append(target, node);\n}\nfunction append_hydration_dev(target, node) {\n dispatch_dev('SvelteDOMInsert', { target, node });\n append_hydration(target, node);\n}\nfunction insert_dev(target, node, anchor) {\n dispatch_dev('SvelteDOMInsert', { target, node, anchor });\n insert(target, node, anchor);\n}\nfunction insert_hydration_dev(target, node, anchor) {\n dispatch_dev('SvelteDOMInsert', { target, node, anchor });\n insert_hydration(target, node, anchor);\n}\nfunction detach_dev(node) {\n dispatch_dev('SvelteDOMRemove', { node });\n detach(node);\n}\nfunction detach_between_dev(before, after) {\n while (before.nextSibling && before.nextSibling !== after) {\n detach_dev(before.nextSibling);\n }\n}\nfunction detach_before_dev(after) {\n while (after.previousSibling) {\n detach_dev(after.previousSibling);\n }\n}\nfunction detach_after_dev(before) {\n while (before.nextSibling) {\n detach_dev(before.nextSibling);\n }\n}\nfunction listen_dev(node, event, handler, options, has_prevent_default, has_stop_propagation) {\n const modifiers = options === true ? ['capture'] : options ? Array.from(Object.keys(options)) : [];\n if (has_prevent_default)\n modifiers.push('preventDefault');\n if (has_stop_propagation)\n modifiers.push('stopPropagation');\n dispatch_dev('SvelteDOMAddEventListener', { node, event, handler, modifiers });\n const dispose = listen(node, event, handler, options);\n return () => {\n dispatch_dev('SvelteDOMRemoveEventListener', { node, event, handler, modifiers });\n dispose();\n };\n}\nfunction attr_dev(node, attribute, value) {\n attr(node, attribute, value);\n if (value == null)\n dispatch_dev('SvelteDOMRemoveAttribute', { node, attribute });\n else\n dispatch_dev('SvelteDOMSetAttribute', { node, attribute, value });\n}\nfunction prop_dev(node, property, value) {\n node[property] = value;\n dispatch_dev('SvelteDOMSetProperty', { node, property, value });\n}\nfunction dataset_dev(node, property, value) {\n node.dataset[property] = value;\n dispatch_dev('SvelteDOMSetDataset', { node, property, value });\n}\nfunction set_data_dev(text, data) {\n data = '' + data;\n if (text.wholeText === data)\n return;\n dispatch_dev('SvelteDOMSetData', { node: text, data });\n text.data = data;\n}\nfunction validate_each_argument(arg) {\n if (typeof arg !== 'string' && !(arg && typeof arg === 'object' && 'length' in arg)) {\n let msg = '{#each} only iterates over array-like objects.';\n if (typeof Symbol === 'function' && arg && Symbol.iterator in arg) {\n msg += ' You can use a spread to convert this iterable into an array.';\n }\n throw new Error(msg);\n }\n}\nfunction validate_slots(name, slot, keys) {\n for (const slot_key of Object.keys(slot)) {\n if (!~keys.indexOf(slot_key)) {\n console.warn(`<${name}> received an unexpected slot \"${slot_key}\".`);\n }\n }\n}\n/**\n * Base class for Svelte components with some minor dev-enhancements. Used when dev=true.\n */\nclass SvelteComponentDev extends SvelteComponent {\n constructor(options) {\n if (!options || (!options.target && !options.$$inline)) {\n throw new Error(\"'target' is a required option\");\n }\n super();\n }\n $destroy() {\n super.$destroy();\n this.$destroy = () => {\n console.warn('Component was already destroyed'); // eslint-disable-line no-console\n };\n }\n $capture_state() { }\n $inject_state() { }\n}\n/**\n * Base class to create strongly typed Svelte components.\n * This only exists for typing purposes and should be used in `.d.ts` files.\n *\n * ### Example:\n *\n * You have component library on npm called `component-library`, from which\n * you export a component called `MyComponent`. For Svelte+TypeScript users,\n * you want to provide typings. Therefore you create a `index.d.ts`:\n * ```ts\n * import { SvelteComponentTyped } from \"svelte\";\n * export class MyComponent extends SvelteComponentTyped<{foo: string}> {}\n * ```\n * Typing this makes it possible for IDEs like VS Code with the Svelte extension\n * to provide intellisense and to use the component like this in a Svelte file\n * with TypeScript:\n * ```svelte\n * \n * \n * ```\n *\n * #### Why not make this part of `SvelteComponent(Dev)`?\n * Because\n * ```ts\n * class ASubclassOfSvelteComponent extends SvelteComponent<{foo: string}> {}\n * const component: typeof SvelteComponent = ASubclassOfSvelteComponent;\n * ```\n * will throw a type error, so we need to separate the more strictly typed class.\n */\nclass SvelteComponentTyped extends SvelteComponentDev {\n constructor(options) {\n super(options);\n }\n}\nfunction loop_guard(timeout) {\n const start = Date.now();\n return () => {\n if (Date.now() - start > timeout) {\n throw new Error('Infinite loop detected');\n }\n };\n}\n\nexport { HtmlTag, HtmlTagHydration, SvelteComponent, SvelteComponentDev, SvelteComponentTyped, SvelteElement, action_destroyer, add_attribute, add_classes, add_flush_callback, add_location, add_render_callback, add_resize_listener, add_transform, afterUpdate, append, append_dev, append_empty_stylesheet, append_hydration, append_hydration_dev, append_styles, assign, attr, attr_dev, attribute_to_object, beforeUpdate, bind, binding_callbacks, blank_object, bubble, check_outros, children, claim_component, claim_element, claim_html_tag, claim_space, claim_svg_element, claim_text, clear_loops, component_subscribe, compute_rest_props, compute_slots, createEventDispatcher, create_animation, create_bidirectional_transition, create_component, create_in_transition, create_out_transition, create_slot, create_ssr_component, current_component, custom_event, dataset_dev, debug, destroy_block, destroy_component, destroy_each, detach, detach_after_dev, detach_before_dev, detach_between_dev, detach_dev, dirty_components, dispatch_dev, each, element, element_is, empty, end_hydrating, escape, escape_attribute_value, escape_object, escaped, exclude_internal_props, fix_and_destroy_block, fix_and_outro_and_destroy_block, fix_position, flush, getAllContexts, getContext, get_all_dirty_from_scope, get_binding_group_value, get_current_component, get_custom_elements_slots, get_root_for_style, get_slot_changes, get_spread_object, get_spread_update, get_store_value, globals, group_outros, handle_promise, hasContext, has_prop, identity, init, insert, insert_dev, insert_hydration, insert_hydration_dev, intros, invalid_attribute_name_character, is_client, is_crossorigin, is_empty, is_function, is_promise, listen, listen_dev, loop, loop_guard, missing_component, mount_component, noop, not_equal, now, null_to_empty, object_without_properties, onDestroy, onMount, once, outro_and_destroy_block, prevent_default, prop_dev, query_selector_all, raf, run, run_all, safe_not_equal, schedule_update, select_multiple_value, select_option, select_options, select_value, self, setContext, set_attributes, set_current_component, set_custom_element_data, set_data, set_data_dev, set_input_type, set_input_value, set_now, set_raf, set_store_value, set_style, set_svg_attributes, space, spread, src_url_equal, start_hydrating, stop_propagation, subscribe, svg_element, text, tick, time_ranges_to_array, to_number, toggle_class, transition_in, transition_out, trusted, update_await_block_branch, update_keyed_each, update_slot, update_slot_base, validate_component, validate_each_argument, validate_each_keys, validate_slots, validate_store, xlink_attr };\n","\"use strict\";Object.defineProperty(exports,\"__esModule\",{value:!0});var t=function(t,e){(null==e||e>t.length)&&(e=t.length);for(var n=0,o=new Array(e);n=t.length?{done:!0}:{done:!1,value:t[o++]}},e:function(t){throw t},f:i}}throw new TypeError(\"Invalid attempt to iterate non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\")}var a,r=!0,s=!1;return{s:function(){n=t[Symbol.iterator]()},n:function(){var t=n.next();return r=t.done,t},e:function(t){s=!0,a=t},f:function(){try{r||null==n.return||n.return()}finally{if(s)throw a}}}}function l(t,e){(null==e||e>t.length)&&(e=t.length);for(var n=0,o=new Array(e);n1&&void 0!==arguments[1]?arguments[1]:null,a=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{},l=a.events,c=void 0===l?t.EVENTS:l,h=a.timeout,u=void 0===h?0:h,d=a.attributeFilter,p=void 0===d?void 0:d,m=a.onError,v=void 0===m?void 0:m;return this.clear(),new Promise((function(a,l){var h=r(e)?e:document.querySelector(e);h&&c.includes(t.EXIST)&&(i?i(h,t.EXIST):a({node:h,event:t.EXIST})),u>0&&(n._timeout=setTimeout((function(){n.clear();var t=new Error(\"[TIMEOUT]: Element \".concat(e,\" cannot be found after \").concat(u,\"ms\"));i?null==v||v(t):l(t)}),u)),n._observer=new MutationObserver((function(n){n.forEach((function(n){var l,h=n.type,u=n.target,d=n.addedNodes,p=n.removedNodes,m=n.attributeName,v=n.oldValue;if(\"childList\"===h&&(c.includes(t.ADD)||c.includes(t.REMOVE))){var y,f=s([].concat(o(c.includes(t.ADD)?Array.from(d):[]),o(c.includes(t.REMOVE)?Array.from(p):[])));try{for(f.s();!(y=f.n()).done;){var b,g=y.value;(g===e||!r(e)&&null!==(b=g.matches)&&void 0!==b&&b.call(g,e))&&(i?i(g,Array.from(d).includes(g)?t.ADD:t.REMOVE):a({node:g,event:Array.from(d).includes(g)?t.ADD:t.REMOVE}))}}catch(t){f.e(t)}finally{f.f()}}\"attributes\"===h&&c.includes(t.CHANGE)&&(u===e||!r(e)&&null!==(l=u.matches)&&void 0!==l&&l.call(u,e))&&(i?i(u,t.CHANGE,{attributeName:m,oldValue:v}):a({node:u,event:t.CHANGE,options:{attributeName:m,oldValue:v}}))}))})),n._observer.observe(document.documentElement,{subtree:!0,childList:c.includes(t.ADD)||c.includes(t.REMOVE),attributes:c.includes(t.CHANGE),attributeOldValue:c.includes(t.CHANGE),attributeFilter:p})}))}},{key:\"clear\",value:function(){var t;null===(t=this._observer)||void 0===t||t.disconnect(),clearTimeout(this._timeout)}}]),t}();a(c,\"EXIST\",\"DOMObserver_exist\"),a(c,\"ADD\",\"DOMObserver_add\"),a(c,\"REMOVE\",\"DOMObserver_remove\"),a(c,\"CHANGE\",\"DOMObserver_change\"),a(c,\"EVENTS\",[c.EXIST,c.ADD,c.REMOVE,c.CHANGE]);class h{static get GAP(){return 10}static#t=[];#e=null;#n=[];#o=0;#i=0;#a=null;#r=null;#s=null;#l=null;#c=null;#h=null;#u=null;#d=null;#p=!1;#m=null;#v=null;#y=!1;#f=null;#b=null;static destroy(){h.#t.forEach((t=>{t.destroy()})),h.#t=[]}constructor(t,e,n,o,i,a,r,s,l,u,d,p,m){this.#c=t,this.#h=e,this.#u=n,this.#p=o||!1,this.#d=i,this.#m=a,this.#v=r||\"top\",this.#y=s||!1,this.#f=l||\"__tooltip-enter\",this.#b=u||\"__tooltip-leave\",this.#o=d||0,this.#i=p||0,this.#e=new c,this.#c.title=\"\",this.#c.setAttribute(\"style\",\"position: relative\"),this.#g(),this.#r.classList.add(this.#m||\"__tooltip\",`__tooltip-${this.#v}`),m?this.#E():this.#T(),h.#t.push(this)}update(t,e,n,o,i,a,r,s,l,c,h,u){const d=e!==this.#u||t!==this.#h,p=i!==this.#m,m=this.#v,v=a!==this.#v,y=u&&this.#s,f=!u&&!this.#s;this.#h=t,this.#u=e,this.#p=n||!1,this.#d=o,this.#m=i,this.#v=a||\"top\",this.#y=r||!1,this.#f=s||\"__tooltip-enter\",this.#b=l||\"__tooltip-leave\",this.#o=c||0,this.#i=h||0,d&&(this.#C(),this.#g()),(p||d)&&this.#r.classList.add(this.#m||\"__tooltip\"),(v||p||d)&&(this.#r.classList.remove(`__tooltip-${m}`),this.#r.classList.add(`__tooltip-${this.#v}`)),y?this.#E():f&&this.#T()}destroy(){var t;this.#C(),this.#E(),this.#A(),null===(t=this.#e)||void 0===t||t.clear(),this.#e=null}#T(){this.#s=this.#_.bind(this),this.#l=this.#D.bind(this),this.#c.addEventListener(\"mouseenter\",this.#s),this.#c.addEventListener(\"mouseleave\",this.#l)}#E(){this.#c.removeEventListener(\"mouseenter\",this.#s),this.#c.removeEventListener(\"mouseleave\",this.#l),this.#s=null,this.#l=null}#g(){if(this.#r=document.createElement(\"div\"),this.#u)this.#e.wait(this.#u,null,{events:[c.EXIST,c.ADD]}).then((({node:t})=>{const e=this.#p?t.cloneNode(!0):t;this.#r.appendChild(e)}));else if(this.#h){const t=document.createTextNode(this.#h);this.#r.appendChild(t)}}#N(){const{width:t,height:e}=this.#c.getBoundingClientRect(),{width:n,height:o}=this.#r.getBoundingClientRect();switch(this.#v){case\"left\":this.#r.style.top=(-(o-e)>>1)+\"px\",this.#r.style.left=-n-h.GAP+\"px\",this.#r.style.bottom=null,this.#r.style.right=null;break;case\"right\":this.#r.style.top=(-(o-e)>>1)+\"px\",this.#r.style.right=-n-h.GAP+\"px\",this.#r.style.bottom=null,this.#r.style.left=null;break;case\"bottom\":this.#r.style.left=(-(n-t)>>1)+\"px\",this.#r.style.bottom=-o-h.GAP+\"px\",this.#r.style.right=null,this.#r.style.top=null;break;default:this.#r.style.left=(-(n-t)>>1)+\"px\",this.#r.style.top=-o-h.GAP+\"px\",this.#r.style.right=null,this.#r.style.bottom=null}}async#w(){this.#y&&await this.#S(1),this.#c.appendChild(this.#r),this.#e.wait(this.#r,null,{events:[c.EXIST,c.ADD]}).then((()=>{this.#N()})),this.#d&&Object.entries(this.#d).forEach((([t,{eventType:e,callback:n,callbackParams:o,closeOnCallback:i}])=>{const a=\"*\"===t?this.#r:this.#r.querySelector(t);if(a){const t=t=>{null==n||n.apply(null,[...o,t]),i&&this.#C()};a.addEventListener(e,t),this.#n.push({trigger:a,eventType:e,listener:t})}}))}async#C(){this.#y&&await this.#S(0),this.#r.remove(),this.#n.forEach((({trigger:t,eventType:e,listener:n})=>t.removeEventListener(e,n))),this.#n=[]}#L(t){return this.#A(),new Promise((e=>this.#a=setTimeout((()=>{this.#A(),e()}),t)))}#A(){clearTimeout(this.#a),this.#a=null}#S(t){return new Promise((e=>{let n,o;if(1===t)n=this.#f,o=this.#b;else n=this.#b,o=this.#f;this.#r.classList.add(n),this.#r.classList.remove(o),1===t&&e();const i=()=>{this.#r.removeEventListener(\"animationend\",i),this.#r.classList.remove(n),e()};this.#r.addEventListener(\"animationend\",i)}))}async#_(){await this.#L(this.#o),await this.#w()}async#D(){await this.#L(this.#i),await this.#C()}}!function(t,e){void 0===e&&(e={});var n=e.insertAt;if(t&&\"undefined\"!=typeof document){var o=document.head||document.getElementsByTagName(\"head\")[0],i=document.createElement(\"style\");i.type=\"text/css\",\"top\"===n&&o.firstChild?o.insertBefore(i,o.firstChild):o.appendChild(i),i.styleSheet?i.styleSheet.cssText=t:i.appendChild(document.createTextNode(t))}}(\".__tooltip {\\n\\tposition: absolute;\\n\\tz-index: 9999;\\n\\tmax-width: 100%;\\n\\tbackground-color: black;\\n\\tcolor: white;\\n\\ttext-align: center;\\n\\tborder-radius: 6px;\\n\\tpadding: 0.5rem;\\n}\\n\\n.__tooltip::after {\\n\\tcontent: '';\\n\\tposition: absolute;\\n\\tmargin-left: -5px;\\n\\tborder-width: 5px;\\n\\tborder-style: solid;\\n}\\n\\n.__tooltip-top::after {\\n\\tbottom: -10px;\\n\\tleft: 50%;\\n\\tborder-color: black transparent transparent transparent;\\n}\\n\\n.__tooltip-bottom::after {\\n\\ttop: -10px;\\n\\tleft: 50%;\\n\\tborder-color: transparent transparent black transparent;\\n}\\n\\n.__tooltip-left::after {\\n\\ttop: calc(50% - 5px);\\n\\tright: -10px;\\n\\tborder-color: transparent transparent transparent black;\\n}\\n\\n.__tooltip-right::after {\\n\\ttop: calc(50% - 5px);\\n\\tleft: -5px;\\n\\tborder-color: transparent black transparent transparent;\\n}\\n\\n.__tooltip-enter {\\n\\tanimation: fadeIn 0.2s linear forwards;\\n}\\n\\n.__tooltip-leave {\\n\\tanimation: fadeOut 0.2s linear forwards;\\n}\\n\\n@keyframes fadeIn {\\n\\tfrom {\\n\\t\\topacity: 0;\\n\\t}\\n\\tto {\\n\\t\\topacity: 1;\\n\\t}\\n}\\n@keyframes fadeOut {\\n\\tfrom {\\n\\t\\topacity: 1;\\n\\t}\\n\\tto {\\n\\t\\topacity: 0;\\n\\t}\\n}\\n\");exports.useTooltip=(t,{content:e,contentSelector:n,contentClone:o,contentActions:i,containerClassName:a,position:r,animated:s,animationEnterClassName:l,animationLeaveClassName:c,enterDelay:u,leaveDelay:d,disabled:p})=>{const m=new h(t,e,n,o,i,a,r,s,l,c,u,d,p);return{update:({content:t,contentSelector:e,contentClone:n,contentActions:o,containerClassName:i,position:a,animated:r,animationEnterClassName:s,animationLeaveClassName:l,enterDelay:c,leaveDelay:h,disabled:u})=>m.update(t,e,n,o,i,a,r,s,l,c,h,u),destroy:()=>m.destroy()}};\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VzIjpbIi4uL25vZGVfbW9kdWxlcy9AdW50ZW1wcy9kb20tb2JzZXJ2ZXIvZGlzdC9pbmRleC5lcy5qcyIsIi4uL3NyYy9Ub29sdGlwLmpzIiwiLi4vbm9kZV9tb2R1bGVzL3N0eWxlLWluamVjdC9kaXN0L3N0eWxlLWluamVjdC5lcy5qcyIsIi4uL3NyYy91c2VUb29sdGlwLmpzIl0sInNvdXJjZXNDb250ZW50IjpbInZhciBlPWZ1bmN0aW9uKGUscil7KG51bGw9PXJ8fHI+ZS5sZW5ndGgpJiYocj1lLmxlbmd0aCk7Zm9yKHZhciB0PTAsbj1uZXcgQXJyYXkocik7dDxyO3QrKyluW3RdPWVbdF07cmV0dXJuIG59O3ZhciByPWZ1bmN0aW9uKHIpe2lmKEFycmF5LmlzQXJyYXkocikpcmV0dXJuIGUocil9O3ZhciB0PWZ1bmN0aW9uKGUpe2lmKFwidW5kZWZpbmVkXCIhPXR5cGVvZiBTeW1ib2wmJlN5bWJvbC5pdGVyYXRvciBpbiBPYmplY3QoZSkpcmV0dXJuIEFycmF5LmZyb20oZSl9O3ZhciBuPWZ1bmN0aW9uKHIsdCl7aWYocil7aWYoXCJzdHJpbmdcIj09dHlwZW9mIHIpcmV0dXJuIGUocix0KTt2YXIgbj1PYmplY3QucHJvdG90eXBlLnRvU3RyaW5nLmNhbGwocikuc2xpY2UoOCwtMSk7cmV0dXJuXCJPYmplY3RcIj09PW4mJnIuY29uc3RydWN0b3ImJihuPXIuY29uc3RydWN0b3IubmFtZSksXCJNYXBcIj09PW58fFwiU2V0XCI9PT1uP0FycmF5LmZyb20ocik6XCJBcmd1bWVudHNcIj09PW58fC9eKD86VWl8SSludCg/Ojh8MTZ8MzIpKD86Q2xhbXBlZCk/QXJyYXkkLy50ZXN0KG4pP2Uocix0KTp2b2lkIDB9fTt2YXIgbz1mdW5jdGlvbigpe3Rocm93IG5ldyBUeXBlRXJyb3IoXCJJbnZhbGlkIGF0dGVtcHQgdG8gc3ByZWFkIG5vbi1pdGVyYWJsZSBpbnN0YW5jZS5cXG5JbiBvcmRlciB0byBiZSBpdGVyYWJsZSwgbm9uLWFycmF5IG9iamVjdHMgbXVzdCBoYXZlIGEgW1N5bWJvbC5pdGVyYXRvcl0oKSBtZXRob2QuXCIpfTt2YXIgaT1mdW5jdGlvbihlKXtyZXR1cm4gcihlKXx8dChlKXx8bihlKXx8bygpfTt2YXIgYT1mdW5jdGlvbihlLHIpe2lmKCEoZSBpbnN0YW5jZW9mIHIpKXRocm93IG5ldyBUeXBlRXJyb3IoXCJDYW5ub3QgY2FsbCBhIGNsYXNzIGFzIGEgZnVuY3Rpb25cIil9O2Z1bmN0aW9uIHUoZSxyKXtmb3IodmFyIHQ9MDt0PHIubGVuZ3RoO3QrKyl7dmFyIG49clt0XTtuLmVudW1lcmFibGU9bi5lbnVtZXJhYmxlfHwhMSxuLmNvbmZpZ3VyYWJsZT0hMCxcInZhbHVlXCJpbiBuJiYobi53cml0YWJsZT0hMCksT2JqZWN0LmRlZmluZVByb3BlcnR5KGUsbi5rZXksbil9fXZhciBsPWZ1bmN0aW9uKGUscix0KXtyZXR1cm4gciYmdShlLnByb3RvdHlwZSxyKSx0JiZ1KGUsdCksZX07dmFyIGM9ZnVuY3Rpb24oZSxyLHQpe3JldHVybiByIGluIGU/T2JqZWN0LmRlZmluZVByb3BlcnR5KGUscix7dmFsdWU6dCxlbnVtZXJhYmxlOiEwLGNvbmZpZ3VyYWJsZTohMCx3cml0YWJsZTohMH0pOmVbcl09dCxlfSxmPWZ1bmN0aW9uKGUpe3JldHVybiAxPT09KG51bGw9PWU/dm9pZCAwOmUubm9kZVR5cGUpfTtmdW5jdGlvbiBzKGUscil7dmFyIHQ7aWYoXCJ1bmRlZmluZWRcIj09dHlwZW9mIFN5bWJvbHx8bnVsbD09ZVtTeW1ib2wuaXRlcmF0b3JdKXtpZihBcnJheS5pc0FycmF5KGUpfHwodD1mdW5jdGlvbihlLHIpe2lmKCFlKXJldHVybjtpZihcInN0cmluZ1wiPT10eXBlb2YgZSlyZXR1cm4gZChlLHIpO3ZhciB0PU9iamVjdC5wcm90b3R5cGUudG9TdHJpbmcuY2FsbChlKS5zbGljZSg4LC0xKTtcIk9iamVjdFwiPT09dCYmZS5jb25zdHJ1Y3RvciYmKHQ9ZS5jb25zdHJ1Y3Rvci5uYW1lKTtpZihcIk1hcFwiPT09dHx8XCJTZXRcIj09PXQpcmV0dXJuIEFycmF5LmZyb20oZSk7aWYoXCJBcmd1bWVudHNcIj09PXR8fC9eKD86VWl8SSludCg/Ojh8MTZ8MzIpKD86Q2xhbXBlZCk/QXJyYXkkLy50ZXN0KHQpKXJldHVybiBkKGUscil9KGUpKXx8ciYmZSYmXCJudW1iZXJcIj09dHlwZW9mIGUubGVuZ3RoKXt0JiYoZT10KTt2YXIgbj0wLG89ZnVuY3Rpb24oKXt9O3JldHVybntzOm8sbjpmdW5jdGlvbigpe3JldHVybiBuPj1lLmxlbmd0aD97ZG9uZTohMH06e2RvbmU6ITEsdmFsdWU6ZVtuKytdfX0sZTpmdW5jdGlvbihlKXt0aHJvdyBlfSxmOm99fXRocm93IG5ldyBUeXBlRXJyb3IoXCJJbnZhbGlkIGF0dGVtcHQgdG8gaXRlcmF0ZSBub24taXRlcmFibGUgaW5zdGFuY2UuXFxuSW4gb3JkZXIgdG8gYmUgaXRlcmFibGUsIG5vbi1hcnJheSBvYmplY3RzIG11c3QgaGF2ZSBhIFtTeW1ib2wuaXRlcmF0b3JdKCkgbWV0aG9kLlwiKX12YXIgaSxhPSEwLHU9ITE7cmV0dXJue3M6ZnVuY3Rpb24oKXt0PWVbU3ltYm9sLml0ZXJhdG9yXSgpfSxuOmZ1bmN0aW9uKCl7dmFyIGU9dC5uZXh0KCk7cmV0dXJuIGE9ZS5kb25lLGV9LGU6ZnVuY3Rpb24oZSl7dT0hMCxpPWV9LGY6ZnVuY3Rpb24oKXt0cnl7YXx8bnVsbD09dC5yZXR1cm58fHQucmV0dXJuKCl9ZmluYWxseXtpZih1KXRocm93IGl9fX19ZnVuY3Rpb24gZChlLHIpeyhudWxsPT1yfHxyPmUubGVuZ3RoKSYmKHI9ZS5sZW5ndGgpO2Zvcih2YXIgdD0wLG49bmV3IEFycmF5KHIpO3Q8cjt0Kyspblt0XT1lW3RdO3JldHVybiBufXZhciB2PWZ1bmN0aW9uKCl7ZnVuY3Rpb24gZSgpe2EodGhpcyxlKSxjKHRoaXMsXCJfb2JzZXJ2ZXJcIixudWxsKX1yZXR1cm4gbChlLFt7a2V5Olwid2FpdFwiLHZhbHVlOmZ1bmN0aW9uKHIpe3ZhciB0PXRoaXMsbj1hcmd1bWVudHMubGVuZ3RoPjEmJnZvaWQgMCE9PWFyZ3VtZW50c1sxXT9hcmd1bWVudHNbMV06bnVsbCxvPWFyZ3VtZW50cy5sZW5ndGg+MiYmdm9pZCAwIT09YXJndW1lbnRzWzJdP2FyZ3VtZW50c1syXTp7fSxhPW8uZXZlbnRzLHU9dm9pZCAwPT09YT9lLkVWRU5UUzphLGw9by50aW1lb3V0LGM9dm9pZCAwPT09bD8wOmwsZD1vLmF0dHJpYnV0ZUZpbHRlcix2PXZvaWQgMD09PWQ/dm9pZCAwOmQsYj1vLm9uRXJyb3IsbT12b2lkIDA9PT1iP3ZvaWQgMDpiO3JldHVybiB0aGlzLmNsZWFyKCksbmV3IFByb21pc2UoKGZ1bmN0aW9uKG8sYSl7dmFyIGw9ZihyKT9yOmRvY3VtZW50LnF1ZXJ5U2VsZWN0b3Iocik7bCYmdS5pbmNsdWRlcyhlLkVYSVNUKSYmKG4/bihsLGUuRVhJU1QpOm8oe25vZGU6bCxldmVudDplLkVYSVNUfSkpLGM+MCYmKHQuX3RpbWVvdXQ9c2V0VGltZW91dCgoZnVuY3Rpb24oKXt0LmNsZWFyKCk7dmFyIGU9bmV3IEVycm9yKFwiW1RJTUVPVVRdOiBFbGVtZW50IFwiLmNvbmNhdChyLFwiIGNhbm5vdCBiZSBmb3VuZCBhZnRlciBcIikuY29uY2F0KGMsXCJtc1wiKSk7bj9udWxsPT1tfHxtKGUpOmEoZSl9KSxjKSksdC5fb2JzZXJ2ZXI9bmV3IE11dGF0aW9uT2JzZXJ2ZXIoKGZ1bmN0aW9uKHQpe3QuZm9yRWFjaCgoZnVuY3Rpb24odCl7dmFyIGEsbD10LnR5cGUsYz10LnRhcmdldCxkPXQuYWRkZWROb2Rlcyx2PXQucmVtb3ZlZE5vZGVzLGI9dC5hdHRyaWJ1dGVOYW1lLG09dC5vbGRWYWx1ZTtpZihcImNoaWxkTGlzdFwiPT09bCYmKHUuaW5jbHVkZXMoZS5BREQpfHx1LmluY2x1ZGVzKGUuUkVNT1ZFKSkpe3ZhciB5LEU9cyhbXS5jb25jYXQoaSh1LmluY2x1ZGVzKGUuQUREKT9BcnJheS5mcm9tKGQpOltdKSxpKHUuaW5jbHVkZXMoZS5SRU1PVkUpP0FycmF5LmZyb20odik6W10pKSk7dHJ5e2ZvcihFLnMoKTshKHk9RS5uKCkpLmRvbmU7KXt2YXIgaCxBPXkudmFsdWU7KEE9PT1yfHwhZihyKSYmbnVsbCE9PShoPUEubWF0Y2hlcykmJnZvaWQgMCE9PWgmJmguY2FsbChBLHIpKSYmKG4/bihBLEFycmF5LmZyb20oZCkuaW5jbHVkZXMoQSk/ZS5BREQ6ZS5SRU1PVkUpOm8oe25vZGU6QSxldmVudDpBcnJheS5mcm9tKGQpLmluY2x1ZGVzKEEpP2UuQUREOmUuUkVNT1ZFfSkpfX1jYXRjaChlKXtFLmUoZSl9ZmluYWxseXtFLmYoKX19XCJhdHRyaWJ1dGVzXCI9PT1sJiZ1LmluY2x1ZGVzKGUuQ0hBTkdFKSYmKChjPT09cnx8IWYocikmJm51bGwhPT0oYT1jLm1hdGNoZXMpJiZ2b2lkIDAhPT1hJiZhLmNhbGwoYyxyKSkmJihuP24oYyxlLkNIQU5HRSx7YXR0cmlidXRlTmFtZTpiLG9sZFZhbHVlOm19KTpvKHtub2RlOmMsZXZlbnQ6ZS5DSEFOR0Usb3B0aW9uczp7YXR0cmlidXRlTmFtZTpiLG9sZFZhbHVlOm19fSkpKX0pKX0pKSx0Ll9vYnNlcnZlci5vYnNlcnZlKGRvY3VtZW50LmRvY3VtZW50RWxlbWVudCx7c3VidHJlZTohMCxjaGlsZExpc3Q6dS5pbmNsdWRlcyhlLkFERCl8fHUuaW5jbHVkZXMoZS5SRU1PVkUpLGF0dHJpYnV0ZXM6dS5pbmNsdWRlcyhlLkNIQU5HRSksYXR0cmlidXRlT2xkVmFsdWU6dS5pbmNsdWRlcyhlLkNIQU5HRSksYXR0cmlidXRlRmlsdGVyOnZ9KX0pKX19LHtrZXk6XCJjbGVhclwiLHZhbHVlOmZ1bmN0aW9uKCl7dmFyIGU7bnVsbD09PShlPXRoaXMuX29ic2VydmVyKXx8dm9pZCAwPT09ZXx8ZS5kaXNjb25uZWN0KCksY2xlYXJUaW1lb3V0KHRoaXMuX3RpbWVvdXQpfX1dKSxlfSgpO2ModixcIkVYSVNUXCIsXCJET01PYnNlcnZlcl9leGlzdFwiKSxjKHYsXCJBRERcIixcIkRPTU9ic2VydmVyX2FkZFwiKSxjKHYsXCJSRU1PVkVcIixcIkRPTU9ic2VydmVyX3JlbW92ZVwiKSxjKHYsXCJDSEFOR0VcIixcIkRPTU9ic2VydmVyX2NoYW5nZVwiKSxjKHYsXCJFVkVOVFNcIixbdi5FWElTVCx2LkFERCx2LlJFTU9WRSx2LkNIQU5HRV0pO2V4cG9ydHt2IGFzIERPTU9ic2VydmVyfTtcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPWRhdGE6YXBwbGljYXRpb24vanNvbjtjaGFyc2V0PXV0Zi04O2Jhc2U2NCxleUoyWlhKemFXOXVJam96TENKbWFXeGxJam9pYVc1a1pYZ3VaWE11YW5NaUxDSnpiM1Z5WTJWeklqcGJJaTR1TDI1dlpHVmZiVzlrZFd4bGN5OUFZbUZpWld3dmNuVnVkR2x0WlM5b1pXeHdaWEp6TDJGeWNtRjVUR2xyWlZSdlFYSnlZWGt1YW5NaUxDSXVMaTl1YjJSbFgyMXZaSFZzWlhNdlFHSmhZbVZzTDNKMWJuUnBiV1V2YUdWc2NHVnljeTloY25KaGVWZHBkR2h2ZFhSSWIyeGxjeTVxY3lJc0lpNHVMMjV2WkdWZmJXOWtkV3hsY3k5QVltRmlaV3d2Y25WdWRHbHRaUzlvWld4d1pYSnpMMmwwWlhKaFlteGxWRzlCY25KaGVTNXFjeUlzSWk0dUwyNXZaR1ZmYlc5a2RXeGxjeTlBWW1GaVpXd3ZjblZ1ZEdsdFpTOW9aV3h3WlhKekwzVnVjM1Z3Y0c5eWRHVmtTWFJsY21GaWJHVlViMEZ5Y21GNUxtcHpJaXdpTGk0dmJtOWtaVjl0YjJSMWJHVnpMMEJpWVdKbGJDOXlkVzUwYVcxbEwyaGxiSEJsY25NdmJtOXVTWFJsY21GaWJHVlRjSEpsWVdRdWFuTWlMQ0l1TGk5dWIyUmxYMjF2WkhWc1pYTXZRR0poWW1Wc0wzSjFiblJwYldVdmFHVnNjR1Z5Y3k5MGIwTnZibk4xYldGaWJHVkJjbkpoZVM1cWN5SXNJaTR1TDI1dlpHVmZiVzlrZFd4bGN5OUFZbUZpWld3dmNuVnVkR2x0WlM5b1pXeHdaWEp6TDJOc1lYTnpRMkZzYkVOb1pXTnJMbXB6SWl3aUxpNHZibTlrWlY5dGIyUjFiR1Z6TDBCaVlXSmxiQzl5ZFc1MGFXMWxMMmhsYkhCbGNuTXZZM0psWVhSbFEyeGhjM011YW5NaUxDSXVMaTl1YjJSbFgyMXZaSFZzWlhNdlFHSmhZbVZzTDNKMWJuUnBiV1V2YUdWc2NHVnljeTlrWldacGJtVlFjbTl3WlhKMGVTNXFjeUlzSWk0dUwzTnlZeTkxZEdsc2N5OXBjMFZzWlcxbGJuUXVhbk1pTENJdUxpOXpjbU12UkU5TlQySnpaWEoyWlhJdWFuTWlYU3dpYzI5MWNtTmxjME52Ym5SbGJuUWlPbHNpWm5WdVkzUnBiMjRnWDJGeWNtRjVUR2xyWlZSdlFYSnlZWGtvWVhKeUxDQnNaVzRwSUh0Y2JpQWdhV1lnS0d4bGJpQTlQU0J1ZFd4c0lIeDhJR3hsYmlBK0lHRnljaTVzWlc1bmRHZ3BJR3hsYmlBOUlHRnljaTVzWlc1bmRHZzdYRzVjYmlBZ1ptOXlJQ2gyWVhJZ2FTQTlJREFzSUdGeWNqSWdQU0J1WlhjZ1FYSnlZWGtvYkdWdUtUc2dhU0E4SUd4bGJqc2dhU3NyS1NCN1hHNGdJQ0FnWVhKeU1sdHBYU0E5SUdGeWNsdHBYVHRjYmlBZ2ZWeHVYRzRnSUhKbGRIVnliaUJoY25JeU8xeHVmVnh1WEc1dGIyUjFiR1V1Wlhod2IzSjBjeUE5SUY5aGNuSmhlVXhwYTJWVWIwRnljbUY1T3lJc0luWmhjaUJoY25KaGVVeHBhMlZVYjBGeWNtRjVJRDBnY21WeGRXbHlaU2hjSWk0dllYSnlZWGxNYVd0bFZHOUJjbkpoZVZ3aUtUdGNibHh1Wm5WdVkzUnBiMjRnWDJGeWNtRjVWMmwwYUc5MWRFaHZiR1Z6S0dGeWNpa2dlMXh1SUNCcFppQW9RWEp5WVhrdWFYTkJjbkpoZVNoaGNuSXBLU0J5WlhSMWNtNGdZWEp5WVhsTWFXdGxWRzlCY25KaGVTaGhjbklwTzF4dWZWeHVYRzV0YjJSMWJHVXVaWGh3YjNKMGN5QTlJRjloY25KaGVWZHBkR2h2ZFhSSWIyeGxjenNpTENKbWRXNWpkR2x2YmlCZmFYUmxjbUZpYkdWVWIwRnljbUY1S0dsMFpYSXBJSHRjYmlBZ2FXWWdLSFI1Y0dWdlppQlRlVzFpYjJ3Z0lUMDlJRndpZFc1a1pXWnBibVZrWENJZ0ppWWdVM2x0WW05c0xtbDBaWEpoZEc5eUlHbHVJRTlpYW1WamRDaHBkR1Z5S1NrZ2NtVjBkWEp1SUVGeWNtRjVMbVp5YjIwb2FYUmxjaWs3WEc1OVhHNWNibTF2WkhWc1pTNWxlSEJ2Y25SeklEMGdYMmwwWlhKaFlteGxWRzlCY25KaGVUc2lMQ0oyWVhJZ1lYSnlZWGxNYVd0bFZHOUJjbkpoZVNBOUlISmxjWFZwY21Vb1hDSXVMMkZ5Y21GNVRHbHJaVlJ2UVhKeVlYbGNJaWs3WEc1Y2JtWjFibU4wYVc5dUlGOTFibk4xY0hCdmNuUmxaRWwwWlhKaFlteGxWRzlCY25KaGVTaHZMQ0J0YVc1TVpXNHBJSHRjYmlBZ2FXWWdLQ0Z2S1NCeVpYUjFjbTQ3WEc0Z0lHbG1JQ2gwZVhCbGIyWWdieUE5UFQwZ1hDSnpkSEpwYm1kY0lpa2djbVYwZFhKdUlHRnljbUY1VEdsclpWUnZRWEp5WVhrb2J5d2diV2x1VEdWdUtUdGNiaUFnZG1GeUlHNGdQU0JQWW1wbFkzUXVjSEp2ZEc5MGVYQmxMblJ2VTNSeWFXNW5MbU5oYkd3b2J5a3VjMnhwWTJVb09Dd2dMVEVwTzF4dUlDQnBaaUFvYmlBOVBUMGdYQ0pQWW1wbFkzUmNJaUFtSmlCdkxtTnZibk4wY25WamRHOXlLU0J1SUQwZ2J5NWpiMjV6ZEhKMVkzUnZjaTV1WVcxbE8xeHVJQ0JwWmlBb2JpQTlQVDBnWENKTllYQmNJaUI4ZkNCdUlEMDlQU0JjSWxObGRGd2lLU0J5WlhSMWNtNGdRWEp5WVhrdVpuSnZiU2h2S1R0Y2JpQWdhV1lnS0c0Z1BUMDlJRndpUVhKbmRXMWxiblJ6WENJZ2ZId2dMMTRvUHpwVmFYeEpLVzUwS0Q4Nk9Id3hObnd6TWlrb1B6cERiR0Z0Y0dWa0tUOUJjbkpoZVNRdkxuUmxjM1FvYmlrcElISmxkSFZ5YmlCaGNuSmhlVXhwYTJWVWIwRnljbUY1S0c4c0lHMXBia3hsYmlrN1hHNTlYRzVjYm0xdlpIVnNaUzVsZUhCdmNuUnpJRDBnWDNWdWMzVndjRzl5ZEdWa1NYUmxjbUZpYkdWVWIwRnljbUY1T3lJc0ltWjFibU4wYVc5dUlGOXViMjVKZEdWeVlXSnNaVk53Y21WaFpDZ3BJSHRjYmlBZ2RHaHliM2NnYm1WM0lGUjVjR1ZGY25KdmNpaGNJa2x1ZG1Gc2FXUWdZWFIwWlcxd2RDQjBieUJ6Y0hKbFlXUWdibTl1TFdsMFpYSmhZbXhsSUdsdWMzUmhibU5sTGx4Y2JrbHVJRzl5WkdWeUlIUnZJR0psSUdsMFpYSmhZbXhsTENCdWIyNHRZWEp5WVhrZ2IySnFaV04wY3lCdGRYTjBJR2hoZG1VZ1lTQmJVM2x0WW05c0xtbDBaWEpoZEc5eVhTZ3BJRzFsZEdodlpDNWNJaWs3WEc1OVhHNWNibTF2WkhWc1pTNWxlSEJ2Y25SeklEMGdYMjV2YmtsMFpYSmhZbXhsVTNCeVpXRmtPeUlzSW5aaGNpQmhjbkpoZVZkcGRHaHZkWFJJYjJ4bGN5QTlJSEpsY1hWcGNtVW9YQ0l1TDJGeWNtRjVWMmwwYUc5MWRFaHZiR1Z6WENJcE8xeHVYRzUyWVhJZ2FYUmxjbUZpYkdWVWIwRnljbUY1SUQwZ2NtVnhkV2x5WlNoY0lpNHZhWFJsY21GaWJHVlViMEZ5Y21GNVhDSXBPMXh1WEc1MllYSWdkVzV6ZFhCd2IzSjBaV1JKZEdWeVlXSnNaVlJ2UVhKeVlYa2dQU0J5WlhGMWFYSmxLRndpTGk5MWJuTjFjSEJ2Y25SbFpFbDBaWEpoWW14bFZHOUJjbkpoZVZ3aUtUdGNibHh1ZG1GeUlHNXZia2wwWlhKaFlteGxVM0J5WldGa0lEMGdjbVZ4ZFdseVpTaGNJaTR2Ym05dVNYUmxjbUZpYkdWVGNISmxZV1JjSWlrN1hHNWNibVoxYm1OMGFXOXVJRjkwYjBOdmJuTjFiV0ZpYkdWQmNuSmhlU2hoY25JcElIdGNiaUFnY21WMGRYSnVJR0Z5Y21GNVYybDBhRzkxZEVodmJHVnpLR0Z5Y2lrZ2ZId2dhWFJsY21GaWJHVlViMEZ5Y21GNUtHRnljaWtnZkh3Z2RXNXpkWEJ3YjNKMFpXUkpkR1Z5WVdKc1pWUnZRWEp5WVhrb1lYSnlLU0I4ZkNCdWIyNUpkR1Z5WVdKc1pWTndjbVZoWkNncE8xeHVmVnh1WEc1dGIyUjFiR1V1Wlhod2IzSjBjeUE5SUY5MGIwTnZibk4xYldGaWJHVkJjbkpoZVRzaUxDSm1kVzVqZEdsdmJpQmZZMnhoYzNORFlXeHNRMmhsWTJzb2FXNXpkR0Z1WTJVc0lFTnZibk4wY25WamRHOXlLU0I3WEc0Z0lHbG1JQ2doS0dsdWMzUmhibU5sSUdsdWMzUmhibU5sYjJZZ1EyOXVjM1J5ZFdOMGIzSXBLU0I3WEc0Z0lDQWdkR2h5YjNjZ2JtVjNJRlI1Y0dWRmNuSnZjaWhjSWtOaGJtNXZkQ0JqWVd4c0lHRWdZMnhoYzNNZ1lYTWdZU0JtZFc1amRHbHZibHdpS1R0Y2JpQWdmVnh1ZlZ4dVhHNXRiMlIxYkdVdVpYaHdiM0owY3lBOUlGOWpiR0Z6YzBOaGJHeERhR1ZqYXpzaUxDSm1kVzVqZEdsdmJpQmZaR1ZtYVc1bFVISnZjR1Z5ZEdsbGN5aDBZWEpuWlhRc0lIQnliM0J6S1NCN1hHNGdJR1p2Y2lBb2RtRnlJR2tnUFNBd095QnBJRHdnY0hKdmNITXViR1Z1WjNSb095QnBLeXNwSUh0Y2JpQWdJQ0IyWVhJZ1pHVnpZM0pwY0hSdmNpQTlJSEJ5YjNCelcybGRPMXh1SUNBZ0lHUmxjMk55YVhCMGIzSXVaVzUxYldWeVlXSnNaU0E5SUdSbGMyTnlhWEIwYjNJdVpXNTFiV1Z5WVdKc1pTQjhmQ0JtWVd4elpUdGNiaUFnSUNCa1pYTmpjbWx3ZEc5eUxtTnZibVpwWjNWeVlXSnNaU0E5SUhSeWRXVTdYRzRnSUNBZ2FXWWdLRndpZG1Gc2RXVmNJaUJwYmlCa1pYTmpjbWx3ZEc5eUtTQmtaWE5qY21sd2RHOXlMbmR5YVhSaFlteGxJRDBnZEhKMVpUdGNiaUFnSUNCUFltcGxZM1F1WkdWbWFXNWxVSEp2Y0dWeWRIa29kR0Z5WjJWMExDQmtaWE5qY21sd2RHOXlMbXRsZVN3Z1pHVnpZM0pwY0hSdmNpazdYRzRnSUgxY2JuMWNibHh1Wm5WdVkzUnBiMjRnWDJOeVpXRjBaVU5zWVhOektFTnZibk4wY25WamRHOXlMQ0J3Y205MGIxQnliM0J6TENCemRHRjBhV05RY205d2N5a2dlMXh1SUNCcFppQW9jSEp2ZEc5UWNtOXdjeWtnWDJSbFptbHVaVkJ5YjNCbGNuUnBaWE1vUTI5dWMzUnlkV04wYjNJdWNISnZkRzkwZVhCbExDQndjbTkwYjFCeWIzQnpLVHRjYmlBZ2FXWWdLSE4wWVhScFkxQnliM0J6S1NCZlpHVm1hVzVsVUhKdmNHVnlkR2xsY3loRGIyNXpkSEoxWTNSdmNpd2djM1JoZEdsalVISnZjSE1wTzF4dUlDQnlaWFIxY200Z1EyOXVjM1J5ZFdOMGIzSTdYRzU5WEc1Y2JtMXZaSFZzWlM1bGVIQnZjblJ6SUQwZ1gyTnlaV0YwWlVOc1lYTnpPeUlzSW1aMWJtTjBhVzl1SUY5a1pXWnBibVZRY205d1pYSjBlU2h2WW1vc0lHdGxlU3dnZG1Gc2RXVXBJSHRjYmlBZ2FXWWdLR3RsZVNCcGJpQnZZbW9wSUh0Y2JpQWdJQ0JQWW1wbFkzUXVaR1ZtYVc1bFVISnZjR1Z5ZEhrb2IySnFMQ0JyWlhrc0lIdGNiaUFnSUNBZ0lIWmhiSFZsT2lCMllXeDFaU3hjYmlBZ0lDQWdJR1Z1ZFcxbGNtRmliR1U2SUhSeWRXVXNYRzRnSUNBZ0lDQmpiMjVtYVdkMWNtRmliR1U2SUhSeWRXVXNYRzRnSUNBZ0lDQjNjbWwwWVdKc1pUb2dkSEoxWlZ4dUlDQWdJSDBwTzF4dUlDQjlJR1ZzYzJVZ2UxeHVJQ0FnSUc5aWFsdHJaWGxkSUQwZ2RtRnNkV1U3WEc0Z0lIMWNibHh1SUNCeVpYUjFjbTRnYjJKcU8xeHVmVnh1WEc1dGIyUjFiR1V1Wlhod2IzSjBjeUE5SUY5a1pXWnBibVZRY205d1pYSjBlVHNpTENKamIyNXpkQ0JwYzBWc1pXMWxiblFnUFNBb2RtRnNkV1VwSUQwK0lIWmhiSFZsUHk1dWIyUmxWSGx3WlNBOVBUMGdNVnh1WEc1bGVIQnZjblFnWkdWbVlYVnNkQ0JwYzBWc1pXMWxiblJjYmlJc0ltbHRjRzl5ZENCcGMwVnNaVzFsYm5RZ1puSnZiU0FuTGk5MWRHbHNjeTlwYzBWc1pXMWxiblFuWEc1Y2JtTnNZWE56SUVSUFRVOWljMlZ5ZG1WeUlIdGNibHgwYzNSaGRHbGpJRVZZU1ZOVUlEMGdKMFJQVFU5aWMyVnlkbVZ5WDJWNGFYTjBKMXh1WEhSemRHRjBhV01nUVVSRUlEMGdKMFJQVFU5aWMyVnlkbVZ5WDJGa1pDZGNibHgwYzNSaGRHbGpJRkpGVFU5V1JTQTlJQ2RFVDAxUFluTmxjblpsY2w5eVpXMXZkbVVuWEc1Y2RITjBZWFJwWXlCRFNFRk9SMFVnUFNBblJFOU5UMkp6WlhKMlpYSmZZMmhoYm1kbEoxeHVYSFJ6ZEdGMGFXTWdSVlpGVGxSVElEMGdXMFJQVFU5aWMyVnlkbVZ5TGtWWVNWTlVMQ0JFVDAxUFluTmxjblpsY2k1QlJFUXNJRVJQVFU5aWMyVnlkbVZ5TGxKRlRVOVdSU3dnUkU5TlQySnpaWEoyWlhJdVEwaEJUa2RGWFZ4dVhHNWNkRjl2WW5ObGNuWmxjaUE5SUc1MWJHeGNibHh1WEhSM1lXbDBLRnh1WEhSY2RIUmhjbWRsZEN4Y2JseDBYSFJ2YmtWMlpXNTBJRDBnYm5Wc2JDeGNibHgwWEhSN0lHVjJaVzUwY3lBOUlFUlBUVTlpYzJWeWRtVnlMa1ZXUlU1VVV5d2dkR2x0Wlc5MWRDQTlJREFzSUdGMGRISnBZblYwWlVacGJIUmxjaUE5SUhWdVpHVm1hVzVsWkN3Z2IyNUZjbkp2Y2lBOUlIVnVaR1ZtYVc1bFpDQjlJRDBnZTMxY2JseDBLU0I3WEc1Y2RGeDBkR2hwY3k1amJHVmhjaWdwWEc1Y2JseDBYSFJ5WlhSMWNtNGdibVYzSUZCeWIyMXBjMlVvS0hKbGMyOXNkbVVzSUhKbGFtVmpkQ2tnUFQ0Z2UxeHVYSFJjZEZ4MFkyOXVjM1FnWld3Z1BTQnBjMFZzWlcxbGJuUW9kR0Z5WjJWMEtTQS9JSFJoY21kbGRDQTZJR1J2WTNWdFpXNTBMbkYxWlhKNVUyVnNaV04wYjNJb2RHRnlaMlYwS1Z4dVhIUmNkRngwYVdZZ0tDRWhaV3dnSmlZZ1pYWmxiblJ6TG1sdVkyeDFaR1Z6S0VSUFRVOWljMlZ5ZG1WeUxrVllTVk5VS1NrZ2UxeHVYSFJjZEZ4MFhIUnBaaUFvYjI1RmRtVnVkQ2tnZTF4dVhIUmNkRngwWEhSY2RHOXVSWFpsYm5Rb1pXd3NJRVJQVFU5aWMyVnlkbVZ5TGtWWVNWTlVLVnh1WEhSY2RGeDBYSFI5SUdWc2MyVWdlMXh1WEhSY2RGeDBYSFJjZEhKbGMyOXNkbVVvZXlCdWIyUmxPaUJsYkN3Z1pYWmxiblE2SUVSUFRVOWljMlZ5ZG1WeUxrVllTVk5VSUgwcFhHNWNkRngwWEhSY2RIMWNibHgwWEhSY2RIMWNibHh1WEhSY2RGeDBhV1lnS0hScGJXVnZkWFFnUGlBd0tTQjdYRzVjZEZ4MFhIUmNkSFJvYVhNdVgzUnBiV1Z2ZFhRZ1BTQnpaWFJVYVcxbGIzVjBLQ2dwSUQwK0lIdGNibHgwWEhSY2RGeDBYSFIwYUdsekxtTnNaV0Z5S0NsY2JseDBYSFJjZEZ4MFhIUmpiMjV6ZENCbGNuSnZjaUE5SUc1bGR5QkZjbkp2Y2loZ1cxUkpUVVZQVlZSZE9pQkZiR1Z0Wlc1MElDUjdkR0Z5WjJWMGZTQmpZVzV1YjNRZ1ltVWdabTkxYm1RZ1lXWjBaWElnSkh0MGFXMWxiM1YwZlcxellDbGNibHgwWEhSY2RGeDBYSFJwWmlBb2IyNUZkbVZ1ZENrZ2UxeHVYSFJjZEZ4MFhIUmNkRngwYjI1RmNuSnZjajh1S0dWeWNtOXlLVnh1WEhSY2RGeDBYSFJjZEgwZ1pXeHpaU0I3WEc1Y2RGeDBYSFJjZEZ4MFhIUnlaV3BsWTNRb1pYSnliM0lwWEc1Y2RGeDBYSFJjZEZ4MGZWeHVYSFJjZEZ4MFhIUjlMQ0IwYVcxbGIzVjBLVnh1WEhSY2RGeDBmVnh1WEc1Y2RGeDBYSFIwYUdsekxsOXZZbk5sY25abGNpQTlJRzVsZHlCTmRYUmhkR2x2Yms5aWMyVnlkbVZ5S0NodGRYUmhkR2x2Ym5NcElEMCtJSHRjYmx4MFhIUmNkRngwYlhWMFlYUnBiMjV6TG1admNrVmhZMmdvS0hzZ2RIbHdaU3dnZEdGeVoyVjBPaUIwWVhKblpYUk9iMlJsTENCaFpHUmxaRTV2WkdWekxDQnlaVzF2ZG1Wa1RtOWtaWE1zSUdGMGRISnBZblYwWlU1aGJXVXNJRzlzWkZaaGJIVmxJSDBwSUQwK0lIdGNibHgwWEhSY2RGeDBYSFJwWmlBb1hHNWNkRngwWEhSY2RGeDBYSFIwZVhCbElEMDlQU0FuWTJocGJHUk1hWE4wSnlBbUpseHVYSFJjZEZ4MFhIUmNkRngwS0dWMlpXNTBjeTVwYm1Oc2RXUmxjeWhFVDAxUFluTmxjblpsY2k1QlJFUXBJSHg4SUdWMlpXNTBjeTVwYm1Oc2RXUmxjeWhFVDAxUFluTmxjblpsY2k1U1JVMVBWa1VwS1Z4dVhIUmNkRngwWEhSY2RDa2dlMXh1WEhSY2RGeDBYSFJjZEZ4MFkyOXVjM1FnYm05a1pYTWdQU0JiWEc1Y2RGeDBYSFJjZEZ4MFhIUmNkQzR1TGlobGRtVnVkSE11YVc1amJIVmtaWE1vUkU5TlQySnpaWEoyWlhJdVFVUkVLU0EvSUVGeWNtRjVMbVp5YjIwb1lXUmtaV1JPYjJSbGN5a2dPaUJiWFNrc1hHNWNkRngwWEhSY2RGeDBYSFJjZEM0dUxpaGxkbVZ1ZEhNdWFXNWpiSFZrWlhNb1JFOU5UMkp6WlhKMlpYSXVVa1ZOVDFaRktTQS9JRUZ5Y21GNUxtWnliMjBvY21WdGIzWmxaRTV2WkdWektTQTZJRnRkS1N4Y2JseDBYSFJjZEZ4MFhIUmNkRjFjYmx4MFhIUmNkRngwWEhSY2RHWnZjaUFvYkdWMElHNXZaR1VnYjJZZ2JtOWtaWE1wSUh0Y2JseDBYSFJjZEZ4MFhIUmNkRngwYVdZZ0tHNXZaR1VnUFQwOUlIUmhjbWRsZENCOGZDQW9JV2x6Uld4bGJXVnVkQ2gwWVhKblpYUXBJQ1ltSUc1dlpHVXViV0YwWTJobGN6OHVLSFJoY21kbGRDa3BLU0I3WEc1Y2RGeDBYSFJjZEZ4MFhIUmNkRngwYVdZZ0tHOXVSWFpsYm5RcElIdGNibHgwWEhSY2RGeDBYSFJjZEZ4MFhIUmNkRzl1UlhabGJuUW9YRzVjZEZ4MFhIUmNkRngwWEhSY2RGeDBYSFJjZEc1dlpHVXNYRzVjZEZ4MFhIUmNkRngwWEhSY2RGeDBYSFJjZEVGeWNtRjVMbVp5YjIwb1lXUmtaV1JPYjJSbGN5a3VhVzVqYkhWa1pYTW9ibTlrWlNrZ1B5QkVUMDFQWW5ObGNuWmxjaTVCUkVRZ09pQkVUMDFQWW5ObGNuWmxjaTVTUlUxUFZrVmNibHgwWEhSY2RGeDBYSFJjZEZ4MFhIUmNkQ2xjYmx4MFhIUmNkRngwWEhSY2RGeDBYSFI5SUdWc2MyVWdlMXh1WEhSY2RGeDBYSFJjZEZ4MFhIUmNkRngwY21WemIyeDJaU2g3WEc1Y2RGeDBYSFJjZEZ4MFhIUmNkRngwWEhSY2RHNXZaR1VzWEc1Y2RGeDBYSFJjZEZ4MFhIUmNkRngwWEhSY2RHVjJaVzUwT2lCQmNuSmhlUzVtY205dEtHRmtaR1ZrVG05a1pYTXBMbWx1WTJ4MVpHVnpLRzV2WkdVcFhHNWNkRngwWEhSY2RGeDBYSFJjZEZ4MFhIUmNkRngwUHlCRVQwMVBZbk5sY25abGNpNUJSRVJjYmx4MFhIUmNkRngwWEhSY2RGeDBYSFJjZEZ4MFhIUTZJRVJQVFU5aWMyVnlkbVZ5TGxKRlRVOVdSU3hjYmx4MFhIUmNkRngwWEhSY2RGeDBYSFJjZEgwcFhHNWNkRngwWEhSY2RGeDBYSFJjZEZ4MGZWeHVYSFJjZEZ4MFhIUmNkRngwWEhSOVhHNWNkRngwWEhSY2RGeDBYSFI5WEc1Y2RGeDBYSFJjZEZ4MGZWeHVYSFJjZEZ4MFhIUmNkR2xtSUNoMGVYQmxJRDA5UFNBbllYUjBjbWxpZFhSbGN5Y2dKaVlnWlhabGJuUnpMbWx1WTJ4MVpHVnpLRVJQVFU5aWMyVnlkbVZ5TGtOSVFVNUhSU2twSUh0Y2JseDBYSFJjZEZ4MFhIUmNkR2xtSUNoMFlYSm5aWFJPYjJSbElEMDlQU0IwWVhKblpYUWdmSHdnS0NGcGMwVnNaVzFsYm5Rb2RHRnlaMlYwS1NBbUppQjBZWEpuWlhST2IyUmxMbTFoZEdOb1pYTS9MaWgwWVhKblpYUXBLU2tnZTF4dVhIUmNkRngwWEhSY2RGeDBYSFJwWmlBb2IyNUZkbVZ1ZENrZ2UxeHVYSFJjZEZ4MFhIUmNkRngwWEhSY2RHOXVSWFpsYm5Rb2RHRnlaMlYwVG05a1pTd2dSRTlOVDJKelpYSjJaWEl1UTBoQlRrZEZMQ0I3WEc1Y2RGeDBYSFJjZEZ4MFhIUmNkRngwWEhSaGRIUnlhV0oxZEdWT1lXMWxMRnh1WEhSY2RGeDBYSFJjZEZ4MFhIUmNkRngwYjJ4a1ZtRnNkV1VzWEc1Y2RGeDBYSFJjZEZ4MFhIUmNkRngwZlNsY2JseDBYSFJjZEZ4MFhIUmNkRngwZlNCbGJITmxJSHRjYmx4MFhIUmNkRngwWEhSY2RGeDBYSFJ5WlhOdmJIWmxLSHRjYmx4MFhIUmNkRngwWEhSY2RGeDBYSFJjZEc1dlpHVTZJSFJoY21kbGRFNXZaR1VzWEc1Y2RGeDBYSFJjZEZ4MFhIUmNkRngwWEhSbGRtVnVkRG9nUkU5TlQySnpaWEoyWlhJdVEwaEJUa2RGTEZ4dVhIUmNkRngwWEhSY2RGeDBYSFJjZEZ4MGIzQjBhVzl1Y3pvZ2UxeHVYSFJjZEZ4MFhIUmNkRngwWEhSY2RGeDBYSFJoZEhSeWFXSjFkR1ZPWVcxbExGeHVYSFJjZEZ4MFhIUmNkRngwWEhSY2RGeDBYSFJ2YkdSV1lXeDFaU3hjYmx4MFhIUmNkRngwWEhSY2RGeDBYSFJjZEgwc1hHNWNkRngwWEhSY2RGeDBYSFJjZEZ4MGZTbGNibHgwWEhSY2RGeDBYSFJjZEZ4MGZWeHVYSFJjZEZ4MFhIUmNkRngwZlZ4dVhIUmNkRngwWEhSY2RIMWNibHgwWEhSY2RGeDBmU2xjYmx4MFhIUmNkSDBwWEc1Y2JseDBYSFJjZEhSb2FYTXVYMjlpYzJWeWRtVnlMbTlpYzJWeWRtVW9aRzlqZFcxbGJuUXVaRzlqZFcxbGJuUkZiR1Z0Wlc1MExDQjdYRzVjZEZ4MFhIUmNkSE4xWW5SeVpXVTZJSFJ5ZFdVc1hHNWNkRngwWEhSY2RHTm9hV3hrVEdsemREb2daWFpsYm5SekxtbHVZMngxWkdWektFUlBUVTlpYzJWeWRtVnlMa0ZFUkNrZ2ZId2daWFpsYm5SekxtbHVZMngxWkdWektFUlBUVTlpYzJWeWRtVnlMbEpGVFU5V1JTa3NYRzVjZEZ4MFhIUmNkR0YwZEhKcFluVjBaWE02SUdWMlpXNTBjeTVwYm1Oc2RXUmxjeWhFVDAxUFluTmxjblpsY2k1RFNFRk9SMFVwTEZ4dVhIUmNkRngwWEhSaGRIUnlhV0oxZEdWUGJHUldZV3gxWlRvZ1pYWmxiblJ6TG1sdVkyeDFaR1Z6S0VSUFRVOWljMlZ5ZG1WeUxrTklRVTVIUlNrc1hHNWNkRngwWEhSY2RHRjBkSEpwWW5WMFpVWnBiSFJsY2l4Y2JseDBYSFJjZEgwcFhHNWNkRngwZlNsY2JseDBmVnh1WEc1Y2RHTnNaV0Z5S0NrZ2UxeHVYSFJjZEhSb2FYTXVYMjlpYzJWeWRtVnlQeTVrYVhOamIyNXVaV04wS0NsY2JseDBYSFJqYkdWaGNsUnBiV1Z2ZFhRb2RHaHBjeTVmZEdsdFpXOTFkQ2xjYmx4MGZWeHVmVnh1WEc1bGVIQnZjblFnWkdWbVlYVnNkQ0JFVDAxUFluTmxjblpsY2x4dUlsMHNJbTVoYldWeklqcGJJbUZ5Y2lJc0lteGxiaUlzSW14bGJtZDBhQ0lzSW1raUxDSmhjbkl5SWl3aVFYSnlZWGtpTENKcGMwRnljbUY1SWl3aVlYSnlZWGxNYVd0bFZHOUJjbkpoZVNJc0ltbDBaWElpTENKVGVXMWliMndpTENKcGRHVnlZWFJ2Y2lJc0lrOWlhbVZqZENJc0ltWnliMjBpTENKdklpd2liV2x1VEdWdUlpd2liaUlzSW5CeWIzUnZkSGx3WlNJc0luUnZVM1J5YVc1bklpd2lZMkZzYkNJc0luTnNhV05sSWl3aVkyOXVjM1J5ZFdOMGIzSWlMQ0p1WVcxbElpd2lkR1Z6ZENJc0lsUjVjR1ZGY25KdmNpSXNJbUZ5Y21GNVYybDBhRzkxZEVodmJHVnpJaXdpYVhSbGNtRmliR1ZVYjBGeWNtRjVJaXdpZFc1emRYQndiM0owWldSSmRHVnlZV0pzWlZSdlFYSnlZWGtpTENKdWIyNUpkR1Z5WVdKc1pWTndjbVZoWkNJc0ltbHVjM1JoYm1ObElpd2lRMjl1YzNSeWRXTjBiM0lpTENKZlpHVm1hVzVsVUhKdmNHVnlkR2xsY3lJc0luUmhjbWRsZENJc0luQnliM0J6SWl3aVpHVnpZM0pwY0hSdmNpSXNJbVZ1ZFcxbGNtRmliR1VpTENKamIyNW1hV2QxY21GaWJHVWlMQ0ozY21sMFlXSnNaU0lzSW1SbFptbHVaVkJ5YjNCbGNuUjVJaXdpYTJWNUlpd2ljSEp2ZEc5UWNtOXdjeUlzSW5OMFlYUnBZMUJ5YjNCeklpd2liMkpxSWl3aWRtRnNkV1VpTENKcGMwVnNaVzFsYm5RaUxDSnViMlJsVkhsd1pTSXNJa1JQVFU5aWMyVnlkbVZ5SWl3aWIyNUZkbVZ1ZENJc0ltVjJaVzUwY3lJc0lrVldSVTVVVXlJc0luUnBiV1Z2ZFhRaUxDSmhkSFJ5YVdKMWRHVkdhV3gwWlhJaUxDSjFibVJsWm1sdVpXUWlMQ0p2YmtWeWNtOXlJaXdpWTJ4bFlYSWlMQ0pRY205dGFYTmxJaXdpY21WemIyeDJaU0lzSW5KbGFtVmpkQ0lzSW1Wc0lpd2laRzlqZFcxbGJuUWlMQ0p4ZFdWeWVWTmxiR1ZqZEc5eUlpd2lhVzVqYkhWa1pYTWlMQ0pGV0VsVFZDSXNJbTV2WkdVaUxDSmxkbVZ1ZENJc0lsOTBhR2x6SWl3aVgzUnBiV1Z2ZFhRaUxDSnpaWFJVYVcxbGIzVjBJaXdpWlhKeWIzSWlMQ0pGY25KdmNpSXNJbDl2WW5ObGNuWmxjaUlzSWsxMWRHRjBhVzl1VDJKelpYSjJaWElpTENKdGRYUmhkR2x2Ym5NaUxDSm1iM0pGWVdOb0lpd2lkSGx3WlNJc0luUmhjbWRsZEU1dlpHVWlMQ0poWkdSbFpFNXZaR1Z6SWl3aWNtVnRiM1psWkU1dlpHVnpJaXdpWVhSMGNtbGlkWFJsVG1GdFpTSXNJbTlzWkZaaGJIVmxJaXdpUVVSRUlpd2lVa1ZOVDFaRklpd2liV0YwWTJobGN5SXNJbDl1YjJSbEpHMWhkR05vWlhNaUxDSkRTRUZPUjBVaUxDSmZkR0Z5WjJWMFRtOWtaU1J0WVhSamFHVnpJaXdpYjNCMGFXOXVjeUlzSW05aWMyVnlkbVVpTENKa2IyTjFiV1Z1ZEVWc1pXMWxiblFpTENKemRXSjBjbVZsSWl3aVkyaHBiR1JNYVhOMElpd2lZWFIwY21saWRYUmxjeUlzSW1GMGRISnBZblYwWlU5c1pGWmhiSFZsSWl3aVpHbHpZMjl1Ym1WamRDSXNJbU5zWldGeVZHbHRaVzkxZENJc0luUm9hWE1pWFN3aWJXRndjR2x1WjNNaU9pSkJRVlZCTEUxQlZrRXNVMEZCTWtKQkxFVkJRVXRETEVsQlEyNUNMRTFCUVZCQkxFZEJRV1ZCTEVWQlFVMUVMRVZCUVVsRkxGVkJRVkZFTEVWQlFVMUVMRVZCUVVsRkxGRkJSUzlETEVsQlFVc3NTVUZCU1VNc1JVRkJTU3hGUVVGSFF5eEZRVUZQTEVsQlFVbERMRTFCUVUxS0xFZEJRVTFGTEVWQlFVbEdMRVZCUVV0RkxFbEJRemxEUXl4RlFVRkxSQ3hIUVVGTFNDeEZRVUZKUnl4SFFVZG9RaXhQUVVGUFF5eEhRMFJVTEUxQlNrRXNVMEZCTkVKS0xFZEJRekZDTEVkQlFVbExMRTFCUVUxRExGRkJRVkZPTEVkQlFVMHNUMEZCVDA4c1JVRkJhVUpRTEVsRFEyeEVMRTFCU2tFc1UwRkJNRUpSTEVkQlEzaENMRWRCUVhOQ0xHOUNRVUZZUXl4UlFVRXdRa0VzVDBGQlQwTXNXVUZCV1VNc1QwRkJUMGdzUjBGQlR5eFBRVUZQU0N4TlFVRk5UeXhMUVVGTFNpeEpRMVV4Uml4TlFWUkJMRk5CUVhGRFN5eEZRVUZIUXl4SFFVTjBReXhIUVVGTFJDeEZRVUZNTEVOQlEwRXNSMEZCYVVJc2FVSkJRVTVCTEVWQlFXZENMRTlCUVU5T0xFVkJRV2xDVFN4RlFVRkhReXhIUVVOMFJDeEpRVUZKUXl4RlFVRkpTaXhQUVVGUFN5eFZRVUZWUXl4VFFVRlRReXhMUVVGTFRDeEhRVUZIVFN4TlFVRk5MRWRCUVVrc1IwRkZjRVFzVFVGRVZTeFhRVUZPU2l4SFFVRnJRa1lzUlVGQlJVOHNZMEZCWVV3c1JVRkJTVVlzUlVGQlJVOHNXVUZCV1VNc1RVRkROME1zVVVGQlRrNHNSMEZCY1VJc1VVRkJUa0VzUlVGQmIwSldMRTFCUVUxUExFdEJRVXRETEVkQlEzaERMR05CUVU1RkxFZEJRWEZDTERKRFFVRXlRMDhzUzBGQlMxQXNSMEZCVjFJc1JVRkJhVUpOTEVWQlFVZERMRkZCUVhoSExFbERTa1lzVFVGS1FTeFhRVU5GTEUxQlFVMHNTVUZCU1ZNc1ZVRkJWU3g1U1VOWGRFSXNUVUZLUVN4VFFVRTBRblpDTEVkQlF6RkNMRTlCUVU5M1FpeEZRVUZyUW5oQ0xFbEJRVkY1UWl4RlFVRm5RbnBDTEVsQlFWRXdRaXhGUVVFeVFqRkNMRWxCUVZFeVFpeExRMGc1Uml4TlFVNUJMRk5CUVhsQ1F5eEZRVUZWUXl4SFFVTnFReXhMUVVGTlJDeGhRVUZ2UWtNc1IwRkRlRUlzVFVGQlRTeEpRVUZKVGl4VlFVRlZMSE5EUTBaNFFpeFRRVUZUVHl4RlFVRnJRa01zUlVGQlVVTXNSMEZEYWtNc1NVRkJTeXhKUVVGSk4wSXNSVUZCU1N4RlFVRkhRU3hGUVVGSk5rSXNSVUZCVFRsQ0xFOUJRVkZETEVsQlFVc3NRMEZEY2tNc1NVRkJTVGhDTEVWQlFXRkVMRVZCUVUwM1FpeEhRVU4yUWpoQ0xFVkJRVmRETEZkQlFXRkVMRVZCUVZkRExHRkJRV01zUlVGRGFrUkVMRVZCUVZkRkxHTkJRV1VzUlVGRGRFSXNWVUZCVjBZc1NVRkJXVUVzUlVGQlYwY3NWVUZCVnl4SFFVTnFSSHBDTEU5QlFVOHdRaXhsUVVGbFRpeEZRVUZSUlN4RlFVRlhTeXhKUVVGTFRDeEpRVlZzUkN4TlFVNUJMRk5CUVhOQ1NpeEZRVUZoVlN4RlFVRlpReXhIUVVjM1F5eFBRVVpKUkN4SFFVRlpWQ3hGUVVGclFrUXNSVUZCV1dJc1ZVRkJWM1ZDTEVkQlEzSkVReXhIUVVGaFZpeEZRVUZyUWtRc1JVRkJZVmNzUjBGRGVrTllMRWREUlZRc1RVRm1RU3hUUVVGNVFsa3NSVUZCUzBnc1JVRkJTMGtzUjBGWmFrTXNUMEZZU1Vvc1MwRkJUMGNzUlVGRFZEbENMRTlCUVU4d1FpeGxRVUZsU1N4RlFVRkxTQ3hGUVVGTExFTkJRemxDU1N4TlFVRlBRU3hGUVVOUVVpeFpRVUZaTEVWQlExcERMR05CUVdNc1JVRkRaRU1zVlVGQlZTeEpRVWRhU3l4RlFVRkpTQ3hIUVVGUFNTeEZRVWRPUkN4SFExcElSU3hGUVVGWkxGTkJRVU5FTEZWQlFUaENMRXRCUVhCQ1FTeE5RVUZCUVN4VFFVRkJRU3hGUVVGUFJTeG5hVU5EUlRsQ1F5eDFSRUZQVHl3MlEwRkhXR1FzWTBGRFFXVXNlVVJCUVZVc09FUkJRM1ZHTEU5QlFTOUdReXhQUVVGQlFTeGhRVUZUUml4RlFVRlpSeXhoUVVGUlF5eFJRVUZCUVN4aFFVRlZMRkZCUVVkRExHZENRVUZCUVN4clFrRkJhMEpETEZGQlFWZERMRkZCUVVGQkxHdENRVUZWUkN4blFrRkZPVVZGTEZGQlJVVXNTVUZCU1VNc1UwRkJVU3hUUVVGRFF5eEZRVUZUUXl4UFFVTjBRa01zUlVGQlMyUXNSVUZCVlZvc1IwRkJWVUVzUlVGQlV6SkNMRk5CUVZORExHTkJRV00xUWl4SFFVTjZSREJDTEVkQlFVMVdMRVZCUVU5aExGTkJRVk5tTEVWQlFWbG5RaXhUUVVOdVEyWXNSVUZEU0VFc1JVRkJVVmNzUlVGQlNWb3NSVUZCV1dkQ0xFOUJSWGhDVGl4RlFVRlJMRU5CUVVWUExFdEJRVTFNTEVWQlFVbE5MRTFCUVU5c1FpeEZRVUZaWjBJc1UwRkpja05hTEVWQlFWVXNTVUZEWW1Vc1JVRkJTME1zVTBGQlYwTXNXVUZCVnl4WFFVTXhRa1lzUlVGQlMxZ3NXVUZEUTJNc1JVRkJVU3hKUVVGSlF5eHRRMEZCTkVKeVF5eHZRMEZCWjBOclFpeFRRVU14UlVnc1JVRkRTRTBzVFVGQlFVRXNSMEZCUVVFc1JVRkJWV1VzUjBGRlZsZ3NSVUZCVDFjc1MwRkZUbXhDTEVsQlIwcGxMRVZCUVV0TExGVkJRVmtzU1VGQlNVTXNhMEpCUVdsQ0xGTkJRVU5ETEVkQlEzUkRRU3hGUVVGVlF5eFRRVUZSTEd0Q1FVRkhReXhKUVVGQlFTeExRVUZqUXl4SlFVRlNNME1zVDBGQmIwSTBReXhKUVVGQlFTeFhRVUZaUXl4SlFVRkJRU3hoUVVGalF5eEpRVUZCUVN4alFVRmxReXhKUVVGQlFTeFpRVVUzUlN4alFVRlVUQ3hKUVVORE1VSXNSVUZCVDJFc1UwRkJVMllzUlVGQldXdERMRTFCUVZGb1F5eEZRVUZQWVN4VFFVRlRaaXhGUVVGWmJVTXNVMEZEYUVVc2RVSkJSVWxxUXl4RlFVRlBZU3hUUVVGVFppeEZRVUZaYTBNc1MwRkJUekZGTEUxQlFVMVBMRXRCUVVzclJDeEhRVUZqTEUxQlF6VkVOVUlzUlVGQlQyRXNVMEZCVTJZc1JVRkJXVzFETEZGQlFWVXpSU3hOUVVGTlR5eExRVUZMWjBVc1IwRkJaMElzY1VOQlJUbERMRTlCUVdaa0xGZEJRMHBCTEVsQlFWTXZRaXhKUVVGWldTeEZRVUZWV2l4alFVRlhLMElzUlVGQlMyMUNMSE5DUVVGTVF5eFBRVUZCY0VJc1JVRkJaUzlDTEUxQlEzaEVaU3hGUVVOSVFTeEZRVU5EWjBJc1JVRkRRWHBFTEUxQlFVMVBMRXRCUVVzclJDeEhRVUZaWml4VFFVRlRSU3hIUVVGUmFrSXNSVUZCV1d0RExFbEJRVTFzUXl4RlFVRlpiVU1zVVVGSGRrVjZRaXhGUVVGUkxFTkJRMUJQTEV0QlFVRkJMRVZCUTBGRExFMUJRVTh4UkN4TlFVRk5UeXhMUVVGTEswUXNSMEZCV1dZc1UwRkJVMFVzUjBGRGNFTnFRaXhGUVVGWmEwTXNTVUZEV214RExFVkJRVmx0UXl3d1EwRk5VQ3hsUVVGVVVDeEhRVUY1UWpGQ0xFVkJRVTloTEZOQlFWTm1MRVZCUVZselF5eFhRVU53UkZRc1NVRkJaVE5ETEVsQlFWbFpMRVZCUVZWYUxHTkJRVmN5UXl4RlFVRlhUeXh6UWtGQldFY3NUMEZCUVZZc1JVRkJjVUl6UXl4TlFVTndSV1VzUlVGRFNFRXNSVUZCVVRSQ0xFVkJRVmszUWl4RlFVRlpjME1zVDBGQlVTeERRVU4yUTA0c1kwRkJRVUVzUlVGRFFVTXNVMEZCUVVFc1NVRkhSSFpDTEVWQlFWRXNRMEZEVUU4c1MwRkJUVmtzUlVGRFRsZ3NUVUZCVDJ4Q0xFVkJRVmx6UXl4UFFVTnVRa1VzVVVGQlV5eERRVU5TVWl4alFVRkJRU3hGUVVOQlF5eFRRVUZCUVN4aFFWTlFaQ3hGUVVGTFN5eFZRVUZWYVVJc1VVRkJVVFZDTEZOQlFWTTJRaXhuUWtGQmFVSXNRMEZEYUVSRExGTkJRVk1zUlVGRFZFTXNWVUZCVnpGRExFVkJRVTloTEZOQlFWTm1MRVZCUVZsclF5eE5RVUZSYUVNc1JVRkJUMkVzVTBGQlUyWXNSVUZCV1cxRExGRkJRek5GVlN4WFFVRlpNME1zUlVGQlQyRXNVMEZCVTJZc1JVRkJXWE5ETEZGQlEzaERVU3hyUWtGQmJVSTFReXhGUVVGUFlTeFRRVUZUWml4RlFVRlpjME1zVVVGREwwTnFReXhuUWtGQlFVRXNORVJCVFVkdFFpd3dRa0ZCVjNWQ0xHRkJRMmhDUXl4aFFVRmhReXhMUVVGTE4wSXNjVUpCY0Vka2NFSXNWVUZEVlN4MVFrRkVWa0VzVVVGRlVTeHhRa0ZHVWtFc1YwRkhWeXgzUWtGSVdFRXNWMEZKVnl4M1FrRktXRUVzVjBGTFZ5eERRVUZEUVN4RlFVRlpaMElzVFVGQlQyaENMRVZCUVZsclF5eEpRVUZMYkVNc1JVRkJXVzFETEU5QlFWRnVReXhGUVVGWmMwTWlmUT09XG4iLCJpbXBvcnQgeyBET01PYnNlcnZlciB9IGZyb20gJ0B1bnRlbXBzL2RvbS1vYnNlcnZlcidcblxuY2xhc3MgVG9vbHRpcCB7XG5cdHN0YXRpYyBnZXQgR0FQKCkge1xuXHRcdHJldHVybiAxMFxuXHR9XG5cblx0c3RhdGljICNpbnN0YW5jZXMgPSBbXVxuXG5cdCNvYnNlcnZlciA9IG51bGxcblx0I2V2ZW50cyA9IFtdXG5cdCNlbnRlckRlbGF5ID0gMFxuXHQjbGVhdmVEZWxheSA9IDBcblx0I2RlbGF5ID0gbnVsbFxuXG5cdCN0b29sdGlwID0gbnVsbFxuXG5cdCNib3VuZEVudGVySGFuZGxlciA9IG51bGxcblx0I2JvdW5kTGVhdmVIYW5kbGVyID0gbnVsbFxuXG5cdCN0YXJnZXQgPSBudWxsXG5cdCNjb250ZW50ID0gbnVsbFxuXHQjY29udGVudFNlbGVjdG9yID0gbnVsbFxuXHQjY29udGVudEFjdGlvbnMgPSBudWxsXG5cdCNjb250ZW50Q2xvbmUgPSBmYWxzZVxuXHQjY29udGFpbmVyQ2xhc3NOYW1lID0gbnVsbFxuXHQjcG9zaXRpb24gPSBudWxsXG5cdCNhbmltYXRlZCA9IGZhbHNlXG5cdCNhbmltYXRpb25FbnRlckNsYXNzTmFtZSA9IG51bGxcblx0I2FuaW1hdGlvbkxlYXZlQ2xhc3NOYW1lID0gbnVsbFxuXG5cdHN0YXRpYyBkZXN0cm95KCkge1xuXHRcdFRvb2x0aXAuI2luc3RhbmNlcy5mb3JFYWNoKChpbnN0YW5jZSkgPT4ge1xuXHRcdFx0aW5zdGFuY2UuZGVzdHJveSgpXG5cdFx0fSlcblx0XHRUb29sdGlwLiNpbnN0YW5jZXMgPSBbXVxuXHR9XG5cblx0Y29uc3RydWN0b3IoXG5cdFx0dGFyZ2V0LFxuXHRcdGNvbnRlbnQsXG5cdFx0Y29udGVudFNlbGVjdG9yLFxuXHRcdGNvbnRlbnRDbG9uZSxcblx0XHRjb250ZW50QWN0aW9ucyxcblx0XHRjb250YWluZXJDbGFzc05hbWUsXG5cdFx0cG9zaXRpb24sXG5cdFx0YW5pbWF0ZWQsXG5cdFx0YW5pbWF0aW9uRW50ZXJDbGFzc05hbWUsXG5cdFx0YW5pbWF0aW9uTGVhdmVDbGFzc05hbWUsXG5cdFx0ZW50ZXJEZWxheSxcblx0XHRsZWF2ZURlbGF5LFxuXHRcdGRpc2FibGVkXG5cdCkge1xuXHRcdHRoaXMuI3RhcmdldCA9IHRhcmdldFxuXHRcdHRoaXMuI2NvbnRlbnQgPSBjb250ZW50XG5cdFx0dGhpcy4jY29udGVudFNlbGVjdG9yID0gY29udGVudFNlbGVjdG9yXG5cdFx0dGhpcy4jY29udGVudENsb25lID0gY29udGVudENsb25lIHx8IGZhbHNlXG5cdFx0dGhpcy4jY29udGVudEFjdGlvbnMgPSBjb250ZW50QWN0aW9uc1xuXHRcdHRoaXMuI2NvbnRhaW5lckNsYXNzTmFtZSA9IGNvbnRhaW5lckNsYXNzTmFtZVxuXHRcdHRoaXMuI3Bvc2l0aW9uID0gcG9zaXRpb24gfHwgJ3RvcCdcblx0XHR0aGlzLiNhbmltYXRlZCA9IGFuaW1hdGVkIHx8IGZhbHNlXG5cdFx0dGhpcy4jYW5pbWF0aW9uRW50ZXJDbGFzc05hbWUgPSBhbmltYXRpb25FbnRlckNsYXNzTmFtZSB8fCAnX190b29sdGlwLWVudGVyJ1xuXHRcdHRoaXMuI2FuaW1hdGlvbkxlYXZlQ2xhc3NOYW1lID0gYW5pbWF0aW9uTGVhdmVDbGFzc05hbWUgfHwgJ19fdG9vbHRpcC1sZWF2ZSdcblx0XHR0aGlzLiNlbnRlckRlbGF5ID0gZW50ZXJEZWxheSB8fCAwXG5cdFx0dGhpcy4jbGVhdmVEZWxheSA9IGxlYXZlRGVsYXkgfHwgMFxuXG5cdFx0dGhpcy4jb2JzZXJ2ZXIgPSBuZXcgRE9NT2JzZXJ2ZXIoKVxuXG5cdFx0dGhpcy4jdGFyZ2V0LnRpdGxlID0gJydcblx0XHR0aGlzLiN0YXJnZXQuc2V0QXR0cmlidXRlKCdzdHlsZScsICdwb3NpdGlvbjogcmVsYXRpdmUnKVxuXG5cdFx0dGhpcy4jY3JlYXRlVG9vbHRpcCgpXG5cdFx0dGhpcy4jdG9vbHRpcC5jbGFzc0xpc3QuYWRkKHRoaXMuI2NvbnRhaW5lckNsYXNzTmFtZSB8fCAnX190b29sdGlwJywgYF9fdG9vbHRpcC0ke3RoaXMuI3Bvc2l0aW9ufWApXG5cblx0XHRkaXNhYmxlZCA/IHRoaXMuI2Rpc2FibGVUYXJnZXQoKSA6IHRoaXMuI2VuYWJsZVRhcmdldCgpXG5cblx0XHRUb29sdGlwLiNpbnN0YW5jZXMucHVzaCh0aGlzKVxuXHR9XG5cblx0dXBkYXRlKFxuXHRcdGNvbnRlbnQsXG5cdFx0Y29udGVudFNlbGVjdG9yLFxuXHRcdGNvbnRlbnRDbG9uZSxcblx0XHRjb250ZW50QWN0aW9ucyxcblx0XHRjb250YWluZXJDbGFzc05hbWUsXG5cdFx0cG9zaXRpb24sXG5cdFx0YW5pbWF0ZWQsXG5cdFx0YW5pbWF0aW9uRW50ZXJDbGFzc05hbWUsXG5cdFx0YW5pbWF0aW9uTGVhdmVDbGFzc05hbWUsXG5cdFx0ZW50ZXJEZWxheSxcblx0XHRsZWF2ZURlbGF5LFxuXHRcdGRpc2FibGVkXG5cdCkge1xuXHRcdGNvbnN0IGhhc0NvbnRlbnRDaGFuZ2VkID0gY29udGVudFNlbGVjdG9yICE9PSB0aGlzLiNjb250ZW50U2VsZWN0b3IgfHwgY29udGVudCAhPT0gdGhpcy4jY29udGVudFxuXHRcdGNvbnN0IGhhc0NvbnRhaW5lckNsYXNzTmFtZUNoYW5nZWQgPSBjb250YWluZXJDbGFzc05hbWUgIT09IHRoaXMuI2NvbnRhaW5lckNsYXNzTmFtZVxuXHRcdGNvbnN0IG9sZFBvc2l0aW9uID0gdGhpcy4jcG9zaXRpb25cblx0XHRjb25zdCBoYXNQb3NpdGlvbkNoYW5nZWQgPSBwb3NpdGlvbiAhPT0gdGhpcy4jcG9zaXRpb25cblx0XHRjb25zdCBoYXNUb0Rpc2FibGVUYXJnZXQgPSBkaXNhYmxlZCAmJiB0aGlzLiNib3VuZEVudGVySGFuZGxlclxuXHRcdGNvbnN0IGhhc1RvRW5hYmxlVGFyZ2V0ID0gIWRpc2FibGVkICYmICF0aGlzLiNib3VuZEVudGVySGFuZGxlclxuXG5cdFx0dGhpcy4jY29udGVudCA9IGNvbnRlbnRcblx0XHR0aGlzLiNjb250ZW50U2VsZWN0b3IgPSBjb250ZW50U2VsZWN0b3Jcblx0XHR0aGlzLiNjb250ZW50Q2xvbmUgPSBjb250ZW50Q2xvbmUgfHwgZmFsc2Vcblx0XHR0aGlzLiNjb250ZW50QWN0aW9ucyA9IGNvbnRlbnRBY3Rpb25zXG5cdFx0dGhpcy4jY29udGFpbmVyQ2xhc3NOYW1lID0gY29udGFpbmVyQ2xhc3NOYW1lXG5cdFx0dGhpcy4jcG9zaXRpb24gPSBwb3NpdGlvbiB8fCAndG9wJ1xuXHRcdHRoaXMuI2FuaW1hdGVkID0gYW5pbWF0ZWQgfHwgZmFsc2Vcblx0XHR0aGlzLiNhbmltYXRpb25FbnRlckNsYXNzTmFtZSA9IGFuaW1hdGlvbkVudGVyQ2xhc3NOYW1lIHx8ICdfX3Rvb2x0aXAtZW50ZXInXG5cdFx0dGhpcy4jYW5pbWF0aW9uTGVhdmVDbGFzc05hbWUgPSBhbmltYXRpb25MZWF2ZUNsYXNzTmFtZSB8fCAnX190b29sdGlwLWxlYXZlJ1xuXHRcdHRoaXMuI2VudGVyRGVsYXkgPSBlbnRlckRlbGF5IHx8IDBcblx0XHR0aGlzLiNsZWF2ZURlbGF5ID0gbGVhdmVEZWxheSB8fCAwXG5cblx0XHRpZiAoaGFzQ29udGVudENoYW5nZWQpIHtcblx0XHRcdHRoaXMuI3JlbW92ZVRvb2x0aXBGcm9tVGFyZ2V0KClcblx0XHRcdHRoaXMuI2NyZWF0ZVRvb2x0aXAoKVxuXHRcdH1cblxuXHRcdGlmIChoYXNDb250YWluZXJDbGFzc05hbWVDaGFuZ2VkIHx8IGhhc0NvbnRlbnRDaGFuZ2VkKSB7XG5cdFx0XHR0aGlzLiN0b29sdGlwLmNsYXNzTGlzdC5hZGQodGhpcy4jY29udGFpbmVyQ2xhc3NOYW1lIHx8ICdfX3Rvb2x0aXAnKVxuXHRcdH1cblxuXHRcdGlmIChoYXNQb3NpdGlvbkNoYW5nZWQgfHwgaGFzQ29udGFpbmVyQ2xhc3NOYW1lQ2hhbmdlZCB8fCBoYXNDb250ZW50Q2hhbmdlZCkge1xuXHRcdFx0dGhpcy4jdG9vbHRpcC5jbGFzc0xpc3QucmVtb3ZlKGBfX3Rvb2x0aXAtJHtvbGRQb3NpdGlvbn1gKVxuXHRcdFx0dGhpcy4jdG9vbHRpcC5jbGFzc0xpc3QuYWRkKGBfX3Rvb2x0aXAtJHt0aGlzLiNwb3NpdGlvbn1gKVxuXHRcdH1cblxuXHRcdGlmIChoYXNUb0Rpc2FibGVUYXJnZXQpIHtcblx0XHRcdHRoaXMuI2Rpc2FibGVUYXJnZXQoKVxuXHRcdH0gZWxzZSBpZiAoaGFzVG9FbmFibGVUYXJnZXQpIHtcblx0XHRcdHRoaXMuI2VuYWJsZVRhcmdldCgpXG5cdFx0fVxuXHR9XG5cblx0ZGVzdHJveSgpIHtcblx0XHR0aGlzLiNyZW1vdmVUb29sdGlwRnJvbVRhcmdldCgpXG5cblx0XHR0aGlzLiNkaXNhYmxlVGFyZ2V0KClcblxuXHRcdHRoaXMuI2NsZWFyRGVsYXkoKVxuXG5cdFx0dGhpcy4jb2JzZXJ2ZXI/LmNsZWFyKClcblx0XHR0aGlzLiNvYnNlcnZlciA9IG51bGxcblx0fVxuXG5cdCNlbmFibGVUYXJnZXQoKSB7XG5cdFx0dGhpcy4jYm91bmRFbnRlckhhbmRsZXIgPSB0aGlzLiNvblRhcmdldEVudGVyLmJpbmQodGhpcylcblx0XHR0aGlzLiNib3VuZExlYXZlSGFuZGxlciA9IHRoaXMuI29uVGFyZ2V0TGVhdmUuYmluZCh0aGlzKVxuXG5cdFx0dGhpcy4jdGFyZ2V0LmFkZEV2ZW50TGlzdGVuZXIoJ21vdXNlZW50ZXInLCB0aGlzLiNib3VuZEVudGVySGFuZGxlcilcblx0XHR0aGlzLiN0YXJnZXQuYWRkRXZlbnRMaXN0ZW5lcignbW91c2VsZWF2ZScsIHRoaXMuI2JvdW5kTGVhdmVIYW5kbGVyKVxuXHR9XG5cblx0I2Rpc2FibGVUYXJnZXQoKSB7XG5cdFx0dGhpcy4jdGFyZ2V0LnJlbW92ZUV2ZW50TGlzdGVuZXIoJ21vdXNlZW50ZXInLCB0aGlzLiNib3VuZEVudGVySGFuZGxlcilcblx0XHR0aGlzLiN0YXJnZXQucmVtb3ZlRXZlbnRMaXN0ZW5lcignbW91c2VsZWF2ZScsIHRoaXMuI2JvdW5kTGVhdmVIYW5kbGVyKVxuXG5cdFx0dGhpcy4jYm91bmRFbnRlckhhbmRsZXIgPSBudWxsXG5cdFx0dGhpcy4jYm91bmRMZWF2ZUhhbmRsZXIgPSBudWxsXG5cdH1cblxuXHQjY3JlYXRlVG9vbHRpcCgpIHtcblx0XHR0aGlzLiN0b29sdGlwID0gZG9jdW1lbnQuY3JlYXRlRWxlbWVudCgnZGl2JylcblxuXHRcdGlmICh0aGlzLiNjb250ZW50U2VsZWN0b3IpIHtcblx0XHRcdHRoaXMuI29ic2VydmVyXG5cdFx0XHRcdC53YWl0KHRoaXMuI2NvbnRlbnRTZWxlY3RvciwgbnVsbCwgeyBldmVudHM6IFtET01PYnNlcnZlci5FWElTVCwgRE9NT2JzZXJ2ZXIuQUREXSB9KVxuXHRcdFx0XHQudGhlbigoeyBub2RlIH0pID0+IHtcblx0XHRcdFx0XHRjb25zdCBjaGlsZCA9IHRoaXMuI2NvbnRlbnRDbG9uZSA/IG5vZGUuY2xvbmVOb2RlKHRydWUpIDogbm9kZVxuXHRcdFx0XHRcdHRoaXMuI3Rvb2x0aXAuYXBwZW5kQ2hpbGQoY2hpbGQpXG5cdFx0XHRcdH0pXG5cdFx0fSBlbHNlIGlmICh0aGlzLiNjb250ZW50KSB7XG5cdFx0XHRjb25zdCBjaGlsZCA9IGRvY3VtZW50LmNyZWF0ZVRleHROb2RlKHRoaXMuI2NvbnRlbnQpXG5cdFx0XHR0aGlzLiN0b29sdGlwLmFwcGVuZENoaWxkKGNoaWxkKVxuXHRcdH1cblx0fVxuXG5cdCNwb3NpdGlvblRvb2x0aXAoKSB7XG5cdFx0Y29uc3QgeyB3aWR0aDogdGFyZ2V0V2lkdGgsIGhlaWdodDogdGFyZ2V0SGVpZ2h0IH0gPSB0aGlzLiN0YXJnZXQuZ2V0Qm91bmRpbmdDbGllbnRSZWN0KClcblx0XHRjb25zdCB7IHdpZHRoOiB0b29sdGlwV2lkdGgsIGhlaWdodDogdG9vbHRpcEhlaWdodCB9ID0gdGhpcy4jdG9vbHRpcC5nZXRCb3VuZGluZ0NsaWVudFJlY3QoKVxuXHRcdHN3aXRjaCAodGhpcy4jcG9zaXRpb24pIHtcblx0XHRcdGNhc2UgJ2xlZnQnOiB7XG5cdFx0XHRcdHRoaXMuI3Rvb2x0aXAuc3R5bGUudG9wID0gYCR7LSh0b29sdGlwSGVpZ2h0IC0gdGFyZ2V0SGVpZ2h0KSA+PiAxfXB4YFxuXHRcdFx0XHR0aGlzLiN0b29sdGlwLnN0eWxlLmxlZnQgPSBgJHstdG9vbHRpcFdpZHRoIC0gVG9vbHRpcC5HQVB9cHhgXG5cdFx0XHRcdHRoaXMuI3Rvb2x0aXAuc3R5bGUuYm90dG9tID0gbnVsbFxuXHRcdFx0XHR0aGlzLiN0b29sdGlwLnN0eWxlLnJpZ2h0ID0gbnVsbFxuXHRcdFx0XHRicmVha1xuXHRcdFx0fVxuXHRcdFx0Y2FzZSAncmlnaHQnOiB7XG5cdFx0XHRcdHRoaXMuI3Rvb2x0aXAuc3R5bGUudG9wID0gYCR7LSh0b29sdGlwSGVpZ2h0IC0gdGFyZ2V0SGVpZ2h0KSA+PiAxfXB4YFxuXHRcdFx0XHR0aGlzLiN0b29sdGlwLnN0eWxlLnJpZ2h0ID0gYCR7LXRvb2x0aXBXaWR0aCAtIFRvb2x0aXAuR0FQfXB4YFxuXHRcdFx0XHR0aGlzLiN0b29sdGlwLnN0eWxlLmJvdHRvbSA9IG51bGxcblx0XHRcdFx0dGhpcy4jdG9vbHRpcC5zdHlsZS5sZWZ0ID0gbnVsbFxuXHRcdFx0XHRicmVha1xuXHRcdFx0fVxuXHRcdFx0Y2FzZSAnYm90dG9tJzoge1xuXHRcdFx0XHR0aGlzLiN0b29sdGlwLnN0eWxlLmxlZnQgPSBgJHstKHRvb2x0aXBXaWR0aCAtIHRhcmdldFdpZHRoKSA+PiAxfXB4YFxuXHRcdFx0XHR0aGlzLiN0b29sdGlwLnN0eWxlLmJvdHRvbSA9IGAkey10b29sdGlwSGVpZ2h0IC0gVG9vbHRpcC5HQVB9cHhgXG5cdFx0XHRcdHRoaXMuI3Rvb2x0aXAuc3R5bGUucmlnaHQgPSBudWxsXG5cdFx0XHRcdHRoaXMuI3Rvb2x0aXAuc3R5bGUudG9wID0gbnVsbFxuXHRcdFx0XHRicmVha1xuXHRcdFx0fVxuXHRcdFx0ZGVmYXVsdDoge1xuXHRcdFx0XHR0aGlzLiN0b29sdGlwLnN0eWxlLmxlZnQgPSBgJHstKHRvb2x0aXBXaWR0aCAtIHRhcmdldFdpZHRoKSA+PiAxfXB4YFxuXHRcdFx0XHR0aGlzLiN0b29sdGlwLnN0eWxlLnRvcCA9IGAkey10b29sdGlwSGVpZ2h0IC0gVG9vbHRpcC5HQVB9cHhgXG5cdFx0XHRcdHRoaXMuI3Rvb2x0aXAuc3R5bGUucmlnaHQgPSBudWxsXG5cdFx0XHRcdHRoaXMuI3Rvb2x0aXAuc3R5bGUuYm90dG9tID0gbnVsbFxuXHRcdFx0fVxuXHRcdH1cblx0fVxuXG5cdGFzeW5jICNhcHBlbmRUb29sdGlwVG9UYXJnZXQoKSB7XG5cdFx0aWYgKHRoaXMuI2FuaW1hdGVkKSB7XG5cdFx0XHRhd2FpdCB0aGlzLiN0cmFuc2l0aW9uVG9vbHRpcCgxKVxuXHRcdH1cblxuXHRcdHRoaXMuI3RhcmdldC5hcHBlbmRDaGlsZCh0aGlzLiN0b29sdGlwKVxuXHRcdHRoaXMuI29ic2VydmVyLndhaXQodGhpcy4jdG9vbHRpcCwgbnVsbCwgeyBldmVudHM6IFtET01PYnNlcnZlci5FWElTVCwgRE9NT2JzZXJ2ZXIuQUREXSB9KS50aGVuKCgpID0+IHtcblx0XHRcdHRoaXMuI3Bvc2l0aW9uVG9vbHRpcCgpXG5cdFx0fSlcblxuXHRcdGlmICh0aGlzLiNjb250ZW50QWN0aW9ucykge1xuXHRcdFx0T2JqZWN0LmVudHJpZXModGhpcy4jY29udGVudEFjdGlvbnMpLmZvckVhY2goXG5cdFx0XHRcdChba2V5LCB7IGV2ZW50VHlwZSwgY2FsbGJhY2ssIGNhbGxiYWNrUGFyYW1zLCBjbG9zZU9uQ2FsbGJhY2sgfV0pID0+IHtcblx0XHRcdFx0XHRjb25zdCB0cmlnZ2VyID0ga2V5ID09PSAnKicgPyB0aGlzLiN0b29sdGlwIDogdGhpcy4jdG9vbHRpcC5xdWVyeVNlbGVjdG9yKGtleSlcblx0XHRcdFx0XHRpZiAodHJpZ2dlcikge1xuXHRcdFx0XHRcdFx0Y29uc3QgbGlzdGVuZXIgPSAoZXZlbnQpID0+IHtcblx0XHRcdFx0XHRcdFx0Y2FsbGJhY2s/LmFwcGx5KG51bGwsIFsuLi5jYWxsYmFja1BhcmFtcywgZXZlbnRdKVxuXHRcdFx0XHRcdFx0XHRpZiAoY2xvc2VPbkNhbGxiYWNrKSB7XG5cdFx0XHRcdFx0XHRcdFx0dGhpcy4jcmVtb3ZlVG9vbHRpcEZyb21UYXJnZXQoKVxuXHRcdFx0XHRcdFx0XHR9XG5cdFx0XHRcdFx0XHR9XG5cdFx0XHRcdFx0XHR0cmlnZ2VyLmFkZEV2ZW50TGlzdGVuZXIoZXZlbnRUeXBlLCBsaXN0ZW5lcilcblx0XHRcdFx0XHRcdHRoaXMuI2V2ZW50cy5wdXNoKHsgdHJpZ2dlciwgZXZlbnRUeXBlLCBsaXN0ZW5lciB9KVxuXHRcdFx0XHRcdH1cblx0XHRcdFx0fVxuXHRcdFx0KVxuXHRcdH1cblx0fVxuXG5cdGFzeW5jICNyZW1vdmVUb29sdGlwRnJvbVRhcmdldCgpIHtcblx0XHRpZiAodGhpcy4jYW5pbWF0ZWQpIHtcblx0XHRcdGF3YWl0IHRoaXMuI3RyYW5zaXRpb25Ub29sdGlwKDApXG5cdFx0fVxuXG5cdFx0dGhpcy4jdG9vbHRpcC5yZW1vdmUoKVxuXG5cdFx0dGhpcy4jZXZlbnRzLmZvckVhY2goKHsgdHJpZ2dlciwgZXZlbnRUeXBlLCBsaXN0ZW5lciB9KSA9PiB0cmlnZ2VyLnJlbW92ZUV2ZW50TGlzdGVuZXIoZXZlbnRUeXBlLCBsaXN0ZW5lcikpXG5cdFx0dGhpcy4jZXZlbnRzID0gW11cblx0fVxuXG5cdCN3YWl0Rm9yRGVsYXkoZGVsYXkpIHtcblx0XHR0aGlzLiNjbGVhckRlbGF5KClcblx0XHRyZXR1cm4gbmV3IFByb21pc2UoXG5cdFx0XHQocmVzb2x2ZSkgPT5cblx0XHRcdFx0KHRoaXMuI2RlbGF5ID0gc2V0VGltZW91dCgoKSA9PiB7XG5cdFx0XHRcdFx0dGhpcy4jY2xlYXJEZWxheSgpXG5cdFx0XHRcdFx0cmVzb2x2ZSgpXG5cdFx0XHRcdH0sIGRlbGF5KSlcblx0XHQpXG5cdH1cblxuXHQjY2xlYXJEZWxheSgpIHtcblx0XHRjbGVhclRpbWVvdXQodGhpcy4jZGVsYXkpXG5cdFx0dGhpcy4jZGVsYXkgPSBudWxsXG5cdH1cblxuXHQjdHJhbnNpdGlvblRvb2x0aXAoZGlyZWN0aW9uKSB7XG5cdFx0cmV0dXJuIG5ldyBQcm9taXNlKChyZXNvbHZlKSA9PiB7XG5cdFx0XHRsZXQgY2xhc3NUb0FkZCwgY2xhc3NUb1JlbW92ZVxuXHRcdFx0c3dpdGNoIChkaXJlY3Rpb24pIHtcblx0XHRcdFx0Y2FzZSAxOiB7XG5cdFx0XHRcdFx0Y2xhc3NUb0FkZCA9IHRoaXMuI2FuaW1hdGlvbkVudGVyQ2xhc3NOYW1lXG5cdFx0XHRcdFx0Y2xhc3NUb1JlbW92ZSA9IHRoaXMuI2FuaW1hdGlvbkxlYXZlQ2xhc3NOYW1lXG5cdFx0XHRcdFx0YnJlYWtcblx0XHRcdFx0fVxuXHRcdFx0XHRkZWZhdWx0OiB7XG5cdFx0XHRcdFx0Y2xhc3NUb0FkZCA9IHRoaXMuI2FuaW1hdGlvbkxlYXZlQ2xhc3NOYW1lXG5cdFx0XHRcdFx0Y2xhc3NUb1JlbW92ZSA9IHRoaXMuI2FuaW1hdGlvbkVudGVyQ2xhc3NOYW1lXG5cdFx0XHRcdH1cblx0XHRcdH1cblx0XHRcdHRoaXMuI3Rvb2x0aXAuY2xhc3NMaXN0LmFkZChjbGFzc1RvQWRkKVxuXHRcdFx0dGhpcy4jdG9vbHRpcC5jbGFzc0xpc3QucmVtb3ZlKGNsYXNzVG9SZW1vdmUpXG5cblx0XHRcdGlmIChkaXJlY3Rpb24gPT09IDEpIHtcblx0XHRcdFx0cmVzb2x2ZSgpXG5cdFx0XHR9XG5cblx0XHRcdGNvbnN0IG9uVHJhbnNpdGlvbkVuZCA9ICgpID0+IHtcblx0XHRcdFx0dGhpcy4jdG9vbHRpcC5yZW1vdmVFdmVudExpc3RlbmVyKCdhbmltYXRpb25lbmQnLCBvblRyYW5zaXRpb25FbmQpXG5cdFx0XHRcdHRoaXMuI3Rvb2x0aXAuY2xhc3NMaXN0LnJlbW92ZShjbGFzc1RvQWRkKVxuXHRcdFx0XHRyZXNvbHZlKClcblx0XHRcdH1cblx0XHRcdHRoaXMuI3Rvb2x0aXAuYWRkRXZlbnRMaXN0ZW5lcignYW5pbWF0aW9uZW5kJywgb25UcmFuc2l0aW9uRW5kKVxuXHRcdH0pXG5cdH1cblxuXHRhc3luYyAjb25UYXJnZXRFbnRlcigpIHtcblx0XHRhd2FpdCB0aGlzLiN3YWl0Rm9yRGVsYXkodGhpcy4jZW50ZXJEZWxheSlcblx0XHRhd2FpdCB0aGlzLiNhcHBlbmRUb29sdGlwVG9UYXJnZXQoKVxuXHR9XG5cblx0YXN5bmMgI29uVGFyZ2V0TGVhdmUoKSB7XG5cdFx0YXdhaXQgdGhpcy4jd2FpdEZvckRlbGF5KHRoaXMuI2xlYXZlRGVsYXkpXG5cdFx0YXdhaXQgdGhpcy4jcmVtb3ZlVG9vbHRpcEZyb21UYXJnZXQoKVxuXHR9XG59XG5cbmV4cG9ydCBkZWZhdWx0IFRvb2x0aXBcbiIsImZ1bmN0aW9uIHN0eWxlSW5qZWN0KGNzcywgcmVmKSB7XG4gIGlmICggcmVmID09PSB2b2lkIDAgKSByZWYgPSB7fTtcbiAgdmFyIGluc2VydEF0ID0gcmVmLmluc2VydEF0O1xuXG4gIGlmICghY3NzIHx8IHR5cGVvZiBkb2N1bWVudCA9PT0gJ3VuZGVmaW5lZCcpIHsgcmV0dXJuOyB9XG5cbiAgdmFyIGhlYWQgPSBkb2N1bWVudC5oZWFkIHx8IGRvY3VtZW50LmdldEVsZW1lbnRzQnlUYWdOYW1lKCdoZWFkJylbMF07XG4gIHZhciBzdHlsZSA9IGRvY3VtZW50LmNyZWF0ZUVsZW1lbnQoJ3N0eWxlJyk7XG4gIHN0eWxlLnR5cGUgPSAndGV4dC9jc3MnO1xuXG4gIGlmIChpbnNlcnRBdCA9PT0gJ3RvcCcpIHtcbiAgICBpZiAoaGVhZC5maXJzdENoaWxkKSB7XG4gICAgICBoZWFkLmluc2VydEJlZm9yZShzdHlsZSwgaGVhZC5maXJzdENoaWxkKTtcbiAgICB9IGVsc2Uge1xuICAgICAgaGVhZC5hcHBlbmRDaGlsZChzdHlsZSk7XG4gICAgfVxuICB9IGVsc2Uge1xuICAgIGhlYWQuYXBwZW5kQ2hpbGQoc3R5bGUpO1xuICB9XG5cbiAgaWYgKHN0eWxlLnN0eWxlU2hlZXQpIHtcbiAgICBzdHlsZS5zdHlsZVNoZWV0LmNzc1RleHQgPSBjc3M7XG4gIH0gZWxzZSB7XG4gICAgc3R5bGUuYXBwZW5kQ2hpbGQoZG9jdW1lbnQuY3JlYXRlVGV4dE5vZGUoY3NzKSk7XG4gIH1cbn1cblxuZXhwb3J0IGRlZmF1bHQgc3R5bGVJbmplY3Q7XG4iLCJpbXBvcnQgVG9vbHRpcCBmcm9tICcuL1Rvb2x0aXAnXG5cbmltcG9ydCAnLi91c2VUb29sdGlwLmNzcydcblxuY29uc3QgdXNlVG9vbHRpcCA9IChcblx0bm9kZSxcblx0e1xuXHRcdGNvbnRlbnQsXG5cdFx0Y29udGVudFNlbGVjdG9yLFxuXHRcdGNvbnRlbnRDbG9uZSxcblx0XHRjb250ZW50QWN0aW9ucyxcblx0XHRjb250YWluZXJDbGFzc05hbWUsXG5cdFx0cG9zaXRpb24sXG5cdFx0YW5pbWF0ZWQsXG5cdFx0YW5pbWF0aW9uRW50ZXJDbGFzc05hbWUsXG5cdFx0YW5pbWF0aW9uTGVhdmVDbGFzc05hbWUsXG5cdFx0ZW50ZXJEZWxheSxcblx0XHRsZWF2ZURlbGF5LFxuXHRcdGRpc2FibGVkLFxuXHR9XG4pID0+IHtcblx0Y29uc3QgdG9vbHRpcCA9IG5ldyBUb29sdGlwKFxuXHRcdG5vZGUsXG5cdFx0Y29udGVudCxcblx0XHRjb250ZW50U2VsZWN0b3IsXG5cdFx0Y29udGVudENsb25lLFxuXHRcdGNvbnRlbnRBY3Rpb25zLFxuXHRcdGNvbnRhaW5lckNsYXNzTmFtZSxcblx0XHRwb3NpdGlvbixcblx0XHRhbmltYXRlZCxcblx0XHRhbmltYXRpb25FbnRlckNsYXNzTmFtZSxcblx0XHRhbmltYXRpb25MZWF2ZUNsYXNzTmFtZSxcblx0XHRlbnRlckRlbGF5LFxuXHRcdGxlYXZlRGVsYXksXG5cdFx0ZGlzYWJsZWRcblx0KVxuXG5cdHJldHVybiB7XG5cdFx0dXBkYXRlOiAoe1xuXHRcdFx0Y29udGVudDogbmV3Q29udGVudCxcblx0XHRcdGNvbnRlbnRTZWxlY3RvcjogbmV3Q29udGVudFNlbGVjdG9yLFxuXHRcdFx0Y29udGVudENsb25lOiBuZXdDb250ZW50Q2xvbmUsXG5cdFx0XHRjb250ZW50QWN0aW9uczogbmV3Q29udGVudEFjdGlvbnMsXG5cdFx0XHRjb250YWluZXJDbGFzc05hbWU6IG5ld0NvbnRhaW5lckNsYXNzTmFtZSxcblx0XHRcdHBvc2l0aW9uOiBuZXdQb3NpdGlvbixcblx0XHRcdGFuaW1hdGVkOiBuZXdBbmltYXRlZCxcblx0XHRcdGFuaW1hdGlvbkVudGVyQ2xhc3NOYW1lOiBuZXdBbmltYXRpb25FbnRlckNsYXNzTmFtZSxcblx0XHRcdGFuaW1hdGlvbkxlYXZlQ2xhc3NOYW1lOiBuZXdBbmltYXRpb25MZWF2ZUNsYXNzTmFtZSxcblx0XHRcdGVudGVyRGVsYXk6IG5ld0VudGVyRGVsYXksXG5cdFx0XHRsZWF2ZURlbGF5OiBuZXdMZWF2ZURlbGF5LFxuXHRcdFx0ZGlzYWJsZWQ6IG5ld0Rpc2FibGVkLFxuXHRcdH0pID0+XG5cdFx0XHR0b29sdGlwLnVwZGF0ZShcblx0XHRcdFx0bmV3Q29udGVudCxcblx0XHRcdFx0bmV3Q29udGVudFNlbGVjdG9yLFxuXHRcdFx0XHRuZXdDb250ZW50Q2xvbmUsXG5cdFx0XHRcdG5ld0NvbnRlbnRBY3Rpb25zLFxuXHRcdFx0XHRuZXdDb250YWluZXJDbGFzc05hbWUsXG5cdFx0XHRcdG5ld1Bvc2l0aW9uLFxuXHRcdFx0XHRuZXdBbmltYXRlZCxcblx0XHRcdFx0bmV3QW5pbWF0aW9uRW50ZXJDbGFzc05hbWUsXG5cdFx0XHRcdG5ld0FuaW1hdGlvbkxlYXZlQ2xhc3NOYW1lLFxuXHRcdFx0XHRuZXdFbnRlckRlbGF5LFxuXHRcdFx0XHRuZXdMZWF2ZURlbGF5LFxuXHRcdFx0XHRuZXdEaXNhYmxlZFxuXHRcdFx0KSxcblx0XHRkZXN0cm95OiAoKSA9PiB0b29sdGlwLmRlc3Ryb3koKSxcblx0fVxufVxuXG5leHBvcnQgZGVmYXVsdCB1c2VUb29sdGlwXG4iXSwibmFtZXMiOlsiZSIsInIiLCJsZW5ndGgiLCJ0IiwibiIsIkFycmF5IiwiaXNBcnJheSIsIk9iamVjdCIsInByb3RvdHlwZSIsInRvU3RyaW5nIiwiY2FsbCIsInNsaWNlIiwiY29uc3RydWN0b3IiLCJuYW1lIiwiZnJvbSIsInRlc3QiLCJpIiwiU3ltYm9sIiwiaXRlcmF0b3IiLCJUeXBlRXJyb3IiLCJvIiwidSIsImVudW1lcmFibGUiLCJjb25maWd1cmFibGUiLCJ3cml0YWJsZSIsImRlZmluZVByb3BlcnR5Iiwia2V5IiwiYyIsInZhbHVlIiwiZiIsIm5vZGVUeXBlIiwicyIsImQiLCJkb25lIiwiYSIsIm5leHQiLCJyZXR1cm4iLCJ2IiwidGhpcyIsImwiLCJhcmd1bWVudHMiLCJldmVudHMiLCJFVkVOVFMiLCJ0aW1lb3V0IiwiYXR0cmlidXRlRmlsdGVyIiwiYiIsIm9uRXJyb3IiLCJtIiwiY2xlYXIiLCJQcm9taXNlIiwiZG9jdW1lbnQiLCJxdWVyeVNlbGVjdG9yIiwiaW5jbHVkZXMiLCJFWElTVCIsIm5vZGUiLCJldmVudCIsIl90aW1lb3V0Iiwic2V0VGltZW91dCIsIkVycm9yIiwiY29uY2F0IiwiX29ic2VydmVyIiwiTXV0YXRpb25PYnNlcnZlciIsImZvckVhY2giLCJ0eXBlIiwidGFyZ2V0IiwiYWRkZWROb2RlcyIsInJlbW92ZWROb2RlcyIsImF0dHJpYnV0ZU5hbWUiLCJvbGRWYWx1ZSIsIkFERCIsIlJFTU9WRSIsInkiLCJFIiwiaCIsIkEiLCJtYXRjaGVzIiwiQ0hBTkdFIiwib3B0aW9ucyIsIm9ic2VydmUiLCJkb2N1bWVudEVsZW1lbnQiLCJzdWJ0cmVlIiwiY2hpbGRMaXN0IiwiYXR0cmlidXRlcyIsImF0dHJpYnV0ZU9sZFZhbHVlIiwiZGlzY29ubmVjdCIsImNsZWFyVGltZW91dCIsIlRvb2x0aXAiLCJHQVAiLCJpbnN0YW5jZXMiLCJpbnN0YW5jZSIsImRlc3Ryb3kiLCJjb250ZW50IiwiY29udGVudFNlbGVjdG9yIiwiY29udGVudENsb25lIiwiY29udGVudEFjdGlvbnMiLCJjb250YWluZXJDbGFzc05hbWUiLCJwb3NpdGlvbiIsImFuaW1hdGVkIiwiYW5pbWF0aW9uRW50ZXJDbGFzc05hbWUiLCJhbmltYXRpb25MZWF2ZUNsYXNzTmFtZSIsImVudGVyRGVsYXkiLCJsZWF2ZURlbGF5IiwiZGlzYWJsZWQiLCJvYnNlcnZlciIsIkRPTU9ic2VydmVyIiwidGl0bGUiLCJzZXRBdHRyaWJ1dGUiLCJjcmVhdGVUb29sdGlwIiwidG9vbHRpcCIsImNsYXNzTGlzdCIsImFkZCIsImRpc2FibGVUYXJnZXQiLCJlbmFibGVUYXJnZXQiLCJwdXNoIiwidXBkYXRlIiwiaGFzQ29udGVudENoYW5nZWQiLCJoYXNDb250YWluZXJDbGFzc05hbWVDaGFuZ2VkIiwib2xkUG9zaXRpb24iLCJoYXNQb3NpdGlvbkNoYW5nZWQiLCJoYXNUb0Rpc2FibGVUYXJnZXQiLCJib3VuZEVudGVySGFuZGxlciIsImhhc1RvRW5hYmxlVGFyZ2V0IiwicmVtb3ZlVG9vbHRpcEZyb21UYXJnZXQiLCJyZW1vdmUiLCJjbGVhckRlbGF5Iiwib25UYXJnZXRFbnRlciIsImJpbmQiLCJib3VuZExlYXZlSGFuZGxlciIsIm9uVGFyZ2V0TGVhdmUiLCJhZGRFdmVudExpc3RlbmVyIiwicmVtb3ZlRXZlbnRMaXN0ZW5lciIsImNyZWF0ZUVsZW1lbnQiLCJ3YWl0IiwidGhlbiIsImNoaWxkIiwiY2xvbmVOb2RlIiwiYXBwZW5kQ2hpbGQiLCJjcmVhdGVUZXh0Tm9kZSIsIndpZHRoIiwidGFyZ2V0V2lkdGgiLCJoZWlnaHQiLCJ0YXJnZXRIZWlnaHQiLCJnZXRCb3VuZGluZ0NsaWVudFJlY3QiLCJ0b29sdGlwV2lkdGgiLCJ0b29sdGlwSGVpZ2h0Iiwic3R5bGUiLCJ0b3AiLCJsZWZ0IiwiYm90dG9tIiwicmlnaHQiLCJ0cmFuc2l0aW9uVG9vbHRpcCIsInBvc2l0aW9uVG9vbHRpcCIsImVudHJpZXMiLCJldmVudFR5cGUiLCJjYWxsYmFjayIsImNhbGxiYWNrUGFyYW1zIiwiY2xvc2VPbkNhbGxiYWNrIiwidHJpZ2dlciIsImxpc3RlbmVyIiwiYXBwbHkiLCJkZWxheSIsInJlc29sdmUiLCJkaXJlY3Rpb24iLCJjbGFzc1RvQWRkIiwiY2xhc3NUb1JlbW92ZSIsIm9uVHJhbnNpdGlvbkVuZCIsIndhaXRGb3JEZWxheSIsImFwcGVuZFRvb2x0aXBUb1RhcmdldCIsImNzcyIsInJlZiIsImluc2VydEF0IiwiaGVhZCIsImdldEVsZW1lbnRzQnlUYWdOYW1lIiwiZmlyc3RDaGlsZCIsImluc2VydEJlZm9yZSIsInN0eWxlU2hlZXQiLCJjc3NUZXh0IiwibmV3Q29udGVudCIsIm5ld0NvbnRlbnRTZWxlY3RvciIsIm5ld0NvbnRlbnRDbG9uZSIsIm5ld0NvbnRlbnRBY3Rpb25zIiwibmV3Q29udGFpbmVyQ2xhc3NOYW1lIiwibmV3UG9zaXRpb24iLCJuZXdBbmltYXRlZCIsIm5ld0FuaW1hdGlvbkVudGVyQ2xhc3NOYW1lIiwibmV3QW5pbWF0aW9uTGVhdmVDbGFzc05hbWUiLCJuZXdFbnRlckRlbGF5IiwibmV3TGVhdmVEZWxheSIsIm5ld0Rpc2FibGVkIl0sIm1hcHBpbmdzIjoib0VBQUEsSUFBSUEsRUFBRSxTQUFTQSxFQUFFQyxJQUFJLE1BQU1BLEdBQUdBLEVBQUVELEVBQUVFLFVBQVVELEVBQUVELEVBQUVFLFFBQVEsSUFBSSxJQUFJQyxFQUFFLEVBQUVDLEVBQUUsSUFBSUMsTUFBTUosR0FBR0UsRUFBRUYsRUFBRUUsSUFBSUMsRUFBRUQsR0FBR0gsRUFBRUcsR0FBRyxPQUFPQyxHQUFPSCxFQUFFLFNBQVNBLEdBQUcsR0FBR0ksTUFBTUMsUUFBUUwsR0FBRyxPQUFPRCxFQUFFQyxJQUE0R0csRUFBRSxTQUFTSCxFQUFFRSxHQUFHLEdBQUdGLEVBQUUsQ0FBQyxHQUFHLGlCQUFpQkEsRUFBRSxPQUFPRCxFQUFFQyxFQUFFRSxHQUFHLElBQUlDLEVBQUVHLE9BQU9DLFVBQVVDLFNBQVNDLEtBQUtULEdBQUdVLE1BQU0sR0FBRyxHQUFHLE1BQU0sV0FBV1AsR0FBR0gsRUFBRVcsY0FBY1IsRUFBRUgsRUFBRVcsWUFBWUMsTUFBTSxRQUFRVCxHQUFHLFFBQVFBLEVBQUVDLE1BQU1TLEtBQUtiLEdBQUcsY0FBY0csR0FBRywyQ0FBMkNXLEtBQUtYLEdBQUdKLEVBQUVDLEVBQUVFLFFBQUcsSUFBMkxhLEVBQUUsU0FBU2hCLEdBQUcsT0FBT0MsRUFBRUQsSUFBMWtCLFNBQVNBLEdBQUcsR0FBRyxvQkFBb0JpQixRQUFRQSxPQUFPQyxZQUFZWCxPQUFPUCxHQUFHLE9BQU9LLE1BQU1TLEtBQUtkLEdBQW9mRyxDQUFFSCxJQUFJSSxFQUFFSixJQUEvTSxXQUFXLE1BQU0sSUFBSW1CLFVBQVUs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\n","\r\n\r\n
\r\n
\r\n \r\n Hover me\r\n
\r\n \r\n
\r\n \r\n
\r\n

Settings

\r\n
\r\n \r\n
\r\n
\r\n \r\n
\r\n
\r\n \r\n
\r\n
\r\n \r\n
\r\n
\r\n \r\n
\r\n
\r\n \r\n
\r\n
\r\n \r\n
\r\n
\r\n \r\n
\r\n
\r\n \r\n
\r\n
\r\n \r\n
\r\n
\r\n
\r\n \r\n
\r\n\r\n\r\n","import App from './App.svelte'\r\n\r\nconst app = new App({\r\n\ttarget: document.body,\r\n})\r\n\r\nexport default app\r\n"],"names":[],"mappings":"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AAC,IAAI,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,OAAO,OAAO,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,OAAO,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,OAAO,GAAE,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,GAAE,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,EAAE,KAAK,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,EAAE,iBAAiB,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,EAAE,iBAAiB,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,KAAK,CAAC,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC,YAAY,CAAC,OAAO,CAAC,oB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"} \ No newline at end of file diff --git a/src/Tooltip.js b/src/Tooltip.js index 2197874..aab3efb 100644 --- a/src/Tooltip.js +++ b/src/Tooltip.js @@ -93,7 +93,6 @@ class Tooltip { ) { const hasContentChanged = contentSelector !== this.#contentSelector || content !== this.#content const hasContainerClassNameChanged = containerClassName !== this.#containerClassName - const oldPosition = this.#position const hasPositionChanged = position !== this.#position const hasToDisableTarget = disabled && this.#boundEnterHandler const hasToEnableTarget = !disabled && !this.#boundEnterHandler @@ -115,13 +114,8 @@ class Tooltip { this.#createTooltip() } - if (hasContainerClassNameChanged || hasContentChanged) { - this.#tooltip.classList.add(this.#containerClassName || '__tooltip') - } - - if (hasPositionChanged || hasContainerClassNameChanged || hasContentChanged) { - this.#tooltip.classList.remove(`__tooltip-${oldPosition}`) - this.#tooltip.classList.add(`__tooltip-${this.#position}`) + if (hasContainerClassNameChanged || hasContentChanged || hasPositionChanged) { + this.#tooltip.setAttribute('class', this.#containerClassName || `__tooltip __tooltip-${this.#position}`) } if (hasToDisableTarget) {