{"version":3,"file":"pxp.bundle.js","sources":["../../node_modules/component-register/dist/component-register.js","../../node_modules/solid-js/dist/solid.js","../../node_modules/solid-js/web/dist/web.js","../../node_modules/solid-element/dist/index.js","../../Common/lib/draggable.ts","../../Common/lib/tooltip.ts","../../Common/lib/visibleWith.ts","../../Common/lib/contextmenu.tsx","../../index.ts","../../pxpApp/index.tsx","../../pxpApp/components/pxp-datepicker/pxp-datepicker.tsx","../../pxpApp/components/pxp-launch-pad/pxp-launch-pad.tsx"],"sourcesContent":["function cloneProps(props) {\n const propKeys = Object.keys(props);\n return propKeys.reduce((memo, k) => {\n const prop = props[k];\n memo[k] = Object.assign({}, prop);\n if (isObject(prop.value) && !isFunction(prop.value) && !Array.isArray(prop.value)) memo[k].value = Object.assign({}, prop.value);\n if (Array.isArray(prop.value)) memo[k].value = prop.value.slice(0);\n return memo;\n }, {});\n}\n\nfunction normalizePropDefs(props) {\n if (!props) return {};\n const propKeys = Object.keys(props);\n return propKeys.reduce((memo, k) => {\n const v = props[k];\n memo[k] = !(isObject(v) && \"value\" in v) ? {\n value: v\n } : v;\n memo[k].attribute || (memo[k].attribute = toAttribute(k));\n memo[k].parse = \"parse\" in memo[k] ? memo[k].parse : typeof memo[k].value !== \"string\";\n return memo;\n }, {});\n}\nfunction propValues(props) {\n const propKeys = Object.keys(props);\n return propKeys.reduce((memo, k) => {\n memo[k] = props[k].value;\n return memo;\n }, {});\n}\nfunction initializeProps(element, propDefinition) {\n const props = cloneProps(propDefinition),\n propKeys = Object.keys(propDefinition);\n propKeys.forEach(key => {\n const prop = props[key],\n attr = element.getAttribute(prop.attribute),\n value = element[key];\n if (attr) prop.value = prop.parse ? parseAttributeValue(attr) : attr;\n if (value != null) prop.value = Array.isArray(value) ? value.slice(0) : value;\n prop.reflect && reflect(element, prop.attribute, prop.value);\n Object.defineProperty(element, key, {\n get() {\n return prop.value;\n },\n\n set(val) {\n const oldValue = prop.value;\n prop.value = val;\n prop.reflect && reflect(this, prop.attribute, prop.value);\n\n for (let i = 0, l = this.__propertyChangedCallbacks.length; i < l; i++) {\n this.__propertyChangedCallbacks[i](key, val, oldValue);\n }\n },\n\n enumerable: true,\n configurable: true\n });\n });\n return props;\n}\nfunction parseAttributeValue(value) {\n if (!value) return;\n\n try {\n return JSON.parse(value);\n } catch (err) {\n return value;\n }\n}\nfunction reflect(node, attribute, value) {\n if (value == null || value === false) return node.removeAttribute(attribute);\n let reflect = JSON.stringify(value);\n node.__updating[attribute] = true;\n if (reflect === \"true\") reflect = \"\";\n node.setAttribute(attribute, reflect);\n Promise.resolve().then(() => delete node.__updating[attribute]);\n}\nfunction toAttribute(propName) {\n return propName.replace(/\\.?([A-Z]+)/g, (x, y) => \"-\" + y.toLowerCase()).replace(\"_\", \"-\").replace(/^-/, \"\");\n}\nfunction toProperty(attr) {\n return attr.toLowerCase().replace(/(-)([a-z])/g, test => test.toUpperCase().replace(\"-\", \"\"));\n}\nfunction isObject(obj) {\n return obj != null && (typeof obj === \"object\" || typeof obj === \"function\");\n}\nfunction isFunction(val) {\n return Object.prototype.toString.call(val) === \"[object Function]\";\n}\nfunction isConstructor(f) {\n return typeof f === \"function\" && f.toString().indexOf(\"class\") === 0;\n}\nfunction reloadElement(node) {\n let callback = null;\n\n while (callback = node.__releaseCallbacks.pop()) callback(node);\n\n delete node.__initialized;\n node.renderRoot.textContent = \"\";\n node.connectedCallback();\n}\n\nlet currentElement;\nfunction getCurrentElement() {\n return currentElement;\n}\nfunction noShadowDOM() {\n Object.defineProperty(currentElement, \"renderRoot\", {\n value: currentElement\n });\n}\nfunction createElementType(BaseElement, propDefinition) {\n const propKeys = Object.keys(propDefinition);\n return class CustomElement extends BaseElement {\n static get observedAttributes() {\n return propKeys.map(k => propDefinition[k].attribute);\n }\n\n constructor() {\n super();\n this.__initialized = false;\n this.__released = false;\n this.__releaseCallbacks = [];\n this.__propertyChangedCallbacks = [];\n this.__updating = {};\n this.props = {};\n }\n\n connectedCallback() {\n if (this.__initialized) return;\n this.__releaseCallbacks = [];\n this.__propertyChangedCallbacks = [];\n this.__updating = {};\n this.props = initializeProps(this, propDefinition);\n const props = propValues(this.props),\n ComponentType = this.Component,\n outerElement = currentElement;\n\n try {\n currentElement = this;\n this.__initialized = true;\n if (isConstructor(ComponentType)) new ComponentType(props, {\n element: this\n });else ComponentType(props, {\n element: this\n });\n } finally {\n currentElement = outerElement;\n }\n }\n\n async disconnectedCallback() {\n // prevent premature releasing when element is only temporarely removed from DOM\n await Promise.resolve();\n if (this.isConnected) return;\n this.__propertyChangedCallbacks.length = 0;\n let callback = null;\n\n while (callback = this.__releaseCallbacks.pop()) callback(this);\n\n delete this.__initialized;\n this.__released = true;\n }\n\n attributeChangedCallback(name, oldVal, newVal) {\n if (!this.__initialized) return;\n if (this.__updating[name]) return;\n name = this.lookupProp(name);\n\n if (name in propDefinition) {\n if (newVal == null && !this[name]) return;\n this[name] = propDefinition[name].parse ? parseAttributeValue(newVal) : newVal;\n }\n }\n\n lookupProp(attrName) {\n if (!propDefinition) return;\n return propKeys.find(k => attrName === k || attrName === propDefinition[k].attribute);\n }\n\n get renderRoot() {\n return this.shadowRoot || this.attachShadow({\n mode: \"open\"\n });\n }\n\n addReleaseCallback(fn) {\n this.__releaseCallbacks.push(fn);\n }\n\n addPropertyChangedCallback(fn) {\n this.__propertyChangedCallbacks.push(fn);\n }\n\n };\n}\n\nfunction createMixin(mixinFn) {\n return ComponentType => (props, options) => {\n options = mixinFn(options);\n if (isConstructor(ComponentType)) return new ComponentType(props, options);\n return ComponentType(props, options);\n };\n}\nfunction compose(...fns) {\n if (fns.length === 0) return i => i;\n if (fns.length === 1) return fns[0];\n return fns.reduce((a, b) => (...args) => a(b(...args)));\n}\n\nconst EC = Symbol('element-context');\n\nfunction lookupContext(element, context) {\n return element[EC] && element[EC][context.id] || (element.host || element.parentNode) && lookupContext(element.host || element.parentNode, context);\n}\n\nfunction createContext(initFn) {\n return {\n id: Symbol('context'),\n initFn\n };\n} // Direct\n\nfunction provide(context, value, element = getCurrentElement()) {\n element[EC] || (element[EC] = {});\n return element[EC][context.id] = context.initFn ? context.initFn(value) : value;\n}\nfunction consume(context, element = getCurrentElement()) {\n return lookupContext(element, context);\n} // HOCs\n\nfunction withProvider(context, value) {\n return createMixin(options => {\n const {\n element\n } = options;\n provide(context, value, element);\n return options;\n });\n}\nfunction withConsumer(context, key) {\n return createMixin(options => {\n const {\n element\n } = options;\n options = Object.assign({}, options, {\n [key]: lookupContext(element, context)\n });\n return options;\n });\n}\n\nfunction walk(root, call) {\n call(root);\n if (root.shadowRoot) walk(root.shadowRoot, call);\n let child = root.firstChild;\n\n while (child) {\n child.nodeType === 1 && walk(child, call);\n child = child.nextSibling;\n }\n}\n\nfunction hot(module, tagName) {\n if (module.hot) {\n function update(possibleError) {\n if (possibleError && possibleError instanceof Error) {\n console.error(possibleError);\n return;\n }\n\n walk(document.body, node => node.localName === tagName && setTimeout(() => reloadElement(node), 0));\n } // handle both Parcel and Webpack style\n\n\n module.hot.accept(update);\n\n if (module.hot.status && module.hot.status() === 'apply') {\n update();\n }\n }\n}\n\nfunction register(tag, props = {}, options = {}) {\n const {\n BaseElement = HTMLElement,\n extension\n } = options;\n return ComponentType => {\n if (!tag) throw new Error(\"tag is required to register a Component\");\n let ElementType = customElements.get(tag);\n\n if (ElementType) {\n // Consider disabling this in a production mode\n ElementType.prototype.Component = ComponentType;\n return ElementType;\n }\n\n ElementType = createElementType(BaseElement, normalizePropDefs(props));\n ElementType.prototype.Component = ComponentType;\n ElementType.prototype.registeredTag = tag;\n customElements.define(tag, ElementType, extension);\n return ElementType;\n };\n}\n\nexport { compose, consume, createContext, createMixin, getCurrentElement, hot, isConstructor, isFunction, isObject, noShadowDOM, provide, register, reloadElement, toAttribute, toProperty, withConsumer, withProvider };\n","let taskIdCounter = 1,\n isCallbackScheduled = false,\n isPerformingWork = false,\n taskQueue = [],\n currentTask = null,\n shouldYieldToHost = null,\n yieldInterval = 5,\n deadline = 0,\n maxYieldInterval = 300,\n scheduleCallback = null,\n scheduledCallback = null;\nconst maxSigned31BitInt = 1073741823;\nfunction setupScheduler() {\n const channel = new MessageChannel(),\n port = channel.port2;\n scheduleCallback = () => port.postMessage(null);\n channel.port1.onmessage = () => {\n if (scheduledCallback !== null) {\n const currentTime = performance.now();\n deadline = currentTime + yieldInterval;\n const hasTimeRemaining = true;\n try {\n const hasMoreWork = scheduledCallback(hasTimeRemaining, currentTime);\n if (!hasMoreWork) {\n scheduledCallback = null;\n } else port.postMessage(null);\n } catch (error) {\n port.postMessage(null);\n throw error;\n }\n }\n };\n if (navigator && navigator.scheduling && navigator.scheduling.isInputPending) {\n const scheduling = navigator.scheduling;\n shouldYieldToHost = () => {\n const currentTime = performance.now();\n if (currentTime >= deadline) {\n if (scheduling.isInputPending()) {\n return true;\n }\n return currentTime >= maxYieldInterval;\n } else {\n return false;\n }\n };\n } else {\n shouldYieldToHost = () => performance.now() >= deadline;\n }\n}\nfunction enqueue(taskQueue, task) {\n function findIndex() {\n let m = 0;\n let n = taskQueue.length - 1;\n while (m <= n) {\n const k = n + m >> 1;\n const cmp = task.expirationTime - taskQueue[k].expirationTime;\n if (cmp > 0) m = k + 1;else if (cmp < 0) n = k - 1;else return k;\n }\n return m;\n }\n taskQueue.splice(findIndex(), 0, task);\n}\nfunction requestCallback(fn, options) {\n if (!scheduleCallback) setupScheduler();\n let startTime = performance.now(),\n timeout = maxSigned31BitInt;\n if (options && options.timeout) timeout = options.timeout;\n const newTask = {\n id: taskIdCounter++,\n fn,\n startTime,\n expirationTime: startTime + timeout\n };\n enqueue(taskQueue, newTask);\n if (!isCallbackScheduled && !isPerformingWork) {\n isCallbackScheduled = true;\n scheduledCallback = flushWork;\n scheduleCallback();\n }\n return newTask;\n}\nfunction cancelCallback(task) {\n task.fn = null;\n}\nfunction flushWork(hasTimeRemaining, initialTime) {\n isCallbackScheduled = false;\n isPerformingWork = true;\n try {\n return workLoop(hasTimeRemaining, initialTime);\n } finally {\n currentTask = null;\n isPerformingWork = false;\n }\n}\nfunction workLoop(hasTimeRemaining, initialTime) {\n let currentTime = initialTime;\n currentTask = taskQueue[0] || null;\n while (currentTask !== null) {\n if (currentTask.expirationTime > currentTime && (!hasTimeRemaining || shouldYieldToHost())) {\n break;\n }\n const callback = currentTask.fn;\n if (callback !== null) {\n currentTask.fn = null;\n const didUserCallbackTimeout = currentTask.expirationTime <= currentTime;\n callback(didUserCallbackTimeout);\n currentTime = performance.now();\n if (currentTask === taskQueue[0]) {\n taskQueue.shift();\n }\n } else taskQueue.shift();\n currentTask = taskQueue[0] || null;\n }\n return currentTask !== null;\n}\n\nconst sharedConfig = {\n context: undefined,\n registry: undefined\n};\nfunction setHydrateContext(context) {\n sharedConfig.context = context;\n}\nfunction nextHydrateContext() {\n return {\n ...sharedConfig.context,\n id: `${sharedConfig.context.id}${sharedConfig.context.count++}-`,\n count: 0\n };\n}\n\nconst equalFn = (a, b) => a === b;\nconst $PROXY = Symbol(\"solid-proxy\");\nconst $TRACK = Symbol(\"solid-track\");\nconst $DEVCOMP = Symbol(\"solid-dev-component\");\nconst signalOptions = {\n equals: equalFn\n};\nlet ERROR = null;\nlet runEffects = runQueue;\nconst STALE = 1;\nconst PENDING = 2;\nconst UNOWNED = {\n owned: null,\n cleanups: null,\n context: null,\n owner: null\n};\nconst NO_INIT = {};\nvar Owner = null;\nlet Transition = null;\nlet Scheduler = null;\nlet ExternalSourceFactory = null;\nlet Listener = null;\nlet Updates = null;\nlet Effects = null;\nlet ExecCount = 0;\nconst [transPending, setTransPending] = /*@__PURE__*/createSignal(false);\nfunction createRoot(fn, detachedOwner) {\n const listener = Listener,\n owner = Owner,\n unowned = fn.length === 0,\n current = detachedOwner === undefined ? owner : detachedOwner,\n root = unowned ? UNOWNED : {\n owned: null,\n cleanups: null,\n context: current ? current.context : null,\n owner: current\n },\n updateFn = unowned ? fn : () => fn(() => untrack(() => cleanNode(root)));\n Owner = root;\n Listener = null;\n try {\n return runUpdates(updateFn, true);\n } finally {\n Listener = listener;\n Owner = owner;\n }\n}\nfunction createSignal(value, options) {\n options = options ? Object.assign({}, signalOptions, options) : signalOptions;\n const s = {\n value,\n observers: null,\n observerSlots: null,\n comparator: options.equals || undefined\n };\n const setter = value => {\n if (typeof value === \"function\") {\n if (Transition && Transition.running && Transition.sources.has(s)) value = value(s.tValue);else value = value(s.value);\n }\n return writeSignal(s, value);\n };\n return [readSignal.bind(s), setter];\n}\nfunction createComputed(fn, value, options) {\n const c = createComputation(fn, value, true, STALE);\n if (Scheduler && Transition && Transition.running) Updates.push(c);else updateComputation(c);\n}\nfunction createRenderEffect(fn, value, options) {\n const c = createComputation(fn, value, false, STALE);\n if (Scheduler && Transition && Transition.running) Updates.push(c);else updateComputation(c);\n}\nfunction createEffect(fn, value, options) {\n runEffects = runUserEffects;\n const c = createComputation(fn, value, false, STALE),\n s = SuspenseContext && useContext(SuspenseContext);\n if (s) c.suspense = s;\n if (!options || !options.render) c.user = true;\n Effects ? Effects.push(c) : updateComputation(c);\n}\nfunction createReaction(onInvalidate, options) {\n let fn;\n const c = createComputation(() => {\n fn ? fn() : untrack(onInvalidate);\n fn = undefined;\n }, undefined, false, 0),\n s = SuspenseContext && useContext(SuspenseContext);\n if (s) c.suspense = s;\n c.user = true;\n return tracking => {\n fn = tracking;\n updateComputation(c);\n };\n}\nfunction createMemo(fn, value, options) {\n options = options ? Object.assign({}, signalOptions, options) : signalOptions;\n const c = createComputation(fn, value, true, 0);\n c.observers = null;\n c.observerSlots = null;\n c.comparator = options.equals || undefined;\n if (Scheduler && Transition && Transition.running) {\n c.tState = STALE;\n Updates.push(c);\n } else updateComputation(c);\n return readSignal.bind(c);\n}\nfunction isPromise(v) {\n return v && typeof v === \"object\" && \"then\" in v;\n}\nfunction createResource(pSource, pFetcher, pOptions) {\n let source;\n let fetcher;\n let options;\n if (arguments.length === 2 && typeof pFetcher === \"object\" || arguments.length === 1) {\n source = true;\n fetcher = pSource;\n options = pFetcher || {};\n } else {\n source = pSource;\n fetcher = pFetcher;\n options = pOptions || {};\n }\n let pr = null,\n initP = NO_INIT,\n id = null,\n loadedUnderTransition = false,\n scheduled = false,\n resolved = (\"initialValue\" in options),\n dynamic = typeof source === \"function\" && createMemo(source);\n const contexts = new Set(),\n [value, setValue] = (options.storage || createSignal)(options.initialValue),\n [error, setError] = createSignal(undefined),\n [track, trigger] = createSignal(undefined, {\n equals: false\n }),\n [state, setState] = createSignal(resolved ? \"ready\" : \"unresolved\");\n if (sharedConfig.context) {\n id = `${sharedConfig.context.id}${sharedConfig.context.count++}`;\n let v;\n if (options.ssrLoadFrom === \"initial\") initP = options.initialValue;else if (sharedConfig.load && (v = sharedConfig.load(id))) initP = v;\n }\n function loadEnd(p, v, error, key) {\n if (pr === p) {\n pr = null;\n key !== undefined && (resolved = true);\n if ((p === initP || v === initP) && options.onHydrated) queueMicrotask(() => options.onHydrated(key, {\n value: v\n }));\n initP = NO_INIT;\n if (Transition && p && loadedUnderTransition) {\n Transition.promises.delete(p);\n loadedUnderTransition = false;\n runUpdates(() => {\n Transition.running = true;\n completeLoad(v, error);\n }, false);\n } else completeLoad(v, error);\n }\n return v;\n }\n function completeLoad(v, err) {\n runUpdates(() => {\n if (err === undefined) setValue(() => v);\n setState(err !== undefined ? \"errored\" : resolved ? \"ready\" : \"unresolved\");\n setError(err);\n for (const c of contexts.keys()) c.decrement();\n contexts.clear();\n }, false);\n }\n function read() {\n const c = SuspenseContext && useContext(SuspenseContext),\n v = value(),\n err = error();\n if (err !== undefined && !pr) throw err;\n if (Listener && !Listener.user && c) {\n createComputed(() => {\n track();\n if (pr) {\n if (c.resolved && Transition && loadedUnderTransition) Transition.promises.add(pr);else if (!contexts.has(c)) {\n c.increment();\n contexts.add(c);\n }\n }\n });\n }\n return v;\n }\n function load(refetching = true) {\n if (refetching !== false && scheduled) return;\n scheduled = false;\n const lookup = dynamic ? dynamic() : source;\n loadedUnderTransition = Transition && Transition.running;\n if (lookup == null || lookup === false) {\n loadEnd(pr, untrack(value));\n return;\n }\n if (Transition && pr) Transition.promises.delete(pr);\n const p = initP !== NO_INIT ? initP : untrack(() => fetcher(lookup, {\n value: value(),\n refetching\n }));\n if (!isPromise(p)) {\n loadEnd(pr, p, undefined, lookup);\n return p;\n }\n pr = p;\n if (\"value\" in p) {\n if (p.status === \"success\") loadEnd(pr, p.value, undefined, lookup);else loadEnd(pr, undefined, undefined, lookup);\n return p;\n }\n scheduled = true;\n queueMicrotask(() => scheduled = false);\n runUpdates(() => {\n setState(resolved ? \"refreshing\" : \"pending\");\n trigger();\n }, false);\n return p.then(v => loadEnd(p, v, undefined, lookup), e => loadEnd(p, undefined, castError(e), lookup));\n }\n Object.defineProperties(read, {\n state: {\n get: () => state()\n },\n error: {\n get: () => error()\n },\n loading: {\n get() {\n const s = state();\n return s === \"pending\" || s === \"refreshing\";\n }\n },\n latest: {\n get() {\n if (!resolved) return read();\n const err = error();\n if (err && !pr) throw err;\n return value();\n }\n }\n });\n if (dynamic) createComputed(() => load(false));else load(false);\n return [read, {\n refetch: load,\n mutate: setValue\n }];\n}\nfunction createDeferred(source, options) {\n let t,\n timeout = options ? options.timeoutMs : undefined;\n const node = createComputation(() => {\n if (!t || !t.fn) t = requestCallback(() => setDeferred(() => node.value), timeout !== undefined ? {\n timeout\n } : undefined);\n return source();\n }, undefined, true);\n const [deferred, setDeferred] = createSignal(Transition && Transition.running && Transition.sources.has(node) ? node.tValue : node.value, options);\n updateComputation(node);\n setDeferred(() => Transition && Transition.running && Transition.sources.has(node) ? node.tValue : node.value);\n return deferred;\n}\nfunction createSelector(source, fn = equalFn, options) {\n const subs = new Map();\n const node = createComputation(p => {\n const v = source();\n for (const [key, val] of subs.entries()) if (fn(key, v) !== fn(key, p)) {\n for (const c of val.values()) {\n c.state = STALE;\n if (c.pure) Updates.push(c);else Effects.push(c);\n }\n }\n return v;\n }, undefined, true, STALE);\n updateComputation(node);\n return key => {\n const listener = Listener;\n if (listener) {\n let l;\n if (l = subs.get(key)) l.add(listener);else subs.set(key, l = new Set([listener]));\n onCleanup(() => {\n l.delete(listener);\n !l.size && subs.delete(key);\n });\n }\n return fn(key, Transition && Transition.running && Transition.sources.has(node) ? node.tValue : node.value);\n };\n}\nfunction batch(fn) {\n return runUpdates(fn, false);\n}\nfunction untrack(fn) {\n if (Listener === null) return fn();\n const listener = Listener;\n Listener = null;\n try {\n return fn();\n } finally {\n Listener = listener;\n }\n}\nfunction on(deps, fn, options) {\n const isArray = Array.isArray(deps);\n let prevInput;\n let defer = options && options.defer;\n return prevValue => {\n let input;\n if (isArray) {\n input = Array(deps.length);\n for (let i = 0; i < deps.length; i++) input[i] = deps[i]();\n } else input = deps();\n if (defer) {\n defer = false;\n return undefined;\n }\n const result = untrack(() => fn(input, prevInput, prevValue));\n prevInput = input;\n return result;\n };\n}\nfunction onMount(fn) {\n createEffect(() => untrack(fn));\n}\nfunction onCleanup(fn) {\n if (Owner === null) ;else if (Owner.cleanups === null) Owner.cleanups = [fn];else Owner.cleanups.push(fn);\n return fn;\n}\nfunction catchError(fn, handler) {\n ERROR || (ERROR = Symbol(\"error\"));\n Owner = createComputation(undefined, undefined, true);\n Owner.context = {\n ...Owner.context,\n [ERROR]: [handler]\n };\n if (Transition && Transition.running) Transition.sources.add(Owner);\n try {\n return fn();\n } catch (err) {\n handleError(err);\n } finally {\n Owner = Owner.owner;\n }\n}\nfunction getListener() {\n return Listener;\n}\nfunction getOwner() {\n return Owner;\n}\nfunction runWithOwner(o, fn) {\n const prev = Owner;\n const prevListener = Listener;\n Owner = o;\n Listener = null;\n try {\n return runUpdates(fn, true);\n } catch (err) {\n handleError(err);\n } finally {\n Owner = prev;\n Listener = prevListener;\n }\n}\nfunction enableScheduling(scheduler = requestCallback) {\n Scheduler = scheduler;\n}\nfunction startTransition(fn) {\n if (Transition && Transition.running) {\n fn();\n return Transition.done;\n }\n const l = Listener;\n const o = Owner;\n return Promise.resolve().then(() => {\n Listener = l;\n Owner = o;\n let t;\n if (Scheduler || SuspenseContext) {\n t = Transition || (Transition = {\n sources: new Set(),\n effects: [],\n promises: new Set(),\n disposed: new Set(),\n queue: new Set(),\n running: true\n });\n t.done || (t.done = new Promise(res => t.resolve = res));\n t.running = true;\n }\n runUpdates(fn, false);\n Listener = Owner = null;\n return t ? t.done : undefined;\n });\n}\nfunction useTransition() {\n return [transPending, startTransition];\n}\nfunction resumeEffects(e) {\n Effects.push.apply(Effects, e);\n e.length = 0;\n}\nfunction createContext(defaultValue, options) {\n const id = Symbol(\"context\");\n return {\n id,\n Provider: createProvider(id),\n defaultValue\n };\n}\nfunction useContext(context) {\n return Owner && Owner.context && Owner.context[context.id] !== undefined ? Owner.context[context.id] : context.defaultValue;\n}\nfunction children(fn) {\n const children = createMemo(fn);\n const memo = createMemo(() => resolveChildren(children()));\n memo.toArray = () => {\n const c = memo();\n return Array.isArray(c) ? c : c != null ? [c] : [];\n };\n return memo;\n}\nlet SuspenseContext;\nfunction getSuspenseContext() {\n return SuspenseContext || (SuspenseContext = createContext());\n}\nfunction enableExternalSource(factory) {\n if (ExternalSourceFactory) {\n const oldFactory = ExternalSourceFactory;\n ExternalSourceFactory = (fn, trigger) => {\n const oldSource = oldFactory(fn, trigger);\n const source = factory(x => oldSource.track(x), trigger);\n return {\n track: x => source.track(x),\n dispose() {\n source.dispose();\n oldSource.dispose();\n }\n };\n };\n } else {\n ExternalSourceFactory = factory;\n }\n}\nfunction readSignal() {\n const runningTransition = Transition && Transition.running;\n if (this.sources && (runningTransition ? this.tState : this.state)) {\n if ((runningTransition ? this.tState : this.state) === STALE) updateComputation(this);else {\n const updates = Updates;\n Updates = null;\n runUpdates(() => lookUpstream(this), false);\n Updates = updates;\n }\n }\n if (Listener) {\n const sSlot = this.observers ? this.observers.length : 0;\n if (!Listener.sources) {\n Listener.sources = [this];\n Listener.sourceSlots = [sSlot];\n } else {\n Listener.sources.push(this);\n Listener.sourceSlots.push(sSlot);\n }\n if (!this.observers) {\n this.observers = [Listener];\n this.observerSlots = [Listener.sources.length - 1];\n } else {\n this.observers.push(Listener);\n this.observerSlots.push(Listener.sources.length - 1);\n }\n }\n if (runningTransition && Transition.sources.has(this)) return this.tValue;\n return this.value;\n}\nfunction writeSignal(node, value, isComp) {\n let current = Transition && Transition.running && Transition.sources.has(node) ? node.tValue : node.value;\n if (!node.comparator || !node.comparator(current, value)) {\n if (Transition) {\n const TransitionRunning = Transition.running;\n if (TransitionRunning || !isComp && Transition.sources.has(node)) {\n Transition.sources.add(node);\n node.tValue = value;\n }\n if (!TransitionRunning) node.value = value;\n } else node.value = value;\n if (node.observers && node.observers.length) {\n runUpdates(() => {\n for (let i = 0; i < node.observers.length; i += 1) {\n const o = node.observers[i];\n const TransitionRunning = Transition && Transition.running;\n if (TransitionRunning && Transition.disposed.has(o)) continue;\n if (TransitionRunning ? !o.tState : !o.state) {\n if (o.pure) Updates.push(o);else Effects.push(o);\n if (o.observers) markDownstream(o);\n }\n if (!TransitionRunning) o.state = STALE;else o.tState = STALE;\n }\n if (Updates.length > 10e5) {\n Updates = [];\n if (false) ;\n throw new Error();\n }\n }, false);\n }\n }\n return value;\n}\nfunction updateComputation(node) {\n if (!node.fn) return;\n cleanNode(node);\n const owner = Owner,\n listener = Listener,\n time = ExecCount;\n Listener = Owner = node;\n runComputation(node, Transition && Transition.running && Transition.sources.has(node) ? node.tValue : node.value, time);\n if (Transition && !Transition.running && Transition.sources.has(node)) {\n queueMicrotask(() => {\n runUpdates(() => {\n Transition && (Transition.running = true);\n Listener = Owner = node;\n runComputation(node, node.tValue, time);\n Listener = Owner = null;\n }, false);\n });\n }\n Listener = listener;\n Owner = owner;\n}\nfunction runComputation(node, value, time) {\n let nextValue;\n try {\n nextValue = node.fn(value);\n } catch (err) {\n if (node.pure) {\n if (Transition && Transition.running) {\n node.tState = STALE;\n node.tOwned && node.tOwned.forEach(cleanNode);\n node.tOwned = undefined;\n } else {\n node.state = STALE;\n node.owned && node.owned.forEach(cleanNode);\n node.owned = null;\n }\n }\n node.updatedAt = time + 1;\n return handleError(err);\n }\n if (!node.updatedAt || node.updatedAt <= time) {\n if (node.updatedAt != null && \"observers\" in node) {\n writeSignal(node, nextValue, true);\n } else if (Transition && Transition.running && node.pure) {\n Transition.sources.add(node);\n node.tValue = nextValue;\n } else node.value = nextValue;\n node.updatedAt = time;\n }\n}\nfunction createComputation(fn, init, pure, state = STALE, options) {\n const c = {\n fn,\n state: state,\n updatedAt: null,\n owned: null,\n sources: null,\n sourceSlots: null,\n cleanups: null,\n value: init,\n owner: Owner,\n context: Owner ? Owner.context : null,\n pure\n };\n if (Transition && Transition.running) {\n c.state = 0;\n c.tState = state;\n }\n if (Owner === null) ;else if (Owner !== UNOWNED) {\n if (Transition && Transition.running && Owner.pure) {\n if (!Owner.tOwned) Owner.tOwned = [c];else Owner.tOwned.push(c);\n } else {\n if (!Owner.owned) Owner.owned = [c];else Owner.owned.push(c);\n }\n }\n if (ExternalSourceFactory) {\n const [track, trigger] = createSignal(undefined, {\n equals: false\n });\n const ordinary = ExternalSourceFactory(c.fn, trigger);\n onCleanup(() => ordinary.dispose());\n const triggerInTransition = () => startTransition(trigger).then(() => inTransition.dispose());\n const inTransition = ExternalSourceFactory(c.fn, triggerInTransition);\n c.fn = x => {\n track();\n return Transition && Transition.running ? inTransition.track(x) : ordinary.track(x);\n };\n }\n return c;\n}\nfunction runTop(node) {\n const runningTransition = Transition && Transition.running;\n if ((runningTransition ? node.tState : node.state) === 0) return;\n if ((runningTransition ? node.tState : node.state) === PENDING) return lookUpstream(node);\n if (node.suspense && untrack(node.suspense.inFallback)) return node.suspense.effects.push(node);\n const ancestors = [node];\n while ((node = node.owner) && (!node.updatedAt || node.updatedAt < ExecCount)) {\n if (runningTransition && Transition.disposed.has(node)) return;\n if (runningTransition ? node.tState : node.state) ancestors.push(node);\n }\n for (let i = ancestors.length - 1; i >= 0; i--) {\n node = ancestors[i];\n if (runningTransition) {\n let top = node,\n prev = ancestors[i + 1];\n while ((top = top.owner) && top !== prev) {\n if (Transition.disposed.has(top)) return;\n }\n }\n if ((runningTransition ? node.tState : node.state) === STALE) {\n updateComputation(node);\n } else if ((runningTransition ? node.tState : node.state) === PENDING) {\n const updates = Updates;\n Updates = null;\n runUpdates(() => lookUpstream(node, ancestors[0]), false);\n Updates = updates;\n }\n }\n}\nfunction runUpdates(fn, init) {\n if (Updates) return fn();\n let wait = false;\n if (!init) Updates = [];\n if (Effects) wait = true;else Effects = [];\n ExecCount++;\n try {\n const res = fn();\n completeUpdates(wait);\n return res;\n } catch (err) {\n if (!wait) Effects = null;\n Updates = null;\n handleError(err);\n }\n}\nfunction completeUpdates(wait) {\n if (Updates) {\n if (Scheduler && Transition && Transition.running) scheduleQueue(Updates);else runQueue(Updates);\n Updates = null;\n }\n if (wait) return;\n let res;\n if (Transition) {\n if (!Transition.promises.size && !Transition.queue.size) {\n const sources = Transition.sources;\n const disposed = Transition.disposed;\n Effects.push.apply(Effects, Transition.effects);\n res = Transition.resolve;\n for (const e of Effects) {\n \"tState\" in e && (e.state = e.tState);\n delete e.tState;\n }\n Transition = null;\n runUpdates(() => {\n for (const d of disposed) cleanNode(d);\n for (const v of sources) {\n v.value = v.tValue;\n if (v.owned) {\n for (let i = 0, len = v.owned.length; i < len; i++) cleanNode(v.owned[i]);\n }\n if (v.tOwned) v.owned = v.tOwned;\n delete v.tValue;\n delete v.tOwned;\n v.tState = 0;\n }\n setTransPending(false);\n }, false);\n } else if (Transition.running) {\n Transition.running = false;\n Transition.effects.push.apply(Transition.effects, Effects);\n Effects = null;\n setTransPending(true);\n return;\n }\n }\n const e = Effects;\n Effects = null;\n if (e.length) runUpdates(() => runEffects(e), false);\n if (res) res();\n}\nfunction runQueue(queue) {\n for (let i = 0; i < queue.length; i++) runTop(queue[i]);\n}\nfunction scheduleQueue(queue) {\n for (let i = 0; i < queue.length; i++) {\n const item = queue[i];\n const tasks = Transition.queue;\n if (!tasks.has(item)) {\n tasks.add(item);\n Scheduler(() => {\n tasks.delete(item);\n runUpdates(() => {\n Transition.running = true;\n runTop(item);\n }, false);\n Transition && (Transition.running = false);\n });\n }\n }\n}\nfunction runUserEffects(queue) {\n let i,\n userLength = 0;\n for (i = 0; i < queue.length; i++) {\n const e = queue[i];\n if (!e.user) runTop(e);else queue[userLength++] = e;\n }\n if (sharedConfig.context) {\n if (sharedConfig.count) {\n sharedConfig.effects || (sharedConfig.effects = []);\n sharedConfig.effects.push(...queue.slice(0, userLength));\n return;\n } else if (sharedConfig.effects) {\n queue = [...sharedConfig.effects, ...queue];\n userLength += sharedConfig.effects.length;\n delete sharedConfig.effects;\n }\n setHydrateContext();\n }\n for (i = 0; i < userLength; i++) runTop(queue[i]);\n}\nfunction lookUpstream(node, ignore) {\n const runningTransition = Transition && Transition.running;\n if (runningTransition) node.tState = 0;else node.state = 0;\n for (let i = 0; i < node.sources.length; i += 1) {\n const source = node.sources[i];\n if (source.sources) {\n const state = runningTransition ? source.tState : source.state;\n if (state === STALE) {\n if (source !== ignore && (!source.updatedAt || source.updatedAt < ExecCount)) runTop(source);\n } else if (state === PENDING) lookUpstream(source, ignore);\n }\n }\n}\nfunction markDownstream(node) {\n const runningTransition = Transition && Transition.running;\n for (let i = 0; i < node.observers.length; i += 1) {\n const o = node.observers[i];\n if (runningTransition ? !o.tState : !o.state) {\n if (runningTransition) o.tState = PENDING;else o.state = PENDING;\n if (o.pure) Updates.push(o);else Effects.push(o);\n o.observers && markDownstream(o);\n }\n }\n}\nfunction cleanNode(node) {\n let i;\n if (node.sources) {\n while (node.sources.length) {\n const source = node.sources.pop(),\n index = node.sourceSlots.pop(),\n obs = source.observers;\n if (obs && obs.length) {\n const n = obs.pop(),\n s = source.observerSlots.pop();\n if (index < obs.length) {\n n.sourceSlots[s] = index;\n obs[index] = n;\n source.observerSlots[index] = s;\n }\n }\n }\n }\n if (Transition && Transition.running && node.pure) {\n if (node.tOwned) {\n for (i = node.tOwned.length - 1; i >= 0; i--) cleanNode(node.tOwned[i]);\n delete node.tOwned;\n }\n reset(node, true);\n } else if (node.owned) {\n for (i = node.owned.length - 1; i >= 0; i--) cleanNode(node.owned[i]);\n node.owned = null;\n }\n if (node.cleanups) {\n for (i = node.cleanups.length - 1; i >= 0; i--) node.cleanups[i]();\n node.cleanups = null;\n }\n if (Transition && Transition.running) node.tState = 0;else node.state = 0;\n}\nfunction reset(node, top) {\n if (!top) {\n node.tState = 0;\n Transition.disposed.add(node);\n }\n if (node.owned) {\n for (let i = 0; i < node.owned.length; i++) reset(node.owned[i]);\n }\n}\nfunction castError(err) {\n if (err instanceof Error) return err;\n return new Error(typeof err === \"string\" ? err : \"Unknown error\", {\n cause: err\n });\n}\nfunction runErrors(err, fns, owner) {\n try {\n for (const f of fns) f(err);\n } catch (e) {\n handleError(e, owner && owner.owner || null);\n }\n}\nfunction handleError(err, owner = Owner) {\n const fns = ERROR && owner && owner.context && owner.context[ERROR];\n const error = castError(err);\n if (!fns) throw error;\n if (Effects) Effects.push({\n fn() {\n runErrors(error, fns, owner);\n },\n state: STALE\n });else runErrors(error, fns, owner);\n}\nfunction resolveChildren(children) {\n if (typeof children === \"function\" && !children.length) return resolveChildren(children());\n if (Array.isArray(children)) {\n const results = [];\n for (let i = 0; i < children.length; i++) {\n const result = resolveChildren(children[i]);\n Array.isArray(result) ? results.push.apply(results, result) : results.push(result);\n }\n return results;\n }\n return children;\n}\nfunction createProvider(id, options) {\n return function provider(props) {\n let res;\n createRenderEffect(() => res = untrack(() => {\n Owner.context = {\n ...Owner.context,\n [id]: props.value\n };\n return children(() => props.children);\n }), undefined);\n return res;\n };\n}\nfunction onError(fn) {\n ERROR || (ERROR = Symbol(\"error\"));\n if (Owner === null) ;else if (Owner.context === null || !Owner.context[ERROR]) {\n Owner.context = {\n ...Owner.context,\n [ERROR]: [fn]\n };\n mutateContext(Owner, ERROR, [fn]);\n } else Owner.context[ERROR].push(fn);\n}\nfunction mutateContext(o, key, value) {\n if (o.owned) {\n for (let i = 0; i < o.owned.length; i++) {\n if (o.owned[i].context === o.context) mutateContext(o.owned[i], key, value);\n if (!o.owned[i].context) {\n o.owned[i].context = o.context;\n mutateContext(o.owned[i], key, value);\n } else if (!o.owned[i].context[key]) {\n o.owned[i].context[key] = value;\n mutateContext(o.owned[i], key, value);\n }\n }\n }\n}\n\nfunction observable(input) {\n return {\n subscribe(observer) {\n if (!(observer instanceof Object) || observer == null) {\n throw new TypeError(\"Expected the observer to be an object.\");\n }\n const handler = typeof observer === \"function\" ? observer : observer.next && observer.next.bind(observer);\n if (!handler) {\n return {\n unsubscribe() {}\n };\n }\n const dispose = createRoot(disposer => {\n createEffect(() => {\n const v = input();\n untrack(() => handler(v));\n });\n return disposer;\n });\n if (getOwner()) onCleanup(dispose);\n return {\n unsubscribe() {\n dispose();\n }\n };\n },\n [Symbol.observable || \"@@observable\"]() {\n return this;\n }\n };\n}\nfunction from(producer) {\n const [s, set] = createSignal(undefined, {\n equals: false\n });\n if (\"subscribe\" in producer) {\n const unsub = producer.subscribe(v => set(() => v));\n onCleanup(() => \"unsubscribe\" in unsub ? unsub.unsubscribe() : unsub());\n } else {\n const clean = producer(set);\n onCleanup(clean);\n }\n return s;\n}\n\nconst FALLBACK = Symbol(\"fallback\");\nfunction dispose(d) {\n for (let i = 0; i < d.length; i++) d[i]();\n}\nfunction mapArray(list, mapFn, options = {}) {\n let items = [],\n mapped = [],\n disposers = [],\n len = 0,\n indexes = mapFn.length > 1 ? [] : null;\n onCleanup(() => dispose(disposers));\n return () => {\n let newItems = list() || [],\n i,\n j;\n newItems[$TRACK];\n return untrack(() => {\n let newLen = newItems.length,\n newIndices,\n newIndicesNext,\n temp,\n tempdisposers,\n tempIndexes,\n start,\n end,\n newEnd,\n item;\n if (newLen === 0) {\n if (len !== 0) {\n dispose(disposers);\n disposers = [];\n items = [];\n mapped = [];\n len = 0;\n indexes && (indexes = []);\n }\n if (options.fallback) {\n items = [FALLBACK];\n mapped[0] = createRoot(disposer => {\n disposers[0] = disposer;\n return options.fallback();\n });\n len = 1;\n }\n }\n else if (len === 0) {\n mapped = new Array(newLen);\n for (j = 0; j < newLen; j++) {\n items[j] = newItems[j];\n mapped[j] = createRoot(mapper);\n }\n len = newLen;\n } else {\n temp = new Array(newLen);\n tempdisposers = new Array(newLen);\n indexes && (tempIndexes = new Array(newLen));\n for (start = 0, end = Math.min(len, newLen); start < end && items[start] === newItems[start]; start++);\n for (end = len - 1, newEnd = newLen - 1; end >= start && newEnd >= start && items[end] === newItems[newEnd]; end--, newEnd--) {\n temp[newEnd] = mapped[end];\n tempdisposers[newEnd] = disposers[end];\n indexes && (tempIndexes[newEnd] = indexes[end]);\n }\n newIndices = new Map();\n newIndicesNext = new Array(newEnd + 1);\n for (j = newEnd; j >= start; j--) {\n item = newItems[j];\n i = newIndices.get(item);\n newIndicesNext[j] = i === undefined ? -1 : i;\n newIndices.set(item, j);\n }\n for (i = start; i <= end; i++) {\n item = items[i];\n j = newIndices.get(item);\n if (j !== undefined && j !== -1) {\n temp[j] = mapped[i];\n tempdisposers[j] = disposers[i];\n indexes && (tempIndexes[j] = indexes[i]);\n j = newIndicesNext[j];\n newIndices.set(item, j);\n } else disposers[i]();\n }\n for (j = start; j < newLen; j++) {\n if (j in temp) {\n mapped[j] = temp[j];\n disposers[j] = tempdisposers[j];\n if (indexes) {\n indexes[j] = tempIndexes[j];\n indexes[j](j);\n }\n } else mapped[j] = createRoot(mapper);\n }\n mapped = mapped.slice(0, len = newLen);\n items = newItems.slice(0);\n }\n return mapped;\n });\n function mapper(disposer) {\n disposers[j] = disposer;\n if (indexes) {\n const [s, set] = createSignal(j);\n indexes[j] = set;\n return mapFn(newItems[j], s);\n }\n return mapFn(newItems[j]);\n }\n };\n}\nfunction indexArray(list, mapFn, options = {}) {\n let items = [],\n mapped = [],\n disposers = [],\n signals = [],\n len = 0,\n i;\n onCleanup(() => dispose(disposers));\n return () => {\n const newItems = list() || [];\n newItems[$TRACK];\n return untrack(() => {\n if (newItems.length === 0) {\n if (len !== 0) {\n dispose(disposers);\n disposers = [];\n items = [];\n mapped = [];\n len = 0;\n signals = [];\n }\n if (options.fallback) {\n items = [FALLBACK];\n mapped[0] = createRoot(disposer => {\n disposers[0] = disposer;\n return options.fallback();\n });\n len = 1;\n }\n return mapped;\n }\n if (items[0] === FALLBACK) {\n disposers[0]();\n disposers = [];\n items = [];\n mapped = [];\n len = 0;\n }\n for (i = 0; i < newItems.length; i++) {\n if (i < items.length && items[i] !== newItems[i]) {\n signals[i](() => newItems[i]);\n } else if (i >= items.length) {\n mapped[i] = createRoot(mapper);\n }\n }\n for (; i < items.length; i++) {\n disposers[i]();\n }\n len = signals.length = disposers.length = newItems.length;\n items = newItems.slice(0);\n return mapped = mapped.slice(0, len);\n });\n function mapper(disposer) {\n disposers[i] = disposer;\n const [s, set] = createSignal(newItems[i]);\n signals[i] = set;\n return mapFn(s, i);\n }\n };\n}\n\nlet hydrationEnabled = false;\nfunction enableHydration() {\n hydrationEnabled = true;\n}\nfunction createComponent(Comp, props) {\n if (hydrationEnabled) {\n if (sharedConfig.context) {\n const c = sharedConfig.context;\n setHydrateContext(nextHydrateContext());\n const r = untrack(() => Comp(props || {}));\n setHydrateContext(c);\n return r;\n }\n }\n return untrack(() => Comp(props || {}));\n}\nfunction trueFn() {\n return true;\n}\nconst propTraps = {\n get(_, property, receiver) {\n if (property === $PROXY) return receiver;\n return _.get(property);\n },\n has(_, property) {\n if (property === $PROXY) return true;\n return _.has(property);\n },\n set: trueFn,\n deleteProperty: trueFn,\n getOwnPropertyDescriptor(_, property) {\n return {\n configurable: true,\n enumerable: true,\n get() {\n return _.get(property);\n },\n set: trueFn,\n deleteProperty: trueFn\n };\n },\n ownKeys(_) {\n return _.keys();\n }\n};\nfunction resolveSource(s) {\n return !(s = typeof s === \"function\" ? s() : s) ? {} : s;\n}\nfunction resolveSources() {\n for (let i = 0, length = this.length; i < length; ++i) {\n const v = this[i]();\n if (v !== undefined) return v;\n }\n}\nfunction mergeProps(...sources) {\n let proxy = false;\n for (let i = 0; i < sources.length; i++) {\n const s = sources[i];\n proxy = proxy || !!s && $PROXY in s;\n sources[i] = typeof s === \"function\" ? (proxy = true, createMemo(s)) : s;\n }\n if (proxy) {\n return new Proxy({\n get(property) {\n for (let i = sources.length - 1; i >= 0; i--) {\n const v = resolveSource(sources[i])[property];\n if (v !== undefined) return v;\n }\n },\n has(property) {\n for (let i = sources.length - 1; i >= 0; i--) {\n if (property in resolveSource(sources[i])) return true;\n }\n return false;\n },\n keys() {\n const keys = [];\n for (let i = 0; i < sources.length; i++) keys.push(...Object.keys(resolveSource(sources[i])));\n return [...new Set(keys)];\n }\n }, propTraps);\n }\n const target = {};\n const sourcesMap = {};\n const defined = new Set();\n for (let i = sources.length - 1; i >= 0; i--) {\n const source = sources[i];\n if (!source) continue;\n const sourceKeys = Object.getOwnPropertyNames(source);\n for (let i = 0, length = sourceKeys.length; i < length; i++) {\n const key = sourceKeys[i];\n if (key === \"__proto__\" || key === \"constructor\") continue;\n const desc = Object.getOwnPropertyDescriptor(source, key);\n if (!defined.has(key)) {\n if (desc.get) {\n defined.add(key);\n Object.defineProperty(target, key, {\n enumerable: true,\n configurable: true,\n get: resolveSources.bind(sourcesMap[key] = [desc.get.bind(source)])\n });\n } else {\n if (desc.value !== undefined) defined.add(key);\n target[key] = desc.value;\n }\n } else {\n const sources = sourcesMap[key];\n if (sources) {\n if (desc.get) {\n sources.push(desc.get.bind(source));\n } else if (desc.value !== undefined) {\n sources.push(() => desc.value);\n }\n } else if (target[key] === undefined) target[key] = desc.value;\n }\n }\n }\n return target;\n}\nfunction splitProps(props, ...keys) {\n if ($PROXY in props) {\n const blocked = new Set(keys.length > 1 ? keys.flat() : keys[0]);\n const res = keys.map(k => {\n return new Proxy({\n get(property) {\n return k.includes(property) ? props[property] : undefined;\n },\n has(property) {\n return k.includes(property) && property in props;\n },\n keys() {\n return k.filter(property => property in props);\n }\n }, propTraps);\n });\n res.push(new Proxy({\n get(property) {\n return blocked.has(property) ? undefined : props[property];\n },\n has(property) {\n return blocked.has(property) ? false : property in props;\n },\n keys() {\n return Object.keys(props).filter(k => !blocked.has(k));\n }\n }, propTraps));\n return res;\n }\n const otherObject = {};\n const objects = keys.map(() => ({}));\n for (const propName of Object.getOwnPropertyNames(props)) {\n const desc = Object.getOwnPropertyDescriptor(props, propName);\n const isDefaultDesc = !desc.get && !desc.set && desc.enumerable && desc.writable && desc.configurable;\n let blocked = false;\n let objectIndex = 0;\n for (const k of keys) {\n if (k.includes(propName)) {\n blocked = true;\n isDefaultDesc ? objects[objectIndex][propName] = desc.value : Object.defineProperty(objects[objectIndex], propName, desc);\n }\n ++objectIndex;\n }\n if (!blocked) {\n isDefaultDesc ? otherObject[propName] = desc.value : Object.defineProperty(otherObject, propName, desc);\n }\n }\n return [...objects, otherObject];\n}\nfunction lazy(fn) {\n let comp;\n let p;\n const wrap = props => {\n const ctx = sharedConfig.context;\n if (ctx) {\n const [s, set] = createSignal();\n sharedConfig.count || (sharedConfig.count = 0);\n sharedConfig.count++;\n (p || (p = fn())).then(mod => {\n setHydrateContext(ctx);\n sharedConfig.count--;\n set(() => mod.default);\n setHydrateContext();\n });\n comp = s;\n } else if (!comp) {\n const [s] = createResource(() => (p || (p = fn())).then(mod => mod.default));\n comp = s;\n }\n let Comp;\n return createMemo(() => (Comp = comp()) && untrack(() => {\n if (false) ;\n if (!ctx) return Comp(props);\n const c = sharedConfig.context;\n setHydrateContext(ctx);\n const r = Comp(props);\n setHydrateContext(c);\n return r;\n }));\n };\n wrap.preload = () => p || ((p = fn()).then(mod => comp = () => mod.default), p);\n return wrap;\n}\nlet counter = 0;\nfunction createUniqueId() {\n const ctx = sharedConfig.context;\n return ctx ? `${ctx.id}${ctx.count++}` : `cl-${counter++}`;\n}\n\nconst narrowedError = name => `Stale read from <${name}>.`;\nfunction For(props) {\n const fallback = \"fallback\" in props && {\n fallback: () => props.fallback\n };\n return createMemo(mapArray(() => props.each, props.children, fallback || undefined));\n}\nfunction Index(props) {\n const fallback = \"fallback\" in props && {\n fallback: () => props.fallback\n };\n return createMemo(indexArray(() => props.each, props.children, fallback || undefined));\n}\nfunction Show(props) {\n const keyed = props.keyed;\n const condition = createMemo(() => props.when, undefined, {\n equals: (a, b) => keyed ? a === b : !a === !b\n });\n return createMemo(() => {\n const c = condition();\n if (c) {\n const child = props.children;\n const fn = typeof child === \"function\" && child.length > 0;\n return fn ? untrack(() => child(keyed ? c : () => {\n if (!untrack(condition)) throw narrowedError(\"Show\");\n return props.when;\n })) : child;\n }\n return props.fallback;\n }, undefined, undefined);\n}\nfunction Switch(props) {\n let keyed = false;\n const equals = (a, b) => a[0] === b[0] && (keyed ? a[1] === b[1] : !a[1] === !b[1]) && a[2] === b[2];\n const conditions = children(() => props.children),\n evalConditions = createMemo(() => {\n let conds = conditions();\n if (!Array.isArray(conds)) conds = [conds];\n for (let i = 0; i < conds.length; i++) {\n const c = conds[i].when;\n if (c) {\n keyed = !!conds[i].keyed;\n return [i, c, conds[i]];\n }\n }\n return [-1];\n }, undefined, {\n equals\n });\n return createMemo(() => {\n const [index, when, cond] = evalConditions();\n if (index < 0) return props.fallback;\n const c = cond.children;\n const fn = typeof c === \"function\" && c.length > 0;\n return fn ? untrack(() => c(keyed ? when : () => {\n if (untrack(evalConditions)[0] !== index) throw narrowedError(\"Match\");\n return cond.when;\n })) : c;\n }, undefined, undefined);\n}\nfunction Match(props) {\n return props;\n}\nlet Errors;\nfunction resetErrorBoundaries() {\n Errors && [...Errors].forEach(fn => fn());\n}\nfunction ErrorBoundary(props) {\n let err;\n if (sharedConfig.context && sharedConfig.load) err = sharedConfig.load(sharedConfig.context.id + sharedConfig.context.count);\n const [errored, setErrored] = createSignal(err, undefined);\n Errors || (Errors = new Set());\n Errors.add(setErrored);\n onCleanup(() => Errors.delete(setErrored));\n return createMemo(() => {\n let e;\n if (e = errored()) {\n const f = props.fallback;\n return typeof f === \"function\" && f.length ? untrack(() => f(e, () => setErrored())) : f;\n }\n return catchError(() => props.children, setErrored);\n }, undefined, undefined);\n}\n\nconst suspenseListEquals = (a, b) => a.showContent === b.showContent && a.showFallback === b.showFallback;\nconst SuspenseListContext = createContext();\nfunction SuspenseList(props) {\n let [wrapper, setWrapper] = createSignal(() => ({\n inFallback: false\n })),\n show;\n const listContext = useContext(SuspenseListContext);\n const [registry, setRegistry] = createSignal([]);\n if (listContext) {\n show = listContext.register(createMemo(() => wrapper()().inFallback));\n }\n const resolved = createMemo(prev => {\n const reveal = props.revealOrder,\n tail = props.tail,\n {\n showContent = true,\n showFallback = true\n } = show ? show() : {},\n reg = registry(),\n reverse = reveal === \"backwards\";\n if (reveal === \"together\") {\n const all = reg.every(inFallback => !inFallback());\n const res = reg.map(() => ({\n showContent: all && showContent,\n showFallback\n }));\n res.inFallback = !all;\n return res;\n }\n let stop = false;\n let inFallback = prev.inFallback;\n const res = [];\n for (let i = 0, len = reg.length; i < len; i++) {\n const n = reverse ? len - i - 1 : i,\n s = reg[n]();\n if (!stop && !s) {\n res[n] = {\n showContent,\n showFallback\n };\n } else {\n const next = !stop;\n if (next) inFallback = true;\n res[n] = {\n showContent: next,\n showFallback: !tail || next && tail === \"collapsed\" ? showFallback : false\n };\n stop = true;\n }\n }\n if (!stop) inFallback = false;\n res.inFallback = inFallback;\n return res;\n }, {\n inFallback: false\n });\n setWrapper(() => resolved);\n return createComponent(SuspenseListContext.Provider, {\n value: {\n register: inFallback => {\n let index;\n setRegistry(registry => {\n index = registry.length;\n return [...registry, inFallback];\n });\n return createMemo(() => resolved()[index], undefined, {\n equals: suspenseListEquals\n });\n }\n },\n get children() {\n return props.children;\n }\n });\n}\nfunction Suspense(props) {\n let counter = 0,\n show,\n ctx,\n p,\n flicker,\n error;\n const [inFallback, setFallback] = createSignal(false),\n SuspenseContext = getSuspenseContext(),\n store = {\n increment: () => {\n if (++counter === 1) setFallback(true);\n },\n decrement: () => {\n if (--counter === 0) setFallback(false);\n },\n inFallback,\n effects: [],\n resolved: false\n },\n owner = getOwner();\n if (sharedConfig.context && sharedConfig.load) {\n const key = sharedConfig.context.id + sharedConfig.context.count;\n let ref = sharedConfig.load(key);\n if (ref && (typeof ref !== \"object\" || ref.status !== \"success\")) p = ref;\n if (p && p !== \"$$f\") {\n const [s, set] = createSignal(undefined, {\n equals: false\n });\n flicker = s;\n p.then(() => {\n sharedConfig.gather(key);\n setHydrateContext(ctx);\n set();\n setHydrateContext();\n }).catch(err => {\n if (err || sharedConfig.done) {\n err && (error = err);\n return set();\n }\n });\n }\n }\n const listContext = useContext(SuspenseListContext);\n if (listContext) show = listContext.register(store.inFallback);\n let dispose;\n onCleanup(() => dispose && dispose());\n return createComponent(SuspenseContext.Provider, {\n value: store,\n get children() {\n return createMemo(() => {\n if (error) throw error;\n ctx = sharedConfig.context;\n if (flicker) {\n flicker();\n return flicker = undefined;\n }\n if (ctx && p === \"$$f\") setHydrateContext();\n const rendered = createMemo(() => props.children);\n return createMemo(prev => {\n const inFallback = store.inFallback(),\n {\n showContent = true,\n showFallback = true\n } = show ? show() : {};\n if ((!inFallback || p && p !== \"$$f\") && showContent) {\n store.resolved = true;\n dispose && dispose();\n dispose = ctx = p = undefined;\n resumeEffects(store.effects);\n return rendered();\n }\n if (!showFallback) return;\n if (dispose) return prev;\n return createRoot(disposer => {\n dispose = disposer;\n if (ctx) {\n setHydrateContext({\n id: ctx.id + \"f\",\n count: 0\n });\n ctx = undefined;\n }\n return props.fallback;\n }, owner);\n });\n });\n }\n });\n}\n\nconst DEV = undefined;\n\nexport { $DEVCOMP, $PROXY, $TRACK, DEV, ErrorBoundary, For, Index, Match, Show, Suspense, SuspenseList, Switch, batch, cancelCallback, catchError, children, createComponent, createComputed, createContext, createDeferred, createEffect, createMemo, createReaction, createRenderEffect, createResource, createRoot, createSelector, createSignal, createUniqueId, enableExternalSource, enableHydration, enableScheduling, equalFn, from, getListener, getOwner, indexArray, lazy, mapArray, mergeProps, observable, on, onCleanup, onError, onMount, requestCallback, resetErrorBoundaries, runWithOwner, sharedConfig, splitProps, startTransition, untrack, useContext, useTransition };\n","import { createRoot, sharedConfig, createRenderEffect, untrack, enableHydration, getOwner, createEffect, runWithOwner, createMemo, createSignal, onCleanup, splitProps } from 'solid-js';\nexport { ErrorBoundary, For, Index, Match, Show, Suspense, SuspenseList, Switch, createComponent, createRenderEffect as effect, getOwner, createMemo as memo, mergeProps, untrack } from 'solid-js';\n\nconst booleans = [\"allowfullscreen\", \"async\", \"autofocus\", \"autoplay\", \"checked\", \"controls\", \"default\", \"disabled\", \"formnovalidate\", \"hidden\", \"indeterminate\", \"ismap\", \"loop\", \"multiple\", \"muted\", \"nomodule\", \"novalidate\", \"open\", \"playsinline\", \"readonly\", \"required\", \"reversed\", \"seamless\", \"selected\"];\nconst Properties = /*#__PURE__*/new Set([\"className\", \"value\", \"readOnly\", \"formNoValidate\", \"isMap\", \"noModule\", \"playsInline\", ...booleans]);\nconst ChildProperties = /*#__PURE__*/new Set([\"innerHTML\", \"textContent\", \"innerText\", \"children\"]);\nconst Aliases = /*#__PURE__*/Object.assign(Object.create(null), {\n className: \"class\",\n htmlFor: \"for\"\n});\nconst PropAliases = /*#__PURE__*/Object.assign(Object.create(null), {\n class: \"className\",\n formnovalidate: {\n $: \"formNoValidate\",\n BUTTON: 1,\n INPUT: 1\n },\n ismap: {\n $: \"isMap\",\n IMG: 1\n },\n nomodule: {\n $: \"noModule\",\n SCRIPT: 1\n },\n playsinline: {\n $: \"playsInline\",\n VIDEO: 1\n },\n readonly: {\n $: \"readOnly\",\n INPUT: 1,\n TEXTAREA: 1\n }\n});\nfunction getPropAlias(prop, tagName) {\n const a = PropAliases[prop];\n return typeof a === \"object\" ? a[tagName] ? a[\"$\"] : undefined : a;\n}\nconst DelegatedEvents = /*#__PURE__*/new Set([\"beforeinput\", \"click\", \"dblclick\", \"contextmenu\", \"focusin\", \"focusout\", \"input\", \"keydown\", \"keyup\", \"mousedown\", \"mousemove\", \"mouseout\", \"mouseover\", \"mouseup\", \"pointerdown\", \"pointermove\", \"pointerout\", \"pointerover\", \"pointerup\", \"touchend\", \"touchmove\", \"touchstart\"]);\nconst SVGElements = /*#__PURE__*/new Set([\n\"altGlyph\", \"altGlyphDef\", \"altGlyphItem\", \"animate\", \"animateColor\", \"animateMotion\", \"animateTransform\", \"circle\", \"clipPath\", \"color-profile\", \"cursor\", \"defs\", \"desc\", \"ellipse\", \"feBlend\", \"feColorMatrix\", \"feComponentTransfer\", \"feComposite\", \"feConvolveMatrix\", \"feDiffuseLighting\", \"feDisplacementMap\", \"feDistantLight\", \"feFlood\", \"feFuncA\", \"feFuncB\", \"feFuncG\", \"feFuncR\", \"feGaussianBlur\", \"feImage\", \"feMerge\", \"feMergeNode\", \"feMorphology\", \"feOffset\", \"fePointLight\", \"feSpecularLighting\", \"feSpotLight\", \"feTile\", \"feTurbulence\", \"filter\", \"font\", \"font-face\", \"font-face-format\", \"font-face-name\", \"font-face-src\", \"font-face-uri\", \"foreignObject\", \"g\", \"glyph\", \"glyphRef\", \"hkern\", \"image\", \"line\", \"linearGradient\", \"marker\", \"mask\", \"metadata\", \"missing-glyph\", \"mpath\", \"path\", \"pattern\", \"polygon\", \"polyline\", \"radialGradient\", \"rect\",\n\"set\", \"stop\",\n\"svg\", \"switch\", \"symbol\", \"text\", \"textPath\",\n\"tref\", \"tspan\", \"use\", \"view\", \"vkern\"]);\nconst SVGNamespace = {\n xlink: \"http://www.w3.org/1999/xlink\",\n xml: \"http://www.w3.org/XML/1998/namespace\"\n};\nconst DOMElements = /*#__PURE__*/new Set([\"html\", \"base\", \"head\", \"link\", \"meta\", \"style\", \"title\", \"body\", \"address\", \"article\", \"aside\", \"footer\", \"header\", \"main\", \"nav\", \"section\", \"body\", \"blockquote\", \"dd\", \"div\", \"dl\", \"dt\", \"figcaption\", \"figure\", \"hr\", \"li\", \"ol\", \"p\", \"pre\", \"ul\", \"a\", \"abbr\", \"b\", \"bdi\", \"bdo\", \"br\", \"cite\", \"code\", \"data\", \"dfn\", \"em\", \"i\", \"kbd\", \"mark\", \"q\", \"rp\", \"rt\", \"ruby\", \"s\", \"samp\", \"small\", \"span\", \"strong\", \"sub\", \"sup\", \"time\", \"u\", \"var\", \"wbr\", \"area\", \"audio\", \"img\", \"map\", \"track\", \"video\", \"embed\", \"iframe\", \"object\", \"param\", \"picture\", \"portal\", \"source\", \"svg\", \"math\", \"canvas\", \"noscript\", \"script\", \"del\", \"ins\", \"caption\", \"col\", \"colgroup\", \"table\", \"tbody\", \"td\", \"tfoot\", \"th\", \"thead\", \"tr\", \"button\", \"datalist\", \"fieldset\", \"form\", \"input\", \"label\", \"legend\", \"meter\", \"optgroup\", \"option\", \"output\", \"progress\", \"select\", \"textarea\", \"details\", \"dialog\", \"menu\", \"summary\", \"details\", \"slot\", \"template\", \"acronym\", \"applet\", \"basefont\", \"bgsound\", \"big\", \"blink\", \"center\", \"content\", \"dir\", \"font\", \"frame\", \"frameset\", \"hgroup\", \"image\", \"keygen\", \"marquee\", \"menuitem\", \"nobr\", \"noembed\", \"noframes\", \"plaintext\", \"rb\", \"rtc\", \"shadow\", \"spacer\", \"strike\", \"tt\", \"xmp\", \"a\", \"abbr\", \"acronym\", \"address\", \"applet\", \"area\", \"article\", \"aside\", \"audio\", \"b\", \"base\", \"basefont\", \"bdi\", \"bdo\", \"bgsound\", \"big\", \"blink\", \"blockquote\", \"body\", \"br\", \"button\", \"canvas\", \"caption\", \"center\", \"cite\", \"code\", \"col\", \"colgroup\", \"content\", \"data\", \"datalist\", \"dd\", \"del\", \"details\", \"dfn\", \"dialog\", \"dir\", \"div\", \"dl\", \"dt\", \"em\", \"embed\", \"fieldset\", \"figcaption\", \"figure\", \"font\", \"footer\", \"form\", \"frame\", \"frameset\", \"head\", \"header\", \"hgroup\", \"hr\", \"html\", \"i\", \"iframe\", \"image\", \"img\", \"input\", \"ins\", \"kbd\", \"keygen\", \"label\", \"legend\", \"li\", \"link\", \"main\", \"map\", \"mark\", \"marquee\", \"menu\", \"menuitem\", \"meta\", \"meter\", \"nav\", \"nobr\", \"noembed\", \"noframes\", \"noscript\", \"object\", \"ol\", \"optgroup\", \"option\", \"output\", \"p\", \"param\", \"picture\", \"plaintext\", \"portal\", \"pre\", \"progress\", \"q\", \"rb\", \"rp\", \"rt\", \"rtc\", \"ruby\", \"s\", \"samp\", \"script\", \"section\", \"select\", \"shadow\", \"slot\", \"small\", \"source\", \"spacer\", \"span\", \"strike\", \"strong\", \"style\", \"sub\", \"summary\", \"sup\", \"table\", \"tbody\", \"td\", \"template\", \"textarea\", \"tfoot\", \"th\", \"thead\", \"time\", \"title\", \"tr\", \"track\", \"tt\", \"u\", \"ul\", \"var\", \"video\", \"wbr\", \"xmp\", \"input\", \"h1\", \"h2\", \"h3\", \"h4\", \"h5\", \"h6\"]);\n\nfunction reconcileArrays(parentNode, a, b) {\n let bLength = b.length,\n aEnd = a.length,\n bEnd = bLength,\n aStart = 0,\n bStart = 0,\n after = a[aEnd - 1].nextSibling,\n map = null;\n while (aStart < aEnd || bStart < bEnd) {\n if (a[aStart] === b[bStart]) {\n aStart++;\n bStart++;\n continue;\n }\n while (a[aEnd - 1] === b[bEnd - 1]) {\n aEnd--;\n bEnd--;\n }\n if (aEnd === aStart) {\n const node = bEnd < bLength ? bStart ? b[bStart - 1].nextSibling : b[bEnd - bStart] : after;\n while (bStart < bEnd) parentNode.insertBefore(b[bStart++], node);\n } else if (bEnd === bStart) {\n while (aStart < aEnd) {\n if (!map || !map.has(a[aStart])) a[aStart].remove();\n aStart++;\n }\n } else if (a[aStart] === b[bEnd - 1] && b[bStart] === a[aEnd - 1]) {\n const node = a[--aEnd].nextSibling;\n parentNode.insertBefore(b[bStart++], a[aStart++].nextSibling);\n parentNode.insertBefore(b[--bEnd], node);\n a[aEnd] = b[bEnd];\n } else {\n if (!map) {\n map = new Map();\n let i = bStart;\n while (i < bEnd) map.set(b[i], i++);\n }\n const index = map.get(a[aStart]);\n if (index != null) {\n if (bStart < index && index < bEnd) {\n let i = aStart,\n sequence = 1,\n t;\n while (++i < aEnd && i < bEnd) {\n if ((t = map.get(a[i])) == null || t !== index + sequence) break;\n sequence++;\n }\n if (sequence > index - bStart) {\n const node = a[aStart];\n while (bStart < index) parentNode.insertBefore(b[bStart++], node);\n } else parentNode.replaceChild(b[bStart++], a[aStart++]);\n } else aStart++;\n } else a[aStart++].remove();\n }\n }\n}\n\nconst $$EVENTS = \"_$DX_DELEGATE\";\nfunction render(code, element, init, options = {}) {\n let disposer;\n createRoot(dispose => {\n disposer = dispose;\n element === document ? code() : insert(element, code(), element.firstChild ? null : undefined, init);\n }, options.owner);\n return () => {\n disposer();\n element.textContent = \"\";\n };\n}\nfunction template(html, isCE, isSVG) {\n let node;\n const create = () => {\n const t = document.createElement(\"template\");\n t.innerHTML = html;\n return isSVG ? t.content.firstChild.firstChild : t.content.firstChild;\n };\n const fn = isCE ? () => untrack(() => document.importNode(node || (node = create()), true)) : () => (node || (node = create())).cloneNode(true);\n fn.cloneNode = fn;\n return fn;\n}\nfunction delegateEvents(eventNames, document = window.document) {\n const e = document[$$EVENTS] || (document[$$EVENTS] = new Set());\n for (let i = 0, l = eventNames.length; i < l; i++) {\n const name = eventNames[i];\n if (!e.has(name)) {\n e.add(name);\n document.addEventListener(name, eventHandler);\n }\n }\n}\nfunction clearDelegatedEvents(document = window.document) {\n if (document[$$EVENTS]) {\n for (let name of document[$$EVENTS].keys()) document.removeEventListener(name, eventHandler);\n delete document[$$EVENTS];\n }\n}\nfunction setProperty(node, name, value) {\n !sharedConfig.context && (node[name] = value);\n}\nfunction setAttribute(node, name, value) {\n if (sharedConfig.context) return;\n if (value == null) node.removeAttribute(name);else node.setAttribute(name, value);\n}\nfunction setAttributeNS(node, namespace, name, value) {\n if (sharedConfig.context) return;\n if (value == null) node.removeAttributeNS(namespace, name);else node.setAttributeNS(namespace, name, value);\n}\nfunction className(node, value) {\n if (sharedConfig.context) return;\n if (value == null) node.removeAttribute(\"class\");else node.className = value;\n}\nfunction addEventListener(node, name, handler, delegate) {\n if (delegate) {\n if (Array.isArray(handler)) {\n node[`$$${name}`] = handler[0];\n node[`$$${name}Data`] = handler[1];\n } else node[`$$${name}`] = handler;\n } else if (Array.isArray(handler)) {\n const handlerFn = handler[0];\n node.addEventListener(name, handler[0] = e => handlerFn.call(node, handler[1], e));\n } else node.addEventListener(name, handler);\n}\nfunction classList(node, value, prev = {}) {\n const classKeys = Object.keys(value || {}),\n prevKeys = Object.keys(prev);\n let i, len;\n for (i = 0, len = prevKeys.length; i < len; i++) {\n const key = prevKeys[i];\n if (!key || key === \"undefined\" || value[key]) continue;\n toggleClassKey(node, key, false);\n delete prev[key];\n }\n for (i = 0, len = classKeys.length; i < len; i++) {\n const key = classKeys[i],\n classValue = !!value[key];\n if (!key || key === \"undefined\" || prev[key] === classValue || !classValue) continue;\n toggleClassKey(node, key, true);\n prev[key] = classValue;\n }\n return prev;\n}\nfunction style(node, value, prev) {\n if (!value) return prev ? setAttribute(node, \"style\") : value;\n const nodeStyle = node.style;\n if (typeof value === \"string\") return nodeStyle.cssText = value;\n typeof prev === \"string\" && (nodeStyle.cssText = prev = undefined);\n prev || (prev = {});\n value || (value = {});\n let v, s;\n for (s in prev) {\n value[s] == null && nodeStyle.removeProperty(s);\n delete prev[s];\n }\n for (s in value) {\n v = value[s];\n if (v !== prev[s]) {\n nodeStyle.setProperty(s, v);\n prev[s] = v;\n }\n }\n return prev;\n}\nfunction spread(node, props = {}, isSVG, skipChildren) {\n const prevProps = {};\n if (!skipChildren) {\n createRenderEffect(() => prevProps.children = insertExpression(node, props.children, prevProps.children));\n }\n createRenderEffect(() => props.ref && props.ref(node));\n createRenderEffect(() => assign(node, props, isSVG, true, prevProps, true));\n return prevProps;\n}\nfunction dynamicProperty(props, key) {\n const src = props[key];\n Object.defineProperty(props, key, {\n get() {\n return src();\n },\n enumerable: true\n });\n return props;\n}\nfunction use(fn, element, arg) {\n return untrack(() => fn(element, arg));\n}\nfunction insert(parent, accessor, marker, initial) {\n if (marker !== undefined && !initial) initial = [];\n if (typeof accessor !== \"function\") return insertExpression(parent, accessor, initial, marker);\n createRenderEffect(current => insertExpression(parent, accessor(), current, marker), initial);\n}\nfunction assign(node, props, isSVG, skipChildren, prevProps = {}, skipRef = false) {\n props || (props = {});\n for (const prop in prevProps) {\n if (!(prop in props)) {\n if (prop === \"children\") continue;\n prevProps[prop] = assignProp(node, prop, null, prevProps[prop], isSVG, skipRef);\n }\n }\n for (const prop in props) {\n if (prop === \"children\") {\n if (!skipChildren) insertExpression(node, props.children);\n continue;\n }\n const value = props[prop];\n prevProps[prop] = assignProp(node, prop, value, prevProps[prop], isSVG, skipRef);\n }\n}\nfunction hydrate$1(code, element, options = {}) {\n sharedConfig.completed = globalThis._$HY.completed;\n sharedConfig.events = globalThis._$HY.events;\n sharedConfig.load = id => globalThis._$HY.r[id];\n sharedConfig.has = id => id in globalThis._$HY.r;\n sharedConfig.gather = root => gatherHydratable(element, root);\n sharedConfig.registry = new Map();\n sharedConfig.context = {\n id: options.renderId || \"\",\n count: 0\n };\n gatherHydratable(element, options.renderId);\n const dispose = render(code, element, [...element.childNodes], options);\n sharedConfig.context = null;\n return dispose;\n}\nfunction getNextElement(template) {\n let node, key;\n if (!sharedConfig.context || !(node = sharedConfig.registry.get(key = getHydrationKey()))) {\n return template();\n }\n if (sharedConfig.completed) sharedConfig.completed.add(node);\n sharedConfig.registry.delete(key);\n return node;\n}\nfunction getNextMatch(el, nodeName) {\n while (el && el.localName !== nodeName) el = el.nextSibling;\n return el;\n}\nfunction getNextMarker(start) {\n let end = start,\n count = 0,\n current = [];\n if (sharedConfig.context) {\n while (end) {\n if (end.nodeType === 8) {\n const v = end.nodeValue;\n if (v === \"$\") count++;else if (v === \"/\") {\n if (count === 0) return [end, current];\n count--;\n }\n }\n current.push(end);\n end = end.nextSibling;\n }\n }\n return [end, current];\n}\nfunction runHydrationEvents() {\n if (sharedConfig.events && !sharedConfig.events.queued) {\n queueMicrotask(() => {\n const {\n completed,\n events\n } = sharedConfig;\n events.queued = false;\n while (events.length) {\n const [el, e] = events[0];\n if (!completed.has(el)) return;\n eventHandler(e);\n events.shift();\n }\n });\n sharedConfig.events.queued = true;\n }\n}\nfunction toPropertyName(name) {\n return name.toLowerCase().replace(/-([a-z])/g, (_, w) => w.toUpperCase());\n}\nfunction toggleClassKey(node, key, value) {\n const classNames = key.trim().split(/\\s+/);\n for (let i = 0, nameLen = classNames.length; i < nameLen; i++) node.classList.toggle(classNames[i], value);\n}\nfunction assignProp(node, prop, value, prev, isSVG, skipRef) {\n let isCE, isProp, isChildProp, propAlias, forceProp;\n if (prop === \"style\") return style(node, value, prev);\n if (prop === \"classList\") return classList(node, value, prev);\n if (value === prev) return prev;\n if (prop === \"ref\") {\n if (!skipRef) value(node);\n } else if (prop.slice(0, 3) === \"on:\") {\n const e = prop.slice(3);\n prev && node.removeEventListener(e, prev);\n value && node.addEventListener(e, value);\n } else if (prop.slice(0, 10) === \"oncapture:\") {\n const e = prop.slice(10);\n prev && node.removeEventListener(e, prev, true);\n value && node.addEventListener(e, value, true);\n } else if (prop.slice(0, 2) === \"on\") {\n const name = prop.slice(2).toLowerCase();\n const delegate = DelegatedEvents.has(name);\n if (!delegate && prev) {\n const h = Array.isArray(prev) ? prev[0] : prev;\n node.removeEventListener(name, h);\n }\n if (delegate || value) {\n addEventListener(node, name, value, delegate);\n delegate && delegateEvents([name]);\n }\n } else if (prop.slice(0, 5) === \"attr:\") {\n setAttribute(node, prop.slice(5), value);\n } else if ((forceProp = prop.slice(0, 5) === \"prop:\") || (isChildProp = ChildProperties.has(prop)) || !isSVG && ((propAlias = getPropAlias(prop, node.tagName)) || (isProp = Properties.has(prop))) || (isCE = node.nodeName.includes(\"-\"))) {\n if (forceProp) {\n prop = prop.slice(5);\n isProp = true;\n } else if (sharedConfig.context) return value;\n if (prop === \"class\" || prop === \"className\") className(node, value);else if (isCE && !isProp && !isChildProp) node[toPropertyName(prop)] = value;else node[propAlias || prop] = value;\n } else {\n const ns = isSVG && prop.indexOf(\":\") > -1 && SVGNamespace[prop.split(\":\")[0]];\n if (ns) setAttributeNS(node, ns, prop, value);else setAttribute(node, Aliases[prop] || prop, value);\n }\n return value;\n}\nfunction eventHandler(e) {\n const key = `$$${e.type}`;\n let node = e.composedPath && e.composedPath()[0] || e.target;\n if (e.target !== node) {\n Object.defineProperty(e, \"target\", {\n configurable: true,\n value: node\n });\n }\n Object.defineProperty(e, \"currentTarget\", {\n configurable: true,\n get() {\n return node || document;\n }\n });\n if (sharedConfig.registry && !sharedConfig.done) sharedConfig.done = _$HY.done = true;\n while (node) {\n const handler = node[key];\n if (handler && !node.disabled) {\n const data = node[`${key}Data`];\n data !== undefined ? handler.call(node, data, e) : handler.call(node, e);\n if (e.cancelBubble) return;\n }\n node = node._$host || node.parentNode || node.host;\n }\n}\nfunction insertExpression(parent, value, current, marker, unwrapArray) {\n if (sharedConfig.context) {\n !current && (current = [...parent.childNodes]);\n let cleaned = [];\n for (let i = 0; i < current.length; i++) {\n const node = current[i];\n if (node.nodeType === 8 && node.data.slice(0, 2) === \"!$\") node.remove();else cleaned.push(node);\n }\n current = cleaned;\n }\n while (typeof current === \"function\") current = current();\n if (value === current) return current;\n const t = typeof value,\n multi = marker !== undefined;\n parent = multi && current[0] && current[0].parentNode || parent;\n if (t === \"string\" || t === \"number\") {\n if (sharedConfig.context) return current;\n if (t === \"number\") value = value.toString();\n if (multi) {\n let node = current[0];\n if (node && node.nodeType === 3) {\n node.data = value;\n } else node = document.createTextNode(value);\n current = cleanChildren(parent, current, marker, node);\n } else {\n if (current !== \"\" && typeof current === \"string\") {\n current = parent.firstChild.data = value;\n } else current = parent.textContent = value;\n }\n } else if (value == null || t === \"boolean\") {\n if (sharedConfig.context) return current;\n current = cleanChildren(parent, current, marker);\n } else if (t === \"function\") {\n createRenderEffect(() => {\n let v = value();\n while (typeof v === \"function\") v = v();\n current = insertExpression(parent, v, current, marker);\n });\n return () => current;\n } else if (Array.isArray(value)) {\n const array = [];\n const currentArray = current && Array.isArray(current);\n if (normalizeIncomingArray(array, value, current, unwrapArray)) {\n createRenderEffect(() => current = insertExpression(parent, array, current, marker, true));\n return () => current;\n }\n if (sharedConfig.context) {\n if (!array.length) return current;\n if (marker === undefined) return [...parent.childNodes];\n let node = array[0];\n let nodes = [node];\n while ((node = node.nextSibling) !== marker) nodes.push(node);\n return current = nodes;\n }\n if (array.length === 0) {\n current = cleanChildren(parent, current, marker);\n if (multi) return current;\n } else if (currentArray) {\n if (current.length === 0) {\n appendNodes(parent, array, marker);\n } else reconcileArrays(parent, current, array);\n } else {\n current && cleanChildren(parent);\n appendNodes(parent, array);\n }\n current = array;\n } else if (value.nodeType) {\n if (sharedConfig.context && value.parentNode) return current = multi ? [value] : value;\n if (Array.isArray(current)) {\n if (multi) return current = cleanChildren(parent, current, marker, value);\n cleanChildren(parent, current, null, value);\n } else if (current == null || current === \"\" || !parent.firstChild) {\n parent.appendChild(value);\n } else parent.replaceChild(value, parent.firstChild);\n current = value;\n } else ;\n return current;\n}\nfunction normalizeIncomingArray(normalized, array, current, unwrap) {\n let dynamic = false;\n for (let i = 0, len = array.length; i < len; i++) {\n let item = array[i],\n prev = current && current[i],\n t;\n if (item == null || item === true || item === false) ; else if ((t = typeof item) === \"object\" && item.nodeType) {\n normalized.push(item);\n } else if (Array.isArray(item)) {\n dynamic = normalizeIncomingArray(normalized, item, prev) || dynamic;\n } else if (t === \"function\") {\n if (unwrap) {\n while (typeof item === \"function\") item = item();\n dynamic = normalizeIncomingArray(normalized, Array.isArray(item) ? item : [item], Array.isArray(prev) ? prev : [prev]) || dynamic;\n } else {\n normalized.push(item);\n dynamic = true;\n }\n } else {\n const value = String(item);\n if (prev && prev.nodeType === 3 && prev.data === value) normalized.push(prev);else normalized.push(document.createTextNode(value));\n }\n }\n return dynamic;\n}\nfunction appendNodes(parent, array, marker = null) {\n for (let i = 0, len = array.length; i < len; i++) parent.insertBefore(array[i], marker);\n}\nfunction cleanChildren(parent, current, marker, replacement) {\n if (marker === undefined) return parent.textContent = \"\";\n const node = replacement || document.createTextNode(\"\");\n if (current.length) {\n let inserted = false;\n for (let i = current.length - 1; i >= 0; i--) {\n const el = current[i];\n if (node !== el) {\n const isParent = el.parentNode === parent;\n if (!inserted && !i) isParent ? parent.replaceChild(node, el) : parent.insertBefore(node, marker);else isParent && el.remove();\n } else inserted = true;\n }\n } else parent.insertBefore(node, marker);\n return [node];\n}\nfunction gatherHydratable(element, root) {\n const templates = element.querySelectorAll(`*[data-hk]`);\n for (let i = 0; i < templates.length; i++) {\n const node = templates[i];\n const key = node.getAttribute(\"data-hk\");\n if ((!root || key.startsWith(root)) && !sharedConfig.registry.has(key)) sharedConfig.registry.set(key, node);\n }\n}\nfunction getHydrationKey() {\n const hydrate = sharedConfig.context;\n return `${hydrate.id}${hydrate.count++}`;\n}\nfunction NoHydration(props) {\n return sharedConfig.context ? undefined : props.children;\n}\nfunction Hydration(props) {\n return props.children;\n}\nfunction voidFn() {}\nconst RequestContext = Symbol();\nfunction innerHTML(parent, content) {\n !sharedConfig.context && (parent.innerHTML = content);\n}\n\nfunction throwInBrowser(func) {\n const err = new Error(`${func.name} is not supported in the browser, returning undefined`);\n console.error(err);\n}\nfunction renderToString(fn, options) {\n throwInBrowser(renderToString);\n}\nfunction renderToStringAsync(fn, options) {\n throwInBrowser(renderToStringAsync);\n}\nfunction renderToStream(fn, options) {\n throwInBrowser(renderToStream);\n}\nfunction ssr(template, ...nodes) {}\nfunction ssrElement(name, props, children, needsId) {}\nfunction ssrClassList(value) {}\nfunction ssrStyle(value) {}\nfunction ssrAttribute(key, value) {}\nfunction ssrHydrationKey() {}\nfunction resolveSSRNode(node) {}\nfunction escape(html) {}\nfunction ssrSpread(props, isSVG, skipChildren) {}\n\nconst isServer = false;\nconst isDev = false;\nconst SVG_NAMESPACE = \"http://www.w3.org/2000/svg\";\nfunction createElement(tagName, isSVG = false) {\n return isSVG ? document.createElementNS(SVG_NAMESPACE, tagName) : document.createElement(tagName);\n}\nconst hydrate = (...args) => {\n enableHydration();\n return hydrate$1(...args);\n};\nfunction Portal(props) {\n const {\n useShadow\n } = props,\n marker = document.createTextNode(\"\"),\n mount = () => props.mount || document.body,\n owner = getOwner();\n let content;\n let hydrating = !!sharedConfig.context;\n createEffect(() => {\n if (hydrating) getOwner().user = hydrating = false;\n content || (content = runWithOwner(owner, () => createMemo(() => props.children)));\n const el = mount();\n if (el instanceof HTMLHeadElement) {\n const [clean, setClean] = createSignal(false);\n const cleanup = () => setClean(true);\n createRoot(dispose => insert(el, () => !clean() ? content() : dispose(), null));\n onCleanup(cleanup);\n } else {\n const container = createElement(props.isSVG ? \"g\" : \"div\", props.isSVG),\n renderRoot = useShadow && container.attachShadow ? container.attachShadow({\n mode: \"open\"\n }) : container;\n Object.defineProperty(container, \"_$host\", {\n get() {\n return marker.parentNode;\n },\n configurable: true\n });\n insert(renderRoot, content);\n el.appendChild(container);\n props.ref && props.ref(container);\n onCleanup(() => el.removeChild(container));\n }\n }, undefined, {\n render: !hydrating\n });\n return marker;\n}\nfunction Dynamic(props) {\n const [p, others] = splitProps(props, [\"component\"]);\n const cached = createMemo(() => p.component);\n return createMemo(() => {\n const component = cached();\n switch (typeof component) {\n case \"function\":\n return untrack(() => component(others));\n case \"string\":\n const isSvg = SVGElements.has(component);\n const el = sharedConfig.context ? getNextElement() : createElement(component, isSvg);\n spread(el, others, isSvg);\n return el;\n }\n });\n}\n\nexport { Aliases, voidFn as Assets, ChildProperties, DOMElements, DelegatedEvents, Dynamic, Hydration, voidFn as HydrationScript, NoHydration, Portal, Properties, RequestContext, SVGElements, SVGNamespace, addEventListener, assign, classList, className, clearDelegatedEvents, delegateEvents, dynamicProperty, escape, voidFn as generateHydrationScript, voidFn as getAssets, getHydrationKey, getNextElement, getNextMarker, getNextMatch, getPropAlias, voidFn as getRequestEvent, hydrate, innerHTML, insert, isDev, isServer, render, renderToStream, renderToString, renderToStringAsync, resolveSSRNode, runHydrationEvents, setAttribute, setAttributeNS, setProperty, spread, ssr, ssrAttribute, ssrClassList, ssrElement, ssrHydrationKey, ssrSpread, ssrStyle, style, template, use, voidFn as useAssets };\n","import { register } from \"component-register\";\nexport { hot, getCurrentElement, noShadowDOM } from \"component-register\";\nimport { createRoot, createSignal } from \"solid-js\";\nimport { insert } from \"solid-js/web\";\nfunction createProps(raw) {\n const keys = Object.keys(raw);\n const props = {};\n for (let i = 0; i < keys.length; i++) {\n const [get, set] = createSignal(raw[keys[i]]);\n Object.defineProperty(props, keys[i], {\n get,\n set(v) {\n set(() => v);\n }\n });\n }\n return props;\n}\nfunction lookupContext(el) {\n if (el.assignedSlot && el.assignedSlot._$owner) return el.assignedSlot._$owner;\n let next = el.parentNode;\n while (next && !next._$owner && !(next.assignedSlot && next.assignedSlot._$owner))\n next = next.parentNode;\n return next && next.assignedSlot ? next.assignedSlot._$owner : el._$owner;\n}\nfunction withSolid(ComponentType) {\n return (rawProps, options) => {\n const { element } = options;\n return createRoot(dispose => {\n const props = createProps(rawProps);\n element.addPropertyChangedCallback((key, val) => (props[key] = val));\n element.addReleaseCallback(() => {\n element.renderRoot.textContent = \"\";\n dispose();\n });\n const comp = ComponentType(props, options);\n return insert(element.renderRoot, comp);\n }, lookupContext(element));\n };\n}\nfunction customElement(tag, props, ComponentType) {\n if (arguments.length === 2) {\n ComponentType = props;\n props = {};\n }\n return register(tag, props)(withSolid(ComponentType));\n}\nexport { withSolid, customElement };\n","import { Accessor, createRenderEffect, Setter, Signal } from \"solid-js\";\r\n\r\nexport interface IDragHandler {\r\n name: string;\r\n handle?: HTMLElement;\r\n\r\n start(ev: DragEvent): void;\r\n stop(ev: DragEvent): void;\r\n}\r\n\r\nexport interface IDropHandler {\r\n name: string;\r\n\r\n drop(ev: DragEvent, dragHandler: IDragHandler): void;\r\n enter(ev: DragEvent, dragHandler: IDragHandler): void;\r\n leave(ev: DragEvent, dragHandler: IDragHandler): void;\r\n over(ev: DragEvent, dragHandler: IDragHandler): void;\r\n}\r\n\r\n// Prepare the draggable directive\r\ndeclare module 'solid-js' {\r\n namespace JSX {\r\n interface Directives {\r\n draggable: IDragHandler;\r\n droppable: IDropHandler;\r\n }\r\n }\r\n}\r\n\r\ndeclare global {\r\n interface Window {\r\n draggable: (options?: IDragHandler) => void;\r\n droppable: (options?: IDropHandler) => void;\r\n }\r\n}\r\n\r\nlet draggingEl: HTMLElement;\r\nlet dragHandler: IDragHandler | undefined;\r\nlet dropHandler: IDropHandler | undefined;\r\n\r\nwindow.addEventListener('dragover', ev => ev.preventDefault());\r\nwindow.draggable = window.draggable ?? function (el: HTMLElement, accessor: () => IDragHandler | undefined) {\r\n const handler = accessor();\r\n let canDrag = true;\r\n\r\n if (!handler) return;\r\n el.addEventListener('mousedown', (ev: MouseEvent) => {\r\n canDrag = !handler.handle || ev.target === handler.handle;\r\n });\r\n\r\n el.setAttribute('draggable', 'true');\r\n el.addEventListener('dragstart', function (this: HTMLElement, ev: DragEvent) {\r\n if (!canDrag) {\r\n ev.preventDefault();\r\n return;\r\n }\r\n\r\n dragHandler = handler;\r\n draggingEl = el;\r\n\r\n ev.dataTransfer!.setDragImage(new Image(), 0, 0);\r\n handler.start(ev);\r\n });\r\n\r\n el.addEventListener('dragend', function (this: HTMLElement, ev: DragEvent) {\r\n handler.stop(ev);\r\n\r\n dragHandler = undefined;\r\n dropHandler = undefined;\r\n });\r\n}\r\n\r\nwindow.droppable = window.droppable ?? function (el: HTMLElement, accessor: () => IDropHandler) {\r\n const handler = accessor();\r\n\r\n function canDropFrom(dragHandler: IDragHandler | undefined) {\r\n return draggingEl !== el\r\n && ((!handler.name && !dragHandler?.name)\r\n || !!handler.name.split(',').find(n => n === dragHandler?.name));\r\n }\r\n\r\n el.addEventListener('dragenter', function (this: HTMLElement, ev: DragEvent) {\r\n ev.preventDefault();\r\n ev.stopPropagation();\r\n\r\n if (dropHandler !== handler) {\r\n dropHandler = handler;\r\n if (canDropFrom(dragHandler)) {\r\n handler.enter(ev, dragHandler!);\r\n }\r\n }\r\n });\r\n\r\n el.addEventListener('dragleave', function (this: HTMLElement, ev: DragEvent) {\r\n ev.stopPropagation();\r\n const relatedTarget = ev.relatedTarget as Node;\r\n\r\n if (relatedTarget !== el && !el.contains(relatedTarget)) {\r\n if (canDropFrom(dragHandler)) {\r\n handler.leave(ev, dragHandler!);\r\n }\r\n dropHandler = undefined;\r\n }\r\n });\r\n\r\n el.addEventListener('dragover', function (this: HTMLElement, ev: DragEvent) {\r\n ev.preventDefault();\r\n\r\n const dt = ev.dataTransfer;\r\n if (!dt) return;\r\n\r\n dropHandler = handler;\r\n if (canDropFrom(dragHandler)) {\r\n handler.over(ev, dragHandler!);\r\n }\r\n\r\n dt.dropEffect = \"move\";\r\n });\r\n\r\n el.addEventListener('drop', function (this: HTMLElement, ev: DragEvent) {\r\n ev.preventDefault();\r\n ev.stopPropagation();\r\n\r\n if (canDropFrom(dragHandler)) {\r\n handler.drop(ev, dragHandler!);\r\n }\r\n dropHandler = undefined;\r\n });\r\n}\r\n\r\n","import { Accessor } from \"solid-js\";\r\nimport '../content/st_api.css';\r\n\r\nexport type TooltipPlacement = 'top' | 'left' | 'bottom' | 'right';\r\n\r\nexport class TooltipOptions {\r\n tooltip: string;\r\n placement: TooltipPlacement = 'top';\r\n\r\n constructor(tooltip: string) {\r\n this.tooltip = tooltip;\r\n }\r\n}\r\n\r\n// Prepare the tooltip directive\r\ndeclare module \"solid-js\" {\r\n namespace JSX {\r\n interface Directives {\r\n tooltip: string | TooltipOptions;\r\n }\r\n }\r\n}\r\n\r\ndeclare global {\r\n interface Window {\r\n tooltip: (el: HTMLButtonElement, params: Accessor) => void;\r\n }\r\n}\r\n\r\n// Create the tooltip div\r\nconst tooltipElement = document.createElement('div');\r\ntooltipElement.classList.add('st-tooltip');\r\n\r\nconst tooltipArrow = document.createElement('span');\r\ntooltipArrow.classList.add('tooltip-arrow');\r\ntooltipElement.appendChild(tooltipArrow);\r\n\r\nconst tooltipContent = document.createElement('div');\r\ntooltipContent.classList.add('tooltip-content');\r\ntooltipElement.appendChild(tooltipContent);\r\n\r\n// If the current element we are tooltiping is removed from the dom, detach the tooltip\r\nlet currentElement: HTMLElement | undefined = undefined;\r\nsetInterval(() => {\r\n if (currentElement && tooltipElement.isConnected && !currentElement.isConnected && document.body.contains(tooltipElement)) {\r\n currentElement = undefined;\r\n document.body.removeChild(tooltipElement);\r\n }\r\n}, 250);\r\n\r\nwindow.tooltip = window.tooltip ?? ((el: HTMLButtonElement, params: Accessor) => {\r\n\r\n el.addEventListener('mouseenter', () => {\r\n if (!params()) return;\r\n let options = params();\r\n if (typeof options === 'string') {\r\n options = new TooltipOptions(options);\r\n }\r\n\r\n currentElement = el;\r\n\r\n tooltipContent.innerText = options.tooltip;\r\n tooltipElement.style.minWidth = '';\r\n tooltipElement.style.opacity = '0';\r\n\r\n const rootElement = el.closest('dialog') || document.body;\r\n rootElement.appendChild(tooltipElement);\r\n\r\n repositionTooltip(el, options);\r\n tooltipElement.style.opacity = '';\r\n })\r\n\r\n el.addEventListener('mouseleave', () => {\r\n const rootElement = el.closest('dialog') || document.body;\r\n if (rootElement?.contains(tooltipElement)) {\r\n rootElement.removeChild(tooltipElement);\r\n }\r\n });\r\n\r\n el.addEventListener('mousedown', () => {\r\n tooltipElement.style.opacity = '0';\r\n });\r\n});\r\n\r\nfunction repositionTooltip(el: HTMLElement, options: TooltipOptions) {\r\n const rootElement = el.closest('dialog') || document.body;\r\n\r\n if (tooltipElement && currentElement) {\r\n const bodyRect = rootElement.getBoundingClientRect();\r\n const elRect = currentElement.getBoundingClientRect();\r\n\r\n tooltipElement.setAttribute('data-placement', options.placement);\r\n tooltipElement.style.left = tooltipElement.style.top = tooltipElement.style.bottom = tooltipElement.style.right = '';\r\n\r\n // Set the default position\r\n if (options.placement === 'top' || options.placement === 'bottom') {\r\n tooltipElement.style.minWidth = elRect.width + 'px';\r\n const ttRect = tooltipElement.getBoundingClientRect();\r\n const hcenter_offset = (elRect.width - ttRect.width) / 2;\r\n\r\n tooltipElement.style.left = (elRect.x + hcenter_offset) + 'px';\r\n if (options.placement === 'top') {\r\n tooltipElement.style.top = (elRect.top - ttRect.height - 6) + 'px';\r\n }\r\n else if (options.placement === 'bottom') {\r\n tooltipElement.style.top = elRect.bottom + 'px';\r\n }\r\n\r\n // If we are outside the screen, set the right position\r\n if (tooltipElement.getBoundingClientRect().right > bodyRect.right) {\r\n tooltipElement.style.left = '';\r\n tooltipElement.style.right = (bodyRect.right - elRect.right) + 'px';\r\n }\r\n\r\n // Check if we should render above the button\r\n if (tooltipElement.getBoundingClientRect().bottom > bodyRect.bottom) {\r\n tooltipElement.setAttribute('data-placement', 'top');\r\n tooltipElement.style.top = (elRect.top - ttRect.height) + 'px';\r\n }\r\n }\r\n else {\r\n tooltipElement.style.minWidth = '';\r\n const ttRect = tooltipElement.getBoundingClientRect();\r\n const vcenter_offset = (elRect.height - ttRect.height) / 2;\r\n tooltipElement.style.top = (elRect.top + vcenter_offset) + 'px';\r\n\r\n if (options.placement === 'right') {\r\n tooltipElement.style.left = elRect.right + 'px';\r\n }\r\n else if (options.placement === 'left') {\r\n tooltipElement.style.left = (elRect.left - ttRect.width) + 'px';\r\n }\r\n\r\n // If we are outside the screen, set the right position\r\n if (tooltipElement.getBoundingClientRect().right > bodyRect.right) {\r\n tooltipElement.setAttribute('data-placement', 'left');\r\n tooltipElement.style.left = (elRect.left - ttRect.width) + 'px';\r\n }\r\n else if (tooltipElement.getBoundingClientRect().left < bodyRect.left) {\r\n tooltipElement.setAttribute('data-placement', 'right');\r\n tooltipElement.style.left = elRect.right + 'px';\r\n }\r\n }\r\n }\r\n}\r\n","import { Accessor, createRenderEffect, Setter, Signal } from \"solid-js\";\r\n\r\ndeclare module 'solid-js' {\r\n namespace JSX {\r\n interface Directives {\r\n visibleWith: HTMLElement\r\n }\r\n }\r\n}\r\n\r\ndeclare global {\r\n interface Window {\r\n visibleWith: (options?: HTMLElement) => void;\r\n }\r\n}\r\n\r\nwindow.visibleWith = window.visibleWith ?? ((el: HTMLElement, target: () => HTMLElement) => {\r\n el.style.transition = 'opacity linear 0.5s';\r\n el.style.opacity = '0.1';\r\n\r\n target()?.addEventListener('mouseenter', ev => {\r\n el.style.opacity = '1';\r\n });\r\n\r\n target().addEventListener('mouseleave', ev => {\r\n el.style.opacity = '0.1';\r\n });\r\n});\r\n","import { Accessor, JSXElement, ParentProps, Signal, createEffect, createSignal, onCleanup, createContext, useContext } from \"solid-js\";\r\nimport { render } from \"solid-js/web\";\r\n\r\nimport styles from './contextmenu.module.css';\r\n\r\n// Prepare the tooltip directive\r\ndeclare module \"solid-js\" {\r\n namespace JSX {\r\n interface Directives {\r\n contextMenu: JSXElement;\r\n }\r\n }\r\n}\r\n\r\ndeclare global {\r\n interface Window {\r\n contextMenu: (el: HTMLElement, params: Accessor) => void;\r\n }\r\n}\r\n\r\nclass ContextMenuContext {\r\n parent: HTMLElement\r\n\r\n constructor(parent: HTMLElement) {\r\n this.parent = parent;\r\n }\r\n\r\n close() {\r\n closeContextMenu();\r\n }\r\n}\r\n\r\nconst ContextMenuContextInstance = createContext(new ContextMenuContext(undefined!));\r\nexport function useContextMenuContext() { return useContext(ContextMenuContextInstance) }\r\n\r\nwindow.contextMenu = window.contextMenu ?? ((el: HTMLElement, params: Accessor) => {\r\n el.addEventListener('contextmenu', ev => {\r\n if (ev.ctrlKey) return;\r\n\r\n const ctx = new ContextMenuContext(el);\r\n ev.preventDefault();\r\n\r\n closeInstance = render(() => \r\n \r\n {params()}\r\n \r\n , contextMenuContainer);\r\n });\r\n});\r\n\r\nlet closeInstance: (() => void) | undefined;\r\n\r\ndocument.addEventListener('mousedown', closeContextMenu);\r\nwindow.addEventListener('focusout', closeContextMenu);\r\nwindow.addEventListener('blur', closeContextMenu);\r\nfunction closeContextMenu() {\r\n if (closeInstance) {\r\n closeInstance();\r\n closeInstance = undefined;\r\n }\r\n}\r\n\r\nlet contextMenuContainer = document.createElement('div');\r\ndocument.addEventListener('DOMContentLoaded', () => {\r\n contextMenuContainer.classList.add(styles.contextMenuContainer);\r\n document.body.appendChild(contextMenuContainer);\r\n});\r\n\r\ninterface ContextMenuOptions {\r\n x: number,\r\n y: number\r\n}\r\n\r\nfunction ContextMenu(props: ParentProps) {\r\n const ctx = useContextMenuContext();\r\n\r\n function initElement(el: HTMLDivElement) {\r\n el.addEventListener('mousedown', ev => ev.stopPropagation());\r\n\r\n reposition(el, props.x, props.y);\r\n }\r\n\r\n return
\r\n {props.children}\r\n
\r\n}\r\n\r\nfunction reposition(el: HTMLElement, x: number, y: number) {\r\n el.style.left = `${x}px`;\r\n el.style.top = `${y}px`;\r\n\r\n const bodyRect = document.body.getBoundingClientRect();\r\n const elRect = el.getBoundingClientRect();\r\n\r\n if (elRect.bottom < bodyRect.bottom && elRect.top - elRect.height > 0) {\r\n el.style.top = `${x - elRect.height}px`;\r\n }\r\n if (elRect.right < bodyRect.right && elRect.left - elRect.width > 0) {\r\n el.style.left = `${y - elRect.width}px`;\r\n }\r\n}\r\n","import { customElement } from \"solid-element\";\r\nimport { Accessor, Component, createRenderEffect, createSignal, Setter, Signal } from \"solid-js\";\r\nimport { render } from 'solid-js/web'\r\n//import ko from 'knockout'\r\nimport './index.css';\r\nimport '@lib/draggable';\r\nimport '@lib/tooltip';\r\nimport '@lib/visibleWith';\r\nimport './Common/lib/contextmenu';\r\nimport { StoryDefinition, StoryMetadata } from \"@lib/stories\";\r\n\r\n// onMouseWheel was removed from typescript (moved to window).\r\ndeclare module 'solid-js' {\r\n namespace JSX {\r\n interface IntrinsicElements {\r\n div: HTMLAttributes & {\r\n onMouseWheel?: (event: MouseEvent) => void;\r\n };\r\n }\r\n }\r\n}\r\n\r\ndeclare global {\r\n interface ST {\r\n OpenOverlay(element: HTMLElement | undefined, xmlRequest: any): Promise\r\n OpenViewInDialog(viewID: string, identity: string): Promise\r\n TransformImagePath(path: string | undefined): string\r\n }\r\n\r\n interface ComponentDefinition {\r\n name: string,\r\n component: Component,\r\n defaultParams: any,\r\n module: string,\r\n metadata: () => StoryMetadata\r\n stories: Record StoryDefinition>,\r\n }\r\n\r\n interface Window {\r\n ST: ST\r\n solidComponents: Record\r\n }\r\n}\r\n\r\nexport async function registerSolidJSComponents(components: Record Promise>) {\r\n const loadedComponents = await Promise.allSettled(Object.entries(components).map(async (cmp) => {\r\n const fpath: string = cmp[0];\r\n const module: any = await cmp[1]();\r\n\r\n if (fpath.endsWith('.stories.tsx')) return;\r\n if (fpath.endsWith('.test.tsx')) return;\r\n\r\n const detail = componentDetails(fpath);\r\n if (detail && module.default) {\r\n window.solidComponents = window.solidComponents || { };\r\n\r\n window.solidComponents[detail.componentName] = {\r\n name: detail.componentName,\r\n component: module.default,\r\n module: import.meta.env.VITE_NS,\r\n defaultParams: module.defaultParams ?? { },\r\n stories: { },\r\n metadata: () => ({\r\n component: module.default,\r\n props: { }\r\n })\r\n }\r\n\r\n const storiesModule = await components[fpath.replace('.tsx', '.stories.tsx')]?.() as any\r\n\r\n if (storiesModule) {\r\n const { default: metadata, ...stories } = storiesModule\r\n window.solidComponents[detail.componentName].metadata = metadata\r\n window.solidComponents[detail.componentName].stories = stories\r\n }\r\n\r\n return detail.componentName\r\n }\r\n }))\r\n \r\n for (const loadedComponent of loadedComponents) {\r\n if (loadedComponent.status === 'rejected' || !loadedComponent.value) {\r\n continue;\r\n }\r\n\r\n const componentName = loadedComponent.value\r\n const { component, defaultParams } = window.solidComponents[componentName]\r\n\r\n if (customElements.get(componentName) || (window as any).ko?.components.isRegistered(componentName)) {\r\n try { console.error(`Duplicate Component: ${componentName}`); }\r\n catch { }\r\n } else {\r\n //console.log(`Registering SolidJS Component: ${componentName}`);\r\n customElement(componentName, defaultParams, component);\r\n }\r\n }\r\n\r\n //window.dispatchEvent(solidJSCreated);\r\n}\r\n\r\nexport async function registerKnockoutComponents(modules: Record Promise>) {\r\n return;\r\n}\r\n\r\nfunction componentDetails(fpath: string) {\r\n const idx = fpath.indexOf('/components/') + '/components/'.length;\r\n const parts = fpath.substring(idx).split('/');\r\n\r\n const res = {\r\n componentName: parts[parts.length - 1].split('.').slice(0, -1).join('.'),\r\n dirName: parts[parts.length - 2],\r\n }; \r\n\r\n if ((res.dirName === res.componentName) || !res.dirName) {\r\n return res;\r\n }\r\n}\r\n\r\n/**\r\n * Ensure global styles associated with components are cascaded down through\r\n * each shadowroot node.\r\n */\r\nexport function initCascadingStyleSheets()\r\n{\r\n let styles: any = null;\r\n\r\n const styleObserver = new MutationObserver((mutations) => {\r\n for (var m of mutations) {\r\n for (var n of m.addedNodes) {\r\n const key = n.parentElement?.getAttribute('data-vite-dev-id');\r\n if (key) {\r\n const sheet = styles[key];\r\n sheet.replace(n.textContent);\r\n }\r\n }\r\n }\r\n });\r\n\r\n const ignoredStylesheets: string[] = ['bootstrap'];\r\n function initStylesheets() {\r\n if (!styles) {\r\n // We need to ensure only component styles are cascaded down. Blindly cascading all sheets causes issues\r\n // when there are relative paths to resources like fonts.\r\n styles = styles || Array.from(document.head.querySelectorAll('style,link'))\r\n .reduce((obj: any, it) => {\r\n if (it.nodeName === 'STYLE' && it.getAttribute('data-vite-dev-id')) {\r\n const key = it.getAttribute('data-vite-dev-id') || '';\r\n const stylesheet = cloneStylesheet(it);\r\n\r\n if (stylesheet) {\r\n obj[key] = stylesheet;\r\n\r\n // Hot-swap support\r\n styleObserver.observe(it, {\r\n childList: true\r\n });\r\n }\r\n }\r\n else if (it.nodeName === 'LINK' && it.getAttribute('rel') === 'stylesheet' && it.getAttribute('href')) {\r\n const key = (it.getAttribute('href') || '').toLowerCase();\r\n\r\n const shouldInclude = it.getAttribute('data-always-include') || !ignoredStylesheets.find(s => key.indexOf(s) >= 0)\r\n if (shouldInclude) {\r\n const stylesheet = cloneStylesheet(it);\r\n if (stylesheet) {\r\n obj[key] = stylesheet;\r\n }\r\n }\r\n\r\n // We only need to apply bundle styles to components, so detach this from the main from\r\n if (key.endsWith('.bundle.js')) {\r\n it.parentNode?.removeChild(it);\r\n }\r\n }\r\n\r\n return obj;\r\n }, {});\r\n }\r\n }\r\n\r\n function loadBaseUrl(href: string) {\r\n let res = undefined;\r\n\r\n const idx = href?.lastIndexOf('/') || -1;\r\n if (idx > -1) {\r\n res = href.substring(0, idx);\r\n }\r\n\r\n return res;\r\n }\r\n\r\n function cloneStylesheet(lnk: any) {\r\n const sheet = lnk.sheet;\r\n const baseURL = loadBaseUrl(lnk.getAttribute('href'));\r\n\r\n if (!sheet) {\r\n return;\r\n }\r\n\r\n const stylesheet = new CSSStyleSheet({\r\n baseURL\r\n });\r\n\r\n const cssText = Array.from(sheet.cssRules)\r\n .map((rule: any) => rule.cssText)\r\n .join('\\n');\r\n\r\n stylesheet.replaceSync(cssText);\r\n return stylesheet;\r\n }\r\n\r\n // Detect the addition of components and add references to the global stylesheets into them\r\n HTMLElement.prototype.attachShadow = (function (attachShadow: any) {\r\n return function (this: any) {\r\n initStylesheets();\r\n\r\n const sh = attachShadow.apply(this, arguments)\r\n for (var key of Object.keys(styles)) {\r\n const css = styles[key];\r\n sh.adoptedStyleSheets.push(css);\r\n }\r\n\r\n return sh\r\n }\r\n })(HTMLElement.prototype.attachShadow);\r\n}\r\n\r\ndeclare global {\r\n interface Window {\r\n SolidJs: {\r\n renderSolidComponent: (component: Component, element: HTMLElement, props: any) => void,\r\n createSignal: typeof createSignal\r\n }\r\n }\r\n}\r\nwindow.SolidJs = {\r\n createSignal: createSignal,\r\n renderSolidComponent: (component, element, props) => {\r\n render(() => component(props ?? {}), element)\r\n }\r\n};\r\n\r\n// Prepare the binding directive\r\ndeclare module 'solid-js' {\r\n namespace JSX {\r\n interface Directives {\r\n model: [accessor: Accessor, setter: Setter]\r\n }\r\n }\r\n}\r\n\r\ndeclare global {\r\n interface Window {\r\n model: (accessor : Accessor, setter: Setter) => void;\r\n\r\n }\r\n}\r\n\r\nwindow.model = window.model ?? ((el: HTMLInputElement, accessor: () => Signal) => {\r\n const [field, setField] = accessor() || [];\r\n\r\n if (!field || !setField) return;\r\n\r\n el.addEventListener(\"input\", onInput);\r\n\r\n createRenderEffect(() => (el.type === 'checkbox' ? el.checked = field() as boolean : el.value = field() as string));\r\n\r\n function onInput(this: HTMLInputElement, e: Event) {\r\n if (this.type === 'checkbox') {\r\n setField(this.checked)\r\n } else {\r\n setField(this.value);\r\n }\r\n }\r\n});\r\n","import { registerSolidJSComponents, registerKnockoutComponents } from '../index';\r\n\r\nregisterSolidJSComponents(import.meta.glob('./components/**/*.{jsx,tsx}'));\r\nregisterKnockoutComponents(import.meta.glob('./components/**/*.{ts}'));\r\n","import { Show, Signal, createContext, createMemo, createSignal, useContext } from \"solid-js\";\r\nimport api from 'pxp-api/pxp-datepicker';\r\n\r\nclass PXPCalendarData { }\r\nclass PxpDatepickerContext {\r\n calendarData: Signal = createSignal()\r\n\r\n translate(key: string): string {\r\n return key;\r\n }\r\n}\r\n\r\nclass PxpDatepickerProps {\r\n context?: PxpDatepickerContext\r\n}\r\n\r\nconst pxpDatepickerContext = createContext(new PxpDatepickerContext());\r\nexport const defaultParams = new PxpDatepickerProps();\r\nexport const usePxpDatepickerContext = () => useContext(pxpDatepickerContext);\r\n\r\nexport default function PXPDatePicker(props: PxpDatepickerProps) {\r\n const context = createMemo(() => props.context || new PxpDatepickerContext());\r\n const calendarData = createMemo(() => context()?.calendarData[0]());\r\n\r\n \r\n \r\n \r\n \r\n \r\n}\r\n\r\nfunction Calendar() {\r\n const ctx = usePxpDatepickerContext();\r\n\r\n return
\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
{ctx.translate('MonthAtAGlance')}
{ctx.translate('Sun')}{ctx.translate('Mon')}{ctx.translate('Tue')}{ctx.translate('Wed')}{ctx.translate('Thu')}{ctx.translate('Fri')}{ctx.translate('Sat')}
\r\n \r\n
\r\n
\r\n}","const TEST_STRING = 'PXP Test Build';\r\n\r\nexport default function () {\r\n return
{TEST_STRING}
\r\n}\r\n"],"names":["cloneProps","props","memo","k","prop","isObject","isFunction","normalizePropDefs","v","toAttribute","propValues","initializeProps","element","propDefinition","key","attr","value","parseAttributeValue","reflect","val","oldValue","i","l","node","attribute","propName","x","y","obj","isConstructor","f","currentElement","createElementType","BaseElement","propKeys","ComponentType","outerElement","callback","name","oldVal","newVal","attrName","fn","register","tag","options","extension","ElementType","signalOptions","a","b","runEffects","runQueue","STALE","PENDING","UNOWNED","Owner","Transition","Listener","Updates","Effects","ExecCount","createRoot","detachedOwner","listener","owner","unowned","current","root","updateFn","untrack","cleanNode","runUpdates","createSignal","s","setter","writeSignal","readSignal","createRenderEffect","c","createComputation","updateComputation","createMemo","createContext","defaultValue","id","createProvider","useContext","context","children","resolveChildren","updates","lookUpstream","sSlot","isComp","o","TransitionRunning","markDownstream","time","runComputation","nextValue","err","handleError","init","pure","state","runTop","ancestors","wait","res","completeUpdates","e","queue","ignore","source","index","obs","n","castError","results","result","createComponent","Comp","narrowedError","Show","keyed","condition","child","reconcileArrays","parentNode","bLength","aEnd","bEnd","aStart","bStart","after","map","sequence","t","render","code","disposer","dispose","insert","template","html","isCE","isSVG","create","className","use","arg","parent","accessor","marker","initial","insertExpression","unwrapArray","multi","cleanChildren","array","currentArray","normalizeIncomingArray","appendNodes","normalized","unwrap","dynamic","len","item","prev","replacement","inserted","el","isParent","createProps","raw","keys","get","set","lookupContext","next","withSolid","rawProps","comp","customElement","draggingEl","dragHandler","dropHandler","ev","handler","canDrag","canDropFrom","relatedTarget","dt","TooltipOptions","tooltip","tooltipElement","tooltipArrow","tooltipContent","params","repositionTooltip","rootElement","bodyRect","elRect","ttRect","hcenter_offset","vcenter_offset","target","ContextMenuContext","constructor","close","closeContextMenu","ContextMenuContextInstance","undefined","useContextMenuContext","window","contextMenu","addEventListener","ctrlKey","ctx","preventDefault","closeInstance","_$createComponent","Provider","ContextMenu","pageX","pageY","contextMenuContainer","document","createElement","classList","add","styles","body","appendChild","initElement","stopPropagation","reposition","_el$","_tmpl$","_ref$","_$use","_$insert","_$effect","_$className","style","left","top","getBoundingClientRect","bottom","height","right","width","registerSolidJSComponents","components","loadedComponents","cmp","fpath","module","detail","componentDetails","storiesModule","metadata","stories","loadedComponent","componentName","component","defaultParams","registerKnockoutComponents","modules","idx","parts","field","setField","onInput","pxpDatepicker_test","pxpDatepicker","pxpLaunchPad$1","PxpDatepickerContext","calendarData","translate","PxpDatepickerProps","pxpDatepickerContext","usePxpDatepickerContext","PXPDatePicker","when","Calendar","_el$2","firstChild","_el$3","_el$4","_el$5","nextSibling","_el$6","_el$7","_el$8","_el$9","_el$10","_el$11","_el$12","_el$13","_el$14","_el$15","_el$16","_el$17","_el$18","_el$19","_el$20","pxpLaunchPad"],"mappings":"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","x_google_ignoreList":[0,1,2,3]}