instaui 0.1.15__py2.py3-none-any.whl → 0.1.17__py2.py3-none-any.whl

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1 +1 @@
1
- {"version":3,"file":"insta-ui.js","sources":["../src/shared/appInfo.ts","../src/systems/mapSystem.ts","../src/systems/objectSystem.ts","../src/shared/computedInit.ts","../src/systems/vueSystem.ts","../node_modules/.pnpm/@vueuse+shared@12.0.0_typescript@5.6.3/node_modules/@vueuse/shared/index.mjs","../node_modules/.pnpm/@vueuse+core@12.0.0_typescript@5.6.3/node_modules/@vueuse/core/index.mjs","../src/systems/jsCodeSystem.ts","../src/systems/fnSystem.ts","../src/shared/varBuilder.ts","../src/shared/varStore.ts","../src/shared/elementRefStore.ts","../src/shared/configTypes/vars.ts","../src/shared/slotStore.ts","../src/shared/vforManager.ts","../src/shared/jsStrVar.ts","../src/systems/valueSystem.ts","../node_modules/.pnpm/@vue+devtools-api@6.6.4/node_modules/@vue/devtools-api/lib/esm/env.js","../node_modules/.pnpm/@vue+devtools-api@6.6.4/node_modules/@vue/devtools-api/lib/esm/const.js","../node_modules/.pnpm/@vue+devtools-api@6.6.4/node_modules/@vue/devtools-api/lib/esm/time.js","../node_modules/.pnpm/@vue+devtools-api@6.6.4/node_modules/@vue/devtools-api/lib/esm/proxy.js","../node_modules/.pnpm/@vue+devtools-api@6.6.4/node_modules/@vue/devtools-api/lib/esm/index.js","../node_modules/.pnpm/vue-router@4.5.0_vue@3.5.13_typescript@5.6.3_/node_modules/vue-router/dist/vue-router.mjs","../src/shared/bindableHelper.ts","../src/shared/dataSender/webSender.ts","../src/shared/dataSender/webViewSender.ts","../src/shared/dataSender/index.ts","../src/shared/webComputed.ts","../src/shared/webWatchStore.ts","../src/shared/jsWatchStore.ts","../src/components/element/events.ts","../src/components/element/styles.ts","../src/components/element/classes.ts","../src/appUtils.ts","../src/components/element/props.ts","../src/components/slotPropContainer.ts","../src/components/element/slots.ts","../src/components/element/directives.ts","../src/components/element/elementRef.ts","../src/components/element/element.ts","../src/components/scopeContainer.ts","../src/app.ts","../src/App.vue","../src/components/vif/vif.ts","../src/systems/numberSystem.ts","../src/components/vfor/vfor.ts","../src/components/scope.ts","../src/components/refresh.ts","../src/components/matchCase.ts","../src/components/match.ts","../src/components/transitionGroup.ts","../src/components/content.ts","../src/shared/routerStore.ts","../src/shared/routerHelper.ts","../src/libMain.ts"],"sourcesContent":["import { TAppConfig } from \"@/shared/configTypes\";\r\n\r\ntype TSetupValue = {\r\n queryPath: string;\r\n version: string;\r\n mode: TAppConfig[\"mode\"];\r\n webServerInfo?: TAppConfig[\"webInfo\"];\r\n pathParams?: Record<string, any>;\r\n queryParams?: Record<string, any>;\r\n};\r\n\r\nlet setupInfo: TSetupValue;\r\n\r\nexport function setup(info: TSetupValue) {\r\n setupInfo = info;\r\n}\r\n\r\nexport function getInfo() {\r\n return setupInfo;\r\n}\r\n\r\nexport function getPageInfoPostData() {\r\n const { queryPath, pathParams, queryParams } = getInfo();\r\n const paramsItem = pathParams === undefined ? {} : { params: pathParams };\r\n const queryItem =\r\n queryParams === undefined ? {} : { queryParams: queryParams };\r\n\r\n return {\r\n path: queryPath,\r\n ...paramsItem,\r\n ...queryItem,\r\n };\r\n}\r\n","class DefaultMap<K, V> extends Map<K, V> {\r\n constructor(private factory: () => V) {\r\n super();\r\n }\r\n\r\n getOrDefault(key: K): V {\r\n if (!this.has(key)) {\r\n const defaultValue = this.factory();\r\n this.set(key, defaultValue);\r\n return defaultValue;\r\n }\r\n return super.get(key)!;\r\n }\r\n}\r\n\r\nexport function defaultMap<K, V>(factory: () => V): DefaultMap<K, V> {\r\n return new DefaultMap(factory);\r\n}\r\n","export function foreachObject<TValue>(\r\n obj: Record<string, TValue>,\r\n fn: (value: TValue, key: string) => any\r\n) {\r\n Object.entries(obj).forEach(([key, value]) => fn(value, key));\r\n}\r\n\r\nexport function mapObjectForValue<TValue>(\r\n obj: Record<string, TValue>,\r\n valueFn: (value: TValue, key: string, index: number) => any\r\n) {\r\n return mapObjectFor(obj, {\r\n valueFn,\r\n });\r\n}\r\n\r\nexport function mapObjectFor<TValue>(\r\n obj: Record<string, TValue>,\r\n fn: {\r\n valueFn: (value: TValue, key: string, index: number) => any;\r\n keyFn?: (key: string, value: TValue) => any;\r\n }\r\n) {\r\n const { valueFn, keyFn } = fn;\r\n\r\n return Object.fromEntries(\r\n Object.entries(obj).map(([key, value], index) => [\r\n keyFn ? keyFn(key, value) : key,\r\n valueFn(value, key, index),\r\n ])\r\n );\r\n}\r\n\r\nfunction handleObject(\r\n obj: any,\r\n path: string | number | any[],\r\n getBindableFn?: (value: any) => any\r\n) {\r\n if (Array.isArray(path)) {\r\n const [flag, ...args] = path as any[];\r\n\r\n switch (flag) {\r\n case \"!\":\r\n return !obj;\r\n\r\n case \"+\":\r\n return obj + args[0];\r\n\r\n case \"~+\":\r\n return args[0] + obj;\r\n }\r\n }\r\n\r\n const newPath = getPath(path, getBindableFn);\r\n return obj[newPath];\r\n}\r\n\r\nfunction getPath(\r\n path: string | number | any[],\r\n getBindableFn?: (value: any) => any\r\n) {\r\n if (typeof path === \"string\" || typeof path === \"number\") {\r\n return path;\r\n }\r\n\r\n if (!Array.isArray(path)) {\r\n throw new Error(`Invalid path ${path}`);\r\n }\r\n\r\n const [flag, ...args] = path as any[];\r\n switch (flag) {\r\n case \"bind\":\r\n if (!getBindableFn) {\r\n throw new Error(\"No bindable function provided\");\r\n }\r\n return getBindableFn(args[0]);\r\n\r\n default:\r\n throw new Error(`Invalid flag ${flag} in array at ${path}`);\r\n }\r\n}\r\n\r\nexport function getByPaths(\r\n object: any,\r\n paths: (string | number)[],\r\n getBindableFn?: (value: any) => any\r\n): any {\r\n return paths.reduce(\r\n (obj, path) => handleObject(obj, path, getBindableFn),\r\n object\r\n );\r\n}\r\n\r\nexport function setByPaths(\r\n object: any,\r\n paths: (string | number)[],\r\n value: any,\r\n getBindableFn?: (value: any) => any\r\n): void {\r\n paths.reduce((obj, path, index) => {\r\n if (index === paths.length - 1) {\r\n obj[getPath(path, getBindableFn)] = value;\r\n } else {\r\n return handleObject(obj, path, getBindableFn);\r\n }\r\n }, object);\r\n}\r\n\r\nexport function deepClone(obj: any) {\r\n return JSON.parse(JSON.stringify(obj));\r\n}\r\n","import { toRaw } from \"vue\";\r\n\r\nclass Initial {\r\n toString() {\r\n return ``;\r\n }\r\n}\r\n\r\nexport const __INITIAL__ = new Initial();\r\n\r\nexport function isInitial(value: any): boolean {\r\n return toRaw(value) === __INITIAL__;\r\n}\r\n","import { customRef, Ref, ComputedRef, toValue } from \"vue\";\r\nimport * as objectSystem from \"@/systems/objectSystem\";\r\nimport * as computedInit from \"@/shared/computedInit\";\r\n\r\nexport function makeRefObjectWithPaths(\r\n object: object | Ref<any> | ComputedRef,\r\n getterOptions: {\r\n paths?: (string | number)[] | undefined;\r\n getBindableValueFn: (value: any) => any;\r\n },\r\n setterOptions?: {\r\n paths?: (string | number)[] | undefined;\r\n getBindableValueFn: (value: any) => any;\r\n }\r\n) {\r\n const { paths: getterPaths, getBindableValueFn: getterGetBindableValueFn } =\r\n getterOptions;\r\n const { paths: setterPaths, getBindableValueFn: setterGetBindableValueFn } =\r\n setterOptions || getterOptions;\r\n\r\n if (getterPaths === undefined || getterPaths.length === 0) {\r\n return object;\r\n }\r\n\r\n return customRef(() => {\r\n return {\r\n get() {\r\n try {\r\n return objectSystem.getByPaths(\r\n toValue(object),\r\n getterPaths,\r\n getterGetBindableValueFn\r\n );\r\n } catch (e) {\r\n return undefined;\r\n }\r\n },\r\n set(newValue) {\r\n objectSystem.setByPaths(\r\n toValue(object),\r\n setterPaths || getterPaths,\r\n newValue,\r\n setterGetBindableValueFn\r\n );\r\n },\r\n };\r\n });\r\n}\r\n\r\nexport function useDeepCompareRef(value: any) {\r\n return customRef((track, trigger) => {\r\n return {\r\n get() {\r\n track();\r\n return value;\r\n },\r\n set(newValue) {\r\n if (\r\n !computedInit.isInitial(value) &&\r\n JSON.stringify(newValue) === JSON.stringify(value)\r\n ) {\r\n return;\r\n }\r\n value = newValue;\r\n trigger();\r\n },\r\n };\r\n });\r\n}\r\n","import { shallowRef, watchEffect, readonly, ref, watch, customRef, getCurrentScope, onScopeDispose, effectScope, getCurrentInstance, inject, provide, isRef, unref, computed, reactive, toRefs as toRefs$1, toRef as toRef$1, onBeforeMount, nextTick, onBeforeUnmount, onMounted, onUnmounted, isReactive } from 'vue';\n\nfunction computedEager(fn, options) {\n var _a;\n const result = shallowRef();\n watchEffect(() => {\n result.value = fn();\n }, {\n ...options,\n flush: (_a = options == null ? void 0 : options.flush) != null ? _a : \"sync\"\n });\n return readonly(result);\n}\n\nfunction computedWithControl(source, fn) {\n let v = void 0;\n let track;\n let trigger;\n const dirty = ref(true);\n const update = () => {\n dirty.value = true;\n trigger();\n };\n watch(source, update, { flush: \"sync\" });\n const get = typeof fn === \"function\" ? fn : fn.get;\n const set = typeof fn === \"function\" ? void 0 : fn.set;\n const result = customRef((_track, _trigger) => {\n track = _track;\n trigger = _trigger;\n return {\n get() {\n if (dirty.value) {\n v = get(v);\n dirty.value = false;\n }\n track();\n return v;\n },\n set(v2) {\n set == null ? void 0 : set(v2);\n }\n };\n });\n if (Object.isExtensible(result))\n result.trigger = update;\n return result;\n}\n\nfunction tryOnScopeDispose(fn) {\n if (getCurrentScope()) {\n onScopeDispose(fn);\n return true;\n }\n return false;\n}\n\nfunction createEventHook() {\n const fns = /* @__PURE__ */ new Set();\n const off = (fn) => {\n fns.delete(fn);\n };\n const on = (fn) => {\n fns.add(fn);\n const offFn = () => off(fn);\n tryOnScopeDispose(offFn);\n return {\n off: offFn\n };\n };\n const trigger = (...args) => {\n return Promise.all(Array.from(fns).map((fn) => fn(...args)));\n };\n return {\n on,\n off,\n trigger\n };\n}\n\nfunction createGlobalState(stateFactory) {\n let initialized = false;\n let state;\n const scope = effectScope(true);\n return (...args) => {\n if (!initialized) {\n state = scope.run(() => stateFactory(...args));\n initialized = true;\n }\n return state;\n };\n}\n\nconst localProvidedStateMap = /* @__PURE__ */ new WeakMap();\n\nconst injectLocal = (...args) => {\n var _a;\n const key = args[0];\n const instance = (_a = getCurrentInstance()) == null ? void 0 : _a.proxy;\n if (instance == null)\n throw new Error(\"injectLocal must be called in setup\");\n if (localProvidedStateMap.has(instance) && key in localProvidedStateMap.get(instance))\n return localProvidedStateMap.get(instance)[key];\n return inject(...args);\n};\n\nconst provideLocal = (key, value) => {\n var _a;\n const instance = (_a = getCurrentInstance()) == null ? void 0 : _a.proxy;\n if (instance == null)\n throw new Error(\"provideLocal must be called in setup\");\n if (!localProvidedStateMap.has(instance))\n localProvidedStateMap.set(instance, /* @__PURE__ */ Object.create(null));\n const localProvidedState = localProvidedStateMap.get(instance);\n localProvidedState[key] = value;\n provide(key, value);\n};\n\nfunction createInjectionState(composable, options) {\n const key = (options == null ? void 0 : options.injectionKey) || Symbol(composable.name || \"InjectionState\");\n const defaultValue = options == null ? void 0 : options.defaultValue;\n const useProvidingState = (...args) => {\n const state = composable(...args);\n provideLocal(key, state);\n return state;\n };\n const useInjectedState = () => injectLocal(key, defaultValue);\n return [useProvidingState, useInjectedState];\n}\n\nfunction createSharedComposable(composable) {\n let subscribers = 0;\n let state;\n let scope;\n const dispose = () => {\n subscribers -= 1;\n if (scope && subscribers <= 0) {\n scope.stop();\n state = void 0;\n scope = void 0;\n }\n };\n return (...args) => {\n subscribers += 1;\n if (!scope) {\n scope = effectScope(true);\n state = scope.run(() => composable(...args));\n }\n tryOnScopeDispose(dispose);\n return state;\n };\n}\n\nfunction extendRef(ref, extend, { enumerable = false, unwrap = true } = {}) {\n for (const [key, value] of Object.entries(extend)) {\n if (key === \"value\")\n continue;\n if (isRef(value) && unwrap) {\n Object.defineProperty(ref, key, {\n get() {\n return value.value;\n },\n set(v) {\n value.value = v;\n },\n enumerable\n });\n } else {\n Object.defineProperty(ref, key, { value, enumerable });\n }\n }\n return ref;\n}\n\nfunction get(obj, key) {\n if (key == null)\n return unref(obj);\n return unref(obj)[key];\n}\n\nfunction isDefined(v) {\n return unref(v) != null;\n}\n\nfunction makeDestructurable(obj, arr) {\n if (typeof Symbol !== \"undefined\") {\n const clone = { ...obj };\n Object.defineProperty(clone, Symbol.iterator, {\n enumerable: false,\n value() {\n let index = 0;\n return {\n next: () => ({\n value: arr[index++],\n done: index > arr.length\n })\n };\n }\n });\n return clone;\n } else {\n return Object.assign([...arr], obj);\n }\n}\n\nfunction toValue(r) {\n return typeof r === \"function\" ? r() : unref(r);\n}\nconst resolveUnref = toValue;\n\nfunction reactify(fn, options) {\n const unrefFn = (options == null ? void 0 : options.computedGetter) === false ? unref : toValue;\n return function(...args) {\n return computed(() => fn.apply(this, args.map((i) => unrefFn(i))));\n };\n}\n\nfunction reactifyObject(obj, optionsOrKeys = {}) {\n let keys = [];\n let options;\n if (Array.isArray(optionsOrKeys)) {\n keys = optionsOrKeys;\n } else {\n options = optionsOrKeys;\n const { includeOwnProperties = true } = optionsOrKeys;\n keys.push(...Object.keys(obj));\n if (includeOwnProperties)\n keys.push(...Object.getOwnPropertyNames(obj));\n }\n return Object.fromEntries(\n keys.map((key) => {\n const value = obj[key];\n return [\n key,\n typeof value === \"function\" ? reactify(value.bind(obj), options) : value\n ];\n })\n );\n}\n\nfunction toReactive(objectRef) {\n if (!isRef(objectRef))\n return reactive(objectRef);\n const proxy = new Proxy({}, {\n get(_, p, receiver) {\n return unref(Reflect.get(objectRef.value, p, receiver));\n },\n set(_, p, value) {\n if (isRef(objectRef.value[p]) && !isRef(value))\n objectRef.value[p].value = value;\n else\n objectRef.value[p] = value;\n return true;\n },\n deleteProperty(_, p) {\n return Reflect.deleteProperty(objectRef.value, p);\n },\n has(_, p) {\n return Reflect.has(objectRef.value, p);\n },\n ownKeys() {\n return Object.keys(objectRef.value);\n },\n getOwnPropertyDescriptor() {\n return {\n enumerable: true,\n configurable: true\n };\n }\n });\n return reactive(proxy);\n}\n\nfunction reactiveComputed(fn) {\n return toReactive(computed(fn));\n}\n\nfunction reactiveOmit(obj, ...keys) {\n const flatKeys = keys.flat();\n const predicate = flatKeys[0];\n return reactiveComputed(() => typeof predicate === \"function\" ? Object.fromEntries(Object.entries(toRefs$1(obj)).filter(([k, v]) => !predicate(toValue(v), k))) : Object.fromEntries(Object.entries(toRefs$1(obj)).filter((e) => !flatKeys.includes(e[0]))));\n}\n\nconst isClient = typeof window !== \"undefined\" && typeof document !== \"undefined\";\nconst isWorker = typeof WorkerGlobalScope !== \"undefined\" && globalThis instanceof WorkerGlobalScope;\nconst isDef = (val) => typeof val !== \"undefined\";\nconst notNullish = (val) => val != null;\nconst assert = (condition, ...infos) => {\n if (!condition)\n console.warn(...infos);\n};\nconst toString = Object.prototype.toString;\nconst isObject = (val) => toString.call(val) === \"[object Object]\";\nconst now = () => Date.now();\nconst timestamp = () => +Date.now();\nconst clamp = (n, min, max) => Math.min(max, Math.max(min, n));\nconst noop = () => {\n};\nconst rand = (min, max) => {\n min = Math.ceil(min);\n max = Math.floor(max);\n return Math.floor(Math.random() * (max - min + 1)) + min;\n};\nconst hasOwn = (val, key) => Object.prototype.hasOwnProperty.call(val, key);\nconst isIOS = /* @__PURE__ */ getIsIOS();\nfunction getIsIOS() {\n var _a, _b;\n return isClient && ((_a = window == null ? void 0 : window.navigator) == null ? void 0 : _a.userAgent) && (/iP(?:ad|hone|od)/.test(window.navigator.userAgent) || ((_b = window == null ? void 0 : window.navigator) == null ? void 0 : _b.maxTouchPoints) > 2 && /iPad|Macintosh/.test(window == null ? void 0 : window.navigator.userAgent));\n}\n\nfunction createFilterWrapper(filter, fn) {\n function wrapper(...args) {\n return new Promise((resolve, reject) => {\n Promise.resolve(filter(() => fn.apply(this, args), { fn, thisArg: this, args })).then(resolve).catch(reject);\n });\n }\n return wrapper;\n}\nconst bypassFilter = (invoke) => {\n return invoke();\n};\nfunction debounceFilter(ms, options = {}) {\n let timer;\n let maxTimer;\n let lastRejector = noop;\n const _clearTimeout = (timer2) => {\n clearTimeout(timer2);\n lastRejector();\n lastRejector = noop;\n };\n const filter = (invoke) => {\n const duration = toValue(ms);\n const maxDuration = toValue(options.maxWait);\n if (timer)\n _clearTimeout(timer);\n if (duration <= 0 || maxDuration !== void 0 && maxDuration <= 0) {\n if (maxTimer) {\n _clearTimeout(maxTimer);\n maxTimer = null;\n }\n return Promise.resolve(invoke());\n }\n return new Promise((resolve, reject) => {\n lastRejector = options.rejectOnCancel ? reject : resolve;\n if (maxDuration && !maxTimer) {\n maxTimer = setTimeout(() => {\n if (timer)\n _clearTimeout(timer);\n maxTimer = null;\n resolve(invoke());\n }, maxDuration);\n }\n timer = setTimeout(() => {\n if (maxTimer)\n _clearTimeout(maxTimer);\n maxTimer = null;\n resolve(invoke());\n }, duration);\n });\n };\n return filter;\n}\nfunction throttleFilter(...args) {\n let lastExec = 0;\n let timer;\n let isLeading = true;\n let lastRejector = noop;\n let lastValue;\n let ms;\n let trailing;\n let leading;\n let rejectOnCancel;\n if (!isRef(args[0]) && typeof args[0] === \"object\")\n ({ delay: ms, trailing = true, leading = true, rejectOnCancel = false } = args[0]);\n else\n [ms, trailing = true, leading = true, rejectOnCancel = false] = args;\n const clear = () => {\n if (timer) {\n clearTimeout(timer);\n timer = void 0;\n lastRejector();\n lastRejector = noop;\n }\n };\n const filter = (_invoke) => {\n const duration = toValue(ms);\n const elapsed = Date.now() - lastExec;\n const invoke = () => {\n return lastValue = _invoke();\n };\n clear();\n if (duration <= 0) {\n lastExec = Date.now();\n return invoke();\n }\n if (elapsed > duration && (leading || !isLeading)) {\n lastExec = Date.now();\n invoke();\n } else if (trailing) {\n lastValue = new Promise((resolve, reject) => {\n lastRejector = rejectOnCancel ? reject : resolve;\n timer = setTimeout(() => {\n lastExec = Date.now();\n isLeading = true;\n resolve(invoke());\n clear();\n }, Math.max(0, duration - elapsed));\n });\n }\n if (!leading && !timer)\n timer = setTimeout(() => isLeading = true, duration);\n isLeading = false;\n return lastValue;\n };\n return filter;\n}\nfunction pausableFilter(extendFilter = bypassFilter) {\n const isActive = ref(true);\n function pause() {\n isActive.value = false;\n }\n function resume() {\n isActive.value = true;\n }\n const eventFilter = (...args) => {\n if (isActive.value)\n extendFilter(...args);\n };\n return { isActive: readonly(isActive), pause, resume, eventFilter };\n}\n\nfunction cacheStringFunction(fn) {\n const cache = /* @__PURE__ */ Object.create(null);\n return (str) => {\n const hit = cache[str];\n return hit || (cache[str] = fn(str));\n };\n}\nconst hyphenateRE = /\\B([A-Z])/g;\nconst hyphenate = cacheStringFunction((str) => str.replace(hyphenateRE, \"-$1\").toLowerCase());\nconst camelizeRE = /-(\\w)/g;\nconst camelize = cacheStringFunction((str) => {\n return str.replace(camelizeRE, (_, c) => c ? c.toUpperCase() : \"\");\n});\n\nfunction promiseTimeout(ms, throwOnTimeout = false, reason = \"Timeout\") {\n return new Promise((resolve, reject) => {\n if (throwOnTimeout)\n setTimeout(() => reject(reason), ms);\n else\n setTimeout(resolve, ms);\n });\n}\nfunction identity(arg) {\n return arg;\n}\nfunction createSingletonPromise(fn) {\n let _promise;\n function wrapper() {\n if (!_promise)\n _promise = fn();\n return _promise;\n }\n wrapper.reset = async () => {\n const _prev = _promise;\n _promise = void 0;\n if (_prev)\n await _prev;\n };\n return wrapper;\n}\nfunction invoke(fn) {\n return fn();\n}\nfunction containsProp(obj, ...props) {\n return props.some((k) => k in obj);\n}\nfunction increaseWithUnit(target, delta) {\n var _a;\n if (typeof target === \"number\")\n return target + delta;\n const value = ((_a = target.match(/^-?\\d+\\.?\\d*/)) == null ? void 0 : _a[0]) || \"\";\n const unit = target.slice(value.length);\n const result = Number.parseFloat(value) + delta;\n if (Number.isNaN(result))\n return target;\n return result + unit;\n}\nfunction objectPick(obj, keys, omitUndefined = false) {\n return keys.reduce((n, k) => {\n if (k in obj) {\n if (!omitUndefined || obj[k] !== void 0)\n n[k] = obj[k];\n }\n return n;\n }, {});\n}\nfunction objectOmit(obj, keys, omitUndefined = false) {\n return Object.fromEntries(Object.entries(obj).filter(([key, value]) => {\n return (!omitUndefined || value !== void 0) && !keys.includes(key);\n }));\n}\nfunction objectEntries(obj) {\n return Object.entries(obj);\n}\nfunction getLifeCycleTarget(target) {\n return target || getCurrentInstance();\n}\n\nfunction toRef(...args) {\n if (args.length !== 1)\n return toRef$1(...args);\n const r = args[0];\n return typeof r === \"function\" ? readonly(customRef(() => ({ get: r, set: noop }))) : ref(r);\n}\nconst resolveRef = toRef;\n\nfunction reactivePick(obj, ...keys) {\n const flatKeys = keys.flat();\n const predicate = flatKeys[0];\n return reactiveComputed(() => typeof predicate === \"function\" ? Object.fromEntries(Object.entries(toRefs$1(obj)).filter(([k, v]) => predicate(toValue(v), k))) : Object.fromEntries(flatKeys.map((k) => [k, toRef(obj, k)])));\n}\n\nfunction refAutoReset(defaultValue, afterMs = 1e4) {\n return customRef((track, trigger) => {\n let value = toValue(defaultValue);\n let timer;\n const resetAfter = () => setTimeout(() => {\n value = toValue(defaultValue);\n trigger();\n }, toValue(afterMs));\n tryOnScopeDispose(() => {\n clearTimeout(timer);\n });\n return {\n get() {\n track();\n return value;\n },\n set(newValue) {\n value = newValue;\n trigger();\n clearTimeout(timer);\n timer = resetAfter();\n }\n };\n });\n}\n\nfunction useDebounceFn(fn, ms = 200, options = {}) {\n return createFilterWrapper(\n debounceFilter(ms, options),\n fn\n );\n}\n\nfunction refDebounced(value, ms = 200, options = {}) {\n const debounced = ref(value.value);\n const updater = useDebounceFn(() => {\n debounced.value = value.value;\n }, ms, options);\n watch(value, () => updater());\n return debounced;\n}\n\nfunction refDefault(source, defaultValue) {\n return computed({\n get() {\n var _a;\n return (_a = source.value) != null ? _a : defaultValue;\n },\n set(value) {\n source.value = value;\n }\n });\n}\n\nfunction useThrottleFn(fn, ms = 200, trailing = false, leading = true, rejectOnCancel = false) {\n return createFilterWrapper(\n throttleFilter(ms, trailing, leading, rejectOnCancel),\n fn\n );\n}\n\nfunction refThrottled(value, delay = 200, trailing = true, leading = true) {\n if (delay <= 0)\n return value;\n const throttled = ref(value.value);\n const updater = useThrottleFn(() => {\n throttled.value = value.value;\n }, delay, trailing, leading);\n watch(value, () => updater());\n return throttled;\n}\n\nfunction refWithControl(initial, options = {}) {\n let source = initial;\n let track;\n let trigger;\n const ref = customRef((_track, _trigger) => {\n track = _track;\n trigger = _trigger;\n return {\n get() {\n return get();\n },\n set(v) {\n set(v);\n }\n };\n });\n function get(tracking = true) {\n if (tracking)\n track();\n return source;\n }\n function set(value, triggering = true) {\n var _a, _b;\n if (value === source)\n return;\n const old = source;\n if (((_a = options.onBeforeChange) == null ? void 0 : _a.call(options, value, old)) === false)\n return;\n source = value;\n (_b = options.onChanged) == null ? void 0 : _b.call(options, value, old);\n if (triggering)\n trigger();\n }\n const untrackedGet = () => get(false);\n const silentSet = (v) => set(v, false);\n const peek = () => get(false);\n const lay = (v) => set(v, false);\n return extendRef(\n ref,\n {\n get,\n set,\n untrackedGet,\n silentSet,\n peek,\n lay\n },\n { enumerable: true }\n );\n}\nconst controlledRef = refWithControl;\n\nfunction set(...args) {\n if (args.length === 2) {\n const [ref, value] = args;\n ref.value = value;\n }\n if (args.length === 3) {\n const [target, key, value] = args;\n target[key] = value;\n }\n}\n\nfunction watchWithFilter(source, cb, options = {}) {\n const {\n eventFilter = bypassFilter,\n ...watchOptions\n } = options;\n return watch(\n source,\n createFilterWrapper(\n eventFilter,\n cb\n ),\n watchOptions\n );\n}\n\nfunction watchPausable(source, cb, options = {}) {\n const {\n eventFilter: filter,\n ...watchOptions\n } = options;\n const { eventFilter, pause, resume, isActive } = pausableFilter(filter);\n const stop = watchWithFilter(\n source,\n cb,\n {\n ...watchOptions,\n eventFilter\n }\n );\n return { stop, pause, resume, isActive };\n}\n\nfunction syncRef(left, right, ...[options]) {\n const {\n flush = \"sync\",\n deep = false,\n immediate = true,\n direction = \"both\",\n transform = {}\n } = options || {};\n const watchers = [];\n const transformLTR = \"ltr\" in transform && transform.ltr || ((v) => v);\n const transformRTL = \"rtl\" in transform && transform.rtl || ((v) => v);\n if (direction === \"both\" || direction === \"ltr\") {\n watchers.push(watchPausable(\n left,\n (newValue) => {\n watchers.forEach((w) => w.pause());\n right.value = transformLTR(newValue);\n watchers.forEach((w) => w.resume());\n },\n { flush, deep, immediate }\n ));\n }\n if (direction === \"both\" || direction === \"rtl\") {\n watchers.push(watchPausable(\n right,\n (newValue) => {\n watchers.forEach((w) => w.pause());\n left.value = transformRTL(newValue);\n watchers.forEach((w) => w.resume());\n },\n { flush, deep, immediate }\n ));\n }\n const stop = () => {\n watchers.forEach((w) => w.stop());\n };\n return stop;\n}\n\nfunction syncRefs(source, targets, options = {}) {\n const {\n flush = \"sync\",\n deep = false,\n immediate = true\n } = options;\n if (!Array.isArray(targets))\n targets = [targets];\n return watch(\n source,\n (newValue) => targets.forEach((target) => target.value = newValue),\n { flush, deep, immediate }\n );\n}\n\nfunction toRefs(objectRef, options = {}) {\n if (!isRef(objectRef))\n return toRefs$1(objectRef);\n const result = Array.isArray(objectRef.value) ? Array.from({ length: objectRef.value.length }) : {};\n for (const key in objectRef.value) {\n result[key] = customRef(() => ({\n get() {\n return objectRef.value[key];\n },\n set(v) {\n var _a;\n const replaceRef = (_a = toValue(options.replaceRef)) != null ? _a : true;\n if (replaceRef) {\n if (Array.isArray(objectRef.value)) {\n const copy = [...objectRef.value];\n copy[key] = v;\n objectRef.value = copy;\n } else {\n const newObject = { ...objectRef.value, [key]: v };\n Object.setPrototypeOf(newObject, Object.getPrototypeOf(objectRef.value));\n objectRef.value = newObject;\n }\n } else {\n objectRef.value[key] = v;\n }\n }\n }));\n }\n return result;\n}\n\nfunction tryOnBeforeMount(fn, sync = true, target) {\n const instance = getLifeCycleTarget(target);\n if (instance)\n onBeforeMount(fn, target);\n else if (sync)\n fn();\n else\n nextTick(fn);\n}\n\nfunction tryOnBeforeUnmount(fn, target) {\n const instance = getLifeCycleTarget(target);\n if (instance)\n onBeforeUnmount(fn, target);\n}\n\nfunction tryOnMounted(fn, sync = true, target) {\n const instance = getLifeCycleTarget();\n if (instance)\n onMounted(fn, target);\n else if (sync)\n fn();\n else\n nextTick(fn);\n}\n\nfunction tryOnUnmounted(fn, target) {\n const instance = getLifeCycleTarget(target);\n if (instance)\n onUnmounted(fn, target);\n}\n\nfunction createUntil(r, isNot = false) {\n function toMatch(condition, { flush = \"sync\", deep = false, timeout, throwOnTimeout } = {}) {\n let stop = null;\n const watcher = new Promise((resolve) => {\n stop = watch(\n r,\n (v) => {\n if (condition(v) !== isNot) {\n if (stop)\n stop();\n else\n nextTick(() => stop == null ? void 0 : stop());\n resolve(v);\n }\n },\n {\n flush,\n deep,\n immediate: true\n }\n );\n });\n const promises = [watcher];\n if (timeout != null) {\n promises.push(\n promiseTimeout(timeout, throwOnTimeout).then(() => toValue(r)).finally(() => stop == null ? void 0 : stop())\n );\n }\n return Promise.race(promises);\n }\n function toBe(value, options) {\n if (!isRef(value))\n return toMatch((v) => v === value, options);\n const { flush = \"sync\", deep = false, timeout, throwOnTimeout } = options != null ? options : {};\n let stop = null;\n const watcher = new Promise((resolve) => {\n stop = watch(\n [r, value],\n ([v1, v2]) => {\n if (isNot !== (v1 === v2)) {\n if (stop)\n stop();\n else\n nextTick(() => stop == null ? void 0 : stop());\n resolve(v1);\n }\n },\n {\n flush,\n deep,\n immediate: true\n }\n );\n });\n const promises = [watcher];\n if (timeout != null) {\n promises.push(\n promiseTimeout(timeout, throwOnTimeout).then(() => toValue(r)).finally(() => {\n stop == null ? void 0 : stop();\n return toValue(r);\n })\n );\n }\n return Promise.race(promises);\n }\n function toBeTruthy(options) {\n return toMatch((v) => Boolean(v), options);\n }\n function toBeNull(options) {\n return toBe(null, options);\n }\n function toBeUndefined(options) {\n return toBe(void 0, options);\n }\n function toBeNaN(options) {\n return toMatch(Number.isNaN, options);\n }\n function toContains(value, options) {\n return toMatch((v) => {\n const array = Array.from(v);\n return array.includes(value) || array.includes(toValue(value));\n }, options);\n }\n function changed(options) {\n return changedTimes(1, options);\n }\n function changedTimes(n = 1, options) {\n let count = -1;\n return toMatch(() => {\n count += 1;\n return count >= n;\n }, options);\n }\n if (Array.isArray(toValue(r))) {\n const instance = {\n toMatch,\n toContains,\n changed,\n changedTimes,\n get not() {\n return createUntil(r, !isNot);\n }\n };\n return instance;\n } else {\n const instance = {\n toMatch,\n toBe,\n toBeTruthy,\n toBeNull,\n toBeNaN,\n toBeUndefined,\n changed,\n changedTimes,\n get not() {\n return createUntil(r, !isNot);\n }\n };\n return instance;\n }\n}\nfunction until(r) {\n return createUntil(r);\n}\n\nfunction defaultComparator(value, othVal) {\n return value === othVal;\n}\nfunction useArrayDifference(...args) {\n var _a;\n const list = args[0];\n const values = args[1];\n let compareFn = (_a = args[2]) != null ? _a : defaultComparator;\n if (typeof compareFn === \"string\") {\n const key = compareFn;\n compareFn = (value, othVal) => value[key] === othVal[key];\n }\n return computed(() => toValue(list).filter((x) => toValue(values).findIndex((y) => compareFn(x, y)) === -1));\n}\n\nfunction useArrayEvery(list, fn) {\n return computed(() => toValue(list).every((element, index, array) => fn(toValue(element), index, array)));\n}\n\nfunction useArrayFilter(list, fn) {\n return computed(() => toValue(list).map((i) => toValue(i)).filter(fn));\n}\n\nfunction useArrayFind(list, fn) {\n return computed(() => toValue(\n toValue(list).find((element, index, array) => fn(toValue(element), index, array))\n ));\n}\n\nfunction useArrayFindIndex(list, fn) {\n return computed(() => toValue(list).findIndex((element, index, array) => fn(toValue(element), index, array)));\n}\n\nfunction findLast(arr, cb) {\n let index = arr.length;\n while (index-- > 0) {\n if (cb(arr[index], index, arr))\n return arr[index];\n }\n return void 0;\n}\nfunction useArrayFindLast(list, fn) {\n return computed(() => toValue(\n !Array.prototype.findLast ? findLast(toValue(list), (element, index, array) => fn(toValue(element), index, array)) : toValue(list).findLast((element, index, array) => fn(toValue(element), index, array))\n ));\n}\n\nfunction isArrayIncludesOptions(obj) {\n return isObject(obj) && containsProp(obj, \"formIndex\", \"comparator\");\n}\nfunction useArrayIncludes(...args) {\n var _a;\n const list = args[0];\n const value = args[1];\n let comparator = args[2];\n let formIndex = 0;\n if (isArrayIncludesOptions(comparator)) {\n formIndex = (_a = comparator.fromIndex) != null ? _a : 0;\n comparator = comparator.comparator;\n }\n if (typeof comparator === \"string\") {\n const key = comparator;\n comparator = (element, value2) => element[key] === toValue(value2);\n }\n comparator = comparator != null ? comparator : (element, value2) => element === toValue(value2);\n return computed(() => toValue(list).slice(formIndex).some((element, index, array) => comparator(\n toValue(element),\n toValue(value),\n index,\n toValue(array)\n )));\n}\n\nfunction useArrayJoin(list, separator) {\n return computed(() => toValue(list).map((i) => toValue(i)).join(toValue(separator)));\n}\n\nfunction useArrayMap(list, fn) {\n return computed(() => toValue(list).map((i) => toValue(i)).map(fn));\n}\n\nfunction useArrayReduce(list, reducer, ...args) {\n const reduceCallback = (sum, value, index) => reducer(toValue(sum), toValue(value), index);\n return computed(() => {\n const resolved = toValue(list);\n return args.length ? resolved.reduce(reduceCallback, typeof args[0] === \"function\" ? toValue(args[0]()) : toValue(args[0])) : resolved.reduce(reduceCallback);\n });\n}\n\nfunction useArraySome(list, fn) {\n return computed(() => toValue(list).some((element, index, array) => fn(toValue(element), index, array)));\n}\n\nfunction uniq(array) {\n return Array.from(new Set(array));\n}\nfunction uniqueElementsBy(array, fn) {\n return array.reduce((acc, v) => {\n if (!acc.some((x) => fn(v, x, array)))\n acc.push(v);\n return acc;\n }, []);\n}\nfunction useArrayUnique(list, compareFn) {\n return computed(() => {\n const resolvedList = toValue(list).map((element) => toValue(element));\n return compareFn ? uniqueElementsBy(resolvedList, compareFn) : uniq(resolvedList);\n });\n}\n\nfunction useCounter(initialValue = 0, options = {}) {\n let _initialValue = unref(initialValue);\n const count = ref(initialValue);\n const {\n max = Number.POSITIVE_INFINITY,\n min = Number.NEGATIVE_INFINITY\n } = options;\n const inc = (delta = 1) => count.value = Math.max(Math.min(max, count.value + delta), min);\n const dec = (delta = 1) => count.value = Math.min(Math.max(min, count.value - delta), max);\n const get = () => count.value;\n const set = (val) => count.value = Math.max(min, Math.min(max, val));\n const reset = (val = _initialValue) => {\n _initialValue = val;\n return set(val);\n };\n return { count, inc, dec, get, set, reset };\n}\n\nconst REGEX_PARSE = /^(\\d{4})[-/]?(\\d{1,2})?[-/]?(\\d{0,2})[T\\s]*(\\d{1,2})?:?(\\d{1,2})?:?(\\d{1,2})?[.:]?(\\d+)?$/i;\nconst REGEX_FORMAT = /[YMDHhms]o|\\[([^\\]]+)\\]|Y{1,4}|M{1,4}|D{1,2}|d{1,4}|H{1,2}|h{1,2}|a{1,2}|A{1,2}|m{1,2}|s{1,2}|Z{1,2}|SSS/g;\nfunction defaultMeridiem(hours, minutes, isLowercase, hasPeriod) {\n let m = hours < 12 ? \"AM\" : \"PM\";\n if (hasPeriod)\n m = m.split(\"\").reduce((acc, curr) => acc += `${curr}.`, \"\");\n return isLowercase ? m.toLowerCase() : m;\n}\nfunction formatOrdinal(num) {\n const suffixes = [\"th\", \"st\", \"nd\", \"rd\"];\n const v = num % 100;\n return num + (suffixes[(v - 20) % 10] || suffixes[v] || suffixes[0]);\n}\nfunction formatDate(date, formatStr, options = {}) {\n var _a;\n const years = date.getFullYear();\n const month = date.getMonth();\n const days = date.getDate();\n const hours = date.getHours();\n const minutes = date.getMinutes();\n const seconds = date.getSeconds();\n const milliseconds = date.getMilliseconds();\n const day = date.getDay();\n const meridiem = (_a = options.customMeridiem) != null ? _a : defaultMeridiem;\n const matches = {\n Yo: () => formatOrdinal(years),\n YY: () => String(years).slice(-2),\n YYYY: () => years,\n M: () => month + 1,\n Mo: () => formatOrdinal(month + 1),\n MM: () => `${month + 1}`.padStart(2, \"0\"),\n MMM: () => date.toLocaleDateString(toValue(options.locales), { month: \"short\" }),\n MMMM: () => date.toLocaleDateString(toValue(options.locales), { month: \"long\" }),\n D: () => String(days),\n Do: () => formatOrdinal(days),\n DD: () => `${days}`.padStart(2, \"0\"),\n H: () => String(hours),\n Ho: () => formatOrdinal(hours),\n HH: () => `${hours}`.padStart(2, \"0\"),\n h: () => `${hours % 12 || 12}`.padStart(1, \"0\"),\n ho: () => formatOrdinal(hours % 12 || 12),\n hh: () => `${hours % 12 || 12}`.padStart(2, \"0\"),\n m: () => String(minutes),\n mo: () => formatOrdinal(minutes),\n mm: () => `${minutes}`.padStart(2, \"0\"),\n s: () => String(seconds),\n so: () => formatOrdinal(seconds),\n ss: () => `${seconds}`.padStart(2, \"0\"),\n SSS: () => `${milliseconds}`.padStart(3, \"0\"),\n d: () => day,\n dd: () => date.toLocaleDateString(toValue(options.locales), { weekday: \"narrow\" }),\n ddd: () => date.toLocaleDateString(toValue(options.locales), { weekday: \"short\" }),\n dddd: () => date.toLocaleDateString(toValue(options.locales), { weekday: \"long\" }),\n A: () => meridiem(hours, minutes),\n AA: () => meridiem(hours, minutes, false, true),\n a: () => meridiem(hours, minutes, true),\n aa: () => meridiem(hours, minutes, true, true)\n };\n return formatStr.replace(REGEX_FORMAT, (match, $1) => {\n var _a2, _b;\n return (_b = $1 != null ? $1 : (_a2 = matches[match]) == null ? void 0 : _a2.call(matches)) != null ? _b : match;\n });\n}\nfunction normalizeDate(date) {\n if (date === null)\n return new Date(Number.NaN);\n if (date === void 0)\n return /* @__PURE__ */ new Date();\n if (date instanceof Date)\n return new Date(date);\n if (typeof date === \"string\" && !/Z$/i.test(date)) {\n const d = date.match(REGEX_PARSE);\n if (d) {\n const m = d[2] - 1 || 0;\n const ms = (d[7] || \"0\").substring(0, 3);\n return new Date(d[1], m, d[3] || 1, d[4] || 0, d[5] || 0, d[6] || 0, ms);\n }\n }\n return new Date(date);\n}\nfunction useDateFormat(date, formatStr = \"HH:mm:ss\", options = {}) {\n return computed(() => formatDate(normalizeDate(toValue(date)), toValue(formatStr), options));\n}\n\nfunction useIntervalFn(cb, interval = 1e3, options = {}) {\n const {\n immediate = true,\n immediateCallback = false\n } = options;\n let timer = null;\n const isActive = ref(false);\n function clean() {\n if (timer) {\n clearInterval(timer);\n timer = null;\n }\n }\n function pause() {\n isActive.value = false;\n clean();\n }\n function resume() {\n const intervalValue = toValue(interval);\n if (intervalValue <= 0)\n return;\n isActive.value = true;\n if (immediateCallback)\n cb();\n clean();\n if (isActive.value)\n timer = setInterval(cb, intervalValue);\n }\n if (immediate && isClient)\n resume();\n if (isRef(interval) || typeof interval === \"function\") {\n const stopWatch = watch(interval, () => {\n if (isActive.value && isClient)\n resume();\n });\n tryOnScopeDispose(stopWatch);\n }\n tryOnScopeDispose(pause);\n return {\n isActive,\n pause,\n resume\n };\n}\n\nfunction useInterval(interval = 1e3, options = {}) {\n const {\n controls: exposeControls = false,\n immediate = true,\n callback\n } = options;\n const counter = ref(0);\n const update = () => counter.value += 1;\n const reset = () => {\n counter.value = 0;\n };\n const controls = useIntervalFn(\n callback ? () => {\n update();\n callback(counter.value);\n } : update,\n interval,\n { immediate }\n );\n if (exposeControls) {\n return {\n counter,\n reset,\n ...controls\n };\n } else {\n return counter;\n }\n}\n\nfunction useLastChanged(source, options = {}) {\n var _a;\n const ms = ref((_a = options.initialValue) != null ? _a : null);\n watch(\n source,\n () => ms.value = timestamp(),\n options\n );\n return ms;\n}\n\nfunction useTimeoutFn(cb, interval, options = {}) {\n const {\n immediate = true\n } = options;\n const isPending = ref(false);\n let timer = null;\n function clear() {\n if (timer) {\n clearTimeout(timer);\n timer = null;\n }\n }\n function stop() {\n isPending.value = false;\n clear();\n }\n function start(...args) {\n clear();\n isPending.value = true;\n timer = setTimeout(() => {\n isPending.value = false;\n timer = null;\n cb(...args);\n }, toValue(interval));\n }\n if (immediate) {\n isPending.value = true;\n if (isClient)\n start();\n }\n tryOnScopeDispose(stop);\n return {\n isPending: readonly(isPending),\n start,\n stop\n };\n}\n\nfunction useTimeout(interval = 1e3, options = {}) {\n const {\n controls: exposeControls = false,\n callback\n } = options;\n const controls = useTimeoutFn(\n callback != null ? callback : noop,\n interval,\n options\n );\n const ready = computed(() => !controls.isPending.value);\n if (exposeControls) {\n return {\n ready,\n ...controls\n };\n } else {\n return ready;\n }\n}\n\nfunction useToNumber(value, options = {}) {\n const {\n method = \"parseFloat\",\n radix,\n nanToZero\n } = options;\n return computed(() => {\n let resolved = toValue(value);\n if (typeof resolved === \"string\")\n resolved = Number[method](resolved, radix);\n if (nanToZero && Number.isNaN(resolved))\n resolved = 0;\n return resolved;\n });\n}\n\nfunction useToString(value) {\n return computed(() => `${toValue(value)}`);\n}\n\nfunction useToggle(initialValue = false, options = {}) {\n const {\n truthyValue = true,\n falsyValue = false\n } = options;\n const valueIsRef = isRef(initialValue);\n const _value = ref(initialValue);\n function toggle(value) {\n if (arguments.length) {\n _value.value = value;\n return _value.value;\n } else {\n const truthy = toValue(truthyValue);\n _value.value = _value.value === truthy ? toValue(falsyValue) : truthy;\n return _value.value;\n }\n }\n if (valueIsRef)\n return toggle;\n else\n return [_value, toggle];\n}\n\nfunction watchArray(source, cb, options) {\n let oldList = (options == null ? void 0 : options.immediate) ? [] : [...source instanceof Function ? source() : Array.isArray(source) ? source : toValue(source)];\n return watch(source, (newList, _, onCleanup) => {\n const oldListRemains = Array.from({ length: oldList.length });\n const added = [];\n for (const obj of newList) {\n let found = false;\n for (let i = 0; i < oldList.length; i++) {\n if (!oldListRemains[i] && obj === oldList[i]) {\n oldListRemains[i] = true;\n found = true;\n break;\n }\n }\n if (!found)\n added.push(obj);\n }\n const removed = oldList.filter((_2, i) => !oldListRemains[i]);\n cb(newList, oldList, added, removed, onCleanup);\n oldList = [...newList];\n }, options);\n}\n\nfunction watchAtMost(source, cb, options) {\n const {\n count,\n ...watchOptions\n } = options;\n const current = ref(0);\n const stop = watchWithFilter(\n source,\n (...args) => {\n current.value += 1;\n if (current.value >= toValue(count))\n nextTick(() => stop());\n cb(...args);\n },\n watchOptions\n );\n return { count: current, stop };\n}\n\nfunction watchDebounced(source, cb, options = {}) {\n const {\n debounce = 0,\n maxWait = void 0,\n ...watchOptions\n } = options;\n return watchWithFilter(\n source,\n cb,\n {\n ...watchOptions,\n eventFilter: debounceFilter(debounce, { maxWait })\n }\n );\n}\n\nfunction watchDeep(source, cb, options) {\n return watch(\n source,\n cb,\n {\n ...options,\n deep: true\n }\n );\n}\n\nfunction watchIgnorable(source, cb, options = {}) {\n const {\n eventFilter = bypassFilter,\n ...watchOptions\n } = options;\n const filteredCb = createFilterWrapper(\n eventFilter,\n cb\n );\n let ignoreUpdates;\n let ignorePrevAsyncUpdates;\n let stop;\n if (watchOptions.flush === \"sync\") {\n const ignore = ref(false);\n ignorePrevAsyncUpdates = () => {\n };\n ignoreUpdates = (updater) => {\n ignore.value = true;\n updater();\n ignore.value = false;\n };\n stop = watch(\n source,\n (...args) => {\n if (!ignore.value)\n filteredCb(...args);\n },\n watchOptions\n );\n } else {\n const disposables = [];\n const ignoreCounter = ref(0);\n const syncCounter = ref(0);\n ignorePrevAsyncUpdates = () => {\n ignoreCounter.value = syncCounter.value;\n };\n disposables.push(\n watch(\n source,\n () => {\n syncCounter.value++;\n },\n { ...watchOptions, flush: \"sync\" }\n )\n );\n ignoreUpdates = (updater) => {\n const syncCounterPrev = syncCounter.value;\n updater();\n ignoreCounter.value += syncCounter.value - syncCounterPrev;\n };\n disposables.push(\n watch(\n source,\n (...args) => {\n const ignore = ignoreCounter.value > 0 && ignoreCounter.value === syncCounter.value;\n ignoreCounter.value = 0;\n syncCounter.value = 0;\n if (ignore)\n return;\n filteredCb(...args);\n },\n watchOptions\n )\n );\n stop = () => {\n disposables.forEach((fn) => fn());\n };\n }\n return { stop, ignoreUpdates, ignorePrevAsyncUpdates };\n}\n\nfunction watchImmediate(source, cb, options) {\n return watch(\n source,\n cb,\n {\n ...options,\n immediate: true\n }\n );\n}\n\nfunction watchOnce(source, cb, options) {\n const stop = watch(source, (...args) => {\n nextTick(() => stop());\n return cb(...args);\n }, options);\n return stop;\n}\n\nfunction watchThrottled(source, cb, options = {}) {\n const {\n throttle = 0,\n trailing = true,\n leading = true,\n ...watchOptions\n } = options;\n return watchWithFilter(\n source,\n cb,\n {\n ...watchOptions,\n eventFilter: throttleFilter(throttle, trailing, leading)\n }\n );\n}\n\nfunction watchTriggerable(source, cb, options = {}) {\n let cleanupFn;\n function onEffect() {\n if (!cleanupFn)\n return;\n const fn = cleanupFn;\n cleanupFn = void 0;\n fn();\n }\n function onCleanup(callback) {\n cleanupFn = callback;\n }\n const _cb = (value, oldValue) => {\n onEffect();\n return cb(value, oldValue, onCleanup);\n };\n const res = watchIgnorable(source, _cb, options);\n const { ignoreUpdates } = res;\n const trigger = () => {\n let res2;\n ignoreUpdates(() => {\n res2 = _cb(getWatchSources(source), getOldValue(source));\n });\n return res2;\n };\n return {\n ...res,\n trigger\n };\n}\nfunction getWatchSources(sources) {\n if (isReactive(sources))\n return sources;\n if (Array.isArray(sources))\n return sources.map((item) => toValue(item));\n return toValue(sources);\n}\nfunction getOldValue(source) {\n return Array.isArray(source) ? source.map(() => void 0) : void 0;\n}\n\nfunction whenever(source, cb, options) {\n const stop = watch(\n source,\n (v, ov, onInvalidate) => {\n if (v) {\n if (options == null ? void 0 : options.once)\n nextTick(() => stop());\n cb(v, ov, onInvalidate);\n }\n },\n {\n ...options,\n once: false\n }\n );\n return stop;\n}\n\nexport { assert, refAutoReset as autoResetRef, bypassFilter, camelize, clamp, computedEager, computedWithControl, containsProp, computedWithControl as controlledComputed, controlledRef, createEventHook, createFilterWrapper, createGlobalState, createInjectionState, reactify as createReactiveFn, createSharedComposable, createSingletonPromise, debounceFilter, refDebounced as debouncedRef, watchDebounced as debouncedWatch, computedEager as eagerComputed, extendRef, formatDate, get, getLifeCycleTarget, hasOwn, hyphenate, identity, watchIgnorable as ignorableWatch, increaseWithUnit, injectLocal, invoke, isClient, isDef, isDefined, isIOS, isObject, isWorker, makeDestructurable, noop, normalizeDate, notNullish, now, objectEntries, objectOmit, objectPick, pausableFilter, watchPausable as pausableWatch, promiseTimeout, provideLocal, rand, reactify, reactifyObject, reactiveComputed, reactiveOmit, reactivePick, refAutoReset, refDebounced, refDefault, refThrottled, refWithControl, resolveRef, resolveUnref, set, syncRef, syncRefs, throttleFilter, refThrottled as throttledRef, watchThrottled as throttledWatch, timestamp, toReactive, toRef, toRefs, toValue, tryOnBeforeMount, tryOnBeforeUnmount, tryOnMounted, tryOnScopeDispose, tryOnUnmounted, until, useArrayDifference, useArrayEvery, useArrayFilter, useArrayFind, useArrayFindIndex, useArrayFindLast, useArrayIncludes, useArrayJoin, useArrayMap, useArrayReduce, useArraySome, useArrayUnique, useCounter, useDateFormat, refDebounced as useDebounce, useDebounceFn, useInterval, useIntervalFn, useLastChanged, refThrottled as useThrottle, useThrottleFn, useTimeout, useTimeoutFn, useToNumber, useToString, useToggle, watchArray, watchAtMost, watchDebounced, watchDeep, watchIgnorable, watchImmediate, watchOnce, watchPausable, watchThrottled, watchTriggerable, watchWithFilter, whenever };\n","import { noop, makeDestructurable, camelize, toValue, isClient, isObject, tryOnScopeDispose, isIOS, tryOnMounted, notNullish, objectOmit, promiseTimeout, until, increaseWithUnit, objectEntries, createSingletonPromise, useTimeoutFn, pausableWatch, toRef, createEventHook, computedWithControl, timestamp, pausableFilter, watchIgnorable, debounceFilter, createFilterWrapper, bypassFilter, toRefs, useIntervalFn, containsProp, hasOwn, throttleFilter, useDebounceFn, useThrottleFn, tryOnUnmounted, clamp, syncRef, objectPick, watchWithFilter, tryOnBeforeUnmount, identity, isDef, whenever, isWorker } from '@vueuse/shared';\nexport * from '@vueuse/shared';\nimport { isRef, ref, shallowRef, watchEffect, computed, inject, defineComponent, h, TransitionGroup, shallowReactive, Fragment, watch, getCurrentInstance, customRef, onUpdated, onMounted, readonly, reactive, toRaw, nextTick, markRaw, unref, getCurrentScope, isReadonly, onBeforeUpdate } from 'vue';\n\nfunction computedAsync(evaluationCallback, initialState, optionsOrRef) {\n let options;\n if (isRef(optionsOrRef)) {\n options = {\n evaluating: optionsOrRef\n };\n } else {\n options = optionsOrRef || {};\n }\n const {\n lazy = false,\n evaluating = void 0,\n shallow = true,\n onError = noop\n } = options;\n const started = ref(!lazy);\n const current = shallow ? shallowRef(initialState) : ref(initialState);\n let counter = 0;\n watchEffect(async (onInvalidate) => {\n if (!started.value)\n return;\n counter++;\n const counterAtBeginning = counter;\n let hasFinished = false;\n if (evaluating) {\n Promise.resolve().then(() => {\n evaluating.value = true;\n });\n }\n try {\n const result = await evaluationCallback((cancelCallback) => {\n onInvalidate(() => {\n if (evaluating)\n evaluating.value = false;\n if (!hasFinished)\n cancelCallback();\n });\n });\n if (counterAtBeginning === counter)\n current.value = result;\n } catch (e) {\n onError(e);\n } finally {\n if (evaluating && counterAtBeginning === counter)\n evaluating.value = false;\n hasFinished = true;\n }\n });\n if (lazy) {\n return computed(() => {\n started.value = true;\n return current.value;\n });\n } else {\n return current;\n }\n}\n\nfunction computedInject(key, options, defaultSource, treatDefaultAsFactory) {\n let source = inject(key);\n if (defaultSource)\n source = inject(key, defaultSource);\n if (treatDefaultAsFactory)\n source = inject(key, defaultSource, treatDefaultAsFactory);\n if (typeof options === \"function\") {\n return computed((ctx) => options(source, ctx));\n } else {\n return computed({\n get: (ctx) => options.get(source, ctx),\n set: options.set\n });\n }\n}\n\nfunction createReusableTemplate(options = {}) {\n const {\n inheritAttrs = true\n } = options;\n const render = shallowRef();\n const define = /* #__PURE__ */ defineComponent({\n setup(_, { slots }) {\n return () => {\n render.value = slots.default;\n };\n }\n });\n const reuse = /* #__PURE__ */ defineComponent({\n inheritAttrs,\n setup(_, { attrs, slots }) {\n return () => {\n var _a;\n if (!render.value && process.env.NODE_ENV !== \"production\")\n throw new Error(\"[VueUse] Failed to find the definition of reusable template\");\n const vnode = (_a = render.value) == null ? void 0 : _a.call(render, { ...keysToCamelKebabCase(attrs), $slots: slots });\n return inheritAttrs && (vnode == null ? void 0 : vnode.length) === 1 ? vnode[0] : vnode;\n };\n }\n });\n return makeDestructurable(\n { define, reuse },\n [define, reuse]\n );\n}\nfunction keysToCamelKebabCase(obj) {\n const newObj = {};\n for (const key in obj)\n newObj[camelize(key)] = obj[key];\n return newObj;\n}\n\nfunction createTemplatePromise(options = {}) {\n let index = 0;\n const instances = ref([]);\n function create(...args) {\n const props = shallowReactive({\n key: index++,\n args,\n promise: void 0,\n resolve: () => {\n },\n reject: () => {\n },\n isResolving: false,\n options\n });\n instances.value.push(props);\n props.promise = new Promise((_resolve, _reject) => {\n props.resolve = (v) => {\n props.isResolving = true;\n return _resolve(v);\n };\n props.reject = _reject;\n }).finally(() => {\n props.promise = void 0;\n const index2 = instances.value.indexOf(props);\n if (index2 !== -1)\n instances.value.splice(index2, 1);\n });\n return props.promise;\n }\n function start(...args) {\n if (options.singleton && instances.value.length > 0)\n return instances.value[0].promise;\n return create(...args);\n }\n const component = /* #__PURE__ */ defineComponent((_, { slots }) => {\n const renderList = () => instances.value.map((props) => {\n var _a;\n return h(Fragment, { key: props.key }, (_a = slots.default) == null ? void 0 : _a.call(slots, props));\n });\n if (options.transition)\n return () => h(TransitionGroup, options.transition, renderList);\n return renderList;\n });\n component.start = start;\n return component;\n}\n\nfunction createUnrefFn(fn) {\n return function(...args) {\n return fn.apply(this, args.map((i) => toValue(i)));\n };\n}\n\nconst defaultWindow = isClient ? window : void 0;\nconst defaultDocument = isClient ? window.document : void 0;\nconst defaultNavigator = isClient ? window.navigator : void 0;\nconst defaultLocation = isClient ? window.location : void 0;\n\nfunction unrefElement(elRef) {\n var _a;\n const plain = toValue(elRef);\n return (_a = plain == null ? void 0 : plain.$el) != null ? _a : plain;\n}\n\nfunction useEventListener(...args) {\n let target;\n let events;\n let listeners;\n let options;\n if (typeof args[0] === \"string\" || Array.isArray(args[0])) {\n [events, listeners, options] = args;\n target = defaultWindow;\n } else {\n [target, events, listeners, options] = args;\n }\n if (!target)\n return noop;\n if (!Array.isArray(events))\n events = [events];\n if (!Array.isArray(listeners))\n listeners = [listeners];\n const cleanups = [];\n const cleanup = () => {\n cleanups.forEach((fn) => fn());\n cleanups.length = 0;\n };\n const register = (el, event, listener, options2) => {\n el.addEventListener(event, listener, options2);\n return () => el.removeEventListener(event, listener, options2);\n };\n const stopWatch = watch(\n () => [unrefElement(target), toValue(options)],\n ([el, options2]) => {\n cleanup();\n if (!el)\n return;\n const optionsClone = isObject(options2) ? { ...options2 } : options2;\n cleanups.push(\n ...events.flatMap((event) => {\n return listeners.map((listener) => register(el, event, listener, optionsClone));\n })\n );\n },\n { immediate: true, flush: \"post\" }\n );\n const stop = () => {\n stopWatch();\n cleanup();\n };\n tryOnScopeDispose(stop);\n return stop;\n}\n\nlet _iOSWorkaround = false;\nfunction onClickOutside(target, handler, options = {}) {\n const { window = defaultWindow, ignore = [], capture = true, detectIframe = false } = options;\n if (!window)\n return noop;\n if (isIOS && !_iOSWorkaround) {\n _iOSWorkaround = true;\n Array.from(window.document.body.children).forEach((el) => el.addEventListener(\"click\", noop));\n window.document.documentElement.addEventListener(\"click\", noop);\n }\n let shouldListen = true;\n const shouldIgnore = (event) => {\n return toValue(ignore).some((target2) => {\n if (typeof target2 === \"string\") {\n return Array.from(window.document.querySelectorAll(target2)).some((el) => el === event.target || event.composedPath().includes(el));\n } else {\n const el = unrefElement(target2);\n return el && (event.target === el || event.composedPath().includes(el));\n }\n });\n };\n function hasMultipleRoots(target2) {\n const vm = toValue(target2);\n return vm && vm.$.subTree.shapeFlag === 16;\n }\n function checkMultipleRoots(target2, event) {\n const vm = toValue(target2);\n const children = vm.$.subTree && vm.$.subTree.children;\n if (children == null || !Array.isArray(children))\n return false;\n return children.some((child) => child.el === event.target || event.composedPath().includes(child.el));\n }\n const listener = (event) => {\n const el = unrefElement(target);\n if (event.target == null)\n return;\n if (!(el instanceof Element) && hasMultipleRoots(target) && checkMultipleRoots(target, event))\n return;\n if (!el || el === event.target || event.composedPath().includes(el))\n return;\n if (event.detail === 0)\n shouldListen = !shouldIgnore(event);\n if (!shouldListen) {\n shouldListen = true;\n return;\n }\n handler(event);\n };\n let isProcessingClick = false;\n const cleanup = [\n useEventListener(window, \"click\", (event) => {\n if (!isProcessingClick) {\n isProcessingClick = true;\n setTimeout(() => {\n isProcessingClick = false;\n }, 0);\n listener(event);\n }\n }, { passive: true, capture }),\n useEventListener(window, \"pointerdown\", (e) => {\n const el = unrefElement(target);\n shouldListen = !shouldIgnore(e) && !!(el && !e.composedPath().includes(el));\n }, { passive: true }),\n detectIframe && useEventListener(window, \"blur\", (event) => {\n setTimeout(() => {\n var _a;\n const el = unrefElement(target);\n if (((_a = window.document.activeElement) == null ? void 0 : _a.tagName) === \"IFRAME\" && !(el == null ? void 0 : el.contains(window.document.activeElement))) {\n handler(event);\n }\n }, 0);\n })\n ].filter(Boolean);\n const stop = () => cleanup.forEach((fn) => fn());\n return stop;\n}\n\nfunction createKeyPredicate(keyFilter) {\n if (typeof keyFilter === \"function\")\n return keyFilter;\n else if (typeof keyFilter === \"string\")\n return (event) => event.key === keyFilter;\n else if (Array.isArray(keyFilter))\n return (event) => keyFilter.includes(event.key);\n return () => true;\n}\nfunction onKeyStroke(...args) {\n let key;\n let handler;\n let options = {};\n if (args.length === 3) {\n key = args[0];\n handler = args[1];\n options = args[2];\n } else if (args.length === 2) {\n if (typeof args[1] === \"object\") {\n key = true;\n handler = args[0];\n options = args[1];\n } else {\n key = args[0];\n handler = args[1];\n }\n } else {\n key = true;\n handler = args[0];\n }\n const {\n target = defaultWindow,\n eventName = \"keydown\",\n passive = false,\n dedupe = false\n } = options;\n const predicate = createKeyPredicate(key);\n const listener = (e) => {\n if (e.repeat && toValue(dedupe))\n return;\n if (predicate(e))\n handler(e);\n };\n return useEventListener(target, eventName, listener, passive);\n}\nfunction onKeyDown(key, handler, options = {}) {\n return onKeyStroke(key, handler, { ...options, eventName: \"keydown\" });\n}\nfunction onKeyPressed(key, handler, options = {}) {\n return onKeyStroke(key, handler, { ...options, eventName: \"keypress\" });\n}\nfunction onKeyUp(key, handler, options = {}) {\n return onKeyStroke(key, handler, { ...options, eventName: \"keyup\" });\n}\n\nconst DEFAULT_DELAY = 500;\nconst DEFAULT_THRESHOLD = 10;\nfunction onLongPress(target, handler, options) {\n var _a, _b;\n const elementRef = computed(() => unrefElement(target));\n let timeout;\n let posStart;\n let startTimestamp;\n let hasLongPressed = false;\n function clear() {\n if (timeout) {\n clearTimeout(timeout);\n timeout = void 0;\n }\n posStart = void 0;\n startTimestamp = void 0;\n hasLongPressed = false;\n }\n function onRelease(ev) {\n var _a2, _b2, _c;\n const [_startTimestamp, _posStart, _hasLongPressed] = [startTimestamp, posStart, hasLongPressed];\n clear();\n if (!(options == null ? void 0 : options.onMouseUp) || !_posStart || !_startTimestamp)\n return;\n if (((_a2 = options == null ? void 0 : options.modifiers) == null ? void 0 : _a2.self) && ev.target !== elementRef.value)\n return;\n if ((_b2 = options == null ? void 0 : options.modifiers) == null ? void 0 : _b2.prevent)\n ev.preventDefault();\n if ((_c = options == null ? void 0 : options.modifiers) == null ? void 0 : _c.stop)\n ev.stopPropagation();\n const dx = ev.x - _posStart.x;\n const dy = ev.y - _posStart.y;\n const distance = Math.sqrt(dx * dx + dy * dy);\n options.onMouseUp(ev.timeStamp - _startTimestamp, distance, _hasLongPressed);\n }\n function onDown(ev) {\n var _a2, _b2, _c, _d;\n if (((_a2 = options == null ? void 0 : options.modifiers) == null ? void 0 : _a2.self) && ev.target !== elementRef.value)\n return;\n clear();\n if ((_b2 = options == null ? void 0 : options.modifiers) == null ? void 0 : _b2.prevent)\n ev.preventDefault();\n if ((_c = options == null ? void 0 : options.modifiers) == null ? void 0 : _c.stop)\n ev.stopPropagation();\n posStart = {\n x: ev.x,\n y: ev.y\n };\n startTimestamp = ev.timeStamp;\n timeout = setTimeout(\n () => {\n hasLongPressed = true;\n handler(ev);\n },\n (_d = options == null ? void 0 : options.delay) != null ? _d : DEFAULT_DELAY\n );\n }\n function onMove(ev) {\n var _a2, _b2, _c, _d;\n if (((_a2 = options == null ? void 0 : options.modifiers) == null ? void 0 : _a2.self) && ev.target !== elementRef.value)\n return;\n if (!posStart || (options == null ? void 0 : options.distanceThreshold) === false)\n return;\n if ((_b2 = options == null ? void 0 : options.modifiers) == null ? void 0 : _b2.prevent)\n ev.preventDefault();\n if ((_c = options == null ? void 0 : options.modifiers) == null ? void 0 : _c.stop)\n ev.stopPropagation();\n const dx = ev.x - posStart.x;\n const dy = ev.y - posStart.y;\n const distance = Math.sqrt(dx * dx + dy * dy);\n if (distance >= ((_d = options == null ? void 0 : options.distanceThreshold) != null ? _d : DEFAULT_THRESHOLD))\n clear();\n }\n const listenerOptions = {\n capture: (_a = options == null ? void 0 : options.modifiers) == null ? void 0 : _a.capture,\n once: (_b = options == null ? void 0 : options.modifiers) == null ? void 0 : _b.once\n };\n const cleanup = [\n useEventListener(elementRef, \"pointerdown\", onDown, listenerOptions),\n useEventListener(elementRef, \"pointermove\", onMove, listenerOptions),\n useEventListener(elementRef, [\"pointerup\", \"pointerleave\"], onRelease, listenerOptions)\n ];\n const stop = () => cleanup.forEach((fn) => fn());\n return stop;\n}\n\nfunction isFocusedElementEditable() {\n const { activeElement, body } = document;\n if (!activeElement)\n return false;\n if (activeElement === body)\n return false;\n switch (activeElement.tagName) {\n case \"INPUT\":\n case \"TEXTAREA\":\n return true;\n }\n return activeElement.hasAttribute(\"contenteditable\");\n}\nfunction isTypedCharValid({\n keyCode,\n metaKey,\n ctrlKey,\n altKey\n}) {\n if (metaKey || ctrlKey || altKey)\n return false;\n if (keyCode >= 48 && keyCode <= 57)\n return true;\n if (keyCode >= 65 && keyCode <= 90)\n return true;\n if (keyCode >= 97 && keyCode <= 122)\n return true;\n return false;\n}\nfunction onStartTyping(callback, options = {}) {\n const { document: document2 = defaultDocument } = options;\n const keydown = (event) => {\n if (!isFocusedElementEditable() && isTypedCharValid(event)) {\n callback(event);\n }\n };\n if (document2)\n useEventListener(document2, \"keydown\", keydown, { passive: true });\n}\n\nfunction templateRef(key, initialValue = null) {\n const instance = getCurrentInstance();\n let _trigger = () => {\n };\n const element = customRef((track, trigger) => {\n _trigger = trigger;\n return {\n get() {\n var _a, _b;\n track();\n return (_b = (_a = instance == null ? void 0 : instance.proxy) == null ? void 0 : _a.$refs[key]) != null ? _b : initialValue;\n },\n set() {\n }\n };\n });\n tryOnMounted(_trigger);\n onUpdated(_trigger);\n return element;\n}\n\nfunction useMounted() {\n const isMounted = ref(false);\n const instance = getCurrentInstance();\n if (instance) {\n onMounted(() => {\n isMounted.value = true;\n }, instance);\n }\n return isMounted;\n}\n\nfunction useSupported(callback) {\n const isMounted = useMounted();\n return computed(() => {\n isMounted.value;\n return Boolean(callback());\n });\n}\n\nfunction useMutationObserver(target, callback, options = {}) {\n const { window = defaultWindow, ...mutationOptions } = options;\n let observer;\n const isSupported = useSupported(() => window && \"MutationObserver\" in window);\n const cleanup = () => {\n if (observer) {\n observer.disconnect();\n observer = void 0;\n }\n };\n const targets = computed(() => {\n const value = toValue(target);\n const items = (Array.isArray(value) ? value : [value]).map(unrefElement).filter(notNullish);\n return new Set(items);\n });\n const stopWatch = watch(\n () => targets.value,\n (targets2) => {\n cleanup();\n if (isSupported.value && targets2.size) {\n observer = new MutationObserver(callback);\n targets2.forEach((el) => observer.observe(el, mutationOptions));\n }\n },\n { immediate: true, flush: \"post\" }\n );\n const takeRecords = () => {\n return observer == null ? void 0 : observer.takeRecords();\n };\n const stop = () => {\n stopWatch();\n cleanup();\n };\n tryOnScopeDispose(stop);\n return {\n isSupported,\n stop,\n takeRecords\n };\n}\n\nfunction useActiveElement(options = {}) {\n var _a;\n const {\n window = defaultWindow,\n deep = true,\n triggerOnRemoval = false\n } = options;\n const document = (_a = options.document) != null ? _a : window == null ? void 0 : window.document;\n const getDeepActiveElement = () => {\n var _a2;\n let element = document == null ? void 0 : document.activeElement;\n if (deep) {\n while (element == null ? void 0 : element.shadowRoot)\n element = (_a2 = element == null ? void 0 : element.shadowRoot) == null ? void 0 : _a2.activeElement;\n }\n return element;\n };\n const activeElement = ref();\n const trigger = () => {\n activeElement.value = getDeepActiveElement();\n };\n if (window) {\n useEventListener(window, \"blur\", (event) => {\n if (event.relatedTarget !== null)\n return;\n trigger();\n }, true);\n useEventListener(window, \"focus\", trigger, true);\n }\n if (triggerOnRemoval) {\n useMutationObserver(document, (mutations) => {\n mutations.filter((m) => m.removedNodes.length).map((n) => Array.from(n.removedNodes)).flat().forEach((node) => {\n if (node === activeElement.value)\n trigger();\n });\n }, {\n childList: true,\n subtree: true\n });\n }\n trigger();\n return activeElement;\n}\n\nfunction useRafFn(fn, options = {}) {\n const {\n immediate = true,\n fpsLimit = void 0,\n window = defaultWindow\n } = options;\n const isActive = ref(false);\n const intervalLimit = fpsLimit ? 1e3 / fpsLimit : null;\n let previousFrameTimestamp = 0;\n let rafId = null;\n function loop(timestamp) {\n if (!isActive.value || !window)\n return;\n if (!previousFrameTimestamp)\n previousFrameTimestamp = timestamp;\n const delta = timestamp - previousFrameTimestamp;\n if (intervalLimit && delta < intervalLimit) {\n rafId = window.requestAnimationFrame(loop);\n return;\n }\n previousFrameTimestamp = timestamp;\n fn({ delta, timestamp });\n rafId = window.requestAnimationFrame(loop);\n }\n function resume() {\n if (!isActive.value && window) {\n isActive.value = true;\n previousFrameTimestamp = 0;\n rafId = window.requestAnimationFrame(loop);\n }\n }\n function pause() {\n isActive.value = false;\n if (rafId != null && window) {\n window.cancelAnimationFrame(rafId);\n rafId = null;\n }\n }\n if (immediate)\n resume();\n tryOnScopeDispose(pause);\n return {\n isActive: readonly(isActive),\n pause,\n resume\n };\n}\n\nfunction useAnimate(target, keyframes, options) {\n let config;\n let animateOptions;\n if (isObject(options)) {\n config = options;\n animateOptions = objectOmit(options, [\"window\", \"immediate\", \"commitStyles\", \"persist\", \"onReady\", \"onError\"]);\n } else {\n config = { duration: options };\n animateOptions = options;\n }\n const {\n window = defaultWindow,\n immediate = true,\n commitStyles,\n persist,\n playbackRate: _playbackRate = 1,\n onReady,\n onError = (e) => {\n console.error(e);\n }\n } = config;\n const isSupported = useSupported(() => window && HTMLElement && \"animate\" in HTMLElement.prototype);\n const animate = shallowRef(void 0);\n const store = shallowReactive({\n startTime: null,\n currentTime: null,\n timeline: null,\n playbackRate: _playbackRate,\n pending: false,\n playState: immediate ? \"idle\" : \"paused\",\n replaceState: \"active\"\n });\n const pending = computed(() => store.pending);\n const playState = computed(() => store.playState);\n const replaceState = computed(() => store.replaceState);\n const startTime = computed({\n get() {\n return store.startTime;\n },\n set(value) {\n store.startTime = value;\n if (animate.value)\n animate.value.startTime = value;\n }\n });\n const currentTime = computed({\n get() {\n return store.currentTime;\n },\n set(value) {\n store.currentTime = value;\n if (animate.value) {\n animate.value.currentTime = value;\n syncResume();\n }\n }\n });\n const timeline = computed({\n get() {\n return store.timeline;\n },\n set(value) {\n store.timeline = value;\n if (animate.value)\n animate.value.timeline = value;\n }\n });\n const playbackRate = computed({\n get() {\n return store.playbackRate;\n },\n set(value) {\n store.playbackRate = value;\n if (animate.value)\n animate.value.playbackRate = value;\n }\n });\n const play = () => {\n if (animate.value) {\n try {\n animate.value.play();\n syncResume();\n } catch (e) {\n syncPause();\n onError(e);\n }\n } else {\n update();\n }\n };\n const pause = () => {\n var _a;\n try {\n (_a = animate.value) == null ? void 0 : _a.pause();\n syncPause();\n } catch (e) {\n onError(e);\n }\n };\n const reverse = () => {\n var _a;\n if (!animate.value)\n update();\n try {\n (_a = animate.value) == null ? void 0 : _a.reverse();\n syncResume();\n } catch (e) {\n syncPause();\n onError(e);\n }\n };\n const finish = () => {\n var _a;\n try {\n (_a = animate.value) == null ? void 0 : _a.finish();\n syncPause();\n } catch (e) {\n onError(e);\n }\n };\n const cancel = () => {\n var _a;\n try {\n (_a = animate.value) == null ? void 0 : _a.cancel();\n syncPause();\n } catch (e) {\n onError(e);\n }\n };\n watch(() => unrefElement(target), (el) => {\n if (el)\n update();\n });\n watch(() => keyframes, (value) => {\n if (animate.value)\n update();\n if (!unrefElement(target) && animate.value) {\n animate.value.effect = new KeyframeEffect(\n unrefElement(target),\n toValue(value),\n animateOptions\n );\n }\n }, { deep: true });\n tryOnMounted(() => update(true), false);\n tryOnScopeDispose(cancel);\n function update(init) {\n const el = unrefElement(target);\n if (!isSupported.value || !el)\n return;\n if (!animate.value)\n animate.value = el.animate(toValue(keyframes), animateOptions);\n if (persist)\n animate.value.persist();\n if (_playbackRate !== 1)\n animate.value.playbackRate = _playbackRate;\n if (init && !immediate)\n animate.value.pause();\n else\n syncResume();\n onReady == null ? void 0 : onReady(animate.value);\n }\n useEventListener(animate, [\"cancel\", \"finish\", \"remove\"], syncPause);\n useEventListener(animate, \"finish\", () => {\n var _a;\n if (commitStyles)\n (_a = animate.value) == null ? void 0 : _a.commitStyles();\n });\n const { resume: resumeRef, pause: pauseRef } = useRafFn(() => {\n if (!animate.value)\n return;\n store.pending = animate.value.pending;\n store.playState = animate.value.playState;\n store.replaceState = animate.value.replaceState;\n store.startTime = animate.value.startTime;\n store.currentTime = animate.value.currentTime;\n store.timeline = animate.value.timeline;\n store.playbackRate = animate.value.playbackRate;\n }, { immediate: false });\n function syncResume() {\n if (isSupported.value)\n resumeRef();\n }\n function syncPause() {\n if (isSupported.value && window)\n window.requestAnimationFrame(pauseRef);\n }\n return {\n isSupported,\n animate,\n // actions\n play,\n pause,\n reverse,\n finish,\n cancel,\n // state\n pending,\n playState,\n replaceState,\n startTime,\n currentTime,\n timeline,\n playbackRate\n };\n}\n\nfunction useAsyncQueue(tasks, options) {\n const {\n interrupt = true,\n onError = noop,\n onFinished = noop,\n signal\n } = options || {};\n const promiseState = {\n aborted: \"aborted\",\n fulfilled: \"fulfilled\",\n pending: \"pending\",\n rejected: \"rejected\"\n };\n const initialResult = Array.from(Array.from({ length: tasks.length }), () => ({ state: promiseState.pending, data: null }));\n const result = reactive(initialResult);\n const activeIndex = ref(-1);\n if (!tasks || tasks.length === 0) {\n onFinished();\n return {\n activeIndex,\n result\n };\n }\n function updateResult(state, res) {\n activeIndex.value++;\n result[activeIndex.value].data = res;\n result[activeIndex.value].state = state;\n }\n tasks.reduce((prev, curr) => {\n return prev.then((prevRes) => {\n var _a;\n if (signal == null ? void 0 : signal.aborted) {\n updateResult(promiseState.aborted, new Error(\"aborted\"));\n return;\n }\n if (((_a = result[activeIndex.value]) == null ? void 0 : _a.state) === promiseState.rejected && interrupt) {\n onFinished();\n return;\n }\n const done = curr(prevRes).then((currentRes) => {\n updateResult(promiseState.fulfilled, currentRes);\n if (activeIndex.value === tasks.length - 1)\n onFinished();\n return currentRes;\n });\n if (!signal)\n return done;\n return Promise.race([done, whenAborted(signal)]);\n }).catch((e) => {\n if (signal == null ? void 0 : signal.aborted) {\n updateResult(promiseState.aborted, e);\n return e;\n }\n updateResult(promiseState.rejected, e);\n onError();\n return e;\n });\n }, Promise.resolve());\n return {\n activeIndex,\n result\n };\n}\nfunction whenAborted(signal) {\n return new Promise((resolve, reject) => {\n const error = new Error(\"aborted\");\n if (signal.aborted)\n reject(error);\n else\n signal.addEventListener(\"abort\", () => reject(error), { once: true });\n });\n}\n\nfunction useAsyncState(promise, initialState, options) {\n const {\n immediate = true,\n delay = 0,\n onError = noop,\n onSuccess = noop,\n resetOnExecute = true,\n shallow = true,\n throwError\n } = options != null ? options : {};\n const state = shallow ? shallowRef(initialState) : ref(initialState);\n const isReady = ref(false);\n const isLoading = ref(false);\n const error = shallowRef(void 0);\n async function execute(delay2 = 0, ...args) {\n if (resetOnExecute)\n state.value = initialState;\n error.value = void 0;\n isReady.value = false;\n isLoading.value = true;\n if (delay2 > 0)\n await promiseTimeout(delay2);\n const _promise = typeof promise === \"function\" ? promise(...args) : promise;\n try {\n const data = await _promise;\n state.value = data;\n isReady.value = true;\n onSuccess(data);\n } catch (e) {\n error.value = e;\n onError(e);\n if (throwError)\n throw e;\n } finally {\n isLoading.value = false;\n }\n return state.value;\n }\n if (immediate)\n execute(delay);\n const shell = {\n state,\n isReady,\n isLoading,\n error,\n execute\n };\n function waitUntilIsLoaded() {\n return new Promise((resolve, reject) => {\n until(isLoading).toBe(false).then(() => resolve(shell)).catch(reject);\n });\n }\n return {\n ...shell,\n then(onFulfilled, onRejected) {\n return waitUntilIsLoaded().then(onFulfilled, onRejected);\n }\n };\n}\n\nconst defaults = {\n array: (v) => JSON.stringify(v),\n object: (v) => JSON.stringify(v),\n set: (v) => JSON.stringify(Array.from(v)),\n map: (v) => JSON.stringify(Object.fromEntries(v)),\n null: () => \"\"\n};\nfunction getDefaultSerialization(target) {\n if (!target)\n return defaults.null;\n if (target instanceof Map)\n return defaults.map;\n else if (target instanceof Set)\n return defaults.set;\n else if (Array.isArray(target))\n return defaults.array;\n else\n return defaults.object;\n}\n\nfunction useBase64(target, options) {\n const base64 = ref(\"\");\n const promise = ref();\n function execute() {\n if (!isClient)\n return;\n promise.value = new Promise((resolve, reject) => {\n try {\n const _target = toValue(target);\n if (_target == null) {\n resolve(\"\");\n } else if (typeof _target === \"string\") {\n resolve(blobToBase64(new Blob([_target], { type: \"text/plain\" })));\n } else if (_target instanceof Blob) {\n resolve(blobToBase64(_target));\n } else if (_target instanceof ArrayBuffer) {\n resolve(window.btoa(String.fromCharCode(...new Uint8Array(_target))));\n } else if (_target instanceof HTMLCanvasElement) {\n resolve(_target.toDataURL(options == null ? void 0 : options.type, options == null ? void 0 : options.quality));\n } else if (_target instanceof HTMLImageElement) {\n const img = _target.cloneNode(false);\n img.crossOrigin = \"Anonymous\";\n imgLoaded(img).then(() => {\n const canvas = document.createElement(\"canvas\");\n const ctx = canvas.getContext(\"2d\");\n canvas.width = img.width;\n canvas.height = img.height;\n ctx.drawImage(img, 0, 0, canvas.width, canvas.height);\n resolve(canvas.toDataURL(options == null ? void 0 : options.type, options == null ? void 0 : options.quality));\n }).catch(reject);\n } else if (typeof _target === \"object\") {\n const _serializeFn = (options == null ? void 0 : options.serializer) || getDefaultSerialization(_target);\n const serialized = _serializeFn(_target);\n return resolve(blobToBase64(new Blob([serialized], { type: \"application/json\" })));\n } else {\n reject(new Error(\"target is unsupported types\"));\n }\n } catch (error) {\n reject(error);\n }\n });\n promise.value.then((res) => base64.value = res);\n return promise.value;\n }\n if (isRef(target) || typeof target === \"function\")\n watch(target, execute, { immediate: true });\n else\n execute();\n return {\n base64,\n promise,\n execute\n };\n}\nfunction imgLoaded(img) {\n return new Promise((resolve, reject) => {\n if (!img.complete) {\n img.onload = () => {\n resolve();\n };\n img.onerror = reject;\n } else {\n resolve();\n }\n });\n}\nfunction blobToBase64(blob) {\n return new Promise((resolve, reject) => {\n const fr = new FileReader();\n fr.onload = (e) => {\n resolve(e.target.result);\n };\n fr.onerror = reject;\n fr.readAsDataURL(blob);\n });\n}\n\nfunction useBattery(options = {}) {\n const { navigator = defaultNavigator } = options;\n const events = [\"chargingchange\", \"chargingtimechange\", \"dischargingtimechange\", \"levelchange\"];\n const isSupported = useSupported(() => navigator && \"getBattery\" in navigator && typeof navigator.getBattery === \"function\");\n const charging = ref(false);\n const chargingTime = ref(0);\n const dischargingTime = ref(0);\n const level = ref(1);\n let battery;\n function updateBatteryInfo() {\n charging.value = this.charging;\n chargingTime.value = this.chargingTime || 0;\n dischargingTime.value = this.dischargingTime || 0;\n level.value = this.level;\n }\n if (isSupported.value) {\n navigator.getBattery().then((_battery) => {\n battery = _battery;\n updateBatteryInfo.call(battery);\n useEventListener(battery, events, updateBatteryInfo, { passive: true });\n });\n }\n return {\n isSupported,\n charging,\n chargingTime,\n dischargingTime,\n level\n };\n}\n\nfunction useBluetooth(options) {\n let {\n acceptAllDevices = false\n } = options || {};\n const {\n filters = void 0,\n optionalServices = void 0,\n navigator = defaultNavigator\n } = options || {};\n const isSupported = useSupported(() => navigator && \"bluetooth\" in navigator);\n const device = shallowRef(void 0);\n const error = shallowRef(null);\n watch(device, () => {\n connectToBluetoothGATTServer();\n });\n async function requestDevice() {\n if (!isSupported.value)\n return;\n error.value = null;\n if (filters && filters.length > 0)\n acceptAllDevices = false;\n try {\n device.value = await (navigator == null ? void 0 : navigator.bluetooth.requestDevice({\n acceptAllDevices,\n filters,\n optionalServices\n }));\n } catch (err) {\n error.value = err;\n }\n }\n const server = ref();\n const isConnected = computed(() => {\n var _a;\n return ((_a = server.value) == null ? void 0 : _a.connected) || false;\n });\n async function connectToBluetoothGATTServer() {\n error.value = null;\n if (device.value && device.value.gatt) {\n device.value.addEventListener(\"gattserverdisconnected\", () => {\n });\n try {\n server.value = await device.value.gatt.connect();\n } catch (err) {\n error.value = err;\n }\n }\n }\n tryOnMounted(() => {\n var _a;\n if (device.value)\n (_a = device.value.gatt) == null ? void 0 : _a.connect();\n });\n tryOnScopeDispose(() => {\n var _a;\n if (device.value)\n (_a = device.value.gatt) == null ? void 0 : _a.disconnect();\n });\n return {\n isSupported,\n isConnected,\n // Device:\n device,\n requestDevice,\n // Server:\n server,\n // Errors:\n error\n };\n}\n\nfunction useMediaQuery(query, options = {}) {\n const { window = defaultWindow } = options;\n const isSupported = useSupported(() => window && \"matchMedia\" in window && typeof window.matchMedia === \"function\");\n let mediaQuery;\n const matches = ref(false);\n const handler = (event) => {\n matches.value = event.matches;\n };\n const cleanup = () => {\n if (!mediaQuery)\n return;\n if (\"removeEventListener\" in mediaQuery)\n mediaQuery.removeEventListener(\"change\", handler);\n else\n mediaQuery.removeListener(handler);\n };\n const stopWatch = watchEffect(() => {\n if (!isSupported.value)\n return;\n cleanup();\n mediaQuery = window.matchMedia(toValue(query));\n if (\"addEventListener\" in mediaQuery)\n mediaQuery.addEventListener(\"change\", handler);\n else\n mediaQuery.addListener(handler);\n matches.value = mediaQuery.matches;\n });\n tryOnScopeDispose(() => {\n stopWatch();\n cleanup();\n mediaQuery = void 0;\n });\n return matches;\n}\n\nconst breakpointsTailwind = {\n \"sm\": 640,\n \"md\": 768,\n \"lg\": 1024,\n \"xl\": 1280,\n \"2xl\": 1536\n};\nconst breakpointsBootstrapV5 = {\n xs: 0,\n sm: 576,\n md: 768,\n lg: 992,\n xl: 1200,\n xxl: 1400\n};\nconst breakpointsVuetifyV2 = {\n xs: 0,\n sm: 600,\n md: 960,\n lg: 1264,\n xl: 1904\n};\nconst breakpointsVuetifyV3 = {\n xs: 0,\n sm: 600,\n md: 960,\n lg: 1280,\n xl: 1920,\n xxl: 2560\n};\nconst breakpointsVuetify = breakpointsVuetifyV2;\nconst breakpointsAntDesign = {\n xs: 480,\n sm: 576,\n md: 768,\n lg: 992,\n xl: 1200,\n xxl: 1600\n};\nconst breakpointsQuasar = {\n xs: 0,\n sm: 600,\n md: 1024,\n lg: 1440,\n xl: 1920\n};\nconst breakpointsSematic = {\n mobileS: 320,\n mobileM: 375,\n mobileL: 425,\n tablet: 768,\n laptop: 1024,\n laptopL: 1440,\n desktop4K: 2560\n};\nconst breakpointsMasterCss = {\n \"3xs\": 360,\n \"2xs\": 480,\n \"xs\": 600,\n \"sm\": 768,\n \"md\": 1024,\n \"lg\": 1280,\n \"xl\": 1440,\n \"2xl\": 1600,\n \"3xl\": 1920,\n \"4xl\": 2560\n};\nconst breakpointsPrimeFlex = {\n sm: 576,\n md: 768,\n lg: 992,\n xl: 1200\n};\nconst breakpointsElement = {\n xs: 0,\n sm: 768,\n md: 992,\n lg: 1200,\n xl: 1920\n};\n\nfunction useBreakpoints(breakpoints, options = {}) {\n function getValue(k, delta) {\n let v = toValue(breakpoints[toValue(k)]);\n if (delta != null)\n v = increaseWithUnit(v, delta);\n if (typeof v === \"number\")\n v = `${v}px`;\n return v;\n }\n const { window = defaultWindow, strategy = \"min-width\" } = options;\n function match(query) {\n if (!window)\n return false;\n return window.matchMedia(query).matches;\n }\n const greaterOrEqual = (k) => {\n return useMediaQuery(() => `(min-width: ${getValue(k)})`, options);\n };\n const smallerOrEqual = (k) => {\n return useMediaQuery(() => `(max-width: ${getValue(k)})`, options);\n };\n const shortcutMethods = Object.keys(breakpoints).reduce((shortcuts, k) => {\n Object.defineProperty(shortcuts, k, {\n get: () => strategy === \"min-width\" ? greaterOrEqual(k) : smallerOrEqual(k),\n enumerable: true,\n configurable: true\n });\n return shortcuts;\n }, {});\n function current() {\n const points = Object.keys(breakpoints).map((i) => [i, greaterOrEqual(i)]);\n return computed(() => points.filter(([, v]) => v.value).map(([k]) => k));\n }\n return Object.assign(shortcutMethods, {\n greaterOrEqual,\n smallerOrEqual,\n greater(k) {\n return useMediaQuery(() => `(min-width: ${getValue(k, 0.1)})`, options);\n },\n smaller(k) {\n return useMediaQuery(() => `(max-width: ${getValue(k, -0.1)})`, options);\n },\n between(a, b) {\n return useMediaQuery(() => `(min-width: ${getValue(a)}) and (max-width: ${getValue(b, -0.1)})`, options);\n },\n isGreater(k) {\n return match(`(min-width: ${getValue(k, 0.1)})`);\n },\n isGreaterOrEqual(k) {\n return match(`(min-width: ${getValue(k)})`);\n },\n isSmaller(k) {\n return match(`(max-width: ${getValue(k, -0.1)})`);\n },\n isSmallerOrEqual(k) {\n return match(`(max-width: ${getValue(k)})`);\n },\n isInBetween(a, b) {\n return match(`(min-width: ${getValue(a)}) and (max-width: ${getValue(b, -0.1)})`);\n },\n current,\n active() {\n const bps = current();\n return computed(() => bps.value.length === 0 ? \"\" : bps.value.at(-1));\n }\n });\n}\n\nfunction useBroadcastChannel(options) {\n const {\n name,\n window = defaultWindow\n } = options;\n const isSupported = useSupported(() => window && \"BroadcastChannel\" in window);\n const isClosed = ref(false);\n const channel = ref();\n const data = ref();\n const error = shallowRef(null);\n const post = (data2) => {\n if (channel.value)\n channel.value.postMessage(data2);\n };\n const close = () => {\n if (channel.value)\n channel.value.close();\n isClosed.value = true;\n };\n if (isSupported.value) {\n tryOnMounted(() => {\n error.value = null;\n channel.value = new BroadcastChannel(name);\n channel.value.addEventListener(\"message\", (e) => {\n data.value = e.data;\n }, { passive: true });\n channel.value.addEventListener(\"messageerror\", (e) => {\n error.value = e;\n }, { passive: true });\n channel.value.addEventListener(\"close\", () => {\n isClosed.value = true;\n });\n });\n }\n tryOnScopeDispose(() => {\n close();\n });\n return {\n isSupported,\n channel,\n data,\n post,\n close,\n error,\n isClosed\n };\n}\n\nconst WRITABLE_PROPERTIES = [\n \"hash\",\n \"host\",\n \"hostname\",\n \"href\",\n \"pathname\",\n \"port\",\n \"protocol\",\n \"search\"\n];\nfunction useBrowserLocation(options = {}) {\n const { window = defaultWindow } = options;\n const refs = Object.fromEntries(\n WRITABLE_PROPERTIES.map((key) => [key, ref()])\n );\n for (const [key, ref2] of objectEntries(refs)) {\n watch(ref2, (value) => {\n if (!(window == null ? void 0 : window.location) || window.location[key] === value)\n return;\n window.location[key] = value;\n });\n }\n const buildState = (trigger) => {\n var _a;\n const { state: state2, length } = (window == null ? void 0 : window.history) || {};\n const { origin } = (window == null ? void 0 : window.location) || {};\n for (const key of WRITABLE_PROPERTIES)\n refs[key].value = (_a = window == null ? void 0 : window.location) == null ? void 0 : _a[key];\n return reactive({\n trigger,\n state: state2,\n length,\n origin,\n ...refs\n });\n };\n const state = ref(buildState(\"load\"));\n if (window) {\n useEventListener(window, \"popstate\", () => state.value = buildState(\"popstate\"), { passive: true });\n useEventListener(window, \"hashchange\", () => state.value = buildState(\"hashchange\"), { passive: true });\n }\n return state;\n}\n\nfunction useCached(refValue, comparator = (a, b) => a === b, watchOptions) {\n const cachedValue = ref(refValue.value);\n watch(() => refValue.value, (value) => {\n if (!comparator(value, cachedValue.value))\n cachedValue.value = value;\n }, watchOptions);\n return cachedValue;\n}\n\nfunction usePermission(permissionDesc, options = {}) {\n const {\n controls = false,\n navigator = defaultNavigator\n } = options;\n const isSupported = useSupported(() => navigator && \"permissions\" in navigator);\n const permissionStatus = shallowRef();\n const desc = typeof permissionDesc === \"string\" ? { name: permissionDesc } : permissionDesc;\n const state = shallowRef();\n const update = () => {\n var _a, _b;\n state.value = (_b = (_a = permissionStatus.value) == null ? void 0 : _a.state) != null ? _b : \"prompt\";\n };\n useEventListener(permissionStatus, \"change\", update);\n const query = createSingletonPromise(async () => {\n if (!isSupported.value)\n return;\n if (!permissionStatus.value) {\n try {\n permissionStatus.value = await navigator.permissions.query(desc);\n } catch (e) {\n permissionStatus.value = void 0;\n } finally {\n update();\n }\n }\n if (controls)\n return toRaw(permissionStatus.value);\n });\n query();\n if (controls) {\n return {\n state,\n isSupported,\n query\n };\n } else {\n return state;\n }\n}\n\nfunction useClipboard(options = {}) {\n const {\n navigator = defaultNavigator,\n read = false,\n source,\n copiedDuring = 1500,\n legacy = false\n } = options;\n const isClipboardApiSupported = useSupported(() => navigator && \"clipboard\" in navigator);\n const permissionRead = usePermission(\"clipboard-read\");\n const permissionWrite = usePermission(\"clipboard-write\");\n const isSupported = computed(() => isClipboardApiSupported.value || legacy);\n const text = ref(\"\");\n const copied = ref(false);\n const timeout = useTimeoutFn(() => copied.value = false, copiedDuring);\n function updateText() {\n if (isClipboardApiSupported.value && isAllowed(permissionRead.value)) {\n navigator.clipboard.readText().then((value) => {\n text.value = value;\n });\n } else {\n text.value = legacyRead();\n }\n }\n if (isSupported.value && read)\n useEventListener([\"copy\", \"cut\"], updateText);\n async function copy(value = toValue(source)) {\n if (isSupported.value && value != null) {\n if (isClipboardApiSupported.value && isAllowed(permissionWrite.value))\n await navigator.clipboard.writeText(value);\n else\n legacyCopy(value);\n text.value = value;\n copied.value = true;\n timeout.start();\n }\n }\n function legacyCopy(value) {\n const ta = document.createElement(\"textarea\");\n ta.value = value != null ? value : \"\";\n ta.style.position = \"absolute\";\n ta.style.opacity = \"0\";\n document.body.appendChild(ta);\n ta.select();\n document.execCommand(\"copy\");\n ta.remove();\n }\n function legacyRead() {\n var _a, _b, _c;\n return (_c = (_b = (_a = document == null ? void 0 : document.getSelection) == null ? void 0 : _a.call(document)) == null ? void 0 : _b.toString()) != null ? _c : \"\";\n }\n function isAllowed(status) {\n return status === \"granted\" || status === \"prompt\";\n }\n return {\n isSupported,\n text,\n copied,\n copy\n };\n}\n\nfunction useClipboardItems(options = {}) {\n const {\n navigator = defaultNavigator,\n read = false,\n source,\n copiedDuring = 1500\n } = options;\n const isSupported = useSupported(() => navigator && \"clipboard\" in navigator);\n const content = ref([]);\n const copied = ref(false);\n const timeout = useTimeoutFn(() => copied.value = false, copiedDuring);\n function updateContent() {\n if (isSupported.value) {\n navigator.clipboard.read().then((items) => {\n content.value = items;\n });\n }\n }\n if (isSupported.value && read)\n useEventListener([\"copy\", \"cut\"], updateContent);\n async function copy(value = toValue(source)) {\n if (isSupported.value && value != null) {\n await navigator.clipboard.write(value);\n content.value = value;\n copied.value = true;\n timeout.start();\n }\n }\n return {\n isSupported,\n content,\n copied,\n copy\n };\n}\n\nfunction cloneFnJSON(source) {\n return JSON.parse(JSON.stringify(source));\n}\nfunction useCloned(source, options = {}) {\n const cloned = ref({});\n const {\n manual,\n clone = cloneFnJSON,\n // watch options\n deep = true,\n immediate = true\n } = options;\n function sync() {\n cloned.value = clone(toValue(source));\n }\n if (!manual && (isRef(source) || typeof source === \"function\")) {\n watch(source, sync, {\n ...options,\n deep,\n immediate\n });\n } else {\n sync();\n }\n return { cloned, sync };\n}\n\nconst _global = typeof globalThis !== \"undefined\" ? globalThis : typeof window !== \"undefined\" ? window : typeof global !== \"undefined\" ? global : typeof self !== \"undefined\" ? self : {};\nconst globalKey = \"__vueuse_ssr_handlers__\";\nconst handlers = /* @__PURE__ */ getHandlers();\nfunction getHandlers() {\n if (!(globalKey in _global))\n _global[globalKey] = _global[globalKey] || {};\n return _global[globalKey];\n}\nfunction getSSRHandler(key, fallback) {\n return handlers[key] || fallback;\n}\nfunction setSSRHandler(key, fn) {\n handlers[key] = fn;\n}\n\nfunction usePreferredDark(options) {\n return useMediaQuery(\"(prefers-color-scheme: dark)\", options);\n}\n\nfunction guessSerializerType(rawInit) {\n return rawInit == null ? \"any\" : rawInit instanceof Set ? \"set\" : rawInit instanceof Map ? \"map\" : rawInit instanceof Date ? \"date\" : typeof rawInit === \"boolean\" ? \"boolean\" : typeof rawInit === \"string\" ? \"string\" : typeof rawInit === \"object\" ? \"object\" : !Number.isNaN(rawInit) ? \"number\" : \"any\";\n}\n\nconst StorageSerializers = {\n boolean: {\n read: (v) => v === \"true\",\n write: (v) => String(v)\n },\n object: {\n read: (v) => JSON.parse(v),\n write: (v) => JSON.stringify(v)\n },\n number: {\n read: (v) => Number.parseFloat(v),\n write: (v) => String(v)\n },\n any: {\n read: (v) => v,\n write: (v) => String(v)\n },\n string: {\n read: (v) => v,\n write: (v) => String(v)\n },\n map: {\n read: (v) => new Map(JSON.parse(v)),\n write: (v) => JSON.stringify(Array.from(v.entries()))\n },\n set: {\n read: (v) => new Set(JSON.parse(v)),\n write: (v) => JSON.stringify(Array.from(v))\n },\n date: {\n read: (v) => new Date(v),\n write: (v) => v.toISOString()\n }\n};\nconst customStorageEventName = \"vueuse-storage\";\nfunction useStorage(key, defaults, storage, options = {}) {\n var _a;\n const {\n flush = \"pre\",\n deep = true,\n listenToStorageChanges = true,\n writeDefaults = true,\n mergeDefaults = false,\n shallow,\n window = defaultWindow,\n eventFilter,\n onError = (e) => {\n console.error(e);\n },\n initOnMounted\n } = options;\n const data = (shallow ? shallowRef : ref)(typeof defaults === \"function\" ? defaults() : defaults);\n if (!storage) {\n try {\n storage = getSSRHandler(\"getDefaultStorage\", () => {\n var _a2;\n return (_a2 = defaultWindow) == null ? void 0 : _a2.localStorage;\n })();\n } catch (e) {\n onError(e);\n }\n }\n if (!storage)\n return data;\n const rawInit = toValue(defaults);\n const type = guessSerializerType(rawInit);\n const serializer = (_a = options.serializer) != null ? _a : StorageSerializers[type];\n const { pause: pauseWatch, resume: resumeWatch } = pausableWatch(\n data,\n () => write(data.value),\n { flush, deep, eventFilter }\n );\n if (window && listenToStorageChanges) {\n tryOnMounted(() => {\n if (storage instanceof Storage)\n useEventListener(window, \"storage\", update);\n else\n useEventListener(window, customStorageEventName, updateFromCustomEvent);\n if (initOnMounted)\n update();\n });\n }\n if (!initOnMounted)\n update();\n function dispatchWriteEvent(oldValue, newValue) {\n if (window) {\n const payload = {\n key,\n oldValue,\n newValue,\n storageArea: storage\n };\n window.dispatchEvent(storage instanceof Storage ? new StorageEvent(\"storage\", payload) : new CustomEvent(customStorageEventName, {\n detail: payload\n }));\n }\n }\n function write(v) {\n try {\n const oldValue = storage.getItem(key);\n if (v == null) {\n dispatchWriteEvent(oldValue, null);\n storage.removeItem(key);\n } else {\n const serialized = serializer.write(v);\n if (oldValue !== serialized) {\n storage.setItem(key, serialized);\n dispatchWriteEvent(oldValue, serialized);\n }\n }\n } catch (e) {\n onError(e);\n }\n }\n function read(event) {\n const rawValue = event ? event.newValue : storage.getItem(key);\n if (rawValue == null) {\n if (writeDefaults && rawInit != null)\n storage.setItem(key, serializer.write(rawInit));\n return rawInit;\n } else if (!event && mergeDefaults) {\n const value = serializer.read(rawValue);\n if (typeof mergeDefaults === \"function\")\n return mergeDefaults(value, rawInit);\n else if (type === \"object\" && !Array.isArray(value))\n return { ...rawInit, ...value };\n return value;\n } else if (typeof rawValue !== \"string\") {\n return rawValue;\n } else {\n return serializer.read(rawValue);\n }\n }\n function update(event) {\n if (event && event.storageArea !== storage)\n return;\n if (event && event.key == null) {\n data.value = rawInit;\n return;\n }\n if (event && event.key !== key)\n return;\n pauseWatch();\n try {\n if ((event == null ? void 0 : event.newValue) !== serializer.write(data.value))\n data.value = read(event);\n } catch (e) {\n onError(e);\n } finally {\n if (event)\n nextTick(resumeWatch);\n else\n resumeWatch();\n }\n }\n function updateFromCustomEvent(event) {\n update(event.detail);\n }\n return data;\n}\n\nconst CSS_DISABLE_TRANS = \"*,*::before,*::after{-webkit-transition:none!important;-moz-transition:none!important;-o-transition:none!important;-ms-transition:none!important;transition:none!important}\";\nfunction useColorMode(options = {}) {\n const {\n selector = \"html\",\n attribute = \"class\",\n initialValue = \"auto\",\n window = defaultWindow,\n storage,\n storageKey = \"vueuse-color-scheme\",\n listenToStorageChanges = true,\n storageRef,\n emitAuto,\n disableTransition = true\n } = options;\n const modes = {\n auto: \"\",\n light: \"light\",\n dark: \"dark\",\n ...options.modes || {}\n };\n const preferredDark = usePreferredDark({ window });\n const system = computed(() => preferredDark.value ? \"dark\" : \"light\");\n const store = storageRef || (storageKey == null ? toRef(initialValue) : useStorage(storageKey, initialValue, storage, { window, listenToStorageChanges }));\n const state = computed(() => store.value === \"auto\" ? system.value : store.value);\n const updateHTMLAttrs = getSSRHandler(\n \"updateHTMLAttrs\",\n (selector2, attribute2, value) => {\n const el = typeof selector2 === \"string\" ? window == null ? void 0 : window.document.querySelector(selector2) : unrefElement(selector2);\n if (!el)\n return;\n const classesToAdd = /* @__PURE__ */ new Set();\n const classesToRemove = /* @__PURE__ */ new Set();\n let attributeToChange = null;\n if (attribute2 === \"class\") {\n const current = value.split(/\\s/g);\n Object.values(modes).flatMap((i) => (i || \"\").split(/\\s/g)).filter(Boolean).forEach((v) => {\n if (current.includes(v))\n classesToAdd.add(v);\n else\n classesToRemove.add(v);\n });\n } else {\n attributeToChange = { key: attribute2, value };\n }\n if (classesToAdd.size === 0 && classesToRemove.size === 0 && attributeToChange === null)\n return;\n let style;\n if (disableTransition) {\n style = window.document.createElement(\"style\");\n style.appendChild(document.createTextNode(CSS_DISABLE_TRANS));\n window.document.head.appendChild(style);\n }\n for (const c of classesToAdd) {\n el.classList.add(c);\n }\n for (const c of classesToRemove) {\n el.classList.remove(c);\n }\n if (attributeToChange) {\n el.setAttribute(attributeToChange.key, attributeToChange.value);\n }\n if (disableTransition) {\n window.getComputedStyle(style).opacity;\n document.head.removeChild(style);\n }\n }\n );\n function defaultOnChanged(mode) {\n var _a;\n updateHTMLAttrs(selector, attribute, (_a = modes[mode]) != null ? _a : mode);\n }\n function onChanged(mode) {\n if (options.onChanged)\n options.onChanged(mode, defaultOnChanged);\n else\n defaultOnChanged(mode);\n }\n watch(state, onChanged, { flush: \"post\", immediate: true });\n tryOnMounted(() => onChanged(state.value));\n const auto = computed({\n get() {\n return emitAuto ? store.value : state.value;\n },\n set(v) {\n store.value = v;\n }\n });\n return Object.assign(auto, { store, system, state });\n}\n\nfunction useConfirmDialog(revealed = ref(false)) {\n const confirmHook = createEventHook();\n const cancelHook = createEventHook();\n const revealHook = createEventHook();\n let _resolve = noop;\n const reveal = (data) => {\n revealHook.trigger(data);\n revealed.value = true;\n return new Promise((resolve) => {\n _resolve = resolve;\n });\n };\n const confirm = (data) => {\n revealed.value = false;\n confirmHook.trigger(data);\n _resolve({ data, isCanceled: false });\n };\n const cancel = (data) => {\n revealed.value = false;\n cancelHook.trigger(data);\n _resolve({ data, isCanceled: true });\n };\n return {\n isRevealed: computed(() => revealed.value),\n reveal,\n confirm,\n cancel,\n onReveal: revealHook.on,\n onConfirm: confirmHook.on,\n onCancel: cancelHook.on\n };\n}\n\nfunction useCssVar(prop, target, options = {}) {\n const { window = defaultWindow, initialValue, observe = false } = options;\n const variable = ref(initialValue);\n const elRef = computed(() => {\n var _a;\n return unrefElement(target) || ((_a = window == null ? void 0 : window.document) == null ? void 0 : _a.documentElement);\n });\n function updateCssVar() {\n var _a;\n const key = toValue(prop);\n const el = toValue(elRef);\n if (el && window && key) {\n const value = (_a = window.getComputedStyle(el).getPropertyValue(key)) == null ? void 0 : _a.trim();\n variable.value = value || initialValue;\n }\n }\n if (observe) {\n useMutationObserver(elRef, updateCssVar, {\n attributeFilter: [\"style\", \"class\"],\n window\n });\n }\n watch(\n [elRef, () => toValue(prop)],\n (_, old) => {\n if (old[0] && old[1])\n old[0].style.removeProperty(old[1]);\n updateCssVar();\n },\n { immediate: true }\n );\n watch(\n variable,\n (val) => {\n var _a;\n const raw_prop = toValue(prop);\n if (((_a = elRef.value) == null ? void 0 : _a.style) && raw_prop) {\n if (val == null)\n elRef.value.style.removeProperty(raw_prop);\n else\n elRef.value.style.setProperty(raw_prop, val);\n }\n }\n );\n return variable;\n}\n\nfunction useCurrentElement(rootComponent) {\n const vm = getCurrentInstance();\n const currentElement = computedWithControl(\n () => null,\n () => rootComponent ? unrefElement(rootComponent) : vm.proxy.$el\n );\n onUpdated(currentElement.trigger);\n onMounted(currentElement.trigger);\n return currentElement;\n}\n\nfunction useCycleList(list, options) {\n const state = shallowRef(getInitialValue());\n const listRef = toRef(list);\n const index = computed({\n get() {\n var _a;\n const targetList = listRef.value;\n let index2 = (options == null ? void 0 : options.getIndexOf) ? options.getIndexOf(state.value, targetList) : targetList.indexOf(state.value);\n if (index2 < 0)\n index2 = (_a = options == null ? void 0 : options.fallbackIndex) != null ? _a : 0;\n return index2;\n },\n set(v) {\n set(v);\n }\n });\n function set(i) {\n const targetList = listRef.value;\n const length = targetList.length;\n const index2 = (i % length + length) % length;\n const value = targetList[index2];\n state.value = value;\n return value;\n }\n function shift(delta = 1) {\n return set(index.value + delta);\n }\n function next(n = 1) {\n return shift(n);\n }\n function prev(n = 1) {\n return shift(-n);\n }\n function getInitialValue() {\n var _a, _b;\n return (_b = toValue((_a = options == null ? void 0 : options.initialValue) != null ? _a : toValue(list)[0])) != null ? _b : void 0;\n }\n watch(listRef, () => set(index.value));\n return {\n state,\n index,\n next,\n prev,\n go: set\n };\n}\n\nfunction useDark(options = {}) {\n const {\n valueDark = \"dark\",\n valueLight = \"\"\n } = options;\n const mode = useColorMode({\n ...options,\n onChanged: (mode2, defaultHandler) => {\n var _a;\n if (options.onChanged)\n (_a = options.onChanged) == null ? void 0 : _a.call(options, mode2 === \"dark\", defaultHandler, mode2);\n else\n defaultHandler(mode2);\n },\n modes: {\n dark: valueDark,\n light: valueLight\n }\n });\n const system = computed(() => mode.system.value);\n const isDark = computed({\n get() {\n return mode.value === \"dark\";\n },\n set(v) {\n const modeVal = v ? \"dark\" : \"light\";\n if (system.value === modeVal)\n mode.value = \"auto\";\n else\n mode.value = modeVal;\n }\n });\n return isDark;\n}\n\nfunction fnBypass(v) {\n return v;\n}\nfunction fnSetSource(source, value) {\n return source.value = value;\n}\nfunction defaultDump(clone) {\n return clone ? typeof clone === \"function\" ? clone : cloneFnJSON : fnBypass;\n}\nfunction defaultParse(clone) {\n return clone ? typeof clone === \"function\" ? clone : cloneFnJSON : fnBypass;\n}\nfunction useManualRefHistory(source, options = {}) {\n const {\n clone = false,\n dump = defaultDump(clone),\n parse = defaultParse(clone),\n setSource = fnSetSource\n } = options;\n function _createHistoryRecord() {\n return markRaw({\n snapshot: dump(source.value),\n timestamp: timestamp()\n });\n }\n const last = ref(_createHistoryRecord());\n const undoStack = ref([]);\n const redoStack = ref([]);\n const _setSource = (record) => {\n setSource(source, parse(record.snapshot));\n last.value = record;\n };\n const commit = () => {\n undoStack.value.unshift(last.value);\n last.value = _createHistoryRecord();\n if (options.capacity && undoStack.value.length > options.capacity)\n undoStack.value.splice(options.capacity, Number.POSITIVE_INFINITY);\n if (redoStack.value.length)\n redoStack.value.splice(0, redoStack.value.length);\n };\n const clear = () => {\n undoStack.value.splice(0, undoStack.value.length);\n redoStack.value.splice(0, redoStack.value.length);\n };\n const undo = () => {\n const state = undoStack.value.shift();\n if (state) {\n redoStack.value.unshift(last.value);\n _setSource(state);\n }\n };\n const redo = () => {\n const state = redoStack.value.shift();\n if (state) {\n undoStack.value.unshift(last.value);\n _setSource(state);\n }\n };\n const reset = () => {\n _setSource(last.value);\n };\n const history = computed(() => [last.value, ...undoStack.value]);\n const canUndo = computed(() => undoStack.value.length > 0);\n const canRedo = computed(() => redoStack.value.length > 0);\n return {\n source,\n undoStack,\n redoStack,\n last,\n history,\n canUndo,\n canRedo,\n clear,\n commit,\n reset,\n undo,\n redo\n };\n}\n\nfunction useRefHistory(source, options = {}) {\n const {\n deep = false,\n flush = \"pre\",\n eventFilter\n } = options;\n const {\n eventFilter: composedFilter,\n pause,\n resume: resumeTracking,\n isActive: isTracking\n } = pausableFilter(eventFilter);\n const {\n ignoreUpdates,\n ignorePrevAsyncUpdates,\n stop\n } = watchIgnorable(\n source,\n commit,\n { deep, flush, eventFilter: composedFilter }\n );\n function setSource(source2, value) {\n ignorePrevAsyncUpdates();\n ignoreUpdates(() => {\n source2.value = value;\n });\n }\n const manualHistory = useManualRefHistory(source, { ...options, clone: options.clone || deep, setSource });\n const { clear, commit: manualCommit } = manualHistory;\n function commit() {\n ignorePrevAsyncUpdates();\n manualCommit();\n }\n function resume(commitNow) {\n resumeTracking();\n if (commitNow)\n commit();\n }\n function batch(fn) {\n let canceled = false;\n const cancel = () => canceled = true;\n ignoreUpdates(() => {\n fn(cancel);\n });\n if (!canceled)\n commit();\n }\n function dispose() {\n stop();\n clear();\n }\n return {\n ...manualHistory,\n isTracking,\n pause,\n resume,\n commit,\n batch,\n dispose\n };\n}\n\nfunction useDebouncedRefHistory(source, options = {}) {\n const filter = options.debounce ? debounceFilter(options.debounce) : void 0;\n const history = useRefHistory(source, { ...options, eventFilter: filter });\n return {\n ...history\n };\n}\n\nfunction useDeviceMotion(options = {}) {\n const {\n window = defaultWindow,\n eventFilter = bypassFilter\n } = options;\n const acceleration = ref({ x: null, y: null, z: null });\n const rotationRate = ref({ alpha: null, beta: null, gamma: null });\n const interval = ref(0);\n const accelerationIncludingGravity = ref({\n x: null,\n y: null,\n z: null\n });\n if (window) {\n const onDeviceMotion = createFilterWrapper(\n eventFilter,\n (event) => {\n acceleration.value = event.acceleration;\n accelerationIncludingGravity.value = event.accelerationIncludingGravity;\n rotationRate.value = event.rotationRate;\n interval.value = event.interval;\n }\n );\n useEventListener(window, \"devicemotion\", onDeviceMotion);\n }\n return {\n acceleration,\n accelerationIncludingGravity,\n rotationRate,\n interval\n };\n}\n\nfunction useDeviceOrientation(options = {}) {\n const { window = defaultWindow } = options;\n const isSupported = useSupported(() => window && \"DeviceOrientationEvent\" in window);\n const isAbsolute = ref(false);\n const alpha = ref(null);\n const beta = ref(null);\n const gamma = ref(null);\n if (window && isSupported.value) {\n useEventListener(window, \"deviceorientation\", (event) => {\n isAbsolute.value = event.absolute;\n alpha.value = event.alpha;\n beta.value = event.beta;\n gamma.value = event.gamma;\n });\n }\n return {\n isSupported,\n isAbsolute,\n alpha,\n beta,\n gamma\n };\n}\n\nfunction useDevicePixelRatio(options = {}) {\n const {\n window = defaultWindow\n } = options;\n const pixelRatio = ref(1);\n if (window) {\n let observe2 = function() {\n pixelRatio.value = window.devicePixelRatio;\n cleanup2();\n media = window.matchMedia(`(resolution: ${pixelRatio.value}dppx)`);\n media.addEventListener(\"change\", observe2, { once: true });\n }, cleanup2 = function() {\n media == null ? void 0 : media.removeEventListener(\"change\", observe2);\n };\n let media;\n observe2();\n tryOnScopeDispose(cleanup2);\n }\n return { pixelRatio };\n}\n\nfunction useDevicesList(options = {}) {\n const {\n navigator = defaultNavigator,\n requestPermissions = false,\n constraints = { audio: true, video: true },\n onUpdated\n } = options;\n const devices = ref([]);\n const videoInputs = computed(() => devices.value.filter((i) => i.kind === \"videoinput\"));\n const audioInputs = computed(() => devices.value.filter((i) => i.kind === \"audioinput\"));\n const audioOutputs = computed(() => devices.value.filter((i) => i.kind === \"audiooutput\"));\n const isSupported = useSupported(() => navigator && navigator.mediaDevices && navigator.mediaDevices.enumerateDevices);\n const permissionGranted = ref(false);\n let stream;\n async function update() {\n if (!isSupported.value)\n return;\n devices.value = await navigator.mediaDevices.enumerateDevices();\n onUpdated == null ? void 0 : onUpdated(devices.value);\n if (stream) {\n stream.getTracks().forEach((t) => t.stop());\n stream = null;\n }\n }\n async function ensurePermissions() {\n if (!isSupported.value)\n return false;\n if (permissionGranted.value)\n return true;\n const { state, query } = usePermission(\"camera\", { controls: true });\n await query();\n if (state.value !== \"granted\") {\n let granted = true;\n try {\n stream = await navigator.mediaDevices.getUserMedia(constraints);\n } catch (e) {\n stream = null;\n granted = false;\n }\n update();\n permissionGranted.value = granted;\n } else {\n permissionGranted.value = true;\n }\n return permissionGranted.value;\n }\n if (isSupported.value) {\n if (requestPermissions)\n ensurePermissions();\n useEventListener(navigator.mediaDevices, \"devicechange\", update);\n update();\n }\n return {\n devices,\n ensurePermissions,\n permissionGranted,\n videoInputs,\n audioInputs,\n audioOutputs,\n isSupported\n };\n}\n\nfunction useDisplayMedia(options = {}) {\n var _a;\n const enabled = ref((_a = options.enabled) != null ? _a : false);\n const video = options.video;\n const audio = options.audio;\n const { navigator = defaultNavigator } = options;\n const isSupported = useSupported(() => {\n var _a2;\n return (_a2 = navigator == null ? void 0 : navigator.mediaDevices) == null ? void 0 : _a2.getDisplayMedia;\n });\n const constraint = { audio, video };\n const stream = shallowRef();\n async function _start() {\n var _a2;\n if (!isSupported.value || stream.value)\n return;\n stream.value = await navigator.mediaDevices.getDisplayMedia(constraint);\n (_a2 = stream.value) == null ? void 0 : _a2.getTracks().forEach((t) => t.addEventListener(\"ended\", stop));\n return stream.value;\n }\n async function _stop() {\n var _a2;\n (_a2 = stream.value) == null ? void 0 : _a2.getTracks().forEach((t) => t.stop());\n stream.value = void 0;\n }\n function stop() {\n _stop();\n enabled.value = false;\n }\n async function start() {\n await _start();\n if (stream.value)\n enabled.value = true;\n return stream.value;\n }\n watch(\n enabled,\n (v) => {\n if (v)\n _start();\n else\n _stop();\n },\n { immediate: true }\n );\n return {\n isSupported,\n stream,\n start,\n stop,\n enabled\n };\n}\n\nfunction useDocumentVisibility(options = {}) {\n const { document = defaultDocument } = options;\n if (!document)\n return ref(\"visible\");\n const visibility = ref(document.visibilityState);\n useEventListener(document, \"visibilitychange\", () => {\n visibility.value = document.visibilityState;\n });\n return visibility;\n}\n\nfunction useDraggable(target, options = {}) {\n var _a, _b;\n const {\n pointerTypes,\n preventDefault,\n stopPropagation,\n exact,\n onMove,\n onEnd,\n onStart,\n initialValue,\n axis = \"both\",\n draggingElement = defaultWindow,\n containerElement,\n handle: draggingHandle = target,\n buttons = [0]\n } = options;\n const position = ref(\n (_a = toValue(initialValue)) != null ? _a : { x: 0, y: 0 }\n );\n const pressedDelta = ref();\n const filterEvent = (e) => {\n if (pointerTypes)\n return pointerTypes.includes(e.pointerType);\n return true;\n };\n const handleEvent = (e) => {\n if (toValue(preventDefault))\n e.preventDefault();\n if (toValue(stopPropagation))\n e.stopPropagation();\n };\n const start = (e) => {\n var _a2;\n if (!toValue(buttons).includes(e.button))\n return;\n if (toValue(options.disabled) || !filterEvent(e))\n return;\n if (toValue(exact) && e.target !== toValue(target))\n return;\n const container = toValue(containerElement);\n const containerRect = (_a2 = container == null ? void 0 : container.getBoundingClientRect) == null ? void 0 : _a2.call(container);\n const targetRect = toValue(target).getBoundingClientRect();\n const pos = {\n x: e.clientX - (container ? targetRect.left - containerRect.left + container.scrollLeft : targetRect.left),\n y: e.clientY - (container ? targetRect.top - containerRect.top + container.scrollTop : targetRect.top)\n };\n if ((onStart == null ? void 0 : onStart(pos, e)) === false)\n return;\n pressedDelta.value = pos;\n handleEvent(e);\n };\n const move = (e) => {\n if (toValue(options.disabled) || !filterEvent(e))\n return;\n if (!pressedDelta.value)\n return;\n const container = toValue(containerElement);\n const targetRect = toValue(target).getBoundingClientRect();\n let { x, y } = position.value;\n if (axis === \"x\" || axis === \"both\") {\n x = e.clientX - pressedDelta.value.x;\n if (container)\n x = Math.min(Math.max(0, x), container.scrollWidth - targetRect.width);\n }\n if (axis === \"y\" || axis === \"both\") {\n y = e.clientY - pressedDelta.value.y;\n if (container)\n y = Math.min(Math.max(0, y), container.scrollHeight - targetRect.height);\n }\n position.value = {\n x,\n y\n };\n onMove == null ? void 0 : onMove(position.value, e);\n handleEvent(e);\n };\n const end = (e) => {\n if (toValue(options.disabled) || !filterEvent(e))\n return;\n if (!pressedDelta.value)\n return;\n pressedDelta.value = void 0;\n onEnd == null ? void 0 : onEnd(position.value, e);\n handleEvent(e);\n };\n if (isClient) {\n const config = { capture: (_b = options.capture) != null ? _b : true };\n useEventListener(draggingHandle, \"pointerdown\", start, config);\n useEventListener(draggingElement, \"pointermove\", move, config);\n useEventListener(draggingElement, \"pointerup\", end, config);\n }\n return {\n ...toRefs(position),\n position,\n isDragging: computed(() => !!pressedDelta.value),\n style: computed(\n () => `left:${position.value.x}px;top:${position.value.y}px;`\n )\n };\n}\n\nfunction useDropZone(target, options = {}) {\n var _a, _b;\n const isOverDropZone = ref(false);\n const files = shallowRef(null);\n let counter = 0;\n let isValid = true;\n if (isClient) {\n const _options = typeof options === \"function\" ? { onDrop: options } : options;\n const multiple = (_a = _options.multiple) != null ? _a : true;\n const preventDefaultForUnhandled = (_b = _options.preventDefaultForUnhandled) != null ? _b : false;\n const getFiles = (event) => {\n var _a2, _b2;\n const list = Array.from((_b2 = (_a2 = event.dataTransfer) == null ? void 0 : _a2.files) != null ? _b2 : []);\n return list.length === 0 ? null : multiple ? list : [list[0]];\n };\n const checkDataTypes = (types) => {\n if (_options.dataTypes) {\n const dataTypes = unref(_options.dataTypes);\n return typeof dataTypes === \"function\" ? dataTypes(types) : dataTypes ? dataTypes.some((item) => types.includes(item)) : true;\n }\n return true;\n };\n const checkValidity = (event) => {\n var _a2, _b2;\n const items = Array.from((_b2 = (_a2 = event.dataTransfer) == null ? void 0 : _a2.items) != null ? _b2 : []);\n const types = items.map((item) => item.type);\n const dataTypesValid = checkDataTypes(types);\n const multipleFilesValid = multiple || items.length <= 1;\n return dataTypesValid && multipleFilesValid;\n };\n const handleDragEvent = (event, eventType) => {\n var _a2, _b2, _c, _d;\n isValid = checkValidity(event);\n if (!isValid) {\n if (preventDefaultForUnhandled) {\n event.preventDefault();\n }\n if (event.dataTransfer) {\n event.dataTransfer.dropEffect = \"none\";\n }\n return;\n }\n event.preventDefault();\n if (event.dataTransfer) {\n event.dataTransfer.dropEffect = \"copy\";\n }\n const currentFiles = getFiles(event);\n switch (eventType) {\n case \"enter\":\n counter += 1;\n isOverDropZone.value = true;\n (_a2 = _options.onEnter) == null ? void 0 : _a2.call(_options, null, event);\n break;\n case \"over\":\n (_b2 = _options.onOver) == null ? void 0 : _b2.call(_options, null, event);\n break;\n case \"leave\":\n counter -= 1;\n if (counter === 0)\n isOverDropZone.value = false;\n (_c = _options.onLeave) == null ? void 0 : _c.call(_options, null, event);\n break;\n case \"drop\":\n counter = 0;\n isOverDropZone.value = false;\n if (isValid) {\n files.value = currentFiles;\n (_d = _options.onDrop) == null ? void 0 : _d.call(_options, currentFiles, event);\n }\n break;\n }\n };\n useEventListener(target, \"dragenter\", (event) => handleDragEvent(event, \"enter\"));\n useEventListener(target, \"dragover\", (event) => handleDragEvent(event, \"over\"));\n useEventListener(target, \"dragleave\", (event) => handleDragEvent(event, \"leave\"));\n useEventListener(target, \"drop\", (event) => handleDragEvent(event, \"drop\"));\n }\n return {\n files,\n isOverDropZone\n };\n}\n\nfunction useResizeObserver(target, callback, options = {}) {\n const { window = defaultWindow, ...observerOptions } = options;\n let observer;\n const isSupported = useSupported(() => window && \"ResizeObserver\" in window);\n const cleanup = () => {\n if (observer) {\n observer.disconnect();\n observer = void 0;\n }\n };\n const targets = computed(() => {\n const _targets = toValue(target);\n return Array.isArray(_targets) ? _targets.map((el) => unrefElement(el)) : [unrefElement(_targets)];\n });\n const stopWatch = watch(\n targets,\n (els) => {\n cleanup();\n if (isSupported.value && window) {\n observer = new ResizeObserver(callback);\n for (const _el of els) {\n if (_el)\n observer.observe(_el, observerOptions);\n }\n }\n },\n { immediate: true, flush: \"post\" }\n );\n const stop = () => {\n cleanup();\n stopWatch();\n };\n tryOnScopeDispose(stop);\n return {\n isSupported,\n stop\n };\n}\n\nfunction useElementBounding(target, options = {}) {\n const {\n reset = true,\n windowResize = true,\n windowScroll = true,\n immediate = true,\n updateTiming = \"sync\"\n } = options;\n const height = ref(0);\n const bottom = ref(0);\n const left = ref(0);\n const right = ref(0);\n const top = ref(0);\n const width = ref(0);\n const x = ref(0);\n const y = ref(0);\n function recalculate() {\n const el = unrefElement(target);\n if (!el) {\n if (reset) {\n height.value = 0;\n bottom.value = 0;\n left.value = 0;\n right.value = 0;\n top.value = 0;\n width.value = 0;\n x.value = 0;\n y.value = 0;\n }\n return;\n }\n const rect = el.getBoundingClientRect();\n height.value = rect.height;\n bottom.value = rect.bottom;\n left.value = rect.left;\n right.value = rect.right;\n top.value = rect.top;\n width.value = rect.width;\n x.value = rect.x;\n y.value = rect.y;\n }\n function update() {\n if (updateTiming === \"sync\")\n recalculate();\n else if (updateTiming === \"next-frame\")\n requestAnimationFrame(() => recalculate());\n }\n useResizeObserver(target, update);\n watch(() => unrefElement(target), (ele) => !ele && update());\n useMutationObserver(target, update, {\n attributeFilter: [\"style\", \"class\"]\n });\n if (windowScroll)\n useEventListener(\"scroll\", update, { capture: true, passive: true });\n if (windowResize)\n useEventListener(\"resize\", update, { passive: true });\n tryOnMounted(() => {\n if (immediate)\n update();\n });\n return {\n height,\n bottom,\n left,\n right,\n top,\n width,\n x,\n y,\n update\n };\n}\n\nfunction useElementByPoint(options) {\n const {\n x,\n y,\n document = defaultDocument,\n multiple,\n interval = \"requestAnimationFrame\",\n immediate = true\n } = options;\n const isSupported = useSupported(() => {\n if (toValue(multiple))\n return document && \"elementsFromPoint\" in document;\n return document && \"elementFromPoint\" in document;\n });\n const element = ref(null);\n const cb = () => {\n var _a, _b;\n element.value = toValue(multiple) ? (_a = document == null ? void 0 : document.elementsFromPoint(toValue(x), toValue(y))) != null ? _a : [] : (_b = document == null ? void 0 : document.elementFromPoint(toValue(x), toValue(y))) != null ? _b : null;\n };\n const controls = interval === \"requestAnimationFrame\" ? useRafFn(cb, { immediate }) : useIntervalFn(cb, interval, { immediate });\n return {\n isSupported,\n element,\n ...controls\n };\n}\n\nfunction useElementHover(el, options = {}) {\n const {\n delayEnter = 0,\n delayLeave = 0,\n window = defaultWindow\n } = options;\n const isHovered = ref(false);\n let timer;\n const toggle = (entering) => {\n const delay = entering ? delayEnter : delayLeave;\n if (timer) {\n clearTimeout(timer);\n timer = void 0;\n }\n if (delay)\n timer = setTimeout(() => isHovered.value = entering, delay);\n else\n isHovered.value = entering;\n };\n if (!window)\n return isHovered;\n useEventListener(el, \"mouseenter\", () => toggle(true), { passive: true });\n useEventListener(el, \"mouseleave\", () => toggle(false), { passive: true });\n return isHovered;\n}\n\nfunction useElementSize(target, initialSize = { width: 0, height: 0 }, options = {}) {\n const { window = defaultWindow, box = \"content-box\" } = options;\n const isSVG = computed(() => {\n var _a, _b;\n return (_b = (_a = unrefElement(target)) == null ? void 0 : _a.namespaceURI) == null ? void 0 : _b.includes(\"svg\");\n });\n const width = ref(initialSize.width);\n const height = ref(initialSize.height);\n const { stop: stop1 } = useResizeObserver(\n target,\n ([entry]) => {\n const boxSize = box === \"border-box\" ? entry.borderBoxSize : box === \"content-box\" ? entry.contentBoxSize : entry.devicePixelContentBoxSize;\n if (window && isSVG.value) {\n const $elem = unrefElement(target);\n if ($elem) {\n const rect = $elem.getBoundingClientRect();\n width.value = rect.width;\n height.value = rect.height;\n }\n } else {\n if (boxSize) {\n const formatBoxSize = Array.isArray(boxSize) ? boxSize : [boxSize];\n width.value = formatBoxSize.reduce((acc, { inlineSize }) => acc + inlineSize, 0);\n height.value = formatBoxSize.reduce((acc, { blockSize }) => acc + blockSize, 0);\n } else {\n width.value = entry.contentRect.width;\n height.value = entry.contentRect.height;\n }\n }\n },\n options\n );\n tryOnMounted(() => {\n const ele = unrefElement(target);\n if (ele) {\n width.value = \"offsetWidth\" in ele ? ele.offsetWidth : initialSize.width;\n height.value = \"offsetHeight\" in ele ? ele.offsetHeight : initialSize.height;\n }\n });\n const stop2 = watch(\n () => unrefElement(target),\n (ele) => {\n width.value = ele ? initialSize.width : 0;\n height.value = ele ? initialSize.height : 0;\n }\n );\n function stop() {\n stop1();\n stop2();\n }\n return {\n width,\n height,\n stop\n };\n}\n\nfunction useIntersectionObserver(target, callback, options = {}) {\n const {\n root,\n rootMargin = \"0px\",\n threshold = 0,\n window = defaultWindow,\n immediate = true\n } = options;\n const isSupported = useSupported(() => window && \"IntersectionObserver\" in window);\n const targets = computed(() => {\n const _target = toValue(target);\n return (Array.isArray(_target) ? _target : [_target]).map(unrefElement).filter(notNullish);\n });\n let cleanup = noop;\n const isActive = ref(immediate);\n const stopWatch = isSupported.value ? watch(\n () => [targets.value, unrefElement(root), isActive.value],\n ([targets2, root2]) => {\n cleanup();\n if (!isActive.value)\n return;\n if (!targets2.length)\n return;\n const observer = new IntersectionObserver(\n callback,\n {\n root: unrefElement(root2),\n rootMargin,\n threshold\n }\n );\n targets2.forEach((el) => el && observer.observe(el));\n cleanup = () => {\n observer.disconnect();\n cleanup = noop;\n };\n },\n { immediate, flush: \"post\" }\n ) : noop;\n const stop = () => {\n cleanup();\n stopWatch();\n isActive.value = false;\n };\n tryOnScopeDispose(stop);\n return {\n isSupported,\n isActive,\n pause() {\n cleanup();\n isActive.value = false;\n },\n resume() {\n isActive.value = true;\n },\n stop\n };\n}\n\nfunction useElementVisibility(element, options = {}) {\n const { window = defaultWindow, scrollTarget, threshold = 0 } = options;\n const elementIsVisible = ref(false);\n useIntersectionObserver(\n element,\n (intersectionObserverEntries) => {\n let isIntersecting = elementIsVisible.value;\n let latestTime = 0;\n for (const entry of intersectionObserverEntries) {\n if (entry.time >= latestTime) {\n latestTime = entry.time;\n isIntersecting = entry.isIntersecting;\n }\n }\n elementIsVisible.value = isIntersecting;\n },\n {\n root: scrollTarget,\n window,\n threshold\n }\n );\n return elementIsVisible;\n}\n\nconst events = /* @__PURE__ */ new Map();\n\nfunction useEventBus(key) {\n const scope = getCurrentScope();\n function on(listener) {\n var _a;\n const listeners = events.get(key) || /* @__PURE__ */ new Set();\n listeners.add(listener);\n events.set(key, listeners);\n const _off = () => off(listener);\n (_a = scope == null ? void 0 : scope.cleanups) == null ? void 0 : _a.push(_off);\n return _off;\n }\n function once(listener) {\n function _listener(...args) {\n off(_listener);\n listener(...args);\n }\n return on(_listener);\n }\n function off(listener) {\n const listeners = events.get(key);\n if (!listeners)\n return;\n listeners.delete(listener);\n if (!listeners.size)\n reset();\n }\n function reset() {\n events.delete(key);\n }\n function emit(event, payload) {\n var _a;\n (_a = events.get(key)) == null ? void 0 : _a.forEach((v) => v(event, payload));\n }\n return { on, once, off, emit, reset };\n}\n\nfunction resolveNestedOptions$1(options) {\n if (options === true)\n return {};\n return options;\n}\nfunction useEventSource(url, events = [], options = {}) {\n const event = ref(null);\n const data = ref(null);\n const status = ref(\"CONNECTING\");\n const eventSource = ref(null);\n const error = shallowRef(null);\n const urlRef = toRef(url);\n const lastEventId = shallowRef(null);\n let explicitlyClosed = false;\n let retried = 0;\n const {\n withCredentials = false,\n immediate = true\n } = options;\n const close = () => {\n if (isClient && eventSource.value) {\n eventSource.value.close();\n eventSource.value = null;\n status.value = \"CLOSED\";\n explicitlyClosed = true;\n }\n };\n const _init = () => {\n if (explicitlyClosed || typeof urlRef.value === \"undefined\")\n return;\n const es = new EventSource(urlRef.value, { withCredentials });\n status.value = \"CONNECTING\";\n eventSource.value = es;\n es.onopen = () => {\n status.value = \"OPEN\";\n error.value = null;\n };\n es.onerror = (e) => {\n status.value = \"CLOSED\";\n error.value = e;\n if (es.readyState === 2 && !explicitlyClosed && options.autoReconnect) {\n es.close();\n const {\n retries = -1,\n delay = 1e3,\n onFailed\n } = resolveNestedOptions$1(options.autoReconnect);\n retried += 1;\n if (typeof retries === \"number\" && (retries < 0 || retried < retries))\n setTimeout(_init, delay);\n else if (typeof retries === \"function\" && retries())\n setTimeout(_init, delay);\n else\n onFailed == null ? void 0 : onFailed();\n }\n };\n es.onmessage = (e) => {\n event.value = null;\n data.value = e.data;\n lastEventId.value = e.lastEventId;\n };\n for (const event_name of events) {\n useEventListener(es, event_name, (e) => {\n event.value = event_name;\n data.value = e.data || null;\n });\n }\n };\n const open = () => {\n if (!isClient)\n return;\n close();\n explicitlyClosed = false;\n retried = 0;\n _init();\n };\n if (immediate)\n watch(urlRef, open, { immediate: true });\n tryOnScopeDispose(close);\n return {\n eventSource,\n event,\n data,\n status,\n error,\n open,\n close,\n lastEventId\n };\n}\n\nfunction useEyeDropper(options = {}) {\n const { initialValue = \"\" } = options;\n const isSupported = useSupported(() => typeof window !== \"undefined\" && \"EyeDropper\" in window);\n const sRGBHex = ref(initialValue);\n async function open(openOptions) {\n if (!isSupported.value)\n return;\n const eyeDropper = new window.EyeDropper();\n const result = await eyeDropper.open(openOptions);\n sRGBHex.value = result.sRGBHex;\n return result;\n }\n return { isSupported, sRGBHex, open };\n}\n\nfunction useFavicon(newIcon = null, options = {}) {\n const {\n baseUrl = \"\",\n rel = \"icon\",\n document = defaultDocument\n } = options;\n const favicon = toRef(newIcon);\n const applyIcon = (icon) => {\n const elements = document == null ? void 0 : document.head.querySelectorAll(`link[rel*=\"${rel}\"]`);\n if (!elements || elements.length === 0) {\n const link = document == null ? void 0 : document.createElement(\"link\");\n if (link) {\n link.rel = rel;\n link.href = `${baseUrl}${icon}`;\n link.type = `image/${icon.split(\".\").pop()}`;\n document == null ? void 0 : document.head.append(link);\n }\n return;\n }\n elements == null ? void 0 : elements.forEach((el) => el.href = `${baseUrl}${icon}`);\n };\n watch(\n favicon,\n (i, o) => {\n if (typeof i === \"string\" && i !== o)\n applyIcon(i);\n },\n { immediate: true }\n );\n return favicon;\n}\n\nconst payloadMapping = {\n json: \"application/json\",\n text: \"text/plain\"\n};\nfunction isFetchOptions(obj) {\n return obj && containsProp(obj, \"immediate\", \"refetch\", \"initialData\", \"timeout\", \"beforeFetch\", \"afterFetch\", \"onFetchError\", \"fetch\", \"updateDataOnError\");\n}\nconst reAbsolute = /^(?:[a-z][a-z\\d+\\-.]*:)?\\/\\//i;\nfunction isAbsoluteURL(url) {\n return reAbsolute.test(url);\n}\nfunction headersToObject(headers) {\n if (typeof Headers !== \"undefined\" && headers instanceof Headers)\n return Object.fromEntries(headers.entries());\n return headers;\n}\nfunction combineCallbacks(combination, ...callbacks) {\n if (combination === \"overwrite\") {\n return async (ctx) => {\n const callback = callbacks[callbacks.length - 1];\n if (callback)\n return { ...ctx, ...await callback(ctx) };\n return ctx;\n };\n } else {\n return async (ctx) => {\n for (const callback of callbacks) {\n if (callback)\n ctx = { ...ctx, ...await callback(ctx) };\n }\n return ctx;\n };\n }\n}\nfunction createFetch(config = {}) {\n const _combination = config.combination || \"chain\";\n const _options = config.options || {};\n const _fetchOptions = config.fetchOptions || {};\n function useFactoryFetch(url, ...args) {\n const computedUrl = computed(() => {\n const baseUrl = toValue(config.baseUrl);\n const targetUrl = toValue(url);\n return baseUrl && !isAbsoluteURL(targetUrl) ? joinPaths(baseUrl, targetUrl) : targetUrl;\n });\n let options = _options;\n let fetchOptions = _fetchOptions;\n if (args.length > 0) {\n if (isFetchOptions(args[0])) {\n options = {\n ...options,\n ...args[0],\n beforeFetch: combineCallbacks(_combination, _options.beforeFetch, args[0].beforeFetch),\n afterFetch: combineCallbacks(_combination, _options.afterFetch, args[0].afterFetch),\n onFetchError: combineCallbacks(_combination, _options.onFetchError, args[0].onFetchError)\n };\n } else {\n fetchOptions = {\n ...fetchOptions,\n ...args[0],\n headers: {\n ...headersToObject(fetchOptions.headers) || {},\n ...headersToObject(args[0].headers) || {}\n }\n };\n }\n }\n if (args.length > 1 && isFetchOptions(args[1])) {\n options = {\n ...options,\n ...args[1],\n beforeFetch: combineCallbacks(_combination, _options.beforeFetch, args[1].beforeFetch),\n afterFetch: combineCallbacks(_combination, _options.afterFetch, args[1].afterFetch),\n onFetchError: combineCallbacks(_combination, _options.onFetchError, args[1].onFetchError)\n };\n }\n return useFetch(computedUrl, fetchOptions, options);\n }\n return useFactoryFetch;\n}\nfunction useFetch(url, ...args) {\n var _a;\n const supportsAbort = typeof AbortController === \"function\";\n let fetchOptions = {};\n let options = {\n immediate: true,\n refetch: false,\n timeout: 0,\n updateDataOnError: false\n };\n const config = {\n method: \"GET\",\n type: \"text\",\n payload: void 0\n };\n if (args.length > 0) {\n if (isFetchOptions(args[0]))\n options = { ...options, ...args[0] };\n else\n fetchOptions = args[0];\n }\n if (args.length > 1) {\n if (isFetchOptions(args[1]))\n options = { ...options, ...args[1] };\n }\n const {\n fetch = (_a = defaultWindow) == null ? void 0 : _a.fetch,\n initialData,\n timeout\n } = options;\n const responseEvent = createEventHook();\n const errorEvent = createEventHook();\n const finallyEvent = createEventHook();\n const isFinished = ref(false);\n const isFetching = ref(false);\n const aborted = ref(false);\n const statusCode = ref(null);\n const response = shallowRef(null);\n const error = shallowRef(null);\n const data = shallowRef(initialData || null);\n const canAbort = computed(() => supportsAbort && isFetching.value);\n let controller;\n let timer;\n const abort = () => {\n if (supportsAbort) {\n controller == null ? void 0 : controller.abort();\n controller = new AbortController();\n controller.signal.onabort = () => aborted.value = true;\n fetchOptions = {\n ...fetchOptions,\n signal: controller.signal\n };\n }\n };\n const loading = (isLoading) => {\n isFetching.value = isLoading;\n isFinished.value = !isLoading;\n };\n if (timeout)\n timer = useTimeoutFn(abort, timeout, { immediate: false });\n let executeCounter = 0;\n const execute = async (throwOnFailed = false) => {\n var _a2, _b;\n abort();\n loading(true);\n error.value = null;\n statusCode.value = null;\n aborted.value = false;\n executeCounter += 1;\n const currentExecuteCounter = executeCounter;\n const defaultFetchOptions = {\n method: config.method,\n headers: {}\n };\n if (config.payload) {\n const headers = headersToObject(defaultFetchOptions.headers);\n const payload = toValue(config.payload);\n const proto = Object.getPrototypeOf(payload);\n if (!config.payloadType && payload && (proto === Object.prototype || Array.isArray(proto)) && !(payload instanceof FormData))\n config.payloadType = \"json\";\n if (config.payloadType)\n headers[\"Content-Type\"] = (_a2 = payloadMapping[config.payloadType]) != null ? _a2 : config.payloadType;\n defaultFetchOptions.body = config.payloadType === \"json\" ? JSON.stringify(payload) : payload;\n }\n let isCanceled = false;\n const context = {\n url: toValue(url),\n options: {\n ...defaultFetchOptions,\n ...fetchOptions\n },\n cancel: () => {\n isCanceled = true;\n }\n };\n if (options.beforeFetch)\n Object.assign(context, await options.beforeFetch(context));\n if (isCanceled || !fetch) {\n loading(false);\n return Promise.resolve(null);\n }\n let responseData = null;\n if (timer)\n timer.start();\n return fetch(\n context.url,\n {\n ...defaultFetchOptions,\n ...context.options,\n headers: {\n ...headersToObject(defaultFetchOptions.headers),\n ...headersToObject((_b = context.options) == null ? void 0 : _b.headers)\n }\n }\n ).then(async (fetchResponse) => {\n response.value = fetchResponse;\n statusCode.value = fetchResponse.status;\n responseData = await fetchResponse.clone()[config.type]();\n if (!fetchResponse.ok) {\n data.value = initialData || null;\n throw new Error(fetchResponse.statusText);\n }\n if (options.afterFetch) {\n ({ data: responseData } = await options.afterFetch({\n data: responseData,\n response: fetchResponse\n }));\n }\n data.value = responseData;\n responseEvent.trigger(fetchResponse);\n return fetchResponse;\n }).catch(async (fetchError) => {\n let errorData = fetchError.message || fetchError.name;\n if (options.onFetchError) {\n ({ error: errorData, data: responseData } = await options.onFetchError({\n data: responseData,\n error: fetchError,\n response: response.value\n }));\n }\n error.value = errorData;\n if (options.updateDataOnError)\n data.value = responseData;\n errorEvent.trigger(fetchError);\n if (throwOnFailed)\n throw fetchError;\n return null;\n }).finally(() => {\n if (currentExecuteCounter === executeCounter)\n loading(false);\n if (timer)\n timer.stop();\n finallyEvent.trigger(null);\n });\n };\n const refetch = toRef(options.refetch);\n watch(\n [\n refetch,\n toRef(url)\n ],\n ([refetch2]) => refetch2 && execute(),\n { deep: true }\n );\n const shell = {\n isFinished: readonly(isFinished),\n isFetching: readonly(isFetching),\n statusCode,\n response,\n error,\n data,\n canAbort,\n aborted,\n abort,\n execute,\n onFetchResponse: responseEvent.on,\n onFetchError: errorEvent.on,\n onFetchFinally: finallyEvent.on,\n // method\n get: setMethod(\"GET\"),\n put: setMethod(\"PUT\"),\n post: setMethod(\"POST\"),\n delete: setMethod(\"DELETE\"),\n patch: setMethod(\"PATCH\"),\n head: setMethod(\"HEAD\"),\n options: setMethod(\"OPTIONS\"),\n // type\n json: setType(\"json\"),\n text: setType(\"text\"),\n blob: setType(\"blob\"),\n arrayBuffer: setType(\"arrayBuffer\"),\n formData: setType(\"formData\")\n };\n function setMethod(method) {\n return (payload, payloadType) => {\n if (!isFetching.value) {\n config.method = method;\n config.payload = payload;\n config.payloadType = payloadType;\n if (isRef(config.payload)) {\n watch(\n [\n refetch,\n toRef(config.payload)\n ],\n ([refetch2]) => refetch2 && execute(),\n { deep: true }\n );\n }\n return {\n ...shell,\n then(onFulfilled, onRejected) {\n return waitUntilFinished().then(onFulfilled, onRejected);\n }\n };\n }\n return void 0;\n };\n }\n function waitUntilFinished() {\n return new Promise((resolve, reject) => {\n until(isFinished).toBe(true).then(() => resolve(shell)).catch(reject);\n });\n }\n function setType(type) {\n return () => {\n if (!isFetching.value) {\n config.type = type;\n return {\n ...shell,\n then(onFulfilled, onRejected) {\n return waitUntilFinished().then(onFulfilled, onRejected);\n }\n };\n }\n return void 0;\n };\n }\n if (options.immediate)\n Promise.resolve().then(() => execute());\n return {\n ...shell,\n then(onFulfilled, onRejected) {\n return waitUntilFinished().then(onFulfilled, onRejected);\n }\n };\n}\nfunction joinPaths(start, end) {\n if (!start.endsWith(\"/\") && !end.startsWith(\"/\")) {\n return `${start}/${end}`;\n }\n if (start.endsWith(\"/\") && end.startsWith(\"/\")) {\n return `${start.slice(0, -1)}${end}`;\n }\n return `${start}${end}`;\n}\n\nconst DEFAULT_OPTIONS = {\n multiple: true,\n accept: \"*\",\n reset: false,\n directory: false\n};\nfunction useFileDialog(options = {}) {\n const {\n document = defaultDocument\n } = options;\n const files = ref(null);\n const { on: onChange, trigger: changeTrigger } = createEventHook();\n const { on: onCancel, trigger: cancelTrigger } = createEventHook();\n let input;\n if (document) {\n input = document.createElement(\"input\");\n input.type = \"file\";\n input.onchange = (event) => {\n const result = event.target;\n files.value = result.files;\n changeTrigger(files.value);\n };\n input.oncancel = () => {\n cancelTrigger();\n };\n }\n const reset = () => {\n files.value = null;\n if (input && input.value) {\n input.value = \"\";\n changeTrigger(null);\n }\n };\n const open = (localOptions) => {\n if (!input)\n return;\n const _options = {\n ...DEFAULT_OPTIONS,\n ...options,\n ...localOptions\n };\n input.multiple = _options.multiple;\n input.accept = _options.accept;\n input.webkitdirectory = _options.directory;\n if (hasOwn(_options, \"capture\"))\n input.capture = _options.capture;\n if (_options.reset)\n reset();\n input.click();\n };\n return {\n files: readonly(files),\n open,\n reset,\n onCancel,\n onChange\n };\n}\n\nfunction useFileSystemAccess(options = {}) {\n const {\n window: _window = defaultWindow,\n dataType = \"Text\"\n } = options;\n const window = _window;\n const isSupported = useSupported(() => window && \"showSaveFilePicker\" in window && \"showOpenFilePicker\" in window);\n const fileHandle = ref();\n const data = ref();\n const file = ref();\n const fileName = computed(() => {\n var _a, _b;\n return (_b = (_a = file.value) == null ? void 0 : _a.name) != null ? _b : \"\";\n });\n const fileMIME = computed(() => {\n var _a, _b;\n return (_b = (_a = file.value) == null ? void 0 : _a.type) != null ? _b : \"\";\n });\n const fileSize = computed(() => {\n var _a, _b;\n return (_b = (_a = file.value) == null ? void 0 : _a.size) != null ? _b : 0;\n });\n const fileLastModified = computed(() => {\n var _a, _b;\n return (_b = (_a = file.value) == null ? void 0 : _a.lastModified) != null ? _b : 0;\n });\n async function open(_options = {}) {\n if (!isSupported.value)\n return;\n const [handle] = await window.showOpenFilePicker({ ...toValue(options), ..._options });\n fileHandle.value = handle;\n await updateData();\n }\n async function create(_options = {}) {\n if (!isSupported.value)\n return;\n fileHandle.value = await window.showSaveFilePicker({ ...options, ..._options });\n data.value = void 0;\n await updateData();\n }\n async function save(_options = {}) {\n if (!isSupported.value)\n return;\n if (!fileHandle.value)\n return saveAs(_options);\n if (data.value) {\n const writableStream = await fileHandle.value.createWritable();\n await writableStream.write(data.value);\n await writableStream.close();\n }\n await updateFile();\n }\n async function saveAs(_options = {}) {\n if (!isSupported.value)\n return;\n fileHandle.value = await window.showSaveFilePicker({ ...options, ..._options });\n if (data.value) {\n const writableStream = await fileHandle.value.createWritable();\n await writableStream.write(data.value);\n await writableStream.close();\n }\n await updateFile();\n }\n async function updateFile() {\n var _a;\n file.value = await ((_a = fileHandle.value) == null ? void 0 : _a.getFile());\n }\n async function updateData() {\n var _a, _b;\n await updateFile();\n const type = toValue(dataType);\n if (type === \"Text\")\n data.value = await ((_a = file.value) == null ? void 0 : _a.text());\n else if (type === \"ArrayBuffer\")\n data.value = await ((_b = file.value) == null ? void 0 : _b.arrayBuffer());\n else if (type === \"Blob\")\n data.value = file.value;\n }\n watch(() => toValue(dataType), updateData);\n return {\n isSupported,\n data,\n file,\n fileName,\n fileMIME,\n fileSize,\n fileLastModified,\n open,\n create,\n save,\n saveAs,\n updateData\n };\n}\n\nfunction useFocus(target, options = {}) {\n const { initialValue = false, focusVisible = false, preventScroll = false } = options;\n const innerFocused = ref(false);\n const targetElement = computed(() => unrefElement(target));\n useEventListener(targetElement, \"focus\", (event) => {\n var _a, _b;\n if (!focusVisible || ((_b = (_a = event.target).matches) == null ? void 0 : _b.call(_a, \":focus-visible\")))\n innerFocused.value = true;\n });\n useEventListener(targetElement, \"blur\", () => innerFocused.value = false);\n const focused = computed({\n get: () => innerFocused.value,\n set(value) {\n var _a, _b;\n if (!value && innerFocused.value)\n (_a = targetElement.value) == null ? void 0 : _a.blur();\n else if (value && !innerFocused.value)\n (_b = targetElement.value) == null ? void 0 : _b.focus({ preventScroll });\n }\n });\n watch(\n targetElement,\n () => {\n focused.value = initialValue;\n },\n { immediate: true, flush: \"post\" }\n );\n return { focused };\n}\n\nconst EVENT_FOCUS_IN = \"focusin\";\nconst EVENT_FOCUS_OUT = \"focusout\";\nfunction useFocusWithin(target, options = {}) {\n const { window = defaultWindow } = options;\n const targetElement = computed(() => unrefElement(target));\n const _focused = ref(false);\n const focused = computed(() => _focused.value);\n const activeElement = useActiveElement(options);\n if (!window || !activeElement.value) {\n return { focused };\n }\n useEventListener(targetElement, EVENT_FOCUS_IN, () => _focused.value = true);\n useEventListener(targetElement, EVENT_FOCUS_OUT, () => _focused.value = false);\n return { focused };\n}\n\nfunction useFps(options) {\n var _a;\n const fps = ref(0);\n if (typeof performance === \"undefined\")\n return fps;\n const every = (_a = options == null ? void 0 : options.every) != null ? _a : 10;\n let last = performance.now();\n let ticks = 0;\n useRafFn(() => {\n ticks += 1;\n if (ticks >= every) {\n const now = performance.now();\n const diff = now - last;\n fps.value = Math.round(1e3 / (diff / ticks));\n last = now;\n ticks = 0;\n }\n });\n return fps;\n}\n\nconst eventHandlers = [\n \"fullscreenchange\",\n \"webkitfullscreenchange\",\n \"webkitendfullscreen\",\n \"mozfullscreenchange\",\n \"MSFullscreenChange\"\n];\nfunction useFullscreen(target, options = {}) {\n const {\n document = defaultDocument,\n autoExit = false\n } = options;\n const targetRef = computed(() => {\n var _a;\n return (_a = unrefElement(target)) != null ? _a : document == null ? void 0 : document.querySelector(\"html\");\n });\n const isFullscreen = ref(false);\n const requestMethod = computed(() => {\n return [\n \"requestFullscreen\",\n \"webkitRequestFullscreen\",\n \"webkitEnterFullscreen\",\n \"webkitEnterFullScreen\",\n \"webkitRequestFullScreen\",\n \"mozRequestFullScreen\",\n \"msRequestFullscreen\"\n ].find((m) => document && m in document || targetRef.value && m in targetRef.value);\n });\n const exitMethod = computed(() => {\n return [\n \"exitFullscreen\",\n \"webkitExitFullscreen\",\n \"webkitExitFullScreen\",\n \"webkitCancelFullScreen\",\n \"mozCancelFullScreen\",\n \"msExitFullscreen\"\n ].find((m) => document && m in document || targetRef.value && m in targetRef.value);\n });\n const fullscreenEnabled = computed(() => {\n return [\n \"fullScreen\",\n \"webkitIsFullScreen\",\n \"webkitDisplayingFullscreen\",\n \"mozFullScreen\",\n \"msFullscreenElement\"\n ].find((m) => document && m in document || targetRef.value && m in targetRef.value);\n });\n const fullscreenElementMethod = [\n \"fullscreenElement\",\n \"webkitFullscreenElement\",\n \"mozFullScreenElement\",\n \"msFullscreenElement\"\n ].find((m) => document && m in document);\n const isSupported = useSupported(() => targetRef.value && document && requestMethod.value !== void 0 && exitMethod.value !== void 0 && fullscreenEnabled.value !== void 0);\n const isCurrentElementFullScreen = () => {\n if (fullscreenElementMethod)\n return (document == null ? void 0 : document[fullscreenElementMethod]) === targetRef.value;\n return false;\n };\n const isElementFullScreen = () => {\n if (fullscreenEnabled.value) {\n if (document && document[fullscreenEnabled.value] != null) {\n return document[fullscreenEnabled.value];\n } else {\n const target2 = targetRef.value;\n if ((target2 == null ? void 0 : target2[fullscreenEnabled.value]) != null) {\n return Boolean(target2[fullscreenEnabled.value]);\n }\n }\n }\n return false;\n };\n async function exit() {\n if (!isSupported.value || !isFullscreen.value)\n return;\n if (exitMethod.value) {\n if ((document == null ? void 0 : document[exitMethod.value]) != null) {\n await document[exitMethod.value]();\n } else {\n const target2 = targetRef.value;\n if ((target2 == null ? void 0 : target2[exitMethod.value]) != null)\n await target2[exitMethod.value]();\n }\n }\n isFullscreen.value = false;\n }\n async function enter() {\n if (!isSupported.value || isFullscreen.value)\n return;\n if (isElementFullScreen())\n await exit();\n const target2 = targetRef.value;\n if (requestMethod.value && (target2 == null ? void 0 : target2[requestMethod.value]) != null) {\n await target2[requestMethod.value]();\n isFullscreen.value = true;\n }\n }\n async function toggle() {\n await (isFullscreen.value ? exit() : enter());\n }\n const handlerCallback = () => {\n const isElementFullScreenValue = isElementFullScreen();\n if (!isElementFullScreenValue || isElementFullScreenValue && isCurrentElementFullScreen())\n isFullscreen.value = isElementFullScreenValue;\n };\n useEventListener(document, eventHandlers, handlerCallback, false);\n useEventListener(() => unrefElement(targetRef), eventHandlers, handlerCallback, false);\n if (autoExit)\n tryOnScopeDispose(exit);\n return {\n isSupported,\n isFullscreen,\n enter,\n exit,\n toggle\n };\n}\n\nfunction mapGamepadToXbox360Controller(gamepad) {\n return computed(() => {\n if (gamepad.value) {\n return {\n buttons: {\n a: gamepad.value.buttons[0],\n b: gamepad.value.buttons[1],\n x: gamepad.value.buttons[2],\n y: gamepad.value.buttons[3]\n },\n bumper: {\n left: gamepad.value.buttons[4],\n right: gamepad.value.buttons[5]\n },\n triggers: {\n left: gamepad.value.buttons[6],\n right: gamepad.value.buttons[7]\n },\n stick: {\n left: {\n horizontal: gamepad.value.axes[0],\n vertical: gamepad.value.axes[1],\n button: gamepad.value.buttons[10]\n },\n right: {\n horizontal: gamepad.value.axes[2],\n vertical: gamepad.value.axes[3],\n button: gamepad.value.buttons[11]\n }\n },\n dpad: {\n up: gamepad.value.buttons[12],\n down: gamepad.value.buttons[13],\n left: gamepad.value.buttons[14],\n right: gamepad.value.buttons[15]\n },\n back: gamepad.value.buttons[8],\n start: gamepad.value.buttons[9]\n };\n }\n return null;\n });\n}\nfunction useGamepad(options = {}) {\n const {\n navigator = defaultNavigator\n } = options;\n const isSupported = useSupported(() => navigator && \"getGamepads\" in navigator);\n const gamepads = ref([]);\n const onConnectedHook = createEventHook();\n const onDisconnectedHook = createEventHook();\n const stateFromGamepad = (gamepad) => {\n const hapticActuators = [];\n const vibrationActuator = \"vibrationActuator\" in gamepad ? gamepad.vibrationActuator : null;\n if (vibrationActuator)\n hapticActuators.push(vibrationActuator);\n if (gamepad.hapticActuators)\n hapticActuators.push(...gamepad.hapticActuators);\n return {\n id: gamepad.id,\n index: gamepad.index,\n connected: gamepad.connected,\n mapping: gamepad.mapping,\n timestamp: gamepad.timestamp,\n vibrationActuator: gamepad.vibrationActuator,\n hapticActuators,\n axes: gamepad.axes.map((axes) => axes),\n buttons: gamepad.buttons.map((button) => ({ pressed: button.pressed, touched: button.touched, value: button.value }))\n };\n };\n const updateGamepadState = () => {\n const _gamepads = (navigator == null ? void 0 : navigator.getGamepads()) || [];\n for (const gamepad of _gamepads) {\n if (gamepad && gamepads.value[gamepad.index])\n gamepads.value[gamepad.index] = stateFromGamepad(gamepad);\n }\n };\n const { isActive, pause, resume } = useRafFn(updateGamepadState);\n const onGamepadConnected = (gamepad) => {\n if (!gamepads.value.some(({ index }) => index === gamepad.index)) {\n gamepads.value.push(stateFromGamepad(gamepad));\n onConnectedHook.trigger(gamepad.index);\n }\n resume();\n };\n const onGamepadDisconnected = (gamepad) => {\n gamepads.value = gamepads.value.filter((x) => x.index !== gamepad.index);\n onDisconnectedHook.trigger(gamepad.index);\n };\n useEventListener(\"gamepadconnected\", (e) => onGamepadConnected(e.gamepad));\n useEventListener(\"gamepaddisconnected\", (e) => onGamepadDisconnected(e.gamepad));\n tryOnMounted(() => {\n const _gamepads = (navigator == null ? void 0 : navigator.getGamepads()) || [];\n for (const gamepad of _gamepads) {\n if (gamepad && gamepads.value[gamepad.index])\n onGamepadConnected(gamepad);\n }\n });\n pause();\n return {\n isSupported,\n onConnected: onConnectedHook.on,\n onDisconnected: onDisconnectedHook.on,\n gamepads,\n pause,\n resume,\n isActive\n };\n}\n\nfunction useGeolocation(options = {}) {\n const {\n enableHighAccuracy = true,\n maximumAge = 3e4,\n timeout = 27e3,\n navigator = defaultNavigator,\n immediate = true\n } = options;\n const isSupported = useSupported(() => navigator && \"geolocation\" in navigator);\n const locatedAt = ref(null);\n const error = shallowRef(null);\n const coords = ref({\n accuracy: 0,\n latitude: Number.POSITIVE_INFINITY,\n longitude: Number.POSITIVE_INFINITY,\n altitude: null,\n altitudeAccuracy: null,\n heading: null,\n speed: null\n });\n function updatePosition(position) {\n locatedAt.value = position.timestamp;\n coords.value = position.coords;\n error.value = null;\n }\n let watcher;\n function resume() {\n if (isSupported.value) {\n watcher = navigator.geolocation.watchPosition(\n updatePosition,\n (err) => error.value = err,\n {\n enableHighAccuracy,\n maximumAge,\n timeout\n }\n );\n }\n }\n if (immediate)\n resume();\n function pause() {\n if (watcher && navigator)\n navigator.geolocation.clearWatch(watcher);\n }\n tryOnScopeDispose(() => {\n pause();\n });\n return {\n isSupported,\n coords,\n locatedAt,\n error,\n resume,\n pause\n };\n}\n\nconst defaultEvents$1 = [\"mousemove\", \"mousedown\", \"resize\", \"keydown\", \"touchstart\", \"wheel\"];\nconst oneMinute = 6e4;\nfunction useIdle(timeout = oneMinute, options = {}) {\n const {\n initialState = false,\n listenForVisibilityChange = true,\n events = defaultEvents$1,\n window = defaultWindow,\n eventFilter = throttleFilter(50)\n } = options;\n const idle = ref(initialState);\n const lastActive = ref(timestamp());\n let timer;\n const reset = () => {\n idle.value = false;\n clearTimeout(timer);\n timer = setTimeout(() => idle.value = true, timeout);\n };\n const onEvent = createFilterWrapper(\n eventFilter,\n () => {\n lastActive.value = timestamp();\n reset();\n }\n );\n if (window) {\n const document = window.document;\n for (const event of events)\n useEventListener(window, event, onEvent, { passive: true });\n if (listenForVisibilityChange) {\n useEventListener(document, \"visibilitychange\", () => {\n if (!document.hidden)\n onEvent();\n });\n }\n reset();\n }\n return {\n idle,\n lastActive,\n reset\n };\n}\n\nasync function loadImage(options) {\n return new Promise((resolve, reject) => {\n const img = new Image();\n const { src, srcset, sizes, class: clazz, loading, crossorigin, referrerPolicy } = options;\n img.src = src;\n if (srcset)\n img.srcset = srcset;\n if (sizes)\n img.sizes = sizes;\n if (clazz)\n img.className = clazz;\n if (loading)\n img.loading = loading;\n if (crossorigin)\n img.crossOrigin = crossorigin;\n if (referrerPolicy)\n img.referrerPolicy = referrerPolicy;\n img.onload = () => resolve(img);\n img.onerror = reject;\n });\n}\nfunction useImage(options, asyncStateOptions = {}) {\n const state = useAsyncState(\n () => loadImage(toValue(options)),\n void 0,\n {\n resetOnExecute: true,\n ...asyncStateOptions\n }\n );\n watch(\n () => toValue(options),\n () => state.execute(asyncStateOptions.delay),\n { deep: true }\n );\n return state;\n}\n\nfunction resolveElement(el) {\n if (typeof Window !== \"undefined\" && el instanceof Window)\n return el.document.documentElement;\n if (typeof Document !== \"undefined\" && el instanceof Document)\n return el.documentElement;\n return el;\n}\n\nconst ARRIVED_STATE_THRESHOLD_PIXELS = 1;\nfunction useScroll(element, options = {}) {\n const {\n throttle = 0,\n idle = 200,\n onStop = noop,\n onScroll = noop,\n offset = {\n left: 0,\n right: 0,\n top: 0,\n bottom: 0\n },\n eventListenerOptions = {\n capture: false,\n passive: true\n },\n behavior = \"auto\",\n window = defaultWindow,\n onError = (e) => {\n console.error(e);\n }\n } = options;\n const internalX = ref(0);\n const internalY = ref(0);\n const x = computed({\n get() {\n return internalX.value;\n },\n set(x2) {\n scrollTo(x2, void 0);\n }\n });\n const y = computed({\n get() {\n return internalY.value;\n },\n set(y2) {\n scrollTo(void 0, y2);\n }\n });\n function scrollTo(_x, _y) {\n var _a, _b, _c, _d;\n if (!window)\n return;\n const _element = toValue(element);\n if (!_element)\n return;\n (_c = _element instanceof Document ? window.document.body : _element) == null ? void 0 : _c.scrollTo({\n top: (_a = toValue(_y)) != null ? _a : y.value,\n left: (_b = toValue(_x)) != null ? _b : x.value,\n behavior: toValue(behavior)\n });\n const scrollContainer = ((_d = _element == null ? void 0 : _element.document) == null ? void 0 : _d.documentElement) || (_element == null ? void 0 : _element.documentElement) || _element;\n if (x != null)\n internalX.value = scrollContainer.scrollLeft;\n if (y != null)\n internalY.value = scrollContainer.scrollTop;\n }\n const isScrolling = ref(false);\n const arrivedState = reactive({\n left: true,\n right: false,\n top: true,\n bottom: false\n });\n const directions = reactive({\n left: false,\n right: false,\n top: false,\n bottom: false\n });\n const onScrollEnd = (e) => {\n if (!isScrolling.value)\n return;\n isScrolling.value = false;\n directions.left = false;\n directions.right = false;\n directions.top = false;\n directions.bottom = false;\n onStop(e);\n };\n const onScrollEndDebounced = useDebounceFn(onScrollEnd, throttle + idle);\n const setArrivedState = (target) => {\n var _a;\n if (!window)\n return;\n const el = ((_a = target == null ? void 0 : target.document) == null ? void 0 : _a.documentElement) || (target == null ? void 0 : target.documentElement) || unrefElement(target);\n const { display, flexDirection } = getComputedStyle(el);\n const scrollLeft = el.scrollLeft;\n directions.left = scrollLeft < internalX.value;\n directions.right = scrollLeft > internalX.value;\n const left = Math.abs(scrollLeft) <= (offset.left || 0);\n const right = Math.abs(scrollLeft) + el.clientWidth >= el.scrollWidth - (offset.right || 0) - ARRIVED_STATE_THRESHOLD_PIXELS;\n if (display === \"flex\" && flexDirection === \"row-reverse\") {\n arrivedState.left = right;\n arrivedState.right = left;\n } else {\n arrivedState.left = left;\n arrivedState.right = right;\n }\n internalX.value = scrollLeft;\n let scrollTop = el.scrollTop;\n if (target === window.document && !scrollTop)\n scrollTop = window.document.body.scrollTop;\n directions.top = scrollTop < internalY.value;\n directions.bottom = scrollTop > internalY.value;\n const top = Math.abs(scrollTop) <= (offset.top || 0);\n const bottom = Math.abs(scrollTop) + el.clientHeight >= el.scrollHeight - (offset.bottom || 0) - ARRIVED_STATE_THRESHOLD_PIXELS;\n if (display === \"flex\" && flexDirection === \"column-reverse\") {\n arrivedState.top = bottom;\n arrivedState.bottom = top;\n } else {\n arrivedState.top = top;\n arrivedState.bottom = bottom;\n }\n internalY.value = scrollTop;\n };\n const onScrollHandler = (e) => {\n var _a;\n if (!window)\n return;\n const eventTarget = (_a = e.target.documentElement) != null ? _a : e.target;\n setArrivedState(eventTarget);\n isScrolling.value = true;\n onScrollEndDebounced(e);\n onScroll(e);\n };\n useEventListener(\n element,\n \"scroll\",\n throttle ? useThrottleFn(onScrollHandler, throttle, true, false) : onScrollHandler,\n eventListenerOptions\n );\n tryOnMounted(() => {\n try {\n const _element = toValue(element);\n if (!_element)\n return;\n setArrivedState(_element);\n } catch (e) {\n onError(e);\n }\n });\n useEventListener(\n element,\n \"scrollend\",\n onScrollEnd,\n eventListenerOptions\n );\n return {\n x,\n y,\n isScrolling,\n arrivedState,\n directions,\n measure() {\n const _element = toValue(element);\n if (window && _element)\n setArrivedState(_element);\n }\n };\n}\n\nfunction useInfiniteScroll(element, onLoadMore, options = {}) {\n var _a;\n const {\n direction = \"bottom\",\n interval = 100,\n canLoadMore = () => true\n } = options;\n const state = reactive(useScroll(\n element,\n {\n ...options,\n offset: {\n [direction]: (_a = options.distance) != null ? _a : 0,\n ...options.offset\n }\n }\n ));\n const promise = ref();\n const isLoading = computed(() => !!promise.value);\n const observedElement = computed(() => {\n return resolveElement(toValue(element));\n });\n const isElementVisible = useElementVisibility(observedElement);\n function checkAndLoad() {\n state.measure();\n if (!observedElement.value || !isElementVisible.value || !canLoadMore(observedElement.value))\n return;\n const { scrollHeight, clientHeight, scrollWidth, clientWidth } = observedElement.value;\n const isNarrower = direction === \"bottom\" || direction === \"top\" ? scrollHeight <= clientHeight : scrollWidth <= clientWidth;\n if (state.arrivedState[direction] || isNarrower) {\n if (!promise.value) {\n promise.value = Promise.all([\n onLoadMore(state),\n new Promise((resolve) => setTimeout(resolve, interval))\n ]).finally(() => {\n promise.value = null;\n nextTick(() => checkAndLoad());\n });\n }\n }\n }\n const stop = watch(\n () => [state.arrivedState[direction], isElementVisible.value],\n checkAndLoad,\n { immediate: true }\n );\n tryOnUnmounted(stop);\n return {\n isLoading,\n reset() {\n nextTick(() => checkAndLoad());\n }\n };\n}\n\nconst defaultEvents = [\"mousedown\", \"mouseup\", \"keydown\", \"keyup\"];\nfunction useKeyModifier(modifier, options = {}) {\n const {\n events = defaultEvents,\n document = defaultDocument,\n initial = null\n } = options;\n const state = ref(initial);\n if (document) {\n events.forEach((listenerEvent) => {\n useEventListener(document, listenerEvent, (evt) => {\n if (typeof evt.getModifierState === \"function\")\n state.value = evt.getModifierState(modifier);\n });\n });\n }\n return state;\n}\n\nfunction useLocalStorage(key, initialValue, options = {}) {\n const { window = defaultWindow } = options;\n return useStorage(key, initialValue, window == null ? void 0 : window.localStorage, options);\n}\n\nconst DefaultMagicKeysAliasMap = {\n ctrl: \"control\",\n command: \"meta\",\n cmd: \"meta\",\n option: \"alt\",\n up: \"arrowup\",\n down: \"arrowdown\",\n left: \"arrowleft\",\n right: \"arrowright\"\n};\n\nfunction useMagicKeys(options = {}) {\n const {\n reactive: useReactive = false,\n target = defaultWindow,\n aliasMap = DefaultMagicKeysAliasMap,\n passive = true,\n onEventFired = noop\n } = options;\n const current = reactive(/* @__PURE__ */ new Set());\n const obj = {\n toJSON() {\n return {};\n },\n current\n };\n const refs = useReactive ? reactive(obj) : obj;\n const metaDeps = /* @__PURE__ */ new Set();\n const usedKeys = /* @__PURE__ */ new Set();\n function setRefs(key, value) {\n if (key in refs) {\n if (useReactive)\n refs[key] = value;\n else\n refs[key].value = value;\n }\n }\n function reset() {\n current.clear();\n for (const key of usedKeys)\n setRefs(key, false);\n }\n function updateRefs(e, value) {\n var _a, _b;\n const key = (_a = e.key) == null ? void 0 : _a.toLowerCase();\n const code = (_b = e.code) == null ? void 0 : _b.toLowerCase();\n const values = [code, key].filter(Boolean);\n if (key) {\n if (value)\n current.add(key);\n else\n current.delete(key);\n }\n for (const key2 of values) {\n usedKeys.add(key2);\n setRefs(key2, value);\n }\n if (key === \"meta\" && !value) {\n metaDeps.forEach((key2) => {\n current.delete(key2);\n setRefs(key2, false);\n });\n metaDeps.clear();\n } else if (typeof e.getModifierState === \"function\" && e.getModifierState(\"Meta\") && value) {\n [...current, ...values].forEach((key2) => metaDeps.add(key2));\n }\n }\n useEventListener(target, \"keydown\", (e) => {\n updateRefs(e, true);\n return onEventFired(e);\n }, { passive });\n useEventListener(target, \"keyup\", (e) => {\n updateRefs(e, false);\n return onEventFired(e);\n }, { passive });\n useEventListener(\"blur\", reset, { passive: true });\n useEventListener(\"focus\", reset, { passive: true });\n const proxy = new Proxy(\n refs,\n {\n get(target2, prop, rec) {\n if (typeof prop !== \"string\")\n return Reflect.get(target2, prop, rec);\n prop = prop.toLowerCase();\n if (prop in aliasMap)\n prop = aliasMap[prop];\n if (!(prop in refs)) {\n if (/[+_-]/.test(prop)) {\n const keys = prop.split(/[+_-]/g).map((i) => i.trim());\n refs[prop] = computed(() => keys.every((key) => toValue(proxy[key])));\n } else {\n refs[prop] = ref(false);\n }\n }\n const r = Reflect.get(target2, prop, rec);\n return useReactive ? toValue(r) : r;\n }\n }\n );\n return proxy;\n}\n\nfunction usingElRef(source, cb) {\n if (toValue(source))\n cb(toValue(source));\n}\nfunction timeRangeToArray(timeRanges) {\n let ranges = [];\n for (let i = 0; i < timeRanges.length; ++i)\n ranges = [...ranges, [timeRanges.start(i), timeRanges.end(i)]];\n return ranges;\n}\nfunction tracksToArray(tracks) {\n return Array.from(tracks).map(({ label, kind, language, mode, activeCues, cues, inBandMetadataTrackDispatchType }, id) => ({ id, label, kind, language, mode, activeCues, cues, inBandMetadataTrackDispatchType }));\n}\nconst defaultOptions = {\n src: \"\",\n tracks: []\n};\nfunction useMediaControls(target, options = {}) {\n target = toRef(target);\n options = {\n ...defaultOptions,\n ...options\n };\n const {\n document = defaultDocument\n } = options;\n const currentTime = ref(0);\n const duration = ref(0);\n const seeking = ref(false);\n const volume = ref(1);\n const waiting = ref(false);\n const ended = ref(false);\n const playing = ref(false);\n const rate = ref(1);\n const stalled = ref(false);\n const buffered = ref([]);\n const tracks = ref([]);\n const selectedTrack = ref(-1);\n const isPictureInPicture = ref(false);\n const muted = ref(false);\n const supportsPictureInPicture = document && \"pictureInPictureEnabled\" in document;\n const sourceErrorEvent = createEventHook();\n const playbackErrorEvent = createEventHook();\n const disableTrack = (track) => {\n usingElRef(target, (el) => {\n if (track) {\n const id = typeof track === \"number\" ? track : track.id;\n el.textTracks[id].mode = \"disabled\";\n } else {\n for (let i = 0; i < el.textTracks.length; ++i)\n el.textTracks[i].mode = \"disabled\";\n }\n selectedTrack.value = -1;\n });\n };\n const enableTrack = (track, disableTracks = true) => {\n usingElRef(target, (el) => {\n const id = typeof track === \"number\" ? track : track.id;\n if (disableTracks)\n disableTrack();\n el.textTracks[id].mode = \"showing\";\n selectedTrack.value = id;\n });\n };\n const togglePictureInPicture = () => {\n return new Promise((resolve, reject) => {\n usingElRef(target, async (el) => {\n if (supportsPictureInPicture) {\n if (!isPictureInPicture.value) {\n el.requestPictureInPicture().then(resolve).catch(reject);\n } else {\n document.exitPictureInPicture().then(resolve).catch(reject);\n }\n }\n });\n });\n };\n watchEffect(() => {\n if (!document)\n return;\n const el = toValue(target);\n if (!el)\n return;\n const src = toValue(options.src);\n let sources = [];\n if (!src)\n return;\n if (typeof src === \"string\")\n sources = [{ src }];\n else if (Array.isArray(src))\n sources = src;\n else if (isObject(src))\n sources = [src];\n el.querySelectorAll(\"source\").forEach((e) => {\n e.removeEventListener(\"error\", sourceErrorEvent.trigger);\n e.remove();\n });\n sources.forEach(({ src: src2, type }) => {\n const source = document.createElement(\"source\");\n source.setAttribute(\"src\", src2);\n source.setAttribute(\"type\", type || \"\");\n source.addEventListener(\"error\", sourceErrorEvent.trigger);\n el.appendChild(source);\n });\n el.load();\n });\n tryOnScopeDispose(() => {\n const el = toValue(target);\n if (!el)\n return;\n el.querySelectorAll(\"source\").forEach((e) => e.removeEventListener(\"error\", sourceErrorEvent.trigger));\n });\n watch([target, volume], () => {\n const el = toValue(target);\n if (!el)\n return;\n el.volume = volume.value;\n });\n watch([target, muted], () => {\n const el = toValue(target);\n if (!el)\n return;\n el.muted = muted.value;\n });\n watch([target, rate], () => {\n const el = toValue(target);\n if (!el)\n return;\n el.playbackRate = rate.value;\n });\n watchEffect(() => {\n if (!document)\n return;\n const textTracks = toValue(options.tracks);\n const el = toValue(target);\n if (!textTracks || !textTracks.length || !el)\n return;\n el.querySelectorAll(\"track\").forEach((e) => e.remove());\n textTracks.forEach(({ default: isDefault, kind, label, src, srcLang }, i) => {\n const track = document.createElement(\"track\");\n track.default = isDefault || false;\n track.kind = kind;\n track.label = label;\n track.src = src;\n track.srclang = srcLang;\n if (track.default)\n selectedTrack.value = i;\n el.appendChild(track);\n });\n });\n const { ignoreUpdates: ignoreCurrentTimeUpdates } = watchIgnorable(currentTime, (time) => {\n const el = toValue(target);\n if (!el)\n return;\n el.currentTime = time;\n });\n const { ignoreUpdates: ignorePlayingUpdates } = watchIgnorable(playing, (isPlaying) => {\n const el = toValue(target);\n if (!el)\n return;\n if (isPlaying) {\n el.play().catch((e) => {\n playbackErrorEvent.trigger(e);\n throw e;\n });\n } else {\n el.pause();\n }\n });\n useEventListener(target, \"timeupdate\", () => ignoreCurrentTimeUpdates(() => currentTime.value = toValue(target).currentTime));\n useEventListener(target, \"durationchange\", () => duration.value = toValue(target).duration);\n useEventListener(target, \"progress\", () => buffered.value = timeRangeToArray(toValue(target).buffered));\n useEventListener(target, \"seeking\", () => seeking.value = true);\n useEventListener(target, \"seeked\", () => seeking.value = false);\n useEventListener(target, [\"waiting\", \"loadstart\"], () => {\n waiting.value = true;\n ignorePlayingUpdates(() => playing.value = false);\n });\n useEventListener(target, \"loadeddata\", () => waiting.value = false);\n useEventListener(target, \"playing\", () => {\n waiting.value = false;\n ended.value = false;\n ignorePlayingUpdates(() => playing.value = true);\n });\n useEventListener(target, \"ratechange\", () => rate.value = toValue(target).playbackRate);\n useEventListener(target, \"stalled\", () => stalled.value = true);\n useEventListener(target, \"ended\", () => ended.value = true);\n useEventListener(target, \"pause\", () => ignorePlayingUpdates(() => playing.value = false));\n useEventListener(target, \"play\", () => ignorePlayingUpdates(() => playing.value = true));\n useEventListener(target, \"enterpictureinpicture\", () => isPictureInPicture.value = true);\n useEventListener(target, \"leavepictureinpicture\", () => isPictureInPicture.value = false);\n useEventListener(target, \"volumechange\", () => {\n const el = toValue(target);\n if (!el)\n return;\n volume.value = el.volume;\n muted.value = el.muted;\n });\n const listeners = [];\n const stop = watch([target], () => {\n const el = toValue(target);\n if (!el)\n return;\n stop();\n listeners[0] = useEventListener(el.textTracks, \"addtrack\", () => tracks.value = tracksToArray(el.textTracks));\n listeners[1] = useEventListener(el.textTracks, \"removetrack\", () => tracks.value = tracksToArray(el.textTracks));\n listeners[2] = useEventListener(el.textTracks, \"change\", () => tracks.value = tracksToArray(el.textTracks));\n });\n tryOnScopeDispose(() => listeners.forEach((listener) => listener()));\n return {\n currentTime,\n duration,\n waiting,\n seeking,\n ended,\n stalled,\n buffered,\n playing,\n rate,\n // Volume\n volume,\n muted,\n // Tracks\n tracks,\n selectedTrack,\n enableTrack,\n disableTrack,\n // Picture in Picture\n supportsPictureInPicture,\n togglePictureInPicture,\n isPictureInPicture,\n // Events\n onSourceError: sourceErrorEvent.on,\n onPlaybackError: playbackErrorEvent.on\n };\n}\n\nfunction useMemoize(resolver, options) {\n const initCache = () => {\n if (options == null ? void 0 : options.cache)\n return shallowReactive(options.cache);\n return shallowReactive(/* @__PURE__ */ new Map());\n };\n const cache = initCache();\n const generateKey = (...args) => (options == null ? void 0 : options.getKey) ? options.getKey(...args) : JSON.stringify(args);\n const _loadData = (key, ...args) => {\n cache.set(key, resolver(...args));\n return cache.get(key);\n };\n const loadData = (...args) => _loadData(generateKey(...args), ...args);\n const deleteData = (...args) => {\n cache.delete(generateKey(...args));\n };\n const clearData = () => {\n cache.clear();\n };\n const memoized = (...args) => {\n const key = generateKey(...args);\n if (cache.has(key))\n return cache.get(key);\n return _loadData(key, ...args);\n };\n memoized.load = loadData;\n memoized.delete = deleteData;\n memoized.clear = clearData;\n memoized.generateKey = generateKey;\n memoized.cache = cache;\n return memoized;\n}\n\nfunction useMemory(options = {}) {\n const memory = ref();\n const isSupported = useSupported(() => typeof performance !== \"undefined\" && \"memory\" in performance);\n if (isSupported.value) {\n const { interval = 1e3 } = options;\n useIntervalFn(() => {\n memory.value = performance.memory;\n }, interval, { immediate: options.immediate, immediateCallback: options.immediateCallback });\n }\n return { isSupported, memory };\n}\n\nconst UseMouseBuiltinExtractors = {\n page: (event) => [event.pageX, event.pageY],\n client: (event) => [event.clientX, event.clientY],\n screen: (event) => [event.screenX, event.screenY],\n movement: (event) => event instanceof Touch ? null : [event.movementX, event.movementY]\n};\nfunction useMouse(options = {}) {\n const {\n type = \"page\",\n touch = true,\n resetOnTouchEnds = false,\n initialValue = { x: 0, y: 0 },\n window = defaultWindow,\n target = window,\n scroll = true,\n eventFilter\n } = options;\n let _prevMouseEvent = null;\n let _prevScrollX = 0;\n let _prevScrollY = 0;\n const x = ref(initialValue.x);\n const y = ref(initialValue.y);\n const sourceType = ref(null);\n const extractor = typeof type === \"function\" ? type : UseMouseBuiltinExtractors[type];\n const mouseHandler = (event) => {\n const result = extractor(event);\n _prevMouseEvent = event;\n if (result) {\n [x.value, y.value] = result;\n sourceType.value = \"mouse\";\n }\n if (window) {\n _prevScrollX = window.scrollX;\n _prevScrollY = window.scrollY;\n }\n };\n const touchHandler = (event) => {\n if (event.touches.length > 0) {\n const result = extractor(event.touches[0]);\n if (result) {\n [x.value, y.value] = result;\n sourceType.value = \"touch\";\n }\n }\n };\n const scrollHandler = () => {\n if (!_prevMouseEvent || !window)\n return;\n const pos = extractor(_prevMouseEvent);\n if (_prevMouseEvent instanceof MouseEvent && pos) {\n x.value = pos[0] + window.scrollX - _prevScrollX;\n y.value = pos[1] + window.scrollY - _prevScrollY;\n }\n };\n const reset = () => {\n x.value = initialValue.x;\n y.value = initialValue.y;\n };\n const mouseHandlerWrapper = eventFilter ? (event) => eventFilter(() => mouseHandler(event), {}) : (event) => mouseHandler(event);\n const touchHandlerWrapper = eventFilter ? (event) => eventFilter(() => touchHandler(event), {}) : (event) => touchHandler(event);\n const scrollHandlerWrapper = eventFilter ? () => eventFilter(() => scrollHandler(), {}) : () => scrollHandler();\n if (target) {\n const listenerOptions = { passive: true };\n useEventListener(target, [\"mousemove\", \"dragover\"], mouseHandlerWrapper, listenerOptions);\n if (touch && type !== \"movement\") {\n useEventListener(target, [\"touchstart\", \"touchmove\"], touchHandlerWrapper, listenerOptions);\n if (resetOnTouchEnds)\n useEventListener(target, \"touchend\", reset, listenerOptions);\n }\n if (scroll && type === \"page\")\n useEventListener(window, \"scroll\", scrollHandlerWrapper, { passive: true });\n }\n return {\n x,\n y,\n sourceType\n };\n}\n\nfunction useMouseInElement(target, options = {}) {\n const {\n handleOutside = true,\n window = defaultWindow\n } = options;\n const type = options.type || \"page\";\n const { x, y, sourceType } = useMouse(options);\n const targetRef = ref(target != null ? target : window == null ? void 0 : window.document.body);\n const elementX = ref(0);\n const elementY = ref(0);\n const elementPositionX = ref(0);\n const elementPositionY = ref(0);\n const elementHeight = ref(0);\n const elementWidth = ref(0);\n const isOutside = ref(true);\n let stop = () => {\n };\n if (window) {\n stop = watch(\n [targetRef, x, y],\n () => {\n const el = unrefElement(targetRef);\n if (!el || !(el instanceof Element))\n return;\n const {\n left,\n top,\n width,\n height\n } = el.getBoundingClientRect();\n elementPositionX.value = left + (type === \"page\" ? window.pageXOffset : 0);\n elementPositionY.value = top + (type === \"page\" ? window.pageYOffset : 0);\n elementHeight.value = height;\n elementWidth.value = width;\n const elX = x.value - elementPositionX.value;\n const elY = y.value - elementPositionY.value;\n isOutside.value = width === 0 || height === 0 || elX < 0 || elY < 0 || elX > width || elY > height;\n if (handleOutside || !isOutside.value) {\n elementX.value = elX;\n elementY.value = elY;\n }\n },\n { immediate: true }\n );\n useEventListener(document, \"mouseleave\", () => {\n isOutside.value = true;\n });\n }\n return {\n x,\n y,\n sourceType,\n elementX,\n elementY,\n elementPositionX,\n elementPositionY,\n elementHeight,\n elementWidth,\n isOutside,\n stop\n };\n}\n\nfunction useMousePressed(options = {}) {\n const {\n touch = true,\n drag = true,\n capture = false,\n initialValue = false,\n window = defaultWindow\n } = options;\n const pressed = ref(initialValue);\n const sourceType = ref(null);\n if (!window) {\n return {\n pressed,\n sourceType\n };\n }\n const onPressed = (srcType) => () => {\n pressed.value = true;\n sourceType.value = srcType;\n };\n const onReleased = () => {\n pressed.value = false;\n sourceType.value = null;\n };\n const target = computed(() => unrefElement(options.target) || window);\n useEventListener(target, \"mousedown\", onPressed(\"mouse\"), { passive: true, capture });\n useEventListener(window, \"mouseleave\", onReleased, { passive: true, capture });\n useEventListener(window, \"mouseup\", onReleased, { passive: true, capture });\n if (drag) {\n useEventListener(target, \"dragstart\", onPressed(\"mouse\"), { passive: true, capture });\n useEventListener(window, \"drop\", onReleased, { passive: true, capture });\n useEventListener(window, \"dragend\", onReleased, { passive: true, capture });\n }\n if (touch) {\n useEventListener(target, \"touchstart\", onPressed(\"touch\"), { passive: true, capture });\n useEventListener(window, \"touchend\", onReleased, { passive: true, capture });\n useEventListener(window, \"touchcancel\", onReleased, { passive: true, capture });\n }\n return {\n pressed,\n sourceType\n };\n}\n\nfunction useNavigatorLanguage(options = {}) {\n const { window = defaultWindow } = options;\n const navigator = window == null ? void 0 : window.navigator;\n const isSupported = useSupported(() => navigator && \"language\" in navigator);\n const language = ref(navigator == null ? void 0 : navigator.language);\n useEventListener(window, \"languagechange\", () => {\n if (navigator)\n language.value = navigator.language;\n });\n return {\n isSupported,\n language\n };\n}\n\nfunction useNetwork(options = {}) {\n const { window = defaultWindow } = options;\n const navigator = window == null ? void 0 : window.navigator;\n const isSupported = useSupported(() => navigator && \"connection\" in navigator);\n const isOnline = ref(true);\n const saveData = ref(false);\n const offlineAt = ref(void 0);\n const onlineAt = ref(void 0);\n const downlink = ref(void 0);\n const downlinkMax = ref(void 0);\n const rtt = ref(void 0);\n const effectiveType = ref(void 0);\n const type = ref(\"unknown\");\n const connection = isSupported.value && navigator.connection;\n function updateNetworkInformation() {\n if (!navigator)\n return;\n isOnline.value = navigator.onLine;\n offlineAt.value = isOnline.value ? void 0 : Date.now();\n onlineAt.value = isOnline.value ? Date.now() : void 0;\n if (connection) {\n downlink.value = connection.downlink;\n downlinkMax.value = connection.downlinkMax;\n effectiveType.value = connection.effectiveType;\n rtt.value = connection.rtt;\n saveData.value = connection.saveData;\n type.value = connection.type;\n }\n }\n if (window) {\n useEventListener(window, \"offline\", () => {\n isOnline.value = false;\n offlineAt.value = Date.now();\n });\n useEventListener(window, \"online\", () => {\n isOnline.value = true;\n onlineAt.value = Date.now();\n });\n }\n if (connection)\n useEventListener(connection, \"change\", updateNetworkInformation, false);\n updateNetworkInformation();\n return {\n isSupported: readonly(isSupported),\n isOnline: readonly(isOnline),\n saveData: readonly(saveData),\n offlineAt: readonly(offlineAt),\n onlineAt: readonly(onlineAt),\n downlink: readonly(downlink),\n downlinkMax: readonly(downlinkMax),\n effectiveType: readonly(effectiveType),\n rtt: readonly(rtt),\n type: readonly(type)\n };\n}\n\nfunction useNow(options = {}) {\n const {\n controls: exposeControls = false,\n interval = \"requestAnimationFrame\"\n } = options;\n const now = ref(/* @__PURE__ */ new Date());\n const update = () => now.value = /* @__PURE__ */ new Date();\n const controls = interval === \"requestAnimationFrame\" ? useRafFn(update, { immediate: true }) : useIntervalFn(update, interval, { immediate: true });\n if (exposeControls) {\n return {\n now,\n ...controls\n };\n } else {\n return now;\n }\n}\n\nfunction useObjectUrl(object) {\n const url = ref();\n const release = () => {\n if (url.value)\n URL.revokeObjectURL(url.value);\n url.value = void 0;\n };\n watch(\n () => toValue(object),\n (newObject) => {\n release();\n if (newObject)\n url.value = URL.createObjectURL(newObject);\n },\n { immediate: true }\n );\n tryOnScopeDispose(release);\n return readonly(url);\n}\n\nfunction useClamp(value, min, max) {\n if (typeof value === \"function\" || isReadonly(value))\n return computed(() => clamp(toValue(value), toValue(min), toValue(max)));\n const _value = ref(value);\n return computed({\n get() {\n return _value.value = clamp(_value.value, toValue(min), toValue(max));\n },\n set(value2) {\n _value.value = clamp(value2, toValue(min), toValue(max));\n }\n });\n}\n\nfunction useOffsetPagination(options) {\n const {\n total = Number.POSITIVE_INFINITY,\n pageSize = 10,\n page = 1,\n onPageChange = noop,\n onPageSizeChange = noop,\n onPageCountChange = noop\n } = options;\n const currentPageSize = useClamp(pageSize, 1, Number.POSITIVE_INFINITY);\n const pageCount = computed(() => Math.max(\n 1,\n Math.ceil(toValue(total) / toValue(currentPageSize))\n ));\n const currentPage = useClamp(page, 1, pageCount);\n const isFirstPage = computed(() => currentPage.value === 1);\n const isLastPage = computed(() => currentPage.value === pageCount.value);\n if (isRef(page)) {\n syncRef(page, currentPage, {\n direction: isReadonly(page) ? \"ltr\" : \"both\"\n });\n }\n if (isRef(pageSize)) {\n syncRef(pageSize, currentPageSize, {\n direction: isReadonly(pageSize) ? \"ltr\" : \"both\"\n });\n }\n function prev() {\n currentPage.value--;\n }\n function next() {\n currentPage.value++;\n }\n const returnValue = {\n currentPage,\n currentPageSize,\n pageCount,\n isFirstPage,\n isLastPage,\n prev,\n next\n };\n watch(currentPage, () => {\n onPageChange(reactive(returnValue));\n });\n watch(currentPageSize, () => {\n onPageSizeChange(reactive(returnValue));\n });\n watch(pageCount, () => {\n onPageCountChange(reactive(returnValue));\n });\n return returnValue;\n}\n\nfunction useOnline(options = {}) {\n const { isOnline } = useNetwork(options);\n return isOnline;\n}\n\nfunction usePageLeave(options = {}) {\n const { window = defaultWindow } = options;\n const isLeft = ref(false);\n const handler = (event) => {\n if (!window)\n return;\n event = event || window.event;\n const from = event.relatedTarget || event.toElement;\n isLeft.value = !from;\n };\n if (window) {\n useEventListener(window, \"mouseout\", handler, { passive: true });\n useEventListener(window.document, \"mouseleave\", handler, { passive: true });\n useEventListener(window.document, \"mouseenter\", handler, { passive: true });\n }\n return isLeft;\n}\n\nfunction useScreenOrientation(options = {}) {\n const {\n window = defaultWindow\n } = options;\n const isSupported = useSupported(() => window && \"screen\" in window && \"orientation\" in window.screen);\n const screenOrientation = isSupported.value ? window.screen.orientation : {};\n const orientation = ref(screenOrientation.type);\n const angle = ref(screenOrientation.angle || 0);\n if (isSupported.value) {\n useEventListener(window, \"orientationchange\", () => {\n orientation.value = screenOrientation.type;\n angle.value = screenOrientation.angle;\n });\n }\n const lockOrientation = (type) => {\n if (isSupported.value && typeof screenOrientation.lock === \"function\")\n return screenOrientation.lock(type);\n return Promise.reject(new Error(\"Not supported\"));\n };\n const unlockOrientation = () => {\n if (isSupported.value && typeof screenOrientation.unlock === \"function\")\n screenOrientation.unlock();\n };\n return {\n isSupported,\n orientation,\n angle,\n lockOrientation,\n unlockOrientation\n };\n}\n\nfunction useParallax(target, options = {}) {\n const {\n deviceOrientationTiltAdjust = (i) => i,\n deviceOrientationRollAdjust = (i) => i,\n mouseTiltAdjust = (i) => i,\n mouseRollAdjust = (i) => i,\n window = defaultWindow\n } = options;\n const orientation = reactive(useDeviceOrientation({ window }));\n const screenOrientation = reactive(useScreenOrientation({ window }));\n const {\n elementX: x,\n elementY: y,\n elementWidth: width,\n elementHeight: height\n } = useMouseInElement(target, { handleOutside: false, window });\n const source = computed(() => {\n if (orientation.isSupported && (orientation.alpha != null && orientation.alpha !== 0 || orientation.gamma != null && orientation.gamma !== 0)) {\n return \"deviceOrientation\";\n }\n return \"mouse\";\n });\n const roll = computed(() => {\n if (source.value === \"deviceOrientation\") {\n let value;\n switch (screenOrientation.orientation) {\n case \"landscape-primary\":\n value = orientation.gamma / 90;\n break;\n case \"landscape-secondary\":\n value = -orientation.gamma / 90;\n break;\n case \"portrait-primary\":\n value = -orientation.beta / 90;\n break;\n case \"portrait-secondary\":\n value = orientation.beta / 90;\n break;\n default:\n value = -orientation.beta / 90;\n }\n return deviceOrientationRollAdjust(value);\n } else {\n const value = -(y.value - height.value / 2) / height.value;\n return mouseRollAdjust(value);\n }\n });\n const tilt = computed(() => {\n if (source.value === \"deviceOrientation\") {\n let value;\n switch (screenOrientation.orientation) {\n case \"landscape-primary\":\n value = orientation.beta / 90;\n break;\n case \"landscape-secondary\":\n value = -orientation.beta / 90;\n break;\n case \"portrait-primary\":\n value = orientation.gamma / 90;\n break;\n case \"portrait-secondary\":\n value = -orientation.gamma / 90;\n break;\n default:\n value = orientation.gamma / 90;\n }\n return deviceOrientationTiltAdjust(value);\n } else {\n const value = (x.value - width.value / 2) / width.value;\n return mouseTiltAdjust(value);\n }\n });\n return { roll, tilt, source };\n}\n\nfunction useParentElement(element = useCurrentElement()) {\n const parentElement = shallowRef();\n const update = () => {\n const el = unrefElement(element);\n if (el)\n parentElement.value = el.parentElement;\n };\n tryOnMounted(update);\n watch(() => toValue(element), update);\n return parentElement;\n}\n\nfunction usePerformanceObserver(options, callback) {\n const {\n window = defaultWindow,\n immediate = true,\n ...performanceOptions\n } = options;\n const isSupported = useSupported(() => window && \"PerformanceObserver\" in window);\n let observer;\n const stop = () => {\n observer == null ? void 0 : observer.disconnect();\n };\n const start = () => {\n if (isSupported.value) {\n stop();\n observer = new PerformanceObserver(callback);\n observer.observe(performanceOptions);\n }\n };\n tryOnScopeDispose(stop);\n if (immediate)\n start();\n return {\n isSupported,\n start,\n stop\n };\n}\n\nconst defaultState = {\n x: 0,\n y: 0,\n pointerId: 0,\n pressure: 0,\n tiltX: 0,\n tiltY: 0,\n width: 0,\n height: 0,\n twist: 0,\n pointerType: null\n};\nconst keys = /* @__PURE__ */ Object.keys(defaultState);\nfunction usePointer(options = {}) {\n const {\n target = defaultWindow\n } = options;\n const isInside = ref(false);\n const state = ref(options.initialValue || {});\n Object.assign(state.value, defaultState, state.value);\n const handler = (event) => {\n isInside.value = true;\n if (options.pointerTypes && !options.pointerTypes.includes(event.pointerType))\n return;\n state.value = objectPick(event, keys, false);\n };\n if (target) {\n const listenerOptions = { passive: true };\n useEventListener(target, [\"pointerdown\", \"pointermove\", \"pointerup\"], handler, listenerOptions);\n useEventListener(target, \"pointerleave\", () => isInside.value = false, listenerOptions);\n }\n return {\n ...toRefs(state),\n isInside\n };\n}\n\nfunction usePointerLock(target, options = {}) {\n const { document = defaultDocument } = options;\n const isSupported = useSupported(() => document && \"pointerLockElement\" in document);\n const element = ref();\n const triggerElement = ref();\n let targetElement;\n if (isSupported.value) {\n useEventListener(document, \"pointerlockchange\", () => {\n var _a;\n const currentElement = (_a = document.pointerLockElement) != null ? _a : element.value;\n if (targetElement && currentElement === targetElement) {\n element.value = document.pointerLockElement;\n if (!element.value)\n targetElement = triggerElement.value = null;\n }\n });\n useEventListener(document, \"pointerlockerror\", () => {\n var _a;\n const currentElement = (_a = document.pointerLockElement) != null ? _a : element.value;\n if (targetElement && currentElement === targetElement) {\n const action = document.pointerLockElement ? \"release\" : \"acquire\";\n throw new Error(`Failed to ${action} pointer lock.`);\n }\n });\n }\n async function lock(e) {\n var _a;\n if (!isSupported.value)\n throw new Error(\"Pointer Lock API is not supported by your browser.\");\n triggerElement.value = e instanceof Event ? e.currentTarget : null;\n targetElement = e instanceof Event ? (_a = unrefElement(target)) != null ? _a : triggerElement.value : unrefElement(e);\n if (!targetElement)\n throw new Error(\"Target element undefined.\");\n targetElement.requestPointerLock();\n return await until(element).toBe(targetElement);\n }\n async function unlock() {\n if (!element.value)\n return false;\n document.exitPointerLock();\n await until(element).toBeNull();\n return true;\n }\n return {\n isSupported,\n element,\n triggerElement,\n lock,\n unlock\n };\n}\n\nfunction usePointerSwipe(target, options = {}) {\n const targetRef = toRef(target);\n const {\n threshold = 50,\n onSwipe,\n onSwipeEnd,\n onSwipeStart,\n disableTextSelect = false\n } = options;\n const posStart = reactive({ x: 0, y: 0 });\n const updatePosStart = (x, y) => {\n posStart.x = x;\n posStart.y = y;\n };\n const posEnd = reactive({ x: 0, y: 0 });\n const updatePosEnd = (x, y) => {\n posEnd.x = x;\n posEnd.y = y;\n };\n const distanceX = computed(() => posStart.x - posEnd.x);\n const distanceY = computed(() => posStart.y - posEnd.y);\n const { max, abs } = Math;\n const isThresholdExceeded = computed(() => max(abs(distanceX.value), abs(distanceY.value)) >= threshold);\n const isSwiping = ref(false);\n const isPointerDown = ref(false);\n const direction = computed(() => {\n if (!isThresholdExceeded.value)\n return \"none\";\n if (abs(distanceX.value) > abs(distanceY.value)) {\n return distanceX.value > 0 ? \"left\" : \"right\";\n } else {\n return distanceY.value > 0 ? \"up\" : \"down\";\n }\n });\n const eventIsAllowed = (e) => {\n var _a, _b, _c;\n const isReleasingButton = e.buttons === 0;\n const isPrimaryButton = e.buttons === 1;\n return (_c = (_b = (_a = options.pointerTypes) == null ? void 0 : _a.includes(e.pointerType)) != null ? _b : isReleasingButton || isPrimaryButton) != null ? _c : true;\n };\n const stops = [\n useEventListener(target, \"pointerdown\", (e) => {\n if (!eventIsAllowed(e))\n return;\n isPointerDown.value = true;\n const eventTarget = e.target;\n eventTarget == null ? void 0 : eventTarget.setPointerCapture(e.pointerId);\n const { clientX: x, clientY: y } = e;\n updatePosStart(x, y);\n updatePosEnd(x, y);\n onSwipeStart == null ? void 0 : onSwipeStart(e);\n }),\n useEventListener(target, \"pointermove\", (e) => {\n if (!eventIsAllowed(e))\n return;\n if (!isPointerDown.value)\n return;\n const { clientX: x, clientY: y } = e;\n updatePosEnd(x, y);\n if (!isSwiping.value && isThresholdExceeded.value)\n isSwiping.value = true;\n if (isSwiping.value)\n onSwipe == null ? void 0 : onSwipe(e);\n }),\n useEventListener(target, \"pointerup\", (e) => {\n if (!eventIsAllowed(e))\n return;\n if (isSwiping.value)\n onSwipeEnd == null ? void 0 : onSwipeEnd(e, direction.value);\n isPointerDown.value = false;\n isSwiping.value = false;\n })\n ];\n tryOnMounted(() => {\n var _a, _b, _c, _d, _e, _f, _g, _h;\n (_b = (_a = targetRef.value) == null ? void 0 : _a.style) == null ? void 0 : _b.setProperty(\"touch-action\", \"none\");\n if (disableTextSelect) {\n (_d = (_c = targetRef.value) == null ? void 0 : _c.style) == null ? void 0 : _d.setProperty(\"-webkit-user-select\", \"none\");\n (_f = (_e = targetRef.value) == null ? void 0 : _e.style) == null ? void 0 : _f.setProperty(\"-ms-user-select\", \"none\");\n (_h = (_g = targetRef.value) == null ? void 0 : _g.style) == null ? void 0 : _h.setProperty(\"user-select\", \"none\");\n }\n });\n const stop = () => stops.forEach((s) => s());\n return {\n isSwiping: readonly(isSwiping),\n direction: readonly(direction),\n posStart: readonly(posStart),\n posEnd: readonly(posEnd),\n distanceX,\n distanceY,\n stop\n };\n}\n\nfunction usePreferredColorScheme(options) {\n const isLight = useMediaQuery(\"(prefers-color-scheme: light)\", options);\n const isDark = useMediaQuery(\"(prefers-color-scheme: dark)\", options);\n return computed(() => {\n if (isDark.value)\n return \"dark\";\n if (isLight.value)\n return \"light\";\n return \"no-preference\";\n });\n}\n\nfunction usePreferredContrast(options) {\n const isMore = useMediaQuery(\"(prefers-contrast: more)\", options);\n const isLess = useMediaQuery(\"(prefers-contrast: less)\", options);\n const isCustom = useMediaQuery(\"(prefers-contrast: custom)\", options);\n return computed(() => {\n if (isMore.value)\n return \"more\";\n if (isLess.value)\n return \"less\";\n if (isCustom.value)\n return \"custom\";\n return \"no-preference\";\n });\n}\n\nfunction usePreferredLanguages(options = {}) {\n const { window = defaultWindow } = options;\n if (!window)\n return ref([\"en\"]);\n const navigator = window.navigator;\n const value = ref(navigator.languages);\n useEventListener(window, \"languagechange\", () => {\n value.value = navigator.languages;\n });\n return value;\n}\n\nfunction usePreferredReducedMotion(options) {\n const isReduced = useMediaQuery(\"(prefers-reduced-motion: reduce)\", options);\n return computed(() => {\n if (isReduced.value)\n return \"reduce\";\n return \"no-preference\";\n });\n}\n\nfunction usePrevious(value, initialValue) {\n const previous = shallowRef(initialValue);\n watch(\n toRef(value),\n (_, oldValue) => {\n previous.value = oldValue;\n },\n { flush: \"sync\" }\n );\n return readonly(previous);\n}\n\nconst topVarName = \"--vueuse-safe-area-top\";\nconst rightVarName = \"--vueuse-safe-area-right\";\nconst bottomVarName = \"--vueuse-safe-area-bottom\";\nconst leftVarName = \"--vueuse-safe-area-left\";\nfunction useScreenSafeArea() {\n const top = ref(\"\");\n const right = ref(\"\");\n const bottom = ref(\"\");\n const left = ref(\"\");\n if (isClient) {\n const topCssVar = useCssVar(topVarName);\n const rightCssVar = useCssVar(rightVarName);\n const bottomCssVar = useCssVar(bottomVarName);\n const leftCssVar = useCssVar(leftVarName);\n topCssVar.value = \"env(safe-area-inset-top, 0px)\";\n rightCssVar.value = \"env(safe-area-inset-right, 0px)\";\n bottomCssVar.value = \"env(safe-area-inset-bottom, 0px)\";\n leftCssVar.value = \"env(safe-area-inset-left, 0px)\";\n update();\n useEventListener(\"resize\", useDebounceFn(update));\n }\n function update() {\n top.value = getValue(topVarName);\n right.value = getValue(rightVarName);\n bottom.value = getValue(bottomVarName);\n left.value = getValue(leftVarName);\n }\n return {\n top,\n right,\n bottom,\n left,\n update\n };\n}\nfunction getValue(position) {\n return getComputedStyle(document.documentElement).getPropertyValue(position);\n}\n\nfunction useScriptTag(src, onLoaded = noop, options = {}) {\n const {\n immediate = true,\n manual = false,\n type = \"text/javascript\",\n async = true,\n crossOrigin,\n referrerPolicy,\n noModule,\n defer,\n document = defaultDocument,\n attrs = {}\n } = options;\n const scriptTag = ref(null);\n let _promise = null;\n const loadScript = (waitForScriptLoad) => new Promise((resolve, reject) => {\n const resolveWithElement = (el2) => {\n scriptTag.value = el2;\n resolve(el2);\n return el2;\n };\n if (!document) {\n resolve(false);\n return;\n }\n let shouldAppend = false;\n let el = document.querySelector(`script[src=\"${toValue(src)}\"]`);\n if (!el) {\n el = document.createElement(\"script\");\n el.type = type;\n el.async = async;\n el.src = toValue(src);\n if (defer)\n el.defer = defer;\n if (crossOrigin)\n el.crossOrigin = crossOrigin;\n if (noModule)\n el.noModule = noModule;\n if (referrerPolicy)\n el.referrerPolicy = referrerPolicy;\n Object.entries(attrs).forEach(([name, value]) => el == null ? void 0 : el.setAttribute(name, value));\n shouldAppend = true;\n } else if (el.hasAttribute(\"data-loaded\")) {\n resolveWithElement(el);\n }\n el.addEventListener(\"error\", (event) => reject(event));\n el.addEventListener(\"abort\", (event) => reject(event));\n el.addEventListener(\"load\", () => {\n el.setAttribute(\"data-loaded\", \"true\");\n onLoaded(el);\n resolveWithElement(el);\n });\n if (shouldAppend)\n el = document.head.appendChild(el);\n if (!waitForScriptLoad)\n resolveWithElement(el);\n });\n const load = (waitForScriptLoad = true) => {\n if (!_promise)\n _promise = loadScript(waitForScriptLoad);\n return _promise;\n };\n const unload = () => {\n if (!document)\n return;\n _promise = null;\n if (scriptTag.value)\n scriptTag.value = null;\n const el = document.querySelector(`script[src=\"${toValue(src)}\"]`);\n if (el)\n document.head.removeChild(el);\n };\n if (immediate && !manual)\n tryOnMounted(load);\n if (!manual)\n tryOnUnmounted(unload);\n return { scriptTag, load, unload };\n}\n\nfunction checkOverflowScroll(ele) {\n const style = window.getComputedStyle(ele);\n if (style.overflowX === \"scroll\" || style.overflowY === \"scroll\" || style.overflowX === \"auto\" && ele.clientWidth < ele.scrollWidth || style.overflowY === \"auto\" && ele.clientHeight < ele.scrollHeight) {\n return true;\n } else {\n const parent = ele.parentNode;\n if (!parent || parent.tagName === \"BODY\")\n return false;\n return checkOverflowScroll(parent);\n }\n}\nfunction preventDefault(rawEvent) {\n const e = rawEvent || window.event;\n const _target = e.target;\n if (checkOverflowScroll(_target))\n return false;\n if (e.touches.length > 1)\n return true;\n if (e.preventDefault)\n e.preventDefault();\n return false;\n}\nconst elInitialOverflow = /* @__PURE__ */ new WeakMap();\nfunction useScrollLock(element, initialState = false) {\n const isLocked = ref(initialState);\n let stopTouchMoveListener = null;\n let initialOverflow = \"\";\n watch(toRef(element), (el) => {\n const target = resolveElement(toValue(el));\n if (target) {\n const ele = target;\n if (!elInitialOverflow.get(ele))\n elInitialOverflow.set(ele, ele.style.overflow);\n if (ele.style.overflow !== \"hidden\")\n initialOverflow = ele.style.overflow;\n if (ele.style.overflow === \"hidden\")\n return isLocked.value = true;\n if (isLocked.value)\n return ele.style.overflow = \"hidden\";\n }\n }, {\n immediate: true\n });\n const lock = () => {\n const el = resolveElement(toValue(element));\n if (!el || isLocked.value)\n return;\n if (isIOS) {\n stopTouchMoveListener = useEventListener(\n el,\n \"touchmove\",\n (e) => {\n preventDefault(e);\n },\n { passive: false }\n );\n }\n el.style.overflow = \"hidden\";\n isLocked.value = true;\n };\n const unlock = () => {\n const el = resolveElement(toValue(element));\n if (!el || !isLocked.value)\n return;\n if (isIOS)\n stopTouchMoveListener == null ? void 0 : stopTouchMoveListener();\n el.style.overflow = initialOverflow;\n elInitialOverflow.delete(el);\n isLocked.value = false;\n };\n tryOnScopeDispose(unlock);\n return computed({\n get() {\n return isLocked.value;\n },\n set(v) {\n if (v)\n lock();\n else unlock();\n }\n });\n}\n\nfunction useSessionStorage(key, initialValue, options = {}) {\n const { window = defaultWindow } = options;\n return useStorage(key, initialValue, window == null ? void 0 : window.sessionStorage, options);\n}\n\nfunction useShare(shareOptions = {}, options = {}) {\n const { navigator = defaultNavigator } = options;\n const _navigator = navigator;\n const isSupported = useSupported(() => _navigator && \"canShare\" in _navigator);\n const share = async (overrideOptions = {}) => {\n if (isSupported.value) {\n const data = {\n ...toValue(shareOptions),\n ...toValue(overrideOptions)\n };\n let granted = true;\n if (data.files && _navigator.canShare)\n granted = _navigator.canShare({ files: data.files });\n if (granted)\n return _navigator.share(data);\n }\n };\n return {\n isSupported,\n share\n };\n}\n\nconst defaultSortFn = (source, compareFn) => source.sort(compareFn);\nconst defaultCompare = (a, b) => a - b;\nfunction useSorted(...args) {\n var _a, _b, _c, _d;\n const [source] = args;\n let compareFn = defaultCompare;\n let options = {};\n if (args.length === 2) {\n if (typeof args[1] === \"object\") {\n options = args[1];\n compareFn = (_a = options.compareFn) != null ? _a : defaultCompare;\n } else {\n compareFn = (_b = args[1]) != null ? _b : defaultCompare;\n }\n } else if (args.length > 2) {\n compareFn = (_c = args[1]) != null ? _c : defaultCompare;\n options = (_d = args[2]) != null ? _d : {};\n }\n const {\n dirty = false,\n sortFn = defaultSortFn\n } = options;\n if (!dirty)\n return computed(() => sortFn([...toValue(source)], compareFn));\n watchEffect(() => {\n const result = sortFn(toValue(source), compareFn);\n if (isRef(source))\n source.value = result;\n else\n source.splice(0, source.length, ...result);\n });\n return source;\n}\n\nfunction useSpeechRecognition(options = {}) {\n const {\n interimResults = true,\n continuous = true,\n maxAlternatives = 1,\n window = defaultWindow\n } = options;\n const lang = toRef(options.lang || \"en-US\");\n const isListening = ref(false);\n const isFinal = ref(false);\n const result = ref(\"\");\n const error = shallowRef(void 0);\n const toggle = (value = !isListening.value) => {\n isListening.value = value;\n };\n const start = () => {\n isListening.value = true;\n };\n const stop = () => {\n isListening.value = false;\n };\n const SpeechRecognition = window && (window.SpeechRecognition || window.webkitSpeechRecognition);\n const isSupported = useSupported(() => SpeechRecognition);\n let recognition;\n if (isSupported.value) {\n recognition = new SpeechRecognition();\n recognition.continuous = continuous;\n recognition.interimResults = interimResults;\n recognition.lang = toValue(lang);\n recognition.maxAlternatives = maxAlternatives;\n recognition.onstart = () => {\n isFinal.value = false;\n };\n watch(lang, (lang2) => {\n if (recognition && !isListening.value)\n recognition.lang = lang2;\n });\n recognition.onresult = (event) => {\n const currentResult = event.results[event.resultIndex];\n const { transcript } = currentResult[0];\n isFinal.value = currentResult.isFinal;\n result.value = transcript;\n error.value = void 0;\n };\n recognition.onerror = (event) => {\n error.value = event;\n };\n recognition.onend = () => {\n isListening.value = false;\n recognition.lang = toValue(lang);\n };\n watch(isListening, () => {\n if (isListening.value)\n recognition.start();\n else\n recognition.stop();\n });\n }\n tryOnScopeDispose(() => {\n isListening.value = false;\n });\n return {\n isSupported,\n isListening,\n isFinal,\n recognition,\n result,\n error,\n toggle,\n start,\n stop\n };\n}\n\nfunction useSpeechSynthesis(text, options = {}) {\n const {\n pitch = 1,\n rate = 1,\n volume = 1,\n window = defaultWindow\n } = options;\n const synth = window && window.speechSynthesis;\n const isSupported = useSupported(() => synth);\n const isPlaying = ref(false);\n const status = ref(\"init\");\n const spokenText = toRef(text || \"\");\n const lang = toRef(options.lang || \"en-US\");\n const error = shallowRef(void 0);\n const toggle = (value = !isPlaying.value) => {\n isPlaying.value = value;\n };\n const bindEventsForUtterance = (utterance2) => {\n utterance2.lang = toValue(lang);\n utterance2.voice = toValue(options.voice) || null;\n utterance2.pitch = toValue(pitch);\n utterance2.rate = toValue(rate);\n utterance2.volume = volume;\n utterance2.onstart = () => {\n isPlaying.value = true;\n status.value = \"play\";\n };\n utterance2.onpause = () => {\n isPlaying.value = false;\n status.value = \"pause\";\n };\n utterance2.onresume = () => {\n isPlaying.value = true;\n status.value = \"play\";\n };\n utterance2.onend = () => {\n isPlaying.value = false;\n status.value = \"end\";\n };\n utterance2.onerror = (event) => {\n error.value = event;\n };\n };\n const utterance = computed(() => {\n isPlaying.value = false;\n status.value = \"init\";\n const newUtterance = new SpeechSynthesisUtterance(spokenText.value);\n bindEventsForUtterance(newUtterance);\n return newUtterance;\n });\n const speak = () => {\n synth.cancel();\n if (utterance)\n synth.speak(utterance.value);\n };\n const stop = () => {\n synth.cancel();\n isPlaying.value = false;\n };\n if (isSupported.value) {\n bindEventsForUtterance(utterance.value);\n watch(lang, (lang2) => {\n if (utterance.value && !isPlaying.value)\n utterance.value.lang = lang2;\n });\n if (options.voice) {\n watch(options.voice, () => {\n synth.cancel();\n });\n }\n watch(isPlaying, () => {\n if (isPlaying.value)\n synth.resume();\n else\n synth.pause();\n });\n }\n tryOnScopeDispose(() => {\n isPlaying.value = false;\n });\n return {\n isSupported,\n isPlaying,\n status,\n utterance,\n error,\n stop,\n toggle,\n speak\n };\n}\n\nfunction useStepper(steps, initialStep) {\n const stepsRef = ref(steps);\n const stepNames = computed(() => Array.isArray(stepsRef.value) ? stepsRef.value : Object.keys(stepsRef.value));\n const index = ref(stepNames.value.indexOf(initialStep != null ? initialStep : stepNames.value[0]));\n const current = computed(() => at(index.value));\n const isFirst = computed(() => index.value === 0);\n const isLast = computed(() => index.value === stepNames.value.length - 1);\n const next = computed(() => stepNames.value[index.value + 1]);\n const previous = computed(() => stepNames.value[index.value - 1]);\n function at(index2) {\n if (Array.isArray(stepsRef.value))\n return stepsRef.value[index2];\n return stepsRef.value[stepNames.value[index2]];\n }\n function get(step) {\n if (!stepNames.value.includes(step))\n return;\n return at(stepNames.value.indexOf(step));\n }\n function goTo(step) {\n if (stepNames.value.includes(step))\n index.value = stepNames.value.indexOf(step);\n }\n function goToNext() {\n if (isLast.value)\n return;\n index.value++;\n }\n function goToPrevious() {\n if (isFirst.value)\n return;\n index.value--;\n }\n function goBackTo(step) {\n if (isAfter(step))\n goTo(step);\n }\n function isNext(step) {\n return stepNames.value.indexOf(step) === index.value + 1;\n }\n function isPrevious(step) {\n return stepNames.value.indexOf(step) === index.value - 1;\n }\n function isCurrent(step) {\n return stepNames.value.indexOf(step) === index.value;\n }\n function isBefore(step) {\n return index.value < stepNames.value.indexOf(step);\n }\n function isAfter(step) {\n return index.value > stepNames.value.indexOf(step);\n }\n return {\n steps: stepsRef,\n stepNames,\n index,\n current,\n next,\n previous,\n isFirst,\n isLast,\n at,\n get,\n goTo,\n goToNext,\n goToPrevious,\n goBackTo,\n isNext,\n isPrevious,\n isCurrent,\n isBefore,\n isAfter\n };\n}\n\nfunction useStorageAsync(key, initialValue, storage, options = {}) {\n var _a;\n const {\n flush = \"pre\",\n deep = true,\n listenToStorageChanges = true,\n writeDefaults = true,\n mergeDefaults = false,\n shallow,\n window = defaultWindow,\n eventFilter,\n onError = (e) => {\n console.error(e);\n }\n } = options;\n const rawInit = toValue(initialValue);\n const type = guessSerializerType(rawInit);\n const data = (shallow ? shallowRef : ref)(initialValue);\n const serializer = (_a = options.serializer) != null ? _a : StorageSerializers[type];\n if (!storage) {\n try {\n storage = getSSRHandler(\"getDefaultStorageAsync\", () => {\n var _a2;\n return (_a2 = defaultWindow) == null ? void 0 : _a2.localStorage;\n })();\n } catch (e) {\n onError(e);\n }\n }\n async function read(event) {\n if (!storage || event && event.key !== key)\n return;\n try {\n const rawValue = event ? event.newValue : await storage.getItem(key);\n if (rawValue == null) {\n data.value = rawInit;\n if (writeDefaults && rawInit !== null)\n await storage.setItem(key, await serializer.write(rawInit));\n } else if (mergeDefaults) {\n const value = await serializer.read(rawValue);\n if (typeof mergeDefaults === \"function\")\n data.value = mergeDefaults(value, rawInit);\n else if (type === \"object\" && !Array.isArray(value))\n data.value = { ...rawInit, ...value };\n else data.value = value;\n } else {\n data.value = await serializer.read(rawValue);\n }\n } catch (e) {\n onError(e);\n }\n }\n read();\n if (window && listenToStorageChanges)\n useEventListener(window, \"storage\", (e) => Promise.resolve().then(() => read(e)));\n if (storage) {\n watchWithFilter(\n data,\n async () => {\n try {\n if (data.value == null)\n await storage.removeItem(key);\n else\n await storage.setItem(key, await serializer.write(data.value));\n } catch (e) {\n onError(e);\n }\n },\n {\n flush,\n deep,\n eventFilter\n }\n );\n }\n return data;\n}\n\nlet _id = 0;\nfunction useStyleTag(css, options = {}) {\n const isLoaded = ref(false);\n const {\n document = defaultDocument,\n immediate = true,\n manual = false,\n id = `vueuse_styletag_${++_id}`\n } = options;\n const cssRef = ref(css);\n let stop = () => {\n };\n const load = () => {\n if (!document)\n return;\n const el = document.getElementById(id) || document.createElement(\"style\");\n if (!el.isConnected) {\n el.id = id;\n if (options.media)\n el.media = options.media;\n document.head.appendChild(el);\n }\n if (isLoaded.value)\n return;\n stop = watch(\n cssRef,\n (value) => {\n el.textContent = value;\n },\n { immediate: true }\n );\n isLoaded.value = true;\n };\n const unload = () => {\n if (!document || !isLoaded.value)\n return;\n stop();\n document.head.removeChild(document.getElementById(id));\n isLoaded.value = false;\n };\n if (immediate && !manual)\n tryOnMounted(load);\n if (!manual)\n tryOnScopeDispose(unload);\n return {\n id,\n css: cssRef,\n unload,\n load,\n isLoaded: readonly(isLoaded)\n };\n}\n\nfunction useSwipe(target, options = {}) {\n const {\n threshold = 50,\n onSwipe,\n onSwipeEnd,\n onSwipeStart,\n passive = true,\n window = defaultWindow\n } = options;\n const coordsStart = reactive({ x: 0, y: 0 });\n const coordsEnd = reactive({ x: 0, y: 0 });\n const diffX = computed(() => coordsStart.x - coordsEnd.x);\n const diffY = computed(() => coordsStart.y - coordsEnd.y);\n const { max, abs } = Math;\n const isThresholdExceeded = computed(() => max(abs(diffX.value), abs(diffY.value)) >= threshold);\n const isSwiping = ref(false);\n const direction = computed(() => {\n if (!isThresholdExceeded.value)\n return \"none\";\n if (abs(diffX.value) > abs(diffY.value)) {\n return diffX.value > 0 ? \"left\" : \"right\";\n } else {\n return diffY.value > 0 ? \"up\" : \"down\";\n }\n });\n const getTouchEventCoords = (e) => [e.touches[0].clientX, e.touches[0].clientY];\n const updateCoordsStart = (x, y) => {\n coordsStart.x = x;\n coordsStart.y = y;\n };\n const updateCoordsEnd = (x, y) => {\n coordsEnd.x = x;\n coordsEnd.y = y;\n };\n let listenerOptions;\n const isPassiveEventSupported = checkPassiveEventSupport(window == null ? void 0 : window.document);\n if (!passive)\n listenerOptions = isPassiveEventSupported ? { passive: false, capture: true } : { capture: true };\n else\n listenerOptions = isPassiveEventSupported ? { passive: true } : { capture: false };\n const onTouchEnd = (e) => {\n if (isSwiping.value)\n onSwipeEnd == null ? void 0 : onSwipeEnd(e, direction.value);\n isSwiping.value = false;\n };\n const stops = [\n useEventListener(target, \"touchstart\", (e) => {\n if (e.touches.length !== 1)\n return;\n const [x, y] = getTouchEventCoords(e);\n updateCoordsStart(x, y);\n updateCoordsEnd(x, y);\n onSwipeStart == null ? void 0 : onSwipeStart(e);\n }, listenerOptions),\n useEventListener(target, \"touchmove\", (e) => {\n if (e.touches.length !== 1)\n return;\n const [x, y] = getTouchEventCoords(e);\n updateCoordsEnd(x, y);\n if (listenerOptions.capture && !listenerOptions.passive && Math.abs(diffX.value) > Math.abs(diffY.value))\n e.preventDefault();\n if (!isSwiping.value && isThresholdExceeded.value)\n isSwiping.value = true;\n if (isSwiping.value)\n onSwipe == null ? void 0 : onSwipe(e);\n }, listenerOptions),\n useEventListener(target, [\"touchend\", \"touchcancel\"], onTouchEnd, listenerOptions)\n ];\n const stop = () => stops.forEach((s) => s());\n return {\n isPassiveEventSupported,\n isSwiping,\n direction,\n coordsStart,\n coordsEnd,\n lengthX: diffX,\n lengthY: diffY,\n stop\n };\n}\nfunction checkPassiveEventSupport(document) {\n if (!document)\n return false;\n let supportsPassive = false;\n const optionsBlock = {\n get passive() {\n supportsPassive = true;\n return false;\n }\n };\n document.addEventListener(\"x\", noop, optionsBlock);\n document.removeEventListener(\"x\", noop);\n return supportsPassive;\n}\n\nfunction useTemplateRefsList() {\n const refs = ref([]);\n refs.value.set = (el) => {\n if (el)\n refs.value.push(el);\n };\n onBeforeUpdate(() => {\n refs.value.length = 0;\n });\n return refs;\n}\n\nfunction useTextDirection(options = {}) {\n const {\n document = defaultDocument,\n selector = \"html\",\n observe = false,\n initialValue = \"ltr\"\n } = options;\n function getValue() {\n var _a, _b;\n return (_b = (_a = document == null ? void 0 : document.querySelector(selector)) == null ? void 0 : _a.getAttribute(\"dir\")) != null ? _b : initialValue;\n }\n const dir = ref(getValue());\n tryOnMounted(() => dir.value = getValue());\n if (observe && document) {\n useMutationObserver(\n document.querySelector(selector),\n () => dir.value = getValue(),\n { attributes: true }\n );\n }\n return computed({\n get() {\n return dir.value;\n },\n set(v) {\n var _a, _b;\n dir.value = v;\n if (!document)\n return;\n if (dir.value)\n (_a = document.querySelector(selector)) == null ? void 0 : _a.setAttribute(\"dir\", dir.value);\n else\n (_b = document.querySelector(selector)) == null ? void 0 : _b.removeAttribute(\"dir\");\n }\n });\n}\n\nfunction getRangesFromSelection(selection) {\n var _a;\n const rangeCount = (_a = selection.rangeCount) != null ? _a : 0;\n return Array.from({ length: rangeCount }, (_, i) => selection.getRangeAt(i));\n}\nfunction useTextSelection(options = {}) {\n const {\n window = defaultWindow\n } = options;\n const selection = ref(null);\n const text = computed(() => {\n var _a, _b;\n return (_b = (_a = selection.value) == null ? void 0 : _a.toString()) != null ? _b : \"\";\n });\n const ranges = computed(() => selection.value ? getRangesFromSelection(selection.value) : []);\n const rects = computed(() => ranges.value.map((range) => range.getBoundingClientRect()));\n function onSelectionChange() {\n selection.value = null;\n if (window)\n selection.value = window.getSelection();\n }\n if (window)\n useEventListener(window.document, \"selectionchange\", onSelectionChange);\n return {\n text,\n rects,\n ranges,\n selection\n };\n}\n\nfunction useTextareaAutosize(options) {\n var _a;\n const textarea = ref(options == null ? void 0 : options.element);\n const input = ref(options == null ? void 0 : options.input);\n const styleProp = (_a = options == null ? void 0 : options.styleProp) != null ? _a : \"height\";\n const textareaScrollHeight = ref(1);\n const textareaOldWidth = ref(0);\n function triggerResize() {\n var _a2;\n if (!textarea.value)\n return;\n let height = \"\";\n textarea.value.style[styleProp] = \"1px\";\n textareaScrollHeight.value = (_a2 = textarea.value) == null ? void 0 : _a2.scrollHeight;\n const _styleTarget = toValue(options == null ? void 0 : options.styleTarget);\n if (_styleTarget)\n _styleTarget.style[styleProp] = `${textareaScrollHeight.value}px`;\n else\n height = `${textareaScrollHeight.value}px`;\n textarea.value.style[styleProp] = height;\n }\n watch([input, textarea], () => nextTick(triggerResize), { immediate: true });\n watch(textareaScrollHeight, () => {\n var _a2;\n return (_a2 = options == null ? void 0 : options.onResize) == null ? void 0 : _a2.call(options);\n });\n useResizeObserver(textarea, ([{ contentRect }]) => {\n if (textareaOldWidth.value === contentRect.width)\n return;\n textareaOldWidth.value = contentRect.width;\n triggerResize();\n });\n if (options == null ? void 0 : options.watch)\n watch(options.watch, triggerResize, { immediate: true, deep: true });\n return {\n textarea,\n input,\n triggerResize\n };\n}\n\nfunction useThrottledRefHistory(source, options = {}) {\n const { throttle = 200, trailing = true } = options;\n const filter = throttleFilter(throttle, trailing);\n const history = useRefHistory(source, { ...options, eventFilter: filter });\n return {\n ...history\n };\n}\n\nconst DEFAULT_UNITS = [\n { max: 6e4, value: 1e3, name: \"second\" },\n { max: 276e4, value: 6e4, name: \"minute\" },\n { max: 72e6, value: 36e5, name: \"hour\" },\n { max: 5184e5, value: 864e5, name: \"day\" },\n { max: 24192e5, value: 6048e5, name: \"week\" },\n { max: 28512e6, value: 2592e6, name: \"month\" },\n { max: Number.POSITIVE_INFINITY, value: 31536e6, name: \"year\" }\n];\nconst DEFAULT_MESSAGES = {\n justNow: \"just now\",\n past: (n) => n.match(/\\d/) ? `${n} ago` : n,\n future: (n) => n.match(/\\d/) ? `in ${n}` : n,\n month: (n, past) => n === 1 ? past ? \"last month\" : \"next month\" : `${n} month${n > 1 ? \"s\" : \"\"}`,\n year: (n, past) => n === 1 ? past ? \"last year\" : \"next year\" : `${n} year${n > 1 ? \"s\" : \"\"}`,\n day: (n, past) => n === 1 ? past ? \"yesterday\" : \"tomorrow\" : `${n} day${n > 1 ? \"s\" : \"\"}`,\n week: (n, past) => n === 1 ? past ? \"last week\" : \"next week\" : `${n} week${n > 1 ? \"s\" : \"\"}`,\n hour: (n) => `${n} hour${n > 1 ? \"s\" : \"\"}`,\n minute: (n) => `${n} minute${n > 1 ? \"s\" : \"\"}`,\n second: (n) => `${n} second${n > 1 ? \"s\" : \"\"}`,\n invalid: \"\"\n};\nfunction DEFAULT_FORMATTER(date) {\n return date.toISOString().slice(0, 10);\n}\nfunction useTimeAgo(time, options = {}) {\n const {\n controls: exposeControls = false,\n updateInterval = 3e4\n } = options;\n const { now, ...controls } = useNow({ interval: updateInterval, controls: true });\n const timeAgo = computed(() => formatTimeAgo(new Date(toValue(time)), options, toValue(now)));\n if (exposeControls) {\n return {\n timeAgo,\n ...controls\n };\n } else {\n return timeAgo;\n }\n}\nfunction formatTimeAgo(from, options = {}, now = Date.now()) {\n var _a;\n const {\n max,\n messages = DEFAULT_MESSAGES,\n fullDateFormatter = DEFAULT_FORMATTER,\n units = DEFAULT_UNITS,\n showSecond = false,\n rounding = \"round\"\n } = options;\n const roundFn = typeof rounding === \"number\" ? (n) => +n.toFixed(rounding) : Math[rounding];\n const diff = +now - +from;\n const absDiff = Math.abs(diff);\n function getValue(diff2, unit) {\n return roundFn(Math.abs(diff2) / unit.value);\n }\n function format(diff2, unit) {\n const val = getValue(diff2, unit);\n const past = diff2 > 0;\n const str = applyFormat(unit.name, val, past);\n return applyFormat(past ? \"past\" : \"future\", str, past);\n }\n function applyFormat(name, val, isPast) {\n const formatter = messages[name];\n if (typeof formatter === \"function\")\n return formatter(val, isPast);\n return formatter.replace(\"{0}\", val.toString());\n }\n if (absDiff < 6e4 && !showSecond)\n return messages.justNow;\n if (typeof max === \"number\" && absDiff > max)\n return fullDateFormatter(new Date(from));\n if (typeof max === \"string\") {\n const unitMax = (_a = units.find((i) => i.name === max)) == null ? void 0 : _a.max;\n if (unitMax && absDiff > unitMax)\n return fullDateFormatter(new Date(from));\n }\n for (const [idx, unit] of units.entries()) {\n const val = getValue(diff, unit);\n if (val <= 0 && units[idx - 1])\n return format(diff, units[idx - 1]);\n if (absDiff < unit.max)\n return format(diff, unit);\n }\n return messages.invalid;\n}\n\nfunction useTimeoutPoll(fn, interval, timeoutPollOptions) {\n const { start } = useTimeoutFn(loop, interval, { immediate: false });\n const isActive = ref(false);\n async function loop() {\n if (!isActive.value)\n return;\n await fn();\n start();\n }\n function resume() {\n if (!isActive.value) {\n isActive.value = true;\n loop();\n }\n }\n function pause() {\n isActive.value = false;\n }\n if (timeoutPollOptions == null ? void 0 : timeoutPollOptions.immediate)\n resume();\n tryOnScopeDispose(pause);\n return {\n isActive,\n pause,\n resume\n };\n}\n\nfunction useTimestamp(options = {}) {\n const {\n controls: exposeControls = false,\n offset = 0,\n immediate = true,\n interval = \"requestAnimationFrame\",\n callback\n } = options;\n const ts = ref(timestamp() + offset);\n const update = () => ts.value = timestamp() + offset;\n const cb = callback ? () => {\n update();\n callback(ts.value);\n } : update;\n const controls = interval === \"requestAnimationFrame\" ? useRafFn(cb, { immediate }) : useIntervalFn(cb, interval, { immediate });\n if (exposeControls) {\n return {\n timestamp: ts,\n ...controls\n };\n } else {\n return ts;\n }\n}\n\nfunction useTitle(newTitle = null, options = {}) {\n var _a, _b, _c;\n const {\n document = defaultDocument,\n restoreOnUnmount = (t) => t\n } = options;\n const originalTitle = (_a = document == null ? void 0 : document.title) != null ? _a : \"\";\n const title = toRef((_b = newTitle != null ? newTitle : document == null ? void 0 : document.title) != null ? _b : null);\n const isReadonly = newTitle && typeof newTitle === \"function\";\n function format(t) {\n if (!(\"titleTemplate\" in options))\n return t;\n const template = options.titleTemplate || \"%s\";\n return typeof template === \"function\" ? template(t) : toValue(template).replace(/%s/g, t);\n }\n watch(\n title,\n (t, o) => {\n if (t !== o && document)\n document.title = format(typeof t === \"string\" ? t : \"\");\n },\n { immediate: true }\n );\n if (options.observe && !options.titleTemplate && document && !isReadonly) {\n useMutationObserver(\n (_c = document.head) == null ? void 0 : _c.querySelector(\"title\"),\n () => {\n if (document && document.title !== title.value)\n title.value = format(document.title);\n },\n { childList: true }\n );\n }\n tryOnBeforeUnmount(() => {\n if (restoreOnUnmount) {\n const restoredTitle = restoreOnUnmount(originalTitle, title.value || \"\");\n if (restoredTitle != null && document)\n document.title = restoredTitle;\n }\n });\n return title;\n}\n\nconst _TransitionPresets = {\n easeInSine: [0.12, 0, 0.39, 0],\n easeOutSine: [0.61, 1, 0.88, 1],\n easeInOutSine: [0.37, 0, 0.63, 1],\n easeInQuad: [0.11, 0, 0.5, 0],\n easeOutQuad: [0.5, 1, 0.89, 1],\n easeInOutQuad: [0.45, 0, 0.55, 1],\n easeInCubic: [0.32, 0, 0.67, 0],\n easeOutCubic: [0.33, 1, 0.68, 1],\n easeInOutCubic: [0.65, 0, 0.35, 1],\n easeInQuart: [0.5, 0, 0.75, 0],\n easeOutQuart: [0.25, 1, 0.5, 1],\n easeInOutQuart: [0.76, 0, 0.24, 1],\n easeInQuint: [0.64, 0, 0.78, 0],\n easeOutQuint: [0.22, 1, 0.36, 1],\n easeInOutQuint: [0.83, 0, 0.17, 1],\n easeInExpo: [0.7, 0, 0.84, 0],\n easeOutExpo: [0.16, 1, 0.3, 1],\n easeInOutExpo: [0.87, 0, 0.13, 1],\n easeInCirc: [0.55, 0, 1, 0.45],\n easeOutCirc: [0, 0.55, 0.45, 1],\n easeInOutCirc: [0.85, 0, 0.15, 1],\n easeInBack: [0.36, 0, 0.66, -0.56],\n easeOutBack: [0.34, 1.56, 0.64, 1],\n easeInOutBack: [0.68, -0.6, 0.32, 1.6]\n};\nconst TransitionPresets = /* @__PURE__ */ Object.assign({}, { linear: identity }, _TransitionPresets);\nfunction createEasingFunction([p0, p1, p2, p3]) {\n const a = (a1, a2) => 1 - 3 * a2 + 3 * a1;\n const b = (a1, a2) => 3 * a2 - 6 * a1;\n const c = (a1) => 3 * a1;\n const calcBezier = (t, a1, a2) => ((a(a1, a2) * t + b(a1, a2)) * t + c(a1)) * t;\n const getSlope = (t, a1, a2) => 3 * a(a1, a2) * t * t + 2 * b(a1, a2) * t + c(a1);\n const getTforX = (x) => {\n let aGuessT = x;\n for (let i = 0; i < 4; ++i) {\n const currentSlope = getSlope(aGuessT, p0, p2);\n if (currentSlope === 0)\n return aGuessT;\n const currentX = calcBezier(aGuessT, p0, p2) - x;\n aGuessT -= currentX / currentSlope;\n }\n return aGuessT;\n };\n return (x) => p0 === p1 && p2 === p3 ? x : calcBezier(getTforX(x), p1, p3);\n}\nfunction lerp(a, b, alpha) {\n return a + alpha * (b - a);\n}\nfunction toVec(t) {\n return (typeof t === \"number\" ? [t] : t) || [];\n}\nfunction executeTransition(source, from, to, options = {}) {\n var _a, _b;\n const fromVal = toValue(from);\n const toVal = toValue(to);\n const v1 = toVec(fromVal);\n const v2 = toVec(toVal);\n const duration = (_a = toValue(options.duration)) != null ? _a : 1e3;\n const startedAt = Date.now();\n const endAt = Date.now() + duration;\n const trans = typeof options.transition === \"function\" ? options.transition : (_b = toValue(options.transition)) != null ? _b : identity;\n const ease = typeof trans === \"function\" ? trans : createEasingFunction(trans);\n return new Promise((resolve) => {\n source.value = fromVal;\n const tick = () => {\n var _a2;\n if ((_a2 = options.abort) == null ? void 0 : _a2.call(options)) {\n resolve();\n return;\n }\n const now = Date.now();\n const alpha = ease((now - startedAt) / duration);\n const arr = toVec(source.value).map((n, i) => lerp(v1[i], v2[i], alpha));\n if (Array.isArray(source.value))\n source.value = arr.map((n, i) => {\n var _a3, _b2;\n return lerp((_a3 = v1[i]) != null ? _a3 : 0, (_b2 = v2[i]) != null ? _b2 : 0, alpha);\n });\n else if (typeof source.value === \"number\")\n source.value = arr[0];\n if (now < endAt) {\n requestAnimationFrame(tick);\n } else {\n source.value = toVal;\n resolve();\n }\n };\n tick();\n });\n}\nfunction useTransition(source, options = {}) {\n let currentId = 0;\n const sourceVal = () => {\n const v = toValue(source);\n return typeof v === \"number\" ? v : v.map(toValue);\n };\n const outputRef = ref(sourceVal());\n watch(sourceVal, async (to) => {\n var _a, _b;\n if (toValue(options.disabled))\n return;\n const id = ++currentId;\n if (options.delay)\n await promiseTimeout(toValue(options.delay));\n if (id !== currentId)\n return;\n const toVal = Array.isArray(to) ? to.map(toValue) : toValue(to);\n (_a = options.onStarted) == null ? void 0 : _a.call(options);\n await executeTransition(outputRef, outputRef.value, toVal, {\n ...options,\n abort: () => {\n var _a2;\n return id !== currentId || ((_a2 = options.abort) == null ? void 0 : _a2.call(options));\n }\n });\n (_b = options.onFinished) == null ? void 0 : _b.call(options);\n }, { deep: true });\n watch(() => toValue(options.disabled), (disabled) => {\n if (disabled) {\n currentId++;\n outputRef.value = sourceVal();\n }\n });\n tryOnScopeDispose(() => {\n currentId++;\n });\n return computed(() => toValue(options.disabled) ? sourceVal() : outputRef.value);\n}\n\nfunction useUrlSearchParams(mode = \"history\", options = {}) {\n const {\n initialValue = {},\n removeNullishValues = true,\n removeFalsyValues = false,\n write: enableWrite = true,\n window = defaultWindow\n } = options;\n if (!window)\n return reactive(initialValue);\n const state = reactive({});\n function getRawParams() {\n if (mode === \"history\") {\n return window.location.search || \"\";\n } else if (mode === \"hash\") {\n const hash = window.location.hash || \"\";\n const index = hash.indexOf(\"?\");\n return index > 0 ? hash.slice(index) : \"\";\n } else {\n return (window.location.hash || \"\").replace(/^#/, \"\");\n }\n }\n function constructQuery(params) {\n const stringified = params.toString();\n if (mode === \"history\")\n return `${stringified ? `?${stringified}` : \"\"}${window.location.hash || \"\"}`;\n if (mode === \"hash-params\")\n return `${window.location.search || \"\"}${stringified ? `#${stringified}` : \"\"}`;\n const hash = window.location.hash || \"#\";\n const index = hash.indexOf(\"?\");\n if (index > 0)\n return `${window.location.search || \"\"}${hash.slice(0, index)}${stringified ? `?${stringified}` : \"\"}`;\n return `${window.location.search || \"\"}${hash}${stringified ? `?${stringified}` : \"\"}`;\n }\n function read() {\n return new URLSearchParams(getRawParams());\n }\n function updateState(params) {\n const unusedKeys = new Set(Object.keys(state));\n for (const key of params.keys()) {\n const paramsForKey = params.getAll(key);\n state[key] = paramsForKey.length > 1 ? paramsForKey : params.get(key) || \"\";\n unusedKeys.delete(key);\n }\n Array.from(unusedKeys).forEach((key) => delete state[key]);\n }\n const { pause, resume } = pausableWatch(\n state,\n () => {\n const params = new URLSearchParams(\"\");\n Object.keys(state).forEach((key) => {\n const mapEntry = state[key];\n if (Array.isArray(mapEntry))\n mapEntry.forEach((value) => params.append(key, value));\n else if (removeNullishValues && mapEntry == null)\n params.delete(key);\n else if (removeFalsyValues && !mapEntry)\n params.delete(key);\n else\n params.set(key, mapEntry);\n });\n write(params);\n },\n { deep: true }\n );\n function write(params, shouldUpdate) {\n pause();\n if (shouldUpdate)\n updateState(params);\n window.history.replaceState(\n window.history.state,\n window.document.title,\n window.location.pathname + constructQuery(params)\n );\n resume();\n }\n function onChanged() {\n if (!enableWrite)\n return;\n write(read(), true);\n }\n useEventListener(window, \"popstate\", onChanged, false);\n if (mode !== \"history\")\n useEventListener(window, \"hashchange\", onChanged, false);\n const initial = read();\n if (initial.keys().next().value)\n updateState(initial);\n else\n Object.assign(state, initialValue);\n return state;\n}\n\nfunction useUserMedia(options = {}) {\n var _a, _b;\n const enabled = ref((_a = options.enabled) != null ? _a : false);\n const autoSwitch = ref((_b = options.autoSwitch) != null ? _b : true);\n const constraints = ref(options.constraints);\n const { navigator = defaultNavigator } = options;\n const isSupported = useSupported(() => {\n var _a2;\n return (_a2 = navigator == null ? void 0 : navigator.mediaDevices) == null ? void 0 : _a2.getUserMedia;\n });\n const stream = shallowRef();\n function getDeviceOptions(type) {\n switch (type) {\n case \"video\": {\n if (constraints.value)\n return constraints.value.video || false;\n break;\n }\n case \"audio\": {\n if (constraints.value)\n return constraints.value.audio || false;\n break;\n }\n }\n }\n async function _start() {\n if (!isSupported.value || stream.value)\n return;\n stream.value = await navigator.mediaDevices.getUserMedia({\n video: getDeviceOptions(\"video\"),\n audio: getDeviceOptions(\"audio\")\n });\n return stream.value;\n }\n function _stop() {\n var _a2;\n (_a2 = stream.value) == null ? void 0 : _a2.getTracks().forEach((t) => t.stop());\n stream.value = void 0;\n }\n function stop() {\n _stop();\n enabled.value = false;\n }\n async function start() {\n await _start();\n if (stream.value)\n enabled.value = true;\n return stream.value;\n }\n async function restart() {\n _stop();\n return await start();\n }\n watch(\n enabled,\n (v) => {\n if (v)\n _start();\n else _stop();\n },\n { immediate: true }\n );\n watch(\n constraints,\n () => {\n if (autoSwitch.value && stream.value)\n restart();\n },\n { immediate: true }\n );\n tryOnScopeDispose(() => {\n stop();\n });\n return {\n isSupported,\n stream,\n start,\n stop,\n restart,\n constraints,\n enabled,\n autoSwitch\n };\n}\n\nfunction useVModel(props, key, emit, options = {}) {\n var _a, _b, _c;\n const {\n clone = false,\n passive = false,\n eventName,\n deep = false,\n defaultValue,\n shouldEmit\n } = options;\n const vm = getCurrentInstance();\n const _emit = emit || (vm == null ? void 0 : vm.emit) || ((_a = vm == null ? void 0 : vm.$emit) == null ? void 0 : _a.bind(vm)) || ((_c = (_b = vm == null ? void 0 : vm.proxy) == null ? void 0 : _b.$emit) == null ? void 0 : _c.bind(vm == null ? void 0 : vm.proxy));\n let event = eventName;\n if (!key) {\n key = \"modelValue\";\n }\n event = event || `update:${key.toString()}`;\n const cloneFn = (val) => !clone ? val : typeof clone === \"function\" ? clone(val) : cloneFnJSON(val);\n const getValue = () => isDef(props[key]) ? cloneFn(props[key]) : defaultValue;\n const triggerEmit = (value) => {\n if (shouldEmit) {\n if (shouldEmit(value))\n _emit(event, value);\n } else {\n _emit(event, value);\n }\n };\n if (passive) {\n const initialValue = getValue();\n const proxy = ref(initialValue);\n let isUpdating = false;\n watch(\n () => props[key],\n (v) => {\n if (!isUpdating) {\n isUpdating = true;\n proxy.value = cloneFn(v);\n nextTick(() => isUpdating = false);\n }\n }\n );\n watch(\n proxy,\n (v) => {\n if (!isUpdating && (v !== props[key] || deep))\n triggerEmit(v);\n },\n { deep }\n );\n return proxy;\n } else {\n return computed({\n get() {\n return getValue();\n },\n set(value) {\n triggerEmit(value);\n }\n });\n }\n}\n\nfunction useVModels(props, emit, options = {}) {\n const ret = {};\n for (const key in props) {\n ret[key] = useVModel(\n props,\n key,\n emit,\n options\n );\n }\n return ret;\n}\n\nfunction useVibrate(options) {\n const {\n pattern = [],\n interval = 0,\n navigator = defaultNavigator\n } = options || {};\n const isSupported = useSupported(() => typeof navigator !== \"undefined\" && \"vibrate\" in navigator);\n const patternRef = toRef(pattern);\n let intervalControls;\n const vibrate = (pattern2 = patternRef.value) => {\n if (isSupported.value)\n navigator.vibrate(pattern2);\n };\n const stop = () => {\n if (isSupported.value)\n navigator.vibrate(0);\n intervalControls == null ? void 0 : intervalControls.pause();\n };\n if (interval > 0) {\n intervalControls = useIntervalFn(\n vibrate,\n interval,\n {\n immediate: false,\n immediateCallback: false\n }\n );\n }\n return {\n isSupported,\n pattern,\n intervalControls,\n vibrate,\n stop\n };\n}\n\nfunction useVirtualList(list, options) {\n const { containerStyle, wrapperProps, scrollTo, calculateRange, currentList, containerRef } = \"itemHeight\" in options ? useVerticalVirtualList(options, list) : useHorizontalVirtualList(options, list);\n return {\n list: currentList,\n scrollTo,\n containerProps: {\n ref: containerRef,\n onScroll: () => {\n calculateRange();\n },\n style: containerStyle\n },\n wrapperProps\n };\n}\nfunction useVirtualListResources(list) {\n const containerRef = ref(null);\n const size = useElementSize(containerRef);\n const currentList = ref([]);\n const source = shallowRef(list);\n const state = ref({ start: 0, end: 10 });\n return { state, source, currentList, size, containerRef };\n}\nfunction createGetViewCapacity(state, source, itemSize) {\n return (containerSize) => {\n if (typeof itemSize === \"number\")\n return Math.ceil(containerSize / itemSize);\n const { start = 0 } = state.value;\n let sum = 0;\n let capacity = 0;\n for (let i = start; i < source.value.length; i++) {\n const size = itemSize(i);\n sum += size;\n capacity = i;\n if (sum > containerSize)\n break;\n }\n return capacity - start;\n };\n}\nfunction createGetOffset(source, itemSize) {\n return (scrollDirection) => {\n if (typeof itemSize === \"number\")\n return Math.floor(scrollDirection / itemSize) + 1;\n let sum = 0;\n let offset = 0;\n for (let i = 0; i < source.value.length; i++) {\n const size = itemSize(i);\n sum += size;\n if (sum >= scrollDirection) {\n offset = i;\n break;\n }\n }\n return offset + 1;\n };\n}\nfunction createCalculateRange(type, overscan, getOffset, getViewCapacity, { containerRef, state, currentList, source }) {\n return () => {\n const element = containerRef.value;\n if (element) {\n const offset = getOffset(type === \"vertical\" ? element.scrollTop : element.scrollLeft);\n const viewCapacity = getViewCapacity(type === \"vertical\" ? element.clientHeight : element.clientWidth);\n const from = offset - overscan;\n const to = offset + viewCapacity + overscan;\n state.value = {\n start: from < 0 ? 0 : from,\n end: to > source.value.length ? source.value.length : to\n };\n currentList.value = source.value.slice(state.value.start, state.value.end).map((ele, index) => ({\n data: ele,\n index: index + state.value.start\n }));\n }\n };\n}\nfunction createGetDistance(itemSize, source) {\n return (index) => {\n if (typeof itemSize === \"number\") {\n const size2 = index * itemSize;\n return size2;\n }\n const size = source.value.slice(0, index).reduce((sum, _, i) => sum + itemSize(i), 0);\n return size;\n };\n}\nfunction useWatchForSizes(size, list, containerRef, calculateRange) {\n watch([size.width, size.height, list, containerRef], () => {\n calculateRange();\n });\n}\nfunction createComputedTotalSize(itemSize, source) {\n return computed(() => {\n if (typeof itemSize === \"number\")\n return source.value.length * itemSize;\n return source.value.reduce((sum, _, index) => sum + itemSize(index), 0);\n });\n}\nconst scrollToDictionaryForElementScrollKey = {\n horizontal: \"scrollLeft\",\n vertical: \"scrollTop\"\n};\nfunction createScrollTo(type, calculateRange, getDistance, containerRef) {\n return (index) => {\n if (containerRef.value) {\n containerRef.value[scrollToDictionaryForElementScrollKey[type]] = getDistance(index);\n calculateRange();\n }\n };\n}\nfunction useHorizontalVirtualList(options, list) {\n const resources = useVirtualListResources(list);\n const { state, source, currentList, size, containerRef } = resources;\n const containerStyle = { overflowX: \"auto\" };\n const { itemWidth, overscan = 5 } = options;\n const getViewCapacity = createGetViewCapacity(state, source, itemWidth);\n const getOffset = createGetOffset(source, itemWidth);\n const calculateRange = createCalculateRange(\"horizontal\", overscan, getOffset, getViewCapacity, resources);\n const getDistanceLeft = createGetDistance(itemWidth, source);\n const offsetLeft = computed(() => getDistanceLeft(state.value.start));\n const totalWidth = createComputedTotalSize(itemWidth, source);\n useWatchForSizes(size, list, containerRef, calculateRange);\n const scrollTo = createScrollTo(\"horizontal\", calculateRange, getDistanceLeft, containerRef);\n const wrapperProps = computed(() => {\n return {\n style: {\n height: \"100%\",\n width: `${totalWidth.value - offsetLeft.value}px`,\n marginLeft: `${offsetLeft.value}px`,\n display: \"flex\"\n }\n };\n });\n return {\n scrollTo,\n calculateRange,\n wrapperProps,\n containerStyle,\n currentList,\n containerRef\n };\n}\nfunction useVerticalVirtualList(options, list) {\n const resources = useVirtualListResources(list);\n const { state, source, currentList, size, containerRef } = resources;\n const containerStyle = { overflowY: \"auto\" };\n const { itemHeight, overscan = 5 } = options;\n const getViewCapacity = createGetViewCapacity(state, source, itemHeight);\n const getOffset = createGetOffset(source, itemHeight);\n const calculateRange = createCalculateRange(\"vertical\", overscan, getOffset, getViewCapacity, resources);\n const getDistanceTop = createGetDistance(itemHeight, source);\n const offsetTop = computed(() => getDistanceTop(state.value.start));\n const totalHeight = createComputedTotalSize(itemHeight, source);\n useWatchForSizes(size, list, containerRef, calculateRange);\n const scrollTo = createScrollTo(\"vertical\", calculateRange, getDistanceTop, containerRef);\n const wrapperProps = computed(() => {\n return {\n style: {\n width: \"100%\",\n height: `${totalHeight.value - offsetTop.value}px`,\n marginTop: `${offsetTop.value}px`\n }\n };\n });\n return {\n calculateRange,\n scrollTo,\n containerStyle,\n wrapperProps,\n currentList,\n containerRef\n };\n}\n\nfunction useWakeLock(options = {}) {\n const {\n navigator = defaultNavigator,\n document = defaultDocument\n } = options;\n const requestedType = ref(false);\n const sentinel = shallowRef(null);\n const documentVisibility = useDocumentVisibility({ document });\n const isSupported = useSupported(() => navigator && \"wakeLock\" in navigator);\n const isActive = computed(() => !!sentinel.value && documentVisibility.value === \"visible\");\n if (isSupported.value) {\n useEventListener(sentinel, \"release\", () => {\n var _a, _b;\n requestedType.value = (_b = (_a = sentinel.value) == null ? void 0 : _a.type) != null ? _b : false;\n });\n whenever(\n () => documentVisibility.value === \"visible\" && (document == null ? void 0 : document.visibilityState) === \"visible\" && requestedType.value,\n (type) => {\n requestedType.value = false;\n forceRequest(type);\n }\n );\n }\n async function forceRequest(type) {\n var _a;\n await ((_a = sentinel.value) == null ? void 0 : _a.release());\n sentinel.value = isSupported.value ? await navigator.wakeLock.request(type) : null;\n }\n async function request(type) {\n if (documentVisibility.value === \"visible\")\n await forceRequest(type);\n else\n requestedType.value = type;\n }\n async function release() {\n requestedType.value = false;\n const s = sentinel.value;\n sentinel.value = null;\n await (s == null ? void 0 : s.release());\n }\n return {\n sentinel,\n isSupported,\n isActive,\n request,\n forceRequest,\n release\n };\n}\n\nfunction useWebNotification(options = {}) {\n const {\n window = defaultWindow,\n requestPermissions: _requestForPermissions = true\n } = options;\n const defaultWebNotificationOptions = options;\n const isSupported = useSupported(() => {\n if (!window || !(\"Notification\" in window))\n return false;\n try {\n new Notification(\"\");\n } catch (e) {\n return false;\n }\n return true;\n });\n const permissionGranted = ref(isSupported.value && \"permission\" in Notification && Notification.permission === \"granted\");\n const notification = ref(null);\n const ensurePermissions = async () => {\n if (!isSupported.value)\n return;\n if (!permissionGranted.value && Notification.permission !== \"denied\") {\n const result = await Notification.requestPermission();\n if (result === \"granted\")\n permissionGranted.value = true;\n }\n return permissionGranted.value;\n };\n const { on: onClick, trigger: clickTrigger } = createEventHook();\n const { on: onShow, trigger: showTrigger } = createEventHook();\n const { on: onError, trigger: errorTrigger } = createEventHook();\n const { on: onClose, trigger: closeTrigger } = createEventHook();\n const show = async (overrides) => {\n if (!isSupported.value || !permissionGranted.value)\n return;\n const options2 = Object.assign({}, defaultWebNotificationOptions, overrides);\n notification.value = new Notification(options2.title || \"\", options2);\n notification.value.onclick = clickTrigger;\n notification.value.onshow = showTrigger;\n notification.value.onerror = errorTrigger;\n notification.value.onclose = closeTrigger;\n return notification.value;\n };\n const close = () => {\n if (notification.value)\n notification.value.close();\n notification.value = null;\n };\n if (_requestForPermissions)\n tryOnMounted(ensurePermissions);\n tryOnScopeDispose(close);\n if (isSupported.value && window) {\n const document = window.document;\n useEventListener(document, \"visibilitychange\", (e) => {\n e.preventDefault();\n if (document.visibilityState === \"visible\") {\n close();\n }\n });\n }\n return {\n isSupported,\n notification,\n ensurePermissions,\n permissionGranted,\n show,\n close,\n onClick,\n onShow,\n onError,\n onClose\n };\n}\n\nconst DEFAULT_PING_MESSAGE = \"ping\";\nfunction resolveNestedOptions(options) {\n if (options === true)\n return {};\n return options;\n}\nfunction useWebSocket(url, options = {}) {\n const {\n onConnected,\n onDisconnected,\n onError,\n onMessage,\n immediate = true,\n autoClose = true,\n protocols = []\n } = options;\n const data = ref(null);\n const status = ref(\"CLOSED\");\n const wsRef = ref();\n const urlRef = toRef(url);\n let heartbeatPause;\n let heartbeatResume;\n let explicitlyClosed = false;\n let retried = 0;\n let bufferedData = [];\n let pongTimeoutWait;\n const _sendBuffer = () => {\n if (bufferedData.length && wsRef.value && status.value === \"OPEN\") {\n for (const buffer of bufferedData)\n wsRef.value.send(buffer);\n bufferedData = [];\n }\n };\n const resetHeartbeat = () => {\n clearTimeout(pongTimeoutWait);\n pongTimeoutWait = void 0;\n };\n const close = (code = 1e3, reason) => {\n if (!isClient || !wsRef.value)\n return;\n explicitlyClosed = true;\n resetHeartbeat();\n heartbeatPause == null ? void 0 : heartbeatPause();\n wsRef.value.close(code, reason);\n wsRef.value = void 0;\n };\n const send = (data2, useBuffer = true) => {\n if (!wsRef.value || status.value !== \"OPEN\") {\n if (useBuffer)\n bufferedData.push(data2);\n return false;\n }\n _sendBuffer();\n wsRef.value.send(data2);\n return true;\n };\n const _init = () => {\n if (explicitlyClosed || typeof urlRef.value === \"undefined\")\n return;\n const ws = new WebSocket(urlRef.value, protocols);\n wsRef.value = ws;\n status.value = \"CONNECTING\";\n ws.onopen = () => {\n status.value = \"OPEN\";\n retried = 0;\n onConnected == null ? void 0 : onConnected(ws);\n heartbeatResume == null ? void 0 : heartbeatResume();\n _sendBuffer();\n };\n ws.onclose = (ev) => {\n status.value = \"CLOSED\";\n onDisconnected == null ? void 0 : onDisconnected(ws, ev);\n if (!explicitlyClosed && options.autoReconnect && (wsRef.value == null || ws === wsRef.value)) {\n const {\n retries = -1,\n delay = 1e3,\n onFailed\n } = resolveNestedOptions(options.autoReconnect);\n if (typeof retries === \"number\" && (retries < 0 || retried < retries)) {\n retried += 1;\n setTimeout(_init, delay);\n } else if (typeof retries === \"function\" && retries()) {\n setTimeout(_init, delay);\n } else {\n onFailed == null ? void 0 : onFailed();\n }\n }\n };\n ws.onerror = (e) => {\n onError == null ? void 0 : onError(ws, e);\n };\n ws.onmessage = (e) => {\n if (options.heartbeat) {\n resetHeartbeat();\n const {\n message = DEFAULT_PING_MESSAGE,\n responseMessage = message\n } = resolveNestedOptions(options.heartbeat);\n if (e.data === responseMessage)\n return;\n }\n data.value = e.data;\n onMessage == null ? void 0 : onMessage(ws, e);\n };\n };\n if (options.heartbeat) {\n const {\n message = DEFAULT_PING_MESSAGE,\n interval = 1e3,\n pongTimeout = 1e3\n } = resolveNestedOptions(options.heartbeat);\n const { pause, resume } = useIntervalFn(\n () => {\n send(message, false);\n if (pongTimeoutWait != null)\n return;\n pongTimeoutWait = setTimeout(() => {\n close();\n explicitlyClosed = false;\n }, pongTimeout);\n },\n interval,\n { immediate: false }\n );\n heartbeatPause = pause;\n heartbeatResume = resume;\n }\n if (autoClose) {\n if (isClient)\n useEventListener(\"beforeunload\", () => close());\n tryOnScopeDispose(close);\n }\n const open = () => {\n if (!isClient && !isWorker)\n return;\n close();\n explicitlyClosed = false;\n retried = 0;\n _init();\n };\n if (immediate)\n open();\n watch(urlRef, open);\n return {\n data,\n status,\n close,\n send,\n open,\n ws: wsRef\n };\n}\n\nfunction useWebWorker(arg0, workerOptions, options) {\n const {\n window = defaultWindow\n } = options != null ? options : {};\n const data = ref(null);\n const worker = shallowRef();\n const post = (...args) => {\n if (!worker.value)\n return;\n worker.value.postMessage(...args);\n };\n const terminate = function terminate2() {\n if (!worker.value)\n return;\n worker.value.terminate();\n };\n if (window) {\n if (typeof arg0 === \"string\")\n worker.value = new Worker(arg0, workerOptions);\n else if (typeof arg0 === \"function\")\n worker.value = arg0();\n else\n worker.value = arg0;\n worker.value.onmessage = (e) => {\n data.value = e.data;\n };\n tryOnScopeDispose(() => {\n if (worker.value)\n worker.value.terminate();\n });\n }\n return {\n data,\n post,\n terminate,\n worker\n };\n}\n\nfunction depsParser(deps, localDeps) {\n if (deps.length === 0 && localDeps.length === 0)\n return \"\";\n const depsString = deps.map((dep) => `'${dep}'`).toString();\n const depsFunctionString = localDeps.filter((dep) => typeof dep === \"function\").map((fn) => {\n const str = fn.toString();\n if (str.trim().startsWith(\"function\")) {\n return str;\n } else {\n const name = fn.name;\n return `const ${name} = ${str}`;\n }\n }).join(\";\");\n const importString = `importScripts(${depsString});`;\n return `${depsString.trim() === \"\" ? \"\" : importString} ${depsFunctionString}`;\n}\n\nfunction jobRunner(userFunc) {\n return (e) => {\n const userFuncArgs = e.data[0];\n return Promise.resolve(userFunc.apply(void 0, userFuncArgs)).then((result) => {\n postMessage([\"SUCCESS\", result]);\n }).catch((error) => {\n postMessage([\"ERROR\", error]);\n });\n };\n}\n\nfunction createWorkerBlobUrl(fn, deps, localDeps) {\n const blobCode = `${depsParser(deps, localDeps)}; onmessage=(${jobRunner})(${fn})`;\n const blob = new Blob([blobCode], { type: \"text/javascript\" });\n const url = URL.createObjectURL(blob);\n return url;\n}\n\nfunction useWebWorkerFn(fn, options = {}) {\n const {\n dependencies = [],\n localDependencies = [],\n timeout,\n window = defaultWindow\n } = options;\n const worker = ref();\n const workerStatus = ref(\"PENDING\");\n const promise = ref({});\n const timeoutId = ref();\n const workerTerminate = (status = \"PENDING\") => {\n if (worker.value && worker.value._url && window) {\n worker.value.terminate();\n URL.revokeObjectURL(worker.value._url);\n promise.value = {};\n worker.value = void 0;\n window.clearTimeout(timeoutId.value);\n workerStatus.value = status;\n }\n };\n workerTerminate();\n tryOnScopeDispose(workerTerminate);\n const generateWorker = () => {\n const blobUrl = createWorkerBlobUrl(fn, dependencies, localDependencies);\n const newWorker = new Worker(blobUrl);\n newWorker._url = blobUrl;\n newWorker.onmessage = (e) => {\n const { resolve = () => {\n }, reject = () => {\n } } = promise.value;\n const [status, result] = e.data;\n switch (status) {\n case \"SUCCESS\":\n resolve(result);\n workerTerminate(status);\n break;\n default:\n reject(result);\n workerTerminate(\"ERROR\");\n break;\n }\n };\n newWorker.onerror = (e) => {\n const { reject = () => {\n } } = promise.value;\n e.preventDefault();\n reject(e);\n workerTerminate(\"ERROR\");\n };\n if (timeout) {\n timeoutId.value = setTimeout(\n () => workerTerminate(\"TIMEOUT_EXPIRED\"),\n timeout\n );\n }\n return newWorker;\n };\n const callWorker = (...fnArgs) => new Promise((resolve, reject) => {\n var _a;\n promise.value = {\n resolve,\n reject\n };\n (_a = worker.value) == null ? void 0 : _a.postMessage([[...fnArgs]]);\n workerStatus.value = \"RUNNING\";\n });\n const workerFn = (...fnArgs) => {\n if (workerStatus.value === \"RUNNING\") {\n console.error(\n \"[useWebWorkerFn] You can only run one instance of the worker at a time.\"\n );\n return Promise.reject();\n }\n worker.value = generateWorker();\n return callWorker(...fnArgs);\n };\n return {\n workerFn,\n workerStatus,\n workerTerminate\n };\n}\n\nfunction useWindowFocus(options = {}) {\n const { window = defaultWindow } = options;\n if (!window)\n return ref(false);\n const focused = ref(window.document.hasFocus());\n useEventListener(window, \"blur\", () => {\n focused.value = false;\n });\n useEventListener(window, \"focus\", () => {\n focused.value = true;\n });\n return focused;\n}\n\nfunction useWindowScroll(options = {}) {\n const { window = defaultWindow, behavior = \"auto\" } = options;\n if (!window) {\n return {\n x: ref(0),\n y: ref(0)\n };\n }\n const internalX = ref(window.scrollX);\n const internalY = ref(window.scrollY);\n const x = computed({\n get() {\n return internalX.value;\n },\n set(x2) {\n scrollTo({ left: x2, behavior });\n }\n });\n const y = computed({\n get() {\n return internalY.value;\n },\n set(y2) {\n scrollTo({ top: y2, behavior });\n }\n });\n useEventListener(\n window,\n \"scroll\",\n () => {\n internalX.value = window.scrollX;\n internalY.value = window.scrollY;\n },\n {\n capture: false,\n passive: true\n }\n );\n return { x, y };\n}\n\nfunction useWindowSize(options = {}) {\n const {\n window = defaultWindow,\n initialWidth = Number.POSITIVE_INFINITY,\n initialHeight = Number.POSITIVE_INFINITY,\n listenOrientation = true,\n includeScrollbar = true,\n type = \"inner\"\n } = options;\n const width = ref(initialWidth);\n const height = ref(initialHeight);\n const update = () => {\n if (window) {\n if (type === \"outer\") {\n width.value = window.outerWidth;\n height.value = window.outerHeight;\n } else if (includeScrollbar) {\n width.value = window.innerWidth;\n height.value = window.innerHeight;\n } else {\n width.value = window.document.documentElement.clientWidth;\n height.value = window.document.documentElement.clientHeight;\n }\n }\n };\n update();\n tryOnMounted(update);\n useEventListener(\"resize\", update, { passive: true });\n if (listenOrientation) {\n const matches = useMediaQuery(\"(orientation: portrait)\");\n watch(matches, () => update());\n }\n return { width, height };\n}\n\nexport { DefaultMagicKeysAliasMap, StorageSerializers, TransitionPresets, computedAsync as asyncComputed, breakpointsAntDesign, breakpointsBootstrapV5, breakpointsElement, breakpointsMasterCss, breakpointsPrimeFlex, breakpointsQuasar, breakpointsSematic, breakpointsTailwind, breakpointsVuetify, breakpointsVuetifyV2, breakpointsVuetifyV3, cloneFnJSON, computedAsync, computedInject, createFetch, createReusableTemplate, createTemplatePromise, createUnrefFn, customStorageEventName, defaultDocument, defaultLocation, defaultNavigator, defaultWindow, executeTransition, formatTimeAgo, getSSRHandler, mapGamepadToXbox360Controller, onClickOutside, onKeyDown, onKeyPressed, onKeyStroke, onKeyUp, onLongPress, onStartTyping, setSSRHandler, templateRef, unrefElement, useActiveElement, useAnimate, useAsyncQueue, useAsyncState, useBase64, useBattery, useBluetooth, useBreakpoints, useBroadcastChannel, useBrowserLocation, useCached, useClipboard, useClipboardItems, useCloned, useColorMode, useConfirmDialog, useCssVar, useCurrentElement, useCycleList, useDark, useDebouncedRefHistory, useDeviceMotion, useDeviceOrientation, useDevicePixelRatio, useDevicesList, useDisplayMedia, useDocumentVisibility, useDraggable, useDropZone, useElementBounding, useElementByPoint, useElementHover, useElementSize, useElementVisibility, useEventBus, useEventListener, useEventSource, useEyeDropper, useFavicon, useFetch, useFileDialog, useFileSystemAccess, useFocus, useFocusWithin, useFps, useFullscreen, useGamepad, useGeolocation, useIdle, useImage, useInfiniteScroll, useIntersectionObserver, useKeyModifier, useLocalStorage, useMagicKeys, useManualRefHistory, useMediaControls, useMediaQuery, useMemoize, useMemory, useMounted, useMouse, useMouseInElement, useMousePressed, useMutationObserver, useNavigatorLanguage, useNetwork, useNow, useObjectUrl, useOffsetPagination, useOnline, usePageLeave, useParallax, useParentElement, usePerformanceObserver, usePermission, usePointer, usePointerLock, usePointerSwipe, usePreferredColorScheme, usePreferredContrast, usePreferredDark, usePreferredLanguages, usePreferredReducedMotion, usePrevious, useRafFn, useRefHistory, useResizeObserver, useScreenOrientation, useScreenSafeArea, useScriptTag, useScroll, useScrollLock, useSessionStorage, useShare, useSorted, useSpeechRecognition, useSpeechSynthesis, useStepper, useStorage, useStorageAsync, useStyleTag, useSupported, useSwipe, useTemplateRefsList, useTextDirection, useTextSelection, useTextareaAutosize, useThrottledRefHistory, useTimeAgo, useTimeoutPoll, useTimestamp, useTitle, useTransition, useUrlSearchParams, useUserMedia, useVModel, useVModels, useVibrate, useVirtualList, useWakeLock, useWebNotification, useWebSocket, useWebWorker, useWebWorkerFn, useWindowFocus, useWindowScroll, useWindowSize };\n","import * as __Vue from \"vue\";\r\n\r\n/**\r\n *\r\n * @param fnCode - example: \"() => { return a + b; }\"\r\n * @param params - example: { a: 1, b: 2 }\r\n * @returns\r\n */\r\nexport function createFnFromString(\r\n fnCode: string,\r\n params?: Record<string, any>\r\n) {\r\n params = params || {};\r\n\r\n const keys = [...Object.keys(params), \"__Vue\"];\r\n const values = [...Object.values(params), __Vue];\r\n\r\n try {\r\n return new Function(...keys, `return (${fnCode})`)(...values);\r\n } catch (error) {\r\n throw new Error(error + \" in function code: \" + fnCode);\r\n }\r\n}\r\n\r\n/**\r\n *\r\n * @param code - example: \":(a, b) => { return a + b; }\"\r\n * @returns\r\n */\r\nexport function tryStringWithColonToFunction(\r\n code: string\r\n): Function | undefined {\r\n if (code.startsWith(\":\")) {\r\n code = code.slice(1);\r\n try {\r\n return createFnFromString(code);\r\n } catch (error) {\r\n throw new Error(error + \" in function code: \" + code);\r\n }\r\n }\r\n\r\n return undefined;\r\n}\r\n","export function memoize<T extends (...args: any[]) => any>(\r\n fn: T,\r\n getKey?: (...args: Parameters<T>) => string\r\n): T {\r\n const cache = new Map<string, ReturnType<T>>();\r\n\r\n return function (...args: Parameters<T>): ReturnType<T> {\r\n const key = getKey ? getKey(...args) : JSON.stringify(args);\r\n if (cache.has(key)) {\r\n return cache.get(key) as ReturnType<T>;\r\n }\r\n const result = fn(...args);\r\n cache.set(key, result);\r\n return result;\r\n } as T;\r\n}\r\n\r\nexport function memoizedValue<T>(fn: () => T): { value: T } {\r\n let result: T | undefined;\r\n\r\n return {\r\n get value(): T {\r\n if (result === undefined) {\r\n result = fn();\r\n }\r\n return result!;\r\n },\r\n };\r\n}\r\n\r\nexport function isAsyncFunction(func: Function): boolean {\r\n return func.constructor.name === \"AsyncFunction\";\r\n}\r\n","import {\r\n TRef,\r\n TVueComputed,\r\n TJsComputed,\r\n TBindableVar,\r\n} from \"@/shared/configTypes\";\r\nimport { computed, readonly, ref, shallowRef, watch } from \"vue\";\r\nimport { TSnapshot } from \"@/shared/bindableHelper\";\r\nimport { asyncComputed } from \"@vueuse/core\";\r\nimport * as jsCodeSystem from \"@/systems/jsCodeSystem\";\r\nimport * as fnSystem from \"@/systems/fnSystem\";\r\nimport { useDeepCompareRef } from \"@/systems/vueSystem\";\r\nimport * as computedInit from \"@/shared/computedInit\";\r\n\r\nexport function createRef(varConfig: TRef, debugInfo?: any) {\r\n const obj = ref(varConfig.value);\r\n return obj;\r\n}\r\n\r\nexport function createVueComputedByStringCode(\r\n varConfig: TVueComputed,\r\n snapshot: TSnapshot,\r\n debugInfo?: any\r\n) {\r\n const { bind: params = {}, code, const: isConsts = [] } = varConfig;\r\n\r\n const refObjs = Object.values(params).map((p, index) => {\r\n const isConst = isConsts[index] === 1;\r\n return isConst ? p : snapshot.getVueRefObjectOrValue(p);\r\n });\r\n\r\n if (fnSystem.isAsyncFunction(new Function(code))) {\r\n return asyncComputed(\r\n async () => {\r\n const fnParams = Object.fromEntries(\r\n Object.keys(params).map((key, index) => {\r\n return [key, refObjs[index]];\r\n })\r\n );\r\n\r\n return await jsCodeSystem.createFnFromString(code, fnParams)();\r\n },\r\n null,\r\n { lazy: true }\r\n );\r\n }\r\n\r\n const fnParams = Object.fromEntries(\r\n Object.keys(params).map((key, index) => {\r\n return [key, refObjs[index]];\r\n })\r\n );\r\n\r\n const fn = jsCodeSystem.createFnFromString(code, fnParams);\r\n const obj = computed(fn);\r\n return obj;\r\n}\r\n\r\nexport function createJsComputedByStringCode(\r\n varConfig: TJsComputed,\r\n snapshot: TSnapshot,\r\n debugInfo?: any\r\n) {\r\n const {\r\n inputs = [],\r\n code,\r\n slient,\r\n data,\r\n asyncInit: asyncInitValue = null,\r\n deepEqOnInput = 0,\r\n } = varConfig;\r\n\r\n const slients = slient || Array(inputs.length).fill(0);\r\n const datas = data || Array(inputs.length).fill(0);\r\n\r\n const watchTargets = inputs\r\n .filter((_, index) => slients[index] === 0 && datas[index] === 0)\r\n .map((input) => snapshot.getVueRefObject(input as TBindableVar));\r\n\r\n function getInputValues() {\r\n return inputs.map((input, index) =>\r\n datas[index] === 1\r\n ? input\r\n : snapshot.getObjectToValue(input as TBindableVar)\r\n );\r\n }\r\n\r\n const fn = jsCodeSystem.createFnFromString(code);\r\n const result =\r\n deepEqOnInput === 0\r\n ? shallowRef(computedInit.__INITIAL__)\r\n : useDeepCompareRef(computedInit.__INITIAL__);\r\n const watchOptions = { immediate: true, deep: true };\r\n\r\n if (fnSystem.isAsyncFunction(fn)) {\r\n result.value = asyncInitValue;\r\n watch(\r\n watchTargets,\r\n async () => {\r\n const args = getInputValues();\r\n if (args.some(computedInit.isInitial)) {\r\n return;\r\n }\r\n\r\n result.value = await fn(...getInputValues());\r\n },\r\n watchOptions\r\n );\r\n } else {\r\n watch(\r\n watchTargets,\r\n () => {\r\n const args = getInputValues();\r\n if (args.some(computedInit.isInitial)) {\r\n return;\r\n }\r\n\r\n result.value = fn(...args);\r\n },\r\n watchOptions\r\n );\r\n }\r\n\r\n return readonly(result);\r\n}\r\n","import { TScope, TBindableVar, TVar } from \"@/shared/configTypes\";\r\nimport { Ref, ComputedRef, shallowRef } from \"vue\";\r\nimport { defaultMap } from \"@/systems/mapSystem\";\r\nimport { useDeepCompareRef } from \"@/systems/vueSystem\";\r\nimport * as varBuilder from \"@/shared/varBuilder\";\r\nimport { TSnapshot } from \"@/shared/bindableHelper\";\r\nimport * as computedInit from \"@/shared/computedInit\";\r\n\r\ntype TVueRef = Ref<any> | ComputedRef<any>;\r\ntype TVarMap = Map<TVar[\"id\"], TVueRef>;\r\ntype TVarSeq = TVarMap[];\r\ntype TDebugInfo = {\r\n scopeId: TScope[\"id\"];\r\n varMapIndex: number;\r\n};\r\nexport type TScopeSnapshot = ReturnType<typeof createScopeSnapshot>;\r\n\r\nfunction varSeqFactory() {\r\n return [];\r\n}\r\n\r\nconst _scopeMap = defaultMap<TScope[\"id\"], TVarSeq>(varSeqFactory);\r\n\r\nexport function getScopeMap() {\r\n return _scopeMap;\r\n}\r\n\r\nexport function createVarStore(scope: TScope, snapshot: TSnapshot) {\r\n const indexSeq = _scopeMap.getOrDefault(scope.id);\r\n\r\n const varMap = new Map();\r\n indexSeq.push(varMap);\r\n\r\n snapshot.replaceSnapshot({\r\n scopeSnapshot: createScopeSnapshot(),\r\n });\r\n\r\n const saveToMap = (v: TVar, obj: any) => {\r\n varMap.set(v.id, obj);\r\n };\r\n\r\n scope.refs?.forEach((varConfig) => {\r\n saveToMap(varConfig, varBuilder.createRef(varConfig));\r\n });\r\n\r\n // web computed must be initialized before js computed and vue computed\r\n scope.web_computed?.forEach((varConfig) => {\r\n const { init } = varConfig;\r\n\r\n const refObj =\r\n varConfig.deepEqOnInput === undefined\r\n ? shallowRef(init ?? computedInit.__INITIAL__)\r\n : useDeepCompareRef(init ?? computedInit.__INITIAL__);\r\n saveToMap(varConfig, refObj);\r\n });\r\n\r\n scope.vue_computed?.forEach((varConfig) => {\r\n saveToMap(\r\n varConfig,\r\n varBuilder.createVueComputedByStringCode(varConfig, snapshot)\r\n );\r\n });\r\n\r\n scope.js_computed?.forEach((varConfig) => {\r\n saveToMap(\r\n varConfig,\r\n varBuilder.createJsComputedByStringCode(varConfig, snapshot)\r\n );\r\n });\r\n\r\n scope.data?.forEach((varConfig) => {\r\n saveToMap(varConfig, varConfig.value);\r\n });\r\n\r\n return indexSeq.length - 1;\r\n}\r\n\r\nexport function createScopeSnapshot() {\r\n const snapshot = new Map<TScope[\"id\"], TVarMap[]>();\r\n\r\n for (const [scopeId, indexSeq] of _scopeMap) {\r\n const varMap = indexSeq[indexSeq.length - 1];\r\n snapshot.set(scopeId, [varMap]);\r\n }\r\n\r\n function getVueRef(varConfig: TBindableVar) {\r\n return _getVueRef(varConfig, snapshot);\r\n }\r\n\r\n return {\r\n getVueRef,\r\n };\r\n}\r\n\r\nexport function getVueRef(varConfig: TBindableVar) {\r\n return _getVueRef(varConfig, _scopeMap);\r\n}\r\n\r\nfunction _getVueRef(\r\n varConfig: TBindableVar,\r\n scopeMap: {\r\n get(scopeId: TScope[\"id\"]): TVarSeq | undefined;\r\n }\r\n) {\r\n const indexSeq = scopeMap.get(varConfig.sid);\r\n if (!indexSeq) {\r\n throw new Error(`Scope ${varConfig.sid} not found`);\r\n }\r\n\r\n const currentVarMap = indexSeq[indexSeq.length - 1];\r\n const ref = currentVarMap.get(varConfig.id);\r\n if (!ref) {\r\n throw new Error(`Var ${varConfig.id} not found in scope ${varConfig.sid}`);\r\n }\r\n\r\n return ref;\r\n}\r\n\r\nexport function clearScopeVarStore(scopeId: TScope[\"id\"]) {\r\n _scopeMap.delete(scopeId);\r\n}\r\n\r\nexport function removeIndexVars(scopeId: TScope[\"id\"], varMapIndex: number) {\r\n const indexMap = _scopeMap.get(scopeId);\r\n if (!indexMap) {\r\n return;\r\n }\r\n\r\n indexMap.splice(varMapIndex, 1);\r\n}\r\n","import { TElementRef, TScope } from \"@/shared/configTypes\";\r\nimport { defaultMap } from \"@/systems/mapSystem\";\r\nimport { shallowRef, ShallowRef } from \"vue\";\r\n\r\nexport type TElementRefSnapshot = ReturnType<typeof createElementRefSnapshot>;\r\n\r\ntype TScopeId = TScope[\"id\"];\r\ntype TRefId = TElementRef[\"id\"];\r\ntype TRefMap = Map<TRefId, ShallowRef>;\r\n\r\nconst scopeMap = defaultMap<TScopeId, TRefMap[]>(() => []);\r\n\r\nexport function createElementRefStore(scope: TScope) {\r\n const refMap = new Map<TRefId, ShallowRef>();\r\n const index = scopeMap.getOrDefault(scope.id).push(refMap);\r\n\r\n scope.eRefs?.forEach((eRef) => {\r\n const refObject = shallowRef();\r\n refMap.set(eRef.id, refObject);\r\n });\r\n\r\n return index;\r\n}\r\n\r\nexport function removeElementRef(scopeId: TScopeId, index: number) {\r\n const refMaps = scopeMap.get(scopeId);\r\n if (!refMaps) {\r\n return;\r\n }\r\n\r\n refMaps.splice(index, 1);\r\n}\r\n\r\nexport function createElementRefSnapshot() {\r\n const snapshotMap = new Map<TScopeId, TRefMap>(\r\n Array.from(scopeMap.entries()).map(([scopeId, refMaps]) => [\r\n scopeId,\r\n refMaps[refMaps.length - 1],\r\n ])\r\n );\r\n\r\n function getRef(elementRef: TElementRef) {\r\n return snapshotMap.get(elementRef.sid)!.get(elementRef.id)!;\r\n }\r\n\r\n return {\r\n getRef,\r\n };\r\n}\r\n","type TMaybeBindable<T = any> = T | TBindableValue;\r\n\r\nexport type TBindableValue =\r\n | TBindableVar\r\n | TBindableVForItem\r\n | TBindableVForIndex\r\n | TBindableJs\r\n | TBindableSlotProp\r\n | TBindableEventContext\r\n | TBindableRouterParams\r\n | TBindableElementRef\r\n | TBindableJsOutput;\r\n\r\nexport type TBinding = TBindableValue;\r\nexport type TNameBinding = Record<string, TBinding>;\r\n\r\nexport interface TVar {\r\n id: string;\r\n sid: string;\r\n path?: (string | number)[];\r\n}\r\n\r\ninterface TBindable {\r\n type:\r\n | \"var\"\r\n | \"js\"\r\n | \"const\"\r\n | \"vf\"\r\n | \"vf-i\"\r\n | \"sp\"\r\n | \"event\"\r\n | \"ele_ref\"\r\n | \"jsOutput\"\r\n | \"routePar\"\r\n | \"routeAct\";\r\n}\r\n\r\nexport interface TBindableJs extends TBindable {\r\n type: \"js\";\r\n code: string;\r\n bind: Record<string, TBindableValue>;\r\n ext?: \"cpt\"[]; // cpt: computed\r\n}\r\n\r\nexport interface TBindableRef extends TBindable {\r\n type: \"var\";\r\n sid: string;\r\n id: string;\r\n path?: (string | number)[];\r\n}\r\n\r\nexport interface TBindableComputed extends TBindable {\r\n type: \"var\";\r\n sid: string;\r\n id: string;\r\n path?: (string | number)[];\r\n}\r\n\r\nexport interface TBindableComputed extends TBindable {\r\n type: \"var\";\r\n sid: string;\r\n id: string;\r\n path?: (string | number)[];\r\n}\r\n\r\nexport interface TBindableWebComputed extends TBindable {\r\n type: \"var\";\r\n sid: string;\r\n id: string;\r\n path?: (string | number)[];\r\n}\r\n\r\nexport interface TBindableVar extends TBindable {\r\n type: \"var\";\r\n sid: string;\r\n id: string;\r\n path?: (string | number)[];\r\n}\r\n\r\nexport interface TBindableRouterParams extends TBindable {\r\n type: \"routePar\";\r\n prop?: \"params\" | \"fullPath\" | \"path\";\r\n path?: (string | number)[];\r\n}\r\n\r\nexport interface TBindableRouterAction extends TBindable {\r\n type: \"routeAct\";\r\n}\r\n\r\nexport interface TBindableElementRef extends TBindable {\r\n type: \"ele_ref\";\r\n sid: string;\r\n id: string;\r\n}\r\n\r\nexport interface TBindableVForItem extends TBindable {\r\n type: \"vf\";\r\n fid: string;\r\n path?: (string | number)[];\r\n}\r\n\r\nexport interface TBindableVForIndex extends TBindable {\r\n type: \"vf-i\";\r\n fid: string;\r\n}\r\n\r\nexport interface TBindableSlotProp extends TBindable {\r\n type: \"sp\";\r\n id: string;\r\n name: string;\r\n}\r\n\r\nexport interface TBindableEventContext extends TBindable {\r\n type: \"event\";\r\n path: string;\r\n}\r\n\r\nexport interface TBindableJsOutput extends TBindable {\r\n type: \"jsOutput\";\r\n}\r\n\r\nexport interface TRef extends TVar {\r\n type: \"ref\";\r\n value: any;\r\n debounced?: number;\r\n}\r\n\r\nexport interface TVueComputed extends TVar {\r\n code: string;\r\n bind: TNameBinding;\r\n const?: (0 | 1)[];\r\n}\r\n\r\nexport interface TJsComputed extends TVar {\r\n inputs: TBinding[];\r\n code: string;\r\n slient?: (1 | 0)[];\r\n data?: (1 | 0)[];\r\n asyncInit?: any;\r\n deepEqOnInput?: 1;\r\n}\r\n\r\nexport interface TWebComputed extends TVar {\r\n url: string;\r\n key: string;\r\n inputs: TBinding[];\r\n init?: any;\r\n}\r\n\r\nexport interface TConstData extends TVar {\r\n value: any;\r\n}\r\n\r\nexport namespace bindableTools {\r\n export function isVar(bindable: TMaybeBindable): bindable is TBindableVar {\r\n return bindable.type === \"var\";\r\n }\r\n\r\n export function isRouterParams(\r\n bindable: TMaybeBindable\r\n ): bindable is TBindableRouterParams {\r\n return bindable.type === \"routePar\";\r\n }\r\n\r\n export function isRouterAction(\r\n bindable: TMaybeBindable\r\n ): bindable is TBindableRouterAction {\r\n return bindable.type === \"routeAct\";\r\n }\r\n\r\n export function isJs(bindable: TMaybeBindable): bindable is TBindableJs {\r\n return bindable.type === \"js\";\r\n }\r\n\r\n export function isJsOutput(\r\n bindable: TMaybeBindable\r\n ): bindable is TBindableJsOutput {\r\n return bindable.type === \"jsOutput\";\r\n }\r\n\r\n export function isVForItem(\r\n bindable: TMaybeBindable\r\n ): bindable is TBindableVForItem {\r\n return bindable.type === \"vf\";\r\n }\r\n\r\n export function isVForIndex(\r\n bindable: TMaybeBindable\r\n ): bindable is TBindableVForIndex {\r\n return bindable.type === \"vf-i\";\r\n }\r\n\r\n export function isSlotProp(\r\n bindable: TMaybeBindable\r\n ): bindable is TBindableSlotProp {\r\n return bindable.type === \"sp\";\r\n }\r\n\r\n export function isEventContext(\r\n bindable: TMaybeBindable\r\n ): bindable is TBindableEventContext {\r\n return bindable.type === \"event\";\r\n }\r\n\r\n export function isElementRef(\r\n bindable: TMaybeBindable\r\n ): bindable is TBindableElementRef {\r\n return bindable.type === \"ele_ref\";\r\n }\r\n\r\n export function IsBinding(bindable: TMaybeBindable): bindable is TBinding {\r\n return bindable.type !== undefined;\r\n }\r\n}\r\n","import { defaultMap } from \"@/systems/mapSystem\";\r\nimport { TSlot, TBindableSlotProp } from \"./configTypes\";\r\n\r\nimport { shallowRef, ShallowRef } from \"vue\";\r\n\r\nexport type TSlotSnapshot = ReturnType<typeof createSnapshot>;\r\n\r\ntype TSlotId = NonNullable<TSlot[\"props\"]>[\"id\"];\r\ntype TSlotPropSeq = ShallowRef[];\r\n\r\nconst _slotMap = defaultMap<TSlotId, TSlotPropSeq>(() => []);\r\n\r\nexport function SetupCollect(slotId: TSlotId) {\r\n const seq = _slotMap.getOrDefault(slotId);\r\n\r\n seq.push(shallowRef({}));\r\n return seq.length - 1;\r\n}\r\n\r\nexport function updateValues(\r\n slotId: TSlotId,\r\n seqIndex: number,\r\n values: Record<string, any>\r\n) {\r\n _slotMap.get(slotId)![seqIndex].value = values;\r\n}\r\n\r\nexport function removeSlotInfo(slotId: TSlotId) {\r\n _slotMap.delete(slotId);\r\n}\r\n\r\n/**\r\n * call in setup of element use slot props value\r\n */\r\nexport function createSnapshot() {\r\n const snapshot = new Map<TSlotId, ShallowRef>();\r\n\r\n for (const [scopeId, indexSeq] of _slotMap) {\r\n const valueSeq = indexSeq[indexSeq.length - 1];\r\n snapshot.set(scopeId, valueSeq);\r\n }\r\n\r\n function getPropsValue(info: TBindableSlotProp) {\r\n return snapshot.get(info.id)!.value[info.name];\r\n }\r\n\r\n return {\r\n getPropsValue,\r\n };\r\n}\r\n","import {\r\n TBindableVar,\r\n TVForComponent,\r\n TBindableVForItem,\r\n} from \"@/shared/configTypes\";\r\nimport { TSnapshot } from \"@/shared/bindableHelper\";\r\nimport {\r\n ComputedRef,\r\n customRef,\r\n ref,\r\n Ref,\r\n toValue,\r\n InjectionKey,\r\n inject,\r\n provide,\r\n} from \"vue\";\r\nimport * as objectSystem from \"@/systems/objectSystem\";\r\nimport { defaultMap } from \"@/systems/mapSystem\";\r\n\r\ntype TFId = TVForComponent[\"props\"][\"fid\"];\r\ntype TArray = TBindableVar | any[];\r\n\r\nexport type TVForInfo = {\r\n fid: string;\r\n index: number;\r\n};\r\n\r\ntype TKey2indexMap = Map<any, Ref<number>>;\r\n\r\nconst vforSourceMap = new Map<TFId, TArraySourceGetter>();\r\nconst fid2keyMap = defaultMap<TFId, TKey2indexMap>(() => new Map());\r\nconst vforSourceLoopNumberMap = new Set<TFId>();\r\n\r\nconst VFOR_KEY = Symbol(\"vfor\") as InjectionKey<Record<TFId, any>>;\r\n\r\nexport function provideVForKey(vforInfo: { fid: string; key: any }) {\r\n const preInfo = injectVForKey() ?? {};\r\n provide(VFOR_KEY, { ...preInfo, ...{ [vforInfo.fid]: vforInfo.key } });\r\n}\r\n\r\nfunction injectVForKey() {\r\n return inject(VFOR_KEY, undefined);\r\n}\r\n\r\nfunction injectVForFid2keyMap() {\r\n const obj = injectVForKey();\r\n const itemMap = new Map();\r\n if (obj === undefined) {\r\n return itemMap;\r\n }\r\n\r\n Object.keys(obj).forEach((fid) => {\r\n itemMap.set(fid, obj[fid]);\r\n });\r\n\r\n return itemMap;\r\n}\r\n\r\nexport function markArray(\r\n fid: TFId,\r\n array: TArray,\r\n isBindRef: boolean,\r\n isLoopNumber: boolean\r\n) {\r\n if (isLoopNumber) {\r\n vforSourceLoopNumberMap.add(fid);\r\n return;\r\n }\r\n\r\n let arraySourceGetter: TArraySourceGetter;\r\n\r\n if (isBindRef) {\r\n arraySourceGetter = new BindableArraySourceGetter(array as TBindableVar);\r\n } else {\r\n const arrayValue = Array.isArray(array)\r\n ? array\r\n : Object.entries(array).map(([key, value], index) => [value, key, index]);\r\n\r\n arraySourceGetter = new ConstArraySourceGetter(arrayValue);\r\n }\r\n\r\n vforSourceMap.set(fid, arraySourceGetter);\r\n}\r\n\r\n/**\r\n * call this function in Container Setup\r\n *\r\n */\r\nexport function markVForIndex(fid: TFId, key: any, index: number) {\r\n const key2indexMap = fid2keyMap.getOrDefault(fid);\r\n\r\n if (!key2indexMap.has(key)) {\r\n key2indexMap.set(key, ref(index));\r\n }\r\n\r\n key2indexMap.get(key)!.value = index;\r\n}\r\n\r\nexport function keysCollector(fid: TFId) {\r\n const usedKeys = new Set<any>();\r\n\r\n function add(key: any) {\r\n usedKeys.add(key);\r\n }\r\n\r\n function removeUnusedKeys() {\r\n const key2indexMap = fid2keyMap.get(fid);\r\n if (key2indexMap === undefined) {\r\n return;\r\n }\r\n\r\n key2indexMap.forEach((_, key) => {\r\n if (!usedKeys.has(key)) {\r\n key2indexMap.delete(key);\r\n }\r\n });\r\n }\r\n\r\n return {\r\n add,\r\n removeUnusedKeys,\r\n };\r\n}\r\n\r\nexport function createVForSnapshot(key?: any) {\r\n const currentKey = key;\r\n const keyMapSnapshot = injectVForFid2keyMap();\r\n\r\n function getVForIndex(fid: TFId) {\r\n const key = keyMapSnapshot.get(fid) ?? currentKey;\r\n\r\n return fid2keyMap.get(fid)!.get(key)!.value;\r\n }\r\n\r\n return {\r\n getVForIndex,\r\n };\r\n}\r\n\r\nexport function createRefObjectWithPaths(options: {\r\n binding: TBindableVForItem;\r\n snapshot: TSnapshot;\r\n}) {\r\n const getter = vforSourceMap.get(options.binding.fid)!;\r\n return getter.createRefObjectWithPaths(options);\r\n}\r\n\r\nexport function isVForLoopNumber(fid: TFId) {\r\n return vforSourceLoopNumberMap.has(fid);\r\n}\r\n\r\ninterface TArraySourceGetter {\r\n createRefObjectWithPaths(options: {\r\n binding: TBindableVForItem;\r\n snapshot: TSnapshot;\r\n }): Ref<any[], any[]>;\r\n}\r\n\r\nclass ConstArraySourceGetter implements TArraySourceGetter {\r\n constructor(private array: any[]) {}\r\n\r\n createRefObjectWithPaths(options: {\r\n binding: TBindableVForItem;\r\n snapshot: TSnapshot;\r\n }) {\r\n const { binding } = options;\r\n const { snapshot } = options;\r\n const { path = [] } = binding;\r\n const paths = [...path];\r\n\r\n const currentVForIndex = snapshot.getVForIndex(binding.fid);\r\n paths.unshift(currentVForIndex);\r\n\r\n return customRef(() => {\r\n return {\r\n get: () => {\r\n return objectSystem.getByPaths(\r\n this.array,\r\n paths,\r\n snapshot.getObjectToValue\r\n );\r\n },\r\n set: () => {\r\n throw new Error(\"Cannot set value to a constant array\");\r\n },\r\n };\r\n });\r\n }\r\n}\r\n\r\nclass BindableArraySourceGetter implements TArraySourceGetter {\r\n private _isDictSource: boolean | undefined;\r\n constructor(private binding: TBindableVar) {}\r\n\r\n private isDictSource(orgRef: Ref<any, any> | ComputedRef<any>) {\r\n if (this._isDictSource === undefined) {\r\n const sourceValue = toValue(orgRef);\r\n this._isDictSource = sourceValue !== null && !Array.isArray(sourceValue);\r\n }\r\n\r\n return this._isDictSource;\r\n }\r\n\r\n createRefObjectWithPaths(options: {\r\n binding: TBindableVForItem;\r\n snapshot: TSnapshot;\r\n }): Ref<any[], any[]> {\r\n const { binding } = options;\r\n const { path = [] } = binding;\r\n const paths = [...path];\r\n const { snapshot } = options;\r\n\r\n const orgRef = snapshot.getVueRefObject(this.binding) as\r\n | Ref<any, any>\r\n | ComputedRef<any>;\r\n\r\n const isDictSource = this.isDictSource(orgRef);\r\n const currentVForIndex = snapshot.getVForIndex(binding.fid);\r\n const defaultDictPath = isDictSource && paths.length === 0 ? [0] : [];\r\n paths.unshift(currentVForIndex, ...defaultDictPath);\r\n\r\n return customRef(() => {\r\n return {\r\n get: () => {\r\n const sourceValue = toValue(orgRef);\r\n\r\n const newSourceValue = isDictSource\r\n ? Object.entries(sourceValue).map(([key, value], index) => [\r\n value,\r\n key,\r\n index,\r\n ])\r\n : sourceValue;\r\n\r\n try {\r\n return objectSystem.getByPaths(\r\n toValue(newSourceValue),\r\n paths,\r\n snapshot.getObjectToValue\r\n );\r\n } catch (e) {\r\n return undefined;\r\n }\r\n },\r\n set: (newValue) => {\r\n const sourceValue = toValue(orgRef);\r\n\r\n if (isDictSource) {\r\n const keys = Object.keys(sourceValue);\r\n\r\n if (currentVForIndex >= keys.length) {\r\n throw new Error(\"Cannot set value to a non-existent key\");\r\n }\r\n\r\n const key = keys[currentVForIndex];\r\n objectSystem.setByPaths(\r\n sourceValue,\r\n [key],\r\n newValue,\r\n snapshot.getObjectToValue\r\n );\r\n\r\n return;\r\n }\r\n\r\n objectSystem.setByPaths(\r\n sourceValue,\r\n paths,\r\n newValue,\r\n snapshot.getObjectToValue\r\n );\r\n },\r\n };\r\n });\r\n }\r\n}\r\n","import { createFnFromString } from \"@/systems/jsCodeSystem\";\r\nimport { computed } from \"vue\";\r\n\r\nexport function createFn(\r\n code: string,\r\n bindings: Record<string, any>,\r\n isComputed = false\r\n) {\r\n if (isComputed) {\r\n code = `$computed(${code})`;\r\n bindings = { ...bindings, $computed: computed };\r\n }\r\n\r\n return createFnFromString(code, bindings);\r\n}\r\n","export function isNullOrUndefined(value: any): boolean {\r\n return value === null || value === undefined;\r\n}\r\n","export function getDevtoolsGlobalHook() {\n return getTarget().__VUE_DEVTOOLS_GLOBAL_HOOK__;\n}\nexport function getTarget() {\n // @ts-expect-error navigator and windows are not available in all environments\n return (typeof navigator !== 'undefined' && typeof window !== 'undefined')\n ? window\n : typeof globalThis !== 'undefined'\n ? globalThis\n : {};\n}\nexport const isProxyAvailable = typeof Proxy === 'function';\n","export const HOOK_SETUP = 'devtools-plugin:setup';\nexport const HOOK_PLUGIN_SETTINGS_SET = 'plugin:settings:set';\n","let supported;\nlet perf;\nexport function isPerformanceSupported() {\n var _a;\n if (supported !== undefined) {\n return supported;\n }\n if (typeof window !== 'undefined' && window.performance) {\n supported = true;\n perf = window.performance;\n }\n else if (typeof globalThis !== 'undefined' && ((_a = globalThis.perf_hooks) === null || _a === void 0 ? void 0 : _a.performance)) {\n supported = true;\n perf = globalThis.perf_hooks.performance;\n }\n else {\n supported = false;\n }\n return supported;\n}\nexport function now() {\n return isPerformanceSupported() ? perf.now() : Date.now();\n}\n","import { HOOK_PLUGIN_SETTINGS_SET } from './const.js';\nimport { now } from './time.js';\nexport class ApiProxy {\n constructor(plugin, hook) {\n this.target = null;\n this.targetQueue = [];\n this.onQueue = [];\n this.plugin = plugin;\n this.hook = hook;\n const defaultSettings = {};\n if (plugin.settings) {\n for (const id in plugin.settings) {\n const item = plugin.settings[id];\n defaultSettings[id] = item.defaultValue;\n }\n }\n const localSettingsSaveId = `__vue-devtools-plugin-settings__${plugin.id}`;\n let currentSettings = Object.assign({}, defaultSettings);\n try {\n const raw = localStorage.getItem(localSettingsSaveId);\n const data = JSON.parse(raw);\n Object.assign(currentSettings, data);\n }\n catch (e) {\n // noop\n }\n this.fallbacks = {\n getSettings() {\n return currentSettings;\n },\n setSettings(value) {\n try {\n localStorage.setItem(localSettingsSaveId, JSON.stringify(value));\n }\n catch (e) {\n // noop\n }\n currentSettings = value;\n },\n now() {\n return now();\n },\n };\n if (hook) {\n hook.on(HOOK_PLUGIN_SETTINGS_SET, (pluginId, value) => {\n if (pluginId === this.plugin.id) {\n this.fallbacks.setSettings(value);\n }\n });\n }\n this.proxiedOn = new Proxy({}, {\n get: (_target, prop) => {\n if (this.target) {\n return this.target.on[prop];\n }\n else {\n return (...args) => {\n this.onQueue.push({\n method: prop,\n args,\n });\n };\n }\n },\n });\n this.proxiedTarget = new Proxy({}, {\n get: (_target, prop) => {\n if (this.target) {\n return this.target[prop];\n }\n else if (prop === 'on') {\n return this.proxiedOn;\n }\n else if (Object.keys(this.fallbacks).includes(prop)) {\n return (...args) => {\n this.targetQueue.push({\n method: prop,\n args,\n resolve: () => { },\n });\n return this.fallbacks[prop](...args);\n };\n }\n else {\n return (...args) => {\n return new Promise((resolve) => {\n this.targetQueue.push({\n method: prop,\n args,\n resolve,\n });\n });\n };\n }\n },\n });\n }\n async setRealTarget(target) {\n this.target = target;\n for (const item of this.onQueue) {\n this.target.on[item.method](...item.args);\n }\n for (const item of this.targetQueue) {\n item.resolve(await this.target[item.method](...item.args));\n }\n }\n}\n","import { getDevtoolsGlobalHook, getTarget, isProxyAvailable } from './env.js';\nimport { HOOK_SETUP } from './const.js';\nimport { ApiProxy } from './proxy.js';\nexport * from './api/index.js';\nexport * from './plugin.js';\nexport * from './time.js';\nexport function setupDevtoolsPlugin(pluginDescriptor, setupFn) {\n const descriptor = pluginDescriptor;\n const target = getTarget();\n const hook = getDevtoolsGlobalHook();\n const enableProxy = isProxyAvailable && descriptor.enableEarlyProxy;\n if (hook && (target.__VUE_DEVTOOLS_PLUGIN_API_AVAILABLE__ || !enableProxy)) {\n hook.emit(HOOK_SETUP, pluginDescriptor, setupFn);\n }\n else {\n const proxy = enableProxy ? new ApiProxy(descriptor, hook) : null;\n const list = target.__VUE_DEVTOOLS_PLUGINS__ = target.__VUE_DEVTOOLS_PLUGINS__ || [];\n list.push({\n pluginDescriptor: descriptor,\n setupFn,\n proxy,\n });\n if (proxy) {\n setupFn(proxy.proxiedTarget);\n }\n }\n}\n","/*!\n * vue-router v4.5.0\n * (c) 2024 Eduardo San Martin Morote\n * @license MIT\n */\nimport { getCurrentInstance, inject, onUnmounted, onDeactivated, onActivated, computed, unref, watchEffect, defineComponent, reactive, h, provide, ref, watch, shallowRef, shallowReactive, nextTick } from 'vue';\nimport { setupDevtoolsPlugin } from '@vue/devtools-api';\n\nconst isBrowser = typeof document !== 'undefined';\n\n/**\n * Allows differentiating lazy components from functional components and vue-class-component\n * @internal\n *\n * @param component\n */\nfunction isRouteComponent(component) {\n return (typeof component === 'object' ||\n 'displayName' in component ||\n 'props' in component ||\n '__vccOpts' in component);\n}\nfunction isESModule(obj) {\n return (obj.__esModule ||\n obj[Symbol.toStringTag] === 'Module' ||\n // support CF with dynamic imports that do not\n // add the Module string tag\n (obj.default && isRouteComponent(obj.default)));\n}\nconst assign = Object.assign;\nfunction applyToParams(fn, params) {\n const newParams = {};\n for (const key in params) {\n const value = params[key];\n newParams[key] = isArray(value)\n ? value.map(fn)\n : fn(value);\n }\n return newParams;\n}\nconst noop = () => { };\n/**\n * Typesafe alternative to Array.isArray\n * https://github.com/microsoft/TypeScript/pull/48228\n */\nconst isArray = Array.isArray;\n\nfunction warn(msg) {\n // avoid using ...args as it breaks in older Edge builds\n const args = Array.from(arguments).slice(1);\n console.warn.apply(console, ['[Vue Router warn]: ' + msg].concat(args));\n}\n\n/**\n * Encoding Rules (␣ = Space)\n * - Path: ␣ \" < > # ? { }\n * - Query: ␣ \" < > # & =\n * - Hash: ␣ \" < > `\n *\n * On top of that, the RFC3986 (https://tools.ietf.org/html/rfc3986#section-2.2)\n * defines some extra characters to be encoded. Most browsers do not encode them\n * in encodeURI https://github.com/whatwg/url/issues/369, so it may be safer to\n * also encode `!'()*`. Leaving un-encoded only ASCII alphanumeric(`a-zA-Z0-9`)\n * plus `-._~`. This extra safety should be applied to query by patching the\n * string returned by encodeURIComponent encodeURI also encodes `[\\]^`. `\\`\n * should be encoded to avoid ambiguity. Browsers (IE, FF, C) transform a `\\`\n * into a `/` if directly typed in. The _backtick_ (`````) should also be\n * encoded everywhere because some browsers like FF encode it when directly\n * written while others don't. Safari and IE don't encode ``\"<>{}``` in hash.\n */\n// const EXTRA_RESERVED_RE = /[!'()*]/g\n// const encodeReservedReplacer = (c: string) => '%' + c.charCodeAt(0).toString(16)\nconst HASH_RE = /#/g; // %23\nconst AMPERSAND_RE = /&/g; // %26\nconst SLASH_RE = /\\//g; // %2F\nconst EQUAL_RE = /=/g; // %3D\nconst IM_RE = /\\?/g; // %3F\nconst PLUS_RE = /\\+/g; // %2B\n/**\n * NOTE: It's not clear to me if we should encode the + symbol in queries, it\n * seems to be less flexible than not doing so and I can't find out the legacy\n * systems requiring this for regular requests like text/html. In the standard,\n * the encoding of the plus character is only mentioned for\n * application/x-www-form-urlencoded\n * (https://url.spec.whatwg.org/#urlencoded-parsing) and most browsers seems lo\n * leave the plus character as is in queries. To be more flexible, we allow the\n * plus character on the query, but it can also be manually encoded by the user.\n *\n * Resources:\n * - https://url.spec.whatwg.org/#urlencoded-parsing\n * - https://stackoverflow.com/questions/1634271/url-encoding-the-space-character-or-20\n */\nconst ENC_BRACKET_OPEN_RE = /%5B/g; // [\nconst ENC_BRACKET_CLOSE_RE = /%5D/g; // ]\nconst ENC_CARET_RE = /%5E/g; // ^\nconst ENC_BACKTICK_RE = /%60/g; // `\nconst ENC_CURLY_OPEN_RE = /%7B/g; // {\nconst ENC_PIPE_RE = /%7C/g; // |\nconst ENC_CURLY_CLOSE_RE = /%7D/g; // }\nconst ENC_SPACE_RE = /%20/g; // }\n/**\n * Encode characters that need to be encoded on the path, search and hash\n * sections of the URL.\n *\n * @internal\n * @param text - string to encode\n * @returns encoded string\n */\nfunction commonEncode(text) {\n return encodeURI('' + text)\n .replace(ENC_PIPE_RE, '|')\n .replace(ENC_BRACKET_OPEN_RE, '[')\n .replace(ENC_BRACKET_CLOSE_RE, ']');\n}\n/**\n * Encode characters that need to be encoded on the hash section of the URL.\n *\n * @param text - string to encode\n * @returns encoded string\n */\nfunction encodeHash(text) {\n return commonEncode(text)\n .replace(ENC_CURLY_OPEN_RE, '{')\n .replace(ENC_CURLY_CLOSE_RE, '}')\n .replace(ENC_CARET_RE, '^');\n}\n/**\n * Encode characters that need to be encoded query values on the query\n * section of the URL.\n *\n * @param text - string to encode\n * @returns encoded string\n */\nfunction encodeQueryValue(text) {\n return (commonEncode(text)\n // Encode the space as +, encode the + to differentiate it from the space\n .replace(PLUS_RE, '%2B')\n .replace(ENC_SPACE_RE, '+')\n .replace(HASH_RE, '%23')\n .replace(AMPERSAND_RE, '%26')\n .replace(ENC_BACKTICK_RE, '`')\n .replace(ENC_CURLY_OPEN_RE, '{')\n .replace(ENC_CURLY_CLOSE_RE, '}')\n .replace(ENC_CARET_RE, '^'));\n}\n/**\n * Like `encodeQueryValue` but also encodes the `=` character.\n *\n * @param text - string to encode\n */\nfunction encodeQueryKey(text) {\n return encodeQueryValue(text).replace(EQUAL_RE, '%3D');\n}\n/**\n * Encode characters that need to be encoded on the path section of the URL.\n *\n * @param text - string to encode\n * @returns encoded string\n */\nfunction encodePath(text) {\n return commonEncode(text).replace(HASH_RE, '%23').replace(IM_RE, '%3F');\n}\n/**\n * Encode characters that need to be encoded on the path section of the URL as a\n * param. This function encodes everything {@link encodePath} does plus the\n * slash (`/`) character. If `text` is `null` or `undefined`, returns an empty\n * string instead.\n *\n * @param text - string to encode\n * @returns encoded string\n */\nfunction encodeParam(text) {\n return text == null ? '' : encodePath(text).replace(SLASH_RE, '%2F');\n}\n/**\n * Decode text using `decodeURIComponent`. Returns the original text if it\n * fails.\n *\n * @param text - string to decode\n * @returns decoded string\n */\nfunction decode(text) {\n try {\n return decodeURIComponent('' + text);\n }\n catch (err) {\n (process.env.NODE_ENV !== 'production') && warn(`Error decoding \"${text}\". Using original value`);\n }\n return '' + text;\n}\n\nconst TRAILING_SLASH_RE = /\\/$/;\nconst removeTrailingSlash = (path) => path.replace(TRAILING_SLASH_RE, '');\n/**\n * Transforms a URI into a normalized history location\n *\n * @param parseQuery\n * @param location - URI to normalize\n * @param currentLocation - current absolute location. Allows resolving relative\n * paths. Must start with `/`. Defaults to `/`\n * @returns a normalized history location\n */\nfunction parseURL(parseQuery, location, currentLocation = '/') {\n let path, query = {}, searchString = '', hash = '';\n // Could use URL and URLSearchParams but IE 11 doesn't support it\n // TODO: move to new URL()\n const hashPos = location.indexOf('#');\n let searchPos = location.indexOf('?');\n // the hash appears before the search, so it's not part of the search string\n if (hashPos < searchPos && hashPos >= 0) {\n searchPos = -1;\n }\n if (searchPos > -1) {\n path = location.slice(0, searchPos);\n searchString = location.slice(searchPos + 1, hashPos > -1 ? hashPos : location.length);\n query = parseQuery(searchString);\n }\n if (hashPos > -1) {\n path = path || location.slice(0, hashPos);\n // keep the # character\n hash = location.slice(hashPos, location.length);\n }\n // no search and no query\n path = resolveRelativePath(path != null ? path : location, currentLocation);\n // empty path means a relative query or hash `?foo=f`, `#thing`\n return {\n fullPath: path + (searchString && '?') + searchString + hash,\n path,\n query,\n hash: decode(hash),\n };\n}\n/**\n * Stringifies a URL object\n *\n * @param stringifyQuery\n * @param location\n */\nfunction stringifyURL(stringifyQuery, location) {\n const query = location.query ? stringifyQuery(location.query) : '';\n return location.path + (query && '?') + query + (location.hash || '');\n}\n/**\n * Strips off the base from the beginning of a location.pathname in a non-case-sensitive way.\n *\n * @param pathname - location.pathname\n * @param base - base to strip off\n */\nfunction stripBase(pathname, base) {\n // no base or base is not found at the beginning\n if (!base || !pathname.toLowerCase().startsWith(base.toLowerCase()))\n return pathname;\n return pathname.slice(base.length) || '/';\n}\n/**\n * Checks if two RouteLocation are equal. This means that both locations are\n * pointing towards the same {@link RouteRecord} and that all `params`, `query`\n * parameters and `hash` are the same\n *\n * @param stringifyQuery - A function that takes a query object of type LocationQueryRaw and returns a string representation of it.\n * @param a - first {@link RouteLocation}\n * @param b - second {@link RouteLocation}\n */\nfunction isSameRouteLocation(stringifyQuery, a, b) {\n const aLastIndex = a.matched.length - 1;\n const bLastIndex = b.matched.length - 1;\n return (aLastIndex > -1 &&\n aLastIndex === bLastIndex &&\n isSameRouteRecord(a.matched[aLastIndex], b.matched[bLastIndex]) &&\n isSameRouteLocationParams(a.params, b.params) &&\n stringifyQuery(a.query) === stringifyQuery(b.query) &&\n a.hash === b.hash);\n}\n/**\n * Check if two `RouteRecords` are equal. Takes into account aliases: they are\n * considered equal to the `RouteRecord` they are aliasing.\n *\n * @param a - first {@link RouteRecord}\n * @param b - second {@link RouteRecord}\n */\nfunction isSameRouteRecord(a, b) {\n // since the original record has an undefined value for aliasOf\n // but all aliases point to the original record, this will always compare\n // the original record\n return (a.aliasOf || a) === (b.aliasOf || b);\n}\nfunction isSameRouteLocationParams(a, b) {\n if (Object.keys(a).length !== Object.keys(b).length)\n return false;\n for (const key in a) {\n if (!isSameRouteLocationParamsValue(a[key], b[key]))\n return false;\n }\n return true;\n}\nfunction isSameRouteLocationParamsValue(a, b) {\n return isArray(a)\n ? isEquivalentArray(a, b)\n : isArray(b)\n ? isEquivalentArray(b, a)\n : a === b;\n}\n/**\n * Check if two arrays are the same or if an array with one single entry is the\n * same as another primitive value. Used to check query and parameters\n *\n * @param a - array of values\n * @param b - array of values or a single value\n */\nfunction isEquivalentArray(a, b) {\n return isArray(b)\n ? a.length === b.length && a.every((value, i) => value === b[i])\n : a.length === 1 && a[0] === b;\n}\n/**\n * Resolves a relative path that starts with `.`.\n *\n * @param to - path location we are resolving\n * @param from - currentLocation.path, should start with `/`\n */\nfunction resolveRelativePath(to, from) {\n if (to.startsWith('/'))\n return to;\n if ((process.env.NODE_ENV !== 'production') && !from.startsWith('/')) {\n warn(`Cannot resolve a relative location without an absolute path. Trying to resolve \"${to}\" from \"${from}\". It should look like \"/${from}\".`);\n return to;\n }\n if (!to)\n return from;\n const fromSegments = from.split('/');\n const toSegments = to.split('/');\n const lastToSegment = toSegments[toSegments.length - 1];\n // make . and ./ the same (../ === .., ../../ === ../..)\n // this is the same behavior as new URL()\n if (lastToSegment === '..' || lastToSegment === '.') {\n toSegments.push('');\n }\n let position = fromSegments.length - 1;\n let toPosition;\n let segment;\n for (toPosition = 0; toPosition < toSegments.length; toPosition++) {\n segment = toSegments[toPosition];\n // we stay on the same position\n if (segment === '.')\n continue;\n // go up in the from array\n if (segment === '..') {\n // we can't go below zero, but we still need to increment toPosition\n if (position > 1)\n position--;\n // continue\n }\n // we reached a non-relative path, we stop here\n else\n break;\n }\n return (fromSegments.slice(0, position).join('/') +\n '/' +\n toSegments.slice(toPosition).join('/'));\n}\n/**\n * Initial route location where the router is. Can be used in navigation guards\n * to differentiate the initial navigation.\n *\n * @example\n * ```js\n * import { START_LOCATION } from 'vue-router'\n *\n * router.beforeEach((to, from) => {\n * if (from === START_LOCATION) {\n * // initial navigation\n * }\n * })\n * ```\n */\nconst START_LOCATION_NORMALIZED = {\n path: '/',\n // TODO: could we use a symbol in the future?\n name: undefined,\n params: {},\n query: {},\n hash: '',\n fullPath: '/',\n matched: [],\n meta: {},\n redirectedFrom: undefined,\n};\n\nvar NavigationType;\n(function (NavigationType) {\n NavigationType[\"pop\"] = \"pop\";\n NavigationType[\"push\"] = \"push\";\n})(NavigationType || (NavigationType = {}));\nvar NavigationDirection;\n(function (NavigationDirection) {\n NavigationDirection[\"back\"] = \"back\";\n NavigationDirection[\"forward\"] = \"forward\";\n NavigationDirection[\"unknown\"] = \"\";\n})(NavigationDirection || (NavigationDirection = {}));\n/**\n * Starting location for Histories\n */\nconst START = '';\n// Generic utils\n/**\n * Normalizes a base by removing any trailing slash and reading the base tag if\n * present.\n *\n * @param base - base to normalize\n */\nfunction normalizeBase(base) {\n if (!base) {\n if (isBrowser) {\n // respect <base> tag\n const baseEl = document.querySelector('base');\n base = (baseEl && baseEl.getAttribute('href')) || '/';\n // strip full URL origin\n base = base.replace(/^\\w+:\\/\\/[^\\/]+/, '');\n }\n else {\n base = '/';\n }\n }\n // ensure leading slash when it was removed by the regex above avoid leading\n // slash with hash because the file could be read from the disk like file://\n // and the leading slash would cause problems\n if (base[0] !== '/' && base[0] !== '#')\n base = '/' + base;\n // remove the trailing slash so all other method can just do `base + fullPath`\n // to build an href\n return removeTrailingSlash(base);\n}\n// remove any character before the hash\nconst BEFORE_HASH_RE = /^[^#]+#/;\nfunction createHref(base, location) {\n return base.replace(BEFORE_HASH_RE, '#') + location;\n}\n\nfunction getElementPosition(el, offset) {\n const docRect = document.documentElement.getBoundingClientRect();\n const elRect = el.getBoundingClientRect();\n return {\n behavior: offset.behavior,\n left: elRect.left - docRect.left - (offset.left || 0),\n top: elRect.top - docRect.top - (offset.top || 0),\n };\n}\nconst computeScrollPosition = () => ({\n left: window.scrollX,\n top: window.scrollY,\n});\nfunction scrollToPosition(position) {\n let scrollToOptions;\n if ('el' in position) {\n const positionEl = position.el;\n const isIdSelector = typeof positionEl === 'string' && positionEl.startsWith('#');\n /**\n * `id`s can accept pretty much any characters, including CSS combinators\n * like `>` or `~`. It's still possible to retrieve elements using\n * `document.getElementById('~')` but it needs to be escaped when using\n * `document.querySelector('#\\\\~')` for it to be valid. The only\n * requirements for `id`s are them to be unique on the page and to not be\n * empty (`id=\"\"`). Because of that, when passing an id selector, it should\n * be properly escaped for it to work with `querySelector`. We could check\n * for the id selector to be simple (no CSS combinators `+ >~`) but that\n * would make things inconsistent since they are valid characters for an\n * `id` but would need to be escaped when using `querySelector`, breaking\n * their usage and ending up in no selector returned. Selectors need to be\n * escaped:\n *\n * - `#1-thing` becomes `#\\31 -thing`\n * - `#with~symbols` becomes `#with\\\\~symbols`\n *\n * - More information about the topic can be found at\n * https://mathiasbynens.be/notes/html5-id-class.\n * - Practical example: https://mathiasbynens.be/demo/html5-id\n */\n if ((process.env.NODE_ENV !== 'production') && typeof position.el === 'string') {\n if (!isIdSelector || !document.getElementById(position.el.slice(1))) {\n try {\n const foundEl = document.querySelector(position.el);\n if (isIdSelector && foundEl) {\n warn(`The selector \"${position.el}\" should be passed as \"el: document.querySelector('${position.el}')\" because it starts with \"#\".`);\n // return to avoid other warnings\n return;\n }\n }\n catch (err) {\n warn(`The selector \"${position.el}\" is invalid. If you are using an id selector, make sure to escape it. You can find more information about escaping characters in selectors at https://mathiasbynens.be/notes/css-escapes or use CSS.escape (https://developer.mozilla.org/en-US/docs/Web/API/CSS/escape).`);\n // return to avoid other warnings\n return;\n }\n }\n }\n const el = typeof positionEl === 'string'\n ? isIdSelector\n ? document.getElementById(positionEl.slice(1))\n : document.querySelector(positionEl)\n : positionEl;\n if (!el) {\n (process.env.NODE_ENV !== 'production') &&\n warn(`Couldn't find element using selector \"${position.el}\" returned by scrollBehavior.`);\n return;\n }\n scrollToOptions = getElementPosition(el, position);\n }\n else {\n scrollToOptions = position;\n }\n if ('scrollBehavior' in document.documentElement.style)\n window.scrollTo(scrollToOptions);\n else {\n window.scrollTo(scrollToOptions.left != null ? scrollToOptions.left : window.scrollX, scrollToOptions.top != null ? scrollToOptions.top : window.scrollY);\n }\n}\nfunction getScrollKey(path, delta) {\n const position = history.state ? history.state.position - delta : -1;\n return position + path;\n}\nconst scrollPositions = new Map();\nfunction saveScrollPosition(key, scrollPosition) {\n scrollPositions.set(key, scrollPosition);\n}\nfunction getSavedScrollPosition(key) {\n const scroll = scrollPositions.get(key);\n // consume it so it's not used again\n scrollPositions.delete(key);\n return scroll;\n}\n// TODO: RFC about how to save scroll position\n/**\n * ScrollBehavior instance used by the router to compute and restore the scroll\n * position when navigating.\n */\n// export interface ScrollHandler<ScrollPositionEntry extends HistoryStateValue, ScrollPosition extends ScrollPositionEntry> {\n// // returns a scroll position that can be saved in history\n// compute(): ScrollPositionEntry\n// // can take an extended ScrollPositionEntry\n// scroll(position: ScrollPosition): void\n// }\n// export const scrollHandler: ScrollHandler<ScrollPosition> = {\n// compute: computeScroll,\n// scroll: scrollToPosition,\n// }\n\nlet createBaseLocation = () => location.protocol + '//' + location.host;\n/**\n * Creates a normalized history location from a window.location object\n * @param base - The base path\n * @param location - The window.location object\n */\nfunction createCurrentLocation(base, location) {\n const { pathname, search, hash } = location;\n // allows hash bases like #, /#, #/, #!, #!/, /#!/, or even /folder#end\n const hashPos = base.indexOf('#');\n if (hashPos > -1) {\n let slicePos = hash.includes(base.slice(hashPos))\n ? base.slice(hashPos).length\n : 1;\n let pathFromHash = hash.slice(slicePos);\n // prepend the starting slash to hash so the url starts with /#\n if (pathFromHash[0] !== '/')\n pathFromHash = '/' + pathFromHash;\n return stripBase(pathFromHash, '');\n }\n const path = stripBase(pathname, base);\n return path + search + hash;\n}\nfunction useHistoryListeners(base, historyState, currentLocation, replace) {\n let listeners = [];\n let teardowns = [];\n // TODO: should it be a stack? a Dict. Check if the popstate listener\n // can trigger twice\n let pauseState = null;\n const popStateHandler = ({ state, }) => {\n const to = createCurrentLocation(base, location);\n const from = currentLocation.value;\n const fromState = historyState.value;\n let delta = 0;\n if (state) {\n currentLocation.value = to;\n historyState.value = state;\n // ignore the popstate and reset the pauseState\n if (pauseState && pauseState === from) {\n pauseState = null;\n return;\n }\n delta = fromState ? state.position - fromState.position : 0;\n }\n else {\n replace(to);\n }\n // Here we could also revert the navigation by calling history.go(-delta)\n // this listener will have to be adapted to not trigger again and to wait for the url\n // to be updated before triggering the listeners. Some kind of validation function would also\n // need to be passed to the listeners so the navigation can be accepted\n // call all listeners\n listeners.forEach(listener => {\n listener(currentLocation.value, from, {\n delta,\n type: NavigationType.pop,\n direction: delta\n ? delta > 0\n ? NavigationDirection.forward\n : NavigationDirection.back\n : NavigationDirection.unknown,\n });\n });\n };\n function pauseListeners() {\n pauseState = currentLocation.value;\n }\n function listen(callback) {\n // set up the listener and prepare teardown callbacks\n listeners.push(callback);\n const teardown = () => {\n const index = listeners.indexOf(callback);\n if (index > -1)\n listeners.splice(index, 1);\n };\n teardowns.push(teardown);\n return teardown;\n }\n function beforeUnloadListener() {\n const { history } = window;\n if (!history.state)\n return;\n history.replaceState(assign({}, history.state, { scroll: computeScrollPosition() }), '');\n }\n function destroy() {\n for (const teardown of teardowns)\n teardown();\n teardowns = [];\n window.removeEventListener('popstate', popStateHandler);\n window.removeEventListener('beforeunload', beforeUnloadListener);\n }\n // set up the listeners and prepare teardown callbacks\n window.addEventListener('popstate', popStateHandler);\n // TODO: could we use 'pagehide' or 'visibilitychange' instead?\n // https://developer.chrome.com/blog/page-lifecycle-api/\n window.addEventListener('beforeunload', beforeUnloadListener, {\n passive: true,\n });\n return {\n pauseListeners,\n listen,\n destroy,\n };\n}\n/**\n * Creates a state object\n */\nfunction buildState(back, current, forward, replaced = false, computeScroll = false) {\n return {\n back,\n current,\n forward,\n replaced,\n position: window.history.length,\n scroll: computeScroll ? computeScrollPosition() : null,\n };\n}\nfunction useHistoryStateNavigation(base) {\n const { history, location } = window;\n // private variables\n const currentLocation = {\n value: createCurrentLocation(base, location),\n };\n const historyState = { value: history.state };\n // build current history entry as this is a fresh navigation\n if (!historyState.value) {\n changeLocation(currentLocation.value, {\n back: null,\n current: currentLocation.value,\n forward: null,\n // the length is off by one, we need to decrease it\n position: history.length - 1,\n replaced: true,\n // don't add a scroll as the user may have an anchor, and we want\n // scrollBehavior to be triggered without a saved position\n scroll: null,\n }, true);\n }\n function changeLocation(to, state, replace) {\n /**\n * if a base tag is provided, and we are on a normal domain, we have to\n * respect the provided `base` attribute because pushState() will use it and\n * potentially erase anything before the `#` like at\n * https://github.com/vuejs/router/issues/685 where a base of\n * `/folder/#` but a base of `/` would erase the `/folder/` section. If\n * there is no host, the `<base>` tag makes no sense and if there isn't a\n * base tag we can just use everything after the `#`.\n */\n const hashIndex = base.indexOf('#');\n const url = hashIndex > -1\n ? (location.host && document.querySelector('base')\n ? base\n : base.slice(hashIndex)) + to\n : createBaseLocation() + base + to;\n try {\n // BROWSER QUIRK\n // NOTE: Safari throws a SecurityError when calling this function 100 times in 30 seconds\n history[replace ? 'replaceState' : 'pushState'](state, '', url);\n historyState.value = state;\n }\n catch (err) {\n if ((process.env.NODE_ENV !== 'production')) {\n warn('Error with push/replace State', err);\n }\n else {\n console.error(err);\n }\n // Force the navigation, this also resets the call count\n location[replace ? 'replace' : 'assign'](url);\n }\n }\n function replace(to, data) {\n const state = assign({}, history.state, buildState(historyState.value.back, \n // keep back and forward entries but override current position\n to, historyState.value.forward, true), data, { position: historyState.value.position });\n changeLocation(to, state, true);\n currentLocation.value = to;\n }\n function push(to, data) {\n // Add to current entry the information of where we are going\n // as well as saving the current position\n const currentState = assign({}, \n // use current history state to gracefully handle a wrong call to\n // history.replaceState\n // https://github.com/vuejs/router/issues/366\n historyState.value, history.state, {\n forward: to,\n scroll: computeScrollPosition(),\n });\n if ((process.env.NODE_ENV !== 'production') && !history.state) {\n warn(`history.state seems to have been manually replaced without preserving the necessary values. Make sure to preserve existing history state if you are manually calling history.replaceState:\\n\\n` +\n `history.replaceState(history.state, '', url)\\n\\n` +\n `You can find more information at https://router.vuejs.org/guide/migration/#Usage-of-history-state`);\n }\n changeLocation(currentState.current, currentState, true);\n const state = assign({}, buildState(currentLocation.value, to, null), { position: currentState.position + 1 }, data);\n changeLocation(to, state, false);\n currentLocation.value = to;\n }\n return {\n location: currentLocation,\n state: historyState,\n push,\n replace,\n };\n}\n/**\n * Creates an HTML5 history. Most common history for single page applications.\n *\n * @param base -\n */\nfunction createWebHistory(base) {\n base = normalizeBase(base);\n const historyNavigation = useHistoryStateNavigation(base);\n const historyListeners = useHistoryListeners(base, historyNavigation.state, historyNavigation.location, historyNavigation.replace);\n function go(delta, triggerListeners = true) {\n if (!triggerListeners)\n historyListeners.pauseListeners();\n history.go(delta);\n }\n const routerHistory = assign({\n // it's overridden right after\n location: '',\n base,\n go,\n createHref: createHref.bind(null, base),\n }, historyNavigation, historyListeners);\n Object.defineProperty(routerHistory, 'location', {\n enumerable: true,\n get: () => historyNavigation.location.value,\n });\n Object.defineProperty(routerHistory, 'state', {\n enumerable: true,\n get: () => historyNavigation.state.value,\n });\n return routerHistory;\n}\n\n/**\n * Creates an in-memory based history. The main purpose of this history is to handle SSR. It starts in a special location that is nowhere.\n * It's up to the user to replace that location with the starter location by either calling `router.push` or `router.replace`.\n *\n * @param base - Base applied to all urls, defaults to '/'\n * @returns a history object that can be passed to the router constructor\n */\nfunction createMemoryHistory(base = '') {\n let listeners = [];\n let queue = [START];\n let position = 0;\n base = normalizeBase(base);\n function setLocation(location) {\n position++;\n if (position !== queue.length) {\n // we are in the middle, we remove everything from here in the queue\n queue.splice(position);\n }\n queue.push(location);\n }\n function triggerListeners(to, from, { direction, delta }) {\n const info = {\n direction,\n delta,\n type: NavigationType.pop,\n };\n for (const callback of listeners) {\n callback(to, from, info);\n }\n }\n const routerHistory = {\n // rewritten by Object.defineProperty\n location: START,\n // TODO: should be kept in queue\n state: {},\n base,\n createHref: createHref.bind(null, base),\n replace(to) {\n // remove current entry and decrement position\n queue.splice(position--, 1);\n setLocation(to);\n },\n push(to, data) {\n setLocation(to);\n },\n listen(callback) {\n listeners.push(callback);\n return () => {\n const index = listeners.indexOf(callback);\n if (index > -1)\n listeners.splice(index, 1);\n };\n },\n destroy() {\n listeners = [];\n queue = [START];\n position = 0;\n },\n go(delta, shouldTrigger = true) {\n const from = this.location;\n const direction = \n // we are considering delta === 0 going forward, but in abstract mode\n // using 0 for the delta doesn't make sense like it does in html5 where\n // it reloads the page\n delta < 0 ? NavigationDirection.back : NavigationDirection.forward;\n position = Math.max(0, Math.min(position + delta, queue.length - 1));\n if (shouldTrigger) {\n triggerListeners(this.location, from, {\n direction,\n delta,\n });\n }\n },\n };\n Object.defineProperty(routerHistory, 'location', {\n enumerable: true,\n get: () => queue[position],\n });\n return routerHistory;\n}\n\n/**\n * Creates a hash history. Useful for web applications with no host (e.g. `file://`) or when configuring a server to\n * handle any URL is not possible.\n *\n * @param base - optional base to provide. Defaults to `location.pathname + location.search` If there is a `<base>` tag\n * in the `head`, its value will be ignored in favor of this parameter **but note it affects all the history.pushState()\n * calls**, meaning that if you use a `<base>` tag, it's `href` value **has to match this parameter** (ignoring anything\n * after the `#`).\n *\n * @example\n * ```js\n * // at https://example.com/folder\n * createWebHashHistory() // gives a url of `https://example.com/folder#`\n * createWebHashHistory('/folder/') // gives a url of `https://example.com/folder/#`\n * // if the `#` is provided in the base, it won't be added by `createWebHashHistory`\n * createWebHashHistory('/folder/#/app/') // gives a url of `https://example.com/folder/#/app/`\n * // you should avoid doing this because it changes the original url and breaks copying urls\n * createWebHashHistory('/other-folder/') // gives a url of `https://example.com/other-folder/#`\n *\n * // at file:///usr/etc/folder/index.html\n * // for locations with no `host`, the base is ignored\n * createWebHashHistory('/iAmIgnored') // gives a url of `file:///usr/etc/folder/index.html#`\n * ```\n */\nfunction createWebHashHistory(base) {\n // Make sure this implementation is fine in terms of encoding, specially for IE11\n // for `file://`, directly use the pathname and ignore the base\n // location.pathname contains an initial `/` even at the root: `https://example.com`\n base = location.host ? base || location.pathname + location.search : '';\n // allow the user to provide a `#` in the middle: `/base/#/app`\n if (!base.includes('#'))\n base += '#';\n if ((process.env.NODE_ENV !== 'production') && !base.endsWith('#/') && !base.endsWith('#')) {\n warn(`A hash base must end with a \"#\":\\n\"${base}\" should be \"${base.replace(/#.*$/, '#')}\".`);\n }\n return createWebHistory(base);\n}\n\nfunction isRouteLocation(route) {\n return typeof route === 'string' || (route && typeof route === 'object');\n}\nfunction isRouteName(name) {\n return typeof name === 'string' || typeof name === 'symbol';\n}\n\nconst NavigationFailureSymbol = Symbol((process.env.NODE_ENV !== 'production') ? 'navigation failure' : '');\n/**\n * Enumeration with all possible types for navigation failures. Can be passed to\n * {@link isNavigationFailure} to check for specific failures.\n */\nvar NavigationFailureType;\n(function (NavigationFailureType) {\n /**\n * An aborted navigation is a navigation that failed because a navigation\n * guard returned `false` or called `next(false)`\n */\n NavigationFailureType[NavigationFailureType[\"aborted\"] = 4] = \"aborted\";\n /**\n * A cancelled navigation is a navigation that failed because a more recent\n * navigation finished started (not necessarily finished).\n */\n NavigationFailureType[NavigationFailureType[\"cancelled\"] = 8] = \"cancelled\";\n /**\n * A duplicated navigation is a navigation that failed because it was\n * initiated while already being at the exact same location.\n */\n NavigationFailureType[NavigationFailureType[\"duplicated\"] = 16] = \"duplicated\";\n})(NavigationFailureType || (NavigationFailureType = {}));\n// DEV only debug messages\nconst ErrorTypeMessages = {\n [1 /* ErrorTypes.MATCHER_NOT_FOUND */]({ location, currentLocation }) {\n return `No match for\\n ${JSON.stringify(location)}${currentLocation\n ? '\\nwhile being at\\n' + JSON.stringify(currentLocation)\n : ''}`;\n },\n [2 /* ErrorTypes.NAVIGATION_GUARD_REDIRECT */]({ from, to, }) {\n return `Redirected from \"${from.fullPath}\" to \"${stringifyRoute(to)}\" via a navigation guard.`;\n },\n [4 /* ErrorTypes.NAVIGATION_ABORTED */]({ from, to }) {\n return `Navigation aborted from \"${from.fullPath}\" to \"${to.fullPath}\" via a navigation guard.`;\n },\n [8 /* ErrorTypes.NAVIGATION_CANCELLED */]({ from, to }) {\n return `Navigation cancelled from \"${from.fullPath}\" to \"${to.fullPath}\" with a new navigation.`;\n },\n [16 /* ErrorTypes.NAVIGATION_DUPLICATED */]({ from, to }) {\n return `Avoided redundant navigation to current location: \"${from.fullPath}\".`;\n },\n};\n/**\n * Creates a typed NavigationFailure object.\n * @internal\n * @param type - NavigationFailureType\n * @param params - { from, to }\n */\nfunction createRouterError(type, params) {\n // keep full error messages in cjs versions\n if ((process.env.NODE_ENV !== 'production') || !true) {\n return assign(new Error(ErrorTypeMessages[type](params)), {\n type,\n [NavigationFailureSymbol]: true,\n }, params);\n }\n else {\n return assign(new Error(), {\n type,\n [NavigationFailureSymbol]: true,\n }, params);\n }\n}\nfunction isNavigationFailure(error, type) {\n return (error instanceof Error &&\n NavigationFailureSymbol in error &&\n (type == null || !!(error.type & type)));\n}\nconst propertiesToLog = ['params', 'query', 'hash'];\nfunction stringifyRoute(to) {\n if (typeof to === 'string')\n return to;\n if (to.path != null)\n return to.path;\n const location = {};\n for (const key of propertiesToLog) {\n if (key in to)\n location[key] = to[key];\n }\n return JSON.stringify(location, null, 2);\n}\n\n// default pattern for a param: non-greedy everything but /\nconst BASE_PARAM_PATTERN = '[^/]+?';\nconst BASE_PATH_PARSER_OPTIONS = {\n sensitive: false,\n strict: false,\n start: true,\n end: true,\n};\n// Special Regex characters that must be escaped in static tokens\nconst REGEX_CHARS_RE = /[.+*?^${}()[\\]/\\\\]/g;\n/**\n * Creates a path parser from an array of Segments (a segment is an array of Tokens)\n *\n * @param segments - array of segments returned by tokenizePath\n * @param extraOptions - optional options for the regexp\n * @returns a PathParser\n */\nfunction tokensToParser(segments, extraOptions) {\n const options = assign({}, BASE_PATH_PARSER_OPTIONS, extraOptions);\n // the amount of scores is the same as the length of segments except for the root segment \"/\"\n const score = [];\n // the regexp as a string\n let pattern = options.start ? '^' : '';\n // extracted keys\n const keys = [];\n for (const segment of segments) {\n // the root segment needs special treatment\n const segmentScores = segment.length ? [] : [90 /* PathScore.Root */];\n // allow trailing slash\n if (options.strict && !segment.length)\n pattern += '/';\n for (let tokenIndex = 0; tokenIndex < segment.length; tokenIndex++) {\n const token = segment[tokenIndex];\n // resets the score if we are inside a sub-segment /:a-other-:b\n let subSegmentScore = 40 /* PathScore.Segment */ +\n (options.sensitive ? 0.25 /* PathScore.BonusCaseSensitive */ : 0);\n if (token.type === 0 /* TokenType.Static */) {\n // prepend the slash if we are starting a new segment\n if (!tokenIndex)\n pattern += '/';\n pattern += token.value.replace(REGEX_CHARS_RE, '\\\\$&');\n subSegmentScore += 40 /* PathScore.Static */;\n }\n else if (token.type === 1 /* TokenType.Param */) {\n const { value, repeatable, optional, regexp } = token;\n keys.push({\n name: value,\n repeatable,\n optional,\n });\n const re = regexp ? regexp : BASE_PARAM_PATTERN;\n // the user provided a custom regexp /:id(\\\\d+)\n if (re !== BASE_PARAM_PATTERN) {\n subSegmentScore += 10 /* PathScore.BonusCustomRegExp */;\n // make sure the regexp is valid before using it\n try {\n new RegExp(`(${re})`);\n }\n catch (err) {\n throw new Error(`Invalid custom RegExp for param \"${value}\" (${re}): ` +\n err.message);\n }\n }\n // when we repeat we must take care of the repeating leading slash\n let subPattern = repeatable ? `((?:${re})(?:/(?:${re}))*)` : `(${re})`;\n // prepend the slash if we are starting a new segment\n if (!tokenIndex)\n subPattern =\n // avoid an optional / if there are more segments e.g. /:p?-static\n // or /:p?-:p2\n optional && segment.length < 2\n ? `(?:/${subPattern})`\n : '/' + subPattern;\n if (optional)\n subPattern += '?';\n pattern += subPattern;\n subSegmentScore += 20 /* PathScore.Dynamic */;\n if (optional)\n subSegmentScore += -8 /* PathScore.BonusOptional */;\n if (repeatable)\n subSegmentScore += -20 /* PathScore.BonusRepeatable */;\n if (re === '.*')\n subSegmentScore += -50 /* PathScore.BonusWildcard */;\n }\n segmentScores.push(subSegmentScore);\n }\n // an empty array like /home/ -> [[{home}], []]\n // if (!segment.length) pattern += '/'\n score.push(segmentScores);\n }\n // only apply the strict bonus to the last score\n if (options.strict && options.end) {\n const i = score.length - 1;\n score[i][score[i].length - 1] += 0.7000000000000001 /* PathScore.BonusStrict */;\n }\n // TODO: dev only warn double trailing slash\n if (!options.strict)\n pattern += '/?';\n if (options.end)\n pattern += '$';\n // allow paths like /dynamic to only match dynamic or dynamic/... but not dynamic_something_else\n else if (options.strict && !pattern.endsWith('/'))\n pattern += '(?:/|$)';\n const re = new RegExp(pattern, options.sensitive ? '' : 'i');\n function parse(path) {\n const match = path.match(re);\n const params = {};\n if (!match)\n return null;\n for (let i = 1; i < match.length; i++) {\n const value = match[i] || '';\n const key = keys[i - 1];\n params[key.name] = value && key.repeatable ? value.split('/') : value;\n }\n return params;\n }\n function stringify(params) {\n let path = '';\n // for optional parameters to allow to be empty\n let avoidDuplicatedSlash = false;\n for (const segment of segments) {\n if (!avoidDuplicatedSlash || !path.endsWith('/'))\n path += '/';\n avoidDuplicatedSlash = false;\n for (const token of segment) {\n if (token.type === 0 /* TokenType.Static */) {\n path += token.value;\n }\n else if (token.type === 1 /* TokenType.Param */) {\n const { value, repeatable, optional } = token;\n const param = value in params ? params[value] : '';\n if (isArray(param) && !repeatable) {\n throw new Error(`Provided param \"${value}\" is an array but it is not repeatable (* or + modifiers)`);\n }\n const text = isArray(param)\n ? param.join('/')\n : param;\n if (!text) {\n if (optional) {\n // if we have more than one optional param like /:a?-static we don't need to care about the optional param\n if (segment.length < 2) {\n // remove the last slash as we could be at the end\n if (path.endsWith('/'))\n path = path.slice(0, -1);\n // do not append a slash on the next iteration\n else\n avoidDuplicatedSlash = true;\n }\n }\n else\n throw new Error(`Missing required param \"${value}\"`);\n }\n path += text;\n }\n }\n }\n // avoid empty path when we have multiple optional params\n return path || '/';\n }\n return {\n re,\n score,\n keys,\n parse,\n stringify,\n };\n}\n/**\n * Compares an array of numbers as used in PathParser.score and returns a\n * number. This function can be used to `sort` an array\n *\n * @param a - first array of numbers\n * @param b - second array of numbers\n * @returns 0 if both are equal, < 0 if a should be sorted first, > 0 if b\n * should be sorted first\n */\nfunction compareScoreArray(a, b) {\n let i = 0;\n while (i < a.length && i < b.length) {\n const diff = b[i] - a[i];\n // only keep going if diff === 0\n if (diff)\n return diff;\n i++;\n }\n // if the last subsegment was Static, the shorter segments should be sorted first\n // otherwise sort the longest segment first\n if (a.length < b.length) {\n return a.length === 1 && a[0] === 40 /* PathScore.Static */ + 40 /* PathScore.Segment */\n ? -1\n : 1;\n }\n else if (a.length > b.length) {\n return b.length === 1 && b[0] === 40 /* PathScore.Static */ + 40 /* PathScore.Segment */\n ? 1\n : -1;\n }\n return 0;\n}\n/**\n * Compare function that can be used with `sort` to sort an array of PathParser\n *\n * @param a - first PathParser\n * @param b - second PathParser\n * @returns 0 if both are equal, < 0 if a should be sorted first, > 0 if b\n */\nfunction comparePathParserScore(a, b) {\n let i = 0;\n const aScore = a.score;\n const bScore = b.score;\n while (i < aScore.length && i < bScore.length) {\n const comp = compareScoreArray(aScore[i], bScore[i]);\n // do not return if both are equal\n if (comp)\n return comp;\n i++;\n }\n if (Math.abs(bScore.length - aScore.length) === 1) {\n if (isLastScoreNegative(aScore))\n return 1;\n if (isLastScoreNegative(bScore))\n return -1;\n }\n // if a and b share the same score entries but b has more, sort b first\n return bScore.length - aScore.length;\n // this is the ternary version\n // return aScore.length < bScore.length\n // ? 1\n // : aScore.length > bScore.length\n // ? -1\n // : 0\n}\n/**\n * This allows detecting splats at the end of a path: /home/:id(.*)*\n *\n * @param score - score to check\n * @returns true if the last entry is negative\n */\nfunction isLastScoreNegative(score) {\n const last = score[score.length - 1];\n return score.length > 0 && last[last.length - 1] < 0;\n}\n\nconst ROOT_TOKEN = {\n type: 0 /* TokenType.Static */,\n value: '',\n};\nconst VALID_PARAM_RE = /[a-zA-Z0-9_]/;\n// After some profiling, the cache seems to be unnecessary because tokenizePath\n// (the slowest part of adding a route) is very fast\n// const tokenCache = new Map<string, Token[][]>()\nfunction tokenizePath(path) {\n if (!path)\n return [[]];\n if (path === '/')\n return [[ROOT_TOKEN]];\n if (!path.startsWith('/')) {\n throw new Error((process.env.NODE_ENV !== 'production')\n ? `Route paths should start with a \"/\": \"${path}\" should be \"/${path}\".`\n : `Invalid path \"${path}\"`);\n }\n // if (tokenCache.has(path)) return tokenCache.get(path)!\n function crash(message) {\n throw new Error(`ERR (${state})/\"${buffer}\": ${message}`);\n }\n let state = 0 /* TokenizerState.Static */;\n let previousState = state;\n const tokens = [];\n // the segment will always be valid because we get into the initial state\n // with the leading /\n let segment;\n function finalizeSegment() {\n if (segment)\n tokens.push(segment);\n segment = [];\n }\n // index on the path\n let i = 0;\n // char at index\n let char;\n // buffer of the value read\n let buffer = '';\n // custom regexp for a param\n let customRe = '';\n function consumeBuffer() {\n if (!buffer)\n return;\n if (state === 0 /* TokenizerState.Static */) {\n segment.push({\n type: 0 /* TokenType.Static */,\n value: buffer,\n });\n }\n else if (state === 1 /* TokenizerState.Param */ ||\n state === 2 /* TokenizerState.ParamRegExp */ ||\n state === 3 /* TokenizerState.ParamRegExpEnd */) {\n if (segment.length > 1 && (char === '*' || char === '+'))\n crash(`A repeatable param (${buffer}) must be alone in its segment. eg: '/:ids+.`);\n segment.push({\n type: 1 /* TokenType.Param */,\n value: buffer,\n regexp: customRe,\n repeatable: char === '*' || char === '+',\n optional: char === '*' || char === '?',\n });\n }\n else {\n crash('Invalid state to consume buffer');\n }\n buffer = '';\n }\n function addCharToBuffer() {\n buffer += char;\n }\n while (i < path.length) {\n char = path[i++];\n if (char === '\\\\' && state !== 2 /* TokenizerState.ParamRegExp */) {\n previousState = state;\n state = 4 /* TokenizerState.EscapeNext */;\n continue;\n }\n switch (state) {\n case 0 /* TokenizerState.Static */:\n if (char === '/') {\n if (buffer) {\n consumeBuffer();\n }\n finalizeSegment();\n }\n else if (char === ':') {\n consumeBuffer();\n state = 1 /* TokenizerState.Param */;\n }\n else {\n addCharToBuffer();\n }\n break;\n case 4 /* TokenizerState.EscapeNext */:\n addCharToBuffer();\n state = previousState;\n break;\n case 1 /* TokenizerState.Param */:\n if (char === '(') {\n state = 2 /* TokenizerState.ParamRegExp */;\n }\n else if (VALID_PARAM_RE.test(char)) {\n addCharToBuffer();\n }\n else {\n consumeBuffer();\n state = 0 /* TokenizerState.Static */;\n // go back one character if we were not modifying\n if (char !== '*' && char !== '?' && char !== '+')\n i--;\n }\n break;\n case 2 /* TokenizerState.ParamRegExp */:\n // TODO: is it worth handling nested regexp? like :p(?:prefix_([^/]+)_suffix)\n // it already works by escaping the closing )\n // https://paths.esm.dev/?p=AAMeJbiAwQEcDKbAoAAkP60PG2R6QAvgNaA6AFACM2ABuQBB#\n // is this really something people need since you can also write\n // /prefix_:p()_suffix\n if (char === ')') {\n // handle the escaped )\n if (customRe[customRe.length - 1] == '\\\\')\n customRe = customRe.slice(0, -1) + char;\n else\n state = 3 /* TokenizerState.ParamRegExpEnd */;\n }\n else {\n customRe += char;\n }\n break;\n case 3 /* TokenizerState.ParamRegExpEnd */:\n // same as finalizing a param\n consumeBuffer();\n state = 0 /* TokenizerState.Static */;\n // go back one character if we were not modifying\n if (char !== '*' && char !== '?' && char !== '+')\n i--;\n customRe = '';\n break;\n default:\n crash('Unknown state');\n break;\n }\n }\n if (state === 2 /* TokenizerState.ParamRegExp */)\n crash(`Unfinished custom RegExp for param \"${buffer}\"`);\n consumeBuffer();\n finalizeSegment();\n // tokenCache.set(path, tokens)\n return tokens;\n}\n\nfunction createRouteRecordMatcher(record, parent, options) {\n const parser = tokensToParser(tokenizePath(record.path), options);\n // warn against params with the same name\n if ((process.env.NODE_ENV !== 'production')) {\n const existingKeys = new Set();\n for (const key of parser.keys) {\n if (existingKeys.has(key.name))\n warn(`Found duplicated params with name \"${key.name}\" for path \"${record.path}\". Only the last one will be available on \"$route.params\".`);\n existingKeys.add(key.name);\n }\n }\n const matcher = assign(parser, {\n record,\n parent,\n // these needs to be populated by the parent\n children: [],\n alias: [],\n });\n if (parent) {\n // both are aliases or both are not aliases\n // we don't want to mix them because the order is used when\n // passing originalRecord in Matcher.addRoute\n if (!matcher.record.aliasOf === !parent.record.aliasOf)\n parent.children.push(matcher);\n }\n return matcher;\n}\n\n/**\n * Creates a Router Matcher.\n *\n * @internal\n * @param routes - array of initial routes\n * @param globalOptions - global route options\n */\nfunction createRouterMatcher(routes, globalOptions) {\n // normalized ordered array of matchers\n const matchers = [];\n const matcherMap = new Map();\n globalOptions = mergeOptions({ strict: false, end: true, sensitive: false }, globalOptions);\n function getRecordMatcher(name) {\n return matcherMap.get(name);\n }\n function addRoute(record, parent, originalRecord) {\n // used later on to remove by name\n const isRootAdd = !originalRecord;\n const mainNormalizedRecord = normalizeRouteRecord(record);\n if ((process.env.NODE_ENV !== 'production')) {\n checkChildMissingNameWithEmptyPath(mainNormalizedRecord, parent);\n }\n // we might be the child of an alias\n mainNormalizedRecord.aliasOf = originalRecord && originalRecord.record;\n const options = mergeOptions(globalOptions, record);\n // generate an array of records to correctly handle aliases\n const normalizedRecords = [mainNormalizedRecord];\n if ('alias' in record) {\n const aliases = typeof record.alias === 'string' ? [record.alias] : record.alias;\n for (const alias of aliases) {\n normalizedRecords.push(\n // we need to normalize again to ensure the `mods` property\n // being non enumerable\n normalizeRouteRecord(assign({}, mainNormalizedRecord, {\n // this allows us to hold a copy of the `components` option\n // so that async components cache is hold on the original record\n components: originalRecord\n ? originalRecord.record.components\n : mainNormalizedRecord.components,\n path: alias,\n // we might be the child of an alias\n aliasOf: originalRecord\n ? originalRecord.record\n : mainNormalizedRecord,\n // the aliases are always of the same kind as the original since they\n // are defined on the same record\n })));\n }\n }\n let matcher;\n let originalMatcher;\n for (const normalizedRecord of normalizedRecords) {\n const { path } = normalizedRecord;\n // Build up the path for nested routes if the child isn't an absolute\n // route. Only add the / delimiter if the child path isn't empty and if the\n // parent path doesn't have a trailing slash\n if (parent && path[0] !== '/') {\n const parentPath = parent.record.path;\n const connectingSlash = parentPath[parentPath.length - 1] === '/' ? '' : '/';\n normalizedRecord.path =\n parent.record.path + (path && connectingSlash + path);\n }\n if ((process.env.NODE_ENV !== 'production') && normalizedRecord.path === '*') {\n throw new Error('Catch all routes (\"*\") must now be defined using a param with a custom regexp.\\n' +\n 'See more at https://router.vuejs.org/guide/migration/#Removed-star-or-catch-all-routes.');\n }\n // create the object beforehand, so it can be passed to children\n matcher = createRouteRecordMatcher(normalizedRecord, parent, options);\n if ((process.env.NODE_ENV !== 'production') && parent && path[0] === '/')\n checkMissingParamsInAbsolutePath(matcher, parent);\n // if we are an alias we must tell the original record that we exist,\n // so we can be removed\n if (originalRecord) {\n originalRecord.alias.push(matcher);\n if ((process.env.NODE_ENV !== 'production')) {\n checkSameParams(originalRecord, matcher);\n }\n }\n else {\n // otherwise, the first record is the original and others are aliases\n originalMatcher = originalMatcher || matcher;\n if (originalMatcher !== matcher)\n originalMatcher.alias.push(matcher);\n // remove the route if named and only for the top record (avoid in nested calls)\n // this works because the original record is the first one\n if (isRootAdd && record.name && !isAliasRecord(matcher)) {\n if ((process.env.NODE_ENV !== 'production')) {\n checkSameNameAsAncestor(record, parent);\n }\n removeRoute(record.name);\n }\n }\n // Avoid adding a record that doesn't display anything. This allows passing through records without a component to\n // not be reached and pass through the catch all route\n if (isMatchable(matcher)) {\n insertMatcher(matcher);\n }\n if (mainNormalizedRecord.children) {\n const children = mainNormalizedRecord.children;\n for (let i = 0; i < children.length; i++) {\n addRoute(children[i], matcher, originalRecord && originalRecord.children[i]);\n }\n }\n // if there was no original record, then the first one was not an alias and all\n // other aliases (if any) need to reference this record when adding children\n originalRecord = originalRecord || matcher;\n // TODO: add normalized records for more flexibility\n // if (parent && isAliasRecord(originalRecord)) {\n // parent.children.push(originalRecord)\n // }\n }\n return originalMatcher\n ? () => {\n // since other matchers are aliases, they should be removed by the original matcher\n removeRoute(originalMatcher);\n }\n : noop;\n }\n function removeRoute(matcherRef) {\n if (isRouteName(matcherRef)) {\n const matcher = matcherMap.get(matcherRef);\n if (matcher) {\n matcherMap.delete(matcherRef);\n matchers.splice(matchers.indexOf(matcher), 1);\n matcher.children.forEach(removeRoute);\n matcher.alias.forEach(removeRoute);\n }\n }\n else {\n const index = matchers.indexOf(matcherRef);\n if (index > -1) {\n matchers.splice(index, 1);\n if (matcherRef.record.name)\n matcherMap.delete(matcherRef.record.name);\n matcherRef.children.forEach(removeRoute);\n matcherRef.alias.forEach(removeRoute);\n }\n }\n }\n function getRoutes() {\n return matchers;\n }\n function insertMatcher(matcher) {\n const index = findInsertionIndex(matcher, matchers);\n matchers.splice(index, 0, matcher);\n // only add the original record to the name map\n if (matcher.record.name && !isAliasRecord(matcher))\n matcherMap.set(matcher.record.name, matcher);\n }\n function resolve(location, currentLocation) {\n let matcher;\n let params = {};\n let path;\n let name;\n if ('name' in location && location.name) {\n matcher = matcherMap.get(location.name);\n if (!matcher)\n throw createRouterError(1 /* ErrorTypes.MATCHER_NOT_FOUND */, {\n location,\n });\n // warn if the user is passing invalid params so they can debug it better when they get removed\n if ((process.env.NODE_ENV !== 'production')) {\n const invalidParams = Object.keys(location.params || {}).filter(paramName => !matcher.keys.find(k => k.name === paramName));\n if (invalidParams.length) {\n warn(`Discarded invalid param(s) \"${invalidParams.join('\", \"')}\" when navigating. See https://github.com/vuejs/router/blob/main/packages/router/CHANGELOG.md#414-2022-08-22 for more details.`);\n }\n }\n name = matcher.record.name;\n params = assign(\n // paramsFromLocation is a new object\n paramsFromLocation(currentLocation.params, \n // only keep params that exist in the resolved location\n // only keep optional params coming from a parent record\n matcher.keys\n .filter(k => !k.optional)\n .concat(matcher.parent ? matcher.parent.keys.filter(k => k.optional) : [])\n .map(k => k.name)), \n // discard any existing params in the current location that do not exist here\n // #1497 this ensures better active/exact matching\n location.params &&\n paramsFromLocation(location.params, matcher.keys.map(k => k.name)));\n // throws if cannot be stringified\n path = matcher.stringify(params);\n }\n else if (location.path != null) {\n // no need to resolve the path with the matcher as it was provided\n // this also allows the user to control the encoding\n path = location.path;\n if ((process.env.NODE_ENV !== 'production') && !path.startsWith('/')) {\n warn(`The Matcher cannot resolve relative paths but received \"${path}\". Unless you directly called \\`matcher.resolve(\"${path}\")\\`, this is probably a bug in vue-router. Please open an issue at https://github.com/vuejs/router/issues/new/choose.`);\n }\n matcher = matchers.find(m => m.re.test(path));\n // matcher should have a value after the loop\n if (matcher) {\n // we know the matcher works because we tested the regexp\n params = matcher.parse(path);\n name = matcher.record.name;\n }\n // location is a relative path\n }\n else {\n // match by name or path of current route\n matcher = currentLocation.name\n ? matcherMap.get(currentLocation.name)\n : matchers.find(m => m.re.test(currentLocation.path));\n if (!matcher)\n throw createRouterError(1 /* ErrorTypes.MATCHER_NOT_FOUND */, {\n location,\n currentLocation,\n });\n name = matcher.record.name;\n // since we are navigating to the same location, we don't need to pick the\n // params like when `name` is provided\n params = assign({}, currentLocation.params, location.params);\n path = matcher.stringify(params);\n }\n const matched = [];\n let parentMatcher = matcher;\n while (parentMatcher) {\n // reversed order so parents are at the beginning\n matched.unshift(parentMatcher.record);\n parentMatcher = parentMatcher.parent;\n }\n return {\n name,\n path,\n params,\n matched,\n meta: mergeMetaFields(matched),\n };\n }\n // add initial routes\n routes.forEach(route => addRoute(route));\n function clearRoutes() {\n matchers.length = 0;\n matcherMap.clear();\n }\n return {\n addRoute,\n resolve,\n removeRoute,\n clearRoutes,\n getRoutes,\n getRecordMatcher,\n };\n}\nfunction paramsFromLocation(params, keys) {\n const newParams = {};\n for (const key of keys) {\n if (key in params)\n newParams[key] = params[key];\n }\n return newParams;\n}\n/**\n * Normalizes a RouteRecordRaw. Creates a copy\n *\n * @param record\n * @returns the normalized version\n */\nfunction normalizeRouteRecord(record) {\n const normalized = {\n path: record.path,\n redirect: record.redirect,\n name: record.name,\n meta: record.meta || {},\n aliasOf: record.aliasOf,\n beforeEnter: record.beforeEnter,\n props: normalizeRecordProps(record),\n children: record.children || [],\n instances: {},\n leaveGuards: new Set(),\n updateGuards: new Set(),\n enterCallbacks: {},\n // must be declared afterwards\n // mods: {},\n components: 'components' in record\n ? record.components || null\n : record.component && { default: record.component },\n };\n // mods contain modules and shouldn't be copied,\n // logged or anything. It's just used for internal\n // advanced use cases like data loaders\n Object.defineProperty(normalized, 'mods', {\n value: {},\n });\n return normalized;\n}\n/**\n * Normalize the optional `props` in a record to always be an object similar to\n * components. Also accept a boolean for components.\n * @param record\n */\nfunction normalizeRecordProps(record) {\n const propsObject = {};\n // props does not exist on redirect records, but we can set false directly\n const props = record.props || false;\n if ('component' in record) {\n propsObject.default = props;\n }\n else {\n // NOTE: we could also allow a function to be applied to every component.\n // Would need user feedback for use cases\n for (const name in record.components)\n propsObject[name] = typeof props === 'object' ? props[name] : props;\n }\n return propsObject;\n}\n/**\n * Checks if a record or any of its parent is an alias\n * @param record\n */\nfunction isAliasRecord(record) {\n while (record) {\n if (record.record.aliasOf)\n return true;\n record = record.parent;\n }\n return false;\n}\n/**\n * Merge meta fields of an array of records\n *\n * @param matched - array of matched records\n */\nfunction mergeMetaFields(matched) {\n return matched.reduce((meta, record) => assign(meta, record.meta), {});\n}\nfunction mergeOptions(defaults, partialOptions) {\n const options = {};\n for (const key in defaults) {\n options[key] = key in partialOptions ? partialOptions[key] : defaults[key];\n }\n return options;\n}\nfunction isSameParam(a, b) {\n return (a.name === b.name &&\n a.optional === b.optional &&\n a.repeatable === b.repeatable);\n}\n/**\n * Check if a path and its alias have the same required params\n *\n * @param a - original record\n * @param b - alias record\n */\nfunction checkSameParams(a, b) {\n for (const key of a.keys) {\n if (!key.optional && !b.keys.find(isSameParam.bind(null, key)))\n return warn(`Alias \"${b.record.path}\" and the original record: \"${a.record.path}\" must have the exact same param named \"${key.name}\"`);\n }\n for (const key of b.keys) {\n if (!key.optional && !a.keys.find(isSameParam.bind(null, key)))\n return warn(`Alias \"${b.record.path}\" and the original record: \"${a.record.path}\" must have the exact same param named \"${key.name}\"`);\n }\n}\n/**\n * A route with a name and a child with an empty path without a name should warn when adding the route\n *\n * @param mainNormalizedRecord - RouteRecordNormalized\n * @param parent - RouteRecordMatcher\n */\nfunction checkChildMissingNameWithEmptyPath(mainNormalizedRecord, parent) {\n if (parent &&\n parent.record.name &&\n !mainNormalizedRecord.name &&\n !mainNormalizedRecord.path) {\n warn(`The route named \"${String(parent.record.name)}\" has a child without a name and an empty path. Using that name won't render the empty path child so you probably want to move the name to the child instead. If this is intentional, add a name to the child route to remove the warning.`);\n }\n}\nfunction checkSameNameAsAncestor(record, parent) {\n for (let ancestor = parent; ancestor; ancestor = ancestor.parent) {\n if (ancestor.record.name === record.name) {\n throw new Error(`A route named \"${String(record.name)}\" has been added as a ${parent === ancestor ? 'child' : 'descendant'} of a route with the same name. Route names must be unique and a nested route cannot use the same name as an ancestor.`);\n }\n }\n}\nfunction checkMissingParamsInAbsolutePath(record, parent) {\n for (const key of parent.keys) {\n if (!record.keys.find(isSameParam.bind(null, key)))\n return warn(`Absolute path \"${record.record.path}\" must have the exact same param named \"${key.name}\" as its parent \"${parent.record.path}\".`);\n }\n}\n/**\n * Performs a binary search to find the correct insertion index for a new matcher.\n *\n * Matchers are primarily sorted by their score. If scores are tied then we also consider parent/child relationships,\n * with descendants coming before ancestors. If there's still a tie, new routes are inserted after existing routes.\n *\n * @param matcher - new matcher to be inserted\n * @param matchers - existing matchers\n */\nfunction findInsertionIndex(matcher, matchers) {\n // First phase: binary search based on score\n let lower = 0;\n let upper = matchers.length;\n while (lower !== upper) {\n const mid = (lower + upper) >> 1;\n const sortOrder = comparePathParserScore(matcher, matchers[mid]);\n if (sortOrder < 0) {\n upper = mid;\n }\n else {\n lower = mid + 1;\n }\n }\n // Second phase: check for an ancestor with the same score\n const insertionAncestor = getInsertionAncestor(matcher);\n if (insertionAncestor) {\n upper = matchers.lastIndexOf(insertionAncestor, upper - 1);\n if ((process.env.NODE_ENV !== 'production') && upper < 0) {\n // This should never happen\n warn(`Finding ancestor route \"${insertionAncestor.record.path}\" failed for \"${matcher.record.path}\"`);\n }\n }\n return upper;\n}\nfunction getInsertionAncestor(matcher) {\n let ancestor = matcher;\n while ((ancestor = ancestor.parent)) {\n if (isMatchable(ancestor) &&\n comparePathParserScore(matcher, ancestor) === 0) {\n return ancestor;\n }\n }\n return;\n}\n/**\n * Checks if a matcher can be reachable. This means if it's possible to reach it as a route. For example, routes without\n * a component, or name, or redirect, are just used to group other routes.\n * @param matcher\n * @param matcher.record record of the matcher\n * @returns\n */\nfunction isMatchable({ record }) {\n return !!(record.name ||\n (record.components && Object.keys(record.components).length) ||\n record.redirect);\n}\n\n/**\n * Transforms a queryString into a {@link LocationQuery} object. Accept both, a\n * version with the leading `?` and without Should work as URLSearchParams\n\n * @internal\n *\n * @param search - search string to parse\n * @returns a query object\n */\nfunction parseQuery(search) {\n const query = {};\n // avoid creating an object with an empty key and empty value\n // because of split('&')\n if (search === '' || search === '?')\n return query;\n const hasLeadingIM = search[0] === '?';\n const searchParams = (hasLeadingIM ? search.slice(1) : search).split('&');\n for (let i = 0; i < searchParams.length; ++i) {\n // pre decode the + into space\n const searchParam = searchParams[i].replace(PLUS_RE, ' ');\n // allow the = character\n const eqPos = searchParam.indexOf('=');\n const key = decode(eqPos < 0 ? searchParam : searchParam.slice(0, eqPos));\n const value = eqPos < 0 ? null : decode(searchParam.slice(eqPos + 1));\n if (key in query) {\n // an extra variable for ts types\n let currentValue = query[key];\n if (!isArray(currentValue)) {\n currentValue = query[key] = [currentValue];\n }\n currentValue.push(value);\n }\n else {\n query[key] = value;\n }\n }\n return query;\n}\n/**\n * Stringifies a {@link LocationQueryRaw} object. Like `URLSearchParams`, it\n * doesn't prepend a `?`\n *\n * @internal\n *\n * @param query - query object to stringify\n * @returns string version of the query without the leading `?`\n */\nfunction stringifyQuery(query) {\n let search = '';\n for (let key in query) {\n const value = query[key];\n key = encodeQueryKey(key);\n if (value == null) {\n // only null adds the value\n if (value !== undefined) {\n search += (search.length ? '&' : '') + key;\n }\n continue;\n }\n // keep null values\n const values = isArray(value)\n ? value.map(v => v && encodeQueryValue(v))\n : [value && encodeQueryValue(value)];\n values.forEach(value => {\n // skip undefined values in arrays as if they were not present\n // smaller code than using filter\n if (value !== undefined) {\n // only append & with non-empty search\n search += (search.length ? '&' : '') + key;\n if (value != null)\n search += '=' + value;\n }\n });\n }\n return search;\n}\n/**\n * Transforms a {@link LocationQueryRaw} into a {@link LocationQuery} by casting\n * numbers into strings, removing keys with an undefined value and replacing\n * undefined with null in arrays\n *\n * @param query - query object to normalize\n * @returns a normalized query object\n */\nfunction normalizeQuery(query) {\n const normalizedQuery = {};\n for (const key in query) {\n const value = query[key];\n if (value !== undefined) {\n normalizedQuery[key] = isArray(value)\n ? value.map(v => (v == null ? null : '' + v))\n : value == null\n ? value\n : '' + value;\n }\n }\n return normalizedQuery;\n}\n\n/**\n * RouteRecord being rendered by the closest ancestor Router View. Used for\n * `onBeforeRouteUpdate` and `onBeforeRouteLeave`. rvlm stands for Router View\n * Location Matched\n *\n * @internal\n */\nconst matchedRouteKey = Symbol((process.env.NODE_ENV !== 'production') ? 'router view location matched' : '');\n/**\n * Allows overriding the router view depth to control which component in\n * `matched` is rendered. rvd stands for Router View Depth\n *\n * @internal\n */\nconst viewDepthKey = Symbol((process.env.NODE_ENV !== 'production') ? 'router view depth' : '');\n/**\n * Allows overriding the router instance returned by `useRouter` in tests. r\n * stands for router\n *\n * @internal\n */\nconst routerKey = Symbol((process.env.NODE_ENV !== 'production') ? 'router' : '');\n/**\n * Allows overriding the current route returned by `useRoute` in tests. rl\n * stands for route location\n *\n * @internal\n */\nconst routeLocationKey = Symbol((process.env.NODE_ENV !== 'production') ? 'route location' : '');\n/**\n * Allows overriding the current route used by router-view. Internally this is\n * used when the `route` prop is passed.\n *\n * @internal\n */\nconst routerViewLocationKey = Symbol((process.env.NODE_ENV !== 'production') ? 'router view location' : '');\n\n/**\n * Create a list of callbacks that can be reset. Used to create before and after navigation guards list\n */\nfunction useCallbacks() {\n let handlers = [];\n function add(handler) {\n handlers.push(handler);\n return () => {\n const i = handlers.indexOf(handler);\n if (i > -1)\n handlers.splice(i, 1);\n };\n }\n function reset() {\n handlers = [];\n }\n return {\n add,\n list: () => handlers.slice(),\n reset,\n };\n}\n\nfunction registerGuard(record, name, guard) {\n const removeFromList = () => {\n record[name].delete(guard);\n };\n onUnmounted(removeFromList);\n onDeactivated(removeFromList);\n onActivated(() => {\n record[name].add(guard);\n });\n record[name].add(guard);\n}\n/**\n * Add a navigation guard that triggers whenever the component for the current\n * location is about to be left. Similar to {@link beforeRouteLeave} but can be\n * used in any component. The guard is removed when the component is unmounted.\n *\n * @param leaveGuard - {@link NavigationGuard}\n */\nfunction onBeforeRouteLeave(leaveGuard) {\n if ((process.env.NODE_ENV !== 'production') && !getCurrentInstance()) {\n warn('getCurrentInstance() returned null. onBeforeRouteLeave() must be called at the top of a setup function');\n return;\n }\n const activeRecord = inject(matchedRouteKey, \n // to avoid warning\n {}).value;\n if (!activeRecord) {\n (process.env.NODE_ENV !== 'production') &&\n warn('No active route record was found when calling `onBeforeRouteLeave()`. Make sure you call this function inside a component child of <router-view>. Maybe you called it inside of App.vue?');\n return;\n }\n registerGuard(activeRecord, 'leaveGuards', leaveGuard);\n}\n/**\n * Add a navigation guard that triggers whenever the current location is about\n * to be updated. Similar to {@link beforeRouteUpdate} but can be used in any\n * component. The guard is removed when the component is unmounted.\n *\n * @param updateGuard - {@link NavigationGuard}\n */\nfunction onBeforeRouteUpdate(updateGuard) {\n if ((process.env.NODE_ENV !== 'production') && !getCurrentInstance()) {\n warn('getCurrentInstance() returned null. onBeforeRouteUpdate() must be called at the top of a setup function');\n return;\n }\n const activeRecord = inject(matchedRouteKey, \n // to avoid warning\n {}).value;\n if (!activeRecord) {\n (process.env.NODE_ENV !== 'production') &&\n warn('No active route record was found when calling `onBeforeRouteUpdate()`. Make sure you call this function inside a component child of <router-view>. Maybe you called it inside of App.vue?');\n return;\n }\n registerGuard(activeRecord, 'updateGuards', updateGuard);\n}\nfunction guardToPromiseFn(guard, to, from, record, name, runWithContext = fn => fn()) {\n // keep a reference to the enterCallbackArray to prevent pushing callbacks if a new navigation took place\n const enterCallbackArray = record &&\n // name is defined if record is because of the function overload\n (record.enterCallbacks[name] = record.enterCallbacks[name] || []);\n return () => new Promise((resolve, reject) => {\n const next = (valid) => {\n if (valid === false) {\n reject(createRouterError(4 /* ErrorTypes.NAVIGATION_ABORTED */, {\n from,\n to,\n }));\n }\n else if (valid instanceof Error) {\n reject(valid);\n }\n else if (isRouteLocation(valid)) {\n reject(createRouterError(2 /* ErrorTypes.NAVIGATION_GUARD_REDIRECT */, {\n from: to,\n to: valid,\n }));\n }\n else {\n if (enterCallbackArray &&\n // since enterCallbackArray is truthy, both record and name also are\n record.enterCallbacks[name] === enterCallbackArray &&\n typeof valid === 'function') {\n enterCallbackArray.push(valid);\n }\n resolve();\n }\n };\n // wrapping with Promise.resolve allows it to work with both async and sync guards\n const guardReturn = runWithContext(() => guard.call(record && record.instances[name], to, from, (process.env.NODE_ENV !== 'production') ? canOnlyBeCalledOnce(next, to, from) : next));\n let guardCall = Promise.resolve(guardReturn);\n if (guard.length < 3)\n guardCall = guardCall.then(next);\n if ((process.env.NODE_ENV !== 'production') && guard.length > 2) {\n const message = `The \"next\" callback was never called inside of ${guard.name ? '\"' + guard.name + '\"' : ''}:\\n${guard.toString()}\\n. If you are returning a value instead of calling \"next\", make sure to remove the \"next\" parameter from your function.`;\n if (typeof guardReturn === 'object' && 'then' in guardReturn) {\n guardCall = guardCall.then(resolvedValue => {\n // @ts-expect-error: _called is added at canOnlyBeCalledOnce\n if (!next._called) {\n warn(message);\n return Promise.reject(new Error('Invalid navigation guard'));\n }\n return resolvedValue;\n });\n }\n else if (guardReturn !== undefined) {\n // @ts-expect-error: _called is added at canOnlyBeCalledOnce\n if (!next._called) {\n warn(message);\n reject(new Error('Invalid navigation guard'));\n return;\n }\n }\n }\n guardCall.catch(err => reject(err));\n });\n}\nfunction canOnlyBeCalledOnce(next, to, from) {\n let called = 0;\n return function () {\n if (called++ === 1)\n warn(`The \"next\" callback was called more than once in one navigation guard when going from \"${from.fullPath}\" to \"${to.fullPath}\". It should be called exactly one time in each navigation guard. This will fail in production.`);\n // @ts-expect-error: we put it in the original one because it's easier to check\n next._called = true;\n if (called === 1)\n next.apply(null, arguments);\n };\n}\nfunction extractComponentsGuards(matched, guardType, to, from, runWithContext = fn => fn()) {\n const guards = [];\n for (const record of matched) {\n if ((process.env.NODE_ENV !== 'production') && !record.components && !record.children.length) {\n warn(`Record with path \"${record.path}\" is either missing a \"component(s)\"` +\n ` or \"children\" property.`);\n }\n for (const name in record.components) {\n let rawComponent = record.components[name];\n if ((process.env.NODE_ENV !== 'production')) {\n if (!rawComponent ||\n (typeof rawComponent !== 'object' &&\n typeof rawComponent !== 'function')) {\n warn(`Component \"${name}\" in record with path \"${record.path}\" is not` +\n ` a valid component. Received \"${String(rawComponent)}\".`);\n // throw to ensure we stop here but warn to ensure the message isn't\n // missed by the user\n throw new Error('Invalid route component');\n }\n else if ('then' in rawComponent) {\n // warn if user wrote import('/component.vue') instead of () =>\n // import('./component.vue')\n warn(`Component \"${name}\" in record with path \"${record.path}\" is a ` +\n `Promise instead of a function that returns a Promise. Did you ` +\n `write \"import('./MyPage.vue')\" instead of ` +\n `\"() => import('./MyPage.vue')\" ? This will break in ` +\n `production if not fixed.`);\n const promise = rawComponent;\n rawComponent = () => promise;\n }\n else if (rawComponent.__asyncLoader &&\n // warn only once per component\n !rawComponent.__warnedDefineAsync) {\n rawComponent.__warnedDefineAsync = true;\n warn(`Component \"${name}\" in record with path \"${record.path}\" is defined ` +\n `using \"defineAsyncComponent()\". ` +\n `Write \"() => import('./MyPage.vue')\" instead of ` +\n `\"defineAsyncComponent(() => import('./MyPage.vue'))\".`);\n }\n }\n // skip update and leave guards if the route component is not mounted\n if (guardType !== 'beforeRouteEnter' && !record.instances[name])\n continue;\n if (isRouteComponent(rawComponent)) {\n // __vccOpts is added by vue-class-component and contain the regular options\n const options = rawComponent.__vccOpts || rawComponent;\n const guard = options[guardType];\n guard &&\n guards.push(guardToPromiseFn(guard, to, from, record, name, runWithContext));\n }\n else {\n // start requesting the chunk already\n let componentPromise = rawComponent();\n if ((process.env.NODE_ENV !== 'production') && !('catch' in componentPromise)) {\n warn(`Component \"${name}\" in record with path \"${record.path}\" is a function that does not return a Promise. If you were passing a functional component, make sure to add a \"displayName\" to the component. This will break in production if not fixed.`);\n componentPromise = Promise.resolve(componentPromise);\n }\n guards.push(() => componentPromise.then(resolved => {\n if (!resolved)\n throw new Error(`Couldn't resolve component \"${name}\" at \"${record.path}\"`);\n const resolvedComponent = isESModule(resolved)\n ? resolved.default\n : resolved;\n // keep the resolved module for plugins like data loaders\n record.mods[name] = resolved;\n // replace the function with the resolved component\n // cannot be null or undefined because we went into the for loop\n record.components[name] = resolvedComponent;\n // __vccOpts is added by vue-class-component and contain the regular options\n const options = resolvedComponent.__vccOpts || resolvedComponent;\n const guard = options[guardType];\n return (guard &&\n guardToPromiseFn(guard, to, from, record, name, runWithContext)());\n }));\n }\n }\n }\n return guards;\n}\n/**\n * Ensures a route is loaded, so it can be passed as o prop to `<RouterView>`.\n *\n * @param route - resolved route to load\n */\nfunction loadRouteLocation(route) {\n return route.matched.every(record => record.redirect)\n ? Promise.reject(new Error('Cannot load a route that redirects.'))\n : Promise.all(route.matched.map(record => record.components &&\n Promise.all(Object.keys(record.components).reduce((promises, name) => {\n const rawComponent = record.components[name];\n if (typeof rawComponent === 'function' &&\n !('displayName' in rawComponent)) {\n promises.push(rawComponent().then(resolved => {\n if (!resolved)\n return Promise.reject(new Error(`Couldn't resolve component \"${name}\" at \"${record.path}\". Ensure you passed a function that returns a promise.`));\n const resolvedComponent = isESModule(resolved)\n ? resolved.default\n : resolved;\n // keep the resolved module for plugins like data loaders\n record.mods[name] = resolved;\n // replace the function with the resolved component\n // cannot be null or undefined because we went into the for loop\n record.components[name] = resolvedComponent;\n return;\n }));\n }\n return promises;\n }, [])))).then(() => route);\n}\n\n// TODO: we could allow currentRoute as a prop to expose `isActive` and\n// `isExactActive` behavior should go through an RFC\n/**\n * Returns the internal behavior of a {@link RouterLink} without the rendering part.\n *\n * @param props - a `to` location and an optional `replace` flag\n */\nfunction useLink(props) {\n const router = inject(routerKey);\n const currentRoute = inject(routeLocationKey);\n let hasPrevious = false;\n let previousTo = null;\n const route = computed(() => {\n const to = unref(props.to);\n if ((process.env.NODE_ENV !== 'production') && (!hasPrevious || to !== previousTo)) {\n if (!isRouteLocation(to)) {\n if (hasPrevious) {\n warn(`Invalid value for prop \"to\" in useLink()\\n- to:`, to, `\\n- previous to:`, previousTo, `\\n- props:`, props);\n }\n else {\n warn(`Invalid value for prop \"to\" in useLink()\\n- to:`, to, `\\n- props:`, props);\n }\n }\n previousTo = to;\n hasPrevious = true;\n }\n return router.resolve(to);\n });\n const activeRecordIndex = computed(() => {\n const { matched } = route.value;\n const { length } = matched;\n const routeMatched = matched[length - 1];\n const currentMatched = currentRoute.matched;\n if (!routeMatched || !currentMatched.length)\n return -1;\n const index = currentMatched.findIndex(isSameRouteRecord.bind(null, routeMatched));\n if (index > -1)\n return index;\n // possible parent record\n const parentRecordPath = getOriginalPath(matched[length - 2]);\n return (\n // we are dealing with nested routes\n length > 1 &&\n // if the parent and matched route have the same path, this link is\n // referring to the empty child. Or we currently are on a different\n // child of the same parent\n getOriginalPath(routeMatched) === parentRecordPath &&\n // avoid comparing the child with its parent\n currentMatched[currentMatched.length - 1].path !== parentRecordPath\n ? currentMatched.findIndex(isSameRouteRecord.bind(null, matched[length - 2]))\n : index);\n });\n const isActive = computed(() => activeRecordIndex.value > -1 &&\n includesParams(currentRoute.params, route.value.params));\n const isExactActive = computed(() => activeRecordIndex.value > -1 &&\n activeRecordIndex.value === currentRoute.matched.length - 1 &&\n isSameRouteLocationParams(currentRoute.params, route.value.params));\n function navigate(e = {}) {\n if (guardEvent(e)) {\n const p = router[unref(props.replace) ? 'replace' : 'push'](unref(props.to)\n // avoid uncaught errors are they are logged anyway\n ).catch(noop);\n if (props.viewTransition &&\n typeof document !== 'undefined' &&\n 'startViewTransition' in document) {\n document.startViewTransition(() => p);\n }\n return p;\n }\n return Promise.resolve();\n }\n // devtools only\n if (((process.env.NODE_ENV !== 'production') || __VUE_PROD_DEVTOOLS__) && isBrowser) {\n const instance = getCurrentInstance();\n if (instance) {\n const linkContextDevtools = {\n route: route.value,\n isActive: isActive.value,\n isExactActive: isExactActive.value,\n error: null,\n };\n // @ts-expect-error: this is internal\n instance.__vrl_devtools = instance.__vrl_devtools || [];\n // @ts-expect-error: this is internal\n instance.__vrl_devtools.push(linkContextDevtools);\n watchEffect(() => {\n linkContextDevtools.route = route.value;\n linkContextDevtools.isActive = isActive.value;\n linkContextDevtools.isExactActive = isExactActive.value;\n linkContextDevtools.error = isRouteLocation(unref(props.to))\n ? null\n : 'Invalid \"to\" value';\n }, { flush: 'post' });\n }\n }\n /**\n * NOTE: update {@link _RouterLinkI}'s `$slots` type when updating this\n */\n return {\n route,\n href: computed(() => route.value.href),\n isActive,\n isExactActive,\n navigate,\n };\n}\nfunction preferSingleVNode(vnodes) {\n return vnodes.length === 1 ? vnodes[0] : vnodes;\n}\nconst RouterLinkImpl = /*#__PURE__*/ defineComponent({\n name: 'RouterLink',\n compatConfig: { MODE: 3 },\n props: {\n to: {\n type: [String, Object],\n required: true,\n },\n replace: Boolean,\n activeClass: String,\n // inactiveClass: String,\n exactActiveClass: String,\n custom: Boolean,\n ariaCurrentValue: {\n type: String,\n default: 'page',\n },\n },\n useLink,\n setup(props, { slots }) {\n const link = reactive(useLink(props));\n const { options } = inject(routerKey);\n const elClass = computed(() => ({\n [getLinkClass(props.activeClass, options.linkActiveClass, 'router-link-active')]: link.isActive,\n // [getLinkClass(\n // props.inactiveClass,\n // options.linkInactiveClass,\n // 'router-link-inactive'\n // )]: !link.isExactActive,\n [getLinkClass(props.exactActiveClass, options.linkExactActiveClass, 'router-link-exact-active')]: link.isExactActive,\n }));\n return () => {\n const children = slots.default && preferSingleVNode(slots.default(link));\n return props.custom\n ? children\n : h('a', {\n 'aria-current': link.isExactActive\n ? props.ariaCurrentValue\n : null,\n href: link.href,\n // this would override user added attrs but Vue will still add\n // the listener, so we end up triggering both\n onClick: link.navigate,\n class: elClass.value,\n }, children);\n };\n },\n});\n// export the public type for h/tsx inference\n// also to avoid inline import() in generated d.ts files\n/**\n * Component to render a link that triggers a navigation on click.\n */\nconst RouterLink = RouterLinkImpl;\nfunction guardEvent(e) {\n // don't redirect with control keys\n if (e.metaKey || e.altKey || e.ctrlKey || e.shiftKey)\n return;\n // don't redirect when preventDefault called\n if (e.defaultPrevented)\n return;\n // don't redirect on right click\n if (e.button !== undefined && e.button !== 0)\n return;\n // don't redirect if `target=\"_blank\"`\n // @ts-expect-error getAttribute does exist\n if (e.currentTarget && e.currentTarget.getAttribute) {\n // @ts-expect-error getAttribute exists\n const target = e.currentTarget.getAttribute('target');\n if (/\\b_blank\\b/i.test(target))\n return;\n }\n // this may be a Weex event which doesn't have this method\n if (e.preventDefault)\n e.preventDefault();\n return true;\n}\nfunction includesParams(outer, inner) {\n for (const key in inner) {\n const innerValue = inner[key];\n const outerValue = outer[key];\n if (typeof innerValue === 'string') {\n if (innerValue !== outerValue)\n return false;\n }\n else {\n if (!isArray(outerValue) ||\n outerValue.length !== innerValue.length ||\n innerValue.some((value, i) => value !== outerValue[i]))\n return false;\n }\n }\n return true;\n}\n/**\n * Get the original path value of a record by following its aliasOf\n * @param record\n */\nfunction getOriginalPath(record) {\n return record ? (record.aliasOf ? record.aliasOf.path : record.path) : '';\n}\n/**\n * Utility class to get the active class based on defaults.\n * @param propClass\n * @param globalClass\n * @param defaultClass\n */\nconst getLinkClass = (propClass, globalClass, defaultClass) => propClass != null\n ? propClass\n : globalClass != null\n ? globalClass\n : defaultClass;\n\nconst RouterViewImpl = /*#__PURE__*/ defineComponent({\n name: 'RouterView',\n // #674 we manually inherit them\n inheritAttrs: false,\n props: {\n name: {\n type: String,\n default: 'default',\n },\n route: Object,\n },\n // Better compat for @vue/compat users\n // https://github.com/vuejs/router/issues/1315\n compatConfig: { MODE: 3 },\n setup(props, { attrs, slots }) {\n (process.env.NODE_ENV !== 'production') && warnDeprecatedUsage();\n const injectedRoute = inject(routerViewLocationKey);\n const routeToDisplay = computed(() => props.route || injectedRoute.value);\n const injectedDepth = inject(viewDepthKey, 0);\n // The depth changes based on empty components option, which allows passthrough routes e.g. routes with children\n // that are used to reuse the `path` property\n const depth = computed(() => {\n let initialDepth = unref(injectedDepth);\n const { matched } = routeToDisplay.value;\n let matchedRoute;\n while ((matchedRoute = matched[initialDepth]) &&\n !matchedRoute.components) {\n initialDepth++;\n }\n return initialDepth;\n });\n const matchedRouteRef = computed(() => routeToDisplay.value.matched[depth.value]);\n provide(viewDepthKey, computed(() => depth.value + 1));\n provide(matchedRouteKey, matchedRouteRef);\n provide(routerViewLocationKey, routeToDisplay);\n const viewRef = ref();\n // watch at the same time the component instance, the route record we are\n // rendering, and the name\n watch(() => [viewRef.value, matchedRouteRef.value, props.name], ([instance, to, name], [oldInstance, from, oldName]) => {\n // copy reused instances\n if (to) {\n // this will update the instance for new instances as well as reused\n // instances when navigating to a new route\n to.instances[name] = instance;\n // the component instance is reused for a different route or name, so\n // we copy any saved update or leave guards. With async setup, the\n // mounting component will mount before the matchedRoute changes,\n // making instance === oldInstance, so we check if guards have been\n // added before. This works because we remove guards when\n // unmounting/deactivating components\n if (from && from !== to && instance && instance === oldInstance) {\n if (!to.leaveGuards.size) {\n to.leaveGuards = from.leaveGuards;\n }\n if (!to.updateGuards.size) {\n to.updateGuards = from.updateGuards;\n }\n }\n }\n // trigger beforeRouteEnter next callbacks\n if (instance &&\n to &&\n // if there is no instance but to and from are the same this might be\n // the first visit\n (!from || !isSameRouteRecord(to, from) || !oldInstance)) {\n (to.enterCallbacks[name] || []).forEach(callback => callback(instance));\n }\n }, { flush: 'post' });\n return () => {\n const route = routeToDisplay.value;\n // we need the value at the time we render because when we unmount, we\n // navigated to a different location so the value is different\n const currentName = props.name;\n const matchedRoute = matchedRouteRef.value;\n const ViewComponent = matchedRoute && matchedRoute.components[currentName];\n if (!ViewComponent) {\n return normalizeSlot(slots.default, { Component: ViewComponent, route });\n }\n // props from route configuration\n const routePropsOption = matchedRoute.props[currentName];\n const routeProps = routePropsOption\n ? routePropsOption === true\n ? route.params\n : typeof routePropsOption === 'function'\n ? routePropsOption(route)\n : routePropsOption\n : null;\n const onVnodeUnmounted = vnode => {\n // remove the instance reference to prevent leak\n if (vnode.component.isUnmounted) {\n matchedRoute.instances[currentName] = null;\n }\n };\n const component = h(ViewComponent, assign({}, routeProps, attrs, {\n onVnodeUnmounted,\n ref: viewRef,\n }));\n if (((process.env.NODE_ENV !== 'production') || __VUE_PROD_DEVTOOLS__) &&\n isBrowser &&\n component.ref) {\n // TODO: can display if it's an alias, its props\n const info = {\n depth: depth.value,\n name: matchedRoute.name,\n path: matchedRoute.path,\n meta: matchedRoute.meta,\n };\n const internalInstances = isArray(component.ref)\n ? component.ref.map(r => r.i)\n : [component.ref.i];\n internalInstances.forEach(instance => {\n // @ts-expect-error\n instance.__vrv_devtools = info;\n });\n }\n return (\n // pass the vnode to the slot as a prop.\n // h and <component :is=\"...\"> both accept vnodes\n normalizeSlot(slots.default, { Component: component, route }) ||\n component);\n };\n },\n});\nfunction normalizeSlot(slot, data) {\n if (!slot)\n return null;\n const slotContent = slot(data);\n return slotContent.length === 1 ? slotContent[0] : slotContent;\n}\n// export the public type for h/tsx inference\n// also to avoid inline import() in generated d.ts files\n/**\n * Component to display the current route the user is at.\n */\nconst RouterView = RouterViewImpl;\n// warn against deprecated usage with <transition> & <keep-alive>\n// due to functional component being no longer eager in Vue 3\nfunction warnDeprecatedUsage() {\n const instance = getCurrentInstance();\n const parentName = instance.parent && instance.parent.type.name;\n const parentSubTreeType = instance.parent && instance.parent.subTree && instance.parent.subTree.type;\n if (parentName &&\n (parentName === 'KeepAlive' || parentName.includes('Transition')) &&\n typeof parentSubTreeType === 'object' &&\n parentSubTreeType.name === 'RouterView') {\n const comp = parentName === 'KeepAlive' ? 'keep-alive' : 'transition';\n warn(`<router-view> can no longer be used directly inside <transition> or <keep-alive>.\\n` +\n `Use slot props instead:\\n\\n` +\n `<router-view v-slot=\"{ Component }\">\\n` +\n ` <${comp}>\\n` +\n ` <component :is=\"Component\" />\\n` +\n ` </${comp}>\\n` +\n `</router-view>`);\n }\n}\n\n/**\n * Copies a route location and removes any problematic properties that cannot be shown in devtools (e.g. Vue instances).\n *\n * @param routeLocation - routeLocation to format\n * @param tooltip - optional tooltip\n * @returns a copy of the routeLocation\n */\nfunction formatRouteLocation(routeLocation, tooltip) {\n const copy = assign({}, routeLocation, {\n // remove variables that can contain vue instances\n matched: routeLocation.matched.map(matched => omit(matched, ['instances', 'children', 'aliasOf'])),\n });\n return {\n _custom: {\n type: null,\n readOnly: true,\n display: routeLocation.fullPath,\n tooltip,\n value: copy,\n },\n };\n}\nfunction formatDisplay(display) {\n return {\n _custom: {\n display,\n },\n };\n}\n// to support multiple router instances\nlet routerId = 0;\nfunction addDevtools(app, router, matcher) {\n // Take over router.beforeEach and afterEach\n // make sure we are not registering the devtool twice\n if (router.__hasDevtools)\n return;\n router.__hasDevtools = true;\n // increment to support multiple router instances\n const id = routerId++;\n setupDevtoolsPlugin({\n id: 'org.vuejs.router' + (id ? '.' + id : ''),\n label: 'Vue Router',\n packageName: 'vue-router',\n homepage: 'https://router.vuejs.org',\n logo: 'https://router.vuejs.org/logo.png',\n componentStateTypes: ['Routing'],\n app,\n }, api => {\n if (typeof api.now !== 'function') {\n console.warn('[Vue Router]: You seem to be using an outdated version of Vue Devtools. Are you still using the Beta release instead of the stable one? You can find the links at https://devtools.vuejs.org/guide/installation.html.');\n }\n // display state added by the router\n api.on.inspectComponent((payload, ctx) => {\n if (payload.instanceData) {\n payload.instanceData.state.push({\n type: 'Routing',\n key: '$route',\n editable: false,\n value: formatRouteLocation(router.currentRoute.value, 'Current Route'),\n });\n }\n });\n // mark router-link as active and display tags on router views\n api.on.visitComponentTree(({ treeNode: node, componentInstance }) => {\n if (componentInstance.__vrv_devtools) {\n const info = componentInstance.__vrv_devtools;\n node.tags.push({\n label: (info.name ? `${info.name.toString()}: ` : '') + info.path,\n textColor: 0,\n tooltip: 'This component is rendered by &lt;router-view&gt;',\n backgroundColor: PINK_500,\n });\n }\n // if multiple useLink are used\n if (isArray(componentInstance.__vrl_devtools)) {\n componentInstance.__devtoolsApi = api;\n componentInstance.__vrl_devtools.forEach(devtoolsData => {\n let label = devtoolsData.route.path;\n let backgroundColor = ORANGE_400;\n let tooltip = '';\n let textColor = 0;\n if (devtoolsData.error) {\n label = devtoolsData.error;\n backgroundColor = RED_100;\n textColor = RED_700;\n }\n else if (devtoolsData.isExactActive) {\n backgroundColor = LIME_500;\n tooltip = 'This is exactly active';\n }\n else if (devtoolsData.isActive) {\n backgroundColor = BLUE_600;\n tooltip = 'This link is active';\n }\n node.tags.push({\n label,\n textColor,\n tooltip,\n backgroundColor,\n });\n });\n }\n });\n watch(router.currentRoute, () => {\n // refresh active state\n refreshRoutesView();\n api.notifyComponentUpdate();\n api.sendInspectorTree(routerInspectorId);\n api.sendInspectorState(routerInspectorId);\n });\n const navigationsLayerId = 'router:navigations:' + id;\n api.addTimelineLayer({\n id: navigationsLayerId,\n label: `Router${id ? ' ' + id : ''} Navigations`,\n color: 0x40a8c4,\n });\n // const errorsLayerId = 'router:errors'\n // api.addTimelineLayer({\n // id: errorsLayerId,\n // label: 'Router Errors',\n // color: 0xea5455,\n // })\n router.onError((error, to) => {\n api.addTimelineEvent({\n layerId: navigationsLayerId,\n event: {\n title: 'Error during Navigation',\n subtitle: to.fullPath,\n logType: 'error',\n time: api.now(),\n data: { error },\n groupId: to.meta.__navigationId,\n },\n });\n });\n // attached to `meta` and used to group events\n let navigationId = 0;\n router.beforeEach((to, from) => {\n const data = {\n guard: formatDisplay('beforeEach'),\n from: formatRouteLocation(from, 'Current Location during this navigation'),\n to: formatRouteLocation(to, 'Target location'),\n };\n // Used to group navigations together, hide from devtools\n Object.defineProperty(to.meta, '__navigationId', {\n value: navigationId++,\n });\n api.addTimelineEvent({\n layerId: navigationsLayerId,\n event: {\n time: api.now(),\n title: 'Start of navigation',\n subtitle: to.fullPath,\n data,\n groupId: to.meta.__navigationId,\n },\n });\n });\n router.afterEach((to, from, failure) => {\n const data = {\n guard: formatDisplay('afterEach'),\n };\n if (failure) {\n data.failure = {\n _custom: {\n type: Error,\n readOnly: true,\n display: failure ? failure.message : '',\n tooltip: 'Navigation Failure',\n value: failure,\n },\n };\n data.status = formatDisplay('❌');\n }\n else {\n data.status = formatDisplay('✅');\n }\n // we set here to have the right order\n data.from = formatRouteLocation(from, 'Current Location during this navigation');\n data.to = formatRouteLocation(to, 'Target location');\n api.addTimelineEvent({\n layerId: navigationsLayerId,\n event: {\n title: 'End of navigation',\n subtitle: to.fullPath,\n time: api.now(),\n data,\n logType: failure ? 'warning' : 'default',\n groupId: to.meta.__navigationId,\n },\n });\n });\n /**\n * Inspector of Existing routes\n */\n const routerInspectorId = 'router-inspector:' + id;\n api.addInspector({\n id: routerInspectorId,\n label: 'Routes' + (id ? ' ' + id : ''),\n icon: 'book',\n treeFilterPlaceholder: 'Search routes',\n });\n function refreshRoutesView() {\n // the routes view isn't active\n if (!activeRoutesPayload)\n return;\n const payload = activeRoutesPayload;\n // children routes will appear as nested\n let routes = matcher.getRoutes().filter(route => !route.parent ||\n // these routes have a parent with no component which will not appear in the view\n // therefore we still need to include them\n !route.parent.record.components);\n // reset match state to false\n routes.forEach(resetMatchStateOnRouteRecord);\n // apply a match state if there is a payload\n if (payload.filter) {\n routes = routes.filter(route => \n // save matches state based on the payload\n isRouteMatching(route, payload.filter.toLowerCase()));\n }\n // mark active routes\n routes.forEach(route => markRouteRecordActive(route, router.currentRoute.value));\n payload.rootNodes = routes.map(formatRouteRecordForInspector);\n }\n let activeRoutesPayload;\n api.on.getInspectorTree(payload => {\n activeRoutesPayload = payload;\n if (payload.app === app && payload.inspectorId === routerInspectorId) {\n refreshRoutesView();\n }\n });\n /**\n * Display information about the currently selected route record\n */\n api.on.getInspectorState(payload => {\n if (payload.app === app && payload.inspectorId === routerInspectorId) {\n const routes = matcher.getRoutes();\n const route = routes.find(route => route.record.__vd_id === payload.nodeId);\n if (route) {\n payload.state = {\n options: formatRouteRecordMatcherForStateInspector(route),\n };\n }\n }\n });\n api.sendInspectorTree(routerInspectorId);\n api.sendInspectorState(routerInspectorId);\n });\n}\nfunction modifierForKey(key) {\n if (key.optional) {\n return key.repeatable ? '*' : '?';\n }\n else {\n return key.repeatable ? '+' : '';\n }\n}\nfunction formatRouteRecordMatcherForStateInspector(route) {\n const { record } = route;\n const fields = [\n { editable: false, key: 'path', value: record.path },\n ];\n if (record.name != null) {\n fields.push({\n editable: false,\n key: 'name',\n value: record.name,\n });\n }\n fields.push({ editable: false, key: 'regexp', value: route.re });\n if (route.keys.length) {\n fields.push({\n editable: false,\n key: 'keys',\n value: {\n _custom: {\n type: null,\n readOnly: true,\n display: route.keys\n .map(key => `${key.name}${modifierForKey(key)}`)\n .join(' '),\n tooltip: 'Param keys',\n value: route.keys,\n },\n },\n });\n }\n if (record.redirect != null) {\n fields.push({\n editable: false,\n key: 'redirect',\n value: record.redirect,\n });\n }\n if (route.alias.length) {\n fields.push({\n editable: false,\n key: 'aliases',\n value: route.alias.map(alias => alias.record.path),\n });\n }\n if (Object.keys(route.record.meta).length) {\n fields.push({\n editable: false,\n key: 'meta',\n value: route.record.meta,\n });\n }\n fields.push({\n key: 'score',\n editable: false,\n value: {\n _custom: {\n type: null,\n readOnly: true,\n display: route.score.map(score => score.join(', ')).join(' | '),\n tooltip: 'Score used to sort routes',\n value: route.score,\n },\n },\n });\n return fields;\n}\n/**\n * Extracted from tailwind palette\n */\nconst PINK_500 = 0xec4899;\nconst BLUE_600 = 0x2563eb;\nconst LIME_500 = 0x84cc16;\nconst CYAN_400 = 0x22d3ee;\nconst ORANGE_400 = 0xfb923c;\n// const GRAY_100 = 0xf4f4f5\nconst DARK = 0x666666;\nconst RED_100 = 0xfee2e2;\nconst RED_700 = 0xb91c1c;\nfunction formatRouteRecordForInspector(route) {\n const tags = [];\n const { record } = route;\n if (record.name != null) {\n tags.push({\n label: String(record.name),\n textColor: 0,\n backgroundColor: CYAN_400,\n });\n }\n if (record.aliasOf) {\n tags.push({\n label: 'alias',\n textColor: 0,\n backgroundColor: ORANGE_400,\n });\n }\n if (route.__vd_match) {\n tags.push({\n label: 'matches',\n textColor: 0,\n backgroundColor: PINK_500,\n });\n }\n if (route.__vd_exactActive) {\n tags.push({\n label: 'exact',\n textColor: 0,\n backgroundColor: LIME_500,\n });\n }\n if (route.__vd_active) {\n tags.push({\n label: 'active',\n textColor: 0,\n backgroundColor: BLUE_600,\n });\n }\n if (record.redirect) {\n tags.push({\n label: typeof record.redirect === 'string'\n ? `redirect: ${record.redirect}`\n : 'redirects',\n textColor: 0xffffff,\n backgroundColor: DARK,\n });\n }\n // add an id to be able to select it. Using the `path` is not possible because\n // empty path children would collide with their parents\n let id = record.__vd_id;\n if (id == null) {\n id = String(routeRecordId++);\n record.__vd_id = id;\n }\n return {\n id,\n label: record.path,\n tags,\n children: route.children.map(formatRouteRecordForInspector),\n };\n}\n// incremental id for route records and inspector state\nlet routeRecordId = 0;\nconst EXTRACT_REGEXP_RE = /^\\/(.*)\\/([a-z]*)$/;\nfunction markRouteRecordActive(route, currentRoute) {\n // no route will be active if matched is empty\n // reset the matching state\n const isExactActive = currentRoute.matched.length &&\n isSameRouteRecord(currentRoute.matched[currentRoute.matched.length - 1], route.record);\n route.__vd_exactActive = route.__vd_active = isExactActive;\n if (!isExactActive) {\n route.__vd_active = currentRoute.matched.some(match => isSameRouteRecord(match, route.record));\n }\n route.children.forEach(childRoute => markRouteRecordActive(childRoute, currentRoute));\n}\nfunction resetMatchStateOnRouteRecord(route) {\n route.__vd_match = false;\n route.children.forEach(resetMatchStateOnRouteRecord);\n}\nfunction isRouteMatching(route, filter) {\n const found = String(route.re).match(EXTRACT_REGEXP_RE);\n route.__vd_match = false;\n if (!found || found.length < 3) {\n return false;\n }\n // use a regexp without $ at the end to match nested routes better\n const nonEndingRE = new RegExp(found[1].replace(/\\$$/, ''), found[2]);\n if (nonEndingRE.test(filter)) {\n // mark children as matches\n route.children.forEach(child => isRouteMatching(child, filter));\n // exception case: `/`\n if (route.record.path !== '/' || filter === '/') {\n route.__vd_match = route.re.test(filter);\n return true;\n }\n // hide the / route\n return false;\n }\n const path = route.record.path.toLowerCase();\n const decodedPath = decode(path);\n // also allow partial matching on the path\n if (!filter.startsWith('/') &&\n (decodedPath.includes(filter) || path.includes(filter)))\n return true;\n if (decodedPath.startsWith(filter) || path.startsWith(filter))\n return true;\n if (route.record.name && String(route.record.name).includes(filter))\n return true;\n return route.children.some(child => isRouteMatching(child, filter));\n}\nfunction omit(obj, keys) {\n const ret = {};\n for (const key in obj) {\n if (!keys.includes(key)) {\n // @ts-expect-error\n ret[key] = obj[key];\n }\n }\n return ret;\n}\n\n/**\n * Creates a Router instance that can be used by a Vue app.\n *\n * @param options - {@link RouterOptions}\n */\nfunction createRouter(options) {\n const matcher = createRouterMatcher(options.routes, options);\n const parseQuery$1 = options.parseQuery || parseQuery;\n const stringifyQuery$1 = options.stringifyQuery || stringifyQuery;\n const routerHistory = options.history;\n if ((process.env.NODE_ENV !== 'production') && !routerHistory)\n throw new Error('Provide the \"history\" option when calling \"createRouter()\":' +\n ' https://router.vuejs.org/api/interfaces/RouterOptions.html#history');\n const beforeGuards = useCallbacks();\n const beforeResolveGuards = useCallbacks();\n const afterGuards = useCallbacks();\n const currentRoute = shallowRef(START_LOCATION_NORMALIZED);\n let pendingLocation = START_LOCATION_NORMALIZED;\n // leave the scrollRestoration if no scrollBehavior is provided\n if (isBrowser && options.scrollBehavior && 'scrollRestoration' in history) {\n history.scrollRestoration = 'manual';\n }\n const normalizeParams = applyToParams.bind(null, paramValue => '' + paramValue);\n const encodeParams = applyToParams.bind(null, encodeParam);\n const decodeParams = \n // @ts-expect-error: intentionally avoid the type check\n applyToParams.bind(null, decode);\n function addRoute(parentOrRoute, route) {\n let parent;\n let record;\n if (isRouteName(parentOrRoute)) {\n parent = matcher.getRecordMatcher(parentOrRoute);\n if ((process.env.NODE_ENV !== 'production') && !parent) {\n warn(`Parent route \"${String(parentOrRoute)}\" not found when adding child route`, route);\n }\n record = route;\n }\n else {\n record = parentOrRoute;\n }\n return matcher.addRoute(record, parent);\n }\n function removeRoute(name) {\n const recordMatcher = matcher.getRecordMatcher(name);\n if (recordMatcher) {\n matcher.removeRoute(recordMatcher);\n }\n else if ((process.env.NODE_ENV !== 'production')) {\n warn(`Cannot remove non-existent route \"${String(name)}\"`);\n }\n }\n function getRoutes() {\n return matcher.getRoutes().map(routeMatcher => routeMatcher.record);\n }\n function hasRoute(name) {\n return !!matcher.getRecordMatcher(name);\n }\n function resolve(rawLocation, currentLocation) {\n // const resolve: Router['resolve'] = (rawLocation: RouteLocationRaw, currentLocation) => {\n // const objectLocation = routerLocationAsObject(rawLocation)\n // we create a copy to modify it later\n currentLocation = assign({}, currentLocation || currentRoute.value);\n if (typeof rawLocation === 'string') {\n const locationNormalized = parseURL(parseQuery$1, rawLocation, currentLocation.path);\n const matchedRoute = matcher.resolve({ path: locationNormalized.path }, currentLocation);\n const href = routerHistory.createHref(locationNormalized.fullPath);\n if ((process.env.NODE_ENV !== 'production')) {\n if (href.startsWith('//'))\n warn(`Location \"${rawLocation}\" resolved to \"${href}\". A resolved location cannot start with multiple slashes.`);\n else if (!matchedRoute.matched.length) {\n warn(`No match found for location with path \"${rawLocation}\"`);\n }\n }\n // locationNormalized is always a new object\n return assign(locationNormalized, matchedRoute, {\n params: decodeParams(matchedRoute.params),\n hash: decode(locationNormalized.hash),\n redirectedFrom: undefined,\n href,\n });\n }\n if ((process.env.NODE_ENV !== 'production') && !isRouteLocation(rawLocation)) {\n warn(`router.resolve() was passed an invalid location. This will fail in production.\\n- Location:`, rawLocation);\n return resolve({});\n }\n let matcherLocation;\n // path could be relative in object as well\n if (rawLocation.path != null) {\n if ((process.env.NODE_ENV !== 'production') &&\n 'params' in rawLocation &&\n !('name' in rawLocation) &&\n // @ts-expect-error: the type is never\n Object.keys(rawLocation.params).length) {\n warn(`Path \"${rawLocation.path}\" was passed with params but they will be ignored. Use a named route alongside params instead.`);\n }\n matcherLocation = assign({}, rawLocation, {\n path: parseURL(parseQuery$1, rawLocation.path, currentLocation.path).path,\n });\n }\n else {\n // remove any nullish param\n const targetParams = assign({}, rawLocation.params);\n for (const key in targetParams) {\n if (targetParams[key] == null) {\n delete targetParams[key];\n }\n }\n // pass encoded values to the matcher, so it can produce encoded path and fullPath\n matcherLocation = assign({}, rawLocation, {\n params: encodeParams(targetParams),\n });\n // current location params are decoded, we need to encode them in case the\n // matcher merges the params\n currentLocation.params = encodeParams(currentLocation.params);\n }\n const matchedRoute = matcher.resolve(matcherLocation, currentLocation);\n const hash = rawLocation.hash || '';\n if ((process.env.NODE_ENV !== 'production') && hash && !hash.startsWith('#')) {\n warn(`A \\`hash\\` should always start with the character \"#\". Replace \"${hash}\" with \"#${hash}\".`);\n }\n // the matcher might have merged current location params, so\n // we need to run the decoding again\n matchedRoute.params = normalizeParams(decodeParams(matchedRoute.params));\n const fullPath = stringifyURL(stringifyQuery$1, assign({}, rawLocation, {\n hash: encodeHash(hash),\n path: matchedRoute.path,\n }));\n const href = routerHistory.createHref(fullPath);\n if ((process.env.NODE_ENV !== 'production')) {\n if (href.startsWith('//')) {\n warn(`Location \"${rawLocation}\" resolved to \"${href}\". A resolved location cannot start with multiple slashes.`);\n }\n else if (!matchedRoute.matched.length) {\n warn(`No match found for location with path \"${rawLocation.path != null ? rawLocation.path : rawLocation}\"`);\n }\n }\n return assign({\n fullPath,\n // keep the hash encoded so fullPath is effectively path + encodedQuery +\n // hash\n hash,\n query: \n // if the user is using a custom query lib like qs, we might have\n // nested objects, so we keep the query as is, meaning it can contain\n // numbers at `$route.query`, but at the point, the user will have to\n // use their own type anyway.\n // https://github.com/vuejs/router/issues/328#issuecomment-649481567\n stringifyQuery$1 === stringifyQuery\n ? normalizeQuery(rawLocation.query)\n : (rawLocation.query || {}),\n }, matchedRoute, {\n redirectedFrom: undefined,\n href,\n });\n }\n function locationAsObject(to) {\n return typeof to === 'string'\n ? parseURL(parseQuery$1, to, currentRoute.value.path)\n : assign({}, to);\n }\n function checkCanceledNavigation(to, from) {\n if (pendingLocation !== to) {\n return createRouterError(8 /* ErrorTypes.NAVIGATION_CANCELLED */, {\n from,\n to,\n });\n }\n }\n function push(to) {\n return pushWithRedirect(to);\n }\n function replace(to) {\n return push(assign(locationAsObject(to), { replace: true }));\n }\n function handleRedirectRecord(to) {\n const lastMatched = to.matched[to.matched.length - 1];\n if (lastMatched && lastMatched.redirect) {\n const { redirect } = lastMatched;\n let newTargetLocation = typeof redirect === 'function' ? redirect(to) : redirect;\n if (typeof newTargetLocation === 'string') {\n newTargetLocation =\n newTargetLocation.includes('?') || newTargetLocation.includes('#')\n ? (newTargetLocation = locationAsObject(newTargetLocation))\n : // force empty params\n { path: newTargetLocation };\n // @ts-expect-error: force empty params when a string is passed to let\n // the router parse them again\n newTargetLocation.params = {};\n }\n if ((process.env.NODE_ENV !== 'production') &&\n newTargetLocation.path == null &&\n !('name' in newTargetLocation)) {\n warn(`Invalid redirect found:\\n${JSON.stringify(newTargetLocation, null, 2)}\\n when navigating to \"${to.fullPath}\". A redirect must contain a name or path. This will break in production.`);\n throw new Error('Invalid redirect');\n }\n return assign({\n query: to.query,\n hash: to.hash,\n // avoid transferring params if the redirect has a path\n params: newTargetLocation.path != null ? {} : to.params,\n }, newTargetLocation);\n }\n }\n function pushWithRedirect(to, redirectedFrom) {\n const targetLocation = (pendingLocation = resolve(to));\n const from = currentRoute.value;\n const data = to.state;\n const force = to.force;\n // to could be a string where `replace` is a function\n const replace = to.replace === true;\n const shouldRedirect = handleRedirectRecord(targetLocation);\n if (shouldRedirect)\n return pushWithRedirect(assign(locationAsObject(shouldRedirect), {\n state: typeof shouldRedirect === 'object'\n ? assign({}, data, shouldRedirect.state)\n : data,\n force,\n replace,\n }), \n // keep original redirectedFrom if it exists\n redirectedFrom || targetLocation);\n // if it was a redirect we already called `pushWithRedirect` above\n const toLocation = targetLocation;\n toLocation.redirectedFrom = redirectedFrom;\n let failure;\n if (!force && isSameRouteLocation(stringifyQuery$1, from, targetLocation)) {\n failure = createRouterError(16 /* ErrorTypes.NAVIGATION_DUPLICATED */, { to: toLocation, from });\n // trigger scroll to allow scrolling to the same anchor\n handleScroll(from, from, \n // this is a push, the only way for it to be triggered from a\n // history.listen is with a redirect, which makes it become a push\n true, \n // This cannot be the first navigation because the initial location\n // cannot be manually navigated to\n false);\n }\n return (failure ? Promise.resolve(failure) : navigate(toLocation, from))\n .catch((error) => isNavigationFailure(error)\n ? // navigation redirects still mark the router as ready\n isNavigationFailure(error, 2 /* ErrorTypes.NAVIGATION_GUARD_REDIRECT */)\n ? error\n : markAsReady(error) // also returns the error\n : // reject any unknown error\n triggerError(error, toLocation, from))\n .then((failure) => {\n if (failure) {\n if (isNavigationFailure(failure, 2 /* ErrorTypes.NAVIGATION_GUARD_REDIRECT */)) {\n if ((process.env.NODE_ENV !== 'production') &&\n // we are redirecting to the same location we were already at\n isSameRouteLocation(stringifyQuery$1, resolve(failure.to), toLocation) &&\n // and we have done it a couple of times\n redirectedFrom &&\n // @ts-expect-error: added only in dev\n (redirectedFrom._count = redirectedFrom._count\n ? // @ts-expect-error\n redirectedFrom._count + 1\n : 1) > 30) {\n warn(`Detected a possibly infinite redirection in a navigation guard when going from \"${from.fullPath}\" to \"${toLocation.fullPath}\". Aborting to avoid a Stack Overflow.\\n Are you always returning a new location within a navigation guard? That would lead to this error. Only return when redirecting or aborting, that should fix this. This might break in production if not fixed.`);\n return Promise.reject(new Error('Infinite redirect in navigation guard'));\n }\n return pushWithRedirect(\n // keep options\n assign({\n // preserve an existing replacement but allow the redirect to override it\n replace,\n }, locationAsObject(failure.to), {\n state: typeof failure.to === 'object'\n ? assign({}, data, failure.to.state)\n : data,\n force,\n }), \n // preserve the original redirectedFrom if any\n redirectedFrom || toLocation);\n }\n }\n else {\n // if we fail we don't finalize the navigation\n failure = finalizeNavigation(toLocation, from, true, replace, data);\n }\n triggerAfterEach(toLocation, from, failure);\n return failure;\n });\n }\n /**\n * Helper to reject and skip all navigation guards if a new navigation happened\n * @param to\n * @param from\n */\n function checkCanceledNavigationAndReject(to, from) {\n const error = checkCanceledNavigation(to, from);\n return error ? Promise.reject(error) : Promise.resolve();\n }\n function runWithContext(fn) {\n const app = installedApps.values().next().value;\n // support Vue < 3.3\n return app && typeof app.runWithContext === 'function'\n ? app.runWithContext(fn)\n : fn();\n }\n // TODO: refactor the whole before guards by internally using router.beforeEach\n function navigate(to, from) {\n let guards;\n const [leavingRecords, updatingRecords, enteringRecords] = extractChangingRecords(to, from);\n // all components here have been resolved once because we are leaving\n guards = extractComponentsGuards(leavingRecords.reverse(), 'beforeRouteLeave', to, from);\n // leavingRecords is already reversed\n for (const record of leavingRecords) {\n record.leaveGuards.forEach(guard => {\n guards.push(guardToPromiseFn(guard, to, from));\n });\n }\n const canceledNavigationCheck = checkCanceledNavigationAndReject.bind(null, to, from);\n guards.push(canceledNavigationCheck);\n // run the queue of per route beforeRouteLeave guards\n return (runGuardQueue(guards)\n .then(() => {\n // check global guards beforeEach\n guards = [];\n for (const guard of beforeGuards.list()) {\n guards.push(guardToPromiseFn(guard, to, from));\n }\n guards.push(canceledNavigationCheck);\n return runGuardQueue(guards);\n })\n .then(() => {\n // check in components beforeRouteUpdate\n guards = extractComponentsGuards(updatingRecords, 'beforeRouteUpdate', to, from);\n for (const record of updatingRecords) {\n record.updateGuards.forEach(guard => {\n guards.push(guardToPromiseFn(guard, to, from));\n });\n }\n guards.push(canceledNavigationCheck);\n // run the queue of per route beforeEnter guards\n return runGuardQueue(guards);\n })\n .then(() => {\n // check the route beforeEnter\n guards = [];\n for (const record of enteringRecords) {\n // do not trigger beforeEnter on reused views\n if (record.beforeEnter) {\n if (isArray(record.beforeEnter)) {\n for (const beforeEnter of record.beforeEnter)\n guards.push(guardToPromiseFn(beforeEnter, to, from));\n }\n else {\n guards.push(guardToPromiseFn(record.beforeEnter, to, from));\n }\n }\n }\n guards.push(canceledNavigationCheck);\n // run the queue of per route beforeEnter guards\n return runGuardQueue(guards);\n })\n .then(() => {\n // NOTE: at this point to.matched is normalized and does not contain any () => Promise<Component>\n // clear existing enterCallbacks, these are added by extractComponentsGuards\n to.matched.forEach(record => (record.enterCallbacks = {}));\n // check in-component beforeRouteEnter\n guards = extractComponentsGuards(enteringRecords, 'beforeRouteEnter', to, from, runWithContext);\n guards.push(canceledNavigationCheck);\n // run the queue of per route beforeEnter guards\n return runGuardQueue(guards);\n })\n .then(() => {\n // check global guards beforeResolve\n guards = [];\n for (const guard of beforeResolveGuards.list()) {\n guards.push(guardToPromiseFn(guard, to, from));\n }\n guards.push(canceledNavigationCheck);\n return runGuardQueue(guards);\n })\n // catch any navigation canceled\n .catch(err => isNavigationFailure(err, 8 /* ErrorTypes.NAVIGATION_CANCELLED */)\n ? err\n : Promise.reject(err)));\n }\n function triggerAfterEach(to, from, failure) {\n // navigation is confirmed, call afterGuards\n // TODO: wrap with error handlers\n afterGuards\n .list()\n .forEach(guard => runWithContext(() => guard(to, from, failure)));\n }\n /**\n * - Cleans up any navigation guards\n * - Changes the url if necessary\n * - Calls the scrollBehavior\n */\n function finalizeNavigation(toLocation, from, isPush, replace, data) {\n // a more recent navigation took place\n const error = checkCanceledNavigation(toLocation, from);\n if (error)\n return error;\n // only consider as push if it's not the first navigation\n const isFirstNavigation = from === START_LOCATION_NORMALIZED;\n const state = !isBrowser ? {} : history.state;\n // change URL only if the user did a push/replace and if it's not the initial navigation because\n // it's just reflecting the url\n if (isPush) {\n // on the initial navigation, we want to reuse the scroll position from\n // history state if it exists\n if (replace || isFirstNavigation)\n routerHistory.replace(toLocation.fullPath, assign({\n scroll: isFirstNavigation && state && state.scroll,\n }, data));\n else\n routerHistory.push(toLocation.fullPath, data);\n }\n // accept current navigation\n currentRoute.value = toLocation;\n handleScroll(toLocation, from, isPush, isFirstNavigation);\n markAsReady();\n }\n let removeHistoryListener;\n // attach listener to history to trigger navigations\n function setupListeners() {\n // avoid setting up listeners twice due to an invalid first navigation\n if (removeHistoryListener)\n return;\n removeHistoryListener = routerHistory.listen((to, _from, info) => {\n if (!router.listening)\n return;\n // cannot be a redirect route because it was in history\n const toLocation = resolve(to);\n // due to dynamic routing, and to hash history with manual navigation\n // (manually changing the url or calling history.hash = '#/somewhere'),\n // there could be a redirect record in history\n const shouldRedirect = handleRedirectRecord(toLocation);\n if (shouldRedirect) {\n pushWithRedirect(assign(shouldRedirect, { replace: true, force: true }), toLocation).catch(noop);\n return;\n }\n pendingLocation = toLocation;\n const from = currentRoute.value;\n // TODO: should be moved to web history?\n if (isBrowser) {\n saveScrollPosition(getScrollKey(from.fullPath, info.delta), computeScrollPosition());\n }\n navigate(toLocation, from)\n .catch((error) => {\n if (isNavigationFailure(error, 4 /* ErrorTypes.NAVIGATION_ABORTED */ | 8 /* ErrorTypes.NAVIGATION_CANCELLED */)) {\n return error;\n }\n if (isNavigationFailure(error, 2 /* ErrorTypes.NAVIGATION_GUARD_REDIRECT */)) {\n // Here we could call if (info.delta) routerHistory.go(-info.delta,\n // false) but this is bug prone as we have no way to wait the\n // navigation to be finished before calling pushWithRedirect. Using\n // a setTimeout of 16ms seems to work but there is no guarantee for\n // it to work on every browser. So instead we do not restore the\n // history entry and trigger a new navigation as requested by the\n // navigation guard.\n // the error is already handled by router.push we just want to avoid\n // logging the error\n pushWithRedirect(assign(locationAsObject(error.to), {\n force: true,\n }), toLocation\n // avoid an uncaught rejection, let push call triggerError\n )\n .then(failure => {\n // manual change in hash history #916 ending up in the URL not\n // changing, but it was changed by the manual url change, so we\n // need to manually change it ourselves\n if (isNavigationFailure(failure, 4 /* ErrorTypes.NAVIGATION_ABORTED */ |\n 16 /* ErrorTypes.NAVIGATION_DUPLICATED */) &&\n !info.delta &&\n info.type === NavigationType.pop) {\n routerHistory.go(-1, false);\n }\n })\n .catch(noop);\n // avoid the then branch\n return Promise.reject();\n }\n // do not restore history on unknown direction\n if (info.delta) {\n routerHistory.go(-info.delta, false);\n }\n // unrecognized error, transfer to the global handler\n return triggerError(error, toLocation, from);\n })\n .then((failure) => {\n failure =\n failure ||\n finalizeNavigation(\n // after navigation, all matched components are resolved\n toLocation, from, false);\n // revert the navigation\n if (failure) {\n if (info.delta &&\n // a new navigation has been triggered, so we do not want to revert, that will change the current history\n // entry while a different route is displayed\n !isNavigationFailure(failure, 8 /* ErrorTypes.NAVIGATION_CANCELLED */)) {\n routerHistory.go(-info.delta, false);\n }\n else if (info.type === NavigationType.pop &&\n isNavigationFailure(failure, 4 /* ErrorTypes.NAVIGATION_ABORTED */ | 16 /* ErrorTypes.NAVIGATION_DUPLICATED */)) {\n // manual change in hash history #916\n // it's like a push but lacks the information of the direction\n routerHistory.go(-1, false);\n }\n }\n triggerAfterEach(toLocation, from, failure);\n })\n // avoid warnings in the console about uncaught rejections, they are logged by triggerErrors\n .catch(noop);\n });\n }\n // Initialization and Errors\n let readyHandlers = useCallbacks();\n let errorListeners = useCallbacks();\n let ready;\n /**\n * Trigger errorListeners added via onError and throws the error as well\n *\n * @param error - error to throw\n * @param to - location we were navigating to when the error happened\n * @param from - location we were navigating from when the error happened\n * @returns the error as a rejected promise\n */\n function triggerError(error, to, from) {\n markAsReady(error);\n const list = errorListeners.list();\n if (list.length) {\n list.forEach(handler => handler(error, to, from));\n }\n else {\n if ((process.env.NODE_ENV !== 'production')) {\n warn('uncaught error during route navigation:');\n }\n console.error(error);\n }\n // reject the error no matter there were error listeners or not\n return Promise.reject(error);\n }\n function isReady() {\n if (ready && currentRoute.value !== START_LOCATION_NORMALIZED)\n return Promise.resolve();\n return new Promise((resolve, reject) => {\n readyHandlers.add([resolve, reject]);\n });\n }\n function markAsReady(err) {\n if (!ready) {\n // still not ready if an error happened\n ready = !err;\n setupListeners();\n readyHandlers\n .list()\n .forEach(([resolve, reject]) => (err ? reject(err) : resolve()));\n readyHandlers.reset();\n }\n return err;\n }\n // Scroll behavior\n function handleScroll(to, from, isPush, isFirstNavigation) {\n const { scrollBehavior } = options;\n if (!isBrowser || !scrollBehavior)\n return Promise.resolve();\n const scrollPosition = (!isPush && getSavedScrollPosition(getScrollKey(to.fullPath, 0))) ||\n ((isFirstNavigation || !isPush) &&\n history.state &&\n history.state.scroll) ||\n null;\n return nextTick()\n .then(() => scrollBehavior(to, from, scrollPosition))\n .then(position => position && scrollToPosition(position))\n .catch(err => triggerError(err, to, from));\n }\n const go = (delta) => routerHistory.go(delta);\n let started;\n const installedApps = new Set();\n const router = {\n currentRoute,\n listening: true,\n addRoute,\n removeRoute,\n clearRoutes: matcher.clearRoutes,\n hasRoute,\n getRoutes,\n resolve,\n options,\n push,\n replace,\n go,\n back: () => go(-1),\n forward: () => go(1),\n beforeEach: beforeGuards.add,\n beforeResolve: beforeResolveGuards.add,\n afterEach: afterGuards.add,\n onError: errorListeners.add,\n isReady,\n install(app) {\n const router = this;\n app.component('RouterLink', RouterLink);\n app.component('RouterView', RouterView);\n app.config.globalProperties.$router = router;\n Object.defineProperty(app.config.globalProperties, '$route', {\n enumerable: true,\n get: () => unref(currentRoute),\n });\n // this initial navigation is only necessary on client, on server it doesn't\n // make sense because it will create an extra unnecessary navigation and could\n // lead to problems\n if (isBrowser &&\n // used for the initial navigation client side to avoid pushing\n // multiple times when the router is used in multiple apps\n !started &&\n currentRoute.value === START_LOCATION_NORMALIZED) {\n // see above\n started = true;\n push(routerHistory.location).catch(err => {\n if ((process.env.NODE_ENV !== 'production'))\n warn('Unexpected error when starting the router:', err);\n });\n }\n const reactiveRoute = {};\n for (const key in START_LOCATION_NORMALIZED) {\n Object.defineProperty(reactiveRoute, key, {\n get: () => currentRoute.value[key],\n enumerable: true,\n });\n }\n app.provide(routerKey, router);\n app.provide(routeLocationKey, shallowReactive(reactiveRoute));\n app.provide(routerViewLocationKey, currentRoute);\n const unmountApp = app.unmount;\n installedApps.add(app);\n app.unmount = function () {\n installedApps.delete(app);\n // the router is not attached to an app anymore\n if (installedApps.size < 1) {\n // invalidate the current navigation\n pendingLocation = START_LOCATION_NORMALIZED;\n removeHistoryListener && removeHistoryListener();\n removeHistoryListener = null;\n currentRoute.value = START_LOCATION_NORMALIZED;\n started = false;\n ready = false;\n }\n unmountApp();\n };\n // TODO: this probably needs to be updated so it can be used by vue-termui\n if (((process.env.NODE_ENV !== 'production') || __VUE_PROD_DEVTOOLS__) && isBrowser) {\n addDevtools(app, router, matcher);\n }\n },\n };\n // TODO: type this as NavigationGuardReturn or similar instead of any\n function runGuardQueue(guards) {\n return guards.reduce((promise, guard) => promise.then(() => runWithContext(guard)), Promise.resolve());\n }\n return router;\n}\nfunction extractChangingRecords(to, from) {\n const leavingRecords = [];\n const updatingRecords = [];\n const enteringRecords = [];\n const len = Math.max(from.matched.length, to.matched.length);\n for (let i = 0; i < len; i++) {\n const recordFrom = from.matched[i];\n if (recordFrom) {\n if (to.matched.find(record => isSameRouteRecord(record, recordFrom)))\n updatingRecords.push(recordFrom);\n else\n leavingRecords.push(recordFrom);\n }\n const recordTo = to.matched[i];\n if (recordTo) {\n // the type doesn't matter because we are comparing per reference\n if (!from.matched.find(record => isSameRouteRecord(record, recordTo))) {\n enteringRecords.push(recordTo);\n }\n }\n }\n return [leavingRecords, updatingRecords, enteringRecords];\n}\n\n/**\n * Returns the router instance. Equivalent to using `$router` inside\n * templates.\n */\nfunction useRouter() {\n return inject(routerKey);\n}\n/**\n * Returns the current route location. Equivalent to using `$route` inside\n * templates.\n */\nfunction useRoute(_name) {\n return inject(routeLocationKey);\n}\n\nexport { NavigationFailureType, RouterLink, RouterView, START_LOCATION_NORMALIZED as START_LOCATION, createMemoryHistory, createRouter, createRouterMatcher, createWebHashHistory, createWebHistory, isNavigationFailure, loadRouteLocation, matchedRouteKey, onBeforeRouteLeave, onBeforeRouteUpdate, parseQuery, routeLocationKey, routerKey, routerViewLocationKey, stringifyQuery, useLink, useRoute, useRouter, viewDepthKey };\n","import { TBinding, bindableTools } from \"@/shared/configTypes/vars\";\r\nimport * as TConfigEventTypes from \"@/shared/configTypes/event\";\r\nimport { getVueRef, createScopeSnapshot } from \"@/shared/varStore\";\r\nimport * as slotStore from \"@/shared/slotStore\";\r\n\r\nimport { Ref, toValue } from \"vue\";\r\nimport * as vforManager from \"@/shared/vforManager\";\r\nimport { TUpdateRefFromServerResponse } from \"./configTypes/server\";\r\nimport * as jsStrVar from \"@/shared/jsStrVar\";\r\nimport * as vueSystem from \"@/systems/vueSystem\";\r\nimport * as objectSystem from \"@/systems/objectSystem\";\r\nimport * as valueSystem from \"@/systems/valueSystem\";\r\nimport * as elementRefStore from \"@/shared/elementRefStore\";\r\nimport * as jsCodeSystem from \"@/systems/jsCodeSystem\";\r\nimport { useRoute, useRouter } from \"vue-router\";\r\n\r\nexport type TSnapshot = ReturnType<typeof createSnapshot>;\r\n\r\nexport function createSnapshot(vforKey?: any) {\r\n let scopeSnapshot = createScopeSnapshot();\r\n let slotSnapshot = slotStore.createSnapshot();\r\n let vforSnapshot = vforManager.createVForSnapshot(vforKey);\r\n let elementRefSnapshot = elementRefStore.createElementRefSnapshot();\r\n let routerSnapshot = useRouter();\r\n let routeSnapshot = useRoute();\r\n\r\n function replaceSnapshot(target: {\r\n scopeSnapshot?: ReturnType<typeof createScopeSnapshot>;\r\n slotSnapshot?: ReturnType<typeof slotStore.createSnapshot>;\r\n vforSnapshot?: ReturnType<typeof vforManager.createVForSnapshot>;\r\n elementRefSnapshot?: ReturnType<\r\n typeof elementRefStore.createElementRefSnapshot\r\n >;\r\n routerSnapshot?: ReturnType<typeof useRouter>;\r\n }) {\r\n if (target.scopeSnapshot) {\r\n scopeSnapshot = target.scopeSnapshot;\r\n }\r\n\r\n if (target.slotSnapshot) {\r\n slotSnapshot = target.slotSnapshot;\r\n }\r\n\r\n if (target.vforSnapshot) {\r\n vforSnapshot = target.vforSnapshot;\r\n }\r\n\r\n if (target.elementRefSnapshot) {\r\n elementRefSnapshot = target.elementRefSnapshot;\r\n }\r\n\r\n if (target.routerSnapshot) {\r\n routerSnapshot = target.routerSnapshot;\r\n }\r\n }\r\n\r\n function getObjectToValue(binding: TBinding): any {\r\n if (bindableTools.isVar(binding)) {\r\n return toValue(getVueRefObject(binding));\r\n }\r\n\r\n if (bindableTools.isVForItem(binding)) {\r\n if (vforManager.isVForLoopNumber(binding.fid)) {\r\n return vforSnapshot.getVForIndex(binding.fid);\r\n }\r\n\r\n return toValue(getVueRefObject(binding));\r\n }\r\n\r\n if (bindableTools.isVForIndex(binding)) {\r\n return vforSnapshot.getVForIndex(binding.fid);\r\n }\r\n\r\n if (bindableTools.isJs(binding)) {\r\n const { code, bind } = binding;\r\n\r\n const fnBindings = objectSystem.mapObjectForValue(bind, (val) => {\r\n return getVueRefObjectOrValue(val);\r\n });\r\n\r\n return jsStrVar.createFn(code, fnBindings)();\r\n }\r\n\r\n if (bindableTools.isSlotProp(binding)) {\r\n return slotSnapshot.getPropsValue(binding);\r\n }\r\n\r\n if (bindableTools.isRouterParams(binding)) {\r\n return toValue(getVueRefObject(binding));\r\n }\r\n\r\n throw new Error(`Invalid binding: ${binding}`);\r\n }\r\n\r\n function getVueRefObject(binding: TBinding) {\r\n if (bindableTools.isVar(binding)) {\r\n const vueObj = scopeSnapshot.getVueRef(binding) || getVueRef(binding);\r\n return vueSystem.makeRefObjectWithPaths(vueObj, {\r\n paths: binding.path,\r\n getBindableValueFn: getObjectToValue,\r\n });\r\n }\r\n\r\n if (bindableTools.isVForItem(binding)) {\r\n return vforManager.createRefObjectWithPaths({\r\n binding,\r\n snapshot: self,\r\n });\r\n }\r\n\r\n if (bindableTools.isVForIndex(binding)) {\r\n return () => getObjectToValue(binding);\r\n }\r\n\r\n if (bindableTools.isRouterParams(binding)) {\r\n const { prop = \"params\" } = binding;\r\n\r\n return vueSystem.makeRefObjectWithPaths(() => routeSnapshot[prop], {\r\n paths: binding.path,\r\n getBindableValueFn: getObjectToValue,\r\n });\r\n }\r\n\r\n throw new Error(`Invalid binding: ${binding}`);\r\n }\r\n\r\n function getVueRefObjectOrValue(binding: TBinding) {\r\n if (bindableTools.isVar(binding)) {\r\n return getVueRefObject(binding);\r\n }\r\n\r\n if (bindableTools.isVForItem(binding)) {\r\n return getVueRefObject(binding);\r\n }\r\n\r\n if (bindableTools.isVForIndex(binding)) {\r\n return getObjectToValue(binding);\r\n }\r\n\r\n if (bindableTools.isJs(binding)) {\r\n return null;\r\n }\r\n\r\n if (bindableTools.isRouterParams(binding)) {\r\n return getVueRefObject(binding);\r\n }\r\n\r\n throw new Error(`Invalid binding: ${binding}`);\r\n }\r\n\r\n function getBindingServerInfo(binding: TBinding) {\r\n if (bindableTools.isVar(binding)) {\r\n return {\r\n sid: binding.sid,\r\n id: binding.id,\r\n };\r\n }\r\n\r\n if (bindableTools.isVForItem(binding)) {\r\n return {\r\n type: \"vf\",\r\n fid: binding.fid,\r\n };\r\n }\r\n\r\n if (bindableTools.isVForIndex(binding)) {\r\n return {\r\n type: \"vf-i\",\r\n fid: binding.fid,\r\n value: null,\r\n };\r\n }\r\n\r\n if (bindableTools.isJs(binding)) {\r\n return null;\r\n }\r\n }\r\n\r\n function updateRefFromServer(infos: TUpdateRefFromServerResponse) {\r\n // TODO\r\n\r\n infos.vars?.forEach((info) => {\r\n (getVueRefObject({ type: \"var\", ...info }) as Ref).value = info.val;\r\n });\r\n\r\n infos.ele_refs?.forEach((info) => {\r\n const elementObj = elementRefSnapshot.getRef({\r\n sid: info.sid,\r\n id: info.id,\r\n }).value;\r\n\r\n elementObj[info.method](...info.args);\r\n });\r\n }\r\n\r\n function updateOutputsRefFromServer(\r\n data: TConfigEventTypes.TEventServerResponse,\r\n outputs: TConfigEventTypes.TWebEventHandler[\"set\"]\r\n ) {\r\n if (\r\n valueSystem.isNullOrUndefined(outputs) ||\r\n valueSystem.isNullOrUndefined(data.values)\r\n ) {\r\n return;\r\n }\r\n\r\n outputs = outputs!;\r\n\r\n const values = data.values!;\r\n const skips = data.skips || new Array(outputs.length).fill(0);\r\n\r\n outputs!.forEach((output, index) => {\r\n if (skips[index] === 1) {\r\n return;\r\n }\r\n\r\n if (bindableTools.isVar(output)) {\r\n const refObj = getVueRefObject(output) as Ref;\r\n refObj.value = values[index];\r\n return;\r\n }\r\n\r\n if (bindableTools.isRouterAction(output)) {\r\n const info = values[index] as {\r\n fn: string;\r\n args: any[];\r\n };\r\n const routerMethod = (routerSnapshot as any)[info.fn] as Function;\r\n routerMethod(...info.args);\r\n\r\n return;\r\n }\r\n\r\n if (bindableTools.isElementRef(output)) {\r\n const elementObj = elementRefSnapshot.getRef(output).value;\r\n const value = values[index] as TConfigEventTypes.TElementRefValue;\r\n const { method, args = [] } = value;\r\n\r\n elementObj[method](...args);\r\n return;\r\n }\r\n\r\n if (bindableTools.isJsOutput(output)) {\r\n const code = values[index] as string;\r\n const fnOrValue = jsCodeSystem.createFnFromString(code);\r\n if (typeof fnOrValue === \"function\") {\r\n fnOrValue();\r\n }\r\n\r\n return;\r\n }\r\n\r\n const refObj = getVueRefObject(output) as Ref;\r\n refObj.value = values[index];\r\n });\r\n }\r\n\r\n const self = {\r\n getVForIndex: vforSnapshot.getVForIndex,\r\n getObjectToValue,\r\n getVueRefObject,\r\n getVueRefObjectOrValue,\r\n getBindingServerInfo,\r\n updateRefFromServer,\r\n updateOutputsRefFromServer,\r\n replaceSnapshot,\r\n };\r\n\r\n return self;\r\n}\r\n","import {\r\n TEventServerResponse,\r\n TWebEventHandler,\r\n} from \"@/shared/configTypes/event\";\r\nimport { type WatchTask } from \"@/shared/webWatchStore\";\r\nimport * as appInfo from \"@/shared/appInfo\";\r\nimport { IDataSender } from \"./base\";\r\n\r\nexport class WebDataSender implements IDataSender {\r\n public async eventSend(\r\n info: TWebEventHandler,\r\n bindings: any[]\r\n ): Promise<TEventServerResponse | null> {\r\n const { fType: eventType, hKey, key: componentKey } = info;\r\n\r\n const webServerInfo = appInfo.getInfo().webServerInfo!;\r\n const keyObj = componentKey !== undefined ? { key: componentKey } : {};\r\n\r\n const url =\r\n eventType === \"sync\"\r\n ? webServerInfo.event_url\r\n : webServerInfo.event_async_url;\r\n\r\n let eProps = {} as Record<string, any>;\r\n\r\n const response = await fetch(url, {\r\n method: \"POST\",\r\n headers: {\r\n \"Content-Type\": \"application/json\",\r\n },\r\n body: JSON.stringify({\r\n bind: bindings,\r\n hKey,\r\n ...keyObj,\r\n page: appInfo.getPageInfoPostData(),\r\n ...eProps,\r\n }),\r\n });\r\n\r\n if (!response.ok) {\r\n throw new Error(`HTTP error! status: ${response.status}`);\r\n }\r\n return (await response.json()) as TEventServerResponse;\r\n }\r\n\r\n public async watchSend(\r\n watchTask: WatchTask\r\n ): Promise<TEventServerResponse | null> {\r\n const { outputs, fType: watchType, key } = watchTask.watchConfig;\r\n\r\n const webServerInfo = appInfo.getInfo().webServerInfo!;\r\n\r\n const url =\r\n watchType === \"sync\"\r\n ? webServerInfo.watch_url\r\n : webServerInfo.watch_async_url;\r\n const inputValues = watchTask.getServerInputs();\r\n\r\n const body = {\r\n key,\r\n input: inputValues,\r\n page: appInfo.getPageInfoPostData(),\r\n };\r\n\r\n const response = await fetch(url, {\r\n method: \"POST\",\r\n headers: {\r\n \"Content-Type\": \"application/json\",\r\n },\r\n body: JSON.stringify(body),\r\n });\r\n\r\n return (await response.json()) as TEventServerResponse;\r\n }\r\n}\r\n","import {\r\n TEventServerResponse,\r\n TWebEventHandler,\r\n} from \"@/shared/configTypes/event\";\r\nimport { type WatchTask } from \"@/shared/webWatchStore\";\r\nimport * as appInfo from \"@/shared/appInfo\";\r\nimport { IDataSender } from \"./base\";\r\n\r\nexport class WebViewDataSender implements IDataSender {\r\n public async eventSend(\r\n info: TWebEventHandler,\r\n bindings: any[]\r\n ): Promise<TEventServerResponse | null> {\r\n const { fType, hKey, key: componentKey } = info;\r\n\r\n const keyObj = componentKey !== undefined ? { key: componentKey } : {};\r\n\r\n let eProps = {} as Record<string, any>;\r\n\r\n const eventInfo = {\r\n bind: bindings,\r\n fType,\r\n hKey,\r\n ...keyObj,\r\n page: appInfo.getPageInfoPostData(),\r\n ...eProps,\r\n };\r\n\r\n return await (window as any).pywebview.api.event_call(eventInfo);\r\n }\r\n\r\n public async watchSend(\r\n watchTask: WatchTask\r\n ): Promise<TEventServerResponse | null> {\r\n const { outputs, fType, key } = watchTask.watchConfig;\r\n\r\n const inputValues = watchTask.getServerInputs();\r\n\r\n const body = {\r\n key,\r\n input: inputValues,\r\n fType,\r\n page: appInfo.getPageInfoPostData(),\r\n };\r\n\r\n return await (window as any).pywebview.api.watch_call(body);\r\n }\r\n}\r\n","import { TAppConfig } from \"@/shared/configTypes\";\r\nimport { IDataSender } from \"./base\";\r\nimport { WebDataSender } from \"./webSender\";\r\nimport { WebViewDataSender } from \"./webviewSender\";\r\n\r\nlet currentDataSender: IDataSender;\r\n\r\nexport function setupDataSender(app: TAppConfig) {\r\n switch (app.mode) {\r\n case \"web\":\r\n currentDataSender = new WebDataSender();\r\n break;\r\n\r\n case \"webview\":\r\n currentDataSender = new WebViewDataSender();\r\n break;\r\n\r\n case \"zero\":\r\n break;\r\n\r\n default:\r\n break;\r\n }\r\n}\r\n\r\nexport function getDataSender() {\r\n return currentDataSender;\r\n}\r\n\r\nexport { type IDataSender } from \"./base\";\r\nexport { WebDataSender } from \"./webSender\";\r\n","import { TBindableVar } from \"@/shared/configTypes\";\r\nimport { TWebComputedConfig } from \"@/shared/configTypes/webComputed\";\r\nimport { TWebWatchConfig } from \"@/shared/configTypes/webWatch\";\r\n\r\nexport function toWatchConfig(\r\n computedConfig: TWebComputedConfig\r\n): TWebWatchConfig {\r\n const output = {\r\n type: \"var\",\r\n sid: computedConfig.sid,\r\n id: computedConfig.id,\r\n } as TBindableVar;\r\n\r\n return {\r\n ...computedConfig,\r\n immediate: true,\r\n outputs: [output, ...(computedConfig.outputs || [])],\r\n } as TWebWatchConfig;\r\n}\r\n","import { nextTick, Ref, watch } from \"vue\";\r\n\r\nimport { TScope } from \"@/shared/configTypes\";\r\nimport { TWebWatchConfig } from \"@/shared/configTypes/webWatch\";\r\nimport { TSnapshot } from \"@/shared/bindableHelper\";\r\nimport { defaultMap } from \"@/systems/mapSystem\";\r\nimport { bindableTools } from \"./configTypes\";\r\nimport { getDataSender } from \"@/shared/dataSender\";\r\nimport * as webComputed from \"@/shared/webComputed\";\r\nimport * as computedInit from \"@/shared/computedInit\";\r\n\r\nexport function setupWebWatchStore(\r\n watchConfig: TScope[\"py_watch\"],\r\n computedConfig: TScope[\"web_computed\"],\r\n snapshots: TSnapshot\r\n) {\r\n return new WebWatchManager(watchConfig, computedConfig, snapshots);\r\n}\r\n\r\nclass WebWatchManager {\r\n private taskQueue: TaskNode[] = [];\r\n\r\n private id2TaskMap: Map<symbol, WatchTask> = new Map();\r\n private input2TaskIdMap = defaultMap<string, symbol[]>(() => []);\r\n\r\n constructor(\r\n watchConfig: TScope[\"py_watch\"],\r\n computedConfig: TScope[\"web_computed\"],\r\n private snapshots: TSnapshot\r\n ) {\r\n const watchTasks: WatchTask[] = [];\r\n\r\n const createWatchTaskFn = (config: TWebWatchConfig) => {\r\n const watchTask = new WatchTask(config, snapshots);\r\n this.id2TaskMap.set(watchTask.id, watchTask);\r\n\r\n config.inputs?.forEach((input, index) => {\r\n const isBinding =\r\n config.data?.[index] === 0 && config.slient?.[index] === 0;\r\n if (isBinding) {\r\n const key = `${input.sid}-${input.id}`;\r\n this.input2TaskIdMap.getOrDefault(key).push(watchTask.id);\r\n }\r\n });\r\n\r\n return watchTask;\r\n };\r\n\r\n watchConfig?.forEach((config) => {\r\n const watchTask = createWatchTaskFn(config);\r\n watchTasks.push(watchTask);\r\n });\r\n\r\n computedConfig?.forEach((computedConfig) => {\r\n const watchTask = createWatchTaskFn(\r\n webComputed.toWatchConfig(computedConfig)\r\n );\r\n watchTasks.push(watchTask);\r\n });\r\n\r\n // build vue watchers\r\n watchTasks.forEach((watchTask) => {\r\n const {\r\n deep = true,\r\n once,\r\n flush,\r\n immediate = true,\r\n } = watchTask.watchConfig;\r\n\r\n const watchOption = {\r\n immediate: immediate,\r\n deep,\r\n once,\r\n flush,\r\n };\r\n\r\n const watchTargets = this._getWatchTargets(watchTask);\r\n watch(\r\n watchTargets,\r\n (values) => {\r\n // console.log(\"watch triggered\", watchTask.watchConfig.debug, values);\r\n\r\n if (values.some(computedInit.isInitial)) {\r\n return;\r\n }\r\n // console.log(\"run task\", watchTask.watchConfig.debug);\r\n\r\n watchTask.modify = true;\r\n this.taskQueue.push(new TaskNode(watchTask));\r\n this._scheduleNextTick();\r\n },\r\n watchOption\r\n );\r\n });\r\n }\r\n\r\n private _getWatchTargets(watchTask: WatchTask) {\r\n if (!watchTask.watchConfig.inputs) {\r\n return [];\r\n }\r\n\r\n const slients = watchTask.slientInputs;\r\n const constDatas = watchTask.constDataInputs;\r\n const inputs = watchTask.watchConfig.inputs.filter(\r\n (input, index) =>\r\n !constDatas[index] &&\r\n (bindableTools.isVar(input) ||\r\n bindableTools.isVForItem(input) ||\r\n bindableTools.isRouterParams(input)) &&\r\n !slients[index]\r\n );\r\n\r\n return inputs.map((input) => this.snapshots.getVueRefObjectOrValue(input));\r\n }\r\n\r\n private _scheduleNextTick() {\r\n nextTick(() => this._runAllTasks());\r\n }\r\n\r\n private _runAllTasks() {\r\n const tasks = this.taskQueue.slice();\r\n this.taskQueue.length = 0;\r\n\r\n this._setTaskNodeRelations(tasks);\r\n\r\n tasks.forEach((task) => {\r\n task.run();\r\n });\r\n }\r\n\r\n private _setTaskNodeRelations(tasks: TaskNode[]) {\r\n tasks.forEach((task) => {\r\n const nextNodes = this._findNextNodes(task, tasks);\r\n\r\n task.appendNextNodes(...nextNodes);\r\n\r\n nextNodes.forEach((nextNode) => {\r\n nextNode.appendPrevNodes(task);\r\n });\r\n });\r\n }\r\n\r\n private _findNextNodes(target: TaskNode, others: TaskNode[]) {\r\n const outputs = target.watchTask.watchConfig.outputs;\r\n\r\n if (outputs && outputs.length <= 0) {\r\n return [];\r\n }\r\n\r\n const taskIdsOfOutput = this._getCalculatorTasksByOutput(\r\n target.watchTask.watchConfig.outputs\r\n );\r\n\r\n return others.filter(\r\n (task) =>\r\n taskIdsOfOutput.has(task.watchTask.id) &&\r\n task.watchTask.id !== target.watchTask.id\r\n );\r\n }\r\n\r\n private _getCalculatorTasksByOutput(outputs: TWebWatchConfig[\"outputs\"]) {\r\n const resultIds: Set<symbol> = new Set();\r\n\r\n outputs?.forEach((output) => {\r\n const key = `${output.sid}-${output.id}`;\r\n const ids = this.input2TaskIdMap.get(key) || [];\r\n ids.forEach((id) => resultIds.add(id));\r\n });\r\n\r\n return resultIds;\r\n }\r\n}\r\n\r\nexport class WatchTask {\r\n public modify = true;\r\n private _running = false;\r\n public readonly id: symbol;\r\n private _runningPromise: Promise<void> | null = null;\r\n private _runningPromiseResolve: ((value: void) => void) | null = null;\r\n private _inputInfos: {\r\n const_data: (1 | 0)[];\r\n slients: (1 | 0)[];\r\n };\r\n\r\n constructor(\r\n public readonly watchConfig: TWebWatchConfig,\r\n public readonly snapshot: TSnapshot\r\n ) {\r\n this.id = Symbol(watchConfig.debug);\r\n this._inputInfos = this.createInputInfos();\r\n }\r\n\r\n private createInputInfos() {\r\n const { inputs = [] } = this.watchConfig;\r\n\r\n const constDatas =\r\n this.watchConfig.data || new Array(inputs.length).fill(0);\r\n\r\n const slients = this.watchConfig.slient || new Array(inputs.length).fill(0);\r\n\r\n return {\r\n const_data: constDatas,\r\n slients,\r\n };\r\n }\r\n\r\n public get slientInputs() {\r\n return this._inputInfos.slients;\r\n }\r\n\r\n public get constDataInputs() {\r\n return this._inputInfos.const_data;\r\n }\r\n\r\n public getServerInputs() {\r\n const { const_data } = this._inputInfos;\r\n\r\n if (!this.watchConfig.inputs) {\r\n return [];\r\n }\r\n\r\n return this.watchConfig.inputs.map((input, index) => {\r\n if (const_data[index] === 0) {\r\n return this.snapshot.getObjectToValue(input);\r\n }\r\n\r\n return input;\r\n });\r\n }\r\n\r\n public get running(): boolean {\r\n return this._running;\r\n }\r\n\r\n public get runningPromise() {\r\n return this._runningPromise;\r\n }\r\n\r\n /**\r\n * setRunning\r\n */\r\n public setRunning() {\r\n this._running = true;\r\n this._runningPromise = new Promise((resolve) => {\r\n this._runningPromiseResolve = resolve;\r\n });\r\n\r\n this._trySetRunningRef(true);\r\n }\r\n\r\n /**\r\n * taskDone\r\n */\r\n public taskDone() {\r\n this._running = false;\r\n if (this._runningPromiseResolve) {\r\n this._runningPromiseResolve();\r\n this._runningPromiseResolve = null;\r\n }\r\n\r\n this._trySetRunningRef(false);\r\n }\r\n\r\n private _trySetRunningRef(value: boolean) {\r\n if (this.watchConfig.running) {\r\n const vueRef = this.snapshot.getVueRefObject(\r\n this.watchConfig.running\r\n ) as Ref;\r\n vueRef.value = value;\r\n }\r\n }\r\n}\r\n\r\nclass TaskNode {\r\n private prevNodes: TaskNode[] = [];\r\n private nextNodes: TaskNode[] = [];\r\n private _runningPrev = false;\r\n\r\n /**\r\n *\r\n */\r\n constructor(public readonly watchTask: WatchTask) {}\r\n\r\n /**\r\n * appendPrevNodes\r\n */\r\n public appendPrevNodes(...nodes: TaskNode[]) {\r\n this.prevNodes.push(...nodes);\r\n }\r\n\r\n /**\r\n *\r\n */\r\n public appendNextNodes(...nodes: TaskNode[]) {\r\n this.nextNodes.push(...nodes);\r\n }\r\n\r\n /**\r\n * hasNextNodes\r\n */\r\n public hasNextNodes() {\r\n return this.nextNodes.length > 0;\r\n }\r\n\r\n /**\r\n * run\r\n */\r\n public async run() {\r\n if (this.prevNodes.length > 0 && !this._runningPrev) {\r\n try {\r\n this._runningPrev = true;\r\n await Promise.all(this.prevNodes.map((node) => node.run()));\r\n } finally {\r\n this._runningPrev = false;\r\n }\r\n }\r\n\r\n if (this.watchTask.running) {\r\n await this.watchTask.runningPromise;\r\n return;\r\n }\r\n\r\n if (!this.watchTask.modify) {\r\n return;\r\n }\r\n\r\n this.watchTask.modify = false;\r\n this.watchTask.setRunning();\r\n\r\n try {\r\n await fetch2server(this.watchTask);\r\n } finally {\r\n this.watchTask.taskDone();\r\n }\r\n }\r\n}\r\n\r\nasync function fetch2server(calcTask: WatchTask) {\r\n const { snapshot } = calcTask;\r\n const { outputs } = calcTask.watchConfig;\r\n\r\n // console.log(\"fetch2server\", calcTask.watchConfig.debug);\r\n\r\n const responseData = await getDataSender().watchSend(calcTask);\r\n if (!responseData) {\r\n return;\r\n }\r\n\r\n snapshot.updateOutputsRefFromServer(responseData, outputs);\r\n}\r\n","import { toValue, watch } from \"vue\";\r\nimport { TVueWatchConfig } from \"@/shared/configTypes/vueWatch\";\r\nimport { TJsWatchConfig } from \"@/shared/configTypes/jsWatch\";\r\nimport { TSnapshot } from \"@/shared/bindableHelper\";\r\nimport * as jsCodeSystem from \"@/systems/jsCodeSystem\";\r\nimport * as objectSystem from \"@/systems/objectSystem\";\r\nimport { TBindableVar } from \"./configTypes\";\r\n\r\nexport function createVueWatch(\r\n watchConfig: TVueWatchConfig,\r\n snapshot: TSnapshot\r\n) {\r\n const {\r\n on: sources,\r\n code,\r\n immediate,\r\n deep,\r\n once,\r\n flush,\r\n bind = {},\r\n onData,\r\n bindData,\r\n } = watchConfig;\r\n\r\n const onDatas = onData || new Array(sources.length).fill(0);\r\n const bindDatas = bindData || new Array(Object.keys(bind).length).fill(0);\r\n\r\n const bindings = objectSystem.mapObjectForValue(bind, (value, _, index) =>\r\n bindDatas[index] === 0 ? snapshot.getVueRefObject(value) : value\r\n );\r\n const fn = jsCodeSystem.createFnFromString(code, bindings);\r\n\r\n const watchTargets =\r\n sources.length === 1\r\n ? _toVueWatchTarget(onDatas[0] === 1, sources[0], snapshot)\r\n : sources.map((input, index) =>\r\n _toVueWatchTarget(onDatas[index] === 1, input, snapshot)\r\n );\r\n\r\n return watch(watchTargets, fn, { immediate, deep, once, flush });\r\n}\r\n\r\nfunction _toVueWatchTarget(\r\n isData: boolean,\r\n input: TBindableVar,\r\n snapshot: TSnapshot\r\n) {\r\n return isData ? () => input : snapshot.getVueRefObject(input);\r\n}\r\n\r\nexport function createJsWatch(\r\n watchConfig: TJsWatchConfig,\r\n snapshot: TSnapshot\r\n) {\r\n const {\r\n inputs = [],\r\n outputs,\r\n slient,\r\n data,\r\n code,\r\n immediate = true,\r\n deep,\r\n once,\r\n flush,\r\n } = watchConfig;\r\n\r\n const slients = slient || new Array(inputs.length).fill(0);\r\n const datas = data || new Array(inputs.length).fill(0);\r\n\r\n const fn = jsCodeSystem.createFnFromString(code);\r\n\r\n const watchTargets = inputs\r\n .filter((_, index) => slients[index] === 0 && datas[index] === 0)\r\n .map((input) => snapshot.getVueRefObject(input));\r\n\r\n function getInputValues() {\r\n return inputs.map((input, index) => {\r\n if (datas[index] === 0) {\r\n return objectSystem.deepClone(toValue(snapshot.getVueRefObject(input)));\r\n }\r\n\r\n return input;\r\n });\r\n }\r\n\r\n watch(\r\n watchTargets,\r\n () => {\r\n let result = fn(...getInputValues());\r\n\r\n if (!outputs) {\r\n return;\r\n }\r\n\r\n const setLen = outputs.length;\r\n const resultValues: any[] = setLen === 1 ? [result] : result;\r\n\r\n const skips = resultValues.map((v) => (v === undefined ? 1 : 0));\r\n\r\n snapshot.updateOutputsRefFromServer(\r\n { values: resultValues, skips },\r\n outputs\r\n );\r\n },\r\n { immediate, deep, once, flush }\r\n );\r\n}\r\n","import * as configTypes from \"@/shared/configTypes\";\r\nimport * as jsCodeSystem from \"@/systems/jsCodeSystem\";\r\nimport * as objectSystem from \"@/systems/objectSystem\";\r\nimport { type TSnapshot } from \"@/shared/bindableHelper\";\r\nimport { bindableTools } from \"@/shared/configTypes/vars\";\r\nimport { getDataSender } from \"@/shared/dataSender\";\r\n\r\nexport type TPrepareBindingsFn = ReturnType<typeof prepareBindings>;\r\n\r\nexport function createEvents(\r\n events: configTypes.TComponent[\"events\"],\r\n snapshot: TSnapshot\r\n): Record<string, Function> {\r\n return Object.assign(\r\n {},\r\n ...Object.entries(events ?? {}).map(([key, infos]) => {\r\n const fns = infos.map((info) => {\r\n if (info.type === \"web\") {\r\n const bindBuilder = prepareBindings(info.bind, snapshot);\r\n\r\n return createWebEventHandlerFn(info, bindBuilder, snapshot);\r\n } else if (info.type === \"vue\") {\r\n return createVueEvent(info, snapshot);\r\n } else if (info.type === \"js\") {\r\n return createJsEvent(info, snapshot);\r\n }\r\n\r\n throw new Error(`unknown event type ${info}`);\r\n });\r\n\r\n const promises = (...args: any[]) =>\r\n fns.map(async (fn) => {\r\n await fn(...args);\r\n });\r\n\r\n const fn = jsCodeSystem.createFnFromString(\r\n ` (...args)=> Promise.all(promises(...args))`,\r\n {\r\n promises: promises,\r\n }\r\n );\r\n\r\n return { [key]: fn };\r\n })\r\n );\r\n}\r\n\r\nfunction prepareBindings(\r\n bindings: configTypes.TWebEventHandler[\"bind\"],\r\n snapshot: TSnapshot\r\n) {\r\n return (...e: any[]) =>\r\n (bindings ?? []).map((binding) => {\r\n if (bindableTools.isEventContext(binding)) {\r\n if (binding.path.startsWith(\":\")) {\r\n const code = binding.path.slice(1);\r\n return jsCodeSystem.createFnFromString(code)(...e);\r\n }\r\n\r\n return objectSystem.getByPaths(e[0], binding.path.split(\".\"));\r\n }\r\n\r\n if (bindableTools.IsBinding(binding)) {\r\n return snapshot.getObjectToValue(binding);\r\n }\r\n\r\n return binding;\r\n });\r\n}\r\n\r\nfunction createWebEventHandlerFn(\r\n info: configTypes.TWebEventHandler,\r\n bindingsBuilder: TPrepareBindingsFn,\r\n snapshot: TSnapshot\r\n) {\r\n async function handleEvent(...e: any[]) {\r\n const bindings = bindingsBuilder(...e);\r\n\r\n const responseData = await getDataSender().eventSend(info, bindings);\r\n if (!responseData) {\r\n return;\r\n }\r\n snapshot.updateOutputsRefFromServer(responseData, info.set);\r\n }\r\n\r\n return handleEvent;\r\n}\r\n\r\nfunction createJsEvent(info: configTypes.TJsEvent, snapshot: TSnapshot) {\r\n const { code, inputs = [], set } = info;\r\n\r\n const eventFn = jsCodeSystem.createFnFromString(code);\r\n\r\n function handleEvent(...e: any[]) {\r\n const inputValues = (inputs ?? []).map((input) => {\r\n if (bindableTools.isEventContext(input)) {\r\n if (input.path.startsWith(\":\")) {\r\n const code = input.path.slice(1);\r\n return jsCodeSystem.createFnFromString(code)(...e);\r\n }\r\n\r\n return objectSystem.getByPaths(e[0], input.path.split(\".\"));\r\n }\r\n\r\n if (bindableTools.IsBinding(input)) {\r\n return objectSystem.deepClone(snapshot.getObjectToValue(input));\r\n }\r\n\r\n return input;\r\n });\r\n\r\n const output = eventFn(...inputValues);\r\n\r\n if (set !== undefined) {\r\n const setLen = set.length;\r\n const outputValues: any[] = setLen === 1 ? [output] : output;\r\n\r\n const skips = outputValues.map((v) => (v === undefined ? 1 : 0));\r\n\r\n snapshot.updateOutputsRefFromServer({ values: outputValues, skips }, set);\r\n }\r\n }\r\n\r\n return handleEvent;\r\n}\r\n\r\nfunction createVueEvent(info: configTypes.TVueEvent, snapshot: TSnapshot) {\r\n const { code, bind = {}, bindData } = info;\r\n\r\n const bindDatas = bindData || new Array(Object.keys(bind).length).fill(0);\r\n const bindings = objectSystem.mapObjectForValue(bind, (value, _, index) =>\r\n bindDatas[index] === 0 ? snapshot.getVueRefObject(value) : value\r\n );\r\n\r\n const eventFn = jsCodeSystem.createFnFromString(code, bindings);\r\n\r\n function handleEvent(...e: any[]) {\r\n eventFn(...e);\r\n }\r\n\r\n return handleEvent;\r\n}\r\n","import { TComponent } from \"@/shared/configTypes\";\r\nimport * as objectSystem from \"@/systems/objectSystem\";\r\nimport { normalizeStyle as _normalizeStyle } from \"vue\";\r\nimport { type TSnapshot } from \"@/shared/bindableHelper\";\r\n\r\nexport function handlerStyles(component: TComponent, snapshot: TSnapshot) {\r\n const result = [] as any[];\r\n\r\n (component.bStyle || []).forEach((style) => {\r\n if (Array.isArray(style)) {\r\n result.push(\r\n ...style.map((item) => {\r\n return snapshot.getObjectToValue(item);\r\n })\r\n );\r\n } else {\r\n result.push(\r\n objectSystem.mapObjectForValue(style, (value) =>\r\n snapshot.getObjectToValue(value)\r\n )\r\n );\r\n }\r\n });\r\n\r\n const styles = _normalizeStyle([component.style || {}, result]);\r\n const hasStyle = styles && Object.keys(styles).length > 0;\r\n\r\n return {\r\n hasStyle,\r\n styles,\r\n };\r\n}\r\n","import * as configTypes from \"@/shared/configTypes\";\r\nimport * as objectSystem from \"@/systems/objectSystem\";\r\nimport { normalizeClass as _normalizeClass } from \"vue\";\r\nimport { type TSnapshot } from \"@/shared/bindableHelper\";\r\n\r\nexport function handlerClasses(\r\n component: configTypes.TComponent,\r\n snapshot: TSnapshot\r\n) {\r\n const classes = component.classes;\r\n\r\n if (!classes) {\r\n return null;\r\n }\r\n\r\n if (typeof classes === \"string\") {\r\n return _normalizeClass(classes);\r\n }\r\n\r\n const { str: strClass, map: mapClass, bind: bindClass } = classes;\r\n\r\n const result = [];\r\n\r\n if (strClass) {\r\n result.push(strClass);\r\n }\r\n\r\n if (mapClass) {\r\n result.push(\r\n objectSystem.mapObjectForValue(mapClass, (value) =>\r\n snapshot.getObjectToValue(value)\r\n )\r\n );\r\n }\r\n\r\n if (bindClass) {\r\n result.push(...bindClass.map((item) => snapshot.getObjectToValue(item)));\r\n }\r\n\r\n return _normalizeClass(result);\r\n}\r\n","import { createFnFromString } from \"./systems/jsCodeSystem\";\r\n\r\nexport function convertDynamicProperties(\r\n obj: Record<string, any>,\r\n recursive = true\r\n) {\r\n if (typeof obj !== \"object\" || obj === null) {\r\n return;\r\n }\r\n if (Array.isArray(obj)) {\r\n if (recursive) {\r\n obj.forEach((v) => convertDynamicProperties(v, true));\r\n }\r\n return;\r\n }\r\n for (const [attr, value] of Object.entries(obj)) {\r\n if (attr.startsWith(\":\")) {\r\n try {\r\n obj[attr.slice(1)] = new Function(`return (${value})`)();\r\n delete obj[attr];\r\n } catch (e) {\r\n console.error(\r\n `Error while converting ${attr} attribute to function:`,\r\n e\r\n );\r\n }\r\n } else {\r\n if (recursive) {\r\n convertDynamicProperties(value, true);\r\n }\r\n }\r\n }\r\n}\r\n\r\nexport function tryConvertDynamicProp(name: string, value: any) {\r\n const isFunc = name.startsWith(\":\");\r\n\r\n if (isFunc) {\r\n name = name.slice(1);\r\n value = createFnFromString(value as string);\r\n }\r\n\r\n return { name, value, isFunc };\r\n}\r\n","import * as configTypes from \"@/shared/configTypes\";\r\nimport { toDisplayString } from \"vue\";\r\nimport * as objectSystem from \"@/systems/objectSystem\";\r\nimport { type TSnapshot } from \"@/shared/bindableHelper\";\r\nimport { tryConvertDynamicProp, convertDynamicProperties } from \"@/appUtils\";\r\nimport { isInitial } from \"@/shared/computedInit\";\r\n\r\nexport function handlerProps(\r\n component: configTypes.TComponent,\r\n staticProps: Record<string, any>,\r\n snapshot: TSnapshot\r\n) {\r\n const result = {} as Record<string, any>;\r\n\r\n objectSystem.foreachObject(component.bProps || {}, (value, key) => {\r\n const realValue = snapshot.getObjectToValue(value);\r\n if (!isInitial(realValue)) {\r\n convertDynamicProperties(realValue);\r\n result[key] = toPropValue(realValue, key);\r\n }\r\n });\r\n\r\n component.proxyProps?.forEach((prop) => {\r\n const value = snapshot.getObjectToValue(prop);\r\n if (typeof value === \"object\") {\r\n objectSystem.foreachObject(value, (v, k) => {\r\n const { name, value } = tryConvertDynamicProp(k, v);\r\n result[name] = value;\r\n });\r\n }\r\n });\r\n\r\n return { ...(staticProps || {}), ...result };\r\n}\r\n\r\nfunction toPropValue(value: any, propName: string) {\r\n if (propName === \"innerText\") {\r\n return toDisplayString(value);\r\n }\r\n\r\n return value;\r\n}\r\n","import { defineComponent, h, Fragment as _Fragment, onUnmounted } from \"vue\";\r\nimport * as slotStore from \"@/shared/slotStore\";\r\n\r\ntype TSlotPropsInfo = {\r\n id: string;\r\n use: string[];\r\n};\r\n\r\ntype TProps = {\r\n propsInfo: TSlotPropsInfo;\r\n propsValue: any;\r\n};\r\n\r\nfunction render(props: TProps, { slots }: any) {\r\n // setup\r\n const { id: slotId, use: propNames } = props.propsInfo;\r\n\r\n const slotSeqIndex = slotStore.SetupCollect(slotId);\r\n\r\n onUnmounted(() => {\r\n slotStore.removeSlotInfo(slotId);\r\n });\r\n\r\n // render\r\n return () => {\r\n const propsValue = props.propsValue;\r\n\r\n slotStore.updateValues(\r\n slotId,\r\n slotSeqIndex,\r\n Object.fromEntries(\r\n propNames.map((propName) => [propName, propsValue[propName]])\r\n )\r\n );\r\n\r\n return h(_Fragment, null, slots.default());\r\n };\r\n}\r\n\r\nexport default defineComponent(render, {\r\n props: [\"propsInfo\", \"propsValue\"],\r\n});\r\n","import * as configTypes from \"@/shared/configTypes\";\r\nimport * as objectSystem from \"@/systems/objectSystem\";\r\n\r\nimport ScopeContainer from \"@/components/scopeContainer\";\r\nimport SlotPropContainer from \"@/components/slotPropContainer\";\r\n\r\nimport { h } from \"vue\";\r\nimport Element from \"./element\";\r\n\r\nexport function handlerSlots(\r\n component: configTypes.TComponent,\r\n isHtmlTag: boolean\r\n) {\r\n if (!component.slots) {\r\n return null;\r\n }\r\n\r\n const slotConfig = component.slots ?? {};\r\n if (Array.isArray(slotConfig)) {\r\n return isHtmlTag\r\n ? createElements(slotConfig)\r\n : () => createElements(slotConfig);\r\n }\r\n\r\n const keyFn = (slotName: string) => (slotName === \":\" ? \"default\" : slotName);\r\n\r\n const valueFn = (slot: configTypes.TSlot) => {\r\n const { items } = slot;\r\n\r\n return (slotProps: any) => {\r\n if (slot.scope) {\r\n const childernSlot = () =>\r\n !!slot.props\r\n ? createSlotPropsContainer(slot.props, slotProps, items)\r\n : createElements(items);\r\n\r\n return h(ScopeContainer, { scope: slot.scope }, childernSlot);\r\n }\r\n\r\n if (slot.props) {\r\n return createSlotPropsContainer(slot.props, slotProps, items);\r\n }\r\n\r\n return createElements(items);\r\n };\r\n };\r\n\r\n const result = objectSystem.mapObjectFor(slotConfig, { keyFn, valueFn });\r\n\r\n return result;\r\n}\r\n\r\nfunction createSlotPropsContainer(\r\n propsInfo: {\r\n id: string;\r\n use: string[];\r\n },\r\n propsValue: any,\r\n items: (configTypes.TComponent | configTypes.TVForComponent)[]\r\n) {\r\n return h(SlotPropContainer, { propsInfo, propsValue }, () =>\r\n createElements(items)\r\n );\r\n}\r\n\r\nfunction createElements(\r\n items: (configTypes.TComponent | configTypes.TVForComponent)[] | undefined\r\n) {\r\n const result = (items ?? []).map((item) => {\r\n return h(Element, {\r\n component: item,\r\n });\r\n });\r\n\r\n return result.length <= 0 ? null : result;\r\n}\r\n","import * as configTypes from \"@/shared/configTypes\";\r\nimport { Ref, vModelDynamic, vShow as _vShow } from \"vue\";\r\nimport { type TSnapshot } from \"@/shared/bindableHelper\";\r\n\r\nexport function collectDirectives(\r\n dirs: configTypes.TComponent[\"dir\"],\r\n snapshot: TSnapshot\r\n) {\r\n const newProps: Record<string, any> = {};\r\n const directiveArray: any[] = [];\r\n\r\n (dirs || []).forEach((directive) => {\r\n const { sys, name, arg, value, mf: modifers } = directive;\r\n\r\n if (name === \"vmodel\") {\r\n const refValue = snapshot.getVueRefObject(value) as Ref<any>;\r\n newProps[`onUpdate:${arg}`] = (value: any) => {\r\n refValue.value = value;\r\n };\r\n\r\n if (sys === 1) {\r\n const mfs = modifers\r\n ? Object.fromEntries(modifers.map((modifier) => [modifier, true]))\r\n : {};\r\n\r\n directiveArray.push([vModelDynamic, refValue.value, void 0, mfs]);\r\n } else {\r\n newProps[arg] = refValue.value;\r\n }\r\n } else if (name === \"vshow\") {\r\n const refValue = snapshot.getVueRefObject(value) as Ref<any>;\r\n directiveArray.push([_vShow, refValue.value]);\r\n } else {\r\n console.warn(`Directive ${name} is not supported yet`);\r\n }\r\n });\r\n\r\n return {\r\n newProps,\r\n directiveArray,\r\n };\r\n}\r\n","import * as configTypes from \"@/shared/configTypes\";\r\nimport { TElementRefSnapshot } from \"@/shared/elementRefStore\";\r\n\r\nexport function handlerElementRef(\r\n component: configTypes.TComponent,\r\n snapshot: TElementRefSnapshot\r\n): Record<string, any> {\r\n const { eRef } = component;\r\n if (eRef === undefined) {\r\n return {};\r\n }\r\n\r\n return { ref: snapshot.getRef(eRef) };\r\n}\r\n","import {\r\n defineComponent,\r\n h,\r\n resolveDynamicComponent,\r\n withDirectives,\r\n normalizeProps as _normalizeProps,\r\n VNode,\r\n RendererNode,\r\n RendererElement,\r\n} from \"vue\";\r\n\r\nimport * as configTypes from \"@/shared/configTypes\";\r\nimport { createEvents } from \"./events\";\r\nimport { handlerStyles } from \"./styles\";\r\nimport { handlerClasses } from \"./classes\";\r\nimport { handlerProps } from \"./props\";\r\nimport { handlerSlots } from \"./slots\";\r\nimport { collectDirectives } from \"./directives\";\r\nimport { handlerElementRef } from \"./elementRef\";\r\nimport { createSnapshot } from \"@/shared/bindableHelper\";\r\nimport { createElementRefSnapshot } from \"@/shared/elementRefStore\";\r\nimport { convertDynamicProperties } from \"@/appUtils\";\r\n\r\ntype TProps = {\r\n component: configTypes.TComponent;\r\n};\r\n\r\ntype TRenderNode = VNode<\r\n RendererNode,\r\n RendererElement,\r\n {\r\n [key: string]: any;\r\n }\r\n>;\r\n\r\ntype TRenderResult = () => TRenderNode;\r\n\r\nexport type TRenderFn = typeof render;\r\n\r\nfunction render(props: TProps): TRenderResult {\r\n // setup\r\n\r\n const snapshot = createSnapshot();\r\n const elementRefSnapshot = createElementRefSnapshot();\r\n\r\n const staticProps = props.component.props ?? {};\r\n convertDynamicProperties(staticProps, true);\r\n\r\n // render\r\n return () => {\r\n const { tag } = props.component;\r\n\r\n const stringTag = configTypes.bindableTools.IsBinding(tag)\r\n ? snapshot.getObjectToValue(tag)\r\n : tag;\r\n\r\n const component = resolveDynamicComponent(stringTag) as any;\r\n const isHtmlTag = typeof component === \"string\";\r\n\r\n const classes = handlerClasses(props.component, snapshot);\r\n const { styles, hasStyle } = handlerStyles(props.component, snapshot);\r\n\r\n const events = createEvents(props.component.events ?? {}, snapshot);\r\n\r\n const slots = handlerSlots(props.component, isHtmlTag);\r\n\r\n const valueProps = handlerProps(props.component, staticProps, snapshot);\r\n\r\n const { newProps, directiveArray } = collectDirectives(\r\n props.component.dir,\r\n snapshot\r\n );\r\n\r\n const elementRefProps = handlerElementRef(\r\n props.component,\r\n elementRefSnapshot\r\n );\r\n\r\n const hProps =\r\n _normalizeProps({\r\n ...valueProps,\r\n ...events,\r\n ...newProps,\r\n ...elementRefProps,\r\n }) || {};\r\n\r\n if (hasStyle) {\r\n hProps.style = styles;\r\n }\r\n\r\n if (classes) {\r\n hProps.class = classes;\r\n }\r\n\r\n const resultNode = h(component as any, { ...hProps }, slots);\r\n\r\n if (directiveArray.length > 0) {\r\n return withDirectives(\r\n // @ts-ignore\r\n resultNode,\r\n directiveArray as any\r\n );\r\n }\r\n\r\n return resultNode;\r\n };\r\n}\r\n\r\nexport default defineComponent(render, {\r\n props: [\"component\"],\r\n});\r\n","import { defineComponent, h, Fragment as _Fragment, onUnmounted } from \"vue\";\r\nimport { TScope, TComponent } from \"@/shared/configTypes\";\r\nimport { createVarStore, removeIndexVars } from \"@/shared/varStore\";\r\nimport {\r\n createElementRefStore,\r\n removeElementRef,\r\n} from \"@/shared/elementRefStore\";\r\nimport { createSnapshot } from \"@/shared/bindableHelper\";\r\nimport { setupWebWatchStore } from \"@/shared/webWatchStore\";\r\nimport {\r\n createJsWatch,\r\n createVueWatch as createVueWatch,\r\n} from \"@/shared/jsWatchStore\";\r\nimport * as vforManager from \"@/shared/vforManager\";\r\nimport Element from \"@/components/element/element\";\r\n\r\ntype TProps = {\r\n scope?: TScope;\r\n};\r\n\r\nfunction setup(scope?: TScope, vforKey?: any) {\r\n if (scope) {\r\n // element refs\r\n const elementRefStoreIndex = createElementRefStore(scope);\r\n\r\n const storeIndex = createVarStore(scope, createSnapshot(vforKey));\r\n const snapshot = createSnapshot(vforKey);\r\n\r\n // web watch\r\n setupWebWatchStore(scope.py_watch, scope.web_computed, snapshot);\r\n scope.vue_watch?.forEach((watch) => createVueWatch(watch, snapshot));\r\n scope.js_watch?.forEach((watch) => createJsWatch(watch, snapshot));\r\n\r\n onUnmounted(() => {\r\n removeIndexVars(scope.id, storeIndex);\r\n removeElementRef(scope.id, elementRefStoreIndex);\r\n });\r\n }\r\n}\r\n\r\nfunction render(props: TProps, { slots }: any) {\r\n // setup\r\n const { scope } = props;\r\n\r\n setup(scope);\r\n\r\n // render\r\n return () => {\r\n return h(_Fragment, null, slots.default());\r\n };\r\n}\r\n\r\nexport default defineComponent(render, {\r\n props: [\"scope\"],\r\n});\r\n\r\nexport const VForScope = defineComponent(\r\n (props: {\r\n scope?: TScope;\r\n items: TComponent[];\r\n vforInfo: {\r\n fid: string;\r\n key: any;\r\n };\r\n }) => {\r\n // setup\r\n const { scope, items, vforInfo } = props;\r\n\r\n vforManager.provideVForKey(vforInfo);\r\n\r\n setup(scope, vforInfo.key);\r\n\r\n const createNodeFn =\r\n items.length === 1\r\n ? () =>\r\n h(Element, {\r\n component: items[0],\r\n })\r\n : () =>\r\n items.map((item) =>\r\n h(Element, {\r\n component: item,\r\n })\r\n );\r\n\r\n // render\r\n return createNodeFn;\r\n },\r\n {\r\n props: [\"scope\", \"items\", \"vforInfo\"],\r\n }\r\n);\r\n","import { TAppConfig } from \"@/shared/configTypes\";\r\nimport { useAsyncState } from \"@vueuse/core\";\r\n\r\nexport function useLoadAppConfig(config?: TAppConfig, url?: string) {\r\n const { state, isReady, isLoading } = useAsyncState(async () => {\r\n let appConfig = config;\r\n const configUrl = url;\r\n if (!appConfig && !configUrl) {\r\n throw new Error(\"Either config or configUrl must be provided\");\r\n }\r\n\r\n if (!appConfig && configUrl) {\r\n appConfig = await (await fetch(configUrl)).json();\r\n }\r\n\r\n if (!appConfig) {\r\n throw new Error(\"Failed to load config\");\r\n }\r\n\r\n return appConfig;\r\n }, {} as TAppConfig);\r\n\r\n return { config: state, isReady, isLoading };\r\n}\r\n\r\nexport function appErrorHandler(err: any, vm: any) {\r\n let componentMessage: string;\r\n if (!vm.component) {\r\n componentMessage = `Error captured from app init`;\r\n } else {\r\n componentMessage = `Error captured from component:tag: ${vm.component.tag} ; id: ${vm.component.id} `;\r\n }\r\n\r\n console.group(componentMessage);\r\n console.error(\"Component:\", vm.component);\r\n console.error(\"Error:\", err);\r\n console.groupEnd();\r\n\r\n return false;\r\n}\r\n","<script setup lang=\"ts\">\r\nimport \"./style.css\";\r\nimport { TAppConfig } from \"@/shared/configTypes\";\r\nimport * as appInfo from \"@/shared/appInfo\";\r\n\r\nimport ScopeContainer from \"@/components/scopeContainer\";\r\nimport Element from \"@/components/element/element\";\r\nimport { onErrorCaptured, watch } from \"vue\";\r\nimport { useLoadAppConfig, appErrorHandler } from \"./app\";\r\nimport { setupDataSender } from \"@/shared/dataSender\";\r\n\r\nconst props = defineProps<{ config?: TAppConfig; configUrl?: string }>();\r\n\r\nconst { config: appConfig, isLoading } = useLoadAppConfig(\r\n props.config,\r\n props.configUrl\r\n);\r\n\r\nlet app = null as TAppConfig | null;\r\n\r\nwatch(appConfig, (appConfig) => {\r\n app = appConfig;\r\n if (appConfig.url) {\r\n appInfo.setup({\r\n mode: appConfig.mode,\r\n version: appConfig.version,\r\n queryPath: appConfig.url.path,\r\n pathParams: appConfig.url.params,\r\n webServerInfo: appConfig.webInfo,\r\n });\r\n\r\n setupDataSender(appConfig);\r\n }\r\n});\r\n\r\nonErrorCaptured(appErrorHandler);\r\n</script>\r\n\r\n<template>\r\n <div class=\"app-box\">\r\n <!-- Loading spinner -->\r\n <div\r\n v-if=\"isLoading\"\r\n style=\"\r\n position: absolute;\r\n top: 50%;\r\n left: 50%;\r\n transform: translate(-50%, -50%);\r\n \"\r\n >\r\n <p style=\"margin: auto\">Loading ...</p>\r\n </div>\r\n\r\n <!-- Main app container -->\r\n <div v-else class=\"insta-main\" :class=\"appConfig.class\">\r\n <ScopeContainer :scope=\"app!.scope\">\r\n <Element\r\n :component=\"component\"\r\n v-for=\"component in app!.items\"\r\n ></Element>\r\n </ScopeContainer>\r\n </div>\r\n </div>\r\n</template>\r\n","import { defineComponent, h } from \"vue\";\r\nimport Element from \"@/components/element/element\";\r\nimport ScopeContainer from \"@/components/scopeContainer\";\r\n\r\nimport { TBindableVar, TScope, TSlot } from \"@/shared/configTypes\";\r\nimport { createSnapshot } from \"@/shared/bindableHelper\";\r\n\r\ntype TProps = {\r\n on: TBindableVar;\r\n scope: TScope;\r\n items: TSlot;\r\n};\r\n\r\nfunction render(props: TProps) {\r\n // setup\r\n const { on, scope, items } = props;\r\n\r\n const snapshot = createSnapshot();\r\n\r\n // render\r\n return () => {\r\n const onValue = typeof on==='boolean'? on : snapshot.getObjectToValue(on!);\r\n\r\n const itemsNode = () =>\r\n onValue\r\n ? (items as unknown as any[]).map((item) =>\r\n h(Element, { component: item })\r\n )\r\n : undefined;\r\n\r\n return h(ScopeContainer, { scope: scope }, itemsNode);\r\n };\r\n}\r\n\r\nexport default defineComponent(render, {\r\n props: [\"on\", \"scope\", \"items\"],\r\n});\r\n","export function range(options: { start?: number; end: number; step?: number }) {\r\n const { start = 0, end, step = 1 } = options;\r\n let array = [];\r\n if (step > 0) {\r\n for (let i = start; i < end; i += step) {\r\n array.push(i);\r\n }\r\n } else {\r\n for (let i = start; i > end; i += step) {\r\n array.push(i);\r\n }\r\n }\r\n return array;\r\n}\r\n","import {\r\n defineComponent,\r\n h,\r\n Fragment as _Fragment,\r\n onUnmounted,\r\n TransitionGroup as _TransitionGroup,\r\n} from \"vue\";\r\n\r\nimport * as numberSystem from \"@/systems/numberSystem\";\r\nimport * as jsCodeSystem from \"@/systems/jsCodeSystem\";\r\nimport * as configTypes from \"@/shared/configTypes\";\r\nimport { clearScopeVarStore } from \"@/shared/varStore\";\r\nimport * as vforManager from \"@/shared/vforManager\";\r\nimport { createSnapshot } from \"@/shared/bindableHelper\";\r\nimport { VForScope } from \"@/components/scopeContainer\";\r\n\r\ntype TProps = configTypes.TVForComponent[\"props\"];\r\n\r\nfunction render(props: TProps) {\r\n // setup\r\n const { array, bArray, items, fkey, fid, scope, num, tsGroup = {} } = props;\r\n\r\n const isBindRef = array === undefined;\r\n const isLoopNumber = num !== undefined;\r\n const arrayValue = isBindRef ? bArray : array;\r\n const snapshot = createSnapshot();\r\n\r\n // // TODO\r\n vforManager.markArray(fid, arrayValue as any, isBindRef, isLoopNumber);\r\n\r\n const vforKey = fkey ?? \"index\";\r\n const keyFn = createKeyFn(vforKey);\r\n\r\n onUnmounted(() => {\r\n clearScopeVarStore(scope.id);\r\n });\r\n\r\n // render\r\n return () => {\r\n const sourceValue = createSourceValueArray(\r\n isLoopNumber,\r\n isBindRef,\r\n arrayValue,\r\n snapshot,\r\n num\r\n );\r\n\r\n const keysCollector = vforManager.keysCollector(fid);\r\n\r\n const itemsNode = (sourceValue as any[]).map((value, index) => {\r\n const key = keyFn(value, index);\r\n\r\n keysCollector.add(key);\r\n vforManager.markVForIndex(fid, key, index);\r\n\r\n return h(VForScope, {\r\n scope: props.scope,\r\n items: items,\r\n vforInfo: {\r\n fid,\r\n key,\r\n },\r\n key,\r\n });\r\n });\r\n\r\n keysCollector.removeUnusedKeys();\r\n\r\n if (!!tsGroup && Object.keys(tsGroup).length > 0) {\r\n return h(_TransitionGroup, tsGroup, {\r\n default: () => itemsNode,\r\n });\r\n }\r\n\r\n return itemsNode;\r\n };\r\n}\r\n\r\nexport default defineComponent(render, {\r\n props: [\"array\", \"items\", \"fid\", \"bArray\", \"scope\", \"num\", \"fkey\", \"tsGroup\"],\r\n});\r\n\r\nfunction createSourceValueArray(\r\n isLoopNumber: boolean,\r\n isBindRef: boolean,\r\n arrayValue: any,\r\n snapshot: ReturnType<typeof createSnapshot>,\r\n num: TProps[\"num\"]\r\n): any[] {\r\n if (isLoopNumber) {\r\n let numValue = 0;\r\n if (typeof num === \"number\") {\r\n numValue = num;\r\n } else {\r\n numValue = snapshot.getObjectToValue(num!) ?? 0;\r\n }\r\n\r\n return numberSystem.range({\r\n end: Math.max(0, numValue),\r\n });\r\n }\r\n\r\n const source = isBindRef\r\n ? snapshot.getObjectToValue(arrayValue as configTypes.TBinding) || []\r\n : arrayValue;\r\n\r\n return typeof source === \"object\" ? Object.values(source) : source;\r\n}\r\n\r\nconst _item_key_fn = (value: any) => value;\r\nconst _index_key_fn = (_: any, index: number) => index;\r\n\r\nfunction createKeyFn(vforKey: string) {\r\n const fn = jsCodeSystem.tryStringWithColonToFunction(vforKey);\r\n if (typeof fn === \"function\") {\r\n return fn;\r\n }\r\n\r\n return vforKey === \"item\" ? _item_key_fn : _index_key_fn;\r\n}\r\n","import { TScope, TScopeItem, TComponent } from \"@/shared/configTypes\";\r\nimport Element from \"@/components/element/element\";\r\n\r\nimport { defineComponent, h, resolveDynamicComponent, VNode } from \"vue\";\r\n\r\nfunction render(items: TScopeItem[]): VNode[] | VNode {\r\n const cmd = items.map((item) => {\r\n if ((item as any).tag) {\r\n const component = item as TComponent;\r\n return h(Element, { component });\r\n }\r\n\r\n // is scope\r\n const cpNode = resolveDynamicComponent(Scope) as string;\r\n const scopeObj = item as TScope;\r\n\r\n return h(cpNode, {\r\n scope: scopeObj,\r\n });\r\n });\r\n\r\n return cmd;\r\n}\r\n\r\nexport const Scope = defineComponent(\r\n (props: { scope: TScope }) => {\r\n const scope = props.scope;\r\n\r\n // render\r\n return () => {\r\n return render(scope.items ?? []);\r\n };\r\n },\r\n {\r\n props: [\"scope\"],\r\n }\r\n);\r\n","import { TVar, TComponent, TScope, TScopeItem } from \"@/shared/configTypes\";\r\nimport Element from \"@/components/element/element\";\r\nimport * as appInfo from \"@/shared/appInfo\";\r\nimport { createVarStore, removeIndexVars } from \"@/shared/varStore\";\r\n\r\nimport {\r\n defineComponent,\r\n h,\r\n VNode,\r\n watch,\r\n shallowRef,\r\n WatchHandle,\r\n resolveDynamicComponent,\r\n onUnmounted,\r\n} from \"vue\";\r\nimport { Scope } from \"@/components/scope\";\r\nimport { createSnapshot, TSnapshot } from \"@/shared/bindableHelper\";\r\n\r\ntype TProps = {\r\n sid: string;\r\n url: string;\r\n hKey: string;\r\n on: TVar[];\r\n bind: TVar[];\r\n items: TScopeItem[];\r\n scope: TScope;\r\n};\r\n\r\nfunction render(items: TScopeItem[]): VNode[] | VNode {\r\n return items.map((item) => {\r\n if ((item as any).tag) {\r\n const component = item as TComponent;\r\n return h(Element, { component });\r\n }\r\n\r\n // is scope\r\n const cpNode = resolveDynamicComponent(Scope) as string;\r\n const scopeObj = item as TScope;\r\n\r\n return h(cpNode, {\r\n scope: scopeObj,\r\n });\r\n });\r\n}\r\n\r\nexport const Refresh = defineComponent(\r\n (props: TProps) => {\r\n const { scope, on, items } = props;\r\n // setup\r\n const itemsRef = shallowRef<TScopeItem[]>(items);\r\n const storeIndex = createVarStore(scope);\r\n const snapshot = createSnapshot();\r\n\r\n helpers.createDynamicWatchRefresh(on, snapshot, async () => {\r\n const { items, on } = await helpers.fetchRemote(props, snapshot);\r\n itemsRef.value = items;\r\n\r\n return on;\r\n });\r\n\r\n onUnmounted(() => {\r\n removeIndexVars(scope.id, storeIndex);\r\n });\r\n\r\n // render\r\n return () => {\r\n return render(itemsRef.value);\r\n };\r\n },\r\n {\r\n props: [\"sid\", \"url\", \"hKey\", \"on\", \"bind\", \"items\", \"scope\"],\r\n }\r\n);\r\n\r\nnamespace helpers {\r\n export function createDynamicWatchRefresh(\r\n targetOns: TVar[],\r\n snapshot: TSnapshot,\r\n callback: () => Promise<TVar[]>\r\n ) {\r\n let currentWatcher = null as WatchHandle | null;\r\n let currentOns = targetOns;\r\n let targetRefs = currentOns.map((v) => snapshot.getVueRefObject(v));\r\n\r\n function setupWatcher() {\r\n if (currentWatcher) {\r\n currentWatcher();\r\n }\r\n\r\n currentWatcher = watch(\r\n targetRefs,\r\n async () => {\r\n currentOns = await callback();\r\n targetRefs = currentOns.map((v) => snapshot.getVueRefObject(v));\r\n setupWatcher();\r\n },\r\n { deep: true }\r\n );\r\n }\r\n\r\n setupWatcher();\r\n\r\n return () => {\r\n if (currentWatcher) {\r\n currentWatcher();\r\n }\r\n };\r\n }\r\n\r\n export async function fetchRemote(props: TProps, snapshot: TSnapshot) {\r\n const fnParams = Object.values(props.bind).map((p) => {\r\n return {\r\n sid: p.sid,\r\n id: p.id,\r\n value: snapshot.getObjectToValue(p),\r\n };\r\n });\r\n\r\n const fnParamsWithKey = {\r\n sid: props.sid,\r\n bind: fnParams,\r\n hKey: props.hKey,\r\n page: appInfo.getPageInfoPostData(),\r\n };\r\n\r\n const fetchOptions = {\r\n method: \"POST\",\r\n headers: {\r\n \"Content-Type\": \"application/json\",\r\n },\r\n body: JSON.stringify(fnParamsWithKey),\r\n };\r\n\r\n const result = await fetch(props.url, fetchOptions);\r\n\r\n if (!result.ok) {\r\n throw new Error(\"Failed to fetch data\");\r\n }\r\n\r\n const data = (await result.json()) as {\r\n items: TComponent[];\r\n on: TVar[];\r\n };\r\n\r\n return data;\r\n }\r\n}\r\n","import { TScope, TComponent } from \"@/shared/configTypes\";\r\n\r\nimport { defineComponent, h } from \"vue\";\r\nimport Element from \"@/components/element/element\";\r\nimport ScopeContainer from \"@/components/scopeContainer\";\r\n\r\ntype TProps = {\r\n scope: TScope;\r\n items: TComponent[];\r\n};\r\n\r\nfunction render(props: TProps) {\r\n // setup\r\n const { scope, items } = props;\r\n\r\n // render\r\n return () => {\r\n const itemsNode = items.map((item) => h(Element, { component: item }));\r\n\r\n return h(ScopeContainer, { scope }, () => itemsNode);\r\n };\r\n}\r\n\r\nexport default defineComponent(render, {\r\n props: [\"scope\", \"items\"],\r\n});\r\n","import { defineComponent, h, Fragment as _Fragment } from \"vue\";\r\nimport { TScope, TBindableVar, TComponent } from \"@/shared/configTypes\";\r\nimport * as bindableHelper from \"@/shared/bindableHelper\";\r\n\r\nimport MatchCase from \"./matchCase\";\r\n\r\ntype TCase = {\r\n props: {\r\n value: any;\r\n scope: TScope;\r\n items: TComponent[];\r\n };\r\n};\r\n\r\ntype TProps = {\r\n on: TBindableVar;\r\n case: TCase[];\r\n default?: {\r\n props: {\r\n scope: TScope;\r\n items: TComponent[];\r\n };\r\n };\r\n};\r\n\r\nfunction render(props: TProps) {\r\n // setup\r\n const { on, case: caseConfig, default: defaultConfig } = props;\r\n\r\n const snapshot = bindableHelper.createSnapshot();\r\n\r\n // render\r\n return () => {\r\n const onValue = snapshot.getObjectToValue(on);\r\n\r\n const itemsNode = caseConfig\r\n .map((config) => {\r\n const { value, items, scope } = config.props;\r\n if (onValue === value) {\r\n return h(MatchCase, {\r\n scope,\r\n items,\r\n key: [\"case\", value].join(\"-\"),\r\n });\r\n }\r\n })\r\n .filter((node) => node);\r\n\r\n if (defaultConfig && !itemsNode.length) {\r\n const { items, scope } = defaultConfig.props;\r\n itemsNode.push(h(MatchCase, { scope, items, key: \"default\" }));\r\n }\r\n\r\n return h(_Fragment, itemsNode);\r\n };\r\n}\r\n\r\nexport default defineComponent(render, {\r\n props: [\"case\", \"on\", \"default\"],\r\n});\r\n","import { defineComponent, h, TransitionGroup as _TransitionGroup } from \"vue\";\r\n\r\ntype TProps = {\r\n name?: string;\r\n tag?: string;\r\n};\r\n\r\nfunction render(props: TProps, { slots }: any) {\r\n // setup\r\n const { name = \"fade\", tag } = props;\r\n\r\n // render\r\n return () => {\r\n return h(\r\n _TransitionGroup,\r\n { name, tag },\r\n {\r\n default: slots.default,\r\n }\r\n );\r\n };\r\n}\r\n\r\nexport default defineComponent(render, {\r\n props: [\"name\", \"tag\"],\r\n});\r\n","import {\r\n defineComponent,\r\n h,\r\n Fragment as _Fragment,\r\n toDisplayString,\r\n} from \"vue\";\r\nimport * as bindableHelper from \"@/shared/bindableHelper\";\r\n\r\ntype TProps = {\r\n content: any;\r\n r?: number;\r\n};\r\n\r\nfunction render(props: TProps) {\r\n // setup\r\n const { content, r: isRef = 0 } = props;\r\n const snapshot = bindableHelper.createSnapshot();\r\n\r\n const getter =\r\n isRef === 1 ? () => snapshot.getObjectToValue(content) : () => content;\r\n\r\n // render\r\n return () => {\r\n return toDisplayString(getter());\r\n };\r\n}\r\n\r\nexport default defineComponent(render, {\r\n props: [\"content\", \"r\"],\r\n});\r\n","import { h, KeepAlive as _KeepAlive, Fragment as _Fragment } from \"vue\";\r\n\r\nimport ScopeContainer from \"@/components/scopeContainer\";\r\nimport Element from \"@/components/element/element.ts\";\r\nimport { TAppConfig, TScope } from \"./configTypes\";\r\nimport { TVueRouteItem, TRouteRecordConfig } from \"./configTypes/router\";\r\n\r\nexport function extraVueRoutesRecords(app: TAppConfig): any[] {\r\n if (!app.router) {\r\n throw new Error(\"Router config is not provided.\");\r\n }\r\n const { routes, kAlive: isKeepAlive = false } = app.router;\r\n\r\n const vueRoutes = routes.map((routeInfo) =>\r\n _config2vueRouteItem(routeInfo, isKeepAlive)\r\n );\r\n\r\n return vueRoutes;\r\n}\r\n\r\nfunction _config2vueRouteItem(\r\n routeInfo: TRouteRecordConfig,\r\n isKeepAlive: boolean\r\n): Record<string, any> {\r\n const { server: serverLoad = false, vueItem, scope } = routeInfo;\r\n\r\n const fn = () => {\r\n if (serverLoad) {\r\n throw new Error(\"Server-side rendering is not supported yet.\");\r\n }\r\n\r\n return Promise.resolve(_renderByConfig(vueItem, scope, isKeepAlive));\r\n };\r\n\r\n const children = vueItem.children?.map((child) =>\r\n _config2vueRouteItem(child, isKeepAlive)\r\n );\r\n\r\n const result: Record<string, any> = {\r\n ...vueItem,\r\n children,\r\n component: fn,\r\n };\r\n\r\n if (vueItem.component.length === 0) {\r\n delete result.component;\r\n }\r\n\r\n if (children === undefined) {\r\n delete result.children;\r\n }\r\n\r\n return result;\r\n}\r\n\r\nfunction _renderByConfig(\r\n vueItem: TVueRouteItem,\r\n scope: TScope,\r\n isKeepAlive: boolean\r\n) {\r\n const { path, component: items } = vueItem;\r\n\r\n const scopeNode = h(ScopeContainer, { scope, key: path }, () =>\r\n items.map((item) => h(Element, { component: item }))\r\n );\r\n\r\n const renderNode = isKeepAlive\r\n ? h(_KeepAlive, null, () => scopeNode)\r\n : scopeNode;\r\n\r\n return renderNode;\r\n}\r\n","import { App } from \"vue\";\r\nimport {\r\n createWebHashHistory,\r\n createWebHistory,\r\n createMemoryHistory,\r\n createRouter,\r\n} from \"vue-router\";\r\nimport { TAppConfig } from \"@/shared/configTypes\";\r\nimport { extraVueRoutesRecords } from \"@/shared/routerStore\";\r\n\r\nexport function useRouterByAppConfig(app: App, config: TAppConfig) {\r\n const { mode = \"hash\" } = config.router!;\r\n\r\n const history =\r\n mode === \"hash\"\r\n ? createWebHashHistory()\r\n : mode === \"memory\"\r\n ? createMemoryHistory()\r\n : createWebHistory();\r\n\r\n app.use(\r\n createRouter({\r\n history: history,\r\n routes: extraVueRoutesRecords(config),\r\n })\r\n );\r\n}\r\n","import InstaApp from \"./App.vue\";\r\nimport vif from \"./components/vif/vif\";\r\nimport VFor from \"@/components/vfor/vfor\";\r\nimport { Refresh } from \"@/components/refresh\";\r\nimport Match from \"@/components/match\";\r\nimport TransitionGroup from \"@/components/transitionGroup\";\r\nimport Content from \"@/components/content\";\r\nimport { App } from \"vue\";\r\nimport { useRouterByAppConfig } from \"@/shared/routerHelper\";\r\nimport { TAppConfig } from \"./shared/configTypes\";\r\nexport { convertDynamicProperties } from \"@/appUtils\";\r\n\r\nexport function install(app: App, config: TAppConfig) {\r\n app.component(\"insta-ui\", InstaApp);\r\n app.component(\"vif\", vif);\r\n app.component(\"vfor\", VFor);\r\n app.component(\"match\", Match);\r\n app.component(\"refresh\", Refresh);\r\n app.component(\"ts-group\", TransitionGroup);\r\n app.component(\"content\", Content);\r\n\r\n if (config.router) {\r\n useRouterByAppConfig(app, config);\r\n }\r\n}\r\n"],"names":["setupInfo","setup","info","getInfo","getPageInfoPostData","queryPath","pathParams","queryParams","DefaultMap","factory","key","defaultValue","defaultMap","foreachObject","obj","fn","value","mapObjectForValue","valueFn","mapObjectFor","keyFn","index","handleObject","path","getBindableFn","flag","args","newPath","getPath","getByPaths","object","paths","setByPaths","deepClone","Initial","__INITIAL__","isInitial","toRaw","makeRefObjectWithPaths","getterOptions","setterOptions","getterPaths","getterGetBindableValueFn","setterPaths","setterGetBindableValueFn","customRef","objectSystem.getByPaths","toValue","newValue","objectSystem.setByPaths","useDeepCompareRef","track","trigger","computedInit.isInitial","r","unref","noop","promiseTimeout","ms","throwOnTimeout","reason","resolve","reject","createUntil","isNot","toMatch","condition","flush","deep","timeout","stop","promises","watch","v","nextTick","toBe","options","isRef","v1","v2","toBeTruthy","toBeNull","toBeUndefined","toBeNaN","toContains","array","changed","changedTimes","n","count","until","computedAsync","evaluationCallback","initialState","optionsOrRef","lazy","evaluating","shallow","onError","started","ref","current","shallowRef","counter","watchEffect","onInvalidate","counterAtBeginning","hasFinished","result","cancelCallback","e","computed","useAsyncState","promise","immediate","delay","onSuccess","resetOnExecute","throwError","state","isReady","isLoading","error","execute","delay2","_promise","data","shell","waitUntilIsLoaded","onFulfilled","onRejected","createFnFromString","fnCode","params","keys","values","__Vue","tryStringWithColonToFunction","code","isAsyncFunction","func","createRef","varConfig","debugInfo","createVueComputedByStringCode","snapshot","isConsts","refObjs","p","fnSystem.isAsyncFunction","asyncComputed","fnParams","jsCodeSystem.createFnFromString","createJsComputedByStringCode","inputs","slient","asyncInitValue","deepEqOnInput","slients","datas","watchTargets","_","input","getInputValues","computedInit.__INITIAL__","watchOptions","readonly","varSeqFactory","_scopeMap","createVarStore","scope","indexSeq","varMap","createScopeSnapshot","saveToMap","_a","varBuilder.createRef","_b","init","refObj","_c","varBuilder.createVueComputedByStringCode","_d","varBuilder.createJsComputedByStringCode","_e","scopeId","getVueRef","_getVueRef","scopeMap","clearScopeVarStore","removeIndexVars","varMapIndex","indexMap","createElementRefStore","refMap","eRef","refObject","removeElementRef","refMaps","createElementRefSnapshot","snapshotMap","getRef","elementRef","bindableTools","isVar","bindable","isRouterParams","isRouterAction","isJs","isJsOutput","isVForItem","isVForIndex","isSlotProp","isEventContext","isElementRef","IsBinding","_slotMap","SetupCollect","slotId","seq","updateValues","seqIndex","removeSlotInfo","createSnapshot","valueSeq","getPropsValue","vforSourceMap","fid2keyMap","vforSourceLoopNumberMap","VFOR_KEY","provideVForKey","vforInfo","preInfo","injectVForKey","provide","inject","injectVForFid2keyMap","itemMap","fid","markArray","isBindRef","isLoopNumber","arraySourceGetter","BindableArraySourceGetter","arrayValue","ConstArraySourceGetter","markVForIndex","key2indexMap","keysCollector","usedKeys","add","removeUnusedKeys","createVForSnapshot","currentKey","keyMapSnapshot","getVForIndex","createRefObjectWithPaths","isVForLoopNumber","binding","currentVForIndex","__publicField","orgRef","sourceValue","isDictSource","defaultDictPath","newSourceValue","createFn","bindings","isComputed","isNullOrUndefined","getDevtoolsGlobalHook","getTarget","isProxyAvailable","HOOK_SETUP","HOOK_PLUGIN_SETTINGS_SET","supported","perf","isPerformanceSupported","now","ApiProxy","plugin","hook","defaultSettings","id","item","localSettingsSaveId","currentSettings","raw","pluginId","_target","prop","target","setupDevtoolsPlugin","pluginDescriptor","setupFn","descriptor","enableProxy","proxy","isBrowser","isRouteComponent","component","isESModule","assign","applyToParams","newParams","isArray","warn","msg","HASH_RE","AMPERSAND_RE","SLASH_RE","EQUAL_RE","IM_RE","PLUS_RE","ENC_BRACKET_OPEN_RE","ENC_BRACKET_CLOSE_RE","ENC_CARET_RE","ENC_BACKTICK_RE","ENC_CURLY_OPEN_RE","ENC_PIPE_RE","ENC_CURLY_CLOSE_RE","ENC_SPACE_RE","commonEncode","text","encodeHash","encodeQueryValue","encodeQueryKey","encodePath","encodeParam","decode","define_process_env_default","TRAILING_SLASH_RE","removeTrailingSlash","parseURL","parseQuery","location","currentLocation","query","searchString","hash","hashPos","searchPos","resolveRelativePath","stringifyURL","stringifyQuery","stripBase","pathname","base","isSameRouteLocation","a","b","aLastIndex","bLastIndex","isSameRouteRecord","isSameRouteLocationParams","isSameRouteLocationParamsValue","isEquivalentArray","i","to","from","fromSegments","toSegments","lastToSegment","position","toPosition","segment","START_LOCATION_NORMALIZED","NavigationType","NavigationDirection","START","normalizeBase","baseEl","BEFORE_HASH_RE","createHref","getElementPosition","el","offset","docRect","elRect","computeScrollPosition","scrollToPosition","scrollToOptions","positionEl","isIdSelector","foundEl","getScrollKey","delta","scrollPositions","saveScrollPosition","scrollPosition","getSavedScrollPosition","scroll","createBaseLocation","createCurrentLocation","search","slicePos","pathFromHash","useHistoryListeners","historyState","replace","listeners","teardowns","pauseState","popStateHandler","fromState","listener","pauseListeners","listen","callback","teardown","beforeUnloadListener","history","destroy","buildState","back","forward","replaced","computeScroll","useHistoryStateNavigation","changeLocation","hashIndex","url","err","push","currentState","createWebHistory","historyNavigation","historyListeners","go","triggerListeners","routerHistory","createMemoryHistory","queue","setLocation","direction","shouldTrigger","createWebHashHistory","isRouteLocation","route","isRouteName","name","NavigationFailureSymbol","NavigationFailureType","ErrorTypeMessages","stringifyRoute","createRouterError","type","isNavigationFailure","propertiesToLog","BASE_PARAM_PATTERN","BASE_PATH_PARSER_OPTIONS","REGEX_CHARS_RE","tokensToParser","segments","extraOptions","score","pattern","segmentScores","tokenIndex","token","subSegmentScore","repeatable","optional","regexp","re","subPattern","parse","match","stringify","avoidDuplicatedSlash","param","compareScoreArray","diff","comparePathParserScore","aScore","bScore","comp","isLastScoreNegative","last","ROOT_TOKEN","VALID_PARAM_RE","tokenizePath","crash","message","buffer","previousState","tokens","finalizeSegment","char","customRe","consumeBuffer","addCharToBuffer","createRouteRecordMatcher","record","parent","parser","existingKeys","matcher","createRouterMatcher","routes","globalOptions","matchers","matcherMap","mergeOptions","getRecordMatcher","addRoute","originalRecord","isRootAdd","mainNormalizedRecord","normalizeRouteRecord","checkChildMissingNameWithEmptyPath","normalizedRecords","aliases","alias","originalMatcher","normalizedRecord","parentPath","connectingSlash","checkMissingParamsInAbsolutePath","checkSameParams","isAliasRecord","checkSameNameAsAncestor","removeRoute","isMatchable","insertMatcher","children","matcherRef","getRoutes","findInsertionIndex","invalidParams","paramName","k","paramsFromLocation","m","matched","parentMatcher","mergeMetaFields","clearRoutes","normalized","normalizeRecordProps","propsObject","props","meta","defaults","partialOptions","isSameParam","ancestor","lower","upper","mid","insertionAncestor","getInsertionAncestor","searchParams","searchParam","eqPos","currentValue","normalizeQuery","normalizedQuery","matchedRouteKey","viewDepthKey","routerKey","routeLocationKey","routerViewLocationKey","useCallbacks","handlers","handler","reset","guardToPromiseFn","guard","runWithContext","enterCallbackArray","next","valid","guardReturn","canOnlyBeCalledOnce","guardCall","resolvedValue","called","extractComponentsGuards","guardType","guards","rawComponent","componentPromise","resolved","resolvedComponent","useLink","router","currentRoute","hasPrevious","previousTo","activeRecordIndex","length","routeMatched","currentMatched","parentRecordPath","getOriginalPath","isActive","includesParams","isExactActive","navigate","guardEvent","instance","getCurrentInstance","linkContextDevtools","preferSingleVNode","vnodes","RouterLinkImpl","defineComponent","slots","link","reactive","elClass","getLinkClass","h","RouterLink","outer","inner","innerValue","outerValue","propClass","globalClass","defaultClass","RouterViewImpl","attrs","warnDeprecatedUsage","injectedRoute","routeToDisplay","injectedDepth","depth","initialDepth","matchedRoute","matchedRouteRef","viewRef","oldInstance","oldName","currentName","ViewComponent","normalizeSlot","routePropsOption","routeProps","vnode","slot","slotContent","RouterView","parentName","parentSubTreeType","formatRouteLocation","routeLocation","tooltip","copy","omit","formatDisplay","display","routerId","addDevtools","app","api","payload","ctx","node","componentInstance","PINK_500","devtoolsData","label","backgroundColor","ORANGE_400","textColor","RED_100","RED_700","LIME_500","BLUE_600","refreshRoutesView","routerInspectorId","navigationsLayerId","navigationId","failure","activeRoutesPayload","resetMatchStateOnRouteRecord","isRouteMatching","markRouteRecordActive","formatRouteRecordForInspector","formatRouteRecordMatcherForStateInspector","modifierForKey","fields","CYAN_400","DARK","tags","routeRecordId","EXTRACT_REGEXP_RE","childRoute","filter","found","child","decodedPath","ret","createRouter","parseQuery$1","stringifyQuery$1","beforeGuards","beforeResolveGuards","afterGuards","pendingLocation","normalizeParams","paramValue","encodeParams","decodeParams","parentOrRoute","recordMatcher","routeMatcher","hasRoute","rawLocation","locationNormalized","href","matcherLocation","targetParams","fullPath","locationAsObject","checkCanceledNavigation","pushWithRedirect","handleRedirectRecord","lastMatched","redirect","newTargetLocation","redirectedFrom","targetLocation","force","shouldRedirect","toLocation","handleScroll","markAsReady","triggerError","finalizeNavigation","triggerAfterEach","checkCanceledNavigationAndReject","installedApps","leavingRecords","updatingRecords","enteringRecords","extractChangingRecords","canceledNavigationCheck","runGuardQueue","beforeEnter","isPush","isFirstNavigation","removeHistoryListener","setupListeners","_from","readyHandlers","errorListeners","ready","list","scrollBehavior","reactiveRoute","shallowReactive","unmountApp","len","recordFrom","recordTo","useRouter","useRoute","_name","vforKey","scopeSnapshot","slotSnapshot","slotStore.createSnapshot","vforSnapshot","vforManager.createVForSnapshot","elementRefSnapshot","elementRefStore.createElementRefSnapshot","routerSnapshot","routeSnapshot","replaceSnapshot","getObjectToValue","getVueRefObject","vforManager.isVForLoopNumber","bind","fnBindings","objectSystem.mapObjectForValue","val","getVueRefObjectOrValue","jsStrVar.createFn","vueObj","vueSystem.makeRefObjectWithPaths","vforManager.createRefObjectWithPaths","self","getBindingServerInfo","updateRefFromServer","infos","updateOutputsRefFromServer","outputs","valueSystem.isNullOrUndefined","skips","output","routerMethod","elementObj","method","fnOrValue","WebDataSender","eventType","hKey","componentKey","webServerInfo","appInfo.getInfo","keyObj","eProps","response","appInfo.getPageInfoPostData","watchTask","watchType","inputValues","body","WebViewDataSender","fType","eventInfo","currentDataSender","setupDataSender","getDataSender","toWatchConfig","computedConfig","setupWebWatchStore","watchConfig","snapshots","WebWatchManager","watchTasks","createWatchTaskFn","config","WatchTask","webComputed.toWatchConfig","once","watchOption","TaskNode","constDatas","tasks","task","nextNodes","nextNode","others","taskIdsOfOutput","resultIds","const_data","vueRef","nodes","fetch2server","calcTask","responseData","createVueWatch","sources","onData","bindData","onDatas","bindDatas","_toVueWatchTarget","isData","createJsWatch","objectSystem.deepClone","resultValues","createEvents","events","fns","bindBuilder","prepareBindings","createWebEventHandlerFn","createVueEvent","createJsEvent","bindingsBuilder","handleEvent","set","eventFn","outputValues","handlerStyles","style","styles","_normalizeStyle","handlerClasses","classes","_normalizeClass","strClass","mapClass","bindClass","convertDynamicProperties","recursive","attr","tryConvertDynamicProp","isFunc","handlerProps","staticProps","objectSystem.foreachObject","realValue","toPropValue","propName","toDisplayString","render","propNames","slotSeqIndex","slotStore.SetupCollect","onUnmounted","slotStore.removeSlotInfo","propsValue","slotStore.updateValues","_Fragment","SlotPropContainer","handlerSlots","isHtmlTag","slotConfig","createElements","objectSystem.mapObjectFor","slotName","items","slotProps","childernSlot","createSlotPropsContainer","ScopeContainer","propsInfo","Element","collectDirectives","dirs","newProps","directiveArray","directive","sys","arg","modifers","refValue","mfs","modifier","vModelDynamic","_vShow","handlerElementRef","tag","stringTag","configTypes.bindableTools","resolveDynamicComponent","hasStyle","valueProps","elementRefProps","hProps","_normalizeProps","resultNode","withDirectives","elementRefStoreIndex","storeIndex","VForScope","vforManager.provideVForKey","useLoadAppConfig","appConfig","configUrl","appErrorHandler","vm","componentMessage","__props","appInfo.setup","onErrorCaptured","on","onValue","vif","range","start","end","step","bArray","fkey","num","tsGroup","vforManager.markArray","createKeyFn","createSourceValueArray","vforManager.keysCollector","itemsNode","vforManager.markVForIndex","_TransitionGroup","VFor","numValue","numberSystem.range","source","_item_key_fn","_index_key_fn","jsCodeSystem.tryStringWithColonToFunction","cpNode","Scope","Refresh","itemsRef","helpers","createDynamicWatchRefresh","targetOns","currentWatcher","currentOns","targetRefs","setupWatcher","fetchRemote","fnParamsWithKey","fetchOptions","MatchCase","caseConfig","defaultConfig","bindableHelper.createSnapshot","Match","TransitionGroup","content","getter","Content","extraVueRoutesRecords","isKeepAlive","routeInfo","_config2vueRouteItem","serverLoad","vueItem","_renderByConfig","scopeNode","_KeepAlive","useRouterByAppConfig","mode","install","InstaApp"],"mappings":"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","x_google_ignoreList":[5,6,17,18,19,20,21,22]}
1
+ {"version":3,"file":"insta-ui.js","sources":["../src/shared/appInfo.ts","../src/systems/mapSystem.ts","../src/systems/objectSystem.ts","../src/shared/computedInit.ts","../src/systems/vueSystem.ts","../node_modules/.pnpm/@vueuse+shared@12.0.0_typescript@5.6.3/node_modules/@vueuse/shared/index.mjs","../node_modules/.pnpm/@vueuse+core@12.0.0_typescript@5.6.3/node_modules/@vueuse/core/index.mjs","../src/systems/jsCodeSystem.ts","../src/systems/fnSystem.ts","../src/shared/varBuilder.ts","../src/shared/varStore.ts","../src/shared/elementRefStore.ts","../src/shared/configTypes/vars.ts","../src/shared/slotStore.ts","../src/shared/vforManager.ts","../src/shared/jsStrVar.ts","../src/systems/valueSystem.ts","../node_modules/.pnpm/@vue+devtools-api@6.6.4/node_modules/@vue/devtools-api/lib/esm/env.js","../node_modules/.pnpm/@vue+devtools-api@6.6.4/node_modules/@vue/devtools-api/lib/esm/const.js","../node_modules/.pnpm/@vue+devtools-api@6.6.4/node_modules/@vue/devtools-api/lib/esm/time.js","../node_modules/.pnpm/@vue+devtools-api@6.6.4/node_modules/@vue/devtools-api/lib/esm/proxy.js","../node_modules/.pnpm/@vue+devtools-api@6.6.4/node_modules/@vue/devtools-api/lib/esm/index.js","../node_modules/.pnpm/vue-router@4.5.0_vue@3.5.13_typescript@5.6.3_/node_modules/vue-router/dist/vue-router.mjs","../src/shared/bindableHelper.ts","../src/shared/dataSender/webSender.ts","../src/shared/dataSender/webViewSender.ts","../src/shared/dataSender/index.ts","../src/shared/webComputed.ts","../src/shared/webWatchStore.ts","../src/shared/jsWatchStore.ts","../src/components/element/events.ts","../src/components/element/styles.ts","../src/components/element/classes.ts","../src/appUtils.ts","../src/components/element/props.ts","../src/components/slotPropContainer.ts","../src/components/element/slots.ts","../src/components/element/directives.ts","../src/components/element/elementRef.ts","../src/components/element/element.ts","../src/components/scopeContainer.ts","../src/app.ts","../src/App.vue","../src/components/vif/vif.ts","../src/systems/numberSystem.ts","../src/components/vfor/vfor.ts","../src/components/scope.ts","../src/components/refresh.ts","../src/components/matchCase.ts","../src/components/match.ts","../src/components/transitionGroup.ts","../src/components/content.ts","../src/shared/routerStore.ts","../src/shared/routerHelper.ts","../src/libMain.ts"],"sourcesContent":["import { TAppConfig } from \"@/shared/configTypes\";\r\n\r\ntype TSetupValue = {\r\n queryPath: string;\r\n version: string;\r\n mode: TAppConfig[\"mode\"];\r\n webServerInfo?: TAppConfig[\"webInfo\"];\r\n pathParams?: Record<string, any>;\r\n queryParams?: Record<string, any>;\r\n};\r\n\r\nlet setupInfo: TSetupValue;\r\n\r\nexport function setup(info: TSetupValue) {\r\n setupInfo = info;\r\n}\r\n\r\nexport function getInfo() {\r\n return setupInfo;\r\n}\r\n\r\nexport function getPageInfoPostData() {\r\n const { queryPath, pathParams, queryParams } = getInfo();\r\n const paramsItem = pathParams === undefined ? {} : { params: pathParams };\r\n const queryItem =\r\n queryParams === undefined ? {} : { queryParams: queryParams };\r\n\r\n return {\r\n path: queryPath,\r\n ...paramsItem,\r\n ...queryItem,\r\n };\r\n}\r\n","class DefaultMap<K, V> extends Map<K, V> {\r\n constructor(private factory: () => V) {\r\n super();\r\n }\r\n\r\n getOrDefault(key: K): V {\r\n if (!this.has(key)) {\r\n const defaultValue = this.factory();\r\n this.set(key, defaultValue);\r\n return defaultValue;\r\n }\r\n return super.get(key)!;\r\n }\r\n}\r\n\r\nexport function defaultMap<K, V>(factory: () => V): DefaultMap<K, V> {\r\n return new DefaultMap(factory);\r\n}\r\n","export function foreachObject<TValue>(\r\n obj: Record<string, TValue>,\r\n fn: (value: TValue, key: string) => any\r\n) {\r\n Object.entries(obj).forEach(([key, value]) => fn(value, key));\r\n}\r\n\r\nexport function mapObjectForValue<TValue>(\r\n obj: Record<string, TValue>,\r\n valueFn: (value: TValue, key: string, index: number) => any\r\n) {\r\n return mapObjectFor(obj, {\r\n valueFn,\r\n });\r\n}\r\n\r\nexport function mapObjectFor<TValue>(\r\n obj: Record<string, TValue>,\r\n fn: {\r\n valueFn: (value: TValue, key: string, index: number) => any;\r\n keyFn?: (key: string, value: TValue) => any;\r\n }\r\n) {\r\n const { valueFn, keyFn } = fn;\r\n\r\n return Object.fromEntries(\r\n Object.entries(obj).map(([key, value], index) => [\r\n keyFn ? keyFn(key, value) : key,\r\n valueFn(value, key, index),\r\n ])\r\n );\r\n}\r\n\r\nfunction handleObject(\r\n obj: any,\r\n path: string | number | any[],\r\n getBindableFn?: (value: any) => any\r\n) {\r\n if (Array.isArray(path)) {\r\n const [flag, ...args] = path as any[];\r\n\r\n switch (flag) {\r\n case \"!\":\r\n return !obj;\r\n\r\n case \"+\":\r\n return obj + args[0];\r\n\r\n case \"~+\":\r\n return args[0] + obj;\r\n }\r\n }\r\n\r\n const newPath = getPath(path, getBindableFn);\r\n return obj[newPath];\r\n}\r\n\r\nfunction getPath(\r\n path: string | number | any[],\r\n getBindableFn?: (value: any) => any\r\n) {\r\n if (typeof path === \"string\" || typeof path === \"number\") {\r\n return path;\r\n }\r\n\r\n if (!Array.isArray(path)) {\r\n throw new Error(`Invalid path ${path}`);\r\n }\r\n\r\n const [flag, ...args] = path as any[];\r\n switch (flag) {\r\n case \"bind\":\r\n if (!getBindableFn) {\r\n throw new Error(\"No bindable function provided\");\r\n }\r\n return getBindableFn(args[0]);\r\n\r\n default:\r\n throw new Error(`Invalid flag ${flag} in array at ${path}`);\r\n }\r\n}\r\n\r\nexport function getByPaths(\r\n object: any,\r\n paths: (string | number)[],\r\n getBindableFn?: (value: any) => any\r\n): any {\r\n return paths.reduce(\r\n (obj, path) => handleObject(obj, path, getBindableFn),\r\n object\r\n );\r\n}\r\n\r\nexport function setByPaths(\r\n object: any,\r\n paths: (string | number)[],\r\n value: any,\r\n getBindableFn?: (value: any) => any\r\n): void {\r\n paths.reduce((obj, path, index) => {\r\n if (index === paths.length - 1) {\r\n obj[getPath(path, getBindableFn)] = value;\r\n } else {\r\n return handleObject(obj, path, getBindableFn);\r\n }\r\n }, object);\r\n}\r\n\r\nexport function deepClone(obj: any) {\r\n return JSON.parse(JSON.stringify(obj));\r\n}\r\n","import { toRaw } from \"vue\";\r\n\r\nclass Initial {\r\n toString() {\r\n return ``;\r\n }\r\n}\r\n\r\nexport const __INITIAL__ = new Initial();\r\n\r\nexport function isInitial(value: any): boolean {\r\n return toRaw(value) === __INITIAL__;\r\n}\r\n","import { customRef, Ref, ComputedRef, toValue } from \"vue\";\r\nimport * as objectSystem from \"@/systems/objectSystem\";\r\nimport * as computedInit from \"@/shared/computedInit\";\r\n\r\nexport function makeRefObjectWithPaths(\r\n object: object | Ref<any> | ComputedRef,\r\n getterOptions: {\r\n paths?: (string | number)[] | undefined;\r\n getBindableValueFn: (value: any) => any;\r\n },\r\n setterOptions?: {\r\n paths?: (string | number)[] | undefined;\r\n getBindableValueFn: (value: any) => any;\r\n }\r\n) {\r\n const { paths: getterPaths, getBindableValueFn: getterGetBindableValueFn } =\r\n getterOptions;\r\n const { paths: setterPaths, getBindableValueFn: setterGetBindableValueFn } =\r\n setterOptions || getterOptions;\r\n\r\n if (getterPaths === undefined || getterPaths.length === 0) {\r\n return object;\r\n }\r\n\r\n return customRef(() => {\r\n return {\r\n get() {\r\n try {\r\n return objectSystem.getByPaths(\r\n toValue(object),\r\n getterPaths,\r\n getterGetBindableValueFn\r\n );\r\n } catch (e) {\r\n return undefined;\r\n }\r\n },\r\n set(newValue) {\r\n objectSystem.setByPaths(\r\n toValue(object),\r\n setterPaths || getterPaths,\r\n newValue,\r\n setterGetBindableValueFn\r\n );\r\n },\r\n };\r\n });\r\n}\r\n\r\nexport function useDeepCompareRef(value: any) {\r\n return customRef((track, trigger) => {\r\n return {\r\n get() {\r\n track();\r\n return value;\r\n },\r\n set(newValue) {\r\n if (\r\n !computedInit.isInitial(value) &&\r\n JSON.stringify(newValue) === JSON.stringify(value)\r\n ) {\r\n return;\r\n }\r\n value = newValue;\r\n trigger();\r\n },\r\n };\r\n });\r\n}\r\n","import { shallowRef, watchEffect, readonly, ref, watch, customRef, getCurrentScope, onScopeDispose, effectScope, getCurrentInstance, inject, provide, isRef, unref, computed, reactive, toRefs as toRefs$1, toRef as toRef$1, onBeforeMount, nextTick, onBeforeUnmount, onMounted, onUnmounted, isReactive } from 'vue';\n\nfunction computedEager(fn, options) {\n var _a;\n const result = shallowRef();\n watchEffect(() => {\n result.value = fn();\n }, {\n ...options,\n flush: (_a = options == null ? void 0 : options.flush) != null ? _a : \"sync\"\n });\n return readonly(result);\n}\n\nfunction computedWithControl(source, fn) {\n let v = void 0;\n let track;\n let trigger;\n const dirty = ref(true);\n const update = () => {\n dirty.value = true;\n trigger();\n };\n watch(source, update, { flush: \"sync\" });\n const get = typeof fn === \"function\" ? fn : fn.get;\n const set = typeof fn === \"function\" ? void 0 : fn.set;\n const result = customRef((_track, _trigger) => {\n track = _track;\n trigger = _trigger;\n return {\n get() {\n if (dirty.value) {\n v = get(v);\n dirty.value = false;\n }\n track();\n return v;\n },\n set(v2) {\n set == null ? void 0 : set(v2);\n }\n };\n });\n if (Object.isExtensible(result))\n result.trigger = update;\n return result;\n}\n\nfunction tryOnScopeDispose(fn) {\n if (getCurrentScope()) {\n onScopeDispose(fn);\n return true;\n }\n return false;\n}\n\nfunction createEventHook() {\n const fns = /* @__PURE__ */ new Set();\n const off = (fn) => {\n fns.delete(fn);\n };\n const on = (fn) => {\n fns.add(fn);\n const offFn = () => off(fn);\n tryOnScopeDispose(offFn);\n return {\n off: offFn\n };\n };\n const trigger = (...args) => {\n return Promise.all(Array.from(fns).map((fn) => fn(...args)));\n };\n return {\n on,\n off,\n trigger\n };\n}\n\nfunction createGlobalState(stateFactory) {\n let initialized = false;\n let state;\n const scope = effectScope(true);\n return (...args) => {\n if (!initialized) {\n state = scope.run(() => stateFactory(...args));\n initialized = true;\n }\n return state;\n };\n}\n\nconst localProvidedStateMap = /* @__PURE__ */ new WeakMap();\n\nconst injectLocal = (...args) => {\n var _a;\n const key = args[0];\n const instance = (_a = getCurrentInstance()) == null ? void 0 : _a.proxy;\n if (instance == null)\n throw new Error(\"injectLocal must be called in setup\");\n if (localProvidedStateMap.has(instance) && key in localProvidedStateMap.get(instance))\n return localProvidedStateMap.get(instance)[key];\n return inject(...args);\n};\n\nconst provideLocal = (key, value) => {\n var _a;\n const instance = (_a = getCurrentInstance()) == null ? void 0 : _a.proxy;\n if (instance == null)\n throw new Error(\"provideLocal must be called in setup\");\n if (!localProvidedStateMap.has(instance))\n localProvidedStateMap.set(instance, /* @__PURE__ */ Object.create(null));\n const localProvidedState = localProvidedStateMap.get(instance);\n localProvidedState[key] = value;\n provide(key, value);\n};\n\nfunction createInjectionState(composable, options) {\n const key = (options == null ? void 0 : options.injectionKey) || Symbol(composable.name || \"InjectionState\");\n const defaultValue = options == null ? void 0 : options.defaultValue;\n const useProvidingState = (...args) => {\n const state = composable(...args);\n provideLocal(key, state);\n return state;\n };\n const useInjectedState = () => injectLocal(key, defaultValue);\n return [useProvidingState, useInjectedState];\n}\n\nfunction createSharedComposable(composable) {\n let subscribers = 0;\n let state;\n let scope;\n const dispose = () => {\n subscribers -= 1;\n if (scope && subscribers <= 0) {\n scope.stop();\n state = void 0;\n scope = void 0;\n }\n };\n return (...args) => {\n subscribers += 1;\n if (!scope) {\n scope = effectScope(true);\n state = scope.run(() => composable(...args));\n }\n tryOnScopeDispose(dispose);\n return state;\n };\n}\n\nfunction extendRef(ref, extend, { enumerable = false, unwrap = true } = {}) {\n for (const [key, value] of Object.entries(extend)) {\n if (key === \"value\")\n continue;\n if (isRef(value) && unwrap) {\n Object.defineProperty(ref, key, {\n get() {\n return value.value;\n },\n set(v) {\n value.value = v;\n },\n enumerable\n });\n } else {\n Object.defineProperty(ref, key, { value, enumerable });\n }\n }\n return ref;\n}\n\nfunction get(obj, key) {\n if (key == null)\n return unref(obj);\n return unref(obj)[key];\n}\n\nfunction isDefined(v) {\n return unref(v) != null;\n}\n\nfunction makeDestructurable(obj, arr) {\n if (typeof Symbol !== \"undefined\") {\n const clone = { ...obj };\n Object.defineProperty(clone, Symbol.iterator, {\n enumerable: false,\n value() {\n let index = 0;\n return {\n next: () => ({\n value: arr[index++],\n done: index > arr.length\n })\n };\n }\n });\n return clone;\n } else {\n return Object.assign([...arr], obj);\n }\n}\n\nfunction toValue(r) {\n return typeof r === \"function\" ? r() : unref(r);\n}\nconst resolveUnref = toValue;\n\nfunction reactify(fn, options) {\n const unrefFn = (options == null ? void 0 : options.computedGetter) === false ? unref : toValue;\n return function(...args) {\n return computed(() => fn.apply(this, args.map((i) => unrefFn(i))));\n };\n}\n\nfunction reactifyObject(obj, optionsOrKeys = {}) {\n let keys = [];\n let options;\n if (Array.isArray(optionsOrKeys)) {\n keys = optionsOrKeys;\n } else {\n options = optionsOrKeys;\n const { includeOwnProperties = true } = optionsOrKeys;\n keys.push(...Object.keys(obj));\n if (includeOwnProperties)\n keys.push(...Object.getOwnPropertyNames(obj));\n }\n return Object.fromEntries(\n keys.map((key) => {\n const value = obj[key];\n return [\n key,\n typeof value === \"function\" ? reactify(value.bind(obj), options) : value\n ];\n })\n );\n}\n\nfunction toReactive(objectRef) {\n if (!isRef(objectRef))\n return reactive(objectRef);\n const proxy = new Proxy({}, {\n get(_, p, receiver) {\n return unref(Reflect.get(objectRef.value, p, receiver));\n },\n set(_, p, value) {\n if (isRef(objectRef.value[p]) && !isRef(value))\n objectRef.value[p].value = value;\n else\n objectRef.value[p] = value;\n return true;\n },\n deleteProperty(_, p) {\n return Reflect.deleteProperty(objectRef.value, p);\n },\n has(_, p) {\n return Reflect.has(objectRef.value, p);\n },\n ownKeys() {\n return Object.keys(objectRef.value);\n },\n getOwnPropertyDescriptor() {\n return {\n enumerable: true,\n configurable: true\n };\n }\n });\n return reactive(proxy);\n}\n\nfunction reactiveComputed(fn) {\n return toReactive(computed(fn));\n}\n\nfunction reactiveOmit(obj, ...keys) {\n const flatKeys = keys.flat();\n const predicate = flatKeys[0];\n return reactiveComputed(() => typeof predicate === \"function\" ? Object.fromEntries(Object.entries(toRefs$1(obj)).filter(([k, v]) => !predicate(toValue(v), k))) : Object.fromEntries(Object.entries(toRefs$1(obj)).filter((e) => !flatKeys.includes(e[0]))));\n}\n\nconst isClient = typeof window !== \"undefined\" && typeof document !== \"undefined\";\nconst isWorker = typeof WorkerGlobalScope !== \"undefined\" && globalThis instanceof WorkerGlobalScope;\nconst isDef = (val) => typeof val !== \"undefined\";\nconst notNullish = (val) => val != null;\nconst assert = (condition, ...infos) => {\n if (!condition)\n console.warn(...infos);\n};\nconst toString = Object.prototype.toString;\nconst isObject = (val) => toString.call(val) === \"[object Object]\";\nconst now = () => Date.now();\nconst timestamp = () => +Date.now();\nconst clamp = (n, min, max) => Math.min(max, Math.max(min, n));\nconst noop = () => {\n};\nconst rand = (min, max) => {\n min = Math.ceil(min);\n max = Math.floor(max);\n return Math.floor(Math.random() * (max - min + 1)) + min;\n};\nconst hasOwn = (val, key) => Object.prototype.hasOwnProperty.call(val, key);\nconst isIOS = /* @__PURE__ */ getIsIOS();\nfunction getIsIOS() {\n var _a, _b;\n return isClient && ((_a = window == null ? void 0 : window.navigator) == null ? void 0 : _a.userAgent) && (/iP(?:ad|hone|od)/.test(window.navigator.userAgent) || ((_b = window == null ? void 0 : window.navigator) == null ? void 0 : _b.maxTouchPoints) > 2 && /iPad|Macintosh/.test(window == null ? void 0 : window.navigator.userAgent));\n}\n\nfunction createFilterWrapper(filter, fn) {\n function wrapper(...args) {\n return new Promise((resolve, reject) => {\n Promise.resolve(filter(() => fn.apply(this, args), { fn, thisArg: this, args })).then(resolve).catch(reject);\n });\n }\n return wrapper;\n}\nconst bypassFilter = (invoke) => {\n return invoke();\n};\nfunction debounceFilter(ms, options = {}) {\n let timer;\n let maxTimer;\n let lastRejector = noop;\n const _clearTimeout = (timer2) => {\n clearTimeout(timer2);\n lastRejector();\n lastRejector = noop;\n };\n const filter = (invoke) => {\n const duration = toValue(ms);\n const maxDuration = toValue(options.maxWait);\n if (timer)\n _clearTimeout(timer);\n if (duration <= 0 || maxDuration !== void 0 && maxDuration <= 0) {\n if (maxTimer) {\n _clearTimeout(maxTimer);\n maxTimer = null;\n }\n return Promise.resolve(invoke());\n }\n return new Promise((resolve, reject) => {\n lastRejector = options.rejectOnCancel ? reject : resolve;\n if (maxDuration && !maxTimer) {\n maxTimer = setTimeout(() => {\n if (timer)\n _clearTimeout(timer);\n maxTimer = null;\n resolve(invoke());\n }, maxDuration);\n }\n timer = setTimeout(() => {\n if (maxTimer)\n _clearTimeout(maxTimer);\n maxTimer = null;\n resolve(invoke());\n }, duration);\n });\n };\n return filter;\n}\nfunction throttleFilter(...args) {\n let lastExec = 0;\n let timer;\n let isLeading = true;\n let lastRejector = noop;\n let lastValue;\n let ms;\n let trailing;\n let leading;\n let rejectOnCancel;\n if (!isRef(args[0]) && typeof args[0] === \"object\")\n ({ delay: ms, trailing = true, leading = true, rejectOnCancel = false } = args[0]);\n else\n [ms, trailing = true, leading = true, rejectOnCancel = false] = args;\n const clear = () => {\n if (timer) {\n clearTimeout(timer);\n timer = void 0;\n lastRejector();\n lastRejector = noop;\n }\n };\n const filter = (_invoke) => {\n const duration = toValue(ms);\n const elapsed = Date.now() - lastExec;\n const invoke = () => {\n return lastValue = _invoke();\n };\n clear();\n if (duration <= 0) {\n lastExec = Date.now();\n return invoke();\n }\n if (elapsed > duration && (leading || !isLeading)) {\n lastExec = Date.now();\n invoke();\n } else if (trailing) {\n lastValue = new Promise((resolve, reject) => {\n lastRejector = rejectOnCancel ? reject : resolve;\n timer = setTimeout(() => {\n lastExec = Date.now();\n isLeading = true;\n resolve(invoke());\n clear();\n }, Math.max(0, duration - elapsed));\n });\n }\n if (!leading && !timer)\n timer = setTimeout(() => isLeading = true, duration);\n isLeading = false;\n return lastValue;\n };\n return filter;\n}\nfunction pausableFilter(extendFilter = bypassFilter) {\n const isActive = ref(true);\n function pause() {\n isActive.value = false;\n }\n function resume() {\n isActive.value = true;\n }\n const eventFilter = (...args) => {\n if (isActive.value)\n extendFilter(...args);\n };\n return { isActive: readonly(isActive), pause, resume, eventFilter };\n}\n\nfunction cacheStringFunction(fn) {\n const cache = /* @__PURE__ */ Object.create(null);\n return (str) => {\n const hit = cache[str];\n return hit || (cache[str] = fn(str));\n };\n}\nconst hyphenateRE = /\\B([A-Z])/g;\nconst hyphenate = cacheStringFunction((str) => str.replace(hyphenateRE, \"-$1\").toLowerCase());\nconst camelizeRE = /-(\\w)/g;\nconst camelize = cacheStringFunction((str) => {\n return str.replace(camelizeRE, (_, c) => c ? c.toUpperCase() : \"\");\n});\n\nfunction promiseTimeout(ms, throwOnTimeout = false, reason = \"Timeout\") {\n return new Promise((resolve, reject) => {\n if (throwOnTimeout)\n setTimeout(() => reject(reason), ms);\n else\n setTimeout(resolve, ms);\n });\n}\nfunction identity(arg) {\n return arg;\n}\nfunction createSingletonPromise(fn) {\n let _promise;\n function wrapper() {\n if (!_promise)\n _promise = fn();\n return _promise;\n }\n wrapper.reset = async () => {\n const _prev = _promise;\n _promise = void 0;\n if (_prev)\n await _prev;\n };\n return wrapper;\n}\nfunction invoke(fn) {\n return fn();\n}\nfunction containsProp(obj, ...props) {\n return props.some((k) => k in obj);\n}\nfunction increaseWithUnit(target, delta) {\n var _a;\n if (typeof target === \"number\")\n return target + delta;\n const value = ((_a = target.match(/^-?\\d+\\.?\\d*/)) == null ? void 0 : _a[0]) || \"\";\n const unit = target.slice(value.length);\n const result = Number.parseFloat(value) + delta;\n if (Number.isNaN(result))\n return target;\n return result + unit;\n}\nfunction objectPick(obj, keys, omitUndefined = false) {\n return keys.reduce((n, k) => {\n if (k in obj) {\n if (!omitUndefined || obj[k] !== void 0)\n n[k] = obj[k];\n }\n return n;\n }, {});\n}\nfunction objectOmit(obj, keys, omitUndefined = false) {\n return Object.fromEntries(Object.entries(obj).filter(([key, value]) => {\n return (!omitUndefined || value !== void 0) && !keys.includes(key);\n }));\n}\nfunction objectEntries(obj) {\n return Object.entries(obj);\n}\nfunction getLifeCycleTarget(target) {\n return target || getCurrentInstance();\n}\n\nfunction toRef(...args) {\n if (args.length !== 1)\n return toRef$1(...args);\n const r = args[0];\n return typeof r === \"function\" ? readonly(customRef(() => ({ get: r, set: noop }))) : ref(r);\n}\nconst resolveRef = toRef;\n\nfunction reactivePick(obj, ...keys) {\n const flatKeys = keys.flat();\n const predicate = flatKeys[0];\n return reactiveComputed(() => typeof predicate === \"function\" ? Object.fromEntries(Object.entries(toRefs$1(obj)).filter(([k, v]) => predicate(toValue(v), k))) : Object.fromEntries(flatKeys.map((k) => [k, toRef(obj, k)])));\n}\n\nfunction refAutoReset(defaultValue, afterMs = 1e4) {\n return customRef((track, trigger) => {\n let value = toValue(defaultValue);\n let timer;\n const resetAfter = () => setTimeout(() => {\n value = toValue(defaultValue);\n trigger();\n }, toValue(afterMs));\n tryOnScopeDispose(() => {\n clearTimeout(timer);\n });\n return {\n get() {\n track();\n return value;\n },\n set(newValue) {\n value = newValue;\n trigger();\n clearTimeout(timer);\n timer = resetAfter();\n }\n };\n });\n}\n\nfunction useDebounceFn(fn, ms = 200, options = {}) {\n return createFilterWrapper(\n debounceFilter(ms, options),\n fn\n );\n}\n\nfunction refDebounced(value, ms = 200, options = {}) {\n const debounced = ref(value.value);\n const updater = useDebounceFn(() => {\n debounced.value = value.value;\n }, ms, options);\n watch(value, () => updater());\n return debounced;\n}\n\nfunction refDefault(source, defaultValue) {\n return computed({\n get() {\n var _a;\n return (_a = source.value) != null ? _a : defaultValue;\n },\n set(value) {\n source.value = value;\n }\n });\n}\n\nfunction useThrottleFn(fn, ms = 200, trailing = false, leading = true, rejectOnCancel = false) {\n return createFilterWrapper(\n throttleFilter(ms, trailing, leading, rejectOnCancel),\n fn\n );\n}\n\nfunction refThrottled(value, delay = 200, trailing = true, leading = true) {\n if (delay <= 0)\n return value;\n const throttled = ref(value.value);\n const updater = useThrottleFn(() => {\n throttled.value = value.value;\n }, delay, trailing, leading);\n watch(value, () => updater());\n return throttled;\n}\n\nfunction refWithControl(initial, options = {}) {\n let source = initial;\n let track;\n let trigger;\n const ref = customRef((_track, _trigger) => {\n track = _track;\n trigger = _trigger;\n return {\n get() {\n return get();\n },\n set(v) {\n set(v);\n }\n };\n });\n function get(tracking = true) {\n if (tracking)\n track();\n return source;\n }\n function set(value, triggering = true) {\n var _a, _b;\n if (value === source)\n return;\n const old = source;\n if (((_a = options.onBeforeChange) == null ? void 0 : _a.call(options, value, old)) === false)\n return;\n source = value;\n (_b = options.onChanged) == null ? void 0 : _b.call(options, value, old);\n if (triggering)\n trigger();\n }\n const untrackedGet = () => get(false);\n const silentSet = (v) => set(v, false);\n const peek = () => get(false);\n const lay = (v) => set(v, false);\n return extendRef(\n ref,\n {\n get,\n set,\n untrackedGet,\n silentSet,\n peek,\n lay\n },\n { enumerable: true }\n );\n}\nconst controlledRef = refWithControl;\n\nfunction set(...args) {\n if (args.length === 2) {\n const [ref, value] = args;\n ref.value = value;\n }\n if (args.length === 3) {\n const [target, key, value] = args;\n target[key] = value;\n }\n}\n\nfunction watchWithFilter(source, cb, options = {}) {\n const {\n eventFilter = bypassFilter,\n ...watchOptions\n } = options;\n return watch(\n source,\n createFilterWrapper(\n eventFilter,\n cb\n ),\n watchOptions\n );\n}\n\nfunction watchPausable(source, cb, options = {}) {\n const {\n eventFilter: filter,\n ...watchOptions\n } = options;\n const { eventFilter, pause, resume, isActive } = pausableFilter(filter);\n const stop = watchWithFilter(\n source,\n cb,\n {\n ...watchOptions,\n eventFilter\n }\n );\n return { stop, pause, resume, isActive };\n}\n\nfunction syncRef(left, right, ...[options]) {\n const {\n flush = \"sync\",\n deep = false,\n immediate = true,\n direction = \"both\",\n transform = {}\n } = options || {};\n const watchers = [];\n const transformLTR = \"ltr\" in transform && transform.ltr || ((v) => v);\n const transformRTL = \"rtl\" in transform && transform.rtl || ((v) => v);\n if (direction === \"both\" || direction === \"ltr\") {\n watchers.push(watchPausable(\n left,\n (newValue) => {\n watchers.forEach((w) => w.pause());\n right.value = transformLTR(newValue);\n watchers.forEach((w) => w.resume());\n },\n { flush, deep, immediate }\n ));\n }\n if (direction === \"both\" || direction === \"rtl\") {\n watchers.push(watchPausable(\n right,\n (newValue) => {\n watchers.forEach((w) => w.pause());\n left.value = transformRTL(newValue);\n watchers.forEach((w) => w.resume());\n },\n { flush, deep, immediate }\n ));\n }\n const stop = () => {\n watchers.forEach((w) => w.stop());\n };\n return stop;\n}\n\nfunction syncRefs(source, targets, options = {}) {\n const {\n flush = \"sync\",\n deep = false,\n immediate = true\n } = options;\n if (!Array.isArray(targets))\n targets = [targets];\n return watch(\n source,\n (newValue) => targets.forEach((target) => target.value = newValue),\n { flush, deep, immediate }\n );\n}\n\nfunction toRefs(objectRef, options = {}) {\n if (!isRef(objectRef))\n return toRefs$1(objectRef);\n const result = Array.isArray(objectRef.value) ? Array.from({ length: objectRef.value.length }) : {};\n for (const key in objectRef.value) {\n result[key] = customRef(() => ({\n get() {\n return objectRef.value[key];\n },\n set(v) {\n var _a;\n const replaceRef = (_a = toValue(options.replaceRef)) != null ? _a : true;\n if (replaceRef) {\n if (Array.isArray(objectRef.value)) {\n const copy = [...objectRef.value];\n copy[key] = v;\n objectRef.value = copy;\n } else {\n const newObject = { ...objectRef.value, [key]: v };\n Object.setPrototypeOf(newObject, Object.getPrototypeOf(objectRef.value));\n objectRef.value = newObject;\n }\n } else {\n objectRef.value[key] = v;\n }\n }\n }));\n }\n return result;\n}\n\nfunction tryOnBeforeMount(fn, sync = true, target) {\n const instance = getLifeCycleTarget(target);\n if (instance)\n onBeforeMount(fn, target);\n else if (sync)\n fn();\n else\n nextTick(fn);\n}\n\nfunction tryOnBeforeUnmount(fn, target) {\n const instance = getLifeCycleTarget(target);\n if (instance)\n onBeforeUnmount(fn, target);\n}\n\nfunction tryOnMounted(fn, sync = true, target) {\n const instance = getLifeCycleTarget();\n if (instance)\n onMounted(fn, target);\n else if (sync)\n fn();\n else\n nextTick(fn);\n}\n\nfunction tryOnUnmounted(fn, target) {\n const instance = getLifeCycleTarget(target);\n if (instance)\n onUnmounted(fn, target);\n}\n\nfunction createUntil(r, isNot = false) {\n function toMatch(condition, { flush = \"sync\", deep = false, timeout, throwOnTimeout } = {}) {\n let stop = null;\n const watcher = new Promise((resolve) => {\n stop = watch(\n r,\n (v) => {\n if (condition(v) !== isNot) {\n if (stop)\n stop();\n else\n nextTick(() => stop == null ? void 0 : stop());\n resolve(v);\n }\n },\n {\n flush,\n deep,\n immediate: true\n }\n );\n });\n const promises = [watcher];\n if (timeout != null) {\n promises.push(\n promiseTimeout(timeout, throwOnTimeout).then(() => toValue(r)).finally(() => stop == null ? void 0 : stop())\n );\n }\n return Promise.race(promises);\n }\n function toBe(value, options) {\n if (!isRef(value))\n return toMatch((v) => v === value, options);\n const { flush = \"sync\", deep = false, timeout, throwOnTimeout } = options != null ? options : {};\n let stop = null;\n const watcher = new Promise((resolve) => {\n stop = watch(\n [r, value],\n ([v1, v2]) => {\n if (isNot !== (v1 === v2)) {\n if (stop)\n stop();\n else\n nextTick(() => stop == null ? void 0 : stop());\n resolve(v1);\n }\n },\n {\n flush,\n deep,\n immediate: true\n }\n );\n });\n const promises = [watcher];\n if (timeout != null) {\n promises.push(\n promiseTimeout(timeout, throwOnTimeout).then(() => toValue(r)).finally(() => {\n stop == null ? void 0 : stop();\n return toValue(r);\n })\n );\n }\n return Promise.race(promises);\n }\n function toBeTruthy(options) {\n return toMatch((v) => Boolean(v), options);\n }\n function toBeNull(options) {\n return toBe(null, options);\n }\n function toBeUndefined(options) {\n return toBe(void 0, options);\n }\n function toBeNaN(options) {\n return toMatch(Number.isNaN, options);\n }\n function toContains(value, options) {\n return toMatch((v) => {\n const array = Array.from(v);\n return array.includes(value) || array.includes(toValue(value));\n }, options);\n }\n function changed(options) {\n return changedTimes(1, options);\n }\n function changedTimes(n = 1, options) {\n let count = -1;\n return toMatch(() => {\n count += 1;\n return count >= n;\n }, options);\n }\n if (Array.isArray(toValue(r))) {\n const instance = {\n toMatch,\n toContains,\n changed,\n changedTimes,\n get not() {\n return createUntil(r, !isNot);\n }\n };\n return instance;\n } else {\n const instance = {\n toMatch,\n toBe,\n toBeTruthy,\n toBeNull,\n toBeNaN,\n toBeUndefined,\n changed,\n changedTimes,\n get not() {\n return createUntil(r, !isNot);\n }\n };\n return instance;\n }\n}\nfunction until(r) {\n return createUntil(r);\n}\n\nfunction defaultComparator(value, othVal) {\n return value === othVal;\n}\nfunction useArrayDifference(...args) {\n var _a;\n const list = args[0];\n const values = args[1];\n let compareFn = (_a = args[2]) != null ? _a : defaultComparator;\n if (typeof compareFn === \"string\") {\n const key = compareFn;\n compareFn = (value, othVal) => value[key] === othVal[key];\n }\n return computed(() => toValue(list).filter((x) => toValue(values).findIndex((y) => compareFn(x, y)) === -1));\n}\n\nfunction useArrayEvery(list, fn) {\n return computed(() => toValue(list).every((element, index, array) => fn(toValue(element), index, array)));\n}\n\nfunction useArrayFilter(list, fn) {\n return computed(() => toValue(list).map((i) => toValue(i)).filter(fn));\n}\n\nfunction useArrayFind(list, fn) {\n return computed(() => toValue(\n toValue(list).find((element, index, array) => fn(toValue(element), index, array))\n ));\n}\n\nfunction useArrayFindIndex(list, fn) {\n return computed(() => toValue(list).findIndex((element, index, array) => fn(toValue(element), index, array)));\n}\n\nfunction findLast(arr, cb) {\n let index = arr.length;\n while (index-- > 0) {\n if (cb(arr[index], index, arr))\n return arr[index];\n }\n return void 0;\n}\nfunction useArrayFindLast(list, fn) {\n return computed(() => toValue(\n !Array.prototype.findLast ? findLast(toValue(list), (element, index, array) => fn(toValue(element), index, array)) : toValue(list).findLast((element, index, array) => fn(toValue(element), index, array))\n ));\n}\n\nfunction isArrayIncludesOptions(obj) {\n return isObject(obj) && containsProp(obj, \"formIndex\", \"comparator\");\n}\nfunction useArrayIncludes(...args) {\n var _a;\n const list = args[0];\n const value = args[1];\n let comparator = args[2];\n let formIndex = 0;\n if (isArrayIncludesOptions(comparator)) {\n formIndex = (_a = comparator.fromIndex) != null ? _a : 0;\n comparator = comparator.comparator;\n }\n if (typeof comparator === \"string\") {\n const key = comparator;\n comparator = (element, value2) => element[key] === toValue(value2);\n }\n comparator = comparator != null ? comparator : (element, value2) => element === toValue(value2);\n return computed(() => toValue(list).slice(formIndex).some((element, index, array) => comparator(\n toValue(element),\n toValue(value),\n index,\n toValue(array)\n )));\n}\n\nfunction useArrayJoin(list, separator) {\n return computed(() => toValue(list).map((i) => toValue(i)).join(toValue(separator)));\n}\n\nfunction useArrayMap(list, fn) {\n return computed(() => toValue(list).map((i) => toValue(i)).map(fn));\n}\n\nfunction useArrayReduce(list, reducer, ...args) {\n const reduceCallback = (sum, value, index) => reducer(toValue(sum), toValue(value), index);\n return computed(() => {\n const resolved = toValue(list);\n return args.length ? resolved.reduce(reduceCallback, typeof args[0] === \"function\" ? toValue(args[0]()) : toValue(args[0])) : resolved.reduce(reduceCallback);\n });\n}\n\nfunction useArraySome(list, fn) {\n return computed(() => toValue(list).some((element, index, array) => fn(toValue(element), index, array)));\n}\n\nfunction uniq(array) {\n return Array.from(new Set(array));\n}\nfunction uniqueElementsBy(array, fn) {\n return array.reduce((acc, v) => {\n if (!acc.some((x) => fn(v, x, array)))\n acc.push(v);\n return acc;\n }, []);\n}\nfunction useArrayUnique(list, compareFn) {\n return computed(() => {\n const resolvedList = toValue(list).map((element) => toValue(element));\n return compareFn ? uniqueElementsBy(resolvedList, compareFn) : uniq(resolvedList);\n });\n}\n\nfunction useCounter(initialValue = 0, options = {}) {\n let _initialValue = unref(initialValue);\n const count = ref(initialValue);\n const {\n max = Number.POSITIVE_INFINITY,\n min = Number.NEGATIVE_INFINITY\n } = options;\n const inc = (delta = 1) => count.value = Math.max(Math.min(max, count.value + delta), min);\n const dec = (delta = 1) => count.value = Math.min(Math.max(min, count.value - delta), max);\n const get = () => count.value;\n const set = (val) => count.value = Math.max(min, Math.min(max, val));\n const reset = (val = _initialValue) => {\n _initialValue = val;\n return set(val);\n };\n return { count, inc, dec, get, set, reset };\n}\n\nconst REGEX_PARSE = /^(\\d{4})[-/]?(\\d{1,2})?[-/]?(\\d{0,2})[T\\s]*(\\d{1,2})?:?(\\d{1,2})?:?(\\d{1,2})?[.:]?(\\d+)?$/i;\nconst REGEX_FORMAT = /[YMDHhms]o|\\[([^\\]]+)\\]|Y{1,4}|M{1,4}|D{1,2}|d{1,4}|H{1,2}|h{1,2}|a{1,2}|A{1,2}|m{1,2}|s{1,2}|Z{1,2}|SSS/g;\nfunction defaultMeridiem(hours, minutes, isLowercase, hasPeriod) {\n let m = hours < 12 ? \"AM\" : \"PM\";\n if (hasPeriod)\n m = m.split(\"\").reduce((acc, curr) => acc += `${curr}.`, \"\");\n return isLowercase ? m.toLowerCase() : m;\n}\nfunction formatOrdinal(num) {\n const suffixes = [\"th\", \"st\", \"nd\", \"rd\"];\n const v = num % 100;\n return num + (suffixes[(v - 20) % 10] || suffixes[v] || suffixes[0]);\n}\nfunction formatDate(date, formatStr, options = {}) {\n var _a;\n const years = date.getFullYear();\n const month = date.getMonth();\n const days = date.getDate();\n const hours = date.getHours();\n const minutes = date.getMinutes();\n const seconds = date.getSeconds();\n const milliseconds = date.getMilliseconds();\n const day = date.getDay();\n const meridiem = (_a = options.customMeridiem) != null ? _a : defaultMeridiem;\n const matches = {\n Yo: () => formatOrdinal(years),\n YY: () => String(years).slice(-2),\n YYYY: () => years,\n M: () => month + 1,\n Mo: () => formatOrdinal(month + 1),\n MM: () => `${month + 1}`.padStart(2, \"0\"),\n MMM: () => date.toLocaleDateString(toValue(options.locales), { month: \"short\" }),\n MMMM: () => date.toLocaleDateString(toValue(options.locales), { month: \"long\" }),\n D: () => String(days),\n Do: () => formatOrdinal(days),\n DD: () => `${days}`.padStart(2, \"0\"),\n H: () => String(hours),\n Ho: () => formatOrdinal(hours),\n HH: () => `${hours}`.padStart(2, \"0\"),\n h: () => `${hours % 12 || 12}`.padStart(1, \"0\"),\n ho: () => formatOrdinal(hours % 12 || 12),\n hh: () => `${hours % 12 || 12}`.padStart(2, \"0\"),\n m: () => String(minutes),\n mo: () => formatOrdinal(minutes),\n mm: () => `${minutes}`.padStart(2, \"0\"),\n s: () => String(seconds),\n so: () => formatOrdinal(seconds),\n ss: () => `${seconds}`.padStart(2, \"0\"),\n SSS: () => `${milliseconds}`.padStart(3, \"0\"),\n d: () => day,\n dd: () => date.toLocaleDateString(toValue(options.locales), { weekday: \"narrow\" }),\n ddd: () => date.toLocaleDateString(toValue(options.locales), { weekday: \"short\" }),\n dddd: () => date.toLocaleDateString(toValue(options.locales), { weekday: \"long\" }),\n A: () => meridiem(hours, minutes),\n AA: () => meridiem(hours, minutes, false, true),\n a: () => meridiem(hours, minutes, true),\n aa: () => meridiem(hours, minutes, true, true)\n };\n return formatStr.replace(REGEX_FORMAT, (match, $1) => {\n var _a2, _b;\n return (_b = $1 != null ? $1 : (_a2 = matches[match]) == null ? void 0 : _a2.call(matches)) != null ? _b : match;\n });\n}\nfunction normalizeDate(date) {\n if (date === null)\n return new Date(Number.NaN);\n if (date === void 0)\n return /* @__PURE__ */ new Date();\n if (date instanceof Date)\n return new Date(date);\n if (typeof date === \"string\" && !/Z$/i.test(date)) {\n const d = date.match(REGEX_PARSE);\n if (d) {\n const m = d[2] - 1 || 0;\n const ms = (d[7] || \"0\").substring(0, 3);\n return new Date(d[1], m, d[3] || 1, d[4] || 0, d[5] || 0, d[6] || 0, ms);\n }\n }\n return new Date(date);\n}\nfunction useDateFormat(date, formatStr = \"HH:mm:ss\", options = {}) {\n return computed(() => formatDate(normalizeDate(toValue(date)), toValue(formatStr), options));\n}\n\nfunction useIntervalFn(cb, interval = 1e3, options = {}) {\n const {\n immediate = true,\n immediateCallback = false\n } = options;\n let timer = null;\n const isActive = ref(false);\n function clean() {\n if (timer) {\n clearInterval(timer);\n timer = null;\n }\n }\n function pause() {\n isActive.value = false;\n clean();\n }\n function resume() {\n const intervalValue = toValue(interval);\n if (intervalValue <= 0)\n return;\n isActive.value = true;\n if (immediateCallback)\n cb();\n clean();\n if (isActive.value)\n timer = setInterval(cb, intervalValue);\n }\n if (immediate && isClient)\n resume();\n if (isRef(interval) || typeof interval === \"function\") {\n const stopWatch = watch(interval, () => {\n if (isActive.value && isClient)\n resume();\n });\n tryOnScopeDispose(stopWatch);\n }\n tryOnScopeDispose(pause);\n return {\n isActive,\n pause,\n resume\n };\n}\n\nfunction useInterval(interval = 1e3, options = {}) {\n const {\n controls: exposeControls = false,\n immediate = true,\n callback\n } = options;\n const counter = ref(0);\n const update = () => counter.value += 1;\n const reset = () => {\n counter.value = 0;\n };\n const controls = useIntervalFn(\n callback ? () => {\n update();\n callback(counter.value);\n } : update,\n interval,\n { immediate }\n );\n if (exposeControls) {\n return {\n counter,\n reset,\n ...controls\n };\n } else {\n return counter;\n }\n}\n\nfunction useLastChanged(source, options = {}) {\n var _a;\n const ms = ref((_a = options.initialValue) != null ? _a : null);\n watch(\n source,\n () => ms.value = timestamp(),\n options\n );\n return ms;\n}\n\nfunction useTimeoutFn(cb, interval, options = {}) {\n const {\n immediate = true\n } = options;\n const isPending = ref(false);\n let timer = null;\n function clear() {\n if (timer) {\n clearTimeout(timer);\n timer = null;\n }\n }\n function stop() {\n isPending.value = false;\n clear();\n }\n function start(...args) {\n clear();\n isPending.value = true;\n timer = setTimeout(() => {\n isPending.value = false;\n timer = null;\n cb(...args);\n }, toValue(interval));\n }\n if (immediate) {\n isPending.value = true;\n if (isClient)\n start();\n }\n tryOnScopeDispose(stop);\n return {\n isPending: readonly(isPending),\n start,\n stop\n };\n}\n\nfunction useTimeout(interval = 1e3, options = {}) {\n const {\n controls: exposeControls = false,\n callback\n } = options;\n const controls = useTimeoutFn(\n callback != null ? callback : noop,\n interval,\n options\n );\n const ready = computed(() => !controls.isPending.value);\n if (exposeControls) {\n return {\n ready,\n ...controls\n };\n } else {\n return ready;\n }\n}\n\nfunction useToNumber(value, options = {}) {\n const {\n method = \"parseFloat\",\n radix,\n nanToZero\n } = options;\n return computed(() => {\n let resolved = toValue(value);\n if (typeof resolved === \"string\")\n resolved = Number[method](resolved, radix);\n if (nanToZero && Number.isNaN(resolved))\n resolved = 0;\n return resolved;\n });\n}\n\nfunction useToString(value) {\n return computed(() => `${toValue(value)}`);\n}\n\nfunction useToggle(initialValue = false, options = {}) {\n const {\n truthyValue = true,\n falsyValue = false\n } = options;\n const valueIsRef = isRef(initialValue);\n const _value = ref(initialValue);\n function toggle(value) {\n if (arguments.length) {\n _value.value = value;\n return _value.value;\n } else {\n const truthy = toValue(truthyValue);\n _value.value = _value.value === truthy ? toValue(falsyValue) : truthy;\n return _value.value;\n }\n }\n if (valueIsRef)\n return toggle;\n else\n return [_value, toggle];\n}\n\nfunction watchArray(source, cb, options) {\n let oldList = (options == null ? void 0 : options.immediate) ? [] : [...source instanceof Function ? source() : Array.isArray(source) ? source : toValue(source)];\n return watch(source, (newList, _, onCleanup) => {\n const oldListRemains = Array.from({ length: oldList.length });\n const added = [];\n for (const obj of newList) {\n let found = false;\n for (let i = 0; i < oldList.length; i++) {\n if (!oldListRemains[i] && obj === oldList[i]) {\n oldListRemains[i] = true;\n found = true;\n break;\n }\n }\n if (!found)\n added.push(obj);\n }\n const removed = oldList.filter((_2, i) => !oldListRemains[i]);\n cb(newList, oldList, added, removed, onCleanup);\n oldList = [...newList];\n }, options);\n}\n\nfunction watchAtMost(source, cb, options) {\n const {\n count,\n ...watchOptions\n } = options;\n const current = ref(0);\n const stop = watchWithFilter(\n source,\n (...args) => {\n current.value += 1;\n if (current.value >= toValue(count))\n nextTick(() => stop());\n cb(...args);\n },\n watchOptions\n );\n return { count: current, stop };\n}\n\nfunction watchDebounced(source, cb, options = {}) {\n const {\n debounce = 0,\n maxWait = void 0,\n ...watchOptions\n } = options;\n return watchWithFilter(\n source,\n cb,\n {\n ...watchOptions,\n eventFilter: debounceFilter(debounce, { maxWait })\n }\n );\n}\n\nfunction watchDeep(source, cb, options) {\n return watch(\n source,\n cb,\n {\n ...options,\n deep: true\n }\n );\n}\n\nfunction watchIgnorable(source, cb, options = {}) {\n const {\n eventFilter = bypassFilter,\n ...watchOptions\n } = options;\n const filteredCb = createFilterWrapper(\n eventFilter,\n cb\n );\n let ignoreUpdates;\n let ignorePrevAsyncUpdates;\n let stop;\n if (watchOptions.flush === \"sync\") {\n const ignore = ref(false);\n ignorePrevAsyncUpdates = () => {\n };\n ignoreUpdates = (updater) => {\n ignore.value = true;\n updater();\n ignore.value = false;\n };\n stop = watch(\n source,\n (...args) => {\n if (!ignore.value)\n filteredCb(...args);\n },\n watchOptions\n );\n } else {\n const disposables = [];\n const ignoreCounter = ref(0);\n const syncCounter = ref(0);\n ignorePrevAsyncUpdates = () => {\n ignoreCounter.value = syncCounter.value;\n };\n disposables.push(\n watch(\n source,\n () => {\n syncCounter.value++;\n },\n { ...watchOptions, flush: \"sync\" }\n )\n );\n ignoreUpdates = (updater) => {\n const syncCounterPrev = syncCounter.value;\n updater();\n ignoreCounter.value += syncCounter.value - syncCounterPrev;\n };\n disposables.push(\n watch(\n source,\n (...args) => {\n const ignore = ignoreCounter.value > 0 && ignoreCounter.value === syncCounter.value;\n ignoreCounter.value = 0;\n syncCounter.value = 0;\n if (ignore)\n return;\n filteredCb(...args);\n },\n watchOptions\n )\n );\n stop = () => {\n disposables.forEach((fn) => fn());\n };\n }\n return { stop, ignoreUpdates, ignorePrevAsyncUpdates };\n}\n\nfunction watchImmediate(source, cb, options) {\n return watch(\n source,\n cb,\n {\n ...options,\n immediate: true\n }\n );\n}\n\nfunction watchOnce(source, cb, options) {\n const stop = watch(source, (...args) => {\n nextTick(() => stop());\n return cb(...args);\n }, options);\n return stop;\n}\n\nfunction watchThrottled(source, cb, options = {}) {\n const {\n throttle = 0,\n trailing = true,\n leading = true,\n ...watchOptions\n } = options;\n return watchWithFilter(\n source,\n cb,\n {\n ...watchOptions,\n eventFilter: throttleFilter(throttle, trailing, leading)\n }\n );\n}\n\nfunction watchTriggerable(source, cb, options = {}) {\n let cleanupFn;\n function onEffect() {\n if (!cleanupFn)\n return;\n const fn = cleanupFn;\n cleanupFn = void 0;\n fn();\n }\n function onCleanup(callback) {\n cleanupFn = callback;\n }\n const _cb = (value, oldValue) => {\n onEffect();\n return cb(value, oldValue, onCleanup);\n };\n const res = watchIgnorable(source, _cb, options);\n const { ignoreUpdates } = res;\n const trigger = () => {\n let res2;\n ignoreUpdates(() => {\n res2 = _cb(getWatchSources(source), getOldValue(source));\n });\n return res2;\n };\n return {\n ...res,\n trigger\n };\n}\nfunction getWatchSources(sources) {\n if (isReactive(sources))\n return sources;\n if (Array.isArray(sources))\n return sources.map((item) => toValue(item));\n return toValue(sources);\n}\nfunction getOldValue(source) {\n return Array.isArray(source) ? source.map(() => void 0) : void 0;\n}\n\nfunction whenever(source, cb, options) {\n const stop = watch(\n source,\n (v, ov, onInvalidate) => {\n if (v) {\n if (options == null ? void 0 : options.once)\n nextTick(() => stop());\n cb(v, ov, onInvalidate);\n }\n },\n {\n ...options,\n once: false\n }\n );\n return stop;\n}\n\nexport { assert, refAutoReset as autoResetRef, bypassFilter, camelize, clamp, computedEager, computedWithControl, containsProp, computedWithControl as controlledComputed, controlledRef, createEventHook, createFilterWrapper, createGlobalState, createInjectionState, reactify as createReactiveFn, createSharedComposable, createSingletonPromise, debounceFilter, refDebounced as debouncedRef, watchDebounced as debouncedWatch, computedEager as eagerComputed, extendRef, formatDate, get, getLifeCycleTarget, hasOwn, hyphenate, identity, watchIgnorable as ignorableWatch, increaseWithUnit, injectLocal, invoke, isClient, isDef, isDefined, isIOS, isObject, isWorker, makeDestructurable, noop, normalizeDate, notNullish, now, objectEntries, objectOmit, objectPick, pausableFilter, watchPausable as pausableWatch, promiseTimeout, provideLocal, rand, reactify, reactifyObject, reactiveComputed, reactiveOmit, reactivePick, refAutoReset, refDebounced, refDefault, refThrottled, refWithControl, resolveRef, resolveUnref, set, syncRef, syncRefs, throttleFilter, refThrottled as throttledRef, watchThrottled as throttledWatch, timestamp, toReactive, toRef, toRefs, toValue, tryOnBeforeMount, tryOnBeforeUnmount, tryOnMounted, tryOnScopeDispose, tryOnUnmounted, until, useArrayDifference, useArrayEvery, useArrayFilter, useArrayFind, useArrayFindIndex, useArrayFindLast, useArrayIncludes, useArrayJoin, useArrayMap, useArrayReduce, useArraySome, useArrayUnique, useCounter, useDateFormat, refDebounced as useDebounce, useDebounceFn, useInterval, useIntervalFn, useLastChanged, refThrottled as useThrottle, useThrottleFn, useTimeout, useTimeoutFn, useToNumber, useToString, useToggle, watchArray, watchAtMost, watchDebounced, watchDeep, watchIgnorable, watchImmediate, watchOnce, watchPausable, watchThrottled, watchTriggerable, watchWithFilter, whenever };\n","import { noop, makeDestructurable, camelize, toValue, isClient, isObject, tryOnScopeDispose, isIOS, tryOnMounted, notNullish, objectOmit, promiseTimeout, until, increaseWithUnit, objectEntries, createSingletonPromise, useTimeoutFn, pausableWatch, toRef, createEventHook, computedWithControl, timestamp, pausableFilter, watchIgnorable, debounceFilter, createFilterWrapper, bypassFilter, toRefs, useIntervalFn, containsProp, hasOwn, throttleFilter, useDebounceFn, useThrottleFn, tryOnUnmounted, clamp, syncRef, objectPick, watchWithFilter, tryOnBeforeUnmount, identity, isDef, whenever, isWorker } from '@vueuse/shared';\nexport * from '@vueuse/shared';\nimport { isRef, ref, shallowRef, watchEffect, computed, inject, defineComponent, h, TransitionGroup, shallowReactive, Fragment, watch, getCurrentInstance, customRef, onUpdated, onMounted, readonly, reactive, toRaw, nextTick, markRaw, unref, getCurrentScope, isReadonly, onBeforeUpdate } from 'vue';\n\nfunction computedAsync(evaluationCallback, initialState, optionsOrRef) {\n let options;\n if (isRef(optionsOrRef)) {\n options = {\n evaluating: optionsOrRef\n };\n } else {\n options = optionsOrRef || {};\n }\n const {\n lazy = false,\n evaluating = void 0,\n shallow = true,\n onError = noop\n } = options;\n const started = ref(!lazy);\n const current = shallow ? shallowRef(initialState) : ref(initialState);\n let counter = 0;\n watchEffect(async (onInvalidate) => {\n if (!started.value)\n return;\n counter++;\n const counterAtBeginning = counter;\n let hasFinished = false;\n if (evaluating) {\n Promise.resolve().then(() => {\n evaluating.value = true;\n });\n }\n try {\n const result = await evaluationCallback((cancelCallback) => {\n onInvalidate(() => {\n if (evaluating)\n evaluating.value = false;\n if (!hasFinished)\n cancelCallback();\n });\n });\n if (counterAtBeginning === counter)\n current.value = result;\n } catch (e) {\n onError(e);\n } finally {\n if (evaluating && counterAtBeginning === counter)\n evaluating.value = false;\n hasFinished = true;\n }\n });\n if (lazy) {\n return computed(() => {\n started.value = true;\n return current.value;\n });\n } else {\n return current;\n }\n}\n\nfunction computedInject(key, options, defaultSource, treatDefaultAsFactory) {\n let source = inject(key);\n if (defaultSource)\n source = inject(key, defaultSource);\n if (treatDefaultAsFactory)\n source = inject(key, defaultSource, treatDefaultAsFactory);\n if (typeof options === \"function\") {\n return computed((ctx) => options(source, ctx));\n } else {\n return computed({\n get: (ctx) => options.get(source, ctx),\n set: options.set\n });\n }\n}\n\nfunction createReusableTemplate(options = {}) {\n const {\n inheritAttrs = true\n } = options;\n const render = shallowRef();\n const define = /* #__PURE__ */ defineComponent({\n setup(_, { slots }) {\n return () => {\n render.value = slots.default;\n };\n }\n });\n const reuse = /* #__PURE__ */ defineComponent({\n inheritAttrs,\n setup(_, { attrs, slots }) {\n return () => {\n var _a;\n if (!render.value && process.env.NODE_ENV !== \"production\")\n throw new Error(\"[VueUse] Failed to find the definition of reusable template\");\n const vnode = (_a = render.value) == null ? void 0 : _a.call(render, { ...keysToCamelKebabCase(attrs), $slots: slots });\n return inheritAttrs && (vnode == null ? void 0 : vnode.length) === 1 ? vnode[0] : vnode;\n };\n }\n });\n return makeDestructurable(\n { define, reuse },\n [define, reuse]\n );\n}\nfunction keysToCamelKebabCase(obj) {\n const newObj = {};\n for (const key in obj)\n newObj[camelize(key)] = obj[key];\n return newObj;\n}\n\nfunction createTemplatePromise(options = {}) {\n let index = 0;\n const instances = ref([]);\n function create(...args) {\n const props = shallowReactive({\n key: index++,\n args,\n promise: void 0,\n resolve: () => {\n },\n reject: () => {\n },\n isResolving: false,\n options\n });\n instances.value.push(props);\n props.promise = new Promise((_resolve, _reject) => {\n props.resolve = (v) => {\n props.isResolving = true;\n return _resolve(v);\n };\n props.reject = _reject;\n }).finally(() => {\n props.promise = void 0;\n const index2 = instances.value.indexOf(props);\n if (index2 !== -1)\n instances.value.splice(index2, 1);\n });\n return props.promise;\n }\n function start(...args) {\n if (options.singleton && instances.value.length > 0)\n return instances.value[0].promise;\n return create(...args);\n }\n const component = /* #__PURE__ */ defineComponent((_, { slots }) => {\n const renderList = () => instances.value.map((props) => {\n var _a;\n return h(Fragment, { key: props.key }, (_a = slots.default) == null ? void 0 : _a.call(slots, props));\n });\n if (options.transition)\n return () => h(TransitionGroup, options.transition, renderList);\n return renderList;\n });\n component.start = start;\n return component;\n}\n\nfunction createUnrefFn(fn) {\n return function(...args) {\n return fn.apply(this, args.map((i) => toValue(i)));\n };\n}\n\nconst defaultWindow = isClient ? window : void 0;\nconst defaultDocument = isClient ? window.document : void 0;\nconst defaultNavigator = isClient ? window.navigator : void 0;\nconst defaultLocation = isClient ? window.location : void 0;\n\nfunction unrefElement(elRef) {\n var _a;\n const plain = toValue(elRef);\n return (_a = plain == null ? void 0 : plain.$el) != null ? _a : plain;\n}\n\nfunction useEventListener(...args) {\n let target;\n let events;\n let listeners;\n let options;\n if (typeof args[0] === \"string\" || Array.isArray(args[0])) {\n [events, listeners, options] = args;\n target = defaultWindow;\n } else {\n [target, events, listeners, options] = args;\n }\n if (!target)\n return noop;\n if (!Array.isArray(events))\n events = [events];\n if (!Array.isArray(listeners))\n listeners = [listeners];\n const cleanups = [];\n const cleanup = () => {\n cleanups.forEach((fn) => fn());\n cleanups.length = 0;\n };\n const register = (el, event, listener, options2) => {\n el.addEventListener(event, listener, options2);\n return () => el.removeEventListener(event, listener, options2);\n };\n const stopWatch = watch(\n () => [unrefElement(target), toValue(options)],\n ([el, options2]) => {\n cleanup();\n if (!el)\n return;\n const optionsClone = isObject(options2) ? { ...options2 } : options2;\n cleanups.push(\n ...events.flatMap((event) => {\n return listeners.map((listener) => register(el, event, listener, optionsClone));\n })\n );\n },\n { immediate: true, flush: \"post\" }\n );\n const stop = () => {\n stopWatch();\n cleanup();\n };\n tryOnScopeDispose(stop);\n return stop;\n}\n\nlet _iOSWorkaround = false;\nfunction onClickOutside(target, handler, options = {}) {\n const { window = defaultWindow, ignore = [], capture = true, detectIframe = false } = options;\n if (!window)\n return noop;\n if (isIOS && !_iOSWorkaround) {\n _iOSWorkaround = true;\n Array.from(window.document.body.children).forEach((el) => el.addEventListener(\"click\", noop));\n window.document.documentElement.addEventListener(\"click\", noop);\n }\n let shouldListen = true;\n const shouldIgnore = (event) => {\n return toValue(ignore).some((target2) => {\n if (typeof target2 === \"string\") {\n return Array.from(window.document.querySelectorAll(target2)).some((el) => el === event.target || event.composedPath().includes(el));\n } else {\n const el = unrefElement(target2);\n return el && (event.target === el || event.composedPath().includes(el));\n }\n });\n };\n function hasMultipleRoots(target2) {\n const vm = toValue(target2);\n return vm && vm.$.subTree.shapeFlag === 16;\n }\n function checkMultipleRoots(target2, event) {\n const vm = toValue(target2);\n const children = vm.$.subTree && vm.$.subTree.children;\n if (children == null || !Array.isArray(children))\n return false;\n return children.some((child) => child.el === event.target || event.composedPath().includes(child.el));\n }\n const listener = (event) => {\n const el = unrefElement(target);\n if (event.target == null)\n return;\n if (!(el instanceof Element) && hasMultipleRoots(target) && checkMultipleRoots(target, event))\n return;\n if (!el || el === event.target || event.composedPath().includes(el))\n return;\n if (event.detail === 0)\n shouldListen = !shouldIgnore(event);\n if (!shouldListen) {\n shouldListen = true;\n return;\n }\n handler(event);\n };\n let isProcessingClick = false;\n const cleanup = [\n useEventListener(window, \"click\", (event) => {\n if (!isProcessingClick) {\n isProcessingClick = true;\n setTimeout(() => {\n isProcessingClick = false;\n }, 0);\n listener(event);\n }\n }, { passive: true, capture }),\n useEventListener(window, \"pointerdown\", (e) => {\n const el = unrefElement(target);\n shouldListen = !shouldIgnore(e) && !!(el && !e.composedPath().includes(el));\n }, { passive: true }),\n detectIframe && useEventListener(window, \"blur\", (event) => {\n setTimeout(() => {\n var _a;\n const el = unrefElement(target);\n if (((_a = window.document.activeElement) == null ? void 0 : _a.tagName) === \"IFRAME\" && !(el == null ? void 0 : el.contains(window.document.activeElement))) {\n handler(event);\n }\n }, 0);\n })\n ].filter(Boolean);\n const stop = () => cleanup.forEach((fn) => fn());\n return stop;\n}\n\nfunction createKeyPredicate(keyFilter) {\n if (typeof keyFilter === \"function\")\n return keyFilter;\n else if (typeof keyFilter === \"string\")\n return (event) => event.key === keyFilter;\n else if (Array.isArray(keyFilter))\n return (event) => keyFilter.includes(event.key);\n return () => true;\n}\nfunction onKeyStroke(...args) {\n let key;\n let handler;\n let options = {};\n if (args.length === 3) {\n key = args[0];\n handler = args[1];\n options = args[2];\n } else if (args.length === 2) {\n if (typeof args[1] === \"object\") {\n key = true;\n handler = args[0];\n options = args[1];\n } else {\n key = args[0];\n handler = args[1];\n }\n } else {\n key = true;\n handler = args[0];\n }\n const {\n target = defaultWindow,\n eventName = \"keydown\",\n passive = false,\n dedupe = false\n } = options;\n const predicate = createKeyPredicate(key);\n const listener = (e) => {\n if (e.repeat && toValue(dedupe))\n return;\n if (predicate(e))\n handler(e);\n };\n return useEventListener(target, eventName, listener, passive);\n}\nfunction onKeyDown(key, handler, options = {}) {\n return onKeyStroke(key, handler, { ...options, eventName: \"keydown\" });\n}\nfunction onKeyPressed(key, handler, options = {}) {\n return onKeyStroke(key, handler, { ...options, eventName: \"keypress\" });\n}\nfunction onKeyUp(key, handler, options = {}) {\n return onKeyStroke(key, handler, { ...options, eventName: \"keyup\" });\n}\n\nconst DEFAULT_DELAY = 500;\nconst DEFAULT_THRESHOLD = 10;\nfunction onLongPress(target, handler, options) {\n var _a, _b;\n const elementRef = computed(() => unrefElement(target));\n let timeout;\n let posStart;\n let startTimestamp;\n let hasLongPressed = false;\n function clear() {\n if (timeout) {\n clearTimeout(timeout);\n timeout = void 0;\n }\n posStart = void 0;\n startTimestamp = void 0;\n hasLongPressed = false;\n }\n function onRelease(ev) {\n var _a2, _b2, _c;\n const [_startTimestamp, _posStart, _hasLongPressed] = [startTimestamp, posStart, hasLongPressed];\n clear();\n if (!(options == null ? void 0 : options.onMouseUp) || !_posStart || !_startTimestamp)\n return;\n if (((_a2 = options == null ? void 0 : options.modifiers) == null ? void 0 : _a2.self) && ev.target !== elementRef.value)\n return;\n if ((_b2 = options == null ? void 0 : options.modifiers) == null ? void 0 : _b2.prevent)\n ev.preventDefault();\n if ((_c = options == null ? void 0 : options.modifiers) == null ? void 0 : _c.stop)\n ev.stopPropagation();\n const dx = ev.x - _posStart.x;\n const dy = ev.y - _posStart.y;\n const distance = Math.sqrt(dx * dx + dy * dy);\n options.onMouseUp(ev.timeStamp - _startTimestamp, distance, _hasLongPressed);\n }\n function onDown(ev) {\n var _a2, _b2, _c, _d;\n if (((_a2 = options == null ? void 0 : options.modifiers) == null ? void 0 : _a2.self) && ev.target !== elementRef.value)\n return;\n clear();\n if ((_b2 = options == null ? void 0 : options.modifiers) == null ? void 0 : _b2.prevent)\n ev.preventDefault();\n if ((_c = options == null ? void 0 : options.modifiers) == null ? void 0 : _c.stop)\n ev.stopPropagation();\n posStart = {\n x: ev.x,\n y: ev.y\n };\n startTimestamp = ev.timeStamp;\n timeout = setTimeout(\n () => {\n hasLongPressed = true;\n handler(ev);\n },\n (_d = options == null ? void 0 : options.delay) != null ? _d : DEFAULT_DELAY\n );\n }\n function onMove(ev) {\n var _a2, _b2, _c, _d;\n if (((_a2 = options == null ? void 0 : options.modifiers) == null ? void 0 : _a2.self) && ev.target !== elementRef.value)\n return;\n if (!posStart || (options == null ? void 0 : options.distanceThreshold) === false)\n return;\n if ((_b2 = options == null ? void 0 : options.modifiers) == null ? void 0 : _b2.prevent)\n ev.preventDefault();\n if ((_c = options == null ? void 0 : options.modifiers) == null ? void 0 : _c.stop)\n ev.stopPropagation();\n const dx = ev.x - posStart.x;\n const dy = ev.y - posStart.y;\n const distance = Math.sqrt(dx * dx + dy * dy);\n if (distance >= ((_d = options == null ? void 0 : options.distanceThreshold) != null ? _d : DEFAULT_THRESHOLD))\n clear();\n }\n const listenerOptions = {\n capture: (_a = options == null ? void 0 : options.modifiers) == null ? void 0 : _a.capture,\n once: (_b = options == null ? void 0 : options.modifiers) == null ? void 0 : _b.once\n };\n const cleanup = [\n useEventListener(elementRef, \"pointerdown\", onDown, listenerOptions),\n useEventListener(elementRef, \"pointermove\", onMove, listenerOptions),\n useEventListener(elementRef, [\"pointerup\", \"pointerleave\"], onRelease, listenerOptions)\n ];\n const stop = () => cleanup.forEach((fn) => fn());\n return stop;\n}\n\nfunction isFocusedElementEditable() {\n const { activeElement, body } = document;\n if (!activeElement)\n return false;\n if (activeElement === body)\n return false;\n switch (activeElement.tagName) {\n case \"INPUT\":\n case \"TEXTAREA\":\n return true;\n }\n return activeElement.hasAttribute(\"contenteditable\");\n}\nfunction isTypedCharValid({\n keyCode,\n metaKey,\n ctrlKey,\n altKey\n}) {\n if (metaKey || ctrlKey || altKey)\n return false;\n if (keyCode >= 48 && keyCode <= 57)\n return true;\n if (keyCode >= 65 && keyCode <= 90)\n return true;\n if (keyCode >= 97 && keyCode <= 122)\n return true;\n return false;\n}\nfunction onStartTyping(callback, options = {}) {\n const { document: document2 = defaultDocument } = options;\n const keydown = (event) => {\n if (!isFocusedElementEditable() && isTypedCharValid(event)) {\n callback(event);\n }\n };\n if (document2)\n useEventListener(document2, \"keydown\", keydown, { passive: true });\n}\n\nfunction templateRef(key, initialValue = null) {\n const instance = getCurrentInstance();\n let _trigger = () => {\n };\n const element = customRef((track, trigger) => {\n _trigger = trigger;\n return {\n get() {\n var _a, _b;\n track();\n return (_b = (_a = instance == null ? void 0 : instance.proxy) == null ? void 0 : _a.$refs[key]) != null ? _b : initialValue;\n },\n set() {\n }\n };\n });\n tryOnMounted(_trigger);\n onUpdated(_trigger);\n return element;\n}\n\nfunction useMounted() {\n const isMounted = ref(false);\n const instance = getCurrentInstance();\n if (instance) {\n onMounted(() => {\n isMounted.value = true;\n }, instance);\n }\n return isMounted;\n}\n\nfunction useSupported(callback) {\n const isMounted = useMounted();\n return computed(() => {\n isMounted.value;\n return Boolean(callback());\n });\n}\n\nfunction useMutationObserver(target, callback, options = {}) {\n const { window = defaultWindow, ...mutationOptions } = options;\n let observer;\n const isSupported = useSupported(() => window && \"MutationObserver\" in window);\n const cleanup = () => {\n if (observer) {\n observer.disconnect();\n observer = void 0;\n }\n };\n const targets = computed(() => {\n const value = toValue(target);\n const items = (Array.isArray(value) ? value : [value]).map(unrefElement).filter(notNullish);\n return new Set(items);\n });\n const stopWatch = watch(\n () => targets.value,\n (targets2) => {\n cleanup();\n if (isSupported.value && targets2.size) {\n observer = new MutationObserver(callback);\n targets2.forEach((el) => observer.observe(el, mutationOptions));\n }\n },\n { immediate: true, flush: \"post\" }\n );\n const takeRecords = () => {\n return observer == null ? void 0 : observer.takeRecords();\n };\n const stop = () => {\n stopWatch();\n cleanup();\n };\n tryOnScopeDispose(stop);\n return {\n isSupported,\n stop,\n takeRecords\n };\n}\n\nfunction useActiveElement(options = {}) {\n var _a;\n const {\n window = defaultWindow,\n deep = true,\n triggerOnRemoval = false\n } = options;\n const document = (_a = options.document) != null ? _a : window == null ? void 0 : window.document;\n const getDeepActiveElement = () => {\n var _a2;\n let element = document == null ? void 0 : document.activeElement;\n if (deep) {\n while (element == null ? void 0 : element.shadowRoot)\n element = (_a2 = element == null ? void 0 : element.shadowRoot) == null ? void 0 : _a2.activeElement;\n }\n return element;\n };\n const activeElement = ref();\n const trigger = () => {\n activeElement.value = getDeepActiveElement();\n };\n if (window) {\n useEventListener(window, \"blur\", (event) => {\n if (event.relatedTarget !== null)\n return;\n trigger();\n }, true);\n useEventListener(window, \"focus\", trigger, true);\n }\n if (triggerOnRemoval) {\n useMutationObserver(document, (mutations) => {\n mutations.filter((m) => m.removedNodes.length).map((n) => Array.from(n.removedNodes)).flat().forEach((node) => {\n if (node === activeElement.value)\n trigger();\n });\n }, {\n childList: true,\n subtree: true\n });\n }\n trigger();\n return activeElement;\n}\n\nfunction useRafFn(fn, options = {}) {\n const {\n immediate = true,\n fpsLimit = void 0,\n window = defaultWindow\n } = options;\n const isActive = ref(false);\n const intervalLimit = fpsLimit ? 1e3 / fpsLimit : null;\n let previousFrameTimestamp = 0;\n let rafId = null;\n function loop(timestamp) {\n if (!isActive.value || !window)\n return;\n if (!previousFrameTimestamp)\n previousFrameTimestamp = timestamp;\n const delta = timestamp - previousFrameTimestamp;\n if (intervalLimit && delta < intervalLimit) {\n rafId = window.requestAnimationFrame(loop);\n return;\n }\n previousFrameTimestamp = timestamp;\n fn({ delta, timestamp });\n rafId = window.requestAnimationFrame(loop);\n }\n function resume() {\n if (!isActive.value && window) {\n isActive.value = true;\n previousFrameTimestamp = 0;\n rafId = window.requestAnimationFrame(loop);\n }\n }\n function pause() {\n isActive.value = false;\n if (rafId != null && window) {\n window.cancelAnimationFrame(rafId);\n rafId = null;\n }\n }\n if (immediate)\n resume();\n tryOnScopeDispose(pause);\n return {\n isActive: readonly(isActive),\n pause,\n resume\n };\n}\n\nfunction useAnimate(target, keyframes, options) {\n let config;\n let animateOptions;\n if (isObject(options)) {\n config = options;\n animateOptions = objectOmit(options, [\"window\", \"immediate\", \"commitStyles\", \"persist\", \"onReady\", \"onError\"]);\n } else {\n config = { duration: options };\n animateOptions = options;\n }\n const {\n window = defaultWindow,\n immediate = true,\n commitStyles,\n persist,\n playbackRate: _playbackRate = 1,\n onReady,\n onError = (e) => {\n console.error(e);\n }\n } = config;\n const isSupported = useSupported(() => window && HTMLElement && \"animate\" in HTMLElement.prototype);\n const animate = shallowRef(void 0);\n const store = shallowReactive({\n startTime: null,\n currentTime: null,\n timeline: null,\n playbackRate: _playbackRate,\n pending: false,\n playState: immediate ? \"idle\" : \"paused\",\n replaceState: \"active\"\n });\n const pending = computed(() => store.pending);\n const playState = computed(() => store.playState);\n const replaceState = computed(() => store.replaceState);\n const startTime = computed({\n get() {\n return store.startTime;\n },\n set(value) {\n store.startTime = value;\n if (animate.value)\n animate.value.startTime = value;\n }\n });\n const currentTime = computed({\n get() {\n return store.currentTime;\n },\n set(value) {\n store.currentTime = value;\n if (animate.value) {\n animate.value.currentTime = value;\n syncResume();\n }\n }\n });\n const timeline = computed({\n get() {\n return store.timeline;\n },\n set(value) {\n store.timeline = value;\n if (animate.value)\n animate.value.timeline = value;\n }\n });\n const playbackRate = computed({\n get() {\n return store.playbackRate;\n },\n set(value) {\n store.playbackRate = value;\n if (animate.value)\n animate.value.playbackRate = value;\n }\n });\n const play = () => {\n if (animate.value) {\n try {\n animate.value.play();\n syncResume();\n } catch (e) {\n syncPause();\n onError(e);\n }\n } else {\n update();\n }\n };\n const pause = () => {\n var _a;\n try {\n (_a = animate.value) == null ? void 0 : _a.pause();\n syncPause();\n } catch (e) {\n onError(e);\n }\n };\n const reverse = () => {\n var _a;\n if (!animate.value)\n update();\n try {\n (_a = animate.value) == null ? void 0 : _a.reverse();\n syncResume();\n } catch (e) {\n syncPause();\n onError(e);\n }\n };\n const finish = () => {\n var _a;\n try {\n (_a = animate.value) == null ? void 0 : _a.finish();\n syncPause();\n } catch (e) {\n onError(e);\n }\n };\n const cancel = () => {\n var _a;\n try {\n (_a = animate.value) == null ? void 0 : _a.cancel();\n syncPause();\n } catch (e) {\n onError(e);\n }\n };\n watch(() => unrefElement(target), (el) => {\n if (el)\n update();\n });\n watch(() => keyframes, (value) => {\n if (animate.value)\n update();\n if (!unrefElement(target) && animate.value) {\n animate.value.effect = new KeyframeEffect(\n unrefElement(target),\n toValue(value),\n animateOptions\n );\n }\n }, { deep: true });\n tryOnMounted(() => update(true), false);\n tryOnScopeDispose(cancel);\n function update(init) {\n const el = unrefElement(target);\n if (!isSupported.value || !el)\n return;\n if (!animate.value)\n animate.value = el.animate(toValue(keyframes), animateOptions);\n if (persist)\n animate.value.persist();\n if (_playbackRate !== 1)\n animate.value.playbackRate = _playbackRate;\n if (init && !immediate)\n animate.value.pause();\n else\n syncResume();\n onReady == null ? void 0 : onReady(animate.value);\n }\n useEventListener(animate, [\"cancel\", \"finish\", \"remove\"], syncPause);\n useEventListener(animate, \"finish\", () => {\n var _a;\n if (commitStyles)\n (_a = animate.value) == null ? void 0 : _a.commitStyles();\n });\n const { resume: resumeRef, pause: pauseRef } = useRafFn(() => {\n if (!animate.value)\n return;\n store.pending = animate.value.pending;\n store.playState = animate.value.playState;\n store.replaceState = animate.value.replaceState;\n store.startTime = animate.value.startTime;\n store.currentTime = animate.value.currentTime;\n store.timeline = animate.value.timeline;\n store.playbackRate = animate.value.playbackRate;\n }, { immediate: false });\n function syncResume() {\n if (isSupported.value)\n resumeRef();\n }\n function syncPause() {\n if (isSupported.value && window)\n window.requestAnimationFrame(pauseRef);\n }\n return {\n isSupported,\n animate,\n // actions\n play,\n pause,\n reverse,\n finish,\n cancel,\n // state\n pending,\n playState,\n replaceState,\n startTime,\n currentTime,\n timeline,\n playbackRate\n };\n}\n\nfunction useAsyncQueue(tasks, options) {\n const {\n interrupt = true,\n onError = noop,\n onFinished = noop,\n signal\n } = options || {};\n const promiseState = {\n aborted: \"aborted\",\n fulfilled: \"fulfilled\",\n pending: \"pending\",\n rejected: \"rejected\"\n };\n const initialResult = Array.from(Array.from({ length: tasks.length }), () => ({ state: promiseState.pending, data: null }));\n const result = reactive(initialResult);\n const activeIndex = ref(-1);\n if (!tasks || tasks.length === 0) {\n onFinished();\n return {\n activeIndex,\n result\n };\n }\n function updateResult(state, res) {\n activeIndex.value++;\n result[activeIndex.value].data = res;\n result[activeIndex.value].state = state;\n }\n tasks.reduce((prev, curr) => {\n return prev.then((prevRes) => {\n var _a;\n if (signal == null ? void 0 : signal.aborted) {\n updateResult(promiseState.aborted, new Error(\"aborted\"));\n return;\n }\n if (((_a = result[activeIndex.value]) == null ? void 0 : _a.state) === promiseState.rejected && interrupt) {\n onFinished();\n return;\n }\n const done = curr(prevRes).then((currentRes) => {\n updateResult(promiseState.fulfilled, currentRes);\n if (activeIndex.value === tasks.length - 1)\n onFinished();\n return currentRes;\n });\n if (!signal)\n return done;\n return Promise.race([done, whenAborted(signal)]);\n }).catch((e) => {\n if (signal == null ? void 0 : signal.aborted) {\n updateResult(promiseState.aborted, e);\n return e;\n }\n updateResult(promiseState.rejected, e);\n onError();\n return e;\n });\n }, Promise.resolve());\n return {\n activeIndex,\n result\n };\n}\nfunction whenAborted(signal) {\n return new Promise((resolve, reject) => {\n const error = new Error(\"aborted\");\n if (signal.aborted)\n reject(error);\n else\n signal.addEventListener(\"abort\", () => reject(error), { once: true });\n });\n}\n\nfunction useAsyncState(promise, initialState, options) {\n const {\n immediate = true,\n delay = 0,\n onError = noop,\n onSuccess = noop,\n resetOnExecute = true,\n shallow = true,\n throwError\n } = options != null ? options : {};\n const state = shallow ? shallowRef(initialState) : ref(initialState);\n const isReady = ref(false);\n const isLoading = ref(false);\n const error = shallowRef(void 0);\n async function execute(delay2 = 0, ...args) {\n if (resetOnExecute)\n state.value = initialState;\n error.value = void 0;\n isReady.value = false;\n isLoading.value = true;\n if (delay2 > 0)\n await promiseTimeout(delay2);\n const _promise = typeof promise === \"function\" ? promise(...args) : promise;\n try {\n const data = await _promise;\n state.value = data;\n isReady.value = true;\n onSuccess(data);\n } catch (e) {\n error.value = e;\n onError(e);\n if (throwError)\n throw e;\n } finally {\n isLoading.value = false;\n }\n return state.value;\n }\n if (immediate)\n execute(delay);\n const shell = {\n state,\n isReady,\n isLoading,\n error,\n execute\n };\n function waitUntilIsLoaded() {\n return new Promise((resolve, reject) => {\n until(isLoading).toBe(false).then(() => resolve(shell)).catch(reject);\n });\n }\n return {\n ...shell,\n then(onFulfilled, onRejected) {\n return waitUntilIsLoaded().then(onFulfilled, onRejected);\n }\n };\n}\n\nconst defaults = {\n array: (v) => JSON.stringify(v),\n object: (v) => JSON.stringify(v),\n set: (v) => JSON.stringify(Array.from(v)),\n map: (v) => JSON.stringify(Object.fromEntries(v)),\n null: () => \"\"\n};\nfunction getDefaultSerialization(target) {\n if (!target)\n return defaults.null;\n if (target instanceof Map)\n return defaults.map;\n else if (target instanceof Set)\n return defaults.set;\n else if (Array.isArray(target))\n return defaults.array;\n else\n return defaults.object;\n}\n\nfunction useBase64(target, options) {\n const base64 = ref(\"\");\n const promise = ref();\n function execute() {\n if (!isClient)\n return;\n promise.value = new Promise((resolve, reject) => {\n try {\n const _target = toValue(target);\n if (_target == null) {\n resolve(\"\");\n } else if (typeof _target === \"string\") {\n resolve(blobToBase64(new Blob([_target], { type: \"text/plain\" })));\n } else if (_target instanceof Blob) {\n resolve(blobToBase64(_target));\n } else if (_target instanceof ArrayBuffer) {\n resolve(window.btoa(String.fromCharCode(...new Uint8Array(_target))));\n } else if (_target instanceof HTMLCanvasElement) {\n resolve(_target.toDataURL(options == null ? void 0 : options.type, options == null ? void 0 : options.quality));\n } else if (_target instanceof HTMLImageElement) {\n const img = _target.cloneNode(false);\n img.crossOrigin = \"Anonymous\";\n imgLoaded(img).then(() => {\n const canvas = document.createElement(\"canvas\");\n const ctx = canvas.getContext(\"2d\");\n canvas.width = img.width;\n canvas.height = img.height;\n ctx.drawImage(img, 0, 0, canvas.width, canvas.height);\n resolve(canvas.toDataURL(options == null ? void 0 : options.type, options == null ? void 0 : options.quality));\n }).catch(reject);\n } else if (typeof _target === \"object\") {\n const _serializeFn = (options == null ? void 0 : options.serializer) || getDefaultSerialization(_target);\n const serialized = _serializeFn(_target);\n return resolve(blobToBase64(new Blob([serialized], { type: \"application/json\" })));\n } else {\n reject(new Error(\"target is unsupported types\"));\n }\n } catch (error) {\n reject(error);\n }\n });\n promise.value.then((res) => base64.value = res);\n return promise.value;\n }\n if (isRef(target) || typeof target === \"function\")\n watch(target, execute, { immediate: true });\n else\n execute();\n return {\n base64,\n promise,\n execute\n };\n}\nfunction imgLoaded(img) {\n return new Promise((resolve, reject) => {\n if (!img.complete) {\n img.onload = () => {\n resolve();\n };\n img.onerror = reject;\n } else {\n resolve();\n }\n });\n}\nfunction blobToBase64(blob) {\n return new Promise((resolve, reject) => {\n const fr = new FileReader();\n fr.onload = (e) => {\n resolve(e.target.result);\n };\n fr.onerror = reject;\n fr.readAsDataURL(blob);\n });\n}\n\nfunction useBattery(options = {}) {\n const { navigator = defaultNavigator } = options;\n const events = [\"chargingchange\", \"chargingtimechange\", \"dischargingtimechange\", \"levelchange\"];\n const isSupported = useSupported(() => navigator && \"getBattery\" in navigator && typeof navigator.getBattery === \"function\");\n const charging = ref(false);\n const chargingTime = ref(0);\n const dischargingTime = ref(0);\n const level = ref(1);\n let battery;\n function updateBatteryInfo() {\n charging.value = this.charging;\n chargingTime.value = this.chargingTime || 0;\n dischargingTime.value = this.dischargingTime || 0;\n level.value = this.level;\n }\n if (isSupported.value) {\n navigator.getBattery().then((_battery) => {\n battery = _battery;\n updateBatteryInfo.call(battery);\n useEventListener(battery, events, updateBatteryInfo, { passive: true });\n });\n }\n return {\n isSupported,\n charging,\n chargingTime,\n dischargingTime,\n level\n };\n}\n\nfunction useBluetooth(options) {\n let {\n acceptAllDevices = false\n } = options || {};\n const {\n filters = void 0,\n optionalServices = void 0,\n navigator = defaultNavigator\n } = options || {};\n const isSupported = useSupported(() => navigator && \"bluetooth\" in navigator);\n const device = shallowRef(void 0);\n const error = shallowRef(null);\n watch(device, () => {\n connectToBluetoothGATTServer();\n });\n async function requestDevice() {\n if (!isSupported.value)\n return;\n error.value = null;\n if (filters && filters.length > 0)\n acceptAllDevices = false;\n try {\n device.value = await (navigator == null ? void 0 : navigator.bluetooth.requestDevice({\n acceptAllDevices,\n filters,\n optionalServices\n }));\n } catch (err) {\n error.value = err;\n }\n }\n const server = ref();\n const isConnected = computed(() => {\n var _a;\n return ((_a = server.value) == null ? void 0 : _a.connected) || false;\n });\n async function connectToBluetoothGATTServer() {\n error.value = null;\n if (device.value && device.value.gatt) {\n device.value.addEventListener(\"gattserverdisconnected\", () => {\n });\n try {\n server.value = await device.value.gatt.connect();\n } catch (err) {\n error.value = err;\n }\n }\n }\n tryOnMounted(() => {\n var _a;\n if (device.value)\n (_a = device.value.gatt) == null ? void 0 : _a.connect();\n });\n tryOnScopeDispose(() => {\n var _a;\n if (device.value)\n (_a = device.value.gatt) == null ? void 0 : _a.disconnect();\n });\n return {\n isSupported,\n isConnected,\n // Device:\n device,\n requestDevice,\n // Server:\n server,\n // Errors:\n error\n };\n}\n\nfunction useMediaQuery(query, options = {}) {\n const { window = defaultWindow } = options;\n const isSupported = useSupported(() => window && \"matchMedia\" in window && typeof window.matchMedia === \"function\");\n let mediaQuery;\n const matches = ref(false);\n const handler = (event) => {\n matches.value = event.matches;\n };\n const cleanup = () => {\n if (!mediaQuery)\n return;\n if (\"removeEventListener\" in mediaQuery)\n mediaQuery.removeEventListener(\"change\", handler);\n else\n mediaQuery.removeListener(handler);\n };\n const stopWatch = watchEffect(() => {\n if (!isSupported.value)\n return;\n cleanup();\n mediaQuery = window.matchMedia(toValue(query));\n if (\"addEventListener\" in mediaQuery)\n mediaQuery.addEventListener(\"change\", handler);\n else\n mediaQuery.addListener(handler);\n matches.value = mediaQuery.matches;\n });\n tryOnScopeDispose(() => {\n stopWatch();\n cleanup();\n mediaQuery = void 0;\n });\n return matches;\n}\n\nconst breakpointsTailwind = {\n \"sm\": 640,\n \"md\": 768,\n \"lg\": 1024,\n \"xl\": 1280,\n \"2xl\": 1536\n};\nconst breakpointsBootstrapV5 = {\n xs: 0,\n sm: 576,\n md: 768,\n lg: 992,\n xl: 1200,\n xxl: 1400\n};\nconst breakpointsVuetifyV2 = {\n xs: 0,\n sm: 600,\n md: 960,\n lg: 1264,\n xl: 1904\n};\nconst breakpointsVuetifyV3 = {\n xs: 0,\n sm: 600,\n md: 960,\n lg: 1280,\n xl: 1920,\n xxl: 2560\n};\nconst breakpointsVuetify = breakpointsVuetifyV2;\nconst breakpointsAntDesign = {\n xs: 480,\n sm: 576,\n md: 768,\n lg: 992,\n xl: 1200,\n xxl: 1600\n};\nconst breakpointsQuasar = {\n xs: 0,\n sm: 600,\n md: 1024,\n lg: 1440,\n xl: 1920\n};\nconst breakpointsSematic = {\n mobileS: 320,\n mobileM: 375,\n mobileL: 425,\n tablet: 768,\n laptop: 1024,\n laptopL: 1440,\n desktop4K: 2560\n};\nconst breakpointsMasterCss = {\n \"3xs\": 360,\n \"2xs\": 480,\n \"xs\": 600,\n \"sm\": 768,\n \"md\": 1024,\n \"lg\": 1280,\n \"xl\": 1440,\n \"2xl\": 1600,\n \"3xl\": 1920,\n \"4xl\": 2560\n};\nconst breakpointsPrimeFlex = {\n sm: 576,\n md: 768,\n lg: 992,\n xl: 1200\n};\nconst breakpointsElement = {\n xs: 0,\n sm: 768,\n md: 992,\n lg: 1200,\n xl: 1920\n};\n\nfunction useBreakpoints(breakpoints, options = {}) {\n function getValue(k, delta) {\n let v = toValue(breakpoints[toValue(k)]);\n if (delta != null)\n v = increaseWithUnit(v, delta);\n if (typeof v === \"number\")\n v = `${v}px`;\n return v;\n }\n const { window = defaultWindow, strategy = \"min-width\" } = options;\n function match(query) {\n if (!window)\n return false;\n return window.matchMedia(query).matches;\n }\n const greaterOrEqual = (k) => {\n return useMediaQuery(() => `(min-width: ${getValue(k)})`, options);\n };\n const smallerOrEqual = (k) => {\n return useMediaQuery(() => `(max-width: ${getValue(k)})`, options);\n };\n const shortcutMethods = Object.keys(breakpoints).reduce((shortcuts, k) => {\n Object.defineProperty(shortcuts, k, {\n get: () => strategy === \"min-width\" ? greaterOrEqual(k) : smallerOrEqual(k),\n enumerable: true,\n configurable: true\n });\n return shortcuts;\n }, {});\n function current() {\n const points = Object.keys(breakpoints).map((i) => [i, greaterOrEqual(i)]);\n return computed(() => points.filter(([, v]) => v.value).map(([k]) => k));\n }\n return Object.assign(shortcutMethods, {\n greaterOrEqual,\n smallerOrEqual,\n greater(k) {\n return useMediaQuery(() => `(min-width: ${getValue(k, 0.1)})`, options);\n },\n smaller(k) {\n return useMediaQuery(() => `(max-width: ${getValue(k, -0.1)})`, options);\n },\n between(a, b) {\n return useMediaQuery(() => `(min-width: ${getValue(a)}) and (max-width: ${getValue(b, -0.1)})`, options);\n },\n isGreater(k) {\n return match(`(min-width: ${getValue(k, 0.1)})`);\n },\n isGreaterOrEqual(k) {\n return match(`(min-width: ${getValue(k)})`);\n },\n isSmaller(k) {\n return match(`(max-width: ${getValue(k, -0.1)})`);\n },\n isSmallerOrEqual(k) {\n return match(`(max-width: ${getValue(k)})`);\n },\n isInBetween(a, b) {\n return match(`(min-width: ${getValue(a)}) and (max-width: ${getValue(b, -0.1)})`);\n },\n current,\n active() {\n const bps = current();\n return computed(() => bps.value.length === 0 ? \"\" : bps.value.at(-1));\n }\n });\n}\n\nfunction useBroadcastChannel(options) {\n const {\n name,\n window = defaultWindow\n } = options;\n const isSupported = useSupported(() => window && \"BroadcastChannel\" in window);\n const isClosed = ref(false);\n const channel = ref();\n const data = ref();\n const error = shallowRef(null);\n const post = (data2) => {\n if (channel.value)\n channel.value.postMessage(data2);\n };\n const close = () => {\n if (channel.value)\n channel.value.close();\n isClosed.value = true;\n };\n if (isSupported.value) {\n tryOnMounted(() => {\n error.value = null;\n channel.value = new BroadcastChannel(name);\n channel.value.addEventListener(\"message\", (e) => {\n data.value = e.data;\n }, { passive: true });\n channel.value.addEventListener(\"messageerror\", (e) => {\n error.value = e;\n }, { passive: true });\n channel.value.addEventListener(\"close\", () => {\n isClosed.value = true;\n });\n });\n }\n tryOnScopeDispose(() => {\n close();\n });\n return {\n isSupported,\n channel,\n data,\n post,\n close,\n error,\n isClosed\n };\n}\n\nconst WRITABLE_PROPERTIES = [\n \"hash\",\n \"host\",\n \"hostname\",\n \"href\",\n \"pathname\",\n \"port\",\n \"protocol\",\n \"search\"\n];\nfunction useBrowserLocation(options = {}) {\n const { window = defaultWindow } = options;\n const refs = Object.fromEntries(\n WRITABLE_PROPERTIES.map((key) => [key, ref()])\n );\n for (const [key, ref2] of objectEntries(refs)) {\n watch(ref2, (value) => {\n if (!(window == null ? void 0 : window.location) || window.location[key] === value)\n return;\n window.location[key] = value;\n });\n }\n const buildState = (trigger) => {\n var _a;\n const { state: state2, length } = (window == null ? void 0 : window.history) || {};\n const { origin } = (window == null ? void 0 : window.location) || {};\n for (const key of WRITABLE_PROPERTIES)\n refs[key].value = (_a = window == null ? void 0 : window.location) == null ? void 0 : _a[key];\n return reactive({\n trigger,\n state: state2,\n length,\n origin,\n ...refs\n });\n };\n const state = ref(buildState(\"load\"));\n if (window) {\n useEventListener(window, \"popstate\", () => state.value = buildState(\"popstate\"), { passive: true });\n useEventListener(window, \"hashchange\", () => state.value = buildState(\"hashchange\"), { passive: true });\n }\n return state;\n}\n\nfunction useCached(refValue, comparator = (a, b) => a === b, watchOptions) {\n const cachedValue = ref(refValue.value);\n watch(() => refValue.value, (value) => {\n if (!comparator(value, cachedValue.value))\n cachedValue.value = value;\n }, watchOptions);\n return cachedValue;\n}\n\nfunction usePermission(permissionDesc, options = {}) {\n const {\n controls = false,\n navigator = defaultNavigator\n } = options;\n const isSupported = useSupported(() => navigator && \"permissions\" in navigator);\n const permissionStatus = shallowRef();\n const desc = typeof permissionDesc === \"string\" ? { name: permissionDesc } : permissionDesc;\n const state = shallowRef();\n const update = () => {\n var _a, _b;\n state.value = (_b = (_a = permissionStatus.value) == null ? void 0 : _a.state) != null ? _b : \"prompt\";\n };\n useEventListener(permissionStatus, \"change\", update);\n const query = createSingletonPromise(async () => {\n if (!isSupported.value)\n return;\n if (!permissionStatus.value) {\n try {\n permissionStatus.value = await navigator.permissions.query(desc);\n } catch (e) {\n permissionStatus.value = void 0;\n } finally {\n update();\n }\n }\n if (controls)\n return toRaw(permissionStatus.value);\n });\n query();\n if (controls) {\n return {\n state,\n isSupported,\n query\n };\n } else {\n return state;\n }\n}\n\nfunction useClipboard(options = {}) {\n const {\n navigator = defaultNavigator,\n read = false,\n source,\n copiedDuring = 1500,\n legacy = false\n } = options;\n const isClipboardApiSupported = useSupported(() => navigator && \"clipboard\" in navigator);\n const permissionRead = usePermission(\"clipboard-read\");\n const permissionWrite = usePermission(\"clipboard-write\");\n const isSupported = computed(() => isClipboardApiSupported.value || legacy);\n const text = ref(\"\");\n const copied = ref(false);\n const timeout = useTimeoutFn(() => copied.value = false, copiedDuring);\n function updateText() {\n if (isClipboardApiSupported.value && isAllowed(permissionRead.value)) {\n navigator.clipboard.readText().then((value) => {\n text.value = value;\n });\n } else {\n text.value = legacyRead();\n }\n }\n if (isSupported.value && read)\n useEventListener([\"copy\", \"cut\"], updateText);\n async function copy(value = toValue(source)) {\n if (isSupported.value && value != null) {\n if (isClipboardApiSupported.value && isAllowed(permissionWrite.value))\n await navigator.clipboard.writeText(value);\n else\n legacyCopy(value);\n text.value = value;\n copied.value = true;\n timeout.start();\n }\n }\n function legacyCopy(value) {\n const ta = document.createElement(\"textarea\");\n ta.value = value != null ? value : \"\";\n ta.style.position = \"absolute\";\n ta.style.opacity = \"0\";\n document.body.appendChild(ta);\n ta.select();\n document.execCommand(\"copy\");\n ta.remove();\n }\n function legacyRead() {\n var _a, _b, _c;\n return (_c = (_b = (_a = document == null ? void 0 : document.getSelection) == null ? void 0 : _a.call(document)) == null ? void 0 : _b.toString()) != null ? _c : \"\";\n }\n function isAllowed(status) {\n return status === \"granted\" || status === \"prompt\";\n }\n return {\n isSupported,\n text,\n copied,\n copy\n };\n}\n\nfunction useClipboardItems(options = {}) {\n const {\n navigator = defaultNavigator,\n read = false,\n source,\n copiedDuring = 1500\n } = options;\n const isSupported = useSupported(() => navigator && \"clipboard\" in navigator);\n const content = ref([]);\n const copied = ref(false);\n const timeout = useTimeoutFn(() => copied.value = false, copiedDuring);\n function updateContent() {\n if (isSupported.value) {\n navigator.clipboard.read().then((items) => {\n content.value = items;\n });\n }\n }\n if (isSupported.value && read)\n useEventListener([\"copy\", \"cut\"], updateContent);\n async function copy(value = toValue(source)) {\n if (isSupported.value && value != null) {\n await navigator.clipboard.write(value);\n content.value = value;\n copied.value = true;\n timeout.start();\n }\n }\n return {\n isSupported,\n content,\n copied,\n copy\n };\n}\n\nfunction cloneFnJSON(source) {\n return JSON.parse(JSON.stringify(source));\n}\nfunction useCloned(source, options = {}) {\n const cloned = ref({});\n const {\n manual,\n clone = cloneFnJSON,\n // watch options\n deep = true,\n immediate = true\n } = options;\n function sync() {\n cloned.value = clone(toValue(source));\n }\n if (!manual && (isRef(source) || typeof source === \"function\")) {\n watch(source, sync, {\n ...options,\n deep,\n immediate\n });\n } else {\n sync();\n }\n return { cloned, sync };\n}\n\nconst _global = typeof globalThis !== \"undefined\" ? globalThis : typeof window !== \"undefined\" ? window : typeof global !== \"undefined\" ? global : typeof self !== \"undefined\" ? self : {};\nconst globalKey = \"__vueuse_ssr_handlers__\";\nconst handlers = /* @__PURE__ */ getHandlers();\nfunction getHandlers() {\n if (!(globalKey in _global))\n _global[globalKey] = _global[globalKey] || {};\n return _global[globalKey];\n}\nfunction getSSRHandler(key, fallback) {\n return handlers[key] || fallback;\n}\nfunction setSSRHandler(key, fn) {\n handlers[key] = fn;\n}\n\nfunction usePreferredDark(options) {\n return useMediaQuery(\"(prefers-color-scheme: dark)\", options);\n}\n\nfunction guessSerializerType(rawInit) {\n return rawInit == null ? \"any\" : rawInit instanceof Set ? \"set\" : rawInit instanceof Map ? \"map\" : rawInit instanceof Date ? \"date\" : typeof rawInit === \"boolean\" ? \"boolean\" : typeof rawInit === \"string\" ? \"string\" : typeof rawInit === \"object\" ? \"object\" : !Number.isNaN(rawInit) ? \"number\" : \"any\";\n}\n\nconst StorageSerializers = {\n boolean: {\n read: (v) => v === \"true\",\n write: (v) => String(v)\n },\n object: {\n read: (v) => JSON.parse(v),\n write: (v) => JSON.stringify(v)\n },\n number: {\n read: (v) => Number.parseFloat(v),\n write: (v) => String(v)\n },\n any: {\n read: (v) => v,\n write: (v) => String(v)\n },\n string: {\n read: (v) => v,\n write: (v) => String(v)\n },\n map: {\n read: (v) => new Map(JSON.parse(v)),\n write: (v) => JSON.stringify(Array.from(v.entries()))\n },\n set: {\n read: (v) => new Set(JSON.parse(v)),\n write: (v) => JSON.stringify(Array.from(v))\n },\n date: {\n read: (v) => new Date(v),\n write: (v) => v.toISOString()\n }\n};\nconst customStorageEventName = \"vueuse-storage\";\nfunction useStorage(key, defaults, storage, options = {}) {\n var _a;\n const {\n flush = \"pre\",\n deep = true,\n listenToStorageChanges = true,\n writeDefaults = true,\n mergeDefaults = false,\n shallow,\n window = defaultWindow,\n eventFilter,\n onError = (e) => {\n console.error(e);\n },\n initOnMounted\n } = options;\n const data = (shallow ? shallowRef : ref)(typeof defaults === \"function\" ? defaults() : defaults);\n if (!storage) {\n try {\n storage = getSSRHandler(\"getDefaultStorage\", () => {\n var _a2;\n return (_a2 = defaultWindow) == null ? void 0 : _a2.localStorage;\n })();\n } catch (e) {\n onError(e);\n }\n }\n if (!storage)\n return data;\n const rawInit = toValue(defaults);\n const type = guessSerializerType(rawInit);\n const serializer = (_a = options.serializer) != null ? _a : StorageSerializers[type];\n const { pause: pauseWatch, resume: resumeWatch } = pausableWatch(\n data,\n () => write(data.value),\n { flush, deep, eventFilter }\n );\n if (window && listenToStorageChanges) {\n tryOnMounted(() => {\n if (storage instanceof Storage)\n useEventListener(window, \"storage\", update);\n else\n useEventListener(window, customStorageEventName, updateFromCustomEvent);\n if (initOnMounted)\n update();\n });\n }\n if (!initOnMounted)\n update();\n function dispatchWriteEvent(oldValue, newValue) {\n if (window) {\n const payload = {\n key,\n oldValue,\n newValue,\n storageArea: storage\n };\n window.dispatchEvent(storage instanceof Storage ? new StorageEvent(\"storage\", payload) : new CustomEvent(customStorageEventName, {\n detail: payload\n }));\n }\n }\n function write(v) {\n try {\n const oldValue = storage.getItem(key);\n if (v == null) {\n dispatchWriteEvent(oldValue, null);\n storage.removeItem(key);\n } else {\n const serialized = serializer.write(v);\n if (oldValue !== serialized) {\n storage.setItem(key, serialized);\n dispatchWriteEvent(oldValue, serialized);\n }\n }\n } catch (e) {\n onError(e);\n }\n }\n function read(event) {\n const rawValue = event ? event.newValue : storage.getItem(key);\n if (rawValue == null) {\n if (writeDefaults && rawInit != null)\n storage.setItem(key, serializer.write(rawInit));\n return rawInit;\n } else if (!event && mergeDefaults) {\n const value = serializer.read(rawValue);\n if (typeof mergeDefaults === \"function\")\n return mergeDefaults(value, rawInit);\n else if (type === \"object\" && !Array.isArray(value))\n return { ...rawInit, ...value };\n return value;\n } else if (typeof rawValue !== \"string\") {\n return rawValue;\n } else {\n return serializer.read(rawValue);\n }\n }\n function update(event) {\n if (event && event.storageArea !== storage)\n return;\n if (event && event.key == null) {\n data.value = rawInit;\n return;\n }\n if (event && event.key !== key)\n return;\n pauseWatch();\n try {\n if ((event == null ? void 0 : event.newValue) !== serializer.write(data.value))\n data.value = read(event);\n } catch (e) {\n onError(e);\n } finally {\n if (event)\n nextTick(resumeWatch);\n else\n resumeWatch();\n }\n }\n function updateFromCustomEvent(event) {\n update(event.detail);\n }\n return data;\n}\n\nconst CSS_DISABLE_TRANS = \"*,*::before,*::after{-webkit-transition:none!important;-moz-transition:none!important;-o-transition:none!important;-ms-transition:none!important;transition:none!important}\";\nfunction useColorMode(options = {}) {\n const {\n selector = \"html\",\n attribute = \"class\",\n initialValue = \"auto\",\n window = defaultWindow,\n storage,\n storageKey = \"vueuse-color-scheme\",\n listenToStorageChanges = true,\n storageRef,\n emitAuto,\n disableTransition = true\n } = options;\n const modes = {\n auto: \"\",\n light: \"light\",\n dark: \"dark\",\n ...options.modes || {}\n };\n const preferredDark = usePreferredDark({ window });\n const system = computed(() => preferredDark.value ? \"dark\" : \"light\");\n const store = storageRef || (storageKey == null ? toRef(initialValue) : useStorage(storageKey, initialValue, storage, { window, listenToStorageChanges }));\n const state = computed(() => store.value === \"auto\" ? system.value : store.value);\n const updateHTMLAttrs = getSSRHandler(\n \"updateHTMLAttrs\",\n (selector2, attribute2, value) => {\n const el = typeof selector2 === \"string\" ? window == null ? void 0 : window.document.querySelector(selector2) : unrefElement(selector2);\n if (!el)\n return;\n const classesToAdd = /* @__PURE__ */ new Set();\n const classesToRemove = /* @__PURE__ */ new Set();\n let attributeToChange = null;\n if (attribute2 === \"class\") {\n const current = value.split(/\\s/g);\n Object.values(modes).flatMap((i) => (i || \"\").split(/\\s/g)).filter(Boolean).forEach((v) => {\n if (current.includes(v))\n classesToAdd.add(v);\n else\n classesToRemove.add(v);\n });\n } else {\n attributeToChange = { key: attribute2, value };\n }\n if (classesToAdd.size === 0 && classesToRemove.size === 0 && attributeToChange === null)\n return;\n let style;\n if (disableTransition) {\n style = window.document.createElement(\"style\");\n style.appendChild(document.createTextNode(CSS_DISABLE_TRANS));\n window.document.head.appendChild(style);\n }\n for (const c of classesToAdd) {\n el.classList.add(c);\n }\n for (const c of classesToRemove) {\n el.classList.remove(c);\n }\n if (attributeToChange) {\n el.setAttribute(attributeToChange.key, attributeToChange.value);\n }\n if (disableTransition) {\n window.getComputedStyle(style).opacity;\n document.head.removeChild(style);\n }\n }\n );\n function defaultOnChanged(mode) {\n var _a;\n updateHTMLAttrs(selector, attribute, (_a = modes[mode]) != null ? _a : mode);\n }\n function onChanged(mode) {\n if (options.onChanged)\n options.onChanged(mode, defaultOnChanged);\n else\n defaultOnChanged(mode);\n }\n watch(state, onChanged, { flush: \"post\", immediate: true });\n tryOnMounted(() => onChanged(state.value));\n const auto = computed({\n get() {\n return emitAuto ? store.value : state.value;\n },\n set(v) {\n store.value = v;\n }\n });\n return Object.assign(auto, { store, system, state });\n}\n\nfunction useConfirmDialog(revealed = ref(false)) {\n const confirmHook = createEventHook();\n const cancelHook = createEventHook();\n const revealHook = createEventHook();\n let _resolve = noop;\n const reveal = (data) => {\n revealHook.trigger(data);\n revealed.value = true;\n return new Promise((resolve) => {\n _resolve = resolve;\n });\n };\n const confirm = (data) => {\n revealed.value = false;\n confirmHook.trigger(data);\n _resolve({ data, isCanceled: false });\n };\n const cancel = (data) => {\n revealed.value = false;\n cancelHook.trigger(data);\n _resolve({ data, isCanceled: true });\n };\n return {\n isRevealed: computed(() => revealed.value),\n reveal,\n confirm,\n cancel,\n onReveal: revealHook.on,\n onConfirm: confirmHook.on,\n onCancel: cancelHook.on\n };\n}\n\nfunction useCssVar(prop, target, options = {}) {\n const { window = defaultWindow, initialValue, observe = false } = options;\n const variable = ref(initialValue);\n const elRef = computed(() => {\n var _a;\n return unrefElement(target) || ((_a = window == null ? void 0 : window.document) == null ? void 0 : _a.documentElement);\n });\n function updateCssVar() {\n var _a;\n const key = toValue(prop);\n const el = toValue(elRef);\n if (el && window && key) {\n const value = (_a = window.getComputedStyle(el).getPropertyValue(key)) == null ? void 0 : _a.trim();\n variable.value = value || initialValue;\n }\n }\n if (observe) {\n useMutationObserver(elRef, updateCssVar, {\n attributeFilter: [\"style\", \"class\"],\n window\n });\n }\n watch(\n [elRef, () => toValue(prop)],\n (_, old) => {\n if (old[0] && old[1])\n old[0].style.removeProperty(old[1]);\n updateCssVar();\n },\n { immediate: true }\n );\n watch(\n variable,\n (val) => {\n var _a;\n const raw_prop = toValue(prop);\n if (((_a = elRef.value) == null ? void 0 : _a.style) && raw_prop) {\n if (val == null)\n elRef.value.style.removeProperty(raw_prop);\n else\n elRef.value.style.setProperty(raw_prop, val);\n }\n }\n );\n return variable;\n}\n\nfunction useCurrentElement(rootComponent) {\n const vm = getCurrentInstance();\n const currentElement = computedWithControl(\n () => null,\n () => rootComponent ? unrefElement(rootComponent) : vm.proxy.$el\n );\n onUpdated(currentElement.trigger);\n onMounted(currentElement.trigger);\n return currentElement;\n}\n\nfunction useCycleList(list, options) {\n const state = shallowRef(getInitialValue());\n const listRef = toRef(list);\n const index = computed({\n get() {\n var _a;\n const targetList = listRef.value;\n let index2 = (options == null ? void 0 : options.getIndexOf) ? options.getIndexOf(state.value, targetList) : targetList.indexOf(state.value);\n if (index2 < 0)\n index2 = (_a = options == null ? void 0 : options.fallbackIndex) != null ? _a : 0;\n return index2;\n },\n set(v) {\n set(v);\n }\n });\n function set(i) {\n const targetList = listRef.value;\n const length = targetList.length;\n const index2 = (i % length + length) % length;\n const value = targetList[index2];\n state.value = value;\n return value;\n }\n function shift(delta = 1) {\n return set(index.value + delta);\n }\n function next(n = 1) {\n return shift(n);\n }\n function prev(n = 1) {\n return shift(-n);\n }\n function getInitialValue() {\n var _a, _b;\n return (_b = toValue((_a = options == null ? void 0 : options.initialValue) != null ? _a : toValue(list)[0])) != null ? _b : void 0;\n }\n watch(listRef, () => set(index.value));\n return {\n state,\n index,\n next,\n prev,\n go: set\n };\n}\n\nfunction useDark(options = {}) {\n const {\n valueDark = \"dark\",\n valueLight = \"\"\n } = options;\n const mode = useColorMode({\n ...options,\n onChanged: (mode2, defaultHandler) => {\n var _a;\n if (options.onChanged)\n (_a = options.onChanged) == null ? void 0 : _a.call(options, mode2 === \"dark\", defaultHandler, mode2);\n else\n defaultHandler(mode2);\n },\n modes: {\n dark: valueDark,\n light: valueLight\n }\n });\n const system = computed(() => mode.system.value);\n const isDark = computed({\n get() {\n return mode.value === \"dark\";\n },\n set(v) {\n const modeVal = v ? \"dark\" : \"light\";\n if (system.value === modeVal)\n mode.value = \"auto\";\n else\n mode.value = modeVal;\n }\n });\n return isDark;\n}\n\nfunction fnBypass(v) {\n return v;\n}\nfunction fnSetSource(source, value) {\n return source.value = value;\n}\nfunction defaultDump(clone) {\n return clone ? typeof clone === \"function\" ? clone : cloneFnJSON : fnBypass;\n}\nfunction defaultParse(clone) {\n return clone ? typeof clone === \"function\" ? clone : cloneFnJSON : fnBypass;\n}\nfunction useManualRefHistory(source, options = {}) {\n const {\n clone = false,\n dump = defaultDump(clone),\n parse = defaultParse(clone),\n setSource = fnSetSource\n } = options;\n function _createHistoryRecord() {\n return markRaw({\n snapshot: dump(source.value),\n timestamp: timestamp()\n });\n }\n const last = ref(_createHistoryRecord());\n const undoStack = ref([]);\n const redoStack = ref([]);\n const _setSource = (record) => {\n setSource(source, parse(record.snapshot));\n last.value = record;\n };\n const commit = () => {\n undoStack.value.unshift(last.value);\n last.value = _createHistoryRecord();\n if (options.capacity && undoStack.value.length > options.capacity)\n undoStack.value.splice(options.capacity, Number.POSITIVE_INFINITY);\n if (redoStack.value.length)\n redoStack.value.splice(0, redoStack.value.length);\n };\n const clear = () => {\n undoStack.value.splice(0, undoStack.value.length);\n redoStack.value.splice(0, redoStack.value.length);\n };\n const undo = () => {\n const state = undoStack.value.shift();\n if (state) {\n redoStack.value.unshift(last.value);\n _setSource(state);\n }\n };\n const redo = () => {\n const state = redoStack.value.shift();\n if (state) {\n undoStack.value.unshift(last.value);\n _setSource(state);\n }\n };\n const reset = () => {\n _setSource(last.value);\n };\n const history = computed(() => [last.value, ...undoStack.value]);\n const canUndo = computed(() => undoStack.value.length > 0);\n const canRedo = computed(() => redoStack.value.length > 0);\n return {\n source,\n undoStack,\n redoStack,\n last,\n history,\n canUndo,\n canRedo,\n clear,\n commit,\n reset,\n undo,\n redo\n };\n}\n\nfunction useRefHistory(source, options = {}) {\n const {\n deep = false,\n flush = \"pre\",\n eventFilter\n } = options;\n const {\n eventFilter: composedFilter,\n pause,\n resume: resumeTracking,\n isActive: isTracking\n } = pausableFilter(eventFilter);\n const {\n ignoreUpdates,\n ignorePrevAsyncUpdates,\n stop\n } = watchIgnorable(\n source,\n commit,\n { deep, flush, eventFilter: composedFilter }\n );\n function setSource(source2, value) {\n ignorePrevAsyncUpdates();\n ignoreUpdates(() => {\n source2.value = value;\n });\n }\n const manualHistory = useManualRefHistory(source, { ...options, clone: options.clone || deep, setSource });\n const { clear, commit: manualCommit } = manualHistory;\n function commit() {\n ignorePrevAsyncUpdates();\n manualCommit();\n }\n function resume(commitNow) {\n resumeTracking();\n if (commitNow)\n commit();\n }\n function batch(fn) {\n let canceled = false;\n const cancel = () => canceled = true;\n ignoreUpdates(() => {\n fn(cancel);\n });\n if (!canceled)\n commit();\n }\n function dispose() {\n stop();\n clear();\n }\n return {\n ...manualHistory,\n isTracking,\n pause,\n resume,\n commit,\n batch,\n dispose\n };\n}\n\nfunction useDebouncedRefHistory(source, options = {}) {\n const filter = options.debounce ? debounceFilter(options.debounce) : void 0;\n const history = useRefHistory(source, { ...options, eventFilter: filter });\n return {\n ...history\n };\n}\n\nfunction useDeviceMotion(options = {}) {\n const {\n window = defaultWindow,\n eventFilter = bypassFilter\n } = options;\n const acceleration = ref({ x: null, y: null, z: null });\n const rotationRate = ref({ alpha: null, beta: null, gamma: null });\n const interval = ref(0);\n const accelerationIncludingGravity = ref({\n x: null,\n y: null,\n z: null\n });\n if (window) {\n const onDeviceMotion = createFilterWrapper(\n eventFilter,\n (event) => {\n acceleration.value = event.acceleration;\n accelerationIncludingGravity.value = event.accelerationIncludingGravity;\n rotationRate.value = event.rotationRate;\n interval.value = event.interval;\n }\n );\n useEventListener(window, \"devicemotion\", onDeviceMotion);\n }\n return {\n acceleration,\n accelerationIncludingGravity,\n rotationRate,\n interval\n };\n}\n\nfunction useDeviceOrientation(options = {}) {\n const { window = defaultWindow } = options;\n const isSupported = useSupported(() => window && \"DeviceOrientationEvent\" in window);\n const isAbsolute = ref(false);\n const alpha = ref(null);\n const beta = ref(null);\n const gamma = ref(null);\n if (window && isSupported.value) {\n useEventListener(window, \"deviceorientation\", (event) => {\n isAbsolute.value = event.absolute;\n alpha.value = event.alpha;\n beta.value = event.beta;\n gamma.value = event.gamma;\n });\n }\n return {\n isSupported,\n isAbsolute,\n alpha,\n beta,\n gamma\n };\n}\n\nfunction useDevicePixelRatio(options = {}) {\n const {\n window = defaultWindow\n } = options;\n const pixelRatio = ref(1);\n if (window) {\n let observe2 = function() {\n pixelRatio.value = window.devicePixelRatio;\n cleanup2();\n media = window.matchMedia(`(resolution: ${pixelRatio.value}dppx)`);\n media.addEventListener(\"change\", observe2, { once: true });\n }, cleanup2 = function() {\n media == null ? void 0 : media.removeEventListener(\"change\", observe2);\n };\n let media;\n observe2();\n tryOnScopeDispose(cleanup2);\n }\n return { pixelRatio };\n}\n\nfunction useDevicesList(options = {}) {\n const {\n navigator = defaultNavigator,\n requestPermissions = false,\n constraints = { audio: true, video: true },\n onUpdated\n } = options;\n const devices = ref([]);\n const videoInputs = computed(() => devices.value.filter((i) => i.kind === \"videoinput\"));\n const audioInputs = computed(() => devices.value.filter((i) => i.kind === \"audioinput\"));\n const audioOutputs = computed(() => devices.value.filter((i) => i.kind === \"audiooutput\"));\n const isSupported = useSupported(() => navigator && navigator.mediaDevices && navigator.mediaDevices.enumerateDevices);\n const permissionGranted = ref(false);\n let stream;\n async function update() {\n if (!isSupported.value)\n return;\n devices.value = await navigator.mediaDevices.enumerateDevices();\n onUpdated == null ? void 0 : onUpdated(devices.value);\n if (stream) {\n stream.getTracks().forEach((t) => t.stop());\n stream = null;\n }\n }\n async function ensurePermissions() {\n if (!isSupported.value)\n return false;\n if (permissionGranted.value)\n return true;\n const { state, query } = usePermission(\"camera\", { controls: true });\n await query();\n if (state.value !== \"granted\") {\n let granted = true;\n try {\n stream = await navigator.mediaDevices.getUserMedia(constraints);\n } catch (e) {\n stream = null;\n granted = false;\n }\n update();\n permissionGranted.value = granted;\n } else {\n permissionGranted.value = true;\n }\n return permissionGranted.value;\n }\n if (isSupported.value) {\n if (requestPermissions)\n ensurePermissions();\n useEventListener(navigator.mediaDevices, \"devicechange\", update);\n update();\n }\n return {\n devices,\n ensurePermissions,\n permissionGranted,\n videoInputs,\n audioInputs,\n audioOutputs,\n isSupported\n };\n}\n\nfunction useDisplayMedia(options = {}) {\n var _a;\n const enabled = ref((_a = options.enabled) != null ? _a : false);\n const video = options.video;\n const audio = options.audio;\n const { navigator = defaultNavigator } = options;\n const isSupported = useSupported(() => {\n var _a2;\n return (_a2 = navigator == null ? void 0 : navigator.mediaDevices) == null ? void 0 : _a2.getDisplayMedia;\n });\n const constraint = { audio, video };\n const stream = shallowRef();\n async function _start() {\n var _a2;\n if (!isSupported.value || stream.value)\n return;\n stream.value = await navigator.mediaDevices.getDisplayMedia(constraint);\n (_a2 = stream.value) == null ? void 0 : _a2.getTracks().forEach((t) => t.addEventListener(\"ended\", stop));\n return stream.value;\n }\n async function _stop() {\n var _a2;\n (_a2 = stream.value) == null ? void 0 : _a2.getTracks().forEach((t) => t.stop());\n stream.value = void 0;\n }\n function stop() {\n _stop();\n enabled.value = false;\n }\n async function start() {\n await _start();\n if (stream.value)\n enabled.value = true;\n return stream.value;\n }\n watch(\n enabled,\n (v) => {\n if (v)\n _start();\n else\n _stop();\n },\n { immediate: true }\n );\n return {\n isSupported,\n stream,\n start,\n stop,\n enabled\n };\n}\n\nfunction useDocumentVisibility(options = {}) {\n const { document = defaultDocument } = options;\n if (!document)\n return ref(\"visible\");\n const visibility = ref(document.visibilityState);\n useEventListener(document, \"visibilitychange\", () => {\n visibility.value = document.visibilityState;\n });\n return visibility;\n}\n\nfunction useDraggable(target, options = {}) {\n var _a, _b;\n const {\n pointerTypes,\n preventDefault,\n stopPropagation,\n exact,\n onMove,\n onEnd,\n onStart,\n initialValue,\n axis = \"both\",\n draggingElement = defaultWindow,\n containerElement,\n handle: draggingHandle = target,\n buttons = [0]\n } = options;\n const position = ref(\n (_a = toValue(initialValue)) != null ? _a : { x: 0, y: 0 }\n );\n const pressedDelta = ref();\n const filterEvent = (e) => {\n if (pointerTypes)\n return pointerTypes.includes(e.pointerType);\n return true;\n };\n const handleEvent = (e) => {\n if (toValue(preventDefault))\n e.preventDefault();\n if (toValue(stopPropagation))\n e.stopPropagation();\n };\n const start = (e) => {\n var _a2;\n if (!toValue(buttons).includes(e.button))\n return;\n if (toValue(options.disabled) || !filterEvent(e))\n return;\n if (toValue(exact) && e.target !== toValue(target))\n return;\n const container = toValue(containerElement);\n const containerRect = (_a2 = container == null ? void 0 : container.getBoundingClientRect) == null ? void 0 : _a2.call(container);\n const targetRect = toValue(target).getBoundingClientRect();\n const pos = {\n x: e.clientX - (container ? targetRect.left - containerRect.left + container.scrollLeft : targetRect.left),\n y: e.clientY - (container ? targetRect.top - containerRect.top + container.scrollTop : targetRect.top)\n };\n if ((onStart == null ? void 0 : onStart(pos, e)) === false)\n return;\n pressedDelta.value = pos;\n handleEvent(e);\n };\n const move = (e) => {\n if (toValue(options.disabled) || !filterEvent(e))\n return;\n if (!pressedDelta.value)\n return;\n const container = toValue(containerElement);\n const targetRect = toValue(target).getBoundingClientRect();\n let { x, y } = position.value;\n if (axis === \"x\" || axis === \"both\") {\n x = e.clientX - pressedDelta.value.x;\n if (container)\n x = Math.min(Math.max(0, x), container.scrollWidth - targetRect.width);\n }\n if (axis === \"y\" || axis === \"both\") {\n y = e.clientY - pressedDelta.value.y;\n if (container)\n y = Math.min(Math.max(0, y), container.scrollHeight - targetRect.height);\n }\n position.value = {\n x,\n y\n };\n onMove == null ? void 0 : onMove(position.value, e);\n handleEvent(e);\n };\n const end = (e) => {\n if (toValue(options.disabled) || !filterEvent(e))\n return;\n if (!pressedDelta.value)\n return;\n pressedDelta.value = void 0;\n onEnd == null ? void 0 : onEnd(position.value, e);\n handleEvent(e);\n };\n if (isClient) {\n const config = { capture: (_b = options.capture) != null ? _b : true };\n useEventListener(draggingHandle, \"pointerdown\", start, config);\n useEventListener(draggingElement, \"pointermove\", move, config);\n useEventListener(draggingElement, \"pointerup\", end, config);\n }\n return {\n ...toRefs(position),\n position,\n isDragging: computed(() => !!pressedDelta.value),\n style: computed(\n () => `left:${position.value.x}px;top:${position.value.y}px;`\n )\n };\n}\n\nfunction useDropZone(target, options = {}) {\n var _a, _b;\n const isOverDropZone = ref(false);\n const files = shallowRef(null);\n let counter = 0;\n let isValid = true;\n if (isClient) {\n const _options = typeof options === \"function\" ? { onDrop: options } : options;\n const multiple = (_a = _options.multiple) != null ? _a : true;\n const preventDefaultForUnhandled = (_b = _options.preventDefaultForUnhandled) != null ? _b : false;\n const getFiles = (event) => {\n var _a2, _b2;\n const list = Array.from((_b2 = (_a2 = event.dataTransfer) == null ? void 0 : _a2.files) != null ? _b2 : []);\n return list.length === 0 ? null : multiple ? list : [list[0]];\n };\n const checkDataTypes = (types) => {\n if (_options.dataTypes) {\n const dataTypes = unref(_options.dataTypes);\n return typeof dataTypes === \"function\" ? dataTypes(types) : dataTypes ? dataTypes.some((item) => types.includes(item)) : true;\n }\n return true;\n };\n const checkValidity = (event) => {\n var _a2, _b2;\n const items = Array.from((_b2 = (_a2 = event.dataTransfer) == null ? void 0 : _a2.items) != null ? _b2 : []);\n const types = items.map((item) => item.type);\n const dataTypesValid = checkDataTypes(types);\n const multipleFilesValid = multiple || items.length <= 1;\n return dataTypesValid && multipleFilesValid;\n };\n const handleDragEvent = (event, eventType) => {\n var _a2, _b2, _c, _d;\n isValid = checkValidity(event);\n if (!isValid) {\n if (preventDefaultForUnhandled) {\n event.preventDefault();\n }\n if (event.dataTransfer) {\n event.dataTransfer.dropEffect = \"none\";\n }\n return;\n }\n event.preventDefault();\n if (event.dataTransfer) {\n event.dataTransfer.dropEffect = \"copy\";\n }\n const currentFiles = getFiles(event);\n switch (eventType) {\n case \"enter\":\n counter += 1;\n isOverDropZone.value = true;\n (_a2 = _options.onEnter) == null ? void 0 : _a2.call(_options, null, event);\n break;\n case \"over\":\n (_b2 = _options.onOver) == null ? void 0 : _b2.call(_options, null, event);\n break;\n case \"leave\":\n counter -= 1;\n if (counter === 0)\n isOverDropZone.value = false;\n (_c = _options.onLeave) == null ? void 0 : _c.call(_options, null, event);\n break;\n case \"drop\":\n counter = 0;\n isOverDropZone.value = false;\n if (isValid) {\n files.value = currentFiles;\n (_d = _options.onDrop) == null ? void 0 : _d.call(_options, currentFiles, event);\n }\n break;\n }\n };\n useEventListener(target, \"dragenter\", (event) => handleDragEvent(event, \"enter\"));\n useEventListener(target, \"dragover\", (event) => handleDragEvent(event, \"over\"));\n useEventListener(target, \"dragleave\", (event) => handleDragEvent(event, \"leave\"));\n useEventListener(target, \"drop\", (event) => handleDragEvent(event, \"drop\"));\n }\n return {\n files,\n isOverDropZone\n };\n}\n\nfunction useResizeObserver(target, callback, options = {}) {\n const { window = defaultWindow, ...observerOptions } = options;\n let observer;\n const isSupported = useSupported(() => window && \"ResizeObserver\" in window);\n const cleanup = () => {\n if (observer) {\n observer.disconnect();\n observer = void 0;\n }\n };\n const targets = computed(() => {\n const _targets = toValue(target);\n return Array.isArray(_targets) ? _targets.map((el) => unrefElement(el)) : [unrefElement(_targets)];\n });\n const stopWatch = watch(\n targets,\n (els) => {\n cleanup();\n if (isSupported.value && window) {\n observer = new ResizeObserver(callback);\n for (const _el of els) {\n if (_el)\n observer.observe(_el, observerOptions);\n }\n }\n },\n { immediate: true, flush: \"post\" }\n );\n const stop = () => {\n cleanup();\n stopWatch();\n };\n tryOnScopeDispose(stop);\n return {\n isSupported,\n stop\n };\n}\n\nfunction useElementBounding(target, options = {}) {\n const {\n reset = true,\n windowResize = true,\n windowScroll = true,\n immediate = true,\n updateTiming = \"sync\"\n } = options;\n const height = ref(0);\n const bottom = ref(0);\n const left = ref(0);\n const right = ref(0);\n const top = ref(0);\n const width = ref(0);\n const x = ref(0);\n const y = ref(0);\n function recalculate() {\n const el = unrefElement(target);\n if (!el) {\n if (reset) {\n height.value = 0;\n bottom.value = 0;\n left.value = 0;\n right.value = 0;\n top.value = 0;\n width.value = 0;\n x.value = 0;\n y.value = 0;\n }\n return;\n }\n const rect = el.getBoundingClientRect();\n height.value = rect.height;\n bottom.value = rect.bottom;\n left.value = rect.left;\n right.value = rect.right;\n top.value = rect.top;\n width.value = rect.width;\n x.value = rect.x;\n y.value = rect.y;\n }\n function update() {\n if (updateTiming === \"sync\")\n recalculate();\n else if (updateTiming === \"next-frame\")\n requestAnimationFrame(() => recalculate());\n }\n useResizeObserver(target, update);\n watch(() => unrefElement(target), (ele) => !ele && update());\n useMutationObserver(target, update, {\n attributeFilter: [\"style\", \"class\"]\n });\n if (windowScroll)\n useEventListener(\"scroll\", update, { capture: true, passive: true });\n if (windowResize)\n useEventListener(\"resize\", update, { passive: true });\n tryOnMounted(() => {\n if (immediate)\n update();\n });\n return {\n height,\n bottom,\n left,\n right,\n top,\n width,\n x,\n y,\n update\n };\n}\n\nfunction useElementByPoint(options) {\n const {\n x,\n y,\n document = defaultDocument,\n multiple,\n interval = \"requestAnimationFrame\",\n immediate = true\n } = options;\n const isSupported = useSupported(() => {\n if (toValue(multiple))\n return document && \"elementsFromPoint\" in document;\n return document && \"elementFromPoint\" in document;\n });\n const element = ref(null);\n const cb = () => {\n var _a, _b;\n element.value = toValue(multiple) ? (_a = document == null ? void 0 : document.elementsFromPoint(toValue(x), toValue(y))) != null ? _a : [] : (_b = document == null ? void 0 : document.elementFromPoint(toValue(x), toValue(y))) != null ? _b : null;\n };\n const controls = interval === \"requestAnimationFrame\" ? useRafFn(cb, { immediate }) : useIntervalFn(cb, interval, { immediate });\n return {\n isSupported,\n element,\n ...controls\n };\n}\n\nfunction useElementHover(el, options = {}) {\n const {\n delayEnter = 0,\n delayLeave = 0,\n window = defaultWindow\n } = options;\n const isHovered = ref(false);\n let timer;\n const toggle = (entering) => {\n const delay = entering ? delayEnter : delayLeave;\n if (timer) {\n clearTimeout(timer);\n timer = void 0;\n }\n if (delay)\n timer = setTimeout(() => isHovered.value = entering, delay);\n else\n isHovered.value = entering;\n };\n if (!window)\n return isHovered;\n useEventListener(el, \"mouseenter\", () => toggle(true), { passive: true });\n useEventListener(el, \"mouseleave\", () => toggle(false), { passive: true });\n return isHovered;\n}\n\nfunction useElementSize(target, initialSize = { width: 0, height: 0 }, options = {}) {\n const { window = defaultWindow, box = \"content-box\" } = options;\n const isSVG = computed(() => {\n var _a, _b;\n return (_b = (_a = unrefElement(target)) == null ? void 0 : _a.namespaceURI) == null ? void 0 : _b.includes(\"svg\");\n });\n const width = ref(initialSize.width);\n const height = ref(initialSize.height);\n const { stop: stop1 } = useResizeObserver(\n target,\n ([entry]) => {\n const boxSize = box === \"border-box\" ? entry.borderBoxSize : box === \"content-box\" ? entry.contentBoxSize : entry.devicePixelContentBoxSize;\n if (window && isSVG.value) {\n const $elem = unrefElement(target);\n if ($elem) {\n const rect = $elem.getBoundingClientRect();\n width.value = rect.width;\n height.value = rect.height;\n }\n } else {\n if (boxSize) {\n const formatBoxSize = Array.isArray(boxSize) ? boxSize : [boxSize];\n width.value = formatBoxSize.reduce((acc, { inlineSize }) => acc + inlineSize, 0);\n height.value = formatBoxSize.reduce((acc, { blockSize }) => acc + blockSize, 0);\n } else {\n width.value = entry.contentRect.width;\n height.value = entry.contentRect.height;\n }\n }\n },\n options\n );\n tryOnMounted(() => {\n const ele = unrefElement(target);\n if (ele) {\n width.value = \"offsetWidth\" in ele ? ele.offsetWidth : initialSize.width;\n height.value = \"offsetHeight\" in ele ? ele.offsetHeight : initialSize.height;\n }\n });\n const stop2 = watch(\n () => unrefElement(target),\n (ele) => {\n width.value = ele ? initialSize.width : 0;\n height.value = ele ? initialSize.height : 0;\n }\n );\n function stop() {\n stop1();\n stop2();\n }\n return {\n width,\n height,\n stop\n };\n}\n\nfunction useIntersectionObserver(target, callback, options = {}) {\n const {\n root,\n rootMargin = \"0px\",\n threshold = 0,\n window = defaultWindow,\n immediate = true\n } = options;\n const isSupported = useSupported(() => window && \"IntersectionObserver\" in window);\n const targets = computed(() => {\n const _target = toValue(target);\n return (Array.isArray(_target) ? _target : [_target]).map(unrefElement).filter(notNullish);\n });\n let cleanup = noop;\n const isActive = ref(immediate);\n const stopWatch = isSupported.value ? watch(\n () => [targets.value, unrefElement(root), isActive.value],\n ([targets2, root2]) => {\n cleanup();\n if (!isActive.value)\n return;\n if (!targets2.length)\n return;\n const observer = new IntersectionObserver(\n callback,\n {\n root: unrefElement(root2),\n rootMargin,\n threshold\n }\n );\n targets2.forEach((el) => el && observer.observe(el));\n cleanup = () => {\n observer.disconnect();\n cleanup = noop;\n };\n },\n { immediate, flush: \"post\" }\n ) : noop;\n const stop = () => {\n cleanup();\n stopWatch();\n isActive.value = false;\n };\n tryOnScopeDispose(stop);\n return {\n isSupported,\n isActive,\n pause() {\n cleanup();\n isActive.value = false;\n },\n resume() {\n isActive.value = true;\n },\n stop\n };\n}\n\nfunction useElementVisibility(element, options = {}) {\n const { window = defaultWindow, scrollTarget, threshold = 0 } = options;\n const elementIsVisible = ref(false);\n useIntersectionObserver(\n element,\n (intersectionObserverEntries) => {\n let isIntersecting = elementIsVisible.value;\n let latestTime = 0;\n for (const entry of intersectionObserverEntries) {\n if (entry.time >= latestTime) {\n latestTime = entry.time;\n isIntersecting = entry.isIntersecting;\n }\n }\n elementIsVisible.value = isIntersecting;\n },\n {\n root: scrollTarget,\n window,\n threshold\n }\n );\n return elementIsVisible;\n}\n\nconst events = /* @__PURE__ */ new Map();\n\nfunction useEventBus(key) {\n const scope = getCurrentScope();\n function on(listener) {\n var _a;\n const listeners = events.get(key) || /* @__PURE__ */ new Set();\n listeners.add(listener);\n events.set(key, listeners);\n const _off = () => off(listener);\n (_a = scope == null ? void 0 : scope.cleanups) == null ? void 0 : _a.push(_off);\n return _off;\n }\n function once(listener) {\n function _listener(...args) {\n off(_listener);\n listener(...args);\n }\n return on(_listener);\n }\n function off(listener) {\n const listeners = events.get(key);\n if (!listeners)\n return;\n listeners.delete(listener);\n if (!listeners.size)\n reset();\n }\n function reset() {\n events.delete(key);\n }\n function emit(event, payload) {\n var _a;\n (_a = events.get(key)) == null ? void 0 : _a.forEach((v) => v(event, payload));\n }\n return { on, once, off, emit, reset };\n}\n\nfunction resolveNestedOptions$1(options) {\n if (options === true)\n return {};\n return options;\n}\nfunction useEventSource(url, events = [], options = {}) {\n const event = ref(null);\n const data = ref(null);\n const status = ref(\"CONNECTING\");\n const eventSource = ref(null);\n const error = shallowRef(null);\n const urlRef = toRef(url);\n const lastEventId = shallowRef(null);\n let explicitlyClosed = false;\n let retried = 0;\n const {\n withCredentials = false,\n immediate = true\n } = options;\n const close = () => {\n if (isClient && eventSource.value) {\n eventSource.value.close();\n eventSource.value = null;\n status.value = \"CLOSED\";\n explicitlyClosed = true;\n }\n };\n const _init = () => {\n if (explicitlyClosed || typeof urlRef.value === \"undefined\")\n return;\n const es = new EventSource(urlRef.value, { withCredentials });\n status.value = \"CONNECTING\";\n eventSource.value = es;\n es.onopen = () => {\n status.value = \"OPEN\";\n error.value = null;\n };\n es.onerror = (e) => {\n status.value = \"CLOSED\";\n error.value = e;\n if (es.readyState === 2 && !explicitlyClosed && options.autoReconnect) {\n es.close();\n const {\n retries = -1,\n delay = 1e3,\n onFailed\n } = resolveNestedOptions$1(options.autoReconnect);\n retried += 1;\n if (typeof retries === \"number\" && (retries < 0 || retried < retries))\n setTimeout(_init, delay);\n else if (typeof retries === \"function\" && retries())\n setTimeout(_init, delay);\n else\n onFailed == null ? void 0 : onFailed();\n }\n };\n es.onmessage = (e) => {\n event.value = null;\n data.value = e.data;\n lastEventId.value = e.lastEventId;\n };\n for (const event_name of events) {\n useEventListener(es, event_name, (e) => {\n event.value = event_name;\n data.value = e.data || null;\n });\n }\n };\n const open = () => {\n if (!isClient)\n return;\n close();\n explicitlyClosed = false;\n retried = 0;\n _init();\n };\n if (immediate)\n watch(urlRef, open, { immediate: true });\n tryOnScopeDispose(close);\n return {\n eventSource,\n event,\n data,\n status,\n error,\n open,\n close,\n lastEventId\n };\n}\n\nfunction useEyeDropper(options = {}) {\n const { initialValue = \"\" } = options;\n const isSupported = useSupported(() => typeof window !== \"undefined\" && \"EyeDropper\" in window);\n const sRGBHex = ref(initialValue);\n async function open(openOptions) {\n if (!isSupported.value)\n return;\n const eyeDropper = new window.EyeDropper();\n const result = await eyeDropper.open(openOptions);\n sRGBHex.value = result.sRGBHex;\n return result;\n }\n return { isSupported, sRGBHex, open };\n}\n\nfunction useFavicon(newIcon = null, options = {}) {\n const {\n baseUrl = \"\",\n rel = \"icon\",\n document = defaultDocument\n } = options;\n const favicon = toRef(newIcon);\n const applyIcon = (icon) => {\n const elements = document == null ? void 0 : document.head.querySelectorAll(`link[rel*=\"${rel}\"]`);\n if (!elements || elements.length === 0) {\n const link = document == null ? void 0 : document.createElement(\"link\");\n if (link) {\n link.rel = rel;\n link.href = `${baseUrl}${icon}`;\n link.type = `image/${icon.split(\".\").pop()}`;\n document == null ? void 0 : document.head.append(link);\n }\n return;\n }\n elements == null ? void 0 : elements.forEach((el) => el.href = `${baseUrl}${icon}`);\n };\n watch(\n favicon,\n (i, o) => {\n if (typeof i === \"string\" && i !== o)\n applyIcon(i);\n },\n { immediate: true }\n );\n return favicon;\n}\n\nconst payloadMapping = {\n json: \"application/json\",\n text: \"text/plain\"\n};\nfunction isFetchOptions(obj) {\n return obj && containsProp(obj, \"immediate\", \"refetch\", \"initialData\", \"timeout\", \"beforeFetch\", \"afterFetch\", \"onFetchError\", \"fetch\", \"updateDataOnError\");\n}\nconst reAbsolute = /^(?:[a-z][a-z\\d+\\-.]*:)?\\/\\//i;\nfunction isAbsoluteURL(url) {\n return reAbsolute.test(url);\n}\nfunction headersToObject(headers) {\n if (typeof Headers !== \"undefined\" && headers instanceof Headers)\n return Object.fromEntries(headers.entries());\n return headers;\n}\nfunction combineCallbacks(combination, ...callbacks) {\n if (combination === \"overwrite\") {\n return async (ctx) => {\n const callback = callbacks[callbacks.length - 1];\n if (callback)\n return { ...ctx, ...await callback(ctx) };\n return ctx;\n };\n } else {\n return async (ctx) => {\n for (const callback of callbacks) {\n if (callback)\n ctx = { ...ctx, ...await callback(ctx) };\n }\n return ctx;\n };\n }\n}\nfunction createFetch(config = {}) {\n const _combination = config.combination || \"chain\";\n const _options = config.options || {};\n const _fetchOptions = config.fetchOptions || {};\n function useFactoryFetch(url, ...args) {\n const computedUrl = computed(() => {\n const baseUrl = toValue(config.baseUrl);\n const targetUrl = toValue(url);\n return baseUrl && !isAbsoluteURL(targetUrl) ? joinPaths(baseUrl, targetUrl) : targetUrl;\n });\n let options = _options;\n let fetchOptions = _fetchOptions;\n if (args.length > 0) {\n if (isFetchOptions(args[0])) {\n options = {\n ...options,\n ...args[0],\n beforeFetch: combineCallbacks(_combination, _options.beforeFetch, args[0].beforeFetch),\n afterFetch: combineCallbacks(_combination, _options.afterFetch, args[0].afterFetch),\n onFetchError: combineCallbacks(_combination, _options.onFetchError, args[0].onFetchError)\n };\n } else {\n fetchOptions = {\n ...fetchOptions,\n ...args[0],\n headers: {\n ...headersToObject(fetchOptions.headers) || {},\n ...headersToObject(args[0].headers) || {}\n }\n };\n }\n }\n if (args.length > 1 && isFetchOptions(args[1])) {\n options = {\n ...options,\n ...args[1],\n beforeFetch: combineCallbacks(_combination, _options.beforeFetch, args[1].beforeFetch),\n afterFetch: combineCallbacks(_combination, _options.afterFetch, args[1].afterFetch),\n onFetchError: combineCallbacks(_combination, _options.onFetchError, args[1].onFetchError)\n };\n }\n return useFetch(computedUrl, fetchOptions, options);\n }\n return useFactoryFetch;\n}\nfunction useFetch(url, ...args) {\n var _a;\n const supportsAbort = typeof AbortController === \"function\";\n let fetchOptions = {};\n let options = {\n immediate: true,\n refetch: false,\n timeout: 0,\n updateDataOnError: false\n };\n const config = {\n method: \"GET\",\n type: \"text\",\n payload: void 0\n };\n if (args.length > 0) {\n if (isFetchOptions(args[0]))\n options = { ...options, ...args[0] };\n else\n fetchOptions = args[0];\n }\n if (args.length > 1) {\n if (isFetchOptions(args[1]))\n options = { ...options, ...args[1] };\n }\n const {\n fetch = (_a = defaultWindow) == null ? void 0 : _a.fetch,\n initialData,\n timeout\n } = options;\n const responseEvent = createEventHook();\n const errorEvent = createEventHook();\n const finallyEvent = createEventHook();\n const isFinished = ref(false);\n const isFetching = ref(false);\n const aborted = ref(false);\n const statusCode = ref(null);\n const response = shallowRef(null);\n const error = shallowRef(null);\n const data = shallowRef(initialData || null);\n const canAbort = computed(() => supportsAbort && isFetching.value);\n let controller;\n let timer;\n const abort = () => {\n if (supportsAbort) {\n controller == null ? void 0 : controller.abort();\n controller = new AbortController();\n controller.signal.onabort = () => aborted.value = true;\n fetchOptions = {\n ...fetchOptions,\n signal: controller.signal\n };\n }\n };\n const loading = (isLoading) => {\n isFetching.value = isLoading;\n isFinished.value = !isLoading;\n };\n if (timeout)\n timer = useTimeoutFn(abort, timeout, { immediate: false });\n let executeCounter = 0;\n const execute = async (throwOnFailed = false) => {\n var _a2, _b;\n abort();\n loading(true);\n error.value = null;\n statusCode.value = null;\n aborted.value = false;\n executeCounter += 1;\n const currentExecuteCounter = executeCounter;\n const defaultFetchOptions = {\n method: config.method,\n headers: {}\n };\n if (config.payload) {\n const headers = headersToObject(defaultFetchOptions.headers);\n const payload = toValue(config.payload);\n const proto = Object.getPrototypeOf(payload);\n if (!config.payloadType && payload && (proto === Object.prototype || Array.isArray(proto)) && !(payload instanceof FormData))\n config.payloadType = \"json\";\n if (config.payloadType)\n headers[\"Content-Type\"] = (_a2 = payloadMapping[config.payloadType]) != null ? _a2 : config.payloadType;\n defaultFetchOptions.body = config.payloadType === \"json\" ? JSON.stringify(payload) : payload;\n }\n let isCanceled = false;\n const context = {\n url: toValue(url),\n options: {\n ...defaultFetchOptions,\n ...fetchOptions\n },\n cancel: () => {\n isCanceled = true;\n }\n };\n if (options.beforeFetch)\n Object.assign(context, await options.beforeFetch(context));\n if (isCanceled || !fetch) {\n loading(false);\n return Promise.resolve(null);\n }\n let responseData = null;\n if (timer)\n timer.start();\n return fetch(\n context.url,\n {\n ...defaultFetchOptions,\n ...context.options,\n headers: {\n ...headersToObject(defaultFetchOptions.headers),\n ...headersToObject((_b = context.options) == null ? void 0 : _b.headers)\n }\n }\n ).then(async (fetchResponse) => {\n response.value = fetchResponse;\n statusCode.value = fetchResponse.status;\n responseData = await fetchResponse.clone()[config.type]();\n if (!fetchResponse.ok) {\n data.value = initialData || null;\n throw new Error(fetchResponse.statusText);\n }\n if (options.afterFetch) {\n ({ data: responseData } = await options.afterFetch({\n data: responseData,\n response: fetchResponse\n }));\n }\n data.value = responseData;\n responseEvent.trigger(fetchResponse);\n return fetchResponse;\n }).catch(async (fetchError) => {\n let errorData = fetchError.message || fetchError.name;\n if (options.onFetchError) {\n ({ error: errorData, data: responseData } = await options.onFetchError({\n data: responseData,\n error: fetchError,\n response: response.value\n }));\n }\n error.value = errorData;\n if (options.updateDataOnError)\n data.value = responseData;\n errorEvent.trigger(fetchError);\n if (throwOnFailed)\n throw fetchError;\n return null;\n }).finally(() => {\n if (currentExecuteCounter === executeCounter)\n loading(false);\n if (timer)\n timer.stop();\n finallyEvent.trigger(null);\n });\n };\n const refetch = toRef(options.refetch);\n watch(\n [\n refetch,\n toRef(url)\n ],\n ([refetch2]) => refetch2 && execute(),\n { deep: true }\n );\n const shell = {\n isFinished: readonly(isFinished),\n isFetching: readonly(isFetching),\n statusCode,\n response,\n error,\n data,\n canAbort,\n aborted,\n abort,\n execute,\n onFetchResponse: responseEvent.on,\n onFetchError: errorEvent.on,\n onFetchFinally: finallyEvent.on,\n // method\n get: setMethod(\"GET\"),\n put: setMethod(\"PUT\"),\n post: setMethod(\"POST\"),\n delete: setMethod(\"DELETE\"),\n patch: setMethod(\"PATCH\"),\n head: setMethod(\"HEAD\"),\n options: setMethod(\"OPTIONS\"),\n // type\n json: setType(\"json\"),\n text: setType(\"text\"),\n blob: setType(\"blob\"),\n arrayBuffer: setType(\"arrayBuffer\"),\n formData: setType(\"formData\")\n };\n function setMethod(method) {\n return (payload, payloadType) => {\n if (!isFetching.value) {\n config.method = method;\n config.payload = payload;\n config.payloadType = payloadType;\n if (isRef(config.payload)) {\n watch(\n [\n refetch,\n toRef(config.payload)\n ],\n ([refetch2]) => refetch2 && execute(),\n { deep: true }\n );\n }\n return {\n ...shell,\n then(onFulfilled, onRejected) {\n return waitUntilFinished().then(onFulfilled, onRejected);\n }\n };\n }\n return void 0;\n };\n }\n function waitUntilFinished() {\n return new Promise((resolve, reject) => {\n until(isFinished).toBe(true).then(() => resolve(shell)).catch(reject);\n });\n }\n function setType(type) {\n return () => {\n if (!isFetching.value) {\n config.type = type;\n return {\n ...shell,\n then(onFulfilled, onRejected) {\n return waitUntilFinished().then(onFulfilled, onRejected);\n }\n };\n }\n return void 0;\n };\n }\n if (options.immediate)\n Promise.resolve().then(() => execute());\n return {\n ...shell,\n then(onFulfilled, onRejected) {\n return waitUntilFinished().then(onFulfilled, onRejected);\n }\n };\n}\nfunction joinPaths(start, end) {\n if (!start.endsWith(\"/\") && !end.startsWith(\"/\")) {\n return `${start}/${end}`;\n }\n if (start.endsWith(\"/\") && end.startsWith(\"/\")) {\n return `${start.slice(0, -1)}${end}`;\n }\n return `${start}${end}`;\n}\n\nconst DEFAULT_OPTIONS = {\n multiple: true,\n accept: \"*\",\n reset: false,\n directory: false\n};\nfunction useFileDialog(options = {}) {\n const {\n document = defaultDocument\n } = options;\n const files = ref(null);\n const { on: onChange, trigger: changeTrigger } = createEventHook();\n const { on: onCancel, trigger: cancelTrigger } = createEventHook();\n let input;\n if (document) {\n input = document.createElement(\"input\");\n input.type = \"file\";\n input.onchange = (event) => {\n const result = event.target;\n files.value = result.files;\n changeTrigger(files.value);\n };\n input.oncancel = () => {\n cancelTrigger();\n };\n }\n const reset = () => {\n files.value = null;\n if (input && input.value) {\n input.value = \"\";\n changeTrigger(null);\n }\n };\n const open = (localOptions) => {\n if (!input)\n return;\n const _options = {\n ...DEFAULT_OPTIONS,\n ...options,\n ...localOptions\n };\n input.multiple = _options.multiple;\n input.accept = _options.accept;\n input.webkitdirectory = _options.directory;\n if (hasOwn(_options, \"capture\"))\n input.capture = _options.capture;\n if (_options.reset)\n reset();\n input.click();\n };\n return {\n files: readonly(files),\n open,\n reset,\n onCancel,\n onChange\n };\n}\n\nfunction useFileSystemAccess(options = {}) {\n const {\n window: _window = defaultWindow,\n dataType = \"Text\"\n } = options;\n const window = _window;\n const isSupported = useSupported(() => window && \"showSaveFilePicker\" in window && \"showOpenFilePicker\" in window);\n const fileHandle = ref();\n const data = ref();\n const file = ref();\n const fileName = computed(() => {\n var _a, _b;\n return (_b = (_a = file.value) == null ? void 0 : _a.name) != null ? _b : \"\";\n });\n const fileMIME = computed(() => {\n var _a, _b;\n return (_b = (_a = file.value) == null ? void 0 : _a.type) != null ? _b : \"\";\n });\n const fileSize = computed(() => {\n var _a, _b;\n return (_b = (_a = file.value) == null ? void 0 : _a.size) != null ? _b : 0;\n });\n const fileLastModified = computed(() => {\n var _a, _b;\n return (_b = (_a = file.value) == null ? void 0 : _a.lastModified) != null ? _b : 0;\n });\n async function open(_options = {}) {\n if (!isSupported.value)\n return;\n const [handle] = await window.showOpenFilePicker({ ...toValue(options), ..._options });\n fileHandle.value = handle;\n await updateData();\n }\n async function create(_options = {}) {\n if (!isSupported.value)\n return;\n fileHandle.value = await window.showSaveFilePicker({ ...options, ..._options });\n data.value = void 0;\n await updateData();\n }\n async function save(_options = {}) {\n if (!isSupported.value)\n return;\n if (!fileHandle.value)\n return saveAs(_options);\n if (data.value) {\n const writableStream = await fileHandle.value.createWritable();\n await writableStream.write(data.value);\n await writableStream.close();\n }\n await updateFile();\n }\n async function saveAs(_options = {}) {\n if (!isSupported.value)\n return;\n fileHandle.value = await window.showSaveFilePicker({ ...options, ..._options });\n if (data.value) {\n const writableStream = await fileHandle.value.createWritable();\n await writableStream.write(data.value);\n await writableStream.close();\n }\n await updateFile();\n }\n async function updateFile() {\n var _a;\n file.value = await ((_a = fileHandle.value) == null ? void 0 : _a.getFile());\n }\n async function updateData() {\n var _a, _b;\n await updateFile();\n const type = toValue(dataType);\n if (type === \"Text\")\n data.value = await ((_a = file.value) == null ? void 0 : _a.text());\n else if (type === \"ArrayBuffer\")\n data.value = await ((_b = file.value) == null ? void 0 : _b.arrayBuffer());\n else if (type === \"Blob\")\n data.value = file.value;\n }\n watch(() => toValue(dataType), updateData);\n return {\n isSupported,\n data,\n file,\n fileName,\n fileMIME,\n fileSize,\n fileLastModified,\n open,\n create,\n save,\n saveAs,\n updateData\n };\n}\n\nfunction useFocus(target, options = {}) {\n const { initialValue = false, focusVisible = false, preventScroll = false } = options;\n const innerFocused = ref(false);\n const targetElement = computed(() => unrefElement(target));\n useEventListener(targetElement, \"focus\", (event) => {\n var _a, _b;\n if (!focusVisible || ((_b = (_a = event.target).matches) == null ? void 0 : _b.call(_a, \":focus-visible\")))\n innerFocused.value = true;\n });\n useEventListener(targetElement, \"blur\", () => innerFocused.value = false);\n const focused = computed({\n get: () => innerFocused.value,\n set(value) {\n var _a, _b;\n if (!value && innerFocused.value)\n (_a = targetElement.value) == null ? void 0 : _a.blur();\n else if (value && !innerFocused.value)\n (_b = targetElement.value) == null ? void 0 : _b.focus({ preventScroll });\n }\n });\n watch(\n targetElement,\n () => {\n focused.value = initialValue;\n },\n { immediate: true, flush: \"post\" }\n );\n return { focused };\n}\n\nconst EVENT_FOCUS_IN = \"focusin\";\nconst EVENT_FOCUS_OUT = \"focusout\";\nfunction useFocusWithin(target, options = {}) {\n const { window = defaultWindow } = options;\n const targetElement = computed(() => unrefElement(target));\n const _focused = ref(false);\n const focused = computed(() => _focused.value);\n const activeElement = useActiveElement(options);\n if (!window || !activeElement.value) {\n return { focused };\n }\n useEventListener(targetElement, EVENT_FOCUS_IN, () => _focused.value = true);\n useEventListener(targetElement, EVENT_FOCUS_OUT, () => _focused.value = false);\n return { focused };\n}\n\nfunction useFps(options) {\n var _a;\n const fps = ref(0);\n if (typeof performance === \"undefined\")\n return fps;\n const every = (_a = options == null ? void 0 : options.every) != null ? _a : 10;\n let last = performance.now();\n let ticks = 0;\n useRafFn(() => {\n ticks += 1;\n if (ticks >= every) {\n const now = performance.now();\n const diff = now - last;\n fps.value = Math.round(1e3 / (diff / ticks));\n last = now;\n ticks = 0;\n }\n });\n return fps;\n}\n\nconst eventHandlers = [\n \"fullscreenchange\",\n \"webkitfullscreenchange\",\n \"webkitendfullscreen\",\n \"mozfullscreenchange\",\n \"MSFullscreenChange\"\n];\nfunction useFullscreen(target, options = {}) {\n const {\n document = defaultDocument,\n autoExit = false\n } = options;\n const targetRef = computed(() => {\n var _a;\n return (_a = unrefElement(target)) != null ? _a : document == null ? void 0 : document.querySelector(\"html\");\n });\n const isFullscreen = ref(false);\n const requestMethod = computed(() => {\n return [\n \"requestFullscreen\",\n \"webkitRequestFullscreen\",\n \"webkitEnterFullscreen\",\n \"webkitEnterFullScreen\",\n \"webkitRequestFullScreen\",\n \"mozRequestFullScreen\",\n \"msRequestFullscreen\"\n ].find((m) => document && m in document || targetRef.value && m in targetRef.value);\n });\n const exitMethod = computed(() => {\n return [\n \"exitFullscreen\",\n \"webkitExitFullscreen\",\n \"webkitExitFullScreen\",\n \"webkitCancelFullScreen\",\n \"mozCancelFullScreen\",\n \"msExitFullscreen\"\n ].find((m) => document && m in document || targetRef.value && m in targetRef.value);\n });\n const fullscreenEnabled = computed(() => {\n return [\n \"fullScreen\",\n \"webkitIsFullScreen\",\n \"webkitDisplayingFullscreen\",\n \"mozFullScreen\",\n \"msFullscreenElement\"\n ].find((m) => document && m in document || targetRef.value && m in targetRef.value);\n });\n const fullscreenElementMethod = [\n \"fullscreenElement\",\n \"webkitFullscreenElement\",\n \"mozFullScreenElement\",\n \"msFullscreenElement\"\n ].find((m) => document && m in document);\n const isSupported = useSupported(() => targetRef.value && document && requestMethod.value !== void 0 && exitMethod.value !== void 0 && fullscreenEnabled.value !== void 0);\n const isCurrentElementFullScreen = () => {\n if (fullscreenElementMethod)\n return (document == null ? void 0 : document[fullscreenElementMethod]) === targetRef.value;\n return false;\n };\n const isElementFullScreen = () => {\n if (fullscreenEnabled.value) {\n if (document && document[fullscreenEnabled.value] != null) {\n return document[fullscreenEnabled.value];\n } else {\n const target2 = targetRef.value;\n if ((target2 == null ? void 0 : target2[fullscreenEnabled.value]) != null) {\n return Boolean(target2[fullscreenEnabled.value]);\n }\n }\n }\n return false;\n };\n async function exit() {\n if (!isSupported.value || !isFullscreen.value)\n return;\n if (exitMethod.value) {\n if ((document == null ? void 0 : document[exitMethod.value]) != null) {\n await document[exitMethod.value]();\n } else {\n const target2 = targetRef.value;\n if ((target2 == null ? void 0 : target2[exitMethod.value]) != null)\n await target2[exitMethod.value]();\n }\n }\n isFullscreen.value = false;\n }\n async function enter() {\n if (!isSupported.value || isFullscreen.value)\n return;\n if (isElementFullScreen())\n await exit();\n const target2 = targetRef.value;\n if (requestMethod.value && (target2 == null ? void 0 : target2[requestMethod.value]) != null) {\n await target2[requestMethod.value]();\n isFullscreen.value = true;\n }\n }\n async function toggle() {\n await (isFullscreen.value ? exit() : enter());\n }\n const handlerCallback = () => {\n const isElementFullScreenValue = isElementFullScreen();\n if (!isElementFullScreenValue || isElementFullScreenValue && isCurrentElementFullScreen())\n isFullscreen.value = isElementFullScreenValue;\n };\n useEventListener(document, eventHandlers, handlerCallback, false);\n useEventListener(() => unrefElement(targetRef), eventHandlers, handlerCallback, false);\n if (autoExit)\n tryOnScopeDispose(exit);\n return {\n isSupported,\n isFullscreen,\n enter,\n exit,\n toggle\n };\n}\n\nfunction mapGamepadToXbox360Controller(gamepad) {\n return computed(() => {\n if (gamepad.value) {\n return {\n buttons: {\n a: gamepad.value.buttons[0],\n b: gamepad.value.buttons[1],\n x: gamepad.value.buttons[2],\n y: gamepad.value.buttons[3]\n },\n bumper: {\n left: gamepad.value.buttons[4],\n right: gamepad.value.buttons[5]\n },\n triggers: {\n left: gamepad.value.buttons[6],\n right: gamepad.value.buttons[7]\n },\n stick: {\n left: {\n horizontal: gamepad.value.axes[0],\n vertical: gamepad.value.axes[1],\n button: gamepad.value.buttons[10]\n },\n right: {\n horizontal: gamepad.value.axes[2],\n vertical: gamepad.value.axes[3],\n button: gamepad.value.buttons[11]\n }\n },\n dpad: {\n up: gamepad.value.buttons[12],\n down: gamepad.value.buttons[13],\n left: gamepad.value.buttons[14],\n right: gamepad.value.buttons[15]\n },\n back: gamepad.value.buttons[8],\n start: gamepad.value.buttons[9]\n };\n }\n return null;\n });\n}\nfunction useGamepad(options = {}) {\n const {\n navigator = defaultNavigator\n } = options;\n const isSupported = useSupported(() => navigator && \"getGamepads\" in navigator);\n const gamepads = ref([]);\n const onConnectedHook = createEventHook();\n const onDisconnectedHook = createEventHook();\n const stateFromGamepad = (gamepad) => {\n const hapticActuators = [];\n const vibrationActuator = \"vibrationActuator\" in gamepad ? gamepad.vibrationActuator : null;\n if (vibrationActuator)\n hapticActuators.push(vibrationActuator);\n if (gamepad.hapticActuators)\n hapticActuators.push(...gamepad.hapticActuators);\n return {\n id: gamepad.id,\n index: gamepad.index,\n connected: gamepad.connected,\n mapping: gamepad.mapping,\n timestamp: gamepad.timestamp,\n vibrationActuator: gamepad.vibrationActuator,\n hapticActuators,\n axes: gamepad.axes.map((axes) => axes),\n buttons: gamepad.buttons.map((button) => ({ pressed: button.pressed, touched: button.touched, value: button.value }))\n };\n };\n const updateGamepadState = () => {\n const _gamepads = (navigator == null ? void 0 : navigator.getGamepads()) || [];\n for (const gamepad of _gamepads) {\n if (gamepad && gamepads.value[gamepad.index])\n gamepads.value[gamepad.index] = stateFromGamepad(gamepad);\n }\n };\n const { isActive, pause, resume } = useRafFn(updateGamepadState);\n const onGamepadConnected = (gamepad) => {\n if (!gamepads.value.some(({ index }) => index === gamepad.index)) {\n gamepads.value.push(stateFromGamepad(gamepad));\n onConnectedHook.trigger(gamepad.index);\n }\n resume();\n };\n const onGamepadDisconnected = (gamepad) => {\n gamepads.value = gamepads.value.filter((x) => x.index !== gamepad.index);\n onDisconnectedHook.trigger(gamepad.index);\n };\n useEventListener(\"gamepadconnected\", (e) => onGamepadConnected(e.gamepad));\n useEventListener(\"gamepaddisconnected\", (e) => onGamepadDisconnected(e.gamepad));\n tryOnMounted(() => {\n const _gamepads = (navigator == null ? void 0 : navigator.getGamepads()) || [];\n for (const gamepad of _gamepads) {\n if (gamepad && gamepads.value[gamepad.index])\n onGamepadConnected(gamepad);\n }\n });\n pause();\n return {\n isSupported,\n onConnected: onConnectedHook.on,\n onDisconnected: onDisconnectedHook.on,\n gamepads,\n pause,\n resume,\n isActive\n };\n}\n\nfunction useGeolocation(options = {}) {\n const {\n enableHighAccuracy = true,\n maximumAge = 3e4,\n timeout = 27e3,\n navigator = defaultNavigator,\n immediate = true\n } = options;\n const isSupported = useSupported(() => navigator && \"geolocation\" in navigator);\n const locatedAt = ref(null);\n const error = shallowRef(null);\n const coords = ref({\n accuracy: 0,\n latitude: Number.POSITIVE_INFINITY,\n longitude: Number.POSITIVE_INFINITY,\n altitude: null,\n altitudeAccuracy: null,\n heading: null,\n speed: null\n });\n function updatePosition(position) {\n locatedAt.value = position.timestamp;\n coords.value = position.coords;\n error.value = null;\n }\n let watcher;\n function resume() {\n if (isSupported.value) {\n watcher = navigator.geolocation.watchPosition(\n updatePosition,\n (err) => error.value = err,\n {\n enableHighAccuracy,\n maximumAge,\n timeout\n }\n );\n }\n }\n if (immediate)\n resume();\n function pause() {\n if (watcher && navigator)\n navigator.geolocation.clearWatch(watcher);\n }\n tryOnScopeDispose(() => {\n pause();\n });\n return {\n isSupported,\n coords,\n locatedAt,\n error,\n resume,\n pause\n };\n}\n\nconst defaultEvents$1 = [\"mousemove\", \"mousedown\", \"resize\", \"keydown\", \"touchstart\", \"wheel\"];\nconst oneMinute = 6e4;\nfunction useIdle(timeout = oneMinute, options = {}) {\n const {\n initialState = false,\n listenForVisibilityChange = true,\n events = defaultEvents$1,\n window = defaultWindow,\n eventFilter = throttleFilter(50)\n } = options;\n const idle = ref(initialState);\n const lastActive = ref(timestamp());\n let timer;\n const reset = () => {\n idle.value = false;\n clearTimeout(timer);\n timer = setTimeout(() => idle.value = true, timeout);\n };\n const onEvent = createFilterWrapper(\n eventFilter,\n () => {\n lastActive.value = timestamp();\n reset();\n }\n );\n if (window) {\n const document = window.document;\n for (const event of events)\n useEventListener(window, event, onEvent, { passive: true });\n if (listenForVisibilityChange) {\n useEventListener(document, \"visibilitychange\", () => {\n if (!document.hidden)\n onEvent();\n });\n }\n reset();\n }\n return {\n idle,\n lastActive,\n reset\n };\n}\n\nasync function loadImage(options) {\n return new Promise((resolve, reject) => {\n const img = new Image();\n const { src, srcset, sizes, class: clazz, loading, crossorigin, referrerPolicy } = options;\n img.src = src;\n if (srcset)\n img.srcset = srcset;\n if (sizes)\n img.sizes = sizes;\n if (clazz)\n img.className = clazz;\n if (loading)\n img.loading = loading;\n if (crossorigin)\n img.crossOrigin = crossorigin;\n if (referrerPolicy)\n img.referrerPolicy = referrerPolicy;\n img.onload = () => resolve(img);\n img.onerror = reject;\n });\n}\nfunction useImage(options, asyncStateOptions = {}) {\n const state = useAsyncState(\n () => loadImage(toValue(options)),\n void 0,\n {\n resetOnExecute: true,\n ...asyncStateOptions\n }\n );\n watch(\n () => toValue(options),\n () => state.execute(asyncStateOptions.delay),\n { deep: true }\n );\n return state;\n}\n\nfunction resolveElement(el) {\n if (typeof Window !== \"undefined\" && el instanceof Window)\n return el.document.documentElement;\n if (typeof Document !== \"undefined\" && el instanceof Document)\n return el.documentElement;\n return el;\n}\n\nconst ARRIVED_STATE_THRESHOLD_PIXELS = 1;\nfunction useScroll(element, options = {}) {\n const {\n throttle = 0,\n idle = 200,\n onStop = noop,\n onScroll = noop,\n offset = {\n left: 0,\n right: 0,\n top: 0,\n bottom: 0\n },\n eventListenerOptions = {\n capture: false,\n passive: true\n },\n behavior = \"auto\",\n window = defaultWindow,\n onError = (e) => {\n console.error(e);\n }\n } = options;\n const internalX = ref(0);\n const internalY = ref(0);\n const x = computed({\n get() {\n return internalX.value;\n },\n set(x2) {\n scrollTo(x2, void 0);\n }\n });\n const y = computed({\n get() {\n return internalY.value;\n },\n set(y2) {\n scrollTo(void 0, y2);\n }\n });\n function scrollTo(_x, _y) {\n var _a, _b, _c, _d;\n if (!window)\n return;\n const _element = toValue(element);\n if (!_element)\n return;\n (_c = _element instanceof Document ? window.document.body : _element) == null ? void 0 : _c.scrollTo({\n top: (_a = toValue(_y)) != null ? _a : y.value,\n left: (_b = toValue(_x)) != null ? _b : x.value,\n behavior: toValue(behavior)\n });\n const scrollContainer = ((_d = _element == null ? void 0 : _element.document) == null ? void 0 : _d.documentElement) || (_element == null ? void 0 : _element.documentElement) || _element;\n if (x != null)\n internalX.value = scrollContainer.scrollLeft;\n if (y != null)\n internalY.value = scrollContainer.scrollTop;\n }\n const isScrolling = ref(false);\n const arrivedState = reactive({\n left: true,\n right: false,\n top: true,\n bottom: false\n });\n const directions = reactive({\n left: false,\n right: false,\n top: false,\n bottom: false\n });\n const onScrollEnd = (e) => {\n if (!isScrolling.value)\n return;\n isScrolling.value = false;\n directions.left = false;\n directions.right = false;\n directions.top = false;\n directions.bottom = false;\n onStop(e);\n };\n const onScrollEndDebounced = useDebounceFn(onScrollEnd, throttle + idle);\n const setArrivedState = (target) => {\n var _a;\n if (!window)\n return;\n const el = ((_a = target == null ? void 0 : target.document) == null ? void 0 : _a.documentElement) || (target == null ? void 0 : target.documentElement) || unrefElement(target);\n const { display, flexDirection } = getComputedStyle(el);\n const scrollLeft = el.scrollLeft;\n directions.left = scrollLeft < internalX.value;\n directions.right = scrollLeft > internalX.value;\n const left = Math.abs(scrollLeft) <= (offset.left || 0);\n const right = Math.abs(scrollLeft) + el.clientWidth >= el.scrollWidth - (offset.right || 0) - ARRIVED_STATE_THRESHOLD_PIXELS;\n if (display === \"flex\" && flexDirection === \"row-reverse\") {\n arrivedState.left = right;\n arrivedState.right = left;\n } else {\n arrivedState.left = left;\n arrivedState.right = right;\n }\n internalX.value = scrollLeft;\n let scrollTop = el.scrollTop;\n if (target === window.document && !scrollTop)\n scrollTop = window.document.body.scrollTop;\n directions.top = scrollTop < internalY.value;\n directions.bottom = scrollTop > internalY.value;\n const top = Math.abs(scrollTop) <= (offset.top || 0);\n const bottom = Math.abs(scrollTop) + el.clientHeight >= el.scrollHeight - (offset.bottom || 0) - ARRIVED_STATE_THRESHOLD_PIXELS;\n if (display === \"flex\" && flexDirection === \"column-reverse\") {\n arrivedState.top = bottom;\n arrivedState.bottom = top;\n } else {\n arrivedState.top = top;\n arrivedState.bottom = bottom;\n }\n internalY.value = scrollTop;\n };\n const onScrollHandler = (e) => {\n var _a;\n if (!window)\n return;\n const eventTarget = (_a = e.target.documentElement) != null ? _a : e.target;\n setArrivedState(eventTarget);\n isScrolling.value = true;\n onScrollEndDebounced(e);\n onScroll(e);\n };\n useEventListener(\n element,\n \"scroll\",\n throttle ? useThrottleFn(onScrollHandler, throttle, true, false) : onScrollHandler,\n eventListenerOptions\n );\n tryOnMounted(() => {\n try {\n const _element = toValue(element);\n if (!_element)\n return;\n setArrivedState(_element);\n } catch (e) {\n onError(e);\n }\n });\n useEventListener(\n element,\n \"scrollend\",\n onScrollEnd,\n eventListenerOptions\n );\n return {\n x,\n y,\n isScrolling,\n arrivedState,\n directions,\n measure() {\n const _element = toValue(element);\n if (window && _element)\n setArrivedState(_element);\n }\n };\n}\n\nfunction useInfiniteScroll(element, onLoadMore, options = {}) {\n var _a;\n const {\n direction = \"bottom\",\n interval = 100,\n canLoadMore = () => true\n } = options;\n const state = reactive(useScroll(\n element,\n {\n ...options,\n offset: {\n [direction]: (_a = options.distance) != null ? _a : 0,\n ...options.offset\n }\n }\n ));\n const promise = ref();\n const isLoading = computed(() => !!promise.value);\n const observedElement = computed(() => {\n return resolveElement(toValue(element));\n });\n const isElementVisible = useElementVisibility(observedElement);\n function checkAndLoad() {\n state.measure();\n if (!observedElement.value || !isElementVisible.value || !canLoadMore(observedElement.value))\n return;\n const { scrollHeight, clientHeight, scrollWidth, clientWidth } = observedElement.value;\n const isNarrower = direction === \"bottom\" || direction === \"top\" ? scrollHeight <= clientHeight : scrollWidth <= clientWidth;\n if (state.arrivedState[direction] || isNarrower) {\n if (!promise.value) {\n promise.value = Promise.all([\n onLoadMore(state),\n new Promise((resolve) => setTimeout(resolve, interval))\n ]).finally(() => {\n promise.value = null;\n nextTick(() => checkAndLoad());\n });\n }\n }\n }\n const stop = watch(\n () => [state.arrivedState[direction], isElementVisible.value],\n checkAndLoad,\n { immediate: true }\n );\n tryOnUnmounted(stop);\n return {\n isLoading,\n reset() {\n nextTick(() => checkAndLoad());\n }\n };\n}\n\nconst defaultEvents = [\"mousedown\", \"mouseup\", \"keydown\", \"keyup\"];\nfunction useKeyModifier(modifier, options = {}) {\n const {\n events = defaultEvents,\n document = defaultDocument,\n initial = null\n } = options;\n const state = ref(initial);\n if (document) {\n events.forEach((listenerEvent) => {\n useEventListener(document, listenerEvent, (evt) => {\n if (typeof evt.getModifierState === \"function\")\n state.value = evt.getModifierState(modifier);\n });\n });\n }\n return state;\n}\n\nfunction useLocalStorage(key, initialValue, options = {}) {\n const { window = defaultWindow } = options;\n return useStorage(key, initialValue, window == null ? void 0 : window.localStorage, options);\n}\n\nconst DefaultMagicKeysAliasMap = {\n ctrl: \"control\",\n command: \"meta\",\n cmd: \"meta\",\n option: \"alt\",\n up: \"arrowup\",\n down: \"arrowdown\",\n left: \"arrowleft\",\n right: \"arrowright\"\n};\n\nfunction useMagicKeys(options = {}) {\n const {\n reactive: useReactive = false,\n target = defaultWindow,\n aliasMap = DefaultMagicKeysAliasMap,\n passive = true,\n onEventFired = noop\n } = options;\n const current = reactive(/* @__PURE__ */ new Set());\n const obj = {\n toJSON() {\n return {};\n },\n current\n };\n const refs = useReactive ? reactive(obj) : obj;\n const metaDeps = /* @__PURE__ */ new Set();\n const usedKeys = /* @__PURE__ */ new Set();\n function setRefs(key, value) {\n if (key in refs) {\n if (useReactive)\n refs[key] = value;\n else\n refs[key].value = value;\n }\n }\n function reset() {\n current.clear();\n for (const key of usedKeys)\n setRefs(key, false);\n }\n function updateRefs(e, value) {\n var _a, _b;\n const key = (_a = e.key) == null ? void 0 : _a.toLowerCase();\n const code = (_b = e.code) == null ? void 0 : _b.toLowerCase();\n const values = [code, key].filter(Boolean);\n if (key) {\n if (value)\n current.add(key);\n else\n current.delete(key);\n }\n for (const key2 of values) {\n usedKeys.add(key2);\n setRefs(key2, value);\n }\n if (key === \"meta\" && !value) {\n metaDeps.forEach((key2) => {\n current.delete(key2);\n setRefs(key2, false);\n });\n metaDeps.clear();\n } else if (typeof e.getModifierState === \"function\" && e.getModifierState(\"Meta\") && value) {\n [...current, ...values].forEach((key2) => metaDeps.add(key2));\n }\n }\n useEventListener(target, \"keydown\", (e) => {\n updateRefs(e, true);\n return onEventFired(e);\n }, { passive });\n useEventListener(target, \"keyup\", (e) => {\n updateRefs(e, false);\n return onEventFired(e);\n }, { passive });\n useEventListener(\"blur\", reset, { passive: true });\n useEventListener(\"focus\", reset, { passive: true });\n const proxy = new Proxy(\n refs,\n {\n get(target2, prop, rec) {\n if (typeof prop !== \"string\")\n return Reflect.get(target2, prop, rec);\n prop = prop.toLowerCase();\n if (prop in aliasMap)\n prop = aliasMap[prop];\n if (!(prop in refs)) {\n if (/[+_-]/.test(prop)) {\n const keys = prop.split(/[+_-]/g).map((i) => i.trim());\n refs[prop] = computed(() => keys.every((key) => toValue(proxy[key])));\n } else {\n refs[prop] = ref(false);\n }\n }\n const r = Reflect.get(target2, prop, rec);\n return useReactive ? toValue(r) : r;\n }\n }\n );\n return proxy;\n}\n\nfunction usingElRef(source, cb) {\n if (toValue(source))\n cb(toValue(source));\n}\nfunction timeRangeToArray(timeRanges) {\n let ranges = [];\n for (let i = 0; i < timeRanges.length; ++i)\n ranges = [...ranges, [timeRanges.start(i), timeRanges.end(i)]];\n return ranges;\n}\nfunction tracksToArray(tracks) {\n return Array.from(tracks).map(({ label, kind, language, mode, activeCues, cues, inBandMetadataTrackDispatchType }, id) => ({ id, label, kind, language, mode, activeCues, cues, inBandMetadataTrackDispatchType }));\n}\nconst defaultOptions = {\n src: \"\",\n tracks: []\n};\nfunction useMediaControls(target, options = {}) {\n target = toRef(target);\n options = {\n ...defaultOptions,\n ...options\n };\n const {\n document = defaultDocument\n } = options;\n const currentTime = ref(0);\n const duration = ref(0);\n const seeking = ref(false);\n const volume = ref(1);\n const waiting = ref(false);\n const ended = ref(false);\n const playing = ref(false);\n const rate = ref(1);\n const stalled = ref(false);\n const buffered = ref([]);\n const tracks = ref([]);\n const selectedTrack = ref(-1);\n const isPictureInPicture = ref(false);\n const muted = ref(false);\n const supportsPictureInPicture = document && \"pictureInPictureEnabled\" in document;\n const sourceErrorEvent = createEventHook();\n const playbackErrorEvent = createEventHook();\n const disableTrack = (track) => {\n usingElRef(target, (el) => {\n if (track) {\n const id = typeof track === \"number\" ? track : track.id;\n el.textTracks[id].mode = \"disabled\";\n } else {\n for (let i = 0; i < el.textTracks.length; ++i)\n el.textTracks[i].mode = \"disabled\";\n }\n selectedTrack.value = -1;\n });\n };\n const enableTrack = (track, disableTracks = true) => {\n usingElRef(target, (el) => {\n const id = typeof track === \"number\" ? track : track.id;\n if (disableTracks)\n disableTrack();\n el.textTracks[id].mode = \"showing\";\n selectedTrack.value = id;\n });\n };\n const togglePictureInPicture = () => {\n return new Promise((resolve, reject) => {\n usingElRef(target, async (el) => {\n if (supportsPictureInPicture) {\n if (!isPictureInPicture.value) {\n el.requestPictureInPicture().then(resolve).catch(reject);\n } else {\n document.exitPictureInPicture().then(resolve).catch(reject);\n }\n }\n });\n });\n };\n watchEffect(() => {\n if (!document)\n return;\n const el = toValue(target);\n if (!el)\n return;\n const src = toValue(options.src);\n let sources = [];\n if (!src)\n return;\n if (typeof src === \"string\")\n sources = [{ src }];\n else if (Array.isArray(src))\n sources = src;\n else if (isObject(src))\n sources = [src];\n el.querySelectorAll(\"source\").forEach((e) => {\n e.removeEventListener(\"error\", sourceErrorEvent.trigger);\n e.remove();\n });\n sources.forEach(({ src: src2, type }) => {\n const source = document.createElement(\"source\");\n source.setAttribute(\"src\", src2);\n source.setAttribute(\"type\", type || \"\");\n source.addEventListener(\"error\", sourceErrorEvent.trigger);\n el.appendChild(source);\n });\n el.load();\n });\n tryOnScopeDispose(() => {\n const el = toValue(target);\n if (!el)\n return;\n el.querySelectorAll(\"source\").forEach((e) => e.removeEventListener(\"error\", sourceErrorEvent.trigger));\n });\n watch([target, volume], () => {\n const el = toValue(target);\n if (!el)\n return;\n el.volume = volume.value;\n });\n watch([target, muted], () => {\n const el = toValue(target);\n if (!el)\n return;\n el.muted = muted.value;\n });\n watch([target, rate], () => {\n const el = toValue(target);\n if (!el)\n return;\n el.playbackRate = rate.value;\n });\n watchEffect(() => {\n if (!document)\n return;\n const textTracks = toValue(options.tracks);\n const el = toValue(target);\n if (!textTracks || !textTracks.length || !el)\n return;\n el.querySelectorAll(\"track\").forEach((e) => e.remove());\n textTracks.forEach(({ default: isDefault, kind, label, src, srcLang }, i) => {\n const track = document.createElement(\"track\");\n track.default = isDefault || false;\n track.kind = kind;\n track.label = label;\n track.src = src;\n track.srclang = srcLang;\n if (track.default)\n selectedTrack.value = i;\n el.appendChild(track);\n });\n });\n const { ignoreUpdates: ignoreCurrentTimeUpdates } = watchIgnorable(currentTime, (time) => {\n const el = toValue(target);\n if (!el)\n return;\n el.currentTime = time;\n });\n const { ignoreUpdates: ignorePlayingUpdates } = watchIgnorable(playing, (isPlaying) => {\n const el = toValue(target);\n if (!el)\n return;\n if (isPlaying) {\n el.play().catch((e) => {\n playbackErrorEvent.trigger(e);\n throw e;\n });\n } else {\n el.pause();\n }\n });\n useEventListener(target, \"timeupdate\", () => ignoreCurrentTimeUpdates(() => currentTime.value = toValue(target).currentTime));\n useEventListener(target, \"durationchange\", () => duration.value = toValue(target).duration);\n useEventListener(target, \"progress\", () => buffered.value = timeRangeToArray(toValue(target).buffered));\n useEventListener(target, \"seeking\", () => seeking.value = true);\n useEventListener(target, \"seeked\", () => seeking.value = false);\n useEventListener(target, [\"waiting\", \"loadstart\"], () => {\n waiting.value = true;\n ignorePlayingUpdates(() => playing.value = false);\n });\n useEventListener(target, \"loadeddata\", () => waiting.value = false);\n useEventListener(target, \"playing\", () => {\n waiting.value = false;\n ended.value = false;\n ignorePlayingUpdates(() => playing.value = true);\n });\n useEventListener(target, \"ratechange\", () => rate.value = toValue(target).playbackRate);\n useEventListener(target, \"stalled\", () => stalled.value = true);\n useEventListener(target, \"ended\", () => ended.value = true);\n useEventListener(target, \"pause\", () => ignorePlayingUpdates(() => playing.value = false));\n useEventListener(target, \"play\", () => ignorePlayingUpdates(() => playing.value = true));\n useEventListener(target, \"enterpictureinpicture\", () => isPictureInPicture.value = true);\n useEventListener(target, \"leavepictureinpicture\", () => isPictureInPicture.value = false);\n useEventListener(target, \"volumechange\", () => {\n const el = toValue(target);\n if (!el)\n return;\n volume.value = el.volume;\n muted.value = el.muted;\n });\n const listeners = [];\n const stop = watch([target], () => {\n const el = toValue(target);\n if (!el)\n return;\n stop();\n listeners[0] = useEventListener(el.textTracks, \"addtrack\", () => tracks.value = tracksToArray(el.textTracks));\n listeners[1] = useEventListener(el.textTracks, \"removetrack\", () => tracks.value = tracksToArray(el.textTracks));\n listeners[2] = useEventListener(el.textTracks, \"change\", () => tracks.value = tracksToArray(el.textTracks));\n });\n tryOnScopeDispose(() => listeners.forEach((listener) => listener()));\n return {\n currentTime,\n duration,\n waiting,\n seeking,\n ended,\n stalled,\n buffered,\n playing,\n rate,\n // Volume\n volume,\n muted,\n // Tracks\n tracks,\n selectedTrack,\n enableTrack,\n disableTrack,\n // Picture in Picture\n supportsPictureInPicture,\n togglePictureInPicture,\n isPictureInPicture,\n // Events\n onSourceError: sourceErrorEvent.on,\n onPlaybackError: playbackErrorEvent.on\n };\n}\n\nfunction useMemoize(resolver, options) {\n const initCache = () => {\n if (options == null ? void 0 : options.cache)\n return shallowReactive(options.cache);\n return shallowReactive(/* @__PURE__ */ new Map());\n };\n const cache = initCache();\n const generateKey = (...args) => (options == null ? void 0 : options.getKey) ? options.getKey(...args) : JSON.stringify(args);\n const _loadData = (key, ...args) => {\n cache.set(key, resolver(...args));\n return cache.get(key);\n };\n const loadData = (...args) => _loadData(generateKey(...args), ...args);\n const deleteData = (...args) => {\n cache.delete(generateKey(...args));\n };\n const clearData = () => {\n cache.clear();\n };\n const memoized = (...args) => {\n const key = generateKey(...args);\n if (cache.has(key))\n return cache.get(key);\n return _loadData(key, ...args);\n };\n memoized.load = loadData;\n memoized.delete = deleteData;\n memoized.clear = clearData;\n memoized.generateKey = generateKey;\n memoized.cache = cache;\n return memoized;\n}\n\nfunction useMemory(options = {}) {\n const memory = ref();\n const isSupported = useSupported(() => typeof performance !== \"undefined\" && \"memory\" in performance);\n if (isSupported.value) {\n const { interval = 1e3 } = options;\n useIntervalFn(() => {\n memory.value = performance.memory;\n }, interval, { immediate: options.immediate, immediateCallback: options.immediateCallback });\n }\n return { isSupported, memory };\n}\n\nconst UseMouseBuiltinExtractors = {\n page: (event) => [event.pageX, event.pageY],\n client: (event) => [event.clientX, event.clientY],\n screen: (event) => [event.screenX, event.screenY],\n movement: (event) => event instanceof Touch ? null : [event.movementX, event.movementY]\n};\nfunction useMouse(options = {}) {\n const {\n type = \"page\",\n touch = true,\n resetOnTouchEnds = false,\n initialValue = { x: 0, y: 0 },\n window = defaultWindow,\n target = window,\n scroll = true,\n eventFilter\n } = options;\n let _prevMouseEvent = null;\n let _prevScrollX = 0;\n let _prevScrollY = 0;\n const x = ref(initialValue.x);\n const y = ref(initialValue.y);\n const sourceType = ref(null);\n const extractor = typeof type === \"function\" ? type : UseMouseBuiltinExtractors[type];\n const mouseHandler = (event) => {\n const result = extractor(event);\n _prevMouseEvent = event;\n if (result) {\n [x.value, y.value] = result;\n sourceType.value = \"mouse\";\n }\n if (window) {\n _prevScrollX = window.scrollX;\n _prevScrollY = window.scrollY;\n }\n };\n const touchHandler = (event) => {\n if (event.touches.length > 0) {\n const result = extractor(event.touches[0]);\n if (result) {\n [x.value, y.value] = result;\n sourceType.value = \"touch\";\n }\n }\n };\n const scrollHandler = () => {\n if (!_prevMouseEvent || !window)\n return;\n const pos = extractor(_prevMouseEvent);\n if (_prevMouseEvent instanceof MouseEvent && pos) {\n x.value = pos[0] + window.scrollX - _prevScrollX;\n y.value = pos[1] + window.scrollY - _prevScrollY;\n }\n };\n const reset = () => {\n x.value = initialValue.x;\n y.value = initialValue.y;\n };\n const mouseHandlerWrapper = eventFilter ? (event) => eventFilter(() => mouseHandler(event), {}) : (event) => mouseHandler(event);\n const touchHandlerWrapper = eventFilter ? (event) => eventFilter(() => touchHandler(event), {}) : (event) => touchHandler(event);\n const scrollHandlerWrapper = eventFilter ? () => eventFilter(() => scrollHandler(), {}) : () => scrollHandler();\n if (target) {\n const listenerOptions = { passive: true };\n useEventListener(target, [\"mousemove\", \"dragover\"], mouseHandlerWrapper, listenerOptions);\n if (touch && type !== \"movement\") {\n useEventListener(target, [\"touchstart\", \"touchmove\"], touchHandlerWrapper, listenerOptions);\n if (resetOnTouchEnds)\n useEventListener(target, \"touchend\", reset, listenerOptions);\n }\n if (scroll && type === \"page\")\n useEventListener(window, \"scroll\", scrollHandlerWrapper, { passive: true });\n }\n return {\n x,\n y,\n sourceType\n };\n}\n\nfunction useMouseInElement(target, options = {}) {\n const {\n handleOutside = true,\n window = defaultWindow\n } = options;\n const type = options.type || \"page\";\n const { x, y, sourceType } = useMouse(options);\n const targetRef = ref(target != null ? target : window == null ? void 0 : window.document.body);\n const elementX = ref(0);\n const elementY = ref(0);\n const elementPositionX = ref(0);\n const elementPositionY = ref(0);\n const elementHeight = ref(0);\n const elementWidth = ref(0);\n const isOutside = ref(true);\n let stop = () => {\n };\n if (window) {\n stop = watch(\n [targetRef, x, y],\n () => {\n const el = unrefElement(targetRef);\n if (!el || !(el instanceof Element))\n return;\n const {\n left,\n top,\n width,\n height\n } = el.getBoundingClientRect();\n elementPositionX.value = left + (type === \"page\" ? window.pageXOffset : 0);\n elementPositionY.value = top + (type === \"page\" ? window.pageYOffset : 0);\n elementHeight.value = height;\n elementWidth.value = width;\n const elX = x.value - elementPositionX.value;\n const elY = y.value - elementPositionY.value;\n isOutside.value = width === 0 || height === 0 || elX < 0 || elY < 0 || elX > width || elY > height;\n if (handleOutside || !isOutside.value) {\n elementX.value = elX;\n elementY.value = elY;\n }\n },\n { immediate: true }\n );\n useEventListener(document, \"mouseleave\", () => {\n isOutside.value = true;\n });\n }\n return {\n x,\n y,\n sourceType,\n elementX,\n elementY,\n elementPositionX,\n elementPositionY,\n elementHeight,\n elementWidth,\n isOutside,\n stop\n };\n}\n\nfunction useMousePressed(options = {}) {\n const {\n touch = true,\n drag = true,\n capture = false,\n initialValue = false,\n window = defaultWindow\n } = options;\n const pressed = ref(initialValue);\n const sourceType = ref(null);\n if (!window) {\n return {\n pressed,\n sourceType\n };\n }\n const onPressed = (srcType) => () => {\n pressed.value = true;\n sourceType.value = srcType;\n };\n const onReleased = () => {\n pressed.value = false;\n sourceType.value = null;\n };\n const target = computed(() => unrefElement(options.target) || window);\n useEventListener(target, \"mousedown\", onPressed(\"mouse\"), { passive: true, capture });\n useEventListener(window, \"mouseleave\", onReleased, { passive: true, capture });\n useEventListener(window, \"mouseup\", onReleased, { passive: true, capture });\n if (drag) {\n useEventListener(target, \"dragstart\", onPressed(\"mouse\"), { passive: true, capture });\n useEventListener(window, \"drop\", onReleased, { passive: true, capture });\n useEventListener(window, \"dragend\", onReleased, { passive: true, capture });\n }\n if (touch) {\n useEventListener(target, \"touchstart\", onPressed(\"touch\"), { passive: true, capture });\n useEventListener(window, \"touchend\", onReleased, { passive: true, capture });\n useEventListener(window, \"touchcancel\", onReleased, { passive: true, capture });\n }\n return {\n pressed,\n sourceType\n };\n}\n\nfunction useNavigatorLanguage(options = {}) {\n const { window = defaultWindow } = options;\n const navigator = window == null ? void 0 : window.navigator;\n const isSupported = useSupported(() => navigator && \"language\" in navigator);\n const language = ref(navigator == null ? void 0 : navigator.language);\n useEventListener(window, \"languagechange\", () => {\n if (navigator)\n language.value = navigator.language;\n });\n return {\n isSupported,\n language\n };\n}\n\nfunction useNetwork(options = {}) {\n const { window = defaultWindow } = options;\n const navigator = window == null ? void 0 : window.navigator;\n const isSupported = useSupported(() => navigator && \"connection\" in navigator);\n const isOnline = ref(true);\n const saveData = ref(false);\n const offlineAt = ref(void 0);\n const onlineAt = ref(void 0);\n const downlink = ref(void 0);\n const downlinkMax = ref(void 0);\n const rtt = ref(void 0);\n const effectiveType = ref(void 0);\n const type = ref(\"unknown\");\n const connection = isSupported.value && navigator.connection;\n function updateNetworkInformation() {\n if (!navigator)\n return;\n isOnline.value = navigator.onLine;\n offlineAt.value = isOnline.value ? void 0 : Date.now();\n onlineAt.value = isOnline.value ? Date.now() : void 0;\n if (connection) {\n downlink.value = connection.downlink;\n downlinkMax.value = connection.downlinkMax;\n effectiveType.value = connection.effectiveType;\n rtt.value = connection.rtt;\n saveData.value = connection.saveData;\n type.value = connection.type;\n }\n }\n if (window) {\n useEventListener(window, \"offline\", () => {\n isOnline.value = false;\n offlineAt.value = Date.now();\n });\n useEventListener(window, \"online\", () => {\n isOnline.value = true;\n onlineAt.value = Date.now();\n });\n }\n if (connection)\n useEventListener(connection, \"change\", updateNetworkInformation, false);\n updateNetworkInformation();\n return {\n isSupported: readonly(isSupported),\n isOnline: readonly(isOnline),\n saveData: readonly(saveData),\n offlineAt: readonly(offlineAt),\n onlineAt: readonly(onlineAt),\n downlink: readonly(downlink),\n downlinkMax: readonly(downlinkMax),\n effectiveType: readonly(effectiveType),\n rtt: readonly(rtt),\n type: readonly(type)\n };\n}\n\nfunction useNow(options = {}) {\n const {\n controls: exposeControls = false,\n interval = \"requestAnimationFrame\"\n } = options;\n const now = ref(/* @__PURE__ */ new Date());\n const update = () => now.value = /* @__PURE__ */ new Date();\n const controls = interval === \"requestAnimationFrame\" ? useRafFn(update, { immediate: true }) : useIntervalFn(update, interval, { immediate: true });\n if (exposeControls) {\n return {\n now,\n ...controls\n };\n } else {\n return now;\n }\n}\n\nfunction useObjectUrl(object) {\n const url = ref();\n const release = () => {\n if (url.value)\n URL.revokeObjectURL(url.value);\n url.value = void 0;\n };\n watch(\n () => toValue(object),\n (newObject) => {\n release();\n if (newObject)\n url.value = URL.createObjectURL(newObject);\n },\n { immediate: true }\n );\n tryOnScopeDispose(release);\n return readonly(url);\n}\n\nfunction useClamp(value, min, max) {\n if (typeof value === \"function\" || isReadonly(value))\n return computed(() => clamp(toValue(value), toValue(min), toValue(max)));\n const _value = ref(value);\n return computed({\n get() {\n return _value.value = clamp(_value.value, toValue(min), toValue(max));\n },\n set(value2) {\n _value.value = clamp(value2, toValue(min), toValue(max));\n }\n });\n}\n\nfunction useOffsetPagination(options) {\n const {\n total = Number.POSITIVE_INFINITY,\n pageSize = 10,\n page = 1,\n onPageChange = noop,\n onPageSizeChange = noop,\n onPageCountChange = noop\n } = options;\n const currentPageSize = useClamp(pageSize, 1, Number.POSITIVE_INFINITY);\n const pageCount = computed(() => Math.max(\n 1,\n Math.ceil(toValue(total) / toValue(currentPageSize))\n ));\n const currentPage = useClamp(page, 1, pageCount);\n const isFirstPage = computed(() => currentPage.value === 1);\n const isLastPage = computed(() => currentPage.value === pageCount.value);\n if (isRef(page)) {\n syncRef(page, currentPage, {\n direction: isReadonly(page) ? \"ltr\" : \"both\"\n });\n }\n if (isRef(pageSize)) {\n syncRef(pageSize, currentPageSize, {\n direction: isReadonly(pageSize) ? \"ltr\" : \"both\"\n });\n }\n function prev() {\n currentPage.value--;\n }\n function next() {\n currentPage.value++;\n }\n const returnValue = {\n currentPage,\n currentPageSize,\n pageCount,\n isFirstPage,\n isLastPage,\n prev,\n next\n };\n watch(currentPage, () => {\n onPageChange(reactive(returnValue));\n });\n watch(currentPageSize, () => {\n onPageSizeChange(reactive(returnValue));\n });\n watch(pageCount, () => {\n onPageCountChange(reactive(returnValue));\n });\n return returnValue;\n}\n\nfunction useOnline(options = {}) {\n const { isOnline } = useNetwork(options);\n return isOnline;\n}\n\nfunction usePageLeave(options = {}) {\n const { window = defaultWindow } = options;\n const isLeft = ref(false);\n const handler = (event) => {\n if (!window)\n return;\n event = event || window.event;\n const from = event.relatedTarget || event.toElement;\n isLeft.value = !from;\n };\n if (window) {\n useEventListener(window, \"mouseout\", handler, { passive: true });\n useEventListener(window.document, \"mouseleave\", handler, { passive: true });\n useEventListener(window.document, \"mouseenter\", handler, { passive: true });\n }\n return isLeft;\n}\n\nfunction useScreenOrientation(options = {}) {\n const {\n window = defaultWindow\n } = options;\n const isSupported = useSupported(() => window && \"screen\" in window && \"orientation\" in window.screen);\n const screenOrientation = isSupported.value ? window.screen.orientation : {};\n const orientation = ref(screenOrientation.type);\n const angle = ref(screenOrientation.angle || 0);\n if (isSupported.value) {\n useEventListener(window, \"orientationchange\", () => {\n orientation.value = screenOrientation.type;\n angle.value = screenOrientation.angle;\n });\n }\n const lockOrientation = (type) => {\n if (isSupported.value && typeof screenOrientation.lock === \"function\")\n return screenOrientation.lock(type);\n return Promise.reject(new Error(\"Not supported\"));\n };\n const unlockOrientation = () => {\n if (isSupported.value && typeof screenOrientation.unlock === \"function\")\n screenOrientation.unlock();\n };\n return {\n isSupported,\n orientation,\n angle,\n lockOrientation,\n unlockOrientation\n };\n}\n\nfunction useParallax(target, options = {}) {\n const {\n deviceOrientationTiltAdjust = (i) => i,\n deviceOrientationRollAdjust = (i) => i,\n mouseTiltAdjust = (i) => i,\n mouseRollAdjust = (i) => i,\n window = defaultWindow\n } = options;\n const orientation = reactive(useDeviceOrientation({ window }));\n const screenOrientation = reactive(useScreenOrientation({ window }));\n const {\n elementX: x,\n elementY: y,\n elementWidth: width,\n elementHeight: height\n } = useMouseInElement(target, { handleOutside: false, window });\n const source = computed(() => {\n if (orientation.isSupported && (orientation.alpha != null && orientation.alpha !== 0 || orientation.gamma != null && orientation.gamma !== 0)) {\n return \"deviceOrientation\";\n }\n return \"mouse\";\n });\n const roll = computed(() => {\n if (source.value === \"deviceOrientation\") {\n let value;\n switch (screenOrientation.orientation) {\n case \"landscape-primary\":\n value = orientation.gamma / 90;\n break;\n case \"landscape-secondary\":\n value = -orientation.gamma / 90;\n break;\n case \"portrait-primary\":\n value = -orientation.beta / 90;\n break;\n case \"portrait-secondary\":\n value = orientation.beta / 90;\n break;\n default:\n value = -orientation.beta / 90;\n }\n return deviceOrientationRollAdjust(value);\n } else {\n const value = -(y.value - height.value / 2) / height.value;\n return mouseRollAdjust(value);\n }\n });\n const tilt = computed(() => {\n if (source.value === \"deviceOrientation\") {\n let value;\n switch (screenOrientation.orientation) {\n case \"landscape-primary\":\n value = orientation.beta / 90;\n break;\n case \"landscape-secondary\":\n value = -orientation.beta / 90;\n break;\n case \"portrait-primary\":\n value = orientation.gamma / 90;\n break;\n case \"portrait-secondary\":\n value = -orientation.gamma / 90;\n break;\n default:\n value = orientation.gamma / 90;\n }\n return deviceOrientationTiltAdjust(value);\n } else {\n const value = (x.value - width.value / 2) / width.value;\n return mouseTiltAdjust(value);\n }\n });\n return { roll, tilt, source };\n}\n\nfunction useParentElement(element = useCurrentElement()) {\n const parentElement = shallowRef();\n const update = () => {\n const el = unrefElement(element);\n if (el)\n parentElement.value = el.parentElement;\n };\n tryOnMounted(update);\n watch(() => toValue(element), update);\n return parentElement;\n}\n\nfunction usePerformanceObserver(options, callback) {\n const {\n window = defaultWindow,\n immediate = true,\n ...performanceOptions\n } = options;\n const isSupported = useSupported(() => window && \"PerformanceObserver\" in window);\n let observer;\n const stop = () => {\n observer == null ? void 0 : observer.disconnect();\n };\n const start = () => {\n if (isSupported.value) {\n stop();\n observer = new PerformanceObserver(callback);\n observer.observe(performanceOptions);\n }\n };\n tryOnScopeDispose(stop);\n if (immediate)\n start();\n return {\n isSupported,\n start,\n stop\n };\n}\n\nconst defaultState = {\n x: 0,\n y: 0,\n pointerId: 0,\n pressure: 0,\n tiltX: 0,\n tiltY: 0,\n width: 0,\n height: 0,\n twist: 0,\n pointerType: null\n};\nconst keys = /* @__PURE__ */ Object.keys(defaultState);\nfunction usePointer(options = {}) {\n const {\n target = defaultWindow\n } = options;\n const isInside = ref(false);\n const state = ref(options.initialValue || {});\n Object.assign(state.value, defaultState, state.value);\n const handler = (event) => {\n isInside.value = true;\n if (options.pointerTypes && !options.pointerTypes.includes(event.pointerType))\n return;\n state.value = objectPick(event, keys, false);\n };\n if (target) {\n const listenerOptions = { passive: true };\n useEventListener(target, [\"pointerdown\", \"pointermove\", \"pointerup\"], handler, listenerOptions);\n useEventListener(target, \"pointerleave\", () => isInside.value = false, listenerOptions);\n }\n return {\n ...toRefs(state),\n isInside\n };\n}\n\nfunction usePointerLock(target, options = {}) {\n const { document = defaultDocument } = options;\n const isSupported = useSupported(() => document && \"pointerLockElement\" in document);\n const element = ref();\n const triggerElement = ref();\n let targetElement;\n if (isSupported.value) {\n useEventListener(document, \"pointerlockchange\", () => {\n var _a;\n const currentElement = (_a = document.pointerLockElement) != null ? _a : element.value;\n if (targetElement && currentElement === targetElement) {\n element.value = document.pointerLockElement;\n if (!element.value)\n targetElement = triggerElement.value = null;\n }\n });\n useEventListener(document, \"pointerlockerror\", () => {\n var _a;\n const currentElement = (_a = document.pointerLockElement) != null ? _a : element.value;\n if (targetElement && currentElement === targetElement) {\n const action = document.pointerLockElement ? \"release\" : \"acquire\";\n throw new Error(`Failed to ${action} pointer lock.`);\n }\n });\n }\n async function lock(e) {\n var _a;\n if (!isSupported.value)\n throw new Error(\"Pointer Lock API is not supported by your browser.\");\n triggerElement.value = e instanceof Event ? e.currentTarget : null;\n targetElement = e instanceof Event ? (_a = unrefElement(target)) != null ? _a : triggerElement.value : unrefElement(e);\n if (!targetElement)\n throw new Error(\"Target element undefined.\");\n targetElement.requestPointerLock();\n return await until(element).toBe(targetElement);\n }\n async function unlock() {\n if (!element.value)\n return false;\n document.exitPointerLock();\n await until(element).toBeNull();\n return true;\n }\n return {\n isSupported,\n element,\n triggerElement,\n lock,\n unlock\n };\n}\n\nfunction usePointerSwipe(target, options = {}) {\n const targetRef = toRef(target);\n const {\n threshold = 50,\n onSwipe,\n onSwipeEnd,\n onSwipeStart,\n disableTextSelect = false\n } = options;\n const posStart = reactive({ x: 0, y: 0 });\n const updatePosStart = (x, y) => {\n posStart.x = x;\n posStart.y = y;\n };\n const posEnd = reactive({ x: 0, y: 0 });\n const updatePosEnd = (x, y) => {\n posEnd.x = x;\n posEnd.y = y;\n };\n const distanceX = computed(() => posStart.x - posEnd.x);\n const distanceY = computed(() => posStart.y - posEnd.y);\n const { max, abs } = Math;\n const isThresholdExceeded = computed(() => max(abs(distanceX.value), abs(distanceY.value)) >= threshold);\n const isSwiping = ref(false);\n const isPointerDown = ref(false);\n const direction = computed(() => {\n if (!isThresholdExceeded.value)\n return \"none\";\n if (abs(distanceX.value) > abs(distanceY.value)) {\n return distanceX.value > 0 ? \"left\" : \"right\";\n } else {\n return distanceY.value > 0 ? \"up\" : \"down\";\n }\n });\n const eventIsAllowed = (e) => {\n var _a, _b, _c;\n const isReleasingButton = e.buttons === 0;\n const isPrimaryButton = e.buttons === 1;\n return (_c = (_b = (_a = options.pointerTypes) == null ? void 0 : _a.includes(e.pointerType)) != null ? _b : isReleasingButton || isPrimaryButton) != null ? _c : true;\n };\n const stops = [\n useEventListener(target, \"pointerdown\", (e) => {\n if (!eventIsAllowed(e))\n return;\n isPointerDown.value = true;\n const eventTarget = e.target;\n eventTarget == null ? void 0 : eventTarget.setPointerCapture(e.pointerId);\n const { clientX: x, clientY: y } = e;\n updatePosStart(x, y);\n updatePosEnd(x, y);\n onSwipeStart == null ? void 0 : onSwipeStart(e);\n }),\n useEventListener(target, \"pointermove\", (e) => {\n if (!eventIsAllowed(e))\n return;\n if (!isPointerDown.value)\n return;\n const { clientX: x, clientY: y } = e;\n updatePosEnd(x, y);\n if (!isSwiping.value && isThresholdExceeded.value)\n isSwiping.value = true;\n if (isSwiping.value)\n onSwipe == null ? void 0 : onSwipe(e);\n }),\n useEventListener(target, \"pointerup\", (e) => {\n if (!eventIsAllowed(e))\n return;\n if (isSwiping.value)\n onSwipeEnd == null ? void 0 : onSwipeEnd(e, direction.value);\n isPointerDown.value = false;\n isSwiping.value = false;\n })\n ];\n tryOnMounted(() => {\n var _a, _b, _c, _d, _e, _f, _g, _h;\n (_b = (_a = targetRef.value) == null ? void 0 : _a.style) == null ? void 0 : _b.setProperty(\"touch-action\", \"none\");\n if (disableTextSelect) {\n (_d = (_c = targetRef.value) == null ? void 0 : _c.style) == null ? void 0 : _d.setProperty(\"-webkit-user-select\", \"none\");\n (_f = (_e = targetRef.value) == null ? void 0 : _e.style) == null ? void 0 : _f.setProperty(\"-ms-user-select\", \"none\");\n (_h = (_g = targetRef.value) == null ? void 0 : _g.style) == null ? void 0 : _h.setProperty(\"user-select\", \"none\");\n }\n });\n const stop = () => stops.forEach((s) => s());\n return {\n isSwiping: readonly(isSwiping),\n direction: readonly(direction),\n posStart: readonly(posStart),\n posEnd: readonly(posEnd),\n distanceX,\n distanceY,\n stop\n };\n}\n\nfunction usePreferredColorScheme(options) {\n const isLight = useMediaQuery(\"(prefers-color-scheme: light)\", options);\n const isDark = useMediaQuery(\"(prefers-color-scheme: dark)\", options);\n return computed(() => {\n if (isDark.value)\n return \"dark\";\n if (isLight.value)\n return \"light\";\n return \"no-preference\";\n });\n}\n\nfunction usePreferredContrast(options) {\n const isMore = useMediaQuery(\"(prefers-contrast: more)\", options);\n const isLess = useMediaQuery(\"(prefers-contrast: less)\", options);\n const isCustom = useMediaQuery(\"(prefers-contrast: custom)\", options);\n return computed(() => {\n if (isMore.value)\n return \"more\";\n if (isLess.value)\n return \"less\";\n if (isCustom.value)\n return \"custom\";\n return \"no-preference\";\n });\n}\n\nfunction usePreferredLanguages(options = {}) {\n const { window = defaultWindow } = options;\n if (!window)\n return ref([\"en\"]);\n const navigator = window.navigator;\n const value = ref(navigator.languages);\n useEventListener(window, \"languagechange\", () => {\n value.value = navigator.languages;\n });\n return value;\n}\n\nfunction usePreferredReducedMotion(options) {\n const isReduced = useMediaQuery(\"(prefers-reduced-motion: reduce)\", options);\n return computed(() => {\n if (isReduced.value)\n return \"reduce\";\n return \"no-preference\";\n });\n}\n\nfunction usePrevious(value, initialValue) {\n const previous = shallowRef(initialValue);\n watch(\n toRef(value),\n (_, oldValue) => {\n previous.value = oldValue;\n },\n { flush: \"sync\" }\n );\n return readonly(previous);\n}\n\nconst topVarName = \"--vueuse-safe-area-top\";\nconst rightVarName = \"--vueuse-safe-area-right\";\nconst bottomVarName = \"--vueuse-safe-area-bottom\";\nconst leftVarName = \"--vueuse-safe-area-left\";\nfunction useScreenSafeArea() {\n const top = ref(\"\");\n const right = ref(\"\");\n const bottom = ref(\"\");\n const left = ref(\"\");\n if (isClient) {\n const topCssVar = useCssVar(topVarName);\n const rightCssVar = useCssVar(rightVarName);\n const bottomCssVar = useCssVar(bottomVarName);\n const leftCssVar = useCssVar(leftVarName);\n topCssVar.value = \"env(safe-area-inset-top, 0px)\";\n rightCssVar.value = \"env(safe-area-inset-right, 0px)\";\n bottomCssVar.value = \"env(safe-area-inset-bottom, 0px)\";\n leftCssVar.value = \"env(safe-area-inset-left, 0px)\";\n update();\n useEventListener(\"resize\", useDebounceFn(update));\n }\n function update() {\n top.value = getValue(topVarName);\n right.value = getValue(rightVarName);\n bottom.value = getValue(bottomVarName);\n left.value = getValue(leftVarName);\n }\n return {\n top,\n right,\n bottom,\n left,\n update\n };\n}\nfunction getValue(position) {\n return getComputedStyle(document.documentElement).getPropertyValue(position);\n}\n\nfunction useScriptTag(src, onLoaded = noop, options = {}) {\n const {\n immediate = true,\n manual = false,\n type = \"text/javascript\",\n async = true,\n crossOrigin,\n referrerPolicy,\n noModule,\n defer,\n document = defaultDocument,\n attrs = {}\n } = options;\n const scriptTag = ref(null);\n let _promise = null;\n const loadScript = (waitForScriptLoad) => new Promise((resolve, reject) => {\n const resolveWithElement = (el2) => {\n scriptTag.value = el2;\n resolve(el2);\n return el2;\n };\n if (!document) {\n resolve(false);\n return;\n }\n let shouldAppend = false;\n let el = document.querySelector(`script[src=\"${toValue(src)}\"]`);\n if (!el) {\n el = document.createElement(\"script\");\n el.type = type;\n el.async = async;\n el.src = toValue(src);\n if (defer)\n el.defer = defer;\n if (crossOrigin)\n el.crossOrigin = crossOrigin;\n if (noModule)\n el.noModule = noModule;\n if (referrerPolicy)\n el.referrerPolicy = referrerPolicy;\n Object.entries(attrs).forEach(([name, value]) => el == null ? void 0 : el.setAttribute(name, value));\n shouldAppend = true;\n } else if (el.hasAttribute(\"data-loaded\")) {\n resolveWithElement(el);\n }\n el.addEventListener(\"error\", (event) => reject(event));\n el.addEventListener(\"abort\", (event) => reject(event));\n el.addEventListener(\"load\", () => {\n el.setAttribute(\"data-loaded\", \"true\");\n onLoaded(el);\n resolveWithElement(el);\n });\n if (shouldAppend)\n el = document.head.appendChild(el);\n if (!waitForScriptLoad)\n resolveWithElement(el);\n });\n const load = (waitForScriptLoad = true) => {\n if (!_promise)\n _promise = loadScript(waitForScriptLoad);\n return _promise;\n };\n const unload = () => {\n if (!document)\n return;\n _promise = null;\n if (scriptTag.value)\n scriptTag.value = null;\n const el = document.querySelector(`script[src=\"${toValue(src)}\"]`);\n if (el)\n document.head.removeChild(el);\n };\n if (immediate && !manual)\n tryOnMounted(load);\n if (!manual)\n tryOnUnmounted(unload);\n return { scriptTag, load, unload };\n}\n\nfunction checkOverflowScroll(ele) {\n const style = window.getComputedStyle(ele);\n if (style.overflowX === \"scroll\" || style.overflowY === \"scroll\" || style.overflowX === \"auto\" && ele.clientWidth < ele.scrollWidth || style.overflowY === \"auto\" && ele.clientHeight < ele.scrollHeight) {\n return true;\n } else {\n const parent = ele.parentNode;\n if (!parent || parent.tagName === \"BODY\")\n return false;\n return checkOverflowScroll(parent);\n }\n}\nfunction preventDefault(rawEvent) {\n const e = rawEvent || window.event;\n const _target = e.target;\n if (checkOverflowScroll(_target))\n return false;\n if (e.touches.length > 1)\n return true;\n if (e.preventDefault)\n e.preventDefault();\n return false;\n}\nconst elInitialOverflow = /* @__PURE__ */ new WeakMap();\nfunction useScrollLock(element, initialState = false) {\n const isLocked = ref(initialState);\n let stopTouchMoveListener = null;\n let initialOverflow = \"\";\n watch(toRef(element), (el) => {\n const target = resolveElement(toValue(el));\n if (target) {\n const ele = target;\n if (!elInitialOverflow.get(ele))\n elInitialOverflow.set(ele, ele.style.overflow);\n if (ele.style.overflow !== \"hidden\")\n initialOverflow = ele.style.overflow;\n if (ele.style.overflow === \"hidden\")\n return isLocked.value = true;\n if (isLocked.value)\n return ele.style.overflow = \"hidden\";\n }\n }, {\n immediate: true\n });\n const lock = () => {\n const el = resolveElement(toValue(element));\n if (!el || isLocked.value)\n return;\n if (isIOS) {\n stopTouchMoveListener = useEventListener(\n el,\n \"touchmove\",\n (e) => {\n preventDefault(e);\n },\n { passive: false }\n );\n }\n el.style.overflow = \"hidden\";\n isLocked.value = true;\n };\n const unlock = () => {\n const el = resolveElement(toValue(element));\n if (!el || !isLocked.value)\n return;\n if (isIOS)\n stopTouchMoveListener == null ? void 0 : stopTouchMoveListener();\n el.style.overflow = initialOverflow;\n elInitialOverflow.delete(el);\n isLocked.value = false;\n };\n tryOnScopeDispose(unlock);\n return computed({\n get() {\n return isLocked.value;\n },\n set(v) {\n if (v)\n lock();\n else unlock();\n }\n });\n}\n\nfunction useSessionStorage(key, initialValue, options = {}) {\n const { window = defaultWindow } = options;\n return useStorage(key, initialValue, window == null ? void 0 : window.sessionStorage, options);\n}\n\nfunction useShare(shareOptions = {}, options = {}) {\n const { navigator = defaultNavigator } = options;\n const _navigator = navigator;\n const isSupported = useSupported(() => _navigator && \"canShare\" in _navigator);\n const share = async (overrideOptions = {}) => {\n if (isSupported.value) {\n const data = {\n ...toValue(shareOptions),\n ...toValue(overrideOptions)\n };\n let granted = true;\n if (data.files && _navigator.canShare)\n granted = _navigator.canShare({ files: data.files });\n if (granted)\n return _navigator.share(data);\n }\n };\n return {\n isSupported,\n share\n };\n}\n\nconst defaultSortFn = (source, compareFn) => source.sort(compareFn);\nconst defaultCompare = (a, b) => a - b;\nfunction useSorted(...args) {\n var _a, _b, _c, _d;\n const [source] = args;\n let compareFn = defaultCompare;\n let options = {};\n if (args.length === 2) {\n if (typeof args[1] === \"object\") {\n options = args[1];\n compareFn = (_a = options.compareFn) != null ? _a : defaultCompare;\n } else {\n compareFn = (_b = args[1]) != null ? _b : defaultCompare;\n }\n } else if (args.length > 2) {\n compareFn = (_c = args[1]) != null ? _c : defaultCompare;\n options = (_d = args[2]) != null ? _d : {};\n }\n const {\n dirty = false,\n sortFn = defaultSortFn\n } = options;\n if (!dirty)\n return computed(() => sortFn([...toValue(source)], compareFn));\n watchEffect(() => {\n const result = sortFn(toValue(source), compareFn);\n if (isRef(source))\n source.value = result;\n else\n source.splice(0, source.length, ...result);\n });\n return source;\n}\n\nfunction useSpeechRecognition(options = {}) {\n const {\n interimResults = true,\n continuous = true,\n maxAlternatives = 1,\n window = defaultWindow\n } = options;\n const lang = toRef(options.lang || \"en-US\");\n const isListening = ref(false);\n const isFinal = ref(false);\n const result = ref(\"\");\n const error = shallowRef(void 0);\n const toggle = (value = !isListening.value) => {\n isListening.value = value;\n };\n const start = () => {\n isListening.value = true;\n };\n const stop = () => {\n isListening.value = false;\n };\n const SpeechRecognition = window && (window.SpeechRecognition || window.webkitSpeechRecognition);\n const isSupported = useSupported(() => SpeechRecognition);\n let recognition;\n if (isSupported.value) {\n recognition = new SpeechRecognition();\n recognition.continuous = continuous;\n recognition.interimResults = interimResults;\n recognition.lang = toValue(lang);\n recognition.maxAlternatives = maxAlternatives;\n recognition.onstart = () => {\n isFinal.value = false;\n };\n watch(lang, (lang2) => {\n if (recognition && !isListening.value)\n recognition.lang = lang2;\n });\n recognition.onresult = (event) => {\n const currentResult = event.results[event.resultIndex];\n const { transcript } = currentResult[0];\n isFinal.value = currentResult.isFinal;\n result.value = transcript;\n error.value = void 0;\n };\n recognition.onerror = (event) => {\n error.value = event;\n };\n recognition.onend = () => {\n isListening.value = false;\n recognition.lang = toValue(lang);\n };\n watch(isListening, () => {\n if (isListening.value)\n recognition.start();\n else\n recognition.stop();\n });\n }\n tryOnScopeDispose(() => {\n isListening.value = false;\n });\n return {\n isSupported,\n isListening,\n isFinal,\n recognition,\n result,\n error,\n toggle,\n start,\n stop\n };\n}\n\nfunction useSpeechSynthesis(text, options = {}) {\n const {\n pitch = 1,\n rate = 1,\n volume = 1,\n window = defaultWindow\n } = options;\n const synth = window && window.speechSynthesis;\n const isSupported = useSupported(() => synth);\n const isPlaying = ref(false);\n const status = ref(\"init\");\n const spokenText = toRef(text || \"\");\n const lang = toRef(options.lang || \"en-US\");\n const error = shallowRef(void 0);\n const toggle = (value = !isPlaying.value) => {\n isPlaying.value = value;\n };\n const bindEventsForUtterance = (utterance2) => {\n utterance2.lang = toValue(lang);\n utterance2.voice = toValue(options.voice) || null;\n utterance2.pitch = toValue(pitch);\n utterance2.rate = toValue(rate);\n utterance2.volume = volume;\n utterance2.onstart = () => {\n isPlaying.value = true;\n status.value = \"play\";\n };\n utterance2.onpause = () => {\n isPlaying.value = false;\n status.value = \"pause\";\n };\n utterance2.onresume = () => {\n isPlaying.value = true;\n status.value = \"play\";\n };\n utterance2.onend = () => {\n isPlaying.value = false;\n status.value = \"end\";\n };\n utterance2.onerror = (event) => {\n error.value = event;\n };\n };\n const utterance = computed(() => {\n isPlaying.value = false;\n status.value = \"init\";\n const newUtterance = new SpeechSynthesisUtterance(spokenText.value);\n bindEventsForUtterance(newUtterance);\n return newUtterance;\n });\n const speak = () => {\n synth.cancel();\n if (utterance)\n synth.speak(utterance.value);\n };\n const stop = () => {\n synth.cancel();\n isPlaying.value = false;\n };\n if (isSupported.value) {\n bindEventsForUtterance(utterance.value);\n watch(lang, (lang2) => {\n if (utterance.value && !isPlaying.value)\n utterance.value.lang = lang2;\n });\n if (options.voice) {\n watch(options.voice, () => {\n synth.cancel();\n });\n }\n watch(isPlaying, () => {\n if (isPlaying.value)\n synth.resume();\n else\n synth.pause();\n });\n }\n tryOnScopeDispose(() => {\n isPlaying.value = false;\n });\n return {\n isSupported,\n isPlaying,\n status,\n utterance,\n error,\n stop,\n toggle,\n speak\n };\n}\n\nfunction useStepper(steps, initialStep) {\n const stepsRef = ref(steps);\n const stepNames = computed(() => Array.isArray(stepsRef.value) ? stepsRef.value : Object.keys(stepsRef.value));\n const index = ref(stepNames.value.indexOf(initialStep != null ? initialStep : stepNames.value[0]));\n const current = computed(() => at(index.value));\n const isFirst = computed(() => index.value === 0);\n const isLast = computed(() => index.value === stepNames.value.length - 1);\n const next = computed(() => stepNames.value[index.value + 1]);\n const previous = computed(() => stepNames.value[index.value - 1]);\n function at(index2) {\n if (Array.isArray(stepsRef.value))\n return stepsRef.value[index2];\n return stepsRef.value[stepNames.value[index2]];\n }\n function get(step) {\n if (!stepNames.value.includes(step))\n return;\n return at(stepNames.value.indexOf(step));\n }\n function goTo(step) {\n if (stepNames.value.includes(step))\n index.value = stepNames.value.indexOf(step);\n }\n function goToNext() {\n if (isLast.value)\n return;\n index.value++;\n }\n function goToPrevious() {\n if (isFirst.value)\n return;\n index.value--;\n }\n function goBackTo(step) {\n if (isAfter(step))\n goTo(step);\n }\n function isNext(step) {\n return stepNames.value.indexOf(step) === index.value + 1;\n }\n function isPrevious(step) {\n return stepNames.value.indexOf(step) === index.value - 1;\n }\n function isCurrent(step) {\n return stepNames.value.indexOf(step) === index.value;\n }\n function isBefore(step) {\n return index.value < stepNames.value.indexOf(step);\n }\n function isAfter(step) {\n return index.value > stepNames.value.indexOf(step);\n }\n return {\n steps: stepsRef,\n stepNames,\n index,\n current,\n next,\n previous,\n isFirst,\n isLast,\n at,\n get,\n goTo,\n goToNext,\n goToPrevious,\n goBackTo,\n isNext,\n isPrevious,\n isCurrent,\n isBefore,\n isAfter\n };\n}\n\nfunction useStorageAsync(key, initialValue, storage, options = {}) {\n var _a;\n const {\n flush = \"pre\",\n deep = true,\n listenToStorageChanges = true,\n writeDefaults = true,\n mergeDefaults = false,\n shallow,\n window = defaultWindow,\n eventFilter,\n onError = (e) => {\n console.error(e);\n }\n } = options;\n const rawInit = toValue(initialValue);\n const type = guessSerializerType(rawInit);\n const data = (shallow ? shallowRef : ref)(initialValue);\n const serializer = (_a = options.serializer) != null ? _a : StorageSerializers[type];\n if (!storage) {\n try {\n storage = getSSRHandler(\"getDefaultStorageAsync\", () => {\n var _a2;\n return (_a2 = defaultWindow) == null ? void 0 : _a2.localStorage;\n })();\n } catch (e) {\n onError(e);\n }\n }\n async function read(event) {\n if (!storage || event && event.key !== key)\n return;\n try {\n const rawValue = event ? event.newValue : await storage.getItem(key);\n if (rawValue == null) {\n data.value = rawInit;\n if (writeDefaults && rawInit !== null)\n await storage.setItem(key, await serializer.write(rawInit));\n } else if (mergeDefaults) {\n const value = await serializer.read(rawValue);\n if (typeof mergeDefaults === \"function\")\n data.value = mergeDefaults(value, rawInit);\n else if (type === \"object\" && !Array.isArray(value))\n data.value = { ...rawInit, ...value };\n else data.value = value;\n } else {\n data.value = await serializer.read(rawValue);\n }\n } catch (e) {\n onError(e);\n }\n }\n read();\n if (window && listenToStorageChanges)\n useEventListener(window, \"storage\", (e) => Promise.resolve().then(() => read(e)));\n if (storage) {\n watchWithFilter(\n data,\n async () => {\n try {\n if (data.value == null)\n await storage.removeItem(key);\n else\n await storage.setItem(key, await serializer.write(data.value));\n } catch (e) {\n onError(e);\n }\n },\n {\n flush,\n deep,\n eventFilter\n }\n );\n }\n return data;\n}\n\nlet _id = 0;\nfunction useStyleTag(css, options = {}) {\n const isLoaded = ref(false);\n const {\n document = defaultDocument,\n immediate = true,\n manual = false,\n id = `vueuse_styletag_${++_id}`\n } = options;\n const cssRef = ref(css);\n let stop = () => {\n };\n const load = () => {\n if (!document)\n return;\n const el = document.getElementById(id) || document.createElement(\"style\");\n if (!el.isConnected) {\n el.id = id;\n if (options.media)\n el.media = options.media;\n document.head.appendChild(el);\n }\n if (isLoaded.value)\n return;\n stop = watch(\n cssRef,\n (value) => {\n el.textContent = value;\n },\n { immediate: true }\n );\n isLoaded.value = true;\n };\n const unload = () => {\n if (!document || !isLoaded.value)\n return;\n stop();\n document.head.removeChild(document.getElementById(id));\n isLoaded.value = false;\n };\n if (immediate && !manual)\n tryOnMounted(load);\n if (!manual)\n tryOnScopeDispose(unload);\n return {\n id,\n css: cssRef,\n unload,\n load,\n isLoaded: readonly(isLoaded)\n };\n}\n\nfunction useSwipe(target, options = {}) {\n const {\n threshold = 50,\n onSwipe,\n onSwipeEnd,\n onSwipeStart,\n passive = true,\n window = defaultWindow\n } = options;\n const coordsStart = reactive({ x: 0, y: 0 });\n const coordsEnd = reactive({ x: 0, y: 0 });\n const diffX = computed(() => coordsStart.x - coordsEnd.x);\n const diffY = computed(() => coordsStart.y - coordsEnd.y);\n const { max, abs } = Math;\n const isThresholdExceeded = computed(() => max(abs(diffX.value), abs(diffY.value)) >= threshold);\n const isSwiping = ref(false);\n const direction = computed(() => {\n if (!isThresholdExceeded.value)\n return \"none\";\n if (abs(diffX.value) > abs(diffY.value)) {\n return diffX.value > 0 ? \"left\" : \"right\";\n } else {\n return diffY.value > 0 ? \"up\" : \"down\";\n }\n });\n const getTouchEventCoords = (e) => [e.touches[0].clientX, e.touches[0].clientY];\n const updateCoordsStart = (x, y) => {\n coordsStart.x = x;\n coordsStart.y = y;\n };\n const updateCoordsEnd = (x, y) => {\n coordsEnd.x = x;\n coordsEnd.y = y;\n };\n let listenerOptions;\n const isPassiveEventSupported = checkPassiveEventSupport(window == null ? void 0 : window.document);\n if (!passive)\n listenerOptions = isPassiveEventSupported ? { passive: false, capture: true } : { capture: true };\n else\n listenerOptions = isPassiveEventSupported ? { passive: true } : { capture: false };\n const onTouchEnd = (e) => {\n if (isSwiping.value)\n onSwipeEnd == null ? void 0 : onSwipeEnd(e, direction.value);\n isSwiping.value = false;\n };\n const stops = [\n useEventListener(target, \"touchstart\", (e) => {\n if (e.touches.length !== 1)\n return;\n const [x, y] = getTouchEventCoords(e);\n updateCoordsStart(x, y);\n updateCoordsEnd(x, y);\n onSwipeStart == null ? void 0 : onSwipeStart(e);\n }, listenerOptions),\n useEventListener(target, \"touchmove\", (e) => {\n if (e.touches.length !== 1)\n return;\n const [x, y] = getTouchEventCoords(e);\n updateCoordsEnd(x, y);\n if (listenerOptions.capture && !listenerOptions.passive && Math.abs(diffX.value) > Math.abs(diffY.value))\n e.preventDefault();\n if (!isSwiping.value && isThresholdExceeded.value)\n isSwiping.value = true;\n if (isSwiping.value)\n onSwipe == null ? void 0 : onSwipe(e);\n }, listenerOptions),\n useEventListener(target, [\"touchend\", \"touchcancel\"], onTouchEnd, listenerOptions)\n ];\n const stop = () => stops.forEach((s) => s());\n return {\n isPassiveEventSupported,\n isSwiping,\n direction,\n coordsStart,\n coordsEnd,\n lengthX: diffX,\n lengthY: diffY,\n stop\n };\n}\nfunction checkPassiveEventSupport(document) {\n if (!document)\n return false;\n let supportsPassive = false;\n const optionsBlock = {\n get passive() {\n supportsPassive = true;\n return false;\n }\n };\n document.addEventListener(\"x\", noop, optionsBlock);\n document.removeEventListener(\"x\", noop);\n return supportsPassive;\n}\n\nfunction useTemplateRefsList() {\n const refs = ref([]);\n refs.value.set = (el) => {\n if (el)\n refs.value.push(el);\n };\n onBeforeUpdate(() => {\n refs.value.length = 0;\n });\n return refs;\n}\n\nfunction useTextDirection(options = {}) {\n const {\n document = defaultDocument,\n selector = \"html\",\n observe = false,\n initialValue = \"ltr\"\n } = options;\n function getValue() {\n var _a, _b;\n return (_b = (_a = document == null ? void 0 : document.querySelector(selector)) == null ? void 0 : _a.getAttribute(\"dir\")) != null ? _b : initialValue;\n }\n const dir = ref(getValue());\n tryOnMounted(() => dir.value = getValue());\n if (observe && document) {\n useMutationObserver(\n document.querySelector(selector),\n () => dir.value = getValue(),\n { attributes: true }\n );\n }\n return computed({\n get() {\n return dir.value;\n },\n set(v) {\n var _a, _b;\n dir.value = v;\n if (!document)\n return;\n if (dir.value)\n (_a = document.querySelector(selector)) == null ? void 0 : _a.setAttribute(\"dir\", dir.value);\n else\n (_b = document.querySelector(selector)) == null ? void 0 : _b.removeAttribute(\"dir\");\n }\n });\n}\n\nfunction getRangesFromSelection(selection) {\n var _a;\n const rangeCount = (_a = selection.rangeCount) != null ? _a : 0;\n return Array.from({ length: rangeCount }, (_, i) => selection.getRangeAt(i));\n}\nfunction useTextSelection(options = {}) {\n const {\n window = defaultWindow\n } = options;\n const selection = ref(null);\n const text = computed(() => {\n var _a, _b;\n return (_b = (_a = selection.value) == null ? void 0 : _a.toString()) != null ? _b : \"\";\n });\n const ranges = computed(() => selection.value ? getRangesFromSelection(selection.value) : []);\n const rects = computed(() => ranges.value.map((range) => range.getBoundingClientRect()));\n function onSelectionChange() {\n selection.value = null;\n if (window)\n selection.value = window.getSelection();\n }\n if (window)\n useEventListener(window.document, \"selectionchange\", onSelectionChange);\n return {\n text,\n rects,\n ranges,\n selection\n };\n}\n\nfunction useTextareaAutosize(options) {\n var _a;\n const textarea = ref(options == null ? void 0 : options.element);\n const input = ref(options == null ? void 0 : options.input);\n const styleProp = (_a = options == null ? void 0 : options.styleProp) != null ? _a : \"height\";\n const textareaScrollHeight = ref(1);\n const textareaOldWidth = ref(0);\n function triggerResize() {\n var _a2;\n if (!textarea.value)\n return;\n let height = \"\";\n textarea.value.style[styleProp] = \"1px\";\n textareaScrollHeight.value = (_a2 = textarea.value) == null ? void 0 : _a2.scrollHeight;\n const _styleTarget = toValue(options == null ? void 0 : options.styleTarget);\n if (_styleTarget)\n _styleTarget.style[styleProp] = `${textareaScrollHeight.value}px`;\n else\n height = `${textareaScrollHeight.value}px`;\n textarea.value.style[styleProp] = height;\n }\n watch([input, textarea], () => nextTick(triggerResize), { immediate: true });\n watch(textareaScrollHeight, () => {\n var _a2;\n return (_a2 = options == null ? void 0 : options.onResize) == null ? void 0 : _a2.call(options);\n });\n useResizeObserver(textarea, ([{ contentRect }]) => {\n if (textareaOldWidth.value === contentRect.width)\n return;\n textareaOldWidth.value = contentRect.width;\n triggerResize();\n });\n if (options == null ? void 0 : options.watch)\n watch(options.watch, triggerResize, { immediate: true, deep: true });\n return {\n textarea,\n input,\n triggerResize\n };\n}\n\nfunction useThrottledRefHistory(source, options = {}) {\n const { throttle = 200, trailing = true } = options;\n const filter = throttleFilter(throttle, trailing);\n const history = useRefHistory(source, { ...options, eventFilter: filter });\n return {\n ...history\n };\n}\n\nconst DEFAULT_UNITS = [\n { max: 6e4, value: 1e3, name: \"second\" },\n { max: 276e4, value: 6e4, name: \"minute\" },\n { max: 72e6, value: 36e5, name: \"hour\" },\n { max: 5184e5, value: 864e5, name: \"day\" },\n { max: 24192e5, value: 6048e5, name: \"week\" },\n { max: 28512e6, value: 2592e6, name: \"month\" },\n { max: Number.POSITIVE_INFINITY, value: 31536e6, name: \"year\" }\n];\nconst DEFAULT_MESSAGES = {\n justNow: \"just now\",\n past: (n) => n.match(/\\d/) ? `${n} ago` : n,\n future: (n) => n.match(/\\d/) ? `in ${n}` : n,\n month: (n, past) => n === 1 ? past ? \"last month\" : \"next month\" : `${n} month${n > 1 ? \"s\" : \"\"}`,\n year: (n, past) => n === 1 ? past ? \"last year\" : \"next year\" : `${n} year${n > 1 ? \"s\" : \"\"}`,\n day: (n, past) => n === 1 ? past ? \"yesterday\" : \"tomorrow\" : `${n} day${n > 1 ? \"s\" : \"\"}`,\n week: (n, past) => n === 1 ? past ? \"last week\" : \"next week\" : `${n} week${n > 1 ? \"s\" : \"\"}`,\n hour: (n) => `${n} hour${n > 1 ? \"s\" : \"\"}`,\n minute: (n) => `${n} minute${n > 1 ? \"s\" : \"\"}`,\n second: (n) => `${n} second${n > 1 ? \"s\" : \"\"}`,\n invalid: \"\"\n};\nfunction DEFAULT_FORMATTER(date) {\n return date.toISOString().slice(0, 10);\n}\nfunction useTimeAgo(time, options = {}) {\n const {\n controls: exposeControls = false,\n updateInterval = 3e4\n } = options;\n const { now, ...controls } = useNow({ interval: updateInterval, controls: true });\n const timeAgo = computed(() => formatTimeAgo(new Date(toValue(time)), options, toValue(now)));\n if (exposeControls) {\n return {\n timeAgo,\n ...controls\n };\n } else {\n return timeAgo;\n }\n}\nfunction formatTimeAgo(from, options = {}, now = Date.now()) {\n var _a;\n const {\n max,\n messages = DEFAULT_MESSAGES,\n fullDateFormatter = DEFAULT_FORMATTER,\n units = DEFAULT_UNITS,\n showSecond = false,\n rounding = \"round\"\n } = options;\n const roundFn = typeof rounding === \"number\" ? (n) => +n.toFixed(rounding) : Math[rounding];\n const diff = +now - +from;\n const absDiff = Math.abs(diff);\n function getValue(diff2, unit) {\n return roundFn(Math.abs(diff2) / unit.value);\n }\n function format(diff2, unit) {\n const val = getValue(diff2, unit);\n const past = diff2 > 0;\n const str = applyFormat(unit.name, val, past);\n return applyFormat(past ? \"past\" : \"future\", str, past);\n }\n function applyFormat(name, val, isPast) {\n const formatter = messages[name];\n if (typeof formatter === \"function\")\n return formatter(val, isPast);\n return formatter.replace(\"{0}\", val.toString());\n }\n if (absDiff < 6e4 && !showSecond)\n return messages.justNow;\n if (typeof max === \"number\" && absDiff > max)\n return fullDateFormatter(new Date(from));\n if (typeof max === \"string\") {\n const unitMax = (_a = units.find((i) => i.name === max)) == null ? void 0 : _a.max;\n if (unitMax && absDiff > unitMax)\n return fullDateFormatter(new Date(from));\n }\n for (const [idx, unit] of units.entries()) {\n const val = getValue(diff, unit);\n if (val <= 0 && units[idx - 1])\n return format(diff, units[idx - 1]);\n if (absDiff < unit.max)\n return format(diff, unit);\n }\n return messages.invalid;\n}\n\nfunction useTimeoutPoll(fn, interval, timeoutPollOptions) {\n const { start } = useTimeoutFn(loop, interval, { immediate: false });\n const isActive = ref(false);\n async function loop() {\n if (!isActive.value)\n return;\n await fn();\n start();\n }\n function resume() {\n if (!isActive.value) {\n isActive.value = true;\n loop();\n }\n }\n function pause() {\n isActive.value = false;\n }\n if (timeoutPollOptions == null ? void 0 : timeoutPollOptions.immediate)\n resume();\n tryOnScopeDispose(pause);\n return {\n isActive,\n pause,\n resume\n };\n}\n\nfunction useTimestamp(options = {}) {\n const {\n controls: exposeControls = false,\n offset = 0,\n immediate = true,\n interval = \"requestAnimationFrame\",\n callback\n } = options;\n const ts = ref(timestamp() + offset);\n const update = () => ts.value = timestamp() + offset;\n const cb = callback ? () => {\n update();\n callback(ts.value);\n } : update;\n const controls = interval === \"requestAnimationFrame\" ? useRafFn(cb, { immediate }) : useIntervalFn(cb, interval, { immediate });\n if (exposeControls) {\n return {\n timestamp: ts,\n ...controls\n };\n } else {\n return ts;\n }\n}\n\nfunction useTitle(newTitle = null, options = {}) {\n var _a, _b, _c;\n const {\n document = defaultDocument,\n restoreOnUnmount = (t) => t\n } = options;\n const originalTitle = (_a = document == null ? void 0 : document.title) != null ? _a : \"\";\n const title = toRef((_b = newTitle != null ? newTitle : document == null ? void 0 : document.title) != null ? _b : null);\n const isReadonly = newTitle && typeof newTitle === \"function\";\n function format(t) {\n if (!(\"titleTemplate\" in options))\n return t;\n const template = options.titleTemplate || \"%s\";\n return typeof template === \"function\" ? template(t) : toValue(template).replace(/%s/g, t);\n }\n watch(\n title,\n (t, o) => {\n if (t !== o && document)\n document.title = format(typeof t === \"string\" ? t : \"\");\n },\n { immediate: true }\n );\n if (options.observe && !options.titleTemplate && document && !isReadonly) {\n useMutationObserver(\n (_c = document.head) == null ? void 0 : _c.querySelector(\"title\"),\n () => {\n if (document && document.title !== title.value)\n title.value = format(document.title);\n },\n { childList: true }\n );\n }\n tryOnBeforeUnmount(() => {\n if (restoreOnUnmount) {\n const restoredTitle = restoreOnUnmount(originalTitle, title.value || \"\");\n if (restoredTitle != null && document)\n document.title = restoredTitle;\n }\n });\n return title;\n}\n\nconst _TransitionPresets = {\n easeInSine: [0.12, 0, 0.39, 0],\n easeOutSine: [0.61, 1, 0.88, 1],\n easeInOutSine: [0.37, 0, 0.63, 1],\n easeInQuad: [0.11, 0, 0.5, 0],\n easeOutQuad: [0.5, 1, 0.89, 1],\n easeInOutQuad: [0.45, 0, 0.55, 1],\n easeInCubic: [0.32, 0, 0.67, 0],\n easeOutCubic: [0.33, 1, 0.68, 1],\n easeInOutCubic: [0.65, 0, 0.35, 1],\n easeInQuart: [0.5, 0, 0.75, 0],\n easeOutQuart: [0.25, 1, 0.5, 1],\n easeInOutQuart: [0.76, 0, 0.24, 1],\n easeInQuint: [0.64, 0, 0.78, 0],\n easeOutQuint: [0.22, 1, 0.36, 1],\n easeInOutQuint: [0.83, 0, 0.17, 1],\n easeInExpo: [0.7, 0, 0.84, 0],\n easeOutExpo: [0.16, 1, 0.3, 1],\n easeInOutExpo: [0.87, 0, 0.13, 1],\n easeInCirc: [0.55, 0, 1, 0.45],\n easeOutCirc: [0, 0.55, 0.45, 1],\n easeInOutCirc: [0.85, 0, 0.15, 1],\n easeInBack: [0.36, 0, 0.66, -0.56],\n easeOutBack: [0.34, 1.56, 0.64, 1],\n easeInOutBack: [0.68, -0.6, 0.32, 1.6]\n};\nconst TransitionPresets = /* @__PURE__ */ Object.assign({}, { linear: identity }, _TransitionPresets);\nfunction createEasingFunction([p0, p1, p2, p3]) {\n const a = (a1, a2) => 1 - 3 * a2 + 3 * a1;\n const b = (a1, a2) => 3 * a2 - 6 * a1;\n const c = (a1) => 3 * a1;\n const calcBezier = (t, a1, a2) => ((a(a1, a2) * t + b(a1, a2)) * t + c(a1)) * t;\n const getSlope = (t, a1, a2) => 3 * a(a1, a2) * t * t + 2 * b(a1, a2) * t + c(a1);\n const getTforX = (x) => {\n let aGuessT = x;\n for (let i = 0; i < 4; ++i) {\n const currentSlope = getSlope(aGuessT, p0, p2);\n if (currentSlope === 0)\n return aGuessT;\n const currentX = calcBezier(aGuessT, p0, p2) - x;\n aGuessT -= currentX / currentSlope;\n }\n return aGuessT;\n };\n return (x) => p0 === p1 && p2 === p3 ? x : calcBezier(getTforX(x), p1, p3);\n}\nfunction lerp(a, b, alpha) {\n return a + alpha * (b - a);\n}\nfunction toVec(t) {\n return (typeof t === \"number\" ? [t] : t) || [];\n}\nfunction executeTransition(source, from, to, options = {}) {\n var _a, _b;\n const fromVal = toValue(from);\n const toVal = toValue(to);\n const v1 = toVec(fromVal);\n const v2 = toVec(toVal);\n const duration = (_a = toValue(options.duration)) != null ? _a : 1e3;\n const startedAt = Date.now();\n const endAt = Date.now() + duration;\n const trans = typeof options.transition === \"function\" ? options.transition : (_b = toValue(options.transition)) != null ? _b : identity;\n const ease = typeof trans === \"function\" ? trans : createEasingFunction(trans);\n return new Promise((resolve) => {\n source.value = fromVal;\n const tick = () => {\n var _a2;\n if ((_a2 = options.abort) == null ? void 0 : _a2.call(options)) {\n resolve();\n return;\n }\n const now = Date.now();\n const alpha = ease((now - startedAt) / duration);\n const arr = toVec(source.value).map((n, i) => lerp(v1[i], v2[i], alpha));\n if (Array.isArray(source.value))\n source.value = arr.map((n, i) => {\n var _a3, _b2;\n return lerp((_a3 = v1[i]) != null ? _a3 : 0, (_b2 = v2[i]) != null ? _b2 : 0, alpha);\n });\n else if (typeof source.value === \"number\")\n source.value = arr[0];\n if (now < endAt) {\n requestAnimationFrame(tick);\n } else {\n source.value = toVal;\n resolve();\n }\n };\n tick();\n });\n}\nfunction useTransition(source, options = {}) {\n let currentId = 0;\n const sourceVal = () => {\n const v = toValue(source);\n return typeof v === \"number\" ? v : v.map(toValue);\n };\n const outputRef = ref(sourceVal());\n watch(sourceVal, async (to) => {\n var _a, _b;\n if (toValue(options.disabled))\n return;\n const id = ++currentId;\n if (options.delay)\n await promiseTimeout(toValue(options.delay));\n if (id !== currentId)\n return;\n const toVal = Array.isArray(to) ? to.map(toValue) : toValue(to);\n (_a = options.onStarted) == null ? void 0 : _a.call(options);\n await executeTransition(outputRef, outputRef.value, toVal, {\n ...options,\n abort: () => {\n var _a2;\n return id !== currentId || ((_a2 = options.abort) == null ? void 0 : _a2.call(options));\n }\n });\n (_b = options.onFinished) == null ? void 0 : _b.call(options);\n }, { deep: true });\n watch(() => toValue(options.disabled), (disabled) => {\n if (disabled) {\n currentId++;\n outputRef.value = sourceVal();\n }\n });\n tryOnScopeDispose(() => {\n currentId++;\n });\n return computed(() => toValue(options.disabled) ? sourceVal() : outputRef.value);\n}\n\nfunction useUrlSearchParams(mode = \"history\", options = {}) {\n const {\n initialValue = {},\n removeNullishValues = true,\n removeFalsyValues = false,\n write: enableWrite = true,\n window = defaultWindow\n } = options;\n if (!window)\n return reactive(initialValue);\n const state = reactive({});\n function getRawParams() {\n if (mode === \"history\") {\n return window.location.search || \"\";\n } else if (mode === \"hash\") {\n const hash = window.location.hash || \"\";\n const index = hash.indexOf(\"?\");\n return index > 0 ? hash.slice(index) : \"\";\n } else {\n return (window.location.hash || \"\").replace(/^#/, \"\");\n }\n }\n function constructQuery(params) {\n const stringified = params.toString();\n if (mode === \"history\")\n return `${stringified ? `?${stringified}` : \"\"}${window.location.hash || \"\"}`;\n if (mode === \"hash-params\")\n return `${window.location.search || \"\"}${stringified ? `#${stringified}` : \"\"}`;\n const hash = window.location.hash || \"#\";\n const index = hash.indexOf(\"?\");\n if (index > 0)\n return `${window.location.search || \"\"}${hash.slice(0, index)}${stringified ? `?${stringified}` : \"\"}`;\n return `${window.location.search || \"\"}${hash}${stringified ? `?${stringified}` : \"\"}`;\n }\n function read() {\n return new URLSearchParams(getRawParams());\n }\n function updateState(params) {\n const unusedKeys = new Set(Object.keys(state));\n for (const key of params.keys()) {\n const paramsForKey = params.getAll(key);\n state[key] = paramsForKey.length > 1 ? paramsForKey : params.get(key) || \"\";\n unusedKeys.delete(key);\n }\n Array.from(unusedKeys).forEach((key) => delete state[key]);\n }\n const { pause, resume } = pausableWatch(\n state,\n () => {\n const params = new URLSearchParams(\"\");\n Object.keys(state).forEach((key) => {\n const mapEntry = state[key];\n if (Array.isArray(mapEntry))\n mapEntry.forEach((value) => params.append(key, value));\n else if (removeNullishValues && mapEntry == null)\n params.delete(key);\n else if (removeFalsyValues && !mapEntry)\n params.delete(key);\n else\n params.set(key, mapEntry);\n });\n write(params);\n },\n { deep: true }\n );\n function write(params, shouldUpdate) {\n pause();\n if (shouldUpdate)\n updateState(params);\n window.history.replaceState(\n window.history.state,\n window.document.title,\n window.location.pathname + constructQuery(params)\n );\n resume();\n }\n function onChanged() {\n if (!enableWrite)\n return;\n write(read(), true);\n }\n useEventListener(window, \"popstate\", onChanged, false);\n if (mode !== \"history\")\n useEventListener(window, \"hashchange\", onChanged, false);\n const initial = read();\n if (initial.keys().next().value)\n updateState(initial);\n else\n Object.assign(state, initialValue);\n return state;\n}\n\nfunction useUserMedia(options = {}) {\n var _a, _b;\n const enabled = ref((_a = options.enabled) != null ? _a : false);\n const autoSwitch = ref((_b = options.autoSwitch) != null ? _b : true);\n const constraints = ref(options.constraints);\n const { navigator = defaultNavigator } = options;\n const isSupported = useSupported(() => {\n var _a2;\n return (_a2 = navigator == null ? void 0 : navigator.mediaDevices) == null ? void 0 : _a2.getUserMedia;\n });\n const stream = shallowRef();\n function getDeviceOptions(type) {\n switch (type) {\n case \"video\": {\n if (constraints.value)\n return constraints.value.video || false;\n break;\n }\n case \"audio\": {\n if (constraints.value)\n return constraints.value.audio || false;\n break;\n }\n }\n }\n async function _start() {\n if (!isSupported.value || stream.value)\n return;\n stream.value = await navigator.mediaDevices.getUserMedia({\n video: getDeviceOptions(\"video\"),\n audio: getDeviceOptions(\"audio\")\n });\n return stream.value;\n }\n function _stop() {\n var _a2;\n (_a2 = stream.value) == null ? void 0 : _a2.getTracks().forEach((t) => t.stop());\n stream.value = void 0;\n }\n function stop() {\n _stop();\n enabled.value = false;\n }\n async function start() {\n await _start();\n if (stream.value)\n enabled.value = true;\n return stream.value;\n }\n async function restart() {\n _stop();\n return await start();\n }\n watch(\n enabled,\n (v) => {\n if (v)\n _start();\n else _stop();\n },\n { immediate: true }\n );\n watch(\n constraints,\n () => {\n if (autoSwitch.value && stream.value)\n restart();\n },\n { immediate: true }\n );\n tryOnScopeDispose(() => {\n stop();\n });\n return {\n isSupported,\n stream,\n start,\n stop,\n restart,\n constraints,\n enabled,\n autoSwitch\n };\n}\n\nfunction useVModel(props, key, emit, options = {}) {\n var _a, _b, _c;\n const {\n clone = false,\n passive = false,\n eventName,\n deep = false,\n defaultValue,\n shouldEmit\n } = options;\n const vm = getCurrentInstance();\n const _emit = emit || (vm == null ? void 0 : vm.emit) || ((_a = vm == null ? void 0 : vm.$emit) == null ? void 0 : _a.bind(vm)) || ((_c = (_b = vm == null ? void 0 : vm.proxy) == null ? void 0 : _b.$emit) == null ? void 0 : _c.bind(vm == null ? void 0 : vm.proxy));\n let event = eventName;\n if (!key) {\n key = \"modelValue\";\n }\n event = event || `update:${key.toString()}`;\n const cloneFn = (val) => !clone ? val : typeof clone === \"function\" ? clone(val) : cloneFnJSON(val);\n const getValue = () => isDef(props[key]) ? cloneFn(props[key]) : defaultValue;\n const triggerEmit = (value) => {\n if (shouldEmit) {\n if (shouldEmit(value))\n _emit(event, value);\n } else {\n _emit(event, value);\n }\n };\n if (passive) {\n const initialValue = getValue();\n const proxy = ref(initialValue);\n let isUpdating = false;\n watch(\n () => props[key],\n (v) => {\n if (!isUpdating) {\n isUpdating = true;\n proxy.value = cloneFn(v);\n nextTick(() => isUpdating = false);\n }\n }\n );\n watch(\n proxy,\n (v) => {\n if (!isUpdating && (v !== props[key] || deep))\n triggerEmit(v);\n },\n { deep }\n );\n return proxy;\n } else {\n return computed({\n get() {\n return getValue();\n },\n set(value) {\n triggerEmit(value);\n }\n });\n }\n}\n\nfunction useVModels(props, emit, options = {}) {\n const ret = {};\n for (const key in props) {\n ret[key] = useVModel(\n props,\n key,\n emit,\n options\n );\n }\n return ret;\n}\n\nfunction useVibrate(options) {\n const {\n pattern = [],\n interval = 0,\n navigator = defaultNavigator\n } = options || {};\n const isSupported = useSupported(() => typeof navigator !== \"undefined\" && \"vibrate\" in navigator);\n const patternRef = toRef(pattern);\n let intervalControls;\n const vibrate = (pattern2 = patternRef.value) => {\n if (isSupported.value)\n navigator.vibrate(pattern2);\n };\n const stop = () => {\n if (isSupported.value)\n navigator.vibrate(0);\n intervalControls == null ? void 0 : intervalControls.pause();\n };\n if (interval > 0) {\n intervalControls = useIntervalFn(\n vibrate,\n interval,\n {\n immediate: false,\n immediateCallback: false\n }\n );\n }\n return {\n isSupported,\n pattern,\n intervalControls,\n vibrate,\n stop\n };\n}\n\nfunction useVirtualList(list, options) {\n const { containerStyle, wrapperProps, scrollTo, calculateRange, currentList, containerRef } = \"itemHeight\" in options ? useVerticalVirtualList(options, list) : useHorizontalVirtualList(options, list);\n return {\n list: currentList,\n scrollTo,\n containerProps: {\n ref: containerRef,\n onScroll: () => {\n calculateRange();\n },\n style: containerStyle\n },\n wrapperProps\n };\n}\nfunction useVirtualListResources(list) {\n const containerRef = ref(null);\n const size = useElementSize(containerRef);\n const currentList = ref([]);\n const source = shallowRef(list);\n const state = ref({ start: 0, end: 10 });\n return { state, source, currentList, size, containerRef };\n}\nfunction createGetViewCapacity(state, source, itemSize) {\n return (containerSize) => {\n if (typeof itemSize === \"number\")\n return Math.ceil(containerSize / itemSize);\n const { start = 0 } = state.value;\n let sum = 0;\n let capacity = 0;\n for (let i = start; i < source.value.length; i++) {\n const size = itemSize(i);\n sum += size;\n capacity = i;\n if (sum > containerSize)\n break;\n }\n return capacity - start;\n };\n}\nfunction createGetOffset(source, itemSize) {\n return (scrollDirection) => {\n if (typeof itemSize === \"number\")\n return Math.floor(scrollDirection / itemSize) + 1;\n let sum = 0;\n let offset = 0;\n for (let i = 0; i < source.value.length; i++) {\n const size = itemSize(i);\n sum += size;\n if (sum >= scrollDirection) {\n offset = i;\n break;\n }\n }\n return offset + 1;\n };\n}\nfunction createCalculateRange(type, overscan, getOffset, getViewCapacity, { containerRef, state, currentList, source }) {\n return () => {\n const element = containerRef.value;\n if (element) {\n const offset = getOffset(type === \"vertical\" ? element.scrollTop : element.scrollLeft);\n const viewCapacity = getViewCapacity(type === \"vertical\" ? element.clientHeight : element.clientWidth);\n const from = offset - overscan;\n const to = offset + viewCapacity + overscan;\n state.value = {\n start: from < 0 ? 0 : from,\n end: to > source.value.length ? source.value.length : to\n };\n currentList.value = source.value.slice(state.value.start, state.value.end).map((ele, index) => ({\n data: ele,\n index: index + state.value.start\n }));\n }\n };\n}\nfunction createGetDistance(itemSize, source) {\n return (index) => {\n if (typeof itemSize === \"number\") {\n const size2 = index * itemSize;\n return size2;\n }\n const size = source.value.slice(0, index).reduce((sum, _, i) => sum + itemSize(i), 0);\n return size;\n };\n}\nfunction useWatchForSizes(size, list, containerRef, calculateRange) {\n watch([size.width, size.height, list, containerRef], () => {\n calculateRange();\n });\n}\nfunction createComputedTotalSize(itemSize, source) {\n return computed(() => {\n if (typeof itemSize === \"number\")\n return source.value.length * itemSize;\n return source.value.reduce((sum, _, index) => sum + itemSize(index), 0);\n });\n}\nconst scrollToDictionaryForElementScrollKey = {\n horizontal: \"scrollLeft\",\n vertical: \"scrollTop\"\n};\nfunction createScrollTo(type, calculateRange, getDistance, containerRef) {\n return (index) => {\n if (containerRef.value) {\n containerRef.value[scrollToDictionaryForElementScrollKey[type]] = getDistance(index);\n calculateRange();\n }\n };\n}\nfunction useHorizontalVirtualList(options, list) {\n const resources = useVirtualListResources(list);\n const { state, source, currentList, size, containerRef } = resources;\n const containerStyle = { overflowX: \"auto\" };\n const { itemWidth, overscan = 5 } = options;\n const getViewCapacity = createGetViewCapacity(state, source, itemWidth);\n const getOffset = createGetOffset(source, itemWidth);\n const calculateRange = createCalculateRange(\"horizontal\", overscan, getOffset, getViewCapacity, resources);\n const getDistanceLeft = createGetDistance(itemWidth, source);\n const offsetLeft = computed(() => getDistanceLeft(state.value.start));\n const totalWidth = createComputedTotalSize(itemWidth, source);\n useWatchForSizes(size, list, containerRef, calculateRange);\n const scrollTo = createScrollTo(\"horizontal\", calculateRange, getDistanceLeft, containerRef);\n const wrapperProps = computed(() => {\n return {\n style: {\n height: \"100%\",\n width: `${totalWidth.value - offsetLeft.value}px`,\n marginLeft: `${offsetLeft.value}px`,\n display: \"flex\"\n }\n };\n });\n return {\n scrollTo,\n calculateRange,\n wrapperProps,\n containerStyle,\n currentList,\n containerRef\n };\n}\nfunction useVerticalVirtualList(options, list) {\n const resources = useVirtualListResources(list);\n const { state, source, currentList, size, containerRef } = resources;\n const containerStyle = { overflowY: \"auto\" };\n const { itemHeight, overscan = 5 } = options;\n const getViewCapacity = createGetViewCapacity(state, source, itemHeight);\n const getOffset = createGetOffset(source, itemHeight);\n const calculateRange = createCalculateRange(\"vertical\", overscan, getOffset, getViewCapacity, resources);\n const getDistanceTop = createGetDistance(itemHeight, source);\n const offsetTop = computed(() => getDistanceTop(state.value.start));\n const totalHeight = createComputedTotalSize(itemHeight, source);\n useWatchForSizes(size, list, containerRef, calculateRange);\n const scrollTo = createScrollTo(\"vertical\", calculateRange, getDistanceTop, containerRef);\n const wrapperProps = computed(() => {\n return {\n style: {\n width: \"100%\",\n height: `${totalHeight.value - offsetTop.value}px`,\n marginTop: `${offsetTop.value}px`\n }\n };\n });\n return {\n calculateRange,\n scrollTo,\n containerStyle,\n wrapperProps,\n currentList,\n containerRef\n };\n}\n\nfunction useWakeLock(options = {}) {\n const {\n navigator = defaultNavigator,\n document = defaultDocument\n } = options;\n const requestedType = ref(false);\n const sentinel = shallowRef(null);\n const documentVisibility = useDocumentVisibility({ document });\n const isSupported = useSupported(() => navigator && \"wakeLock\" in navigator);\n const isActive = computed(() => !!sentinel.value && documentVisibility.value === \"visible\");\n if (isSupported.value) {\n useEventListener(sentinel, \"release\", () => {\n var _a, _b;\n requestedType.value = (_b = (_a = sentinel.value) == null ? void 0 : _a.type) != null ? _b : false;\n });\n whenever(\n () => documentVisibility.value === \"visible\" && (document == null ? void 0 : document.visibilityState) === \"visible\" && requestedType.value,\n (type) => {\n requestedType.value = false;\n forceRequest(type);\n }\n );\n }\n async function forceRequest(type) {\n var _a;\n await ((_a = sentinel.value) == null ? void 0 : _a.release());\n sentinel.value = isSupported.value ? await navigator.wakeLock.request(type) : null;\n }\n async function request(type) {\n if (documentVisibility.value === \"visible\")\n await forceRequest(type);\n else\n requestedType.value = type;\n }\n async function release() {\n requestedType.value = false;\n const s = sentinel.value;\n sentinel.value = null;\n await (s == null ? void 0 : s.release());\n }\n return {\n sentinel,\n isSupported,\n isActive,\n request,\n forceRequest,\n release\n };\n}\n\nfunction useWebNotification(options = {}) {\n const {\n window = defaultWindow,\n requestPermissions: _requestForPermissions = true\n } = options;\n const defaultWebNotificationOptions = options;\n const isSupported = useSupported(() => {\n if (!window || !(\"Notification\" in window))\n return false;\n try {\n new Notification(\"\");\n } catch (e) {\n return false;\n }\n return true;\n });\n const permissionGranted = ref(isSupported.value && \"permission\" in Notification && Notification.permission === \"granted\");\n const notification = ref(null);\n const ensurePermissions = async () => {\n if (!isSupported.value)\n return;\n if (!permissionGranted.value && Notification.permission !== \"denied\") {\n const result = await Notification.requestPermission();\n if (result === \"granted\")\n permissionGranted.value = true;\n }\n return permissionGranted.value;\n };\n const { on: onClick, trigger: clickTrigger } = createEventHook();\n const { on: onShow, trigger: showTrigger } = createEventHook();\n const { on: onError, trigger: errorTrigger } = createEventHook();\n const { on: onClose, trigger: closeTrigger } = createEventHook();\n const show = async (overrides) => {\n if (!isSupported.value || !permissionGranted.value)\n return;\n const options2 = Object.assign({}, defaultWebNotificationOptions, overrides);\n notification.value = new Notification(options2.title || \"\", options2);\n notification.value.onclick = clickTrigger;\n notification.value.onshow = showTrigger;\n notification.value.onerror = errorTrigger;\n notification.value.onclose = closeTrigger;\n return notification.value;\n };\n const close = () => {\n if (notification.value)\n notification.value.close();\n notification.value = null;\n };\n if (_requestForPermissions)\n tryOnMounted(ensurePermissions);\n tryOnScopeDispose(close);\n if (isSupported.value && window) {\n const document = window.document;\n useEventListener(document, \"visibilitychange\", (e) => {\n e.preventDefault();\n if (document.visibilityState === \"visible\") {\n close();\n }\n });\n }\n return {\n isSupported,\n notification,\n ensurePermissions,\n permissionGranted,\n show,\n close,\n onClick,\n onShow,\n onError,\n onClose\n };\n}\n\nconst DEFAULT_PING_MESSAGE = \"ping\";\nfunction resolveNestedOptions(options) {\n if (options === true)\n return {};\n return options;\n}\nfunction useWebSocket(url, options = {}) {\n const {\n onConnected,\n onDisconnected,\n onError,\n onMessage,\n immediate = true,\n autoClose = true,\n protocols = []\n } = options;\n const data = ref(null);\n const status = ref(\"CLOSED\");\n const wsRef = ref();\n const urlRef = toRef(url);\n let heartbeatPause;\n let heartbeatResume;\n let explicitlyClosed = false;\n let retried = 0;\n let bufferedData = [];\n let pongTimeoutWait;\n const _sendBuffer = () => {\n if (bufferedData.length && wsRef.value && status.value === \"OPEN\") {\n for (const buffer of bufferedData)\n wsRef.value.send(buffer);\n bufferedData = [];\n }\n };\n const resetHeartbeat = () => {\n clearTimeout(pongTimeoutWait);\n pongTimeoutWait = void 0;\n };\n const close = (code = 1e3, reason) => {\n if (!isClient || !wsRef.value)\n return;\n explicitlyClosed = true;\n resetHeartbeat();\n heartbeatPause == null ? void 0 : heartbeatPause();\n wsRef.value.close(code, reason);\n wsRef.value = void 0;\n };\n const send = (data2, useBuffer = true) => {\n if (!wsRef.value || status.value !== \"OPEN\") {\n if (useBuffer)\n bufferedData.push(data2);\n return false;\n }\n _sendBuffer();\n wsRef.value.send(data2);\n return true;\n };\n const _init = () => {\n if (explicitlyClosed || typeof urlRef.value === \"undefined\")\n return;\n const ws = new WebSocket(urlRef.value, protocols);\n wsRef.value = ws;\n status.value = \"CONNECTING\";\n ws.onopen = () => {\n status.value = \"OPEN\";\n retried = 0;\n onConnected == null ? void 0 : onConnected(ws);\n heartbeatResume == null ? void 0 : heartbeatResume();\n _sendBuffer();\n };\n ws.onclose = (ev) => {\n status.value = \"CLOSED\";\n onDisconnected == null ? void 0 : onDisconnected(ws, ev);\n if (!explicitlyClosed && options.autoReconnect && (wsRef.value == null || ws === wsRef.value)) {\n const {\n retries = -1,\n delay = 1e3,\n onFailed\n } = resolveNestedOptions(options.autoReconnect);\n if (typeof retries === \"number\" && (retries < 0 || retried < retries)) {\n retried += 1;\n setTimeout(_init, delay);\n } else if (typeof retries === \"function\" && retries()) {\n setTimeout(_init, delay);\n } else {\n onFailed == null ? void 0 : onFailed();\n }\n }\n };\n ws.onerror = (e) => {\n onError == null ? void 0 : onError(ws, e);\n };\n ws.onmessage = (e) => {\n if (options.heartbeat) {\n resetHeartbeat();\n const {\n message = DEFAULT_PING_MESSAGE,\n responseMessage = message\n } = resolveNestedOptions(options.heartbeat);\n if (e.data === responseMessage)\n return;\n }\n data.value = e.data;\n onMessage == null ? void 0 : onMessage(ws, e);\n };\n };\n if (options.heartbeat) {\n const {\n message = DEFAULT_PING_MESSAGE,\n interval = 1e3,\n pongTimeout = 1e3\n } = resolveNestedOptions(options.heartbeat);\n const { pause, resume } = useIntervalFn(\n () => {\n send(message, false);\n if (pongTimeoutWait != null)\n return;\n pongTimeoutWait = setTimeout(() => {\n close();\n explicitlyClosed = false;\n }, pongTimeout);\n },\n interval,\n { immediate: false }\n );\n heartbeatPause = pause;\n heartbeatResume = resume;\n }\n if (autoClose) {\n if (isClient)\n useEventListener(\"beforeunload\", () => close());\n tryOnScopeDispose(close);\n }\n const open = () => {\n if (!isClient && !isWorker)\n return;\n close();\n explicitlyClosed = false;\n retried = 0;\n _init();\n };\n if (immediate)\n open();\n watch(urlRef, open);\n return {\n data,\n status,\n close,\n send,\n open,\n ws: wsRef\n };\n}\n\nfunction useWebWorker(arg0, workerOptions, options) {\n const {\n window = defaultWindow\n } = options != null ? options : {};\n const data = ref(null);\n const worker = shallowRef();\n const post = (...args) => {\n if (!worker.value)\n return;\n worker.value.postMessage(...args);\n };\n const terminate = function terminate2() {\n if (!worker.value)\n return;\n worker.value.terminate();\n };\n if (window) {\n if (typeof arg0 === \"string\")\n worker.value = new Worker(arg0, workerOptions);\n else if (typeof arg0 === \"function\")\n worker.value = arg0();\n else\n worker.value = arg0;\n worker.value.onmessage = (e) => {\n data.value = e.data;\n };\n tryOnScopeDispose(() => {\n if (worker.value)\n worker.value.terminate();\n });\n }\n return {\n data,\n post,\n terminate,\n worker\n };\n}\n\nfunction depsParser(deps, localDeps) {\n if (deps.length === 0 && localDeps.length === 0)\n return \"\";\n const depsString = deps.map((dep) => `'${dep}'`).toString();\n const depsFunctionString = localDeps.filter((dep) => typeof dep === \"function\").map((fn) => {\n const str = fn.toString();\n if (str.trim().startsWith(\"function\")) {\n return str;\n } else {\n const name = fn.name;\n return `const ${name} = ${str}`;\n }\n }).join(\";\");\n const importString = `importScripts(${depsString});`;\n return `${depsString.trim() === \"\" ? \"\" : importString} ${depsFunctionString}`;\n}\n\nfunction jobRunner(userFunc) {\n return (e) => {\n const userFuncArgs = e.data[0];\n return Promise.resolve(userFunc.apply(void 0, userFuncArgs)).then((result) => {\n postMessage([\"SUCCESS\", result]);\n }).catch((error) => {\n postMessage([\"ERROR\", error]);\n });\n };\n}\n\nfunction createWorkerBlobUrl(fn, deps, localDeps) {\n const blobCode = `${depsParser(deps, localDeps)}; onmessage=(${jobRunner})(${fn})`;\n const blob = new Blob([blobCode], { type: \"text/javascript\" });\n const url = URL.createObjectURL(blob);\n return url;\n}\n\nfunction useWebWorkerFn(fn, options = {}) {\n const {\n dependencies = [],\n localDependencies = [],\n timeout,\n window = defaultWindow\n } = options;\n const worker = ref();\n const workerStatus = ref(\"PENDING\");\n const promise = ref({});\n const timeoutId = ref();\n const workerTerminate = (status = \"PENDING\") => {\n if (worker.value && worker.value._url && window) {\n worker.value.terminate();\n URL.revokeObjectURL(worker.value._url);\n promise.value = {};\n worker.value = void 0;\n window.clearTimeout(timeoutId.value);\n workerStatus.value = status;\n }\n };\n workerTerminate();\n tryOnScopeDispose(workerTerminate);\n const generateWorker = () => {\n const blobUrl = createWorkerBlobUrl(fn, dependencies, localDependencies);\n const newWorker = new Worker(blobUrl);\n newWorker._url = blobUrl;\n newWorker.onmessage = (e) => {\n const { resolve = () => {\n }, reject = () => {\n } } = promise.value;\n const [status, result] = e.data;\n switch (status) {\n case \"SUCCESS\":\n resolve(result);\n workerTerminate(status);\n break;\n default:\n reject(result);\n workerTerminate(\"ERROR\");\n break;\n }\n };\n newWorker.onerror = (e) => {\n const { reject = () => {\n } } = promise.value;\n e.preventDefault();\n reject(e);\n workerTerminate(\"ERROR\");\n };\n if (timeout) {\n timeoutId.value = setTimeout(\n () => workerTerminate(\"TIMEOUT_EXPIRED\"),\n timeout\n );\n }\n return newWorker;\n };\n const callWorker = (...fnArgs) => new Promise((resolve, reject) => {\n var _a;\n promise.value = {\n resolve,\n reject\n };\n (_a = worker.value) == null ? void 0 : _a.postMessage([[...fnArgs]]);\n workerStatus.value = \"RUNNING\";\n });\n const workerFn = (...fnArgs) => {\n if (workerStatus.value === \"RUNNING\") {\n console.error(\n \"[useWebWorkerFn] You can only run one instance of the worker at a time.\"\n );\n return Promise.reject();\n }\n worker.value = generateWorker();\n return callWorker(...fnArgs);\n };\n return {\n workerFn,\n workerStatus,\n workerTerminate\n };\n}\n\nfunction useWindowFocus(options = {}) {\n const { window = defaultWindow } = options;\n if (!window)\n return ref(false);\n const focused = ref(window.document.hasFocus());\n useEventListener(window, \"blur\", () => {\n focused.value = false;\n });\n useEventListener(window, \"focus\", () => {\n focused.value = true;\n });\n return focused;\n}\n\nfunction useWindowScroll(options = {}) {\n const { window = defaultWindow, behavior = \"auto\" } = options;\n if (!window) {\n return {\n x: ref(0),\n y: ref(0)\n };\n }\n const internalX = ref(window.scrollX);\n const internalY = ref(window.scrollY);\n const x = computed({\n get() {\n return internalX.value;\n },\n set(x2) {\n scrollTo({ left: x2, behavior });\n }\n });\n const y = computed({\n get() {\n return internalY.value;\n },\n set(y2) {\n scrollTo({ top: y2, behavior });\n }\n });\n useEventListener(\n window,\n \"scroll\",\n () => {\n internalX.value = window.scrollX;\n internalY.value = window.scrollY;\n },\n {\n capture: false,\n passive: true\n }\n );\n return { x, y };\n}\n\nfunction useWindowSize(options = {}) {\n const {\n window = defaultWindow,\n initialWidth = Number.POSITIVE_INFINITY,\n initialHeight = Number.POSITIVE_INFINITY,\n listenOrientation = true,\n includeScrollbar = true,\n type = \"inner\"\n } = options;\n const width = ref(initialWidth);\n const height = ref(initialHeight);\n const update = () => {\n if (window) {\n if (type === \"outer\") {\n width.value = window.outerWidth;\n height.value = window.outerHeight;\n } else if (includeScrollbar) {\n width.value = window.innerWidth;\n height.value = window.innerHeight;\n } else {\n width.value = window.document.documentElement.clientWidth;\n height.value = window.document.documentElement.clientHeight;\n }\n }\n };\n update();\n tryOnMounted(update);\n useEventListener(\"resize\", update, { passive: true });\n if (listenOrientation) {\n const matches = useMediaQuery(\"(orientation: portrait)\");\n watch(matches, () => update());\n }\n return { width, height };\n}\n\nexport { DefaultMagicKeysAliasMap, StorageSerializers, TransitionPresets, computedAsync as asyncComputed, breakpointsAntDesign, breakpointsBootstrapV5, breakpointsElement, breakpointsMasterCss, breakpointsPrimeFlex, breakpointsQuasar, breakpointsSematic, breakpointsTailwind, breakpointsVuetify, breakpointsVuetifyV2, breakpointsVuetifyV3, cloneFnJSON, computedAsync, computedInject, createFetch, createReusableTemplate, createTemplatePromise, createUnrefFn, customStorageEventName, defaultDocument, defaultLocation, defaultNavigator, defaultWindow, executeTransition, formatTimeAgo, getSSRHandler, mapGamepadToXbox360Controller, onClickOutside, onKeyDown, onKeyPressed, onKeyStroke, onKeyUp, onLongPress, onStartTyping, setSSRHandler, templateRef, unrefElement, useActiveElement, useAnimate, useAsyncQueue, useAsyncState, useBase64, useBattery, useBluetooth, useBreakpoints, useBroadcastChannel, useBrowserLocation, useCached, useClipboard, useClipboardItems, useCloned, useColorMode, useConfirmDialog, useCssVar, useCurrentElement, useCycleList, useDark, useDebouncedRefHistory, useDeviceMotion, useDeviceOrientation, useDevicePixelRatio, useDevicesList, useDisplayMedia, useDocumentVisibility, useDraggable, useDropZone, useElementBounding, useElementByPoint, useElementHover, useElementSize, useElementVisibility, useEventBus, useEventListener, useEventSource, useEyeDropper, useFavicon, useFetch, useFileDialog, useFileSystemAccess, useFocus, useFocusWithin, useFps, useFullscreen, useGamepad, useGeolocation, useIdle, useImage, useInfiniteScroll, useIntersectionObserver, useKeyModifier, useLocalStorage, useMagicKeys, useManualRefHistory, useMediaControls, useMediaQuery, useMemoize, useMemory, useMounted, useMouse, useMouseInElement, useMousePressed, useMutationObserver, useNavigatorLanguage, useNetwork, useNow, useObjectUrl, useOffsetPagination, useOnline, usePageLeave, useParallax, useParentElement, usePerformanceObserver, usePermission, usePointer, usePointerLock, usePointerSwipe, usePreferredColorScheme, usePreferredContrast, usePreferredDark, usePreferredLanguages, usePreferredReducedMotion, usePrevious, useRafFn, useRefHistory, useResizeObserver, useScreenOrientation, useScreenSafeArea, useScriptTag, useScroll, useScrollLock, useSessionStorage, useShare, useSorted, useSpeechRecognition, useSpeechSynthesis, useStepper, useStorage, useStorageAsync, useStyleTag, useSupported, useSwipe, useTemplateRefsList, useTextDirection, useTextSelection, useTextareaAutosize, useThrottledRefHistory, useTimeAgo, useTimeoutPoll, useTimestamp, useTitle, useTransition, useUrlSearchParams, useUserMedia, useVModel, useVModels, useVibrate, useVirtualList, useWakeLock, useWebNotification, useWebSocket, useWebWorker, useWebWorkerFn, useWindowFocus, useWindowScroll, useWindowSize };\n","import * as __Vue from \"vue\";\r\n\r\n/**\r\n *\r\n * @param fnCode - example: \"() => { return a + b; }\"\r\n * @param params - example: { a: 1, b: 2 }\r\n * @returns\r\n */\r\nexport function createFnFromString(\r\n fnCode: string,\r\n params?: Record<string, any>\r\n) {\r\n params = params || {};\r\n\r\n const keys = [...Object.keys(params), \"__Vue\"];\r\n const values = [...Object.values(params), __Vue];\r\n\r\n try {\r\n return new Function(...keys, `return (${fnCode})`)(...values);\r\n } catch (error) {\r\n throw new Error(error + \" in function code: \" + fnCode);\r\n }\r\n}\r\n\r\n/**\r\n *\r\n * @param code - example: \":(a, b) => { return a + b; }\"\r\n * @returns\r\n */\r\nexport function tryStringWithColonToFunction(\r\n code: string\r\n): Function | undefined {\r\n if (code.startsWith(\":\")) {\r\n code = code.slice(1);\r\n try {\r\n return createFnFromString(code);\r\n } catch (error) {\r\n throw new Error(error + \" in function code: \" + code);\r\n }\r\n }\r\n\r\n return undefined;\r\n}\r\n","export function memoize<T extends (...args: any[]) => any>(\r\n fn: T,\r\n getKey?: (...args: Parameters<T>) => string\r\n): T {\r\n const cache = new Map<string, ReturnType<T>>();\r\n\r\n return function (...args: Parameters<T>): ReturnType<T> {\r\n const key = getKey ? getKey(...args) : JSON.stringify(args);\r\n if (cache.has(key)) {\r\n return cache.get(key) as ReturnType<T>;\r\n }\r\n const result = fn(...args);\r\n cache.set(key, result);\r\n return result;\r\n } as T;\r\n}\r\n\r\nexport function memoizedValue<T>(fn: () => T): { value: T } {\r\n let result: T | undefined;\r\n\r\n return {\r\n get value(): T {\r\n if (result === undefined) {\r\n result = fn();\r\n }\r\n return result!;\r\n },\r\n };\r\n}\r\n\r\nexport function isAsyncFunction(func: Function): boolean {\r\n return func.constructor.name === \"AsyncFunction\";\r\n}\r\n","import {\r\n TRef,\r\n TVueComputed,\r\n TJsComputed,\r\n TBindableVar,\r\n} from \"@/shared/configTypes\";\r\nimport { computed, readonly, ref, shallowRef, watch } from \"vue\";\r\nimport { TSnapshot } from \"@/shared/bindableHelper\";\r\nimport { asyncComputed } from \"@vueuse/core\";\r\nimport * as jsCodeSystem from \"@/systems/jsCodeSystem\";\r\nimport * as fnSystem from \"@/systems/fnSystem\";\r\nimport { useDeepCompareRef } from \"@/systems/vueSystem\";\r\nimport * as computedInit from \"@/shared/computedInit\";\r\n\r\nexport function createRef(varConfig: TRef, debugInfo?: any) {\r\n const { deepCompare = false } = varConfig;\r\n const obj = deepCompare\r\n ? useDeepCompareRef(varConfig.value)\r\n : ref(varConfig.value);\r\n return obj;\r\n}\r\n\r\nexport function createVueComputedByStringCode(\r\n varConfig: TVueComputed,\r\n snapshot: TSnapshot,\r\n debugInfo?: any\r\n) {\r\n const { bind: params = {}, code, const: isConsts = [] } = varConfig;\r\n\r\n const refObjs = Object.values(params).map((p, index) => {\r\n const isConst = isConsts[index] === 1;\r\n return isConst ? p : snapshot.getVueRefObjectOrValue(p);\r\n });\r\n\r\n if (fnSystem.isAsyncFunction(new Function(code))) {\r\n return asyncComputed(\r\n async () => {\r\n const fnParams = Object.fromEntries(\r\n Object.keys(params).map((key, index) => {\r\n return [key, refObjs[index]];\r\n })\r\n );\r\n\r\n return await jsCodeSystem.createFnFromString(code, fnParams)();\r\n },\r\n null,\r\n { lazy: true }\r\n );\r\n }\r\n\r\n const fnParams = Object.fromEntries(\r\n Object.keys(params).map((key, index) => {\r\n return [key, refObjs[index]];\r\n })\r\n );\r\n\r\n const fn = jsCodeSystem.createFnFromString(code, fnParams);\r\n const obj = computed(fn);\r\n return obj;\r\n}\r\n\r\nexport function createJsComputedByStringCode(\r\n varConfig: TJsComputed,\r\n snapshot: TSnapshot,\r\n debugInfo?: any\r\n) {\r\n const {\r\n inputs = [],\r\n code,\r\n slient,\r\n data,\r\n asyncInit: asyncInitValue = null,\r\n deepEqOnInput = 0,\r\n } = varConfig;\r\n\r\n const slients = slient || Array(inputs.length).fill(0);\r\n const datas = data || Array(inputs.length).fill(0);\r\n\r\n const watchTargets = inputs\r\n .filter((_, index) => slients[index] === 0 && datas[index] === 0)\r\n .map((input) => snapshot.getVueRefObject(input as TBindableVar));\r\n\r\n function getInputValues() {\r\n return inputs.map((input, index) =>\r\n datas[index] === 1\r\n ? input\r\n : snapshot.getObjectToValue(input as TBindableVar)\r\n );\r\n }\r\n\r\n const fn = jsCodeSystem.createFnFromString(code);\r\n const result =\r\n deepEqOnInput === 0\r\n ? shallowRef(computedInit.__INITIAL__)\r\n : useDeepCompareRef(computedInit.__INITIAL__);\r\n const watchOptions = { immediate: true, deep: true };\r\n\r\n if (fnSystem.isAsyncFunction(fn)) {\r\n result.value = asyncInitValue;\r\n watch(\r\n watchTargets,\r\n async () => {\r\n const args = getInputValues();\r\n if (args.some(computedInit.isInitial)) {\r\n return;\r\n }\r\n\r\n result.value = await fn(...getInputValues());\r\n },\r\n watchOptions\r\n );\r\n } else {\r\n watch(\r\n watchTargets,\r\n () => {\r\n const args = getInputValues();\r\n if (args.some(computedInit.isInitial)) {\r\n return;\r\n }\r\n\r\n result.value = fn(...args);\r\n },\r\n watchOptions\r\n );\r\n }\r\n\r\n return readonly(result);\r\n}\r\n","import { TScope, TBindableVar, TVar } from \"@/shared/configTypes\";\r\nimport { Ref, ComputedRef, shallowRef } from \"vue\";\r\nimport { defaultMap } from \"@/systems/mapSystem\";\r\nimport { useDeepCompareRef } from \"@/systems/vueSystem\";\r\nimport * as varBuilder from \"@/shared/varBuilder\";\r\nimport { TSnapshot } from \"@/shared/bindableHelper\";\r\nimport * as computedInit from \"@/shared/computedInit\";\r\n\r\ntype TVueRef = Ref<any> | ComputedRef<any>;\r\ntype TVarMap = Map<TVar[\"id\"], TVueRef>;\r\ntype TVarSeq = TVarMap[];\r\ntype TDebugInfo = {\r\n scopeId: TScope[\"id\"];\r\n varMapIndex: number;\r\n};\r\nexport type TScopeSnapshot = ReturnType<typeof createScopeSnapshot>;\r\n\r\nfunction varSeqFactory() {\r\n return [];\r\n}\r\n\r\nconst _scopeMap = defaultMap<TScope[\"id\"], TVarSeq>(varSeqFactory);\r\n\r\nexport function getScopeMap() {\r\n return _scopeMap;\r\n}\r\n\r\nexport function createVarStore(scope: TScope, snapshot: TSnapshot) {\r\n const indexSeq = _scopeMap.getOrDefault(scope.id);\r\n\r\n const varMap = new Map();\r\n indexSeq.push(varMap);\r\n\r\n snapshot.replaceSnapshot({\r\n scopeSnapshot: createScopeSnapshot(),\r\n });\r\n\r\n const saveToMap = (v: TVar, obj: any) => {\r\n varMap.set(v.id, obj);\r\n };\r\n\r\n scope.refs?.forEach((varConfig) => {\r\n saveToMap(varConfig, varBuilder.createRef(varConfig));\r\n });\r\n\r\n // web computed must be initialized before js computed and vue computed\r\n scope.web_computed?.forEach((varConfig) => {\r\n const { init } = varConfig;\r\n\r\n const refObj =\r\n varConfig.deepEqOnInput === undefined\r\n ? shallowRef(init ?? computedInit.__INITIAL__)\r\n : useDeepCompareRef(init ?? computedInit.__INITIAL__);\r\n saveToMap(varConfig, refObj);\r\n });\r\n\r\n scope.vue_computed?.forEach((varConfig) => {\r\n saveToMap(\r\n varConfig,\r\n varBuilder.createVueComputedByStringCode(varConfig, snapshot)\r\n );\r\n });\r\n\r\n scope.js_computed?.forEach((varConfig) => {\r\n saveToMap(\r\n varConfig,\r\n varBuilder.createJsComputedByStringCode(varConfig, snapshot)\r\n );\r\n });\r\n\r\n scope.data?.forEach((varConfig) => {\r\n saveToMap(varConfig, varConfig.value);\r\n });\r\n\r\n return indexSeq.length - 1;\r\n}\r\n\r\nexport function createScopeSnapshot() {\r\n const snapshot = new Map<TScope[\"id\"], TVarMap[]>();\r\n\r\n for (const [scopeId, indexSeq] of _scopeMap) {\r\n const varMap = indexSeq[indexSeq.length - 1];\r\n snapshot.set(scopeId, [varMap]);\r\n }\r\n\r\n function getVueRef(varConfig: TBindableVar) {\r\n return _getVueRef(varConfig, snapshot);\r\n }\r\n\r\n return {\r\n getVueRef,\r\n };\r\n}\r\n\r\nexport function getVueRef(varConfig: TBindableVar) {\r\n return _getVueRef(varConfig, _scopeMap);\r\n}\r\n\r\nfunction _getVueRef(\r\n varConfig: TBindableVar,\r\n scopeMap: {\r\n get(scopeId: TScope[\"id\"]): TVarSeq | undefined;\r\n }\r\n) {\r\n const indexSeq = scopeMap.get(varConfig.sid);\r\n if (!indexSeq) {\r\n throw new Error(`Scope ${varConfig.sid} not found`);\r\n }\r\n\r\n const currentVarMap = indexSeq[indexSeq.length - 1];\r\n const ref = currentVarMap.get(varConfig.id);\r\n if (!ref) {\r\n throw new Error(`Var ${varConfig.id} not found in scope ${varConfig.sid}`);\r\n }\r\n\r\n return ref;\r\n}\r\n\r\nexport function clearScopeVarStore(scopeId: TScope[\"id\"]) {\r\n _scopeMap.delete(scopeId);\r\n}\r\n\r\nexport function removeIndexVars(scopeId: TScope[\"id\"], varMapIndex: number) {\r\n const indexMap = _scopeMap.get(scopeId);\r\n if (!indexMap) {\r\n return;\r\n }\r\n\r\n indexMap.splice(varMapIndex, 1);\r\n}\r\n","import { TElementRef, TScope } from \"@/shared/configTypes\";\r\nimport { defaultMap } from \"@/systems/mapSystem\";\r\nimport { shallowRef, ShallowRef } from \"vue\";\r\n\r\nexport type TElementRefSnapshot = ReturnType<typeof createElementRefSnapshot>;\r\n\r\ntype TScopeId = TScope[\"id\"];\r\ntype TRefId = TElementRef[\"id\"];\r\ntype TRefMap = Map<TRefId, ShallowRef>;\r\n\r\nconst scopeMap = defaultMap<TScopeId, TRefMap[]>(() => []);\r\n\r\nexport function createElementRefStore(scope: TScope) {\r\n const refMap = new Map<TRefId, ShallowRef>();\r\n const index = scopeMap.getOrDefault(scope.id).push(refMap);\r\n\r\n scope.eRefs?.forEach((eRef) => {\r\n const refObject = shallowRef();\r\n refMap.set(eRef.id, refObject);\r\n });\r\n\r\n return index;\r\n}\r\n\r\nexport function removeElementRef(scopeId: TScopeId, index: number) {\r\n const refMaps = scopeMap.get(scopeId);\r\n if (!refMaps) {\r\n return;\r\n }\r\n\r\n refMaps.splice(index, 1);\r\n}\r\n\r\nexport function createElementRefSnapshot() {\r\n const snapshotMap = new Map<TScopeId, TRefMap>(\r\n Array.from(scopeMap.entries()).map(([scopeId, refMaps]) => [\r\n scopeId,\r\n refMaps[refMaps.length - 1],\r\n ])\r\n );\r\n\r\n function getRef(elementRef: TElementRef) {\r\n return snapshotMap.get(elementRef.sid)!.get(elementRef.id)!;\r\n }\r\n\r\n return {\r\n getRef,\r\n };\r\n}\r\n","type TMaybeBindable<T = any> = T | TBindableValue;\r\n\r\nexport type TBindableValue =\r\n | TBindableVar\r\n | TBindableVForItem\r\n | TBindableVForIndex\r\n | TBindableJs\r\n | TBindableSlotProp\r\n | TBindableEventContext\r\n | TBindableRouterParams\r\n | TBindableElementRef\r\n | TBindableJsOutput;\r\n\r\nexport type TBinding = TBindableValue;\r\nexport type TNameBinding = Record<string, TBinding>;\r\n\r\nexport interface TVar {\r\n id: string;\r\n sid: string;\r\n path?: (string | number)[];\r\n}\r\n\r\ninterface TBindable {\r\n type:\r\n | \"var\"\r\n | \"js\"\r\n | \"const\"\r\n | \"vf\"\r\n | \"vf-i\"\r\n | \"sp\"\r\n | \"event\"\r\n | \"ele_ref\"\r\n | \"jsOutput\"\r\n | \"routePar\"\r\n | \"routeAct\";\r\n}\r\n\r\nexport interface TBindableJs extends TBindable {\r\n type: \"js\";\r\n code: string;\r\n bind: Record<string, TBindableValue>;\r\n ext?: \"cpt\"[]; // cpt: computed\r\n}\r\n\r\nexport interface TBindableRef extends TBindable {\r\n type: \"var\";\r\n sid: string;\r\n id: string;\r\n path?: (string | number)[];\r\n}\r\n\r\nexport interface TBindableComputed extends TBindable {\r\n type: \"var\";\r\n sid: string;\r\n id: string;\r\n path?: (string | number)[];\r\n}\r\n\r\nexport interface TBindableComputed extends TBindable {\r\n type: \"var\";\r\n sid: string;\r\n id: string;\r\n path?: (string | number)[];\r\n}\r\n\r\nexport interface TBindableWebComputed extends TBindable {\r\n type: \"var\";\r\n sid: string;\r\n id: string;\r\n path?: (string | number)[];\r\n}\r\n\r\nexport interface TBindableVar extends TBindable {\r\n type: \"var\";\r\n sid: string;\r\n id: string;\r\n path?: (string | number)[];\r\n}\r\n\r\nexport interface TBindableRouterParams extends TBindable {\r\n type: \"routePar\";\r\n prop?: \"params\" | \"fullPath\" | \"path\";\r\n path?: (string | number)[];\r\n}\r\n\r\nexport interface TBindableRouterAction extends TBindable {\r\n type: \"routeAct\";\r\n}\r\n\r\nexport interface TBindableElementRef extends TBindable {\r\n type: \"ele_ref\";\r\n sid: string;\r\n id: string;\r\n}\r\n\r\nexport interface TBindableVForItem extends TBindable {\r\n type: \"vf\";\r\n fid: string;\r\n path?: (string | number)[];\r\n}\r\n\r\nexport interface TBindableVForIndex extends TBindable {\r\n type: \"vf-i\";\r\n fid: string;\r\n}\r\n\r\nexport interface TBindableSlotProp extends TBindable {\r\n type: \"sp\";\r\n id: string;\r\n name: string;\r\n}\r\n\r\nexport interface TBindableEventContext extends TBindable {\r\n type: \"event\";\r\n path: string;\r\n}\r\n\r\nexport interface TBindableJsOutput extends TBindable {\r\n type: \"jsOutput\";\r\n}\r\n\r\nexport interface TRef extends TVar {\r\n type: \"ref\";\r\n value: any;\r\n deepCompare?: boolean;\r\n debounced?: number;\r\n}\r\n\r\nexport interface TVueComputed extends TVar {\r\n code: string;\r\n bind: TNameBinding;\r\n const?: (0 | 1)[];\r\n}\r\n\r\nexport interface TJsComputed extends TVar {\r\n inputs: TBinding[];\r\n code: string;\r\n slient?: (1 | 0)[];\r\n data?: (1 | 0)[];\r\n asyncInit?: any;\r\n deepEqOnInput?: 1;\r\n}\r\n\r\nexport interface TWebComputed extends TVar {\r\n url: string;\r\n key: string;\r\n inputs: TBinding[];\r\n init?: any;\r\n}\r\n\r\nexport interface TConstData extends TVar {\r\n value: any;\r\n}\r\n\r\nexport namespace bindableTools {\r\n export function isVar(bindable: TMaybeBindable): bindable is TBindableVar {\r\n return bindable.type === \"var\";\r\n }\r\n\r\n export function isRouterParams(\r\n bindable: TMaybeBindable\r\n ): bindable is TBindableRouterParams {\r\n return bindable.type === \"routePar\";\r\n }\r\n\r\n export function isRouterAction(\r\n bindable: TMaybeBindable\r\n ): bindable is TBindableRouterAction {\r\n return bindable.type === \"routeAct\";\r\n }\r\n\r\n export function isJs(bindable: TMaybeBindable): bindable is TBindableJs {\r\n return bindable.type === \"js\";\r\n }\r\n\r\n export function isJsOutput(\r\n bindable: TMaybeBindable\r\n ): bindable is TBindableJsOutput {\r\n return bindable.type === \"jsOutput\";\r\n }\r\n\r\n export function isVForItem(\r\n bindable: TMaybeBindable\r\n ): bindable is TBindableVForItem {\r\n return bindable.type === \"vf\";\r\n }\r\n\r\n export function isVForIndex(\r\n bindable: TMaybeBindable\r\n ): bindable is TBindableVForIndex {\r\n return bindable.type === \"vf-i\";\r\n }\r\n\r\n export function isSlotProp(\r\n bindable: TMaybeBindable\r\n ): bindable is TBindableSlotProp {\r\n return bindable.type === \"sp\";\r\n }\r\n\r\n export function isEventContext(\r\n bindable: TMaybeBindable\r\n ): bindable is TBindableEventContext {\r\n return bindable.type === \"event\";\r\n }\r\n\r\n export function isElementRef(\r\n bindable: TMaybeBindable\r\n ): bindable is TBindableElementRef {\r\n return bindable.type === \"ele_ref\";\r\n }\r\n\r\n export function IsBinding(bindable: TMaybeBindable): bindable is TBinding {\r\n return bindable.type !== undefined;\r\n }\r\n}\r\n","import { defaultMap } from \"@/systems/mapSystem\";\r\nimport { TSlot, TBindableSlotProp } from \"./configTypes\";\r\n\r\nimport { shallowRef, ShallowRef } from \"vue\";\r\n\r\nexport type TSlotSnapshot = ReturnType<typeof createSnapshot>;\r\n\r\ntype TSlotId = NonNullable<TSlot[\"props\"]>[\"id\"];\r\ntype TSlotPropSeq = ShallowRef[];\r\n\r\nconst _slotMap = defaultMap<TSlotId, TSlotPropSeq>(() => []);\r\n\r\nexport function SetupCollect(slotId: TSlotId) {\r\n const seq = _slotMap.getOrDefault(slotId);\r\n\r\n seq.push(shallowRef({}));\r\n return seq.length - 1;\r\n}\r\n\r\nexport function updateValues(\r\n slotId: TSlotId,\r\n seqIndex: number,\r\n values: Record<string, any>\r\n) {\r\n _slotMap.get(slotId)![seqIndex].value = values;\r\n}\r\n\r\nexport function removeSlotInfo(slotId: TSlotId) {\r\n _slotMap.delete(slotId);\r\n}\r\n\r\n/**\r\n * call in setup of element use slot props value\r\n */\r\nexport function createSnapshot() {\r\n const snapshot = new Map<TSlotId, ShallowRef>();\r\n\r\n for (const [scopeId, indexSeq] of _slotMap) {\r\n const valueSeq = indexSeq[indexSeq.length - 1];\r\n snapshot.set(scopeId, valueSeq);\r\n }\r\n\r\n function getPropsValue(info: TBindableSlotProp) {\r\n return snapshot.get(info.id)!.value[info.name];\r\n }\r\n\r\n return {\r\n getPropsValue,\r\n };\r\n}\r\n","import {\r\n TBindableVar,\r\n TVForComponent,\r\n TBindableVForItem,\r\n} from \"@/shared/configTypes\";\r\nimport { TSnapshot } from \"@/shared/bindableHelper\";\r\nimport {\r\n ComputedRef,\r\n customRef,\r\n ref,\r\n Ref,\r\n toValue,\r\n InjectionKey,\r\n inject,\r\n provide,\r\n} from \"vue\";\r\nimport * as objectSystem from \"@/systems/objectSystem\";\r\nimport { defaultMap } from \"@/systems/mapSystem\";\r\n\r\ntype TFId = TVForComponent[\"props\"][\"fid\"];\r\ntype TArray = TBindableVar | any[];\r\n\r\nexport type TVForInfo = {\r\n fid: string;\r\n index: number;\r\n};\r\n\r\ntype TKey2indexMap = Map<any, Ref<number>>;\r\n\r\nconst vforSourceMap = new Map<TFId, TArraySourceGetter>();\r\nconst fid2keyMap = defaultMap<TFId, TKey2indexMap>(() => new Map());\r\nconst vforSourceLoopNumberMap = new Set<TFId>();\r\n\r\nconst VFOR_KEY = Symbol(\"vfor\") as InjectionKey<Record<TFId, any>>;\r\n\r\nexport function provideVForKey(vforInfo: { fid: string; key: any }) {\r\n const preInfo = injectVForKey() ?? {};\r\n provide(VFOR_KEY, { ...preInfo, ...{ [vforInfo.fid]: vforInfo.key } });\r\n}\r\n\r\nfunction injectVForKey() {\r\n return inject(VFOR_KEY, undefined);\r\n}\r\n\r\nfunction injectVForFid2keyMap() {\r\n const obj = injectVForKey();\r\n const itemMap = new Map();\r\n if (obj === undefined) {\r\n return itemMap;\r\n }\r\n\r\n Object.keys(obj).forEach((fid) => {\r\n itemMap.set(fid, obj[fid]);\r\n });\r\n\r\n return itemMap;\r\n}\r\n\r\nexport function markArray(\r\n fid: TFId,\r\n array: TArray,\r\n isBindRef: boolean,\r\n isLoopNumber: boolean\r\n) {\r\n if (isLoopNumber) {\r\n vforSourceLoopNumberMap.add(fid);\r\n return;\r\n }\r\n\r\n let arraySourceGetter: TArraySourceGetter;\r\n\r\n if (isBindRef) {\r\n arraySourceGetter = new BindableArraySourceGetter(array as TBindableVar);\r\n } else {\r\n const arrayValue = Array.isArray(array)\r\n ? array\r\n : Object.entries(array).map(([key, value], index) => [value, key, index]);\r\n\r\n arraySourceGetter = new ConstArraySourceGetter(arrayValue);\r\n }\r\n\r\n vforSourceMap.set(fid, arraySourceGetter);\r\n}\r\n\r\n/**\r\n * call this function in Container Setup\r\n *\r\n */\r\nexport function markVForIndex(fid: TFId, key: any, index: number) {\r\n const key2indexMap = fid2keyMap.getOrDefault(fid);\r\n\r\n if (!key2indexMap.has(key)) {\r\n key2indexMap.set(key, ref(index));\r\n }\r\n\r\n key2indexMap.get(key)!.value = index;\r\n}\r\n\r\nexport function keysCollector(fid: TFId) {\r\n const usedKeys = new Set<any>();\r\n\r\n function add(key: any) {\r\n usedKeys.add(key);\r\n }\r\n\r\n function removeUnusedKeys() {\r\n const key2indexMap = fid2keyMap.get(fid);\r\n if (key2indexMap === undefined) {\r\n return;\r\n }\r\n\r\n key2indexMap.forEach((_, key) => {\r\n if (!usedKeys.has(key)) {\r\n key2indexMap.delete(key);\r\n }\r\n });\r\n }\r\n\r\n return {\r\n add,\r\n removeUnusedKeys,\r\n };\r\n}\r\n\r\nexport function createVForSnapshot(key?: any) {\r\n const currentKey = key;\r\n const keyMapSnapshot = injectVForFid2keyMap();\r\n\r\n function getVForIndex(fid: TFId) {\r\n const key = keyMapSnapshot.get(fid) ?? currentKey;\r\n\r\n return fid2keyMap.get(fid)!.get(key)!.value;\r\n }\r\n\r\n return {\r\n getVForIndex,\r\n };\r\n}\r\n\r\nexport function createRefObjectWithPaths(options: {\r\n binding: TBindableVForItem;\r\n snapshot: TSnapshot;\r\n}) {\r\n const getter = vforSourceMap.get(options.binding.fid)!;\r\n return getter.createRefObjectWithPaths(options);\r\n}\r\n\r\nexport function isVForLoopNumber(fid: TFId) {\r\n return vforSourceLoopNumberMap.has(fid);\r\n}\r\n\r\ninterface TArraySourceGetter {\r\n createRefObjectWithPaths(options: {\r\n binding: TBindableVForItem;\r\n snapshot: TSnapshot;\r\n }): Ref<any[], any[]>;\r\n}\r\n\r\nclass ConstArraySourceGetter implements TArraySourceGetter {\r\n constructor(private array: any[]) {}\r\n\r\n createRefObjectWithPaths(options: {\r\n binding: TBindableVForItem;\r\n snapshot: TSnapshot;\r\n }) {\r\n const { binding } = options;\r\n const { snapshot } = options;\r\n const { path = [] } = binding;\r\n const paths = [...path];\r\n\r\n const currentVForIndex = snapshot.getVForIndex(binding.fid);\r\n paths.unshift(currentVForIndex);\r\n\r\n return customRef(() => {\r\n return {\r\n get: () => {\r\n return objectSystem.getByPaths(\r\n this.array,\r\n paths,\r\n snapshot.getObjectToValue\r\n );\r\n },\r\n set: () => {\r\n throw new Error(\"Cannot set value to a constant array\");\r\n },\r\n };\r\n });\r\n }\r\n}\r\n\r\nclass BindableArraySourceGetter implements TArraySourceGetter {\r\n private _isDictSource: boolean | undefined;\r\n constructor(private binding: TBindableVar) {}\r\n\r\n private isDictSource(orgRef: Ref<any, any> | ComputedRef<any>) {\r\n if (this._isDictSource === undefined) {\r\n const sourceValue = toValue(orgRef);\r\n this._isDictSource = sourceValue !== null && !Array.isArray(sourceValue);\r\n }\r\n\r\n return this._isDictSource;\r\n }\r\n\r\n createRefObjectWithPaths(options: {\r\n binding: TBindableVForItem;\r\n snapshot: TSnapshot;\r\n }): Ref<any[], any[]> {\r\n const { binding } = options;\r\n const { path = [] } = binding;\r\n const paths = [...path];\r\n const { snapshot } = options;\r\n\r\n const orgRef = snapshot.getVueRefObject(this.binding) as\r\n | Ref<any, any>\r\n | ComputedRef<any>;\r\n\r\n const isDictSource = this.isDictSource(orgRef);\r\n const currentVForIndex = snapshot.getVForIndex(binding.fid);\r\n const defaultDictPath = isDictSource && paths.length === 0 ? [0] : [];\r\n paths.unshift(currentVForIndex, ...defaultDictPath);\r\n\r\n return customRef(() => {\r\n return {\r\n get: () => {\r\n const sourceValue = toValue(orgRef);\r\n\r\n const newSourceValue = isDictSource\r\n ? Object.entries(sourceValue).map(([key, value], index) => [\r\n value,\r\n key,\r\n index,\r\n ])\r\n : sourceValue;\r\n\r\n try {\r\n return objectSystem.getByPaths(\r\n toValue(newSourceValue),\r\n paths,\r\n snapshot.getObjectToValue\r\n );\r\n } catch (e) {\r\n return undefined;\r\n }\r\n },\r\n set: (newValue) => {\r\n const sourceValue = toValue(orgRef);\r\n\r\n if (isDictSource) {\r\n const keys = Object.keys(sourceValue);\r\n\r\n if (currentVForIndex >= keys.length) {\r\n throw new Error(\"Cannot set value to a non-existent key\");\r\n }\r\n\r\n const key = keys[currentVForIndex];\r\n objectSystem.setByPaths(\r\n sourceValue,\r\n [key],\r\n newValue,\r\n snapshot.getObjectToValue\r\n );\r\n\r\n return;\r\n }\r\n\r\n objectSystem.setByPaths(\r\n sourceValue,\r\n paths,\r\n newValue,\r\n snapshot.getObjectToValue\r\n );\r\n },\r\n };\r\n });\r\n }\r\n}\r\n","import { createFnFromString } from \"@/systems/jsCodeSystem\";\r\nimport { computed } from \"vue\";\r\n\r\nexport function createFn(\r\n code: string,\r\n bindings: Record<string, any>,\r\n isComputed = false\r\n) {\r\n if (isComputed) {\r\n code = `$computed(${code})`;\r\n bindings = { ...bindings, $computed: computed };\r\n }\r\n\r\n return createFnFromString(code, bindings);\r\n}\r\n","export function isNullOrUndefined(value: any): boolean {\r\n return value === null || value === undefined;\r\n}\r\n","export function getDevtoolsGlobalHook() {\n return getTarget().__VUE_DEVTOOLS_GLOBAL_HOOK__;\n}\nexport function getTarget() {\n // @ts-expect-error navigator and windows are not available in all environments\n return (typeof navigator !== 'undefined' && typeof window !== 'undefined')\n ? window\n : typeof globalThis !== 'undefined'\n ? globalThis\n : {};\n}\nexport const isProxyAvailable = typeof Proxy === 'function';\n","export const HOOK_SETUP = 'devtools-plugin:setup';\nexport const HOOK_PLUGIN_SETTINGS_SET = 'plugin:settings:set';\n","let supported;\nlet perf;\nexport function isPerformanceSupported() {\n var _a;\n if (supported !== undefined) {\n return supported;\n }\n if (typeof window !== 'undefined' && window.performance) {\n supported = true;\n perf = window.performance;\n }\n else if (typeof globalThis !== 'undefined' && ((_a = globalThis.perf_hooks) === null || _a === void 0 ? void 0 : _a.performance)) {\n supported = true;\n perf = globalThis.perf_hooks.performance;\n }\n else {\n supported = false;\n }\n return supported;\n}\nexport function now() {\n return isPerformanceSupported() ? perf.now() : Date.now();\n}\n","import { HOOK_PLUGIN_SETTINGS_SET } from './const.js';\nimport { now } from './time.js';\nexport class ApiProxy {\n constructor(plugin, hook) {\n this.target = null;\n this.targetQueue = [];\n this.onQueue = [];\n this.plugin = plugin;\n this.hook = hook;\n const defaultSettings = {};\n if (plugin.settings) {\n for (const id in plugin.settings) {\n const item = plugin.settings[id];\n defaultSettings[id] = item.defaultValue;\n }\n }\n const localSettingsSaveId = `__vue-devtools-plugin-settings__${plugin.id}`;\n let currentSettings = Object.assign({}, defaultSettings);\n try {\n const raw = localStorage.getItem(localSettingsSaveId);\n const data = JSON.parse(raw);\n Object.assign(currentSettings, data);\n }\n catch (e) {\n // noop\n }\n this.fallbacks = {\n getSettings() {\n return currentSettings;\n },\n setSettings(value) {\n try {\n localStorage.setItem(localSettingsSaveId, JSON.stringify(value));\n }\n catch (e) {\n // noop\n }\n currentSettings = value;\n },\n now() {\n return now();\n },\n };\n if (hook) {\n hook.on(HOOK_PLUGIN_SETTINGS_SET, (pluginId, value) => {\n if (pluginId === this.plugin.id) {\n this.fallbacks.setSettings(value);\n }\n });\n }\n this.proxiedOn = new Proxy({}, {\n get: (_target, prop) => {\n if (this.target) {\n return this.target.on[prop];\n }\n else {\n return (...args) => {\n this.onQueue.push({\n method: prop,\n args,\n });\n };\n }\n },\n });\n this.proxiedTarget = new Proxy({}, {\n get: (_target, prop) => {\n if (this.target) {\n return this.target[prop];\n }\n else if (prop === 'on') {\n return this.proxiedOn;\n }\n else if (Object.keys(this.fallbacks).includes(prop)) {\n return (...args) => {\n this.targetQueue.push({\n method: prop,\n args,\n resolve: () => { },\n });\n return this.fallbacks[prop](...args);\n };\n }\n else {\n return (...args) => {\n return new Promise((resolve) => {\n this.targetQueue.push({\n method: prop,\n args,\n resolve,\n });\n });\n };\n }\n },\n });\n }\n async setRealTarget(target) {\n this.target = target;\n for (const item of this.onQueue) {\n this.target.on[item.method](...item.args);\n }\n for (const item of this.targetQueue) {\n item.resolve(await this.target[item.method](...item.args));\n }\n }\n}\n","import { getDevtoolsGlobalHook, getTarget, isProxyAvailable } from './env.js';\nimport { HOOK_SETUP } from './const.js';\nimport { ApiProxy } from './proxy.js';\nexport * from './api/index.js';\nexport * from './plugin.js';\nexport * from './time.js';\nexport function setupDevtoolsPlugin(pluginDescriptor, setupFn) {\n const descriptor = pluginDescriptor;\n const target = getTarget();\n const hook = getDevtoolsGlobalHook();\n const enableProxy = isProxyAvailable && descriptor.enableEarlyProxy;\n if (hook && (target.__VUE_DEVTOOLS_PLUGIN_API_AVAILABLE__ || !enableProxy)) {\n hook.emit(HOOK_SETUP, pluginDescriptor, setupFn);\n }\n else {\n const proxy = enableProxy ? new ApiProxy(descriptor, hook) : null;\n const list = target.__VUE_DEVTOOLS_PLUGINS__ = target.__VUE_DEVTOOLS_PLUGINS__ || [];\n list.push({\n pluginDescriptor: descriptor,\n setupFn,\n proxy,\n });\n if (proxy) {\n setupFn(proxy.proxiedTarget);\n }\n }\n}\n","/*!\n * vue-router v4.5.0\n * (c) 2024 Eduardo San Martin Morote\n * @license MIT\n */\nimport { getCurrentInstance, inject, onUnmounted, onDeactivated, onActivated, computed, unref, watchEffect, defineComponent, reactive, h, provide, ref, watch, shallowRef, shallowReactive, nextTick } from 'vue';\nimport { setupDevtoolsPlugin } from '@vue/devtools-api';\n\nconst isBrowser = typeof document !== 'undefined';\n\n/**\n * Allows differentiating lazy components from functional components and vue-class-component\n * @internal\n *\n * @param component\n */\nfunction isRouteComponent(component) {\n return (typeof component === 'object' ||\n 'displayName' in component ||\n 'props' in component ||\n '__vccOpts' in component);\n}\nfunction isESModule(obj) {\n return (obj.__esModule ||\n obj[Symbol.toStringTag] === 'Module' ||\n // support CF with dynamic imports that do not\n // add the Module string tag\n (obj.default && isRouteComponent(obj.default)));\n}\nconst assign = Object.assign;\nfunction applyToParams(fn, params) {\n const newParams = {};\n for (const key in params) {\n const value = params[key];\n newParams[key] = isArray(value)\n ? value.map(fn)\n : fn(value);\n }\n return newParams;\n}\nconst noop = () => { };\n/**\n * Typesafe alternative to Array.isArray\n * https://github.com/microsoft/TypeScript/pull/48228\n */\nconst isArray = Array.isArray;\n\nfunction warn(msg) {\n // avoid using ...args as it breaks in older Edge builds\n const args = Array.from(arguments).slice(1);\n console.warn.apply(console, ['[Vue Router warn]: ' + msg].concat(args));\n}\n\n/**\n * Encoding Rules (␣ = Space)\n * - Path: ␣ \" < > # ? { }\n * - Query: ␣ \" < > # & =\n * - Hash: ␣ \" < > `\n *\n * On top of that, the RFC3986 (https://tools.ietf.org/html/rfc3986#section-2.2)\n * defines some extra characters to be encoded. Most browsers do not encode them\n * in encodeURI https://github.com/whatwg/url/issues/369, so it may be safer to\n * also encode `!'()*`. Leaving un-encoded only ASCII alphanumeric(`a-zA-Z0-9`)\n * plus `-._~`. This extra safety should be applied to query by patching the\n * string returned by encodeURIComponent encodeURI also encodes `[\\]^`. `\\`\n * should be encoded to avoid ambiguity. Browsers (IE, FF, C) transform a `\\`\n * into a `/` if directly typed in. The _backtick_ (`````) should also be\n * encoded everywhere because some browsers like FF encode it when directly\n * written while others don't. Safari and IE don't encode ``\"<>{}``` in hash.\n */\n// const EXTRA_RESERVED_RE = /[!'()*]/g\n// const encodeReservedReplacer = (c: string) => '%' + c.charCodeAt(0).toString(16)\nconst HASH_RE = /#/g; // %23\nconst AMPERSAND_RE = /&/g; // %26\nconst SLASH_RE = /\\//g; // %2F\nconst EQUAL_RE = /=/g; // %3D\nconst IM_RE = /\\?/g; // %3F\nconst PLUS_RE = /\\+/g; // %2B\n/**\n * NOTE: It's not clear to me if we should encode the + symbol in queries, it\n * seems to be less flexible than not doing so and I can't find out the legacy\n * systems requiring this for regular requests like text/html. In the standard,\n * the encoding of the plus character is only mentioned for\n * application/x-www-form-urlencoded\n * (https://url.spec.whatwg.org/#urlencoded-parsing) and most browsers seems lo\n * leave the plus character as is in queries. To be more flexible, we allow the\n * plus character on the query, but it can also be manually encoded by the user.\n *\n * Resources:\n * - https://url.spec.whatwg.org/#urlencoded-parsing\n * - https://stackoverflow.com/questions/1634271/url-encoding-the-space-character-or-20\n */\nconst ENC_BRACKET_OPEN_RE = /%5B/g; // [\nconst ENC_BRACKET_CLOSE_RE = /%5D/g; // ]\nconst ENC_CARET_RE = /%5E/g; // ^\nconst ENC_BACKTICK_RE = /%60/g; // `\nconst ENC_CURLY_OPEN_RE = /%7B/g; // {\nconst ENC_PIPE_RE = /%7C/g; // |\nconst ENC_CURLY_CLOSE_RE = /%7D/g; // }\nconst ENC_SPACE_RE = /%20/g; // }\n/**\n * Encode characters that need to be encoded on the path, search and hash\n * sections of the URL.\n *\n * @internal\n * @param text - string to encode\n * @returns encoded string\n */\nfunction commonEncode(text) {\n return encodeURI('' + text)\n .replace(ENC_PIPE_RE, '|')\n .replace(ENC_BRACKET_OPEN_RE, '[')\n .replace(ENC_BRACKET_CLOSE_RE, ']');\n}\n/**\n * Encode characters that need to be encoded on the hash section of the URL.\n *\n * @param text - string to encode\n * @returns encoded string\n */\nfunction encodeHash(text) {\n return commonEncode(text)\n .replace(ENC_CURLY_OPEN_RE, '{')\n .replace(ENC_CURLY_CLOSE_RE, '}')\n .replace(ENC_CARET_RE, '^');\n}\n/**\n * Encode characters that need to be encoded query values on the query\n * section of the URL.\n *\n * @param text - string to encode\n * @returns encoded string\n */\nfunction encodeQueryValue(text) {\n return (commonEncode(text)\n // Encode the space as +, encode the + to differentiate it from the space\n .replace(PLUS_RE, '%2B')\n .replace(ENC_SPACE_RE, '+')\n .replace(HASH_RE, '%23')\n .replace(AMPERSAND_RE, '%26')\n .replace(ENC_BACKTICK_RE, '`')\n .replace(ENC_CURLY_OPEN_RE, '{')\n .replace(ENC_CURLY_CLOSE_RE, '}')\n .replace(ENC_CARET_RE, '^'));\n}\n/**\n * Like `encodeQueryValue` but also encodes the `=` character.\n *\n * @param text - string to encode\n */\nfunction encodeQueryKey(text) {\n return encodeQueryValue(text).replace(EQUAL_RE, '%3D');\n}\n/**\n * Encode characters that need to be encoded on the path section of the URL.\n *\n * @param text - string to encode\n * @returns encoded string\n */\nfunction encodePath(text) {\n return commonEncode(text).replace(HASH_RE, '%23').replace(IM_RE, '%3F');\n}\n/**\n * Encode characters that need to be encoded on the path section of the URL as a\n * param. This function encodes everything {@link encodePath} does plus the\n * slash (`/`) character. If `text` is `null` or `undefined`, returns an empty\n * string instead.\n *\n * @param text - string to encode\n * @returns encoded string\n */\nfunction encodeParam(text) {\n return text == null ? '' : encodePath(text).replace(SLASH_RE, '%2F');\n}\n/**\n * Decode text using `decodeURIComponent`. Returns the original text if it\n * fails.\n *\n * @param text - string to decode\n * @returns decoded string\n */\nfunction decode(text) {\n try {\n return decodeURIComponent('' + text);\n }\n catch (err) {\n (process.env.NODE_ENV !== 'production') && warn(`Error decoding \"${text}\". Using original value`);\n }\n return '' + text;\n}\n\nconst TRAILING_SLASH_RE = /\\/$/;\nconst removeTrailingSlash = (path) => path.replace(TRAILING_SLASH_RE, '');\n/**\n * Transforms a URI into a normalized history location\n *\n * @param parseQuery\n * @param location - URI to normalize\n * @param currentLocation - current absolute location. Allows resolving relative\n * paths. Must start with `/`. Defaults to `/`\n * @returns a normalized history location\n */\nfunction parseURL(parseQuery, location, currentLocation = '/') {\n let path, query = {}, searchString = '', hash = '';\n // Could use URL and URLSearchParams but IE 11 doesn't support it\n // TODO: move to new URL()\n const hashPos = location.indexOf('#');\n let searchPos = location.indexOf('?');\n // the hash appears before the search, so it's not part of the search string\n if (hashPos < searchPos && hashPos >= 0) {\n searchPos = -1;\n }\n if (searchPos > -1) {\n path = location.slice(0, searchPos);\n searchString = location.slice(searchPos + 1, hashPos > -1 ? hashPos : location.length);\n query = parseQuery(searchString);\n }\n if (hashPos > -1) {\n path = path || location.slice(0, hashPos);\n // keep the # character\n hash = location.slice(hashPos, location.length);\n }\n // no search and no query\n path = resolveRelativePath(path != null ? path : location, currentLocation);\n // empty path means a relative query or hash `?foo=f`, `#thing`\n return {\n fullPath: path + (searchString && '?') + searchString + hash,\n path,\n query,\n hash: decode(hash),\n };\n}\n/**\n * Stringifies a URL object\n *\n * @param stringifyQuery\n * @param location\n */\nfunction stringifyURL(stringifyQuery, location) {\n const query = location.query ? stringifyQuery(location.query) : '';\n return location.path + (query && '?') + query + (location.hash || '');\n}\n/**\n * Strips off the base from the beginning of a location.pathname in a non-case-sensitive way.\n *\n * @param pathname - location.pathname\n * @param base - base to strip off\n */\nfunction stripBase(pathname, base) {\n // no base or base is not found at the beginning\n if (!base || !pathname.toLowerCase().startsWith(base.toLowerCase()))\n return pathname;\n return pathname.slice(base.length) || '/';\n}\n/**\n * Checks if two RouteLocation are equal. This means that both locations are\n * pointing towards the same {@link RouteRecord} and that all `params`, `query`\n * parameters and `hash` are the same\n *\n * @param stringifyQuery - A function that takes a query object of type LocationQueryRaw and returns a string representation of it.\n * @param a - first {@link RouteLocation}\n * @param b - second {@link RouteLocation}\n */\nfunction isSameRouteLocation(stringifyQuery, a, b) {\n const aLastIndex = a.matched.length - 1;\n const bLastIndex = b.matched.length - 1;\n return (aLastIndex > -1 &&\n aLastIndex === bLastIndex &&\n isSameRouteRecord(a.matched[aLastIndex], b.matched[bLastIndex]) &&\n isSameRouteLocationParams(a.params, b.params) &&\n stringifyQuery(a.query) === stringifyQuery(b.query) &&\n a.hash === b.hash);\n}\n/**\n * Check if two `RouteRecords` are equal. Takes into account aliases: they are\n * considered equal to the `RouteRecord` they are aliasing.\n *\n * @param a - first {@link RouteRecord}\n * @param b - second {@link RouteRecord}\n */\nfunction isSameRouteRecord(a, b) {\n // since the original record has an undefined value for aliasOf\n // but all aliases point to the original record, this will always compare\n // the original record\n return (a.aliasOf || a) === (b.aliasOf || b);\n}\nfunction isSameRouteLocationParams(a, b) {\n if (Object.keys(a).length !== Object.keys(b).length)\n return false;\n for (const key in a) {\n if (!isSameRouteLocationParamsValue(a[key], b[key]))\n return false;\n }\n return true;\n}\nfunction isSameRouteLocationParamsValue(a, b) {\n return isArray(a)\n ? isEquivalentArray(a, b)\n : isArray(b)\n ? isEquivalentArray(b, a)\n : a === b;\n}\n/**\n * Check if two arrays are the same or if an array with one single entry is the\n * same as another primitive value. Used to check query and parameters\n *\n * @param a - array of values\n * @param b - array of values or a single value\n */\nfunction isEquivalentArray(a, b) {\n return isArray(b)\n ? a.length === b.length && a.every((value, i) => value === b[i])\n : a.length === 1 && a[0] === b;\n}\n/**\n * Resolves a relative path that starts with `.`.\n *\n * @param to - path location we are resolving\n * @param from - currentLocation.path, should start with `/`\n */\nfunction resolveRelativePath(to, from) {\n if (to.startsWith('/'))\n return to;\n if ((process.env.NODE_ENV !== 'production') && !from.startsWith('/')) {\n warn(`Cannot resolve a relative location without an absolute path. Trying to resolve \"${to}\" from \"${from}\". It should look like \"/${from}\".`);\n return to;\n }\n if (!to)\n return from;\n const fromSegments = from.split('/');\n const toSegments = to.split('/');\n const lastToSegment = toSegments[toSegments.length - 1];\n // make . and ./ the same (../ === .., ../../ === ../..)\n // this is the same behavior as new URL()\n if (lastToSegment === '..' || lastToSegment === '.') {\n toSegments.push('');\n }\n let position = fromSegments.length - 1;\n let toPosition;\n let segment;\n for (toPosition = 0; toPosition < toSegments.length; toPosition++) {\n segment = toSegments[toPosition];\n // we stay on the same position\n if (segment === '.')\n continue;\n // go up in the from array\n if (segment === '..') {\n // we can't go below zero, but we still need to increment toPosition\n if (position > 1)\n position--;\n // continue\n }\n // we reached a non-relative path, we stop here\n else\n break;\n }\n return (fromSegments.slice(0, position).join('/') +\n '/' +\n toSegments.slice(toPosition).join('/'));\n}\n/**\n * Initial route location where the router is. Can be used in navigation guards\n * to differentiate the initial navigation.\n *\n * @example\n * ```js\n * import { START_LOCATION } from 'vue-router'\n *\n * router.beforeEach((to, from) => {\n * if (from === START_LOCATION) {\n * // initial navigation\n * }\n * })\n * ```\n */\nconst START_LOCATION_NORMALIZED = {\n path: '/',\n // TODO: could we use a symbol in the future?\n name: undefined,\n params: {},\n query: {},\n hash: '',\n fullPath: '/',\n matched: [],\n meta: {},\n redirectedFrom: undefined,\n};\n\nvar NavigationType;\n(function (NavigationType) {\n NavigationType[\"pop\"] = \"pop\";\n NavigationType[\"push\"] = \"push\";\n})(NavigationType || (NavigationType = {}));\nvar NavigationDirection;\n(function (NavigationDirection) {\n NavigationDirection[\"back\"] = \"back\";\n NavigationDirection[\"forward\"] = \"forward\";\n NavigationDirection[\"unknown\"] = \"\";\n})(NavigationDirection || (NavigationDirection = {}));\n/**\n * Starting location for Histories\n */\nconst START = '';\n// Generic utils\n/**\n * Normalizes a base by removing any trailing slash and reading the base tag if\n * present.\n *\n * @param base - base to normalize\n */\nfunction normalizeBase(base) {\n if (!base) {\n if (isBrowser) {\n // respect <base> tag\n const baseEl = document.querySelector('base');\n base = (baseEl && baseEl.getAttribute('href')) || '/';\n // strip full URL origin\n base = base.replace(/^\\w+:\\/\\/[^\\/]+/, '');\n }\n else {\n base = '/';\n }\n }\n // ensure leading slash when it was removed by the regex above avoid leading\n // slash with hash because the file could be read from the disk like file://\n // and the leading slash would cause problems\n if (base[0] !== '/' && base[0] !== '#')\n base = '/' + base;\n // remove the trailing slash so all other method can just do `base + fullPath`\n // to build an href\n return removeTrailingSlash(base);\n}\n// remove any character before the hash\nconst BEFORE_HASH_RE = /^[^#]+#/;\nfunction createHref(base, location) {\n return base.replace(BEFORE_HASH_RE, '#') + location;\n}\n\nfunction getElementPosition(el, offset) {\n const docRect = document.documentElement.getBoundingClientRect();\n const elRect = el.getBoundingClientRect();\n return {\n behavior: offset.behavior,\n left: elRect.left - docRect.left - (offset.left || 0),\n top: elRect.top - docRect.top - (offset.top || 0),\n };\n}\nconst computeScrollPosition = () => ({\n left: window.scrollX,\n top: window.scrollY,\n});\nfunction scrollToPosition(position) {\n let scrollToOptions;\n if ('el' in position) {\n const positionEl = position.el;\n const isIdSelector = typeof positionEl === 'string' && positionEl.startsWith('#');\n /**\n * `id`s can accept pretty much any characters, including CSS combinators\n * like `>` or `~`. It's still possible to retrieve elements using\n * `document.getElementById('~')` but it needs to be escaped when using\n * `document.querySelector('#\\\\~')` for it to be valid. The only\n * requirements for `id`s are them to be unique on the page and to not be\n * empty (`id=\"\"`). Because of that, when passing an id selector, it should\n * be properly escaped for it to work with `querySelector`. We could check\n * for the id selector to be simple (no CSS combinators `+ >~`) but that\n * would make things inconsistent since they are valid characters for an\n * `id` but would need to be escaped when using `querySelector`, breaking\n * their usage and ending up in no selector returned. Selectors need to be\n * escaped:\n *\n * - `#1-thing` becomes `#\\31 -thing`\n * - `#with~symbols` becomes `#with\\\\~symbols`\n *\n * - More information about the topic can be found at\n * https://mathiasbynens.be/notes/html5-id-class.\n * - Practical example: https://mathiasbynens.be/demo/html5-id\n */\n if ((process.env.NODE_ENV !== 'production') && typeof position.el === 'string') {\n if (!isIdSelector || !document.getElementById(position.el.slice(1))) {\n try {\n const foundEl = document.querySelector(position.el);\n if (isIdSelector && foundEl) {\n warn(`The selector \"${position.el}\" should be passed as \"el: document.querySelector('${position.el}')\" because it starts with \"#\".`);\n // return to avoid other warnings\n return;\n }\n }\n catch (err) {\n warn(`The selector \"${position.el}\" is invalid. If you are using an id selector, make sure to escape it. You can find more information about escaping characters in selectors at https://mathiasbynens.be/notes/css-escapes or use CSS.escape (https://developer.mozilla.org/en-US/docs/Web/API/CSS/escape).`);\n // return to avoid other warnings\n return;\n }\n }\n }\n const el = typeof positionEl === 'string'\n ? isIdSelector\n ? document.getElementById(positionEl.slice(1))\n : document.querySelector(positionEl)\n : positionEl;\n if (!el) {\n (process.env.NODE_ENV !== 'production') &&\n warn(`Couldn't find element using selector \"${position.el}\" returned by scrollBehavior.`);\n return;\n }\n scrollToOptions = getElementPosition(el, position);\n }\n else {\n scrollToOptions = position;\n }\n if ('scrollBehavior' in document.documentElement.style)\n window.scrollTo(scrollToOptions);\n else {\n window.scrollTo(scrollToOptions.left != null ? scrollToOptions.left : window.scrollX, scrollToOptions.top != null ? scrollToOptions.top : window.scrollY);\n }\n}\nfunction getScrollKey(path, delta) {\n const position = history.state ? history.state.position - delta : -1;\n return position + path;\n}\nconst scrollPositions = new Map();\nfunction saveScrollPosition(key, scrollPosition) {\n scrollPositions.set(key, scrollPosition);\n}\nfunction getSavedScrollPosition(key) {\n const scroll = scrollPositions.get(key);\n // consume it so it's not used again\n scrollPositions.delete(key);\n return scroll;\n}\n// TODO: RFC about how to save scroll position\n/**\n * ScrollBehavior instance used by the router to compute and restore the scroll\n * position when navigating.\n */\n// export interface ScrollHandler<ScrollPositionEntry extends HistoryStateValue, ScrollPosition extends ScrollPositionEntry> {\n// // returns a scroll position that can be saved in history\n// compute(): ScrollPositionEntry\n// // can take an extended ScrollPositionEntry\n// scroll(position: ScrollPosition): void\n// }\n// export const scrollHandler: ScrollHandler<ScrollPosition> = {\n// compute: computeScroll,\n// scroll: scrollToPosition,\n// }\n\nlet createBaseLocation = () => location.protocol + '//' + location.host;\n/**\n * Creates a normalized history location from a window.location object\n * @param base - The base path\n * @param location - The window.location object\n */\nfunction createCurrentLocation(base, location) {\n const { pathname, search, hash } = location;\n // allows hash bases like #, /#, #/, #!, #!/, /#!/, or even /folder#end\n const hashPos = base.indexOf('#');\n if (hashPos > -1) {\n let slicePos = hash.includes(base.slice(hashPos))\n ? base.slice(hashPos).length\n : 1;\n let pathFromHash = hash.slice(slicePos);\n // prepend the starting slash to hash so the url starts with /#\n if (pathFromHash[0] !== '/')\n pathFromHash = '/' + pathFromHash;\n return stripBase(pathFromHash, '');\n }\n const path = stripBase(pathname, base);\n return path + search + hash;\n}\nfunction useHistoryListeners(base, historyState, currentLocation, replace) {\n let listeners = [];\n let teardowns = [];\n // TODO: should it be a stack? a Dict. Check if the popstate listener\n // can trigger twice\n let pauseState = null;\n const popStateHandler = ({ state, }) => {\n const to = createCurrentLocation(base, location);\n const from = currentLocation.value;\n const fromState = historyState.value;\n let delta = 0;\n if (state) {\n currentLocation.value = to;\n historyState.value = state;\n // ignore the popstate and reset the pauseState\n if (pauseState && pauseState === from) {\n pauseState = null;\n return;\n }\n delta = fromState ? state.position - fromState.position : 0;\n }\n else {\n replace(to);\n }\n // Here we could also revert the navigation by calling history.go(-delta)\n // this listener will have to be adapted to not trigger again and to wait for the url\n // to be updated before triggering the listeners. Some kind of validation function would also\n // need to be passed to the listeners so the navigation can be accepted\n // call all listeners\n listeners.forEach(listener => {\n listener(currentLocation.value, from, {\n delta,\n type: NavigationType.pop,\n direction: delta\n ? delta > 0\n ? NavigationDirection.forward\n : NavigationDirection.back\n : NavigationDirection.unknown,\n });\n });\n };\n function pauseListeners() {\n pauseState = currentLocation.value;\n }\n function listen(callback) {\n // set up the listener and prepare teardown callbacks\n listeners.push(callback);\n const teardown = () => {\n const index = listeners.indexOf(callback);\n if (index > -1)\n listeners.splice(index, 1);\n };\n teardowns.push(teardown);\n return teardown;\n }\n function beforeUnloadListener() {\n const { history } = window;\n if (!history.state)\n return;\n history.replaceState(assign({}, history.state, { scroll: computeScrollPosition() }), '');\n }\n function destroy() {\n for (const teardown of teardowns)\n teardown();\n teardowns = [];\n window.removeEventListener('popstate', popStateHandler);\n window.removeEventListener('beforeunload', beforeUnloadListener);\n }\n // set up the listeners and prepare teardown callbacks\n window.addEventListener('popstate', popStateHandler);\n // TODO: could we use 'pagehide' or 'visibilitychange' instead?\n // https://developer.chrome.com/blog/page-lifecycle-api/\n window.addEventListener('beforeunload', beforeUnloadListener, {\n passive: true,\n });\n return {\n pauseListeners,\n listen,\n destroy,\n };\n}\n/**\n * Creates a state object\n */\nfunction buildState(back, current, forward, replaced = false, computeScroll = false) {\n return {\n back,\n current,\n forward,\n replaced,\n position: window.history.length,\n scroll: computeScroll ? computeScrollPosition() : null,\n };\n}\nfunction useHistoryStateNavigation(base) {\n const { history, location } = window;\n // private variables\n const currentLocation = {\n value: createCurrentLocation(base, location),\n };\n const historyState = { value: history.state };\n // build current history entry as this is a fresh navigation\n if (!historyState.value) {\n changeLocation(currentLocation.value, {\n back: null,\n current: currentLocation.value,\n forward: null,\n // the length is off by one, we need to decrease it\n position: history.length - 1,\n replaced: true,\n // don't add a scroll as the user may have an anchor, and we want\n // scrollBehavior to be triggered without a saved position\n scroll: null,\n }, true);\n }\n function changeLocation(to, state, replace) {\n /**\n * if a base tag is provided, and we are on a normal domain, we have to\n * respect the provided `base` attribute because pushState() will use it and\n * potentially erase anything before the `#` like at\n * https://github.com/vuejs/router/issues/685 where a base of\n * `/folder/#` but a base of `/` would erase the `/folder/` section. If\n * there is no host, the `<base>` tag makes no sense and if there isn't a\n * base tag we can just use everything after the `#`.\n */\n const hashIndex = base.indexOf('#');\n const url = hashIndex > -1\n ? (location.host && document.querySelector('base')\n ? base\n : base.slice(hashIndex)) + to\n : createBaseLocation() + base + to;\n try {\n // BROWSER QUIRK\n // NOTE: Safari throws a SecurityError when calling this function 100 times in 30 seconds\n history[replace ? 'replaceState' : 'pushState'](state, '', url);\n historyState.value = state;\n }\n catch (err) {\n if ((process.env.NODE_ENV !== 'production')) {\n warn('Error with push/replace State', err);\n }\n else {\n console.error(err);\n }\n // Force the navigation, this also resets the call count\n location[replace ? 'replace' : 'assign'](url);\n }\n }\n function replace(to, data) {\n const state = assign({}, history.state, buildState(historyState.value.back, \n // keep back and forward entries but override current position\n to, historyState.value.forward, true), data, { position: historyState.value.position });\n changeLocation(to, state, true);\n currentLocation.value = to;\n }\n function push(to, data) {\n // Add to current entry the information of where we are going\n // as well as saving the current position\n const currentState = assign({}, \n // use current history state to gracefully handle a wrong call to\n // history.replaceState\n // https://github.com/vuejs/router/issues/366\n historyState.value, history.state, {\n forward: to,\n scroll: computeScrollPosition(),\n });\n if ((process.env.NODE_ENV !== 'production') && !history.state) {\n warn(`history.state seems to have been manually replaced without preserving the necessary values. Make sure to preserve existing history state if you are manually calling history.replaceState:\\n\\n` +\n `history.replaceState(history.state, '', url)\\n\\n` +\n `You can find more information at https://router.vuejs.org/guide/migration/#Usage-of-history-state`);\n }\n changeLocation(currentState.current, currentState, true);\n const state = assign({}, buildState(currentLocation.value, to, null), { position: currentState.position + 1 }, data);\n changeLocation(to, state, false);\n currentLocation.value = to;\n }\n return {\n location: currentLocation,\n state: historyState,\n push,\n replace,\n };\n}\n/**\n * Creates an HTML5 history. Most common history for single page applications.\n *\n * @param base -\n */\nfunction createWebHistory(base) {\n base = normalizeBase(base);\n const historyNavigation = useHistoryStateNavigation(base);\n const historyListeners = useHistoryListeners(base, historyNavigation.state, historyNavigation.location, historyNavigation.replace);\n function go(delta, triggerListeners = true) {\n if (!triggerListeners)\n historyListeners.pauseListeners();\n history.go(delta);\n }\n const routerHistory = assign({\n // it's overridden right after\n location: '',\n base,\n go,\n createHref: createHref.bind(null, base),\n }, historyNavigation, historyListeners);\n Object.defineProperty(routerHistory, 'location', {\n enumerable: true,\n get: () => historyNavigation.location.value,\n });\n Object.defineProperty(routerHistory, 'state', {\n enumerable: true,\n get: () => historyNavigation.state.value,\n });\n return routerHistory;\n}\n\n/**\n * Creates an in-memory based history. The main purpose of this history is to handle SSR. It starts in a special location that is nowhere.\n * It's up to the user to replace that location with the starter location by either calling `router.push` or `router.replace`.\n *\n * @param base - Base applied to all urls, defaults to '/'\n * @returns a history object that can be passed to the router constructor\n */\nfunction createMemoryHistory(base = '') {\n let listeners = [];\n let queue = [START];\n let position = 0;\n base = normalizeBase(base);\n function setLocation(location) {\n position++;\n if (position !== queue.length) {\n // we are in the middle, we remove everything from here in the queue\n queue.splice(position);\n }\n queue.push(location);\n }\n function triggerListeners(to, from, { direction, delta }) {\n const info = {\n direction,\n delta,\n type: NavigationType.pop,\n };\n for (const callback of listeners) {\n callback(to, from, info);\n }\n }\n const routerHistory = {\n // rewritten by Object.defineProperty\n location: START,\n // TODO: should be kept in queue\n state: {},\n base,\n createHref: createHref.bind(null, base),\n replace(to) {\n // remove current entry and decrement position\n queue.splice(position--, 1);\n setLocation(to);\n },\n push(to, data) {\n setLocation(to);\n },\n listen(callback) {\n listeners.push(callback);\n return () => {\n const index = listeners.indexOf(callback);\n if (index > -1)\n listeners.splice(index, 1);\n };\n },\n destroy() {\n listeners = [];\n queue = [START];\n position = 0;\n },\n go(delta, shouldTrigger = true) {\n const from = this.location;\n const direction = \n // we are considering delta === 0 going forward, but in abstract mode\n // using 0 for the delta doesn't make sense like it does in html5 where\n // it reloads the page\n delta < 0 ? NavigationDirection.back : NavigationDirection.forward;\n position = Math.max(0, Math.min(position + delta, queue.length - 1));\n if (shouldTrigger) {\n triggerListeners(this.location, from, {\n direction,\n delta,\n });\n }\n },\n };\n Object.defineProperty(routerHistory, 'location', {\n enumerable: true,\n get: () => queue[position],\n });\n return routerHistory;\n}\n\n/**\n * Creates a hash history. Useful for web applications with no host (e.g. `file://`) or when configuring a server to\n * handle any URL is not possible.\n *\n * @param base - optional base to provide. Defaults to `location.pathname + location.search` If there is a `<base>` tag\n * in the `head`, its value will be ignored in favor of this parameter **but note it affects all the history.pushState()\n * calls**, meaning that if you use a `<base>` tag, it's `href` value **has to match this parameter** (ignoring anything\n * after the `#`).\n *\n * @example\n * ```js\n * // at https://example.com/folder\n * createWebHashHistory() // gives a url of `https://example.com/folder#`\n * createWebHashHistory('/folder/') // gives a url of `https://example.com/folder/#`\n * // if the `#` is provided in the base, it won't be added by `createWebHashHistory`\n * createWebHashHistory('/folder/#/app/') // gives a url of `https://example.com/folder/#/app/`\n * // you should avoid doing this because it changes the original url and breaks copying urls\n * createWebHashHistory('/other-folder/') // gives a url of `https://example.com/other-folder/#`\n *\n * // at file:///usr/etc/folder/index.html\n * // for locations with no `host`, the base is ignored\n * createWebHashHistory('/iAmIgnored') // gives a url of `file:///usr/etc/folder/index.html#`\n * ```\n */\nfunction createWebHashHistory(base) {\n // Make sure this implementation is fine in terms of encoding, specially for IE11\n // for `file://`, directly use the pathname and ignore the base\n // location.pathname contains an initial `/` even at the root: `https://example.com`\n base = location.host ? base || location.pathname + location.search : '';\n // allow the user to provide a `#` in the middle: `/base/#/app`\n if (!base.includes('#'))\n base += '#';\n if ((process.env.NODE_ENV !== 'production') && !base.endsWith('#/') && !base.endsWith('#')) {\n warn(`A hash base must end with a \"#\":\\n\"${base}\" should be \"${base.replace(/#.*$/, '#')}\".`);\n }\n return createWebHistory(base);\n}\n\nfunction isRouteLocation(route) {\n return typeof route === 'string' || (route && typeof route === 'object');\n}\nfunction isRouteName(name) {\n return typeof name === 'string' || typeof name === 'symbol';\n}\n\nconst NavigationFailureSymbol = Symbol((process.env.NODE_ENV !== 'production') ? 'navigation failure' : '');\n/**\n * Enumeration with all possible types for navigation failures. Can be passed to\n * {@link isNavigationFailure} to check for specific failures.\n */\nvar NavigationFailureType;\n(function (NavigationFailureType) {\n /**\n * An aborted navigation is a navigation that failed because a navigation\n * guard returned `false` or called `next(false)`\n */\n NavigationFailureType[NavigationFailureType[\"aborted\"] = 4] = \"aborted\";\n /**\n * A cancelled navigation is a navigation that failed because a more recent\n * navigation finished started (not necessarily finished).\n */\n NavigationFailureType[NavigationFailureType[\"cancelled\"] = 8] = \"cancelled\";\n /**\n * A duplicated navigation is a navigation that failed because it was\n * initiated while already being at the exact same location.\n */\n NavigationFailureType[NavigationFailureType[\"duplicated\"] = 16] = \"duplicated\";\n})(NavigationFailureType || (NavigationFailureType = {}));\n// DEV only debug messages\nconst ErrorTypeMessages = {\n [1 /* ErrorTypes.MATCHER_NOT_FOUND */]({ location, currentLocation }) {\n return `No match for\\n ${JSON.stringify(location)}${currentLocation\n ? '\\nwhile being at\\n' + JSON.stringify(currentLocation)\n : ''}`;\n },\n [2 /* ErrorTypes.NAVIGATION_GUARD_REDIRECT */]({ from, to, }) {\n return `Redirected from \"${from.fullPath}\" to \"${stringifyRoute(to)}\" via a navigation guard.`;\n },\n [4 /* ErrorTypes.NAVIGATION_ABORTED */]({ from, to }) {\n return `Navigation aborted from \"${from.fullPath}\" to \"${to.fullPath}\" via a navigation guard.`;\n },\n [8 /* ErrorTypes.NAVIGATION_CANCELLED */]({ from, to }) {\n return `Navigation cancelled from \"${from.fullPath}\" to \"${to.fullPath}\" with a new navigation.`;\n },\n [16 /* ErrorTypes.NAVIGATION_DUPLICATED */]({ from, to }) {\n return `Avoided redundant navigation to current location: \"${from.fullPath}\".`;\n },\n};\n/**\n * Creates a typed NavigationFailure object.\n * @internal\n * @param type - NavigationFailureType\n * @param params - { from, to }\n */\nfunction createRouterError(type, params) {\n // keep full error messages in cjs versions\n if ((process.env.NODE_ENV !== 'production') || !true) {\n return assign(new Error(ErrorTypeMessages[type](params)), {\n type,\n [NavigationFailureSymbol]: true,\n }, params);\n }\n else {\n return assign(new Error(), {\n type,\n [NavigationFailureSymbol]: true,\n }, params);\n }\n}\nfunction isNavigationFailure(error, type) {\n return (error instanceof Error &&\n NavigationFailureSymbol in error &&\n (type == null || !!(error.type & type)));\n}\nconst propertiesToLog = ['params', 'query', 'hash'];\nfunction stringifyRoute(to) {\n if (typeof to === 'string')\n return to;\n if (to.path != null)\n return to.path;\n const location = {};\n for (const key of propertiesToLog) {\n if (key in to)\n location[key] = to[key];\n }\n return JSON.stringify(location, null, 2);\n}\n\n// default pattern for a param: non-greedy everything but /\nconst BASE_PARAM_PATTERN = '[^/]+?';\nconst BASE_PATH_PARSER_OPTIONS = {\n sensitive: false,\n strict: false,\n start: true,\n end: true,\n};\n// Special Regex characters that must be escaped in static tokens\nconst REGEX_CHARS_RE = /[.+*?^${}()[\\]/\\\\]/g;\n/**\n * Creates a path parser from an array of Segments (a segment is an array of Tokens)\n *\n * @param segments - array of segments returned by tokenizePath\n * @param extraOptions - optional options for the regexp\n * @returns a PathParser\n */\nfunction tokensToParser(segments, extraOptions) {\n const options = assign({}, BASE_PATH_PARSER_OPTIONS, extraOptions);\n // the amount of scores is the same as the length of segments except for the root segment \"/\"\n const score = [];\n // the regexp as a string\n let pattern = options.start ? '^' : '';\n // extracted keys\n const keys = [];\n for (const segment of segments) {\n // the root segment needs special treatment\n const segmentScores = segment.length ? [] : [90 /* PathScore.Root */];\n // allow trailing slash\n if (options.strict && !segment.length)\n pattern += '/';\n for (let tokenIndex = 0; tokenIndex < segment.length; tokenIndex++) {\n const token = segment[tokenIndex];\n // resets the score if we are inside a sub-segment /:a-other-:b\n let subSegmentScore = 40 /* PathScore.Segment */ +\n (options.sensitive ? 0.25 /* PathScore.BonusCaseSensitive */ : 0);\n if (token.type === 0 /* TokenType.Static */) {\n // prepend the slash if we are starting a new segment\n if (!tokenIndex)\n pattern += '/';\n pattern += token.value.replace(REGEX_CHARS_RE, '\\\\$&');\n subSegmentScore += 40 /* PathScore.Static */;\n }\n else if (token.type === 1 /* TokenType.Param */) {\n const { value, repeatable, optional, regexp } = token;\n keys.push({\n name: value,\n repeatable,\n optional,\n });\n const re = regexp ? regexp : BASE_PARAM_PATTERN;\n // the user provided a custom regexp /:id(\\\\d+)\n if (re !== BASE_PARAM_PATTERN) {\n subSegmentScore += 10 /* PathScore.BonusCustomRegExp */;\n // make sure the regexp is valid before using it\n try {\n new RegExp(`(${re})`);\n }\n catch (err) {\n throw new Error(`Invalid custom RegExp for param \"${value}\" (${re}): ` +\n err.message);\n }\n }\n // when we repeat we must take care of the repeating leading slash\n let subPattern = repeatable ? `((?:${re})(?:/(?:${re}))*)` : `(${re})`;\n // prepend the slash if we are starting a new segment\n if (!tokenIndex)\n subPattern =\n // avoid an optional / if there are more segments e.g. /:p?-static\n // or /:p?-:p2\n optional && segment.length < 2\n ? `(?:/${subPattern})`\n : '/' + subPattern;\n if (optional)\n subPattern += '?';\n pattern += subPattern;\n subSegmentScore += 20 /* PathScore.Dynamic */;\n if (optional)\n subSegmentScore += -8 /* PathScore.BonusOptional */;\n if (repeatable)\n subSegmentScore += -20 /* PathScore.BonusRepeatable */;\n if (re === '.*')\n subSegmentScore += -50 /* PathScore.BonusWildcard */;\n }\n segmentScores.push(subSegmentScore);\n }\n // an empty array like /home/ -> [[{home}], []]\n // if (!segment.length) pattern += '/'\n score.push(segmentScores);\n }\n // only apply the strict bonus to the last score\n if (options.strict && options.end) {\n const i = score.length - 1;\n score[i][score[i].length - 1] += 0.7000000000000001 /* PathScore.BonusStrict */;\n }\n // TODO: dev only warn double trailing slash\n if (!options.strict)\n pattern += '/?';\n if (options.end)\n pattern += '$';\n // allow paths like /dynamic to only match dynamic or dynamic/... but not dynamic_something_else\n else if (options.strict && !pattern.endsWith('/'))\n pattern += '(?:/|$)';\n const re = new RegExp(pattern, options.sensitive ? '' : 'i');\n function parse(path) {\n const match = path.match(re);\n const params = {};\n if (!match)\n return null;\n for (let i = 1; i < match.length; i++) {\n const value = match[i] || '';\n const key = keys[i - 1];\n params[key.name] = value && key.repeatable ? value.split('/') : value;\n }\n return params;\n }\n function stringify(params) {\n let path = '';\n // for optional parameters to allow to be empty\n let avoidDuplicatedSlash = false;\n for (const segment of segments) {\n if (!avoidDuplicatedSlash || !path.endsWith('/'))\n path += '/';\n avoidDuplicatedSlash = false;\n for (const token of segment) {\n if (token.type === 0 /* TokenType.Static */) {\n path += token.value;\n }\n else if (token.type === 1 /* TokenType.Param */) {\n const { value, repeatable, optional } = token;\n const param = value in params ? params[value] : '';\n if (isArray(param) && !repeatable) {\n throw new Error(`Provided param \"${value}\" is an array but it is not repeatable (* or + modifiers)`);\n }\n const text = isArray(param)\n ? param.join('/')\n : param;\n if (!text) {\n if (optional) {\n // if we have more than one optional param like /:a?-static we don't need to care about the optional param\n if (segment.length < 2) {\n // remove the last slash as we could be at the end\n if (path.endsWith('/'))\n path = path.slice(0, -1);\n // do not append a slash on the next iteration\n else\n avoidDuplicatedSlash = true;\n }\n }\n else\n throw new Error(`Missing required param \"${value}\"`);\n }\n path += text;\n }\n }\n }\n // avoid empty path when we have multiple optional params\n return path || '/';\n }\n return {\n re,\n score,\n keys,\n parse,\n stringify,\n };\n}\n/**\n * Compares an array of numbers as used in PathParser.score and returns a\n * number. This function can be used to `sort` an array\n *\n * @param a - first array of numbers\n * @param b - second array of numbers\n * @returns 0 if both are equal, < 0 if a should be sorted first, > 0 if b\n * should be sorted first\n */\nfunction compareScoreArray(a, b) {\n let i = 0;\n while (i < a.length && i < b.length) {\n const diff = b[i] - a[i];\n // only keep going if diff === 0\n if (diff)\n return diff;\n i++;\n }\n // if the last subsegment was Static, the shorter segments should be sorted first\n // otherwise sort the longest segment first\n if (a.length < b.length) {\n return a.length === 1 && a[0] === 40 /* PathScore.Static */ + 40 /* PathScore.Segment */\n ? -1\n : 1;\n }\n else if (a.length > b.length) {\n return b.length === 1 && b[0] === 40 /* PathScore.Static */ + 40 /* PathScore.Segment */\n ? 1\n : -1;\n }\n return 0;\n}\n/**\n * Compare function that can be used with `sort` to sort an array of PathParser\n *\n * @param a - first PathParser\n * @param b - second PathParser\n * @returns 0 if both are equal, < 0 if a should be sorted first, > 0 if b\n */\nfunction comparePathParserScore(a, b) {\n let i = 0;\n const aScore = a.score;\n const bScore = b.score;\n while (i < aScore.length && i < bScore.length) {\n const comp = compareScoreArray(aScore[i], bScore[i]);\n // do not return if both are equal\n if (comp)\n return comp;\n i++;\n }\n if (Math.abs(bScore.length - aScore.length) === 1) {\n if (isLastScoreNegative(aScore))\n return 1;\n if (isLastScoreNegative(bScore))\n return -1;\n }\n // if a and b share the same score entries but b has more, sort b first\n return bScore.length - aScore.length;\n // this is the ternary version\n // return aScore.length < bScore.length\n // ? 1\n // : aScore.length > bScore.length\n // ? -1\n // : 0\n}\n/**\n * This allows detecting splats at the end of a path: /home/:id(.*)*\n *\n * @param score - score to check\n * @returns true if the last entry is negative\n */\nfunction isLastScoreNegative(score) {\n const last = score[score.length - 1];\n return score.length > 0 && last[last.length - 1] < 0;\n}\n\nconst ROOT_TOKEN = {\n type: 0 /* TokenType.Static */,\n value: '',\n};\nconst VALID_PARAM_RE = /[a-zA-Z0-9_]/;\n// After some profiling, the cache seems to be unnecessary because tokenizePath\n// (the slowest part of adding a route) is very fast\n// const tokenCache = new Map<string, Token[][]>()\nfunction tokenizePath(path) {\n if (!path)\n return [[]];\n if (path === '/')\n return [[ROOT_TOKEN]];\n if (!path.startsWith('/')) {\n throw new Error((process.env.NODE_ENV !== 'production')\n ? `Route paths should start with a \"/\": \"${path}\" should be \"/${path}\".`\n : `Invalid path \"${path}\"`);\n }\n // if (tokenCache.has(path)) return tokenCache.get(path)!\n function crash(message) {\n throw new Error(`ERR (${state})/\"${buffer}\": ${message}`);\n }\n let state = 0 /* TokenizerState.Static */;\n let previousState = state;\n const tokens = [];\n // the segment will always be valid because we get into the initial state\n // with the leading /\n let segment;\n function finalizeSegment() {\n if (segment)\n tokens.push(segment);\n segment = [];\n }\n // index on the path\n let i = 0;\n // char at index\n let char;\n // buffer of the value read\n let buffer = '';\n // custom regexp for a param\n let customRe = '';\n function consumeBuffer() {\n if (!buffer)\n return;\n if (state === 0 /* TokenizerState.Static */) {\n segment.push({\n type: 0 /* TokenType.Static */,\n value: buffer,\n });\n }\n else if (state === 1 /* TokenizerState.Param */ ||\n state === 2 /* TokenizerState.ParamRegExp */ ||\n state === 3 /* TokenizerState.ParamRegExpEnd */) {\n if (segment.length > 1 && (char === '*' || char === '+'))\n crash(`A repeatable param (${buffer}) must be alone in its segment. eg: '/:ids+.`);\n segment.push({\n type: 1 /* TokenType.Param */,\n value: buffer,\n regexp: customRe,\n repeatable: char === '*' || char === '+',\n optional: char === '*' || char === '?',\n });\n }\n else {\n crash('Invalid state to consume buffer');\n }\n buffer = '';\n }\n function addCharToBuffer() {\n buffer += char;\n }\n while (i < path.length) {\n char = path[i++];\n if (char === '\\\\' && state !== 2 /* TokenizerState.ParamRegExp */) {\n previousState = state;\n state = 4 /* TokenizerState.EscapeNext */;\n continue;\n }\n switch (state) {\n case 0 /* TokenizerState.Static */:\n if (char === '/') {\n if (buffer) {\n consumeBuffer();\n }\n finalizeSegment();\n }\n else if (char === ':') {\n consumeBuffer();\n state = 1 /* TokenizerState.Param */;\n }\n else {\n addCharToBuffer();\n }\n break;\n case 4 /* TokenizerState.EscapeNext */:\n addCharToBuffer();\n state = previousState;\n break;\n case 1 /* TokenizerState.Param */:\n if (char === '(') {\n state = 2 /* TokenizerState.ParamRegExp */;\n }\n else if (VALID_PARAM_RE.test(char)) {\n addCharToBuffer();\n }\n else {\n consumeBuffer();\n state = 0 /* TokenizerState.Static */;\n // go back one character if we were not modifying\n if (char !== '*' && char !== '?' && char !== '+')\n i--;\n }\n break;\n case 2 /* TokenizerState.ParamRegExp */:\n // TODO: is it worth handling nested regexp? like :p(?:prefix_([^/]+)_suffix)\n // it already works by escaping the closing )\n // https://paths.esm.dev/?p=AAMeJbiAwQEcDKbAoAAkP60PG2R6QAvgNaA6AFACM2ABuQBB#\n // is this really something people need since you can also write\n // /prefix_:p()_suffix\n if (char === ')') {\n // handle the escaped )\n if (customRe[customRe.length - 1] == '\\\\')\n customRe = customRe.slice(0, -1) + char;\n else\n state = 3 /* TokenizerState.ParamRegExpEnd */;\n }\n else {\n customRe += char;\n }\n break;\n case 3 /* TokenizerState.ParamRegExpEnd */:\n // same as finalizing a param\n consumeBuffer();\n state = 0 /* TokenizerState.Static */;\n // go back one character if we were not modifying\n if (char !== '*' && char !== '?' && char !== '+')\n i--;\n customRe = '';\n break;\n default:\n crash('Unknown state');\n break;\n }\n }\n if (state === 2 /* TokenizerState.ParamRegExp */)\n crash(`Unfinished custom RegExp for param \"${buffer}\"`);\n consumeBuffer();\n finalizeSegment();\n // tokenCache.set(path, tokens)\n return tokens;\n}\n\nfunction createRouteRecordMatcher(record, parent, options) {\n const parser = tokensToParser(tokenizePath(record.path), options);\n // warn against params with the same name\n if ((process.env.NODE_ENV !== 'production')) {\n const existingKeys = new Set();\n for (const key of parser.keys) {\n if (existingKeys.has(key.name))\n warn(`Found duplicated params with name \"${key.name}\" for path \"${record.path}\". Only the last one will be available on \"$route.params\".`);\n existingKeys.add(key.name);\n }\n }\n const matcher = assign(parser, {\n record,\n parent,\n // these needs to be populated by the parent\n children: [],\n alias: [],\n });\n if (parent) {\n // both are aliases or both are not aliases\n // we don't want to mix them because the order is used when\n // passing originalRecord in Matcher.addRoute\n if (!matcher.record.aliasOf === !parent.record.aliasOf)\n parent.children.push(matcher);\n }\n return matcher;\n}\n\n/**\n * Creates a Router Matcher.\n *\n * @internal\n * @param routes - array of initial routes\n * @param globalOptions - global route options\n */\nfunction createRouterMatcher(routes, globalOptions) {\n // normalized ordered array of matchers\n const matchers = [];\n const matcherMap = new Map();\n globalOptions = mergeOptions({ strict: false, end: true, sensitive: false }, globalOptions);\n function getRecordMatcher(name) {\n return matcherMap.get(name);\n }\n function addRoute(record, parent, originalRecord) {\n // used later on to remove by name\n const isRootAdd = !originalRecord;\n const mainNormalizedRecord = normalizeRouteRecord(record);\n if ((process.env.NODE_ENV !== 'production')) {\n checkChildMissingNameWithEmptyPath(mainNormalizedRecord, parent);\n }\n // we might be the child of an alias\n mainNormalizedRecord.aliasOf = originalRecord && originalRecord.record;\n const options = mergeOptions(globalOptions, record);\n // generate an array of records to correctly handle aliases\n const normalizedRecords = [mainNormalizedRecord];\n if ('alias' in record) {\n const aliases = typeof record.alias === 'string' ? [record.alias] : record.alias;\n for (const alias of aliases) {\n normalizedRecords.push(\n // we need to normalize again to ensure the `mods` property\n // being non enumerable\n normalizeRouteRecord(assign({}, mainNormalizedRecord, {\n // this allows us to hold a copy of the `components` option\n // so that async components cache is hold on the original record\n components: originalRecord\n ? originalRecord.record.components\n : mainNormalizedRecord.components,\n path: alias,\n // we might be the child of an alias\n aliasOf: originalRecord\n ? originalRecord.record\n : mainNormalizedRecord,\n // the aliases are always of the same kind as the original since they\n // are defined on the same record\n })));\n }\n }\n let matcher;\n let originalMatcher;\n for (const normalizedRecord of normalizedRecords) {\n const { path } = normalizedRecord;\n // Build up the path for nested routes if the child isn't an absolute\n // route. Only add the / delimiter if the child path isn't empty and if the\n // parent path doesn't have a trailing slash\n if (parent && path[0] !== '/') {\n const parentPath = parent.record.path;\n const connectingSlash = parentPath[parentPath.length - 1] === '/' ? '' : '/';\n normalizedRecord.path =\n parent.record.path + (path && connectingSlash + path);\n }\n if ((process.env.NODE_ENV !== 'production') && normalizedRecord.path === '*') {\n throw new Error('Catch all routes (\"*\") must now be defined using a param with a custom regexp.\\n' +\n 'See more at https://router.vuejs.org/guide/migration/#Removed-star-or-catch-all-routes.');\n }\n // create the object beforehand, so it can be passed to children\n matcher = createRouteRecordMatcher(normalizedRecord, parent, options);\n if ((process.env.NODE_ENV !== 'production') && parent && path[0] === '/')\n checkMissingParamsInAbsolutePath(matcher, parent);\n // if we are an alias we must tell the original record that we exist,\n // so we can be removed\n if (originalRecord) {\n originalRecord.alias.push(matcher);\n if ((process.env.NODE_ENV !== 'production')) {\n checkSameParams(originalRecord, matcher);\n }\n }\n else {\n // otherwise, the first record is the original and others are aliases\n originalMatcher = originalMatcher || matcher;\n if (originalMatcher !== matcher)\n originalMatcher.alias.push(matcher);\n // remove the route if named and only for the top record (avoid in nested calls)\n // this works because the original record is the first one\n if (isRootAdd && record.name && !isAliasRecord(matcher)) {\n if ((process.env.NODE_ENV !== 'production')) {\n checkSameNameAsAncestor(record, parent);\n }\n removeRoute(record.name);\n }\n }\n // Avoid adding a record that doesn't display anything. This allows passing through records without a component to\n // not be reached and pass through the catch all route\n if (isMatchable(matcher)) {\n insertMatcher(matcher);\n }\n if (mainNormalizedRecord.children) {\n const children = mainNormalizedRecord.children;\n for (let i = 0; i < children.length; i++) {\n addRoute(children[i], matcher, originalRecord && originalRecord.children[i]);\n }\n }\n // if there was no original record, then the first one was not an alias and all\n // other aliases (if any) need to reference this record when adding children\n originalRecord = originalRecord || matcher;\n // TODO: add normalized records for more flexibility\n // if (parent && isAliasRecord(originalRecord)) {\n // parent.children.push(originalRecord)\n // }\n }\n return originalMatcher\n ? () => {\n // since other matchers are aliases, they should be removed by the original matcher\n removeRoute(originalMatcher);\n }\n : noop;\n }\n function removeRoute(matcherRef) {\n if (isRouteName(matcherRef)) {\n const matcher = matcherMap.get(matcherRef);\n if (matcher) {\n matcherMap.delete(matcherRef);\n matchers.splice(matchers.indexOf(matcher), 1);\n matcher.children.forEach(removeRoute);\n matcher.alias.forEach(removeRoute);\n }\n }\n else {\n const index = matchers.indexOf(matcherRef);\n if (index > -1) {\n matchers.splice(index, 1);\n if (matcherRef.record.name)\n matcherMap.delete(matcherRef.record.name);\n matcherRef.children.forEach(removeRoute);\n matcherRef.alias.forEach(removeRoute);\n }\n }\n }\n function getRoutes() {\n return matchers;\n }\n function insertMatcher(matcher) {\n const index = findInsertionIndex(matcher, matchers);\n matchers.splice(index, 0, matcher);\n // only add the original record to the name map\n if (matcher.record.name && !isAliasRecord(matcher))\n matcherMap.set(matcher.record.name, matcher);\n }\n function resolve(location, currentLocation) {\n let matcher;\n let params = {};\n let path;\n let name;\n if ('name' in location && location.name) {\n matcher = matcherMap.get(location.name);\n if (!matcher)\n throw createRouterError(1 /* ErrorTypes.MATCHER_NOT_FOUND */, {\n location,\n });\n // warn if the user is passing invalid params so they can debug it better when they get removed\n if ((process.env.NODE_ENV !== 'production')) {\n const invalidParams = Object.keys(location.params || {}).filter(paramName => !matcher.keys.find(k => k.name === paramName));\n if (invalidParams.length) {\n warn(`Discarded invalid param(s) \"${invalidParams.join('\", \"')}\" when navigating. See https://github.com/vuejs/router/blob/main/packages/router/CHANGELOG.md#414-2022-08-22 for more details.`);\n }\n }\n name = matcher.record.name;\n params = assign(\n // paramsFromLocation is a new object\n paramsFromLocation(currentLocation.params, \n // only keep params that exist in the resolved location\n // only keep optional params coming from a parent record\n matcher.keys\n .filter(k => !k.optional)\n .concat(matcher.parent ? matcher.parent.keys.filter(k => k.optional) : [])\n .map(k => k.name)), \n // discard any existing params in the current location that do not exist here\n // #1497 this ensures better active/exact matching\n location.params &&\n paramsFromLocation(location.params, matcher.keys.map(k => k.name)));\n // throws if cannot be stringified\n path = matcher.stringify(params);\n }\n else if (location.path != null) {\n // no need to resolve the path with the matcher as it was provided\n // this also allows the user to control the encoding\n path = location.path;\n if ((process.env.NODE_ENV !== 'production') && !path.startsWith('/')) {\n warn(`The Matcher cannot resolve relative paths but received \"${path}\". Unless you directly called \\`matcher.resolve(\"${path}\")\\`, this is probably a bug in vue-router. Please open an issue at https://github.com/vuejs/router/issues/new/choose.`);\n }\n matcher = matchers.find(m => m.re.test(path));\n // matcher should have a value after the loop\n if (matcher) {\n // we know the matcher works because we tested the regexp\n params = matcher.parse(path);\n name = matcher.record.name;\n }\n // location is a relative path\n }\n else {\n // match by name or path of current route\n matcher = currentLocation.name\n ? matcherMap.get(currentLocation.name)\n : matchers.find(m => m.re.test(currentLocation.path));\n if (!matcher)\n throw createRouterError(1 /* ErrorTypes.MATCHER_NOT_FOUND */, {\n location,\n currentLocation,\n });\n name = matcher.record.name;\n // since we are navigating to the same location, we don't need to pick the\n // params like when `name` is provided\n params = assign({}, currentLocation.params, location.params);\n path = matcher.stringify(params);\n }\n const matched = [];\n let parentMatcher = matcher;\n while (parentMatcher) {\n // reversed order so parents are at the beginning\n matched.unshift(parentMatcher.record);\n parentMatcher = parentMatcher.parent;\n }\n return {\n name,\n path,\n params,\n matched,\n meta: mergeMetaFields(matched),\n };\n }\n // add initial routes\n routes.forEach(route => addRoute(route));\n function clearRoutes() {\n matchers.length = 0;\n matcherMap.clear();\n }\n return {\n addRoute,\n resolve,\n removeRoute,\n clearRoutes,\n getRoutes,\n getRecordMatcher,\n };\n}\nfunction paramsFromLocation(params, keys) {\n const newParams = {};\n for (const key of keys) {\n if (key in params)\n newParams[key] = params[key];\n }\n return newParams;\n}\n/**\n * Normalizes a RouteRecordRaw. Creates a copy\n *\n * @param record\n * @returns the normalized version\n */\nfunction normalizeRouteRecord(record) {\n const normalized = {\n path: record.path,\n redirect: record.redirect,\n name: record.name,\n meta: record.meta || {},\n aliasOf: record.aliasOf,\n beforeEnter: record.beforeEnter,\n props: normalizeRecordProps(record),\n children: record.children || [],\n instances: {},\n leaveGuards: new Set(),\n updateGuards: new Set(),\n enterCallbacks: {},\n // must be declared afterwards\n // mods: {},\n components: 'components' in record\n ? record.components || null\n : record.component && { default: record.component },\n };\n // mods contain modules and shouldn't be copied,\n // logged or anything. It's just used for internal\n // advanced use cases like data loaders\n Object.defineProperty(normalized, 'mods', {\n value: {},\n });\n return normalized;\n}\n/**\n * Normalize the optional `props` in a record to always be an object similar to\n * components. Also accept a boolean for components.\n * @param record\n */\nfunction normalizeRecordProps(record) {\n const propsObject = {};\n // props does not exist on redirect records, but we can set false directly\n const props = record.props || false;\n if ('component' in record) {\n propsObject.default = props;\n }\n else {\n // NOTE: we could also allow a function to be applied to every component.\n // Would need user feedback for use cases\n for (const name in record.components)\n propsObject[name] = typeof props === 'object' ? props[name] : props;\n }\n return propsObject;\n}\n/**\n * Checks if a record or any of its parent is an alias\n * @param record\n */\nfunction isAliasRecord(record) {\n while (record) {\n if (record.record.aliasOf)\n return true;\n record = record.parent;\n }\n return false;\n}\n/**\n * Merge meta fields of an array of records\n *\n * @param matched - array of matched records\n */\nfunction mergeMetaFields(matched) {\n return matched.reduce((meta, record) => assign(meta, record.meta), {});\n}\nfunction mergeOptions(defaults, partialOptions) {\n const options = {};\n for (const key in defaults) {\n options[key] = key in partialOptions ? partialOptions[key] : defaults[key];\n }\n return options;\n}\nfunction isSameParam(a, b) {\n return (a.name === b.name &&\n a.optional === b.optional &&\n a.repeatable === b.repeatable);\n}\n/**\n * Check if a path and its alias have the same required params\n *\n * @param a - original record\n * @param b - alias record\n */\nfunction checkSameParams(a, b) {\n for (const key of a.keys) {\n if (!key.optional && !b.keys.find(isSameParam.bind(null, key)))\n return warn(`Alias \"${b.record.path}\" and the original record: \"${a.record.path}\" must have the exact same param named \"${key.name}\"`);\n }\n for (const key of b.keys) {\n if (!key.optional && !a.keys.find(isSameParam.bind(null, key)))\n return warn(`Alias \"${b.record.path}\" and the original record: \"${a.record.path}\" must have the exact same param named \"${key.name}\"`);\n }\n}\n/**\n * A route with a name and a child with an empty path without a name should warn when adding the route\n *\n * @param mainNormalizedRecord - RouteRecordNormalized\n * @param parent - RouteRecordMatcher\n */\nfunction checkChildMissingNameWithEmptyPath(mainNormalizedRecord, parent) {\n if (parent &&\n parent.record.name &&\n !mainNormalizedRecord.name &&\n !mainNormalizedRecord.path) {\n warn(`The route named \"${String(parent.record.name)}\" has a child without a name and an empty path. Using that name won't render the empty path child so you probably want to move the name to the child instead. If this is intentional, add a name to the child route to remove the warning.`);\n }\n}\nfunction checkSameNameAsAncestor(record, parent) {\n for (let ancestor = parent; ancestor; ancestor = ancestor.parent) {\n if (ancestor.record.name === record.name) {\n throw new Error(`A route named \"${String(record.name)}\" has been added as a ${parent === ancestor ? 'child' : 'descendant'} of a route with the same name. Route names must be unique and a nested route cannot use the same name as an ancestor.`);\n }\n }\n}\nfunction checkMissingParamsInAbsolutePath(record, parent) {\n for (const key of parent.keys) {\n if (!record.keys.find(isSameParam.bind(null, key)))\n return warn(`Absolute path \"${record.record.path}\" must have the exact same param named \"${key.name}\" as its parent \"${parent.record.path}\".`);\n }\n}\n/**\n * Performs a binary search to find the correct insertion index for a new matcher.\n *\n * Matchers are primarily sorted by their score. If scores are tied then we also consider parent/child relationships,\n * with descendants coming before ancestors. If there's still a tie, new routes are inserted after existing routes.\n *\n * @param matcher - new matcher to be inserted\n * @param matchers - existing matchers\n */\nfunction findInsertionIndex(matcher, matchers) {\n // First phase: binary search based on score\n let lower = 0;\n let upper = matchers.length;\n while (lower !== upper) {\n const mid = (lower + upper) >> 1;\n const sortOrder = comparePathParserScore(matcher, matchers[mid]);\n if (sortOrder < 0) {\n upper = mid;\n }\n else {\n lower = mid + 1;\n }\n }\n // Second phase: check for an ancestor with the same score\n const insertionAncestor = getInsertionAncestor(matcher);\n if (insertionAncestor) {\n upper = matchers.lastIndexOf(insertionAncestor, upper - 1);\n if ((process.env.NODE_ENV !== 'production') && upper < 0) {\n // This should never happen\n warn(`Finding ancestor route \"${insertionAncestor.record.path}\" failed for \"${matcher.record.path}\"`);\n }\n }\n return upper;\n}\nfunction getInsertionAncestor(matcher) {\n let ancestor = matcher;\n while ((ancestor = ancestor.parent)) {\n if (isMatchable(ancestor) &&\n comparePathParserScore(matcher, ancestor) === 0) {\n return ancestor;\n }\n }\n return;\n}\n/**\n * Checks if a matcher can be reachable. This means if it's possible to reach it as a route. For example, routes without\n * a component, or name, or redirect, are just used to group other routes.\n * @param matcher\n * @param matcher.record record of the matcher\n * @returns\n */\nfunction isMatchable({ record }) {\n return !!(record.name ||\n (record.components && Object.keys(record.components).length) ||\n record.redirect);\n}\n\n/**\n * Transforms a queryString into a {@link LocationQuery} object. Accept both, a\n * version with the leading `?` and without Should work as URLSearchParams\n\n * @internal\n *\n * @param search - search string to parse\n * @returns a query object\n */\nfunction parseQuery(search) {\n const query = {};\n // avoid creating an object with an empty key and empty value\n // because of split('&')\n if (search === '' || search === '?')\n return query;\n const hasLeadingIM = search[0] === '?';\n const searchParams = (hasLeadingIM ? search.slice(1) : search).split('&');\n for (let i = 0; i < searchParams.length; ++i) {\n // pre decode the + into space\n const searchParam = searchParams[i].replace(PLUS_RE, ' ');\n // allow the = character\n const eqPos = searchParam.indexOf('=');\n const key = decode(eqPos < 0 ? searchParam : searchParam.slice(0, eqPos));\n const value = eqPos < 0 ? null : decode(searchParam.slice(eqPos + 1));\n if (key in query) {\n // an extra variable for ts types\n let currentValue = query[key];\n if (!isArray(currentValue)) {\n currentValue = query[key] = [currentValue];\n }\n currentValue.push(value);\n }\n else {\n query[key] = value;\n }\n }\n return query;\n}\n/**\n * Stringifies a {@link LocationQueryRaw} object. Like `URLSearchParams`, it\n * doesn't prepend a `?`\n *\n * @internal\n *\n * @param query - query object to stringify\n * @returns string version of the query without the leading `?`\n */\nfunction stringifyQuery(query) {\n let search = '';\n for (let key in query) {\n const value = query[key];\n key = encodeQueryKey(key);\n if (value == null) {\n // only null adds the value\n if (value !== undefined) {\n search += (search.length ? '&' : '') + key;\n }\n continue;\n }\n // keep null values\n const values = isArray(value)\n ? value.map(v => v && encodeQueryValue(v))\n : [value && encodeQueryValue(value)];\n values.forEach(value => {\n // skip undefined values in arrays as if they were not present\n // smaller code than using filter\n if (value !== undefined) {\n // only append & with non-empty search\n search += (search.length ? '&' : '') + key;\n if (value != null)\n search += '=' + value;\n }\n });\n }\n return search;\n}\n/**\n * Transforms a {@link LocationQueryRaw} into a {@link LocationQuery} by casting\n * numbers into strings, removing keys with an undefined value and replacing\n * undefined with null in arrays\n *\n * @param query - query object to normalize\n * @returns a normalized query object\n */\nfunction normalizeQuery(query) {\n const normalizedQuery = {};\n for (const key in query) {\n const value = query[key];\n if (value !== undefined) {\n normalizedQuery[key] = isArray(value)\n ? value.map(v => (v == null ? null : '' + v))\n : value == null\n ? value\n : '' + value;\n }\n }\n return normalizedQuery;\n}\n\n/**\n * RouteRecord being rendered by the closest ancestor Router View. Used for\n * `onBeforeRouteUpdate` and `onBeforeRouteLeave`. rvlm stands for Router View\n * Location Matched\n *\n * @internal\n */\nconst matchedRouteKey = Symbol((process.env.NODE_ENV !== 'production') ? 'router view location matched' : '');\n/**\n * Allows overriding the router view depth to control which component in\n * `matched` is rendered. rvd stands for Router View Depth\n *\n * @internal\n */\nconst viewDepthKey = Symbol((process.env.NODE_ENV !== 'production') ? 'router view depth' : '');\n/**\n * Allows overriding the router instance returned by `useRouter` in tests. r\n * stands for router\n *\n * @internal\n */\nconst routerKey = Symbol((process.env.NODE_ENV !== 'production') ? 'router' : '');\n/**\n * Allows overriding the current route returned by `useRoute` in tests. rl\n * stands for route location\n *\n * @internal\n */\nconst routeLocationKey = Symbol((process.env.NODE_ENV !== 'production') ? 'route location' : '');\n/**\n * Allows overriding the current route used by router-view. Internally this is\n * used when the `route` prop is passed.\n *\n * @internal\n */\nconst routerViewLocationKey = Symbol((process.env.NODE_ENV !== 'production') ? 'router view location' : '');\n\n/**\n * Create a list of callbacks that can be reset. Used to create before and after navigation guards list\n */\nfunction useCallbacks() {\n let handlers = [];\n function add(handler) {\n handlers.push(handler);\n return () => {\n const i = handlers.indexOf(handler);\n if (i > -1)\n handlers.splice(i, 1);\n };\n }\n function reset() {\n handlers = [];\n }\n return {\n add,\n list: () => handlers.slice(),\n reset,\n };\n}\n\nfunction registerGuard(record, name, guard) {\n const removeFromList = () => {\n record[name].delete(guard);\n };\n onUnmounted(removeFromList);\n onDeactivated(removeFromList);\n onActivated(() => {\n record[name].add(guard);\n });\n record[name].add(guard);\n}\n/**\n * Add a navigation guard that triggers whenever the component for the current\n * location is about to be left. Similar to {@link beforeRouteLeave} but can be\n * used in any component. The guard is removed when the component is unmounted.\n *\n * @param leaveGuard - {@link NavigationGuard}\n */\nfunction onBeforeRouteLeave(leaveGuard) {\n if ((process.env.NODE_ENV !== 'production') && !getCurrentInstance()) {\n warn('getCurrentInstance() returned null. onBeforeRouteLeave() must be called at the top of a setup function');\n return;\n }\n const activeRecord = inject(matchedRouteKey, \n // to avoid warning\n {}).value;\n if (!activeRecord) {\n (process.env.NODE_ENV !== 'production') &&\n warn('No active route record was found when calling `onBeforeRouteLeave()`. Make sure you call this function inside a component child of <router-view>. Maybe you called it inside of App.vue?');\n return;\n }\n registerGuard(activeRecord, 'leaveGuards', leaveGuard);\n}\n/**\n * Add a navigation guard that triggers whenever the current location is about\n * to be updated. Similar to {@link beforeRouteUpdate} but can be used in any\n * component. The guard is removed when the component is unmounted.\n *\n * @param updateGuard - {@link NavigationGuard}\n */\nfunction onBeforeRouteUpdate(updateGuard) {\n if ((process.env.NODE_ENV !== 'production') && !getCurrentInstance()) {\n warn('getCurrentInstance() returned null. onBeforeRouteUpdate() must be called at the top of a setup function');\n return;\n }\n const activeRecord = inject(matchedRouteKey, \n // to avoid warning\n {}).value;\n if (!activeRecord) {\n (process.env.NODE_ENV !== 'production') &&\n warn('No active route record was found when calling `onBeforeRouteUpdate()`. Make sure you call this function inside a component child of <router-view>. Maybe you called it inside of App.vue?');\n return;\n }\n registerGuard(activeRecord, 'updateGuards', updateGuard);\n}\nfunction guardToPromiseFn(guard, to, from, record, name, runWithContext = fn => fn()) {\n // keep a reference to the enterCallbackArray to prevent pushing callbacks if a new navigation took place\n const enterCallbackArray = record &&\n // name is defined if record is because of the function overload\n (record.enterCallbacks[name] = record.enterCallbacks[name] || []);\n return () => new Promise((resolve, reject) => {\n const next = (valid) => {\n if (valid === false) {\n reject(createRouterError(4 /* ErrorTypes.NAVIGATION_ABORTED */, {\n from,\n to,\n }));\n }\n else if (valid instanceof Error) {\n reject(valid);\n }\n else if (isRouteLocation(valid)) {\n reject(createRouterError(2 /* ErrorTypes.NAVIGATION_GUARD_REDIRECT */, {\n from: to,\n to: valid,\n }));\n }\n else {\n if (enterCallbackArray &&\n // since enterCallbackArray is truthy, both record and name also are\n record.enterCallbacks[name] === enterCallbackArray &&\n typeof valid === 'function') {\n enterCallbackArray.push(valid);\n }\n resolve();\n }\n };\n // wrapping with Promise.resolve allows it to work with both async and sync guards\n const guardReturn = runWithContext(() => guard.call(record && record.instances[name], to, from, (process.env.NODE_ENV !== 'production') ? canOnlyBeCalledOnce(next, to, from) : next));\n let guardCall = Promise.resolve(guardReturn);\n if (guard.length < 3)\n guardCall = guardCall.then(next);\n if ((process.env.NODE_ENV !== 'production') && guard.length > 2) {\n const message = `The \"next\" callback was never called inside of ${guard.name ? '\"' + guard.name + '\"' : ''}:\\n${guard.toString()}\\n. If you are returning a value instead of calling \"next\", make sure to remove the \"next\" parameter from your function.`;\n if (typeof guardReturn === 'object' && 'then' in guardReturn) {\n guardCall = guardCall.then(resolvedValue => {\n // @ts-expect-error: _called is added at canOnlyBeCalledOnce\n if (!next._called) {\n warn(message);\n return Promise.reject(new Error('Invalid navigation guard'));\n }\n return resolvedValue;\n });\n }\n else if (guardReturn !== undefined) {\n // @ts-expect-error: _called is added at canOnlyBeCalledOnce\n if (!next._called) {\n warn(message);\n reject(new Error('Invalid navigation guard'));\n return;\n }\n }\n }\n guardCall.catch(err => reject(err));\n });\n}\nfunction canOnlyBeCalledOnce(next, to, from) {\n let called = 0;\n return function () {\n if (called++ === 1)\n warn(`The \"next\" callback was called more than once in one navigation guard when going from \"${from.fullPath}\" to \"${to.fullPath}\". It should be called exactly one time in each navigation guard. This will fail in production.`);\n // @ts-expect-error: we put it in the original one because it's easier to check\n next._called = true;\n if (called === 1)\n next.apply(null, arguments);\n };\n}\nfunction extractComponentsGuards(matched, guardType, to, from, runWithContext = fn => fn()) {\n const guards = [];\n for (const record of matched) {\n if ((process.env.NODE_ENV !== 'production') && !record.components && !record.children.length) {\n warn(`Record with path \"${record.path}\" is either missing a \"component(s)\"` +\n ` or \"children\" property.`);\n }\n for (const name in record.components) {\n let rawComponent = record.components[name];\n if ((process.env.NODE_ENV !== 'production')) {\n if (!rawComponent ||\n (typeof rawComponent !== 'object' &&\n typeof rawComponent !== 'function')) {\n warn(`Component \"${name}\" in record with path \"${record.path}\" is not` +\n ` a valid component. Received \"${String(rawComponent)}\".`);\n // throw to ensure we stop here but warn to ensure the message isn't\n // missed by the user\n throw new Error('Invalid route component');\n }\n else if ('then' in rawComponent) {\n // warn if user wrote import('/component.vue') instead of () =>\n // import('./component.vue')\n warn(`Component \"${name}\" in record with path \"${record.path}\" is a ` +\n `Promise instead of a function that returns a Promise. Did you ` +\n `write \"import('./MyPage.vue')\" instead of ` +\n `\"() => import('./MyPage.vue')\" ? This will break in ` +\n `production if not fixed.`);\n const promise = rawComponent;\n rawComponent = () => promise;\n }\n else if (rawComponent.__asyncLoader &&\n // warn only once per component\n !rawComponent.__warnedDefineAsync) {\n rawComponent.__warnedDefineAsync = true;\n warn(`Component \"${name}\" in record with path \"${record.path}\" is defined ` +\n `using \"defineAsyncComponent()\". ` +\n `Write \"() => import('./MyPage.vue')\" instead of ` +\n `\"defineAsyncComponent(() => import('./MyPage.vue'))\".`);\n }\n }\n // skip update and leave guards if the route component is not mounted\n if (guardType !== 'beforeRouteEnter' && !record.instances[name])\n continue;\n if (isRouteComponent(rawComponent)) {\n // __vccOpts is added by vue-class-component and contain the regular options\n const options = rawComponent.__vccOpts || rawComponent;\n const guard = options[guardType];\n guard &&\n guards.push(guardToPromiseFn(guard, to, from, record, name, runWithContext));\n }\n else {\n // start requesting the chunk already\n let componentPromise = rawComponent();\n if ((process.env.NODE_ENV !== 'production') && !('catch' in componentPromise)) {\n warn(`Component \"${name}\" in record with path \"${record.path}\" is a function that does not return a Promise. If you were passing a functional component, make sure to add a \"displayName\" to the component. This will break in production if not fixed.`);\n componentPromise = Promise.resolve(componentPromise);\n }\n guards.push(() => componentPromise.then(resolved => {\n if (!resolved)\n throw new Error(`Couldn't resolve component \"${name}\" at \"${record.path}\"`);\n const resolvedComponent = isESModule(resolved)\n ? resolved.default\n : resolved;\n // keep the resolved module for plugins like data loaders\n record.mods[name] = resolved;\n // replace the function with the resolved component\n // cannot be null or undefined because we went into the for loop\n record.components[name] = resolvedComponent;\n // __vccOpts is added by vue-class-component and contain the regular options\n const options = resolvedComponent.__vccOpts || resolvedComponent;\n const guard = options[guardType];\n return (guard &&\n guardToPromiseFn(guard, to, from, record, name, runWithContext)());\n }));\n }\n }\n }\n return guards;\n}\n/**\n * Ensures a route is loaded, so it can be passed as o prop to `<RouterView>`.\n *\n * @param route - resolved route to load\n */\nfunction loadRouteLocation(route) {\n return route.matched.every(record => record.redirect)\n ? Promise.reject(new Error('Cannot load a route that redirects.'))\n : Promise.all(route.matched.map(record => record.components &&\n Promise.all(Object.keys(record.components).reduce((promises, name) => {\n const rawComponent = record.components[name];\n if (typeof rawComponent === 'function' &&\n !('displayName' in rawComponent)) {\n promises.push(rawComponent().then(resolved => {\n if (!resolved)\n return Promise.reject(new Error(`Couldn't resolve component \"${name}\" at \"${record.path}\". Ensure you passed a function that returns a promise.`));\n const resolvedComponent = isESModule(resolved)\n ? resolved.default\n : resolved;\n // keep the resolved module for plugins like data loaders\n record.mods[name] = resolved;\n // replace the function with the resolved component\n // cannot be null or undefined because we went into the for loop\n record.components[name] = resolvedComponent;\n return;\n }));\n }\n return promises;\n }, [])))).then(() => route);\n}\n\n// TODO: we could allow currentRoute as a prop to expose `isActive` and\n// `isExactActive` behavior should go through an RFC\n/**\n * Returns the internal behavior of a {@link RouterLink} without the rendering part.\n *\n * @param props - a `to` location and an optional `replace` flag\n */\nfunction useLink(props) {\n const router = inject(routerKey);\n const currentRoute = inject(routeLocationKey);\n let hasPrevious = false;\n let previousTo = null;\n const route = computed(() => {\n const to = unref(props.to);\n if ((process.env.NODE_ENV !== 'production') && (!hasPrevious || to !== previousTo)) {\n if (!isRouteLocation(to)) {\n if (hasPrevious) {\n warn(`Invalid value for prop \"to\" in useLink()\\n- to:`, to, `\\n- previous to:`, previousTo, `\\n- props:`, props);\n }\n else {\n warn(`Invalid value for prop \"to\" in useLink()\\n- to:`, to, `\\n- props:`, props);\n }\n }\n previousTo = to;\n hasPrevious = true;\n }\n return router.resolve(to);\n });\n const activeRecordIndex = computed(() => {\n const { matched } = route.value;\n const { length } = matched;\n const routeMatched = matched[length - 1];\n const currentMatched = currentRoute.matched;\n if (!routeMatched || !currentMatched.length)\n return -1;\n const index = currentMatched.findIndex(isSameRouteRecord.bind(null, routeMatched));\n if (index > -1)\n return index;\n // possible parent record\n const parentRecordPath = getOriginalPath(matched[length - 2]);\n return (\n // we are dealing with nested routes\n length > 1 &&\n // if the parent and matched route have the same path, this link is\n // referring to the empty child. Or we currently are on a different\n // child of the same parent\n getOriginalPath(routeMatched) === parentRecordPath &&\n // avoid comparing the child with its parent\n currentMatched[currentMatched.length - 1].path !== parentRecordPath\n ? currentMatched.findIndex(isSameRouteRecord.bind(null, matched[length - 2]))\n : index);\n });\n const isActive = computed(() => activeRecordIndex.value > -1 &&\n includesParams(currentRoute.params, route.value.params));\n const isExactActive = computed(() => activeRecordIndex.value > -1 &&\n activeRecordIndex.value === currentRoute.matched.length - 1 &&\n isSameRouteLocationParams(currentRoute.params, route.value.params));\n function navigate(e = {}) {\n if (guardEvent(e)) {\n const p = router[unref(props.replace) ? 'replace' : 'push'](unref(props.to)\n // avoid uncaught errors are they are logged anyway\n ).catch(noop);\n if (props.viewTransition &&\n typeof document !== 'undefined' &&\n 'startViewTransition' in document) {\n document.startViewTransition(() => p);\n }\n return p;\n }\n return Promise.resolve();\n }\n // devtools only\n if (((process.env.NODE_ENV !== 'production') || __VUE_PROD_DEVTOOLS__) && isBrowser) {\n const instance = getCurrentInstance();\n if (instance) {\n const linkContextDevtools = {\n route: route.value,\n isActive: isActive.value,\n isExactActive: isExactActive.value,\n error: null,\n };\n // @ts-expect-error: this is internal\n instance.__vrl_devtools = instance.__vrl_devtools || [];\n // @ts-expect-error: this is internal\n instance.__vrl_devtools.push(linkContextDevtools);\n watchEffect(() => {\n linkContextDevtools.route = route.value;\n linkContextDevtools.isActive = isActive.value;\n linkContextDevtools.isExactActive = isExactActive.value;\n linkContextDevtools.error = isRouteLocation(unref(props.to))\n ? null\n : 'Invalid \"to\" value';\n }, { flush: 'post' });\n }\n }\n /**\n * NOTE: update {@link _RouterLinkI}'s `$slots` type when updating this\n */\n return {\n route,\n href: computed(() => route.value.href),\n isActive,\n isExactActive,\n navigate,\n };\n}\nfunction preferSingleVNode(vnodes) {\n return vnodes.length === 1 ? vnodes[0] : vnodes;\n}\nconst RouterLinkImpl = /*#__PURE__*/ defineComponent({\n name: 'RouterLink',\n compatConfig: { MODE: 3 },\n props: {\n to: {\n type: [String, Object],\n required: true,\n },\n replace: Boolean,\n activeClass: String,\n // inactiveClass: String,\n exactActiveClass: String,\n custom: Boolean,\n ariaCurrentValue: {\n type: String,\n default: 'page',\n },\n },\n useLink,\n setup(props, { slots }) {\n const link = reactive(useLink(props));\n const { options } = inject(routerKey);\n const elClass = computed(() => ({\n [getLinkClass(props.activeClass, options.linkActiveClass, 'router-link-active')]: link.isActive,\n // [getLinkClass(\n // props.inactiveClass,\n // options.linkInactiveClass,\n // 'router-link-inactive'\n // )]: !link.isExactActive,\n [getLinkClass(props.exactActiveClass, options.linkExactActiveClass, 'router-link-exact-active')]: link.isExactActive,\n }));\n return () => {\n const children = slots.default && preferSingleVNode(slots.default(link));\n return props.custom\n ? children\n : h('a', {\n 'aria-current': link.isExactActive\n ? props.ariaCurrentValue\n : null,\n href: link.href,\n // this would override user added attrs but Vue will still add\n // the listener, so we end up triggering both\n onClick: link.navigate,\n class: elClass.value,\n }, children);\n };\n },\n});\n// export the public type for h/tsx inference\n// also to avoid inline import() in generated d.ts files\n/**\n * Component to render a link that triggers a navigation on click.\n */\nconst RouterLink = RouterLinkImpl;\nfunction guardEvent(e) {\n // don't redirect with control keys\n if (e.metaKey || e.altKey || e.ctrlKey || e.shiftKey)\n return;\n // don't redirect when preventDefault called\n if (e.defaultPrevented)\n return;\n // don't redirect on right click\n if (e.button !== undefined && e.button !== 0)\n return;\n // don't redirect if `target=\"_blank\"`\n // @ts-expect-error getAttribute does exist\n if (e.currentTarget && e.currentTarget.getAttribute) {\n // @ts-expect-error getAttribute exists\n const target = e.currentTarget.getAttribute('target');\n if (/\\b_blank\\b/i.test(target))\n return;\n }\n // this may be a Weex event which doesn't have this method\n if (e.preventDefault)\n e.preventDefault();\n return true;\n}\nfunction includesParams(outer, inner) {\n for (const key in inner) {\n const innerValue = inner[key];\n const outerValue = outer[key];\n if (typeof innerValue === 'string') {\n if (innerValue !== outerValue)\n return false;\n }\n else {\n if (!isArray(outerValue) ||\n outerValue.length !== innerValue.length ||\n innerValue.some((value, i) => value !== outerValue[i]))\n return false;\n }\n }\n return true;\n}\n/**\n * Get the original path value of a record by following its aliasOf\n * @param record\n */\nfunction getOriginalPath(record) {\n return record ? (record.aliasOf ? record.aliasOf.path : record.path) : '';\n}\n/**\n * Utility class to get the active class based on defaults.\n * @param propClass\n * @param globalClass\n * @param defaultClass\n */\nconst getLinkClass = (propClass, globalClass, defaultClass) => propClass != null\n ? propClass\n : globalClass != null\n ? globalClass\n : defaultClass;\n\nconst RouterViewImpl = /*#__PURE__*/ defineComponent({\n name: 'RouterView',\n // #674 we manually inherit them\n inheritAttrs: false,\n props: {\n name: {\n type: String,\n default: 'default',\n },\n route: Object,\n },\n // Better compat for @vue/compat users\n // https://github.com/vuejs/router/issues/1315\n compatConfig: { MODE: 3 },\n setup(props, { attrs, slots }) {\n (process.env.NODE_ENV !== 'production') && warnDeprecatedUsage();\n const injectedRoute = inject(routerViewLocationKey);\n const routeToDisplay = computed(() => props.route || injectedRoute.value);\n const injectedDepth = inject(viewDepthKey, 0);\n // The depth changes based on empty components option, which allows passthrough routes e.g. routes with children\n // that are used to reuse the `path` property\n const depth = computed(() => {\n let initialDepth = unref(injectedDepth);\n const { matched } = routeToDisplay.value;\n let matchedRoute;\n while ((matchedRoute = matched[initialDepth]) &&\n !matchedRoute.components) {\n initialDepth++;\n }\n return initialDepth;\n });\n const matchedRouteRef = computed(() => routeToDisplay.value.matched[depth.value]);\n provide(viewDepthKey, computed(() => depth.value + 1));\n provide(matchedRouteKey, matchedRouteRef);\n provide(routerViewLocationKey, routeToDisplay);\n const viewRef = ref();\n // watch at the same time the component instance, the route record we are\n // rendering, and the name\n watch(() => [viewRef.value, matchedRouteRef.value, props.name], ([instance, to, name], [oldInstance, from, oldName]) => {\n // copy reused instances\n if (to) {\n // this will update the instance for new instances as well as reused\n // instances when navigating to a new route\n to.instances[name] = instance;\n // the component instance is reused for a different route or name, so\n // we copy any saved update or leave guards. With async setup, the\n // mounting component will mount before the matchedRoute changes,\n // making instance === oldInstance, so we check if guards have been\n // added before. This works because we remove guards when\n // unmounting/deactivating components\n if (from && from !== to && instance && instance === oldInstance) {\n if (!to.leaveGuards.size) {\n to.leaveGuards = from.leaveGuards;\n }\n if (!to.updateGuards.size) {\n to.updateGuards = from.updateGuards;\n }\n }\n }\n // trigger beforeRouteEnter next callbacks\n if (instance &&\n to &&\n // if there is no instance but to and from are the same this might be\n // the first visit\n (!from || !isSameRouteRecord(to, from) || !oldInstance)) {\n (to.enterCallbacks[name] || []).forEach(callback => callback(instance));\n }\n }, { flush: 'post' });\n return () => {\n const route = routeToDisplay.value;\n // we need the value at the time we render because when we unmount, we\n // navigated to a different location so the value is different\n const currentName = props.name;\n const matchedRoute = matchedRouteRef.value;\n const ViewComponent = matchedRoute && matchedRoute.components[currentName];\n if (!ViewComponent) {\n return normalizeSlot(slots.default, { Component: ViewComponent, route });\n }\n // props from route configuration\n const routePropsOption = matchedRoute.props[currentName];\n const routeProps = routePropsOption\n ? routePropsOption === true\n ? route.params\n : typeof routePropsOption === 'function'\n ? routePropsOption(route)\n : routePropsOption\n : null;\n const onVnodeUnmounted = vnode => {\n // remove the instance reference to prevent leak\n if (vnode.component.isUnmounted) {\n matchedRoute.instances[currentName] = null;\n }\n };\n const component = h(ViewComponent, assign({}, routeProps, attrs, {\n onVnodeUnmounted,\n ref: viewRef,\n }));\n if (((process.env.NODE_ENV !== 'production') || __VUE_PROD_DEVTOOLS__) &&\n isBrowser &&\n component.ref) {\n // TODO: can display if it's an alias, its props\n const info = {\n depth: depth.value,\n name: matchedRoute.name,\n path: matchedRoute.path,\n meta: matchedRoute.meta,\n };\n const internalInstances = isArray(component.ref)\n ? component.ref.map(r => r.i)\n : [component.ref.i];\n internalInstances.forEach(instance => {\n // @ts-expect-error\n instance.__vrv_devtools = info;\n });\n }\n return (\n // pass the vnode to the slot as a prop.\n // h and <component :is=\"...\"> both accept vnodes\n normalizeSlot(slots.default, { Component: component, route }) ||\n component);\n };\n },\n});\nfunction normalizeSlot(slot, data) {\n if (!slot)\n return null;\n const slotContent = slot(data);\n return slotContent.length === 1 ? slotContent[0] : slotContent;\n}\n// export the public type for h/tsx inference\n// also to avoid inline import() in generated d.ts files\n/**\n * Component to display the current route the user is at.\n */\nconst RouterView = RouterViewImpl;\n// warn against deprecated usage with <transition> & <keep-alive>\n// due to functional component being no longer eager in Vue 3\nfunction warnDeprecatedUsage() {\n const instance = getCurrentInstance();\n const parentName = instance.parent && instance.parent.type.name;\n const parentSubTreeType = instance.parent && instance.parent.subTree && instance.parent.subTree.type;\n if (parentName &&\n (parentName === 'KeepAlive' || parentName.includes('Transition')) &&\n typeof parentSubTreeType === 'object' &&\n parentSubTreeType.name === 'RouterView') {\n const comp = parentName === 'KeepAlive' ? 'keep-alive' : 'transition';\n warn(`<router-view> can no longer be used directly inside <transition> or <keep-alive>.\\n` +\n `Use slot props instead:\\n\\n` +\n `<router-view v-slot=\"{ Component }\">\\n` +\n ` <${comp}>\\n` +\n ` <component :is=\"Component\" />\\n` +\n ` </${comp}>\\n` +\n `</router-view>`);\n }\n}\n\n/**\n * Copies a route location and removes any problematic properties that cannot be shown in devtools (e.g. Vue instances).\n *\n * @param routeLocation - routeLocation to format\n * @param tooltip - optional tooltip\n * @returns a copy of the routeLocation\n */\nfunction formatRouteLocation(routeLocation, tooltip) {\n const copy = assign({}, routeLocation, {\n // remove variables that can contain vue instances\n matched: routeLocation.matched.map(matched => omit(matched, ['instances', 'children', 'aliasOf'])),\n });\n return {\n _custom: {\n type: null,\n readOnly: true,\n display: routeLocation.fullPath,\n tooltip,\n value: copy,\n },\n };\n}\nfunction formatDisplay(display) {\n return {\n _custom: {\n display,\n },\n };\n}\n// to support multiple router instances\nlet routerId = 0;\nfunction addDevtools(app, router, matcher) {\n // Take over router.beforeEach and afterEach\n // make sure we are not registering the devtool twice\n if (router.__hasDevtools)\n return;\n router.__hasDevtools = true;\n // increment to support multiple router instances\n const id = routerId++;\n setupDevtoolsPlugin({\n id: 'org.vuejs.router' + (id ? '.' + id : ''),\n label: 'Vue Router',\n packageName: 'vue-router',\n homepage: 'https://router.vuejs.org',\n logo: 'https://router.vuejs.org/logo.png',\n componentStateTypes: ['Routing'],\n app,\n }, api => {\n if (typeof api.now !== 'function') {\n console.warn('[Vue Router]: You seem to be using an outdated version of Vue Devtools. Are you still using the Beta release instead of the stable one? You can find the links at https://devtools.vuejs.org/guide/installation.html.');\n }\n // display state added by the router\n api.on.inspectComponent((payload, ctx) => {\n if (payload.instanceData) {\n payload.instanceData.state.push({\n type: 'Routing',\n key: '$route',\n editable: false,\n value: formatRouteLocation(router.currentRoute.value, 'Current Route'),\n });\n }\n });\n // mark router-link as active and display tags on router views\n api.on.visitComponentTree(({ treeNode: node, componentInstance }) => {\n if (componentInstance.__vrv_devtools) {\n const info = componentInstance.__vrv_devtools;\n node.tags.push({\n label: (info.name ? `${info.name.toString()}: ` : '') + info.path,\n textColor: 0,\n tooltip: 'This component is rendered by &lt;router-view&gt;',\n backgroundColor: PINK_500,\n });\n }\n // if multiple useLink are used\n if (isArray(componentInstance.__vrl_devtools)) {\n componentInstance.__devtoolsApi = api;\n componentInstance.__vrl_devtools.forEach(devtoolsData => {\n let label = devtoolsData.route.path;\n let backgroundColor = ORANGE_400;\n let tooltip = '';\n let textColor = 0;\n if (devtoolsData.error) {\n label = devtoolsData.error;\n backgroundColor = RED_100;\n textColor = RED_700;\n }\n else if (devtoolsData.isExactActive) {\n backgroundColor = LIME_500;\n tooltip = 'This is exactly active';\n }\n else if (devtoolsData.isActive) {\n backgroundColor = BLUE_600;\n tooltip = 'This link is active';\n }\n node.tags.push({\n label,\n textColor,\n tooltip,\n backgroundColor,\n });\n });\n }\n });\n watch(router.currentRoute, () => {\n // refresh active state\n refreshRoutesView();\n api.notifyComponentUpdate();\n api.sendInspectorTree(routerInspectorId);\n api.sendInspectorState(routerInspectorId);\n });\n const navigationsLayerId = 'router:navigations:' + id;\n api.addTimelineLayer({\n id: navigationsLayerId,\n label: `Router${id ? ' ' + id : ''} Navigations`,\n color: 0x40a8c4,\n });\n // const errorsLayerId = 'router:errors'\n // api.addTimelineLayer({\n // id: errorsLayerId,\n // label: 'Router Errors',\n // color: 0xea5455,\n // })\n router.onError((error, to) => {\n api.addTimelineEvent({\n layerId: navigationsLayerId,\n event: {\n title: 'Error during Navigation',\n subtitle: to.fullPath,\n logType: 'error',\n time: api.now(),\n data: { error },\n groupId: to.meta.__navigationId,\n },\n });\n });\n // attached to `meta` and used to group events\n let navigationId = 0;\n router.beforeEach((to, from) => {\n const data = {\n guard: formatDisplay('beforeEach'),\n from: formatRouteLocation(from, 'Current Location during this navigation'),\n to: formatRouteLocation(to, 'Target location'),\n };\n // Used to group navigations together, hide from devtools\n Object.defineProperty(to.meta, '__navigationId', {\n value: navigationId++,\n });\n api.addTimelineEvent({\n layerId: navigationsLayerId,\n event: {\n time: api.now(),\n title: 'Start of navigation',\n subtitle: to.fullPath,\n data,\n groupId: to.meta.__navigationId,\n },\n });\n });\n router.afterEach((to, from, failure) => {\n const data = {\n guard: formatDisplay('afterEach'),\n };\n if (failure) {\n data.failure = {\n _custom: {\n type: Error,\n readOnly: true,\n display: failure ? failure.message : '',\n tooltip: 'Navigation Failure',\n value: failure,\n },\n };\n data.status = formatDisplay('❌');\n }\n else {\n data.status = formatDisplay('✅');\n }\n // we set here to have the right order\n data.from = formatRouteLocation(from, 'Current Location during this navigation');\n data.to = formatRouteLocation(to, 'Target location');\n api.addTimelineEvent({\n layerId: navigationsLayerId,\n event: {\n title: 'End of navigation',\n subtitle: to.fullPath,\n time: api.now(),\n data,\n logType: failure ? 'warning' : 'default',\n groupId: to.meta.__navigationId,\n },\n });\n });\n /**\n * Inspector of Existing routes\n */\n const routerInspectorId = 'router-inspector:' + id;\n api.addInspector({\n id: routerInspectorId,\n label: 'Routes' + (id ? ' ' + id : ''),\n icon: 'book',\n treeFilterPlaceholder: 'Search routes',\n });\n function refreshRoutesView() {\n // the routes view isn't active\n if (!activeRoutesPayload)\n return;\n const payload = activeRoutesPayload;\n // children routes will appear as nested\n let routes = matcher.getRoutes().filter(route => !route.parent ||\n // these routes have a parent with no component which will not appear in the view\n // therefore we still need to include them\n !route.parent.record.components);\n // reset match state to false\n routes.forEach(resetMatchStateOnRouteRecord);\n // apply a match state if there is a payload\n if (payload.filter) {\n routes = routes.filter(route => \n // save matches state based on the payload\n isRouteMatching(route, payload.filter.toLowerCase()));\n }\n // mark active routes\n routes.forEach(route => markRouteRecordActive(route, router.currentRoute.value));\n payload.rootNodes = routes.map(formatRouteRecordForInspector);\n }\n let activeRoutesPayload;\n api.on.getInspectorTree(payload => {\n activeRoutesPayload = payload;\n if (payload.app === app && payload.inspectorId === routerInspectorId) {\n refreshRoutesView();\n }\n });\n /**\n * Display information about the currently selected route record\n */\n api.on.getInspectorState(payload => {\n if (payload.app === app && payload.inspectorId === routerInspectorId) {\n const routes = matcher.getRoutes();\n const route = routes.find(route => route.record.__vd_id === payload.nodeId);\n if (route) {\n payload.state = {\n options: formatRouteRecordMatcherForStateInspector(route),\n };\n }\n }\n });\n api.sendInspectorTree(routerInspectorId);\n api.sendInspectorState(routerInspectorId);\n });\n}\nfunction modifierForKey(key) {\n if (key.optional) {\n return key.repeatable ? '*' : '?';\n }\n else {\n return key.repeatable ? '+' : '';\n }\n}\nfunction formatRouteRecordMatcherForStateInspector(route) {\n const { record } = route;\n const fields = [\n { editable: false, key: 'path', value: record.path },\n ];\n if (record.name != null) {\n fields.push({\n editable: false,\n key: 'name',\n value: record.name,\n });\n }\n fields.push({ editable: false, key: 'regexp', value: route.re });\n if (route.keys.length) {\n fields.push({\n editable: false,\n key: 'keys',\n value: {\n _custom: {\n type: null,\n readOnly: true,\n display: route.keys\n .map(key => `${key.name}${modifierForKey(key)}`)\n .join(' '),\n tooltip: 'Param keys',\n value: route.keys,\n },\n },\n });\n }\n if (record.redirect != null) {\n fields.push({\n editable: false,\n key: 'redirect',\n value: record.redirect,\n });\n }\n if (route.alias.length) {\n fields.push({\n editable: false,\n key: 'aliases',\n value: route.alias.map(alias => alias.record.path),\n });\n }\n if (Object.keys(route.record.meta).length) {\n fields.push({\n editable: false,\n key: 'meta',\n value: route.record.meta,\n });\n }\n fields.push({\n key: 'score',\n editable: false,\n value: {\n _custom: {\n type: null,\n readOnly: true,\n display: route.score.map(score => score.join(', ')).join(' | '),\n tooltip: 'Score used to sort routes',\n value: route.score,\n },\n },\n });\n return fields;\n}\n/**\n * Extracted from tailwind palette\n */\nconst PINK_500 = 0xec4899;\nconst BLUE_600 = 0x2563eb;\nconst LIME_500 = 0x84cc16;\nconst CYAN_400 = 0x22d3ee;\nconst ORANGE_400 = 0xfb923c;\n// const GRAY_100 = 0xf4f4f5\nconst DARK = 0x666666;\nconst RED_100 = 0xfee2e2;\nconst RED_700 = 0xb91c1c;\nfunction formatRouteRecordForInspector(route) {\n const tags = [];\n const { record } = route;\n if (record.name != null) {\n tags.push({\n label: String(record.name),\n textColor: 0,\n backgroundColor: CYAN_400,\n });\n }\n if (record.aliasOf) {\n tags.push({\n label: 'alias',\n textColor: 0,\n backgroundColor: ORANGE_400,\n });\n }\n if (route.__vd_match) {\n tags.push({\n label: 'matches',\n textColor: 0,\n backgroundColor: PINK_500,\n });\n }\n if (route.__vd_exactActive) {\n tags.push({\n label: 'exact',\n textColor: 0,\n backgroundColor: LIME_500,\n });\n }\n if (route.__vd_active) {\n tags.push({\n label: 'active',\n textColor: 0,\n backgroundColor: BLUE_600,\n });\n }\n if (record.redirect) {\n tags.push({\n label: typeof record.redirect === 'string'\n ? `redirect: ${record.redirect}`\n : 'redirects',\n textColor: 0xffffff,\n backgroundColor: DARK,\n });\n }\n // add an id to be able to select it. Using the `path` is not possible because\n // empty path children would collide with their parents\n let id = record.__vd_id;\n if (id == null) {\n id = String(routeRecordId++);\n record.__vd_id = id;\n }\n return {\n id,\n label: record.path,\n tags,\n children: route.children.map(formatRouteRecordForInspector),\n };\n}\n// incremental id for route records and inspector state\nlet routeRecordId = 0;\nconst EXTRACT_REGEXP_RE = /^\\/(.*)\\/([a-z]*)$/;\nfunction markRouteRecordActive(route, currentRoute) {\n // no route will be active if matched is empty\n // reset the matching state\n const isExactActive = currentRoute.matched.length &&\n isSameRouteRecord(currentRoute.matched[currentRoute.matched.length - 1], route.record);\n route.__vd_exactActive = route.__vd_active = isExactActive;\n if (!isExactActive) {\n route.__vd_active = currentRoute.matched.some(match => isSameRouteRecord(match, route.record));\n }\n route.children.forEach(childRoute => markRouteRecordActive(childRoute, currentRoute));\n}\nfunction resetMatchStateOnRouteRecord(route) {\n route.__vd_match = false;\n route.children.forEach(resetMatchStateOnRouteRecord);\n}\nfunction isRouteMatching(route, filter) {\n const found = String(route.re).match(EXTRACT_REGEXP_RE);\n route.__vd_match = false;\n if (!found || found.length < 3) {\n return false;\n }\n // use a regexp without $ at the end to match nested routes better\n const nonEndingRE = new RegExp(found[1].replace(/\\$$/, ''), found[2]);\n if (nonEndingRE.test(filter)) {\n // mark children as matches\n route.children.forEach(child => isRouteMatching(child, filter));\n // exception case: `/`\n if (route.record.path !== '/' || filter === '/') {\n route.__vd_match = route.re.test(filter);\n return true;\n }\n // hide the / route\n return false;\n }\n const path = route.record.path.toLowerCase();\n const decodedPath = decode(path);\n // also allow partial matching on the path\n if (!filter.startsWith('/') &&\n (decodedPath.includes(filter) || path.includes(filter)))\n return true;\n if (decodedPath.startsWith(filter) || path.startsWith(filter))\n return true;\n if (route.record.name && String(route.record.name).includes(filter))\n return true;\n return route.children.some(child => isRouteMatching(child, filter));\n}\nfunction omit(obj, keys) {\n const ret = {};\n for (const key in obj) {\n if (!keys.includes(key)) {\n // @ts-expect-error\n ret[key] = obj[key];\n }\n }\n return ret;\n}\n\n/**\n * Creates a Router instance that can be used by a Vue app.\n *\n * @param options - {@link RouterOptions}\n */\nfunction createRouter(options) {\n const matcher = createRouterMatcher(options.routes, options);\n const parseQuery$1 = options.parseQuery || parseQuery;\n const stringifyQuery$1 = options.stringifyQuery || stringifyQuery;\n const routerHistory = options.history;\n if ((process.env.NODE_ENV !== 'production') && !routerHistory)\n throw new Error('Provide the \"history\" option when calling \"createRouter()\":' +\n ' https://router.vuejs.org/api/interfaces/RouterOptions.html#history');\n const beforeGuards = useCallbacks();\n const beforeResolveGuards = useCallbacks();\n const afterGuards = useCallbacks();\n const currentRoute = shallowRef(START_LOCATION_NORMALIZED);\n let pendingLocation = START_LOCATION_NORMALIZED;\n // leave the scrollRestoration if no scrollBehavior is provided\n if (isBrowser && options.scrollBehavior && 'scrollRestoration' in history) {\n history.scrollRestoration = 'manual';\n }\n const normalizeParams = applyToParams.bind(null, paramValue => '' + paramValue);\n const encodeParams = applyToParams.bind(null, encodeParam);\n const decodeParams = \n // @ts-expect-error: intentionally avoid the type check\n applyToParams.bind(null, decode);\n function addRoute(parentOrRoute, route) {\n let parent;\n let record;\n if (isRouteName(parentOrRoute)) {\n parent = matcher.getRecordMatcher(parentOrRoute);\n if ((process.env.NODE_ENV !== 'production') && !parent) {\n warn(`Parent route \"${String(parentOrRoute)}\" not found when adding child route`, route);\n }\n record = route;\n }\n else {\n record = parentOrRoute;\n }\n return matcher.addRoute(record, parent);\n }\n function removeRoute(name) {\n const recordMatcher = matcher.getRecordMatcher(name);\n if (recordMatcher) {\n matcher.removeRoute(recordMatcher);\n }\n else if ((process.env.NODE_ENV !== 'production')) {\n warn(`Cannot remove non-existent route \"${String(name)}\"`);\n }\n }\n function getRoutes() {\n return matcher.getRoutes().map(routeMatcher => routeMatcher.record);\n }\n function hasRoute(name) {\n return !!matcher.getRecordMatcher(name);\n }\n function resolve(rawLocation, currentLocation) {\n // const resolve: Router['resolve'] = (rawLocation: RouteLocationRaw, currentLocation) => {\n // const objectLocation = routerLocationAsObject(rawLocation)\n // we create a copy to modify it later\n currentLocation = assign({}, currentLocation || currentRoute.value);\n if (typeof rawLocation === 'string') {\n const locationNormalized = parseURL(parseQuery$1, rawLocation, currentLocation.path);\n const matchedRoute = matcher.resolve({ path: locationNormalized.path }, currentLocation);\n const href = routerHistory.createHref(locationNormalized.fullPath);\n if ((process.env.NODE_ENV !== 'production')) {\n if (href.startsWith('//'))\n warn(`Location \"${rawLocation}\" resolved to \"${href}\". A resolved location cannot start with multiple slashes.`);\n else if (!matchedRoute.matched.length) {\n warn(`No match found for location with path \"${rawLocation}\"`);\n }\n }\n // locationNormalized is always a new object\n return assign(locationNormalized, matchedRoute, {\n params: decodeParams(matchedRoute.params),\n hash: decode(locationNormalized.hash),\n redirectedFrom: undefined,\n href,\n });\n }\n if ((process.env.NODE_ENV !== 'production') && !isRouteLocation(rawLocation)) {\n warn(`router.resolve() was passed an invalid location. This will fail in production.\\n- Location:`, rawLocation);\n return resolve({});\n }\n let matcherLocation;\n // path could be relative in object as well\n if (rawLocation.path != null) {\n if ((process.env.NODE_ENV !== 'production') &&\n 'params' in rawLocation &&\n !('name' in rawLocation) &&\n // @ts-expect-error: the type is never\n Object.keys(rawLocation.params).length) {\n warn(`Path \"${rawLocation.path}\" was passed with params but they will be ignored. Use a named route alongside params instead.`);\n }\n matcherLocation = assign({}, rawLocation, {\n path: parseURL(parseQuery$1, rawLocation.path, currentLocation.path).path,\n });\n }\n else {\n // remove any nullish param\n const targetParams = assign({}, rawLocation.params);\n for (const key in targetParams) {\n if (targetParams[key] == null) {\n delete targetParams[key];\n }\n }\n // pass encoded values to the matcher, so it can produce encoded path and fullPath\n matcherLocation = assign({}, rawLocation, {\n params: encodeParams(targetParams),\n });\n // current location params are decoded, we need to encode them in case the\n // matcher merges the params\n currentLocation.params = encodeParams(currentLocation.params);\n }\n const matchedRoute = matcher.resolve(matcherLocation, currentLocation);\n const hash = rawLocation.hash || '';\n if ((process.env.NODE_ENV !== 'production') && hash && !hash.startsWith('#')) {\n warn(`A \\`hash\\` should always start with the character \"#\". Replace \"${hash}\" with \"#${hash}\".`);\n }\n // the matcher might have merged current location params, so\n // we need to run the decoding again\n matchedRoute.params = normalizeParams(decodeParams(matchedRoute.params));\n const fullPath = stringifyURL(stringifyQuery$1, assign({}, rawLocation, {\n hash: encodeHash(hash),\n path: matchedRoute.path,\n }));\n const href = routerHistory.createHref(fullPath);\n if ((process.env.NODE_ENV !== 'production')) {\n if (href.startsWith('//')) {\n warn(`Location \"${rawLocation}\" resolved to \"${href}\". A resolved location cannot start with multiple slashes.`);\n }\n else if (!matchedRoute.matched.length) {\n warn(`No match found for location with path \"${rawLocation.path != null ? rawLocation.path : rawLocation}\"`);\n }\n }\n return assign({\n fullPath,\n // keep the hash encoded so fullPath is effectively path + encodedQuery +\n // hash\n hash,\n query: \n // if the user is using a custom query lib like qs, we might have\n // nested objects, so we keep the query as is, meaning it can contain\n // numbers at `$route.query`, but at the point, the user will have to\n // use their own type anyway.\n // https://github.com/vuejs/router/issues/328#issuecomment-649481567\n stringifyQuery$1 === stringifyQuery\n ? normalizeQuery(rawLocation.query)\n : (rawLocation.query || {}),\n }, matchedRoute, {\n redirectedFrom: undefined,\n href,\n });\n }\n function locationAsObject(to) {\n return typeof to === 'string'\n ? parseURL(parseQuery$1, to, currentRoute.value.path)\n : assign({}, to);\n }\n function checkCanceledNavigation(to, from) {\n if (pendingLocation !== to) {\n return createRouterError(8 /* ErrorTypes.NAVIGATION_CANCELLED */, {\n from,\n to,\n });\n }\n }\n function push(to) {\n return pushWithRedirect(to);\n }\n function replace(to) {\n return push(assign(locationAsObject(to), { replace: true }));\n }\n function handleRedirectRecord(to) {\n const lastMatched = to.matched[to.matched.length - 1];\n if (lastMatched && lastMatched.redirect) {\n const { redirect } = lastMatched;\n let newTargetLocation = typeof redirect === 'function' ? redirect(to) : redirect;\n if (typeof newTargetLocation === 'string') {\n newTargetLocation =\n newTargetLocation.includes('?') || newTargetLocation.includes('#')\n ? (newTargetLocation = locationAsObject(newTargetLocation))\n : // force empty params\n { path: newTargetLocation };\n // @ts-expect-error: force empty params when a string is passed to let\n // the router parse them again\n newTargetLocation.params = {};\n }\n if ((process.env.NODE_ENV !== 'production') &&\n newTargetLocation.path == null &&\n !('name' in newTargetLocation)) {\n warn(`Invalid redirect found:\\n${JSON.stringify(newTargetLocation, null, 2)}\\n when navigating to \"${to.fullPath}\". A redirect must contain a name or path. This will break in production.`);\n throw new Error('Invalid redirect');\n }\n return assign({\n query: to.query,\n hash: to.hash,\n // avoid transferring params if the redirect has a path\n params: newTargetLocation.path != null ? {} : to.params,\n }, newTargetLocation);\n }\n }\n function pushWithRedirect(to, redirectedFrom) {\n const targetLocation = (pendingLocation = resolve(to));\n const from = currentRoute.value;\n const data = to.state;\n const force = to.force;\n // to could be a string where `replace` is a function\n const replace = to.replace === true;\n const shouldRedirect = handleRedirectRecord(targetLocation);\n if (shouldRedirect)\n return pushWithRedirect(assign(locationAsObject(shouldRedirect), {\n state: typeof shouldRedirect === 'object'\n ? assign({}, data, shouldRedirect.state)\n : data,\n force,\n replace,\n }), \n // keep original redirectedFrom if it exists\n redirectedFrom || targetLocation);\n // if it was a redirect we already called `pushWithRedirect` above\n const toLocation = targetLocation;\n toLocation.redirectedFrom = redirectedFrom;\n let failure;\n if (!force && isSameRouteLocation(stringifyQuery$1, from, targetLocation)) {\n failure = createRouterError(16 /* ErrorTypes.NAVIGATION_DUPLICATED */, { to: toLocation, from });\n // trigger scroll to allow scrolling to the same anchor\n handleScroll(from, from, \n // this is a push, the only way for it to be triggered from a\n // history.listen is with a redirect, which makes it become a push\n true, \n // This cannot be the first navigation because the initial location\n // cannot be manually navigated to\n false);\n }\n return (failure ? Promise.resolve(failure) : navigate(toLocation, from))\n .catch((error) => isNavigationFailure(error)\n ? // navigation redirects still mark the router as ready\n isNavigationFailure(error, 2 /* ErrorTypes.NAVIGATION_GUARD_REDIRECT */)\n ? error\n : markAsReady(error) // also returns the error\n : // reject any unknown error\n triggerError(error, toLocation, from))\n .then((failure) => {\n if (failure) {\n if (isNavigationFailure(failure, 2 /* ErrorTypes.NAVIGATION_GUARD_REDIRECT */)) {\n if ((process.env.NODE_ENV !== 'production') &&\n // we are redirecting to the same location we were already at\n isSameRouteLocation(stringifyQuery$1, resolve(failure.to), toLocation) &&\n // and we have done it a couple of times\n redirectedFrom &&\n // @ts-expect-error: added only in dev\n (redirectedFrom._count = redirectedFrom._count\n ? // @ts-expect-error\n redirectedFrom._count + 1\n : 1) > 30) {\n warn(`Detected a possibly infinite redirection in a navigation guard when going from \"${from.fullPath}\" to \"${toLocation.fullPath}\". Aborting to avoid a Stack Overflow.\\n Are you always returning a new location within a navigation guard? That would lead to this error. Only return when redirecting or aborting, that should fix this. This might break in production if not fixed.`);\n return Promise.reject(new Error('Infinite redirect in navigation guard'));\n }\n return pushWithRedirect(\n // keep options\n assign({\n // preserve an existing replacement but allow the redirect to override it\n replace,\n }, locationAsObject(failure.to), {\n state: typeof failure.to === 'object'\n ? assign({}, data, failure.to.state)\n : data,\n force,\n }), \n // preserve the original redirectedFrom if any\n redirectedFrom || toLocation);\n }\n }\n else {\n // if we fail we don't finalize the navigation\n failure = finalizeNavigation(toLocation, from, true, replace, data);\n }\n triggerAfterEach(toLocation, from, failure);\n return failure;\n });\n }\n /**\n * Helper to reject and skip all navigation guards if a new navigation happened\n * @param to\n * @param from\n */\n function checkCanceledNavigationAndReject(to, from) {\n const error = checkCanceledNavigation(to, from);\n return error ? Promise.reject(error) : Promise.resolve();\n }\n function runWithContext(fn) {\n const app = installedApps.values().next().value;\n // support Vue < 3.3\n return app && typeof app.runWithContext === 'function'\n ? app.runWithContext(fn)\n : fn();\n }\n // TODO: refactor the whole before guards by internally using router.beforeEach\n function navigate(to, from) {\n let guards;\n const [leavingRecords, updatingRecords, enteringRecords] = extractChangingRecords(to, from);\n // all components here have been resolved once because we are leaving\n guards = extractComponentsGuards(leavingRecords.reverse(), 'beforeRouteLeave', to, from);\n // leavingRecords is already reversed\n for (const record of leavingRecords) {\n record.leaveGuards.forEach(guard => {\n guards.push(guardToPromiseFn(guard, to, from));\n });\n }\n const canceledNavigationCheck = checkCanceledNavigationAndReject.bind(null, to, from);\n guards.push(canceledNavigationCheck);\n // run the queue of per route beforeRouteLeave guards\n return (runGuardQueue(guards)\n .then(() => {\n // check global guards beforeEach\n guards = [];\n for (const guard of beforeGuards.list()) {\n guards.push(guardToPromiseFn(guard, to, from));\n }\n guards.push(canceledNavigationCheck);\n return runGuardQueue(guards);\n })\n .then(() => {\n // check in components beforeRouteUpdate\n guards = extractComponentsGuards(updatingRecords, 'beforeRouteUpdate', to, from);\n for (const record of updatingRecords) {\n record.updateGuards.forEach(guard => {\n guards.push(guardToPromiseFn(guard, to, from));\n });\n }\n guards.push(canceledNavigationCheck);\n // run the queue of per route beforeEnter guards\n return runGuardQueue(guards);\n })\n .then(() => {\n // check the route beforeEnter\n guards = [];\n for (const record of enteringRecords) {\n // do not trigger beforeEnter on reused views\n if (record.beforeEnter) {\n if (isArray(record.beforeEnter)) {\n for (const beforeEnter of record.beforeEnter)\n guards.push(guardToPromiseFn(beforeEnter, to, from));\n }\n else {\n guards.push(guardToPromiseFn(record.beforeEnter, to, from));\n }\n }\n }\n guards.push(canceledNavigationCheck);\n // run the queue of per route beforeEnter guards\n return runGuardQueue(guards);\n })\n .then(() => {\n // NOTE: at this point to.matched is normalized and does not contain any () => Promise<Component>\n // clear existing enterCallbacks, these are added by extractComponentsGuards\n to.matched.forEach(record => (record.enterCallbacks = {}));\n // check in-component beforeRouteEnter\n guards = extractComponentsGuards(enteringRecords, 'beforeRouteEnter', to, from, runWithContext);\n guards.push(canceledNavigationCheck);\n // run the queue of per route beforeEnter guards\n return runGuardQueue(guards);\n })\n .then(() => {\n // check global guards beforeResolve\n guards = [];\n for (const guard of beforeResolveGuards.list()) {\n guards.push(guardToPromiseFn(guard, to, from));\n }\n guards.push(canceledNavigationCheck);\n return runGuardQueue(guards);\n })\n // catch any navigation canceled\n .catch(err => isNavigationFailure(err, 8 /* ErrorTypes.NAVIGATION_CANCELLED */)\n ? err\n : Promise.reject(err)));\n }\n function triggerAfterEach(to, from, failure) {\n // navigation is confirmed, call afterGuards\n // TODO: wrap with error handlers\n afterGuards\n .list()\n .forEach(guard => runWithContext(() => guard(to, from, failure)));\n }\n /**\n * - Cleans up any navigation guards\n * - Changes the url if necessary\n * - Calls the scrollBehavior\n */\n function finalizeNavigation(toLocation, from, isPush, replace, data) {\n // a more recent navigation took place\n const error = checkCanceledNavigation(toLocation, from);\n if (error)\n return error;\n // only consider as push if it's not the first navigation\n const isFirstNavigation = from === START_LOCATION_NORMALIZED;\n const state = !isBrowser ? {} : history.state;\n // change URL only if the user did a push/replace and if it's not the initial navigation because\n // it's just reflecting the url\n if (isPush) {\n // on the initial navigation, we want to reuse the scroll position from\n // history state if it exists\n if (replace || isFirstNavigation)\n routerHistory.replace(toLocation.fullPath, assign({\n scroll: isFirstNavigation && state && state.scroll,\n }, data));\n else\n routerHistory.push(toLocation.fullPath, data);\n }\n // accept current navigation\n currentRoute.value = toLocation;\n handleScroll(toLocation, from, isPush, isFirstNavigation);\n markAsReady();\n }\n let removeHistoryListener;\n // attach listener to history to trigger navigations\n function setupListeners() {\n // avoid setting up listeners twice due to an invalid first navigation\n if (removeHistoryListener)\n return;\n removeHistoryListener = routerHistory.listen((to, _from, info) => {\n if (!router.listening)\n return;\n // cannot be a redirect route because it was in history\n const toLocation = resolve(to);\n // due to dynamic routing, and to hash history with manual navigation\n // (manually changing the url or calling history.hash = '#/somewhere'),\n // there could be a redirect record in history\n const shouldRedirect = handleRedirectRecord(toLocation);\n if (shouldRedirect) {\n pushWithRedirect(assign(shouldRedirect, { replace: true, force: true }), toLocation).catch(noop);\n return;\n }\n pendingLocation = toLocation;\n const from = currentRoute.value;\n // TODO: should be moved to web history?\n if (isBrowser) {\n saveScrollPosition(getScrollKey(from.fullPath, info.delta), computeScrollPosition());\n }\n navigate(toLocation, from)\n .catch((error) => {\n if (isNavigationFailure(error, 4 /* ErrorTypes.NAVIGATION_ABORTED */ | 8 /* ErrorTypes.NAVIGATION_CANCELLED */)) {\n return error;\n }\n if (isNavigationFailure(error, 2 /* ErrorTypes.NAVIGATION_GUARD_REDIRECT */)) {\n // Here we could call if (info.delta) routerHistory.go(-info.delta,\n // false) but this is bug prone as we have no way to wait the\n // navigation to be finished before calling pushWithRedirect. Using\n // a setTimeout of 16ms seems to work but there is no guarantee for\n // it to work on every browser. So instead we do not restore the\n // history entry and trigger a new navigation as requested by the\n // navigation guard.\n // the error is already handled by router.push we just want to avoid\n // logging the error\n pushWithRedirect(assign(locationAsObject(error.to), {\n force: true,\n }), toLocation\n // avoid an uncaught rejection, let push call triggerError\n )\n .then(failure => {\n // manual change in hash history #916 ending up in the URL not\n // changing, but it was changed by the manual url change, so we\n // need to manually change it ourselves\n if (isNavigationFailure(failure, 4 /* ErrorTypes.NAVIGATION_ABORTED */ |\n 16 /* ErrorTypes.NAVIGATION_DUPLICATED */) &&\n !info.delta &&\n info.type === NavigationType.pop) {\n routerHistory.go(-1, false);\n }\n })\n .catch(noop);\n // avoid the then branch\n return Promise.reject();\n }\n // do not restore history on unknown direction\n if (info.delta) {\n routerHistory.go(-info.delta, false);\n }\n // unrecognized error, transfer to the global handler\n return triggerError(error, toLocation, from);\n })\n .then((failure) => {\n failure =\n failure ||\n finalizeNavigation(\n // after navigation, all matched components are resolved\n toLocation, from, false);\n // revert the navigation\n if (failure) {\n if (info.delta &&\n // a new navigation has been triggered, so we do not want to revert, that will change the current history\n // entry while a different route is displayed\n !isNavigationFailure(failure, 8 /* ErrorTypes.NAVIGATION_CANCELLED */)) {\n routerHistory.go(-info.delta, false);\n }\n else if (info.type === NavigationType.pop &&\n isNavigationFailure(failure, 4 /* ErrorTypes.NAVIGATION_ABORTED */ | 16 /* ErrorTypes.NAVIGATION_DUPLICATED */)) {\n // manual change in hash history #916\n // it's like a push but lacks the information of the direction\n routerHistory.go(-1, false);\n }\n }\n triggerAfterEach(toLocation, from, failure);\n })\n // avoid warnings in the console about uncaught rejections, they are logged by triggerErrors\n .catch(noop);\n });\n }\n // Initialization and Errors\n let readyHandlers = useCallbacks();\n let errorListeners = useCallbacks();\n let ready;\n /**\n * Trigger errorListeners added via onError and throws the error as well\n *\n * @param error - error to throw\n * @param to - location we were navigating to when the error happened\n * @param from - location we were navigating from when the error happened\n * @returns the error as a rejected promise\n */\n function triggerError(error, to, from) {\n markAsReady(error);\n const list = errorListeners.list();\n if (list.length) {\n list.forEach(handler => handler(error, to, from));\n }\n else {\n if ((process.env.NODE_ENV !== 'production')) {\n warn('uncaught error during route navigation:');\n }\n console.error(error);\n }\n // reject the error no matter there were error listeners or not\n return Promise.reject(error);\n }\n function isReady() {\n if (ready && currentRoute.value !== START_LOCATION_NORMALIZED)\n return Promise.resolve();\n return new Promise((resolve, reject) => {\n readyHandlers.add([resolve, reject]);\n });\n }\n function markAsReady(err) {\n if (!ready) {\n // still not ready if an error happened\n ready = !err;\n setupListeners();\n readyHandlers\n .list()\n .forEach(([resolve, reject]) => (err ? reject(err) : resolve()));\n readyHandlers.reset();\n }\n return err;\n }\n // Scroll behavior\n function handleScroll(to, from, isPush, isFirstNavigation) {\n const { scrollBehavior } = options;\n if (!isBrowser || !scrollBehavior)\n return Promise.resolve();\n const scrollPosition = (!isPush && getSavedScrollPosition(getScrollKey(to.fullPath, 0))) ||\n ((isFirstNavigation || !isPush) &&\n history.state &&\n history.state.scroll) ||\n null;\n return nextTick()\n .then(() => scrollBehavior(to, from, scrollPosition))\n .then(position => position && scrollToPosition(position))\n .catch(err => triggerError(err, to, from));\n }\n const go = (delta) => routerHistory.go(delta);\n let started;\n const installedApps = new Set();\n const router = {\n currentRoute,\n listening: true,\n addRoute,\n removeRoute,\n clearRoutes: matcher.clearRoutes,\n hasRoute,\n getRoutes,\n resolve,\n options,\n push,\n replace,\n go,\n back: () => go(-1),\n forward: () => go(1),\n beforeEach: beforeGuards.add,\n beforeResolve: beforeResolveGuards.add,\n afterEach: afterGuards.add,\n onError: errorListeners.add,\n isReady,\n install(app) {\n const router = this;\n app.component('RouterLink', RouterLink);\n app.component('RouterView', RouterView);\n app.config.globalProperties.$router = router;\n Object.defineProperty(app.config.globalProperties, '$route', {\n enumerable: true,\n get: () => unref(currentRoute),\n });\n // this initial navigation is only necessary on client, on server it doesn't\n // make sense because it will create an extra unnecessary navigation and could\n // lead to problems\n if (isBrowser &&\n // used for the initial navigation client side to avoid pushing\n // multiple times when the router is used in multiple apps\n !started &&\n currentRoute.value === START_LOCATION_NORMALIZED) {\n // see above\n started = true;\n push(routerHistory.location).catch(err => {\n if ((process.env.NODE_ENV !== 'production'))\n warn('Unexpected error when starting the router:', err);\n });\n }\n const reactiveRoute = {};\n for (const key in START_LOCATION_NORMALIZED) {\n Object.defineProperty(reactiveRoute, key, {\n get: () => currentRoute.value[key],\n enumerable: true,\n });\n }\n app.provide(routerKey, router);\n app.provide(routeLocationKey, shallowReactive(reactiveRoute));\n app.provide(routerViewLocationKey, currentRoute);\n const unmountApp = app.unmount;\n installedApps.add(app);\n app.unmount = function () {\n installedApps.delete(app);\n // the router is not attached to an app anymore\n if (installedApps.size < 1) {\n // invalidate the current navigation\n pendingLocation = START_LOCATION_NORMALIZED;\n removeHistoryListener && removeHistoryListener();\n removeHistoryListener = null;\n currentRoute.value = START_LOCATION_NORMALIZED;\n started = false;\n ready = false;\n }\n unmountApp();\n };\n // TODO: this probably needs to be updated so it can be used by vue-termui\n if (((process.env.NODE_ENV !== 'production') || __VUE_PROD_DEVTOOLS__) && isBrowser) {\n addDevtools(app, router, matcher);\n }\n },\n };\n // TODO: type this as NavigationGuardReturn or similar instead of any\n function runGuardQueue(guards) {\n return guards.reduce((promise, guard) => promise.then(() => runWithContext(guard)), Promise.resolve());\n }\n return router;\n}\nfunction extractChangingRecords(to, from) {\n const leavingRecords = [];\n const updatingRecords = [];\n const enteringRecords = [];\n const len = Math.max(from.matched.length, to.matched.length);\n for (let i = 0; i < len; i++) {\n const recordFrom = from.matched[i];\n if (recordFrom) {\n if (to.matched.find(record => isSameRouteRecord(record, recordFrom)))\n updatingRecords.push(recordFrom);\n else\n leavingRecords.push(recordFrom);\n }\n const recordTo = to.matched[i];\n if (recordTo) {\n // the type doesn't matter because we are comparing per reference\n if (!from.matched.find(record => isSameRouteRecord(record, recordTo))) {\n enteringRecords.push(recordTo);\n }\n }\n }\n return [leavingRecords, updatingRecords, enteringRecords];\n}\n\n/**\n * Returns the router instance. Equivalent to using `$router` inside\n * templates.\n */\nfunction useRouter() {\n return inject(routerKey);\n}\n/**\n * Returns the current route location. Equivalent to using `$route` inside\n * templates.\n */\nfunction useRoute(_name) {\n return inject(routeLocationKey);\n}\n\nexport { NavigationFailureType, RouterLink, RouterView, START_LOCATION_NORMALIZED as START_LOCATION, createMemoryHistory, createRouter, createRouterMatcher, createWebHashHistory, createWebHistory, isNavigationFailure, loadRouteLocation, matchedRouteKey, onBeforeRouteLeave, onBeforeRouteUpdate, parseQuery, routeLocationKey, routerKey, routerViewLocationKey, stringifyQuery, useLink, useRoute, useRouter, viewDepthKey };\n","import { TBinding, bindableTools } from \"@/shared/configTypes/vars\";\r\nimport * as TConfigEventTypes from \"@/shared/configTypes/event\";\r\nimport { getVueRef, createScopeSnapshot } from \"@/shared/varStore\";\r\nimport * as slotStore from \"@/shared/slotStore\";\r\n\r\nimport { Ref, toValue } from \"vue\";\r\nimport * as vforManager from \"@/shared/vforManager\";\r\nimport { TUpdateRefFromServerResponse } from \"./configTypes/server\";\r\nimport * as jsStrVar from \"@/shared/jsStrVar\";\r\nimport * as vueSystem from \"@/systems/vueSystem\";\r\nimport * as objectSystem from \"@/systems/objectSystem\";\r\nimport * as valueSystem from \"@/systems/valueSystem\";\r\nimport * as elementRefStore from \"@/shared/elementRefStore\";\r\nimport * as jsCodeSystem from \"@/systems/jsCodeSystem\";\r\nimport { useRoute, useRouter } from \"vue-router\";\r\n\r\nexport type TSnapshot = ReturnType<typeof createSnapshot>;\r\n\r\nexport function createSnapshot(vforKey?: any) {\r\n let scopeSnapshot = createScopeSnapshot();\r\n let slotSnapshot = slotStore.createSnapshot();\r\n let vforSnapshot = vforManager.createVForSnapshot(vforKey);\r\n let elementRefSnapshot = elementRefStore.createElementRefSnapshot();\r\n let routerSnapshot = useRouter();\r\n let routeSnapshot = useRoute();\r\n\r\n function replaceSnapshot(target: {\r\n scopeSnapshot?: ReturnType<typeof createScopeSnapshot>;\r\n slotSnapshot?: ReturnType<typeof slotStore.createSnapshot>;\r\n vforSnapshot?: ReturnType<typeof vforManager.createVForSnapshot>;\r\n elementRefSnapshot?: ReturnType<\r\n typeof elementRefStore.createElementRefSnapshot\r\n >;\r\n routerSnapshot?: ReturnType<typeof useRouter>;\r\n }) {\r\n if (target.scopeSnapshot) {\r\n scopeSnapshot = target.scopeSnapshot;\r\n }\r\n\r\n if (target.slotSnapshot) {\r\n slotSnapshot = target.slotSnapshot;\r\n }\r\n\r\n if (target.vforSnapshot) {\r\n vforSnapshot = target.vforSnapshot;\r\n }\r\n\r\n if (target.elementRefSnapshot) {\r\n elementRefSnapshot = target.elementRefSnapshot;\r\n }\r\n\r\n if (target.routerSnapshot) {\r\n routerSnapshot = target.routerSnapshot;\r\n }\r\n }\r\n\r\n function getObjectToValue(binding: TBinding): any {\r\n if (bindableTools.isVar(binding)) {\r\n return toValue(getVueRefObject(binding));\r\n }\r\n\r\n if (bindableTools.isVForItem(binding)) {\r\n if (vforManager.isVForLoopNumber(binding.fid)) {\r\n return vforSnapshot.getVForIndex(binding.fid);\r\n }\r\n\r\n return toValue(getVueRefObject(binding));\r\n }\r\n\r\n if (bindableTools.isVForIndex(binding)) {\r\n return vforSnapshot.getVForIndex(binding.fid);\r\n }\r\n\r\n if (bindableTools.isJs(binding)) {\r\n const { code, bind } = binding;\r\n\r\n const fnBindings = objectSystem.mapObjectForValue(bind, (val) => {\r\n return getVueRefObjectOrValue(val);\r\n });\r\n\r\n return jsStrVar.createFn(code, fnBindings)();\r\n }\r\n\r\n if (bindableTools.isSlotProp(binding)) {\r\n return slotSnapshot.getPropsValue(binding);\r\n }\r\n\r\n if (bindableTools.isRouterParams(binding)) {\r\n return toValue(getVueRefObject(binding));\r\n }\r\n\r\n throw new Error(`Invalid binding: ${binding}`);\r\n }\r\n\r\n function getVueRefObject(binding: TBinding) {\r\n if (bindableTools.isVar(binding)) {\r\n const vueObj = scopeSnapshot.getVueRef(binding) || getVueRef(binding);\r\n return vueSystem.makeRefObjectWithPaths(vueObj, {\r\n paths: binding.path,\r\n getBindableValueFn: getObjectToValue,\r\n });\r\n }\r\n\r\n if (bindableTools.isVForItem(binding)) {\r\n return vforManager.createRefObjectWithPaths({\r\n binding,\r\n snapshot: self,\r\n });\r\n }\r\n\r\n if (bindableTools.isVForIndex(binding)) {\r\n return () => getObjectToValue(binding);\r\n }\r\n\r\n if (bindableTools.isRouterParams(binding)) {\r\n const { prop = \"params\" } = binding;\r\n\r\n return vueSystem.makeRefObjectWithPaths(() => routeSnapshot[prop], {\r\n paths: binding.path,\r\n getBindableValueFn: getObjectToValue,\r\n });\r\n }\r\n\r\n throw new Error(`Invalid binding: ${binding}`);\r\n }\r\n\r\n function getVueRefObjectOrValue(binding: TBinding) {\r\n if (bindableTools.isVar(binding)) {\r\n return getVueRefObject(binding);\r\n }\r\n\r\n if (bindableTools.isVForItem(binding)) {\r\n return getVueRefObject(binding);\r\n }\r\n\r\n if (bindableTools.isVForIndex(binding)) {\r\n return getObjectToValue(binding);\r\n }\r\n\r\n if (bindableTools.isJs(binding)) {\r\n return null;\r\n }\r\n\r\n if (bindableTools.isRouterParams(binding)) {\r\n return getVueRefObject(binding);\r\n }\r\n\r\n throw new Error(`Invalid binding: ${binding}`);\r\n }\r\n\r\n function getBindingServerInfo(binding: TBinding) {\r\n if (bindableTools.isVar(binding)) {\r\n return {\r\n sid: binding.sid,\r\n id: binding.id,\r\n };\r\n }\r\n\r\n if (bindableTools.isVForItem(binding)) {\r\n return {\r\n type: \"vf\",\r\n fid: binding.fid,\r\n };\r\n }\r\n\r\n if (bindableTools.isVForIndex(binding)) {\r\n return {\r\n type: \"vf-i\",\r\n fid: binding.fid,\r\n value: null,\r\n };\r\n }\r\n\r\n if (bindableTools.isJs(binding)) {\r\n return null;\r\n }\r\n }\r\n\r\n function updateRefFromServer(infos: TUpdateRefFromServerResponse) {\r\n // TODO\r\n\r\n infos.vars?.forEach((info) => {\r\n (getVueRefObject({ type: \"var\", ...info }) as Ref).value = info.val;\r\n });\r\n\r\n infos.ele_refs?.forEach((info) => {\r\n const elementObj = elementRefSnapshot.getRef({\r\n sid: info.sid,\r\n id: info.id,\r\n }).value;\r\n\r\n elementObj[info.method](...info.args);\r\n });\r\n }\r\n\r\n function updateOutputsRefFromServer(\r\n data: TConfigEventTypes.TEventServerResponse,\r\n outputs: TConfigEventTypes.TWebEventHandler[\"set\"]\r\n ) {\r\n if (\r\n valueSystem.isNullOrUndefined(outputs) ||\r\n valueSystem.isNullOrUndefined(data.values)\r\n ) {\r\n return;\r\n }\r\n\r\n outputs = outputs!;\r\n\r\n const values = data.values!;\r\n const skips = data.skips || new Array(outputs.length).fill(0);\r\n\r\n outputs!.forEach((output, index) => {\r\n if (skips[index] === 1) {\r\n return;\r\n }\r\n\r\n if (bindableTools.isVar(output)) {\r\n const refObj = getVueRefObject(output) as Ref;\r\n refObj.value = values[index];\r\n return;\r\n }\r\n\r\n if (bindableTools.isRouterAction(output)) {\r\n const info = values[index] as {\r\n fn: string;\r\n args: any[];\r\n };\r\n const routerMethod = (routerSnapshot as any)[info.fn] as Function;\r\n routerMethod(...info.args);\r\n\r\n return;\r\n }\r\n\r\n if (bindableTools.isElementRef(output)) {\r\n const elementObj = elementRefSnapshot.getRef(output).value;\r\n const value = values[index] as TConfigEventTypes.TElementRefValue;\r\n const { method, args = [] } = value;\r\n\r\n elementObj[method](...args);\r\n return;\r\n }\r\n\r\n if (bindableTools.isJsOutput(output)) {\r\n const code = values[index] as string;\r\n const fnOrValue = jsCodeSystem.createFnFromString(code);\r\n if (typeof fnOrValue === \"function\") {\r\n fnOrValue();\r\n }\r\n\r\n return;\r\n }\r\n\r\n const refObj = getVueRefObject(output) as Ref;\r\n refObj.value = values[index];\r\n });\r\n }\r\n\r\n const self = {\r\n getVForIndex: vforSnapshot.getVForIndex,\r\n getObjectToValue,\r\n getVueRefObject,\r\n getVueRefObjectOrValue,\r\n getBindingServerInfo,\r\n updateRefFromServer,\r\n updateOutputsRefFromServer,\r\n replaceSnapshot,\r\n };\r\n\r\n return self;\r\n}\r\n","import {\r\n TEventServerResponse,\r\n TWebEventHandler,\r\n} from \"@/shared/configTypes/event\";\r\nimport { type WatchTask } from \"@/shared/webWatchStore\";\r\nimport * as appInfo from \"@/shared/appInfo\";\r\nimport { IDataSender } from \"./base\";\r\n\r\nexport class WebDataSender implements IDataSender {\r\n public async eventSend(\r\n info: TWebEventHandler,\r\n bindings: any[]\r\n ): Promise<TEventServerResponse | null> {\r\n const { fType: eventType, hKey, key: componentKey } = info;\r\n\r\n const webServerInfo = appInfo.getInfo().webServerInfo!;\r\n const keyObj = componentKey !== undefined ? { key: componentKey } : {};\r\n\r\n const url =\r\n eventType === \"sync\"\r\n ? webServerInfo.event_url\r\n : webServerInfo.event_async_url;\r\n\r\n let eProps = {} as Record<string, any>;\r\n\r\n const response = await fetch(url, {\r\n method: \"POST\",\r\n headers: {\r\n \"Content-Type\": \"application/json\",\r\n },\r\n body: JSON.stringify({\r\n bind: bindings,\r\n hKey,\r\n ...keyObj,\r\n page: appInfo.getPageInfoPostData(),\r\n ...eProps,\r\n }),\r\n });\r\n\r\n if (!response.ok) {\r\n throw new Error(`HTTP error! status: ${response.status}`);\r\n }\r\n return (await response.json()) as TEventServerResponse;\r\n }\r\n\r\n public async watchSend(\r\n watchTask: WatchTask\r\n ): Promise<TEventServerResponse | null> {\r\n const { outputs, fType: watchType, key } = watchTask.watchConfig;\r\n\r\n const webServerInfo = appInfo.getInfo().webServerInfo!;\r\n\r\n const url =\r\n watchType === \"sync\"\r\n ? webServerInfo.watch_url\r\n : webServerInfo.watch_async_url;\r\n const inputValues = watchTask.getServerInputs();\r\n\r\n const body = {\r\n key,\r\n input: inputValues,\r\n page: appInfo.getPageInfoPostData(),\r\n };\r\n\r\n const response = await fetch(url, {\r\n method: \"POST\",\r\n headers: {\r\n \"Content-Type\": \"application/json\",\r\n },\r\n body: JSON.stringify(body),\r\n });\r\n\r\n return (await response.json()) as TEventServerResponse;\r\n }\r\n}\r\n","import {\r\n TEventServerResponse,\r\n TWebEventHandler,\r\n} from \"@/shared/configTypes/event\";\r\nimport { type WatchTask } from \"@/shared/webWatchStore\";\r\nimport * as appInfo from \"@/shared/appInfo\";\r\nimport { IDataSender } from \"./base\";\r\n\r\nexport class WebViewDataSender implements IDataSender {\r\n public async eventSend(\r\n info: TWebEventHandler,\r\n bindings: any[]\r\n ): Promise<TEventServerResponse | null> {\r\n const { fType, hKey, key: componentKey } = info;\r\n\r\n const keyObj = componentKey !== undefined ? { key: componentKey } : {};\r\n\r\n let eProps = {} as Record<string, any>;\r\n\r\n const eventInfo = {\r\n bind: bindings,\r\n fType,\r\n hKey,\r\n ...keyObj,\r\n page: appInfo.getPageInfoPostData(),\r\n ...eProps,\r\n };\r\n\r\n return await (window as any).pywebview.api.event_call(eventInfo);\r\n }\r\n\r\n public async watchSend(\r\n watchTask: WatchTask\r\n ): Promise<TEventServerResponse | null> {\r\n const { outputs, fType, key } = watchTask.watchConfig;\r\n\r\n const inputValues = watchTask.getServerInputs();\r\n\r\n const body = {\r\n key,\r\n input: inputValues,\r\n fType,\r\n page: appInfo.getPageInfoPostData(),\r\n };\r\n\r\n return await (window as any).pywebview.api.watch_call(body);\r\n }\r\n}\r\n","import { TAppConfig } from \"@/shared/configTypes\";\r\nimport { IDataSender } from \"./base\";\r\nimport { WebDataSender } from \"./webSender\";\r\nimport { WebViewDataSender } from \"./webviewSender\";\r\n\r\nlet currentDataSender: IDataSender;\r\n\r\nexport function setupDataSender(app: TAppConfig) {\r\n switch (app.mode) {\r\n case \"web\":\r\n currentDataSender = new WebDataSender();\r\n break;\r\n\r\n case \"webview\":\r\n currentDataSender = new WebViewDataSender();\r\n break;\r\n\r\n case \"zero\":\r\n break;\r\n\r\n default:\r\n break;\r\n }\r\n}\r\n\r\nexport function getDataSender() {\r\n return currentDataSender;\r\n}\r\n\r\nexport { type IDataSender } from \"./base\";\r\nexport { WebDataSender } from \"./webSender\";\r\n","import { TBindableVar } from \"@/shared/configTypes\";\r\nimport { TWebComputedConfig } from \"@/shared/configTypes/webComputed\";\r\nimport { TWebWatchConfig } from \"@/shared/configTypes/webWatch\";\r\n\r\nexport function toWatchConfig(\r\n computedConfig: TWebComputedConfig\r\n): TWebWatchConfig {\r\n const output = {\r\n type: \"var\",\r\n sid: computedConfig.sid,\r\n id: computedConfig.id,\r\n } as TBindableVar;\r\n\r\n return {\r\n ...computedConfig,\r\n immediate: true,\r\n outputs: [output, ...(computedConfig.outputs || [])],\r\n } as TWebWatchConfig;\r\n}\r\n","import { nextTick, Ref, watch } from \"vue\";\r\n\r\nimport { TScope } from \"@/shared/configTypes\";\r\nimport { TWebWatchConfig } from \"@/shared/configTypes/webWatch\";\r\nimport { TSnapshot } from \"@/shared/bindableHelper\";\r\nimport { defaultMap } from \"@/systems/mapSystem\";\r\nimport { bindableTools } from \"./configTypes\";\r\nimport { getDataSender } from \"@/shared/dataSender\";\r\nimport * as webComputed from \"@/shared/webComputed\";\r\nimport * as computedInit from \"@/shared/computedInit\";\r\n\r\nexport function setupWebWatchStore(\r\n watchConfig: TScope[\"py_watch\"],\r\n computedConfig: TScope[\"web_computed\"],\r\n snapshots: TSnapshot\r\n) {\r\n return new WebWatchManager(watchConfig, computedConfig, snapshots);\r\n}\r\n\r\nclass WebWatchManager {\r\n private taskQueue: TaskNode[] = [];\r\n\r\n private id2TaskMap: Map<symbol, WatchTask> = new Map();\r\n private input2TaskIdMap = defaultMap<string, symbol[]>(() => []);\r\n\r\n constructor(\r\n watchConfig: TScope[\"py_watch\"],\r\n computedConfig: TScope[\"web_computed\"],\r\n private snapshots: TSnapshot\r\n ) {\r\n const watchTasks: WatchTask[] = [];\r\n\r\n const createWatchTaskFn = (config: TWebWatchConfig) => {\r\n const watchTask = new WatchTask(config, snapshots);\r\n this.id2TaskMap.set(watchTask.id, watchTask);\r\n\r\n config.inputs?.forEach((input, index) => {\r\n const isBinding =\r\n config.data?.[index] === 0 && config.slient?.[index] === 0;\r\n if (isBinding) {\r\n const key = `${input.sid}-${input.id}`;\r\n this.input2TaskIdMap.getOrDefault(key).push(watchTask.id);\r\n }\r\n });\r\n\r\n return watchTask;\r\n };\r\n\r\n watchConfig?.forEach((config) => {\r\n const watchTask = createWatchTaskFn(config);\r\n watchTasks.push(watchTask);\r\n });\r\n\r\n computedConfig?.forEach((computedConfig) => {\r\n const watchTask = createWatchTaskFn(\r\n webComputed.toWatchConfig(computedConfig)\r\n );\r\n watchTasks.push(watchTask);\r\n });\r\n\r\n // build vue watchers\r\n watchTasks.forEach((watchTask) => {\r\n const {\r\n deep = true,\r\n once,\r\n flush,\r\n immediate = true,\r\n } = watchTask.watchConfig;\r\n\r\n const watchOption = {\r\n immediate: immediate,\r\n deep,\r\n once,\r\n flush,\r\n };\r\n\r\n const watchTargets = this._getWatchTargets(watchTask);\r\n watch(\r\n watchTargets,\r\n (values) => {\r\n // console.log(\"watch triggered\", watchTask.watchConfig.debug, values);\r\n\r\n if (values.some(computedInit.isInitial)) {\r\n return;\r\n }\r\n // console.log(\"run task\", watchTask.watchConfig.debug);\r\n\r\n watchTask.modify = true;\r\n this.taskQueue.push(new TaskNode(watchTask));\r\n this._scheduleNextTick();\r\n },\r\n watchOption\r\n );\r\n });\r\n }\r\n\r\n private _getWatchTargets(watchTask: WatchTask) {\r\n if (!watchTask.watchConfig.inputs) {\r\n return [];\r\n }\r\n\r\n const slients = watchTask.slientInputs;\r\n const constDatas = watchTask.constDataInputs;\r\n const inputs = watchTask.watchConfig.inputs.filter(\r\n (input, index) =>\r\n !constDatas[index] &&\r\n (bindableTools.isVar(input) ||\r\n bindableTools.isVForItem(input) ||\r\n bindableTools.isRouterParams(input)) &&\r\n !slients[index]\r\n );\r\n\r\n return inputs.map((input) => this.snapshots.getVueRefObjectOrValue(input));\r\n }\r\n\r\n private _scheduleNextTick() {\r\n nextTick(() => this._runAllTasks());\r\n }\r\n\r\n private _runAllTasks() {\r\n const tasks = this.taskQueue.slice();\r\n this.taskQueue.length = 0;\r\n\r\n this._setTaskNodeRelations(tasks);\r\n\r\n tasks.forEach((task) => {\r\n task.run();\r\n });\r\n }\r\n\r\n private _setTaskNodeRelations(tasks: TaskNode[]) {\r\n tasks.forEach((task) => {\r\n const nextNodes = this._findNextNodes(task, tasks);\r\n\r\n task.appendNextNodes(...nextNodes);\r\n\r\n nextNodes.forEach((nextNode) => {\r\n nextNode.appendPrevNodes(task);\r\n });\r\n });\r\n }\r\n\r\n private _findNextNodes(target: TaskNode, others: TaskNode[]) {\r\n const outputs = target.watchTask.watchConfig.outputs;\r\n\r\n if (outputs && outputs.length <= 0) {\r\n return [];\r\n }\r\n\r\n const taskIdsOfOutput = this._getCalculatorTasksByOutput(\r\n target.watchTask.watchConfig.outputs\r\n );\r\n\r\n return others.filter(\r\n (task) =>\r\n taskIdsOfOutput.has(task.watchTask.id) &&\r\n task.watchTask.id !== target.watchTask.id\r\n );\r\n }\r\n\r\n private _getCalculatorTasksByOutput(outputs: TWebWatchConfig[\"outputs\"]) {\r\n const resultIds: Set<symbol> = new Set();\r\n\r\n outputs?.forEach((output) => {\r\n const key = `${output.sid}-${output.id}`;\r\n const ids = this.input2TaskIdMap.get(key) || [];\r\n ids.forEach((id) => resultIds.add(id));\r\n });\r\n\r\n return resultIds;\r\n }\r\n}\r\n\r\nexport class WatchTask {\r\n public modify = true;\r\n private _running = false;\r\n public readonly id: symbol;\r\n private _runningPromise: Promise<void> | null = null;\r\n private _runningPromiseResolve: ((value: void) => void) | null = null;\r\n private _inputInfos: {\r\n const_data: (1 | 0)[];\r\n slients: (1 | 0)[];\r\n };\r\n\r\n constructor(\r\n public readonly watchConfig: TWebWatchConfig,\r\n public readonly snapshot: TSnapshot\r\n ) {\r\n this.id = Symbol(watchConfig.debug);\r\n this._inputInfos = this.createInputInfos();\r\n }\r\n\r\n private createInputInfos() {\r\n const { inputs = [] } = this.watchConfig;\r\n\r\n const constDatas =\r\n this.watchConfig.data || new Array(inputs.length).fill(0);\r\n\r\n const slients = this.watchConfig.slient || new Array(inputs.length).fill(0);\r\n\r\n return {\r\n const_data: constDatas,\r\n slients,\r\n };\r\n }\r\n\r\n public get slientInputs() {\r\n return this._inputInfos.slients;\r\n }\r\n\r\n public get constDataInputs() {\r\n return this._inputInfos.const_data;\r\n }\r\n\r\n public getServerInputs() {\r\n const { const_data } = this._inputInfos;\r\n\r\n if (!this.watchConfig.inputs) {\r\n return [];\r\n }\r\n\r\n return this.watchConfig.inputs.map((input, index) => {\r\n if (const_data[index] === 0) {\r\n return this.snapshot.getObjectToValue(input);\r\n }\r\n\r\n return input;\r\n });\r\n }\r\n\r\n public get running(): boolean {\r\n return this._running;\r\n }\r\n\r\n public get runningPromise() {\r\n return this._runningPromise;\r\n }\r\n\r\n /**\r\n * setRunning\r\n */\r\n public setRunning() {\r\n this._running = true;\r\n this._runningPromise = new Promise((resolve) => {\r\n this._runningPromiseResolve = resolve;\r\n });\r\n\r\n this._trySetRunningRef(true);\r\n }\r\n\r\n /**\r\n * taskDone\r\n */\r\n public taskDone() {\r\n this._running = false;\r\n if (this._runningPromiseResolve) {\r\n this._runningPromiseResolve();\r\n this._runningPromiseResolve = null;\r\n }\r\n\r\n this._trySetRunningRef(false);\r\n }\r\n\r\n private _trySetRunningRef(value: boolean) {\r\n if (this.watchConfig.running) {\r\n const vueRef = this.snapshot.getVueRefObject(\r\n this.watchConfig.running\r\n ) as Ref;\r\n vueRef.value = value;\r\n }\r\n }\r\n}\r\n\r\nclass TaskNode {\r\n private prevNodes: TaskNode[] = [];\r\n private nextNodes: TaskNode[] = [];\r\n private _runningPrev = false;\r\n\r\n /**\r\n *\r\n */\r\n constructor(public readonly watchTask: WatchTask) {}\r\n\r\n /**\r\n * appendPrevNodes\r\n */\r\n public appendPrevNodes(...nodes: TaskNode[]) {\r\n this.prevNodes.push(...nodes);\r\n }\r\n\r\n /**\r\n *\r\n */\r\n public appendNextNodes(...nodes: TaskNode[]) {\r\n this.nextNodes.push(...nodes);\r\n }\r\n\r\n /**\r\n * hasNextNodes\r\n */\r\n public hasNextNodes() {\r\n return this.nextNodes.length > 0;\r\n }\r\n\r\n /**\r\n * run\r\n */\r\n public async run() {\r\n if (this.prevNodes.length > 0 && !this._runningPrev) {\r\n try {\r\n this._runningPrev = true;\r\n await Promise.all(this.prevNodes.map((node) => node.run()));\r\n } finally {\r\n this._runningPrev = false;\r\n }\r\n }\r\n\r\n if (this.watchTask.running) {\r\n await this.watchTask.runningPromise;\r\n return;\r\n }\r\n\r\n if (!this.watchTask.modify) {\r\n return;\r\n }\r\n\r\n this.watchTask.modify = false;\r\n this.watchTask.setRunning();\r\n\r\n try {\r\n await fetch2server(this.watchTask);\r\n } finally {\r\n this.watchTask.taskDone();\r\n }\r\n }\r\n}\r\n\r\nasync function fetch2server(calcTask: WatchTask) {\r\n const { snapshot } = calcTask;\r\n const { outputs } = calcTask.watchConfig;\r\n\r\n // console.log(\"fetch2server\", calcTask.watchConfig.debug);\r\n\r\n const responseData = await getDataSender().watchSend(calcTask);\r\n if (!responseData) {\r\n return;\r\n }\r\n\r\n snapshot.updateOutputsRefFromServer(responseData, outputs);\r\n}\r\n","import { toValue, watch } from \"vue\";\r\nimport { TVueWatchConfig } from \"@/shared/configTypes/vueWatch\";\r\nimport { TJsWatchConfig } from \"@/shared/configTypes/jsWatch\";\r\nimport { TSnapshot } from \"@/shared/bindableHelper\";\r\nimport * as jsCodeSystem from \"@/systems/jsCodeSystem\";\r\nimport * as objectSystem from \"@/systems/objectSystem\";\r\nimport { TBindableVar } from \"./configTypes\";\r\n\r\nexport function createVueWatch(\r\n watchConfig: TVueWatchConfig,\r\n snapshot: TSnapshot\r\n) {\r\n const {\r\n on: sources,\r\n code,\r\n immediate,\r\n deep,\r\n once,\r\n flush,\r\n bind = {},\r\n onData,\r\n bindData,\r\n } = watchConfig;\r\n\r\n const onDatas = onData || new Array(sources.length).fill(0);\r\n const bindDatas = bindData || new Array(Object.keys(bind).length).fill(0);\r\n\r\n const bindings = objectSystem.mapObjectForValue(bind, (value, _, index) =>\r\n bindDatas[index] === 0 ? snapshot.getVueRefObject(value) : value\r\n );\r\n const fn = jsCodeSystem.createFnFromString(code, bindings);\r\n\r\n const watchTargets =\r\n sources.length === 1\r\n ? _toVueWatchTarget(onDatas[0] === 1, sources[0], snapshot)\r\n : sources.map((input, index) =>\r\n _toVueWatchTarget(onDatas[index] === 1, input, snapshot)\r\n );\r\n\r\n return watch(watchTargets, fn, { immediate, deep, once, flush });\r\n}\r\n\r\nfunction _toVueWatchTarget(\r\n isData: boolean,\r\n input: TBindableVar,\r\n snapshot: TSnapshot\r\n) {\r\n return isData ? () => input : snapshot.getVueRefObject(input);\r\n}\r\n\r\nexport function createJsWatch(\r\n watchConfig: TJsWatchConfig,\r\n snapshot: TSnapshot\r\n) {\r\n const {\r\n inputs = [],\r\n outputs,\r\n slient,\r\n data,\r\n code,\r\n immediate = true,\r\n deep,\r\n once,\r\n flush,\r\n } = watchConfig;\r\n\r\n const slients = slient || new Array(inputs.length).fill(0);\r\n const datas = data || new Array(inputs.length).fill(0);\r\n\r\n const fn = jsCodeSystem.createFnFromString(code);\r\n\r\n const watchTargets = inputs\r\n .filter((_, index) => slients[index] === 0 && datas[index] === 0)\r\n .map((input) => snapshot.getVueRefObject(input));\r\n\r\n function getInputValues() {\r\n return inputs.map((input, index) => {\r\n if (datas[index] === 0) {\r\n return objectSystem.deepClone(toValue(snapshot.getVueRefObject(input)));\r\n }\r\n\r\n return input;\r\n });\r\n }\r\n\r\n watch(\r\n watchTargets,\r\n () => {\r\n let result = fn(...getInputValues());\r\n\r\n if (!outputs) {\r\n return;\r\n }\r\n\r\n const setLen = outputs.length;\r\n const resultValues: any[] = setLen === 1 ? [result] : result;\r\n\r\n const skips = resultValues.map((v) => (v === undefined ? 1 : 0));\r\n\r\n snapshot.updateOutputsRefFromServer(\r\n { values: resultValues, skips },\r\n outputs\r\n );\r\n },\r\n { immediate, deep, once, flush }\r\n );\r\n}\r\n","import * as configTypes from \"@/shared/configTypes\";\r\nimport * as jsCodeSystem from \"@/systems/jsCodeSystem\";\r\nimport * as objectSystem from \"@/systems/objectSystem\";\r\nimport { type TSnapshot } from \"@/shared/bindableHelper\";\r\nimport { bindableTools } from \"@/shared/configTypes/vars\";\r\nimport { getDataSender } from \"@/shared/dataSender\";\r\n\r\nexport type TPrepareBindingsFn = ReturnType<typeof prepareBindings>;\r\n\r\nexport function createEvents(\r\n events: configTypes.TComponent[\"events\"],\r\n snapshot: TSnapshot\r\n): Record<string, Function> {\r\n return Object.assign(\r\n {},\r\n ...Object.entries(events ?? {}).map(([key, infos]) => {\r\n const fns = infos.map((info) => {\r\n if (info.type === \"web\") {\r\n const bindBuilder = prepareBindings(info.bind, snapshot);\r\n\r\n return createWebEventHandlerFn(info, bindBuilder, snapshot);\r\n } else if (info.type === \"vue\") {\r\n return createVueEvent(info, snapshot);\r\n } else if (info.type === \"js\") {\r\n return createJsEvent(info, snapshot);\r\n }\r\n\r\n throw new Error(`unknown event type ${info}`);\r\n });\r\n\r\n const promises = (...args: any[]) =>\r\n fns.map(async (fn) => {\r\n await fn(...args);\r\n });\r\n\r\n const fn = jsCodeSystem.createFnFromString(\r\n ` (...args)=> Promise.all(promises(...args))`,\r\n {\r\n promises: promises,\r\n }\r\n );\r\n\r\n return { [key]: fn };\r\n })\r\n );\r\n}\r\n\r\nfunction prepareBindings(\r\n bindings: configTypes.TWebEventHandler[\"bind\"],\r\n snapshot: TSnapshot\r\n) {\r\n return (...e: any[]) =>\r\n (bindings ?? []).map((binding) => {\r\n if (bindableTools.isEventContext(binding)) {\r\n if (binding.path.startsWith(\":\")) {\r\n const code = binding.path.slice(1);\r\n return jsCodeSystem.createFnFromString(code)(...e);\r\n }\r\n\r\n return objectSystem.getByPaths(e[0], binding.path.split(\".\"));\r\n }\r\n\r\n if (bindableTools.IsBinding(binding)) {\r\n return snapshot.getObjectToValue(binding);\r\n }\r\n\r\n return binding;\r\n });\r\n}\r\n\r\nfunction createWebEventHandlerFn(\r\n info: configTypes.TWebEventHandler,\r\n bindingsBuilder: TPrepareBindingsFn,\r\n snapshot: TSnapshot\r\n) {\r\n async function handleEvent(...e: any[]) {\r\n const bindings = bindingsBuilder(...e);\r\n\r\n const responseData = await getDataSender().eventSend(info, bindings);\r\n if (!responseData) {\r\n return;\r\n }\r\n snapshot.updateOutputsRefFromServer(responseData, info.set);\r\n }\r\n\r\n return handleEvent;\r\n}\r\n\r\nfunction createJsEvent(info: configTypes.TJsEvent, snapshot: TSnapshot) {\r\n const { code, inputs = [], set } = info;\r\n\r\n const eventFn = jsCodeSystem.createFnFromString(code);\r\n\r\n function handleEvent(...e: any[]) {\r\n const inputValues = (inputs ?? []).map((input) => {\r\n if (bindableTools.isEventContext(input)) {\r\n if (input.path.startsWith(\":\")) {\r\n const code = input.path.slice(1);\r\n return jsCodeSystem.createFnFromString(code)(...e);\r\n }\r\n\r\n return objectSystem.getByPaths(e[0], input.path.split(\".\"));\r\n }\r\n\r\n if (bindableTools.IsBinding(input)) {\r\n return objectSystem.deepClone(snapshot.getObjectToValue(input));\r\n }\r\n\r\n return input;\r\n });\r\n\r\n const output = eventFn(...inputValues);\r\n\r\n if (set !== undefined) {\r\n const setLen = set.length;\r\n const outputValues: any[] = setLen === 1 ? [output] : output;\r\n\r\n const skips = outputValues.map((v) => (v === undefined ? 1 : 0));\r\n\r\n snapshot.updateOutputsRefFromServer({ values: outputValues, skips }, set);\r\n }\r\n }\r\n\r\n return handleEvent;\r\n}\r\n\r\nfunction createVueEvent(info: configTypes.TVueEvent, snapshot: TSnapshot) {\r\n const { code, bind = {}, bindData } = info;\r\n\r\n const bindDatas = bindData || new Array(Object.keys(bind).length).fill(0);\r\n const bindings = objectSystem.mapObjectForValue(bind, (value, _, index) =>\r\n bindDatas[index] === 0 ? snapshot.getVueRefObject(value) : value\r\n );\r\n\r\n const eventFn = jsCodeSystem.createFnFromString(code, bindings);\r\n\r\n function handleEvent(...e: any[]) {\r\n eventFn(...e);\r\n }\r\n\r\n return handleEvent;\r\n}\r\n","import { TComponent } from \"@/shared/configTypes\";\r\nimport * as objectSystem from \"@/systems/objectSystem\";\r\nimport { normalizeStyle as _normalizeStyle } from \"vue\";\r\nimport { type TSnapshot } from \"@/shared/bindableHelper\";\r\n\r\nexport function handlerStyles(component: TComponent, snapshot: TSnapshot) {\r\n const result = [] as any[];\r\n\r\n (component.bStyle || []).forEach((style) => {\r\n if (Array.isArray(style)) {\r\n result.push(\r\n ...style.map((item) => {\r\n return snapshot.getObjectToValue(item);\r\n })\r\n );\r\n } else {\r\n result.push(\r\n objectSystem.mapObjectForValue(style, (value) =>\r\n snapshot.getObjectToValue(value)\r\n )\r\n );\r\n }\r\n });\r\n\r\n const styles = _normalizeStyle([component.style || {}, result]);\r\n const hasStyle = styles && Object.keys(styles).length > 0;\r\n\r\n return {\r\n hasStyle,\r\n styles,\r\n };\r\n}\r\n","import * as configTypes from \"@/shared/configTypes\";\r\nimport * as objectSystem from \"@/systems/objectSystem\";\r\nimport { normalizeClass as _normalizeClass } from \"vue\";\r\nimport { type TSnapshot } from \"@/shared/bindableHelper\";\r\n\r\nexport function handlerClasses(\r\n component: configTypes.TComponent,\r\n snapshot: TSnapshot\r\n) {\r\n const classes = component.classes;\r\n\r\n if (!classes) {\r\n return null;\r\n }\r\n\r\n if (typeof classes === \"string\") {\r\n return _normalizeClass(classes);\r\n }\r\n\r\n const { str: strClass, map: mapClass, bind: bindClass } = classes;\r\n\r\n const result = [];\r\n\r\n if (strClass) {\r\n result.push(strClass);\r\n }\r\n\r\n if (mapClass) {\r\n result.push(\r\n objectSystem.mapObjectForValue(mapClass, (value) =>\r\n snapshot.getObjectToValue(value)\r\n )\r\n );\r\n }\r\n\r\n if (bindClass) {\r\n result.push(...bindClass.map((item) => snapshot.getObjectToValue(item)));\r\n }\r\n\r\n return _normalizeClass(result);\r\n}\r\n","import { createFnFromString } from \"./systems/jsCodeSystem\";\r\n\r\nexport function convertDynamicProperties(\r\n obj: Record<string, any>,\r\n recursive = true\r\n) {\r\n if (typeof obj !== \"object\" || obj === null) {\r\n return;\r\n }\r\n if (Array.isArray(obj)) {\r\n if (recursive) {\r\n obj.forEach((v) => convertDynamicProperties(v, true));\r\n }\r\n return;\r\n }\r\n for (const [attr, value] of Object.entries(obj)) {\r\n if (attr.startsWith(\":\")) {\r\n try {\r\n obj[attr.slice(1)] = new Function(`return (${value})`)();\r\n delete obj[attr];\r\n } catch (e) {\r\n console.error(\r\n `Error while converting ${attr} attribute to function:`,\r\n e\r\n );\r\n }\r\n } else {\r\n if (recursive) {\r\n convertDynamicProperties(value, true);\r\n }\r\n }\r\n }\r\n}\r\n\r\nexport function tryConvertDynamicProp(name: string, value: any) {\r\n const isFunc = name.startsWith(\":\");\r\n\r\n if (isFunc) {\r\n name = name.slice(1);\r\n value = createFnFromString(value as string);\r\n }\r\n\r\n return { name, value, isFunc };\r\n}\r\n","import * as configTypes from \"@/shared/configTypes\";\r\nimport { toDisplayString } from \"vue\";\r\nimport * as objectSystem from \"@/systems/objectSystem\";\r\nimport { type TSnapshot } from \"@/shared/bindableHelper\";\r\nimport { tryConvertDynamicProp, convertDynamicProperties } from \"@/appUtils\";\r\nimport { isInitial } from \"@/shared/computedInit\";\r\n\r\nexport function handlerProps(\r\n component: configTypes.TComponent,\r\n staticProps: Record<string, any>,\r\n snapshot: TSnapshot\r\n) {\r\n const result = {} as Record<string, any>;\r\n\r\n objectSystem.foreachObject(component.bProps || {}, (value, key) => {\r\n const realValue = snapshot.getObjectToValue(value);\r\n if (!isInitial(realValue)) {\r\n convertDynamicProperties(realValue);\r\n result[key] = toPropValue(realValue, key);\r\n }\r\n });\r\n\r\n component.proxyProps?.forEach((prop) => {\r\n const value = snapshot.getObjectToValue(prop);\r\n if (typeof value === \"object\") {\r\n objectSystem.foreachObject(value, (v, k) => {\r\n const { name, value } = tryConvertDynamicProp(k, v);\r\n result[name] = value;\r\n });\r\n }\r\n });\r\n\r\n return { ...(staticProps || {}), ...result };\r\n}\r\n\r\nfunction toPropValue(value: any, propName: string) {\r\n if (propName === \"innerText\") {\r\n return toDisplayString(value);\r\n }\r\n\r\n return value;\r\n}\r\n","import { defineComponent, h, Fragment as _Fragment, onUnmounted } from \"vue\";\r\nimport * as slotStore from \"@/shared/slotStore\";\r\n\r\ntype TSlotPropsInfo = {\r\n id: string;\r\n use: string[];\r\n};\r\n\r\ntype TProps = {\r\n propsInfo: TSlotPropsInfo;\r\n propsValue: any;\r\n};\r\n\r\nfunction render(props: TProps, { slots }: any) {\r\n // setup\r\n const { id: slotId, use: propNames } = props.propsInfo;\r\n\r\n const slotSeqIndex = slotStore.SetupCollect(slotId);\r\n\r\n onUnmounted(() => {\r\n slotStore.removeSlotInfo(slotId);\r\n });\r\n\r\n // render\r\n return () => {\r\n const propsValue = props.propsValue;\r\n\r\n slotStore.updateValues(\r\n slotId,\r\n slotSeqIndex,\r\n Object.fromEntries(\r\n propNames.map((propName) => [propName, propsValue[propName]])\r\n )\r\n );\r\n\r\n return h(_Fragment, null, slots.default());\r\n };\r\n}\r\n\r\nexport default defineComponent(render, {\r\n props: [\"propsInfo\", \"propsValue\"],\r\n});\r\n","import * as configTypes from \"@/shared/configTypes\";\r\nimport * as objectSystem from \"@/systems/objectSystem\";\r\n\r\nimport ScopeContainer from \"@/components/scopeContainer\";\r\nimport SlotPropContainer from \"@/components/slotPropContainer\";\r\n\r\nimport { h } from \"vue\";\r\nimport Element from \"./element\";\r\n\r\nexport function handlerSlots(\r\n component: configTypes.TComponent,\r\n isHtmlTag: boolean\r\n) {\r\n if (!component.slots) {\r\n return null;\r\n }\r\n\r\n const slotConfig = component.slots ?? {};\r\n if (Array.isArray(slotConfig)) {\r\n return isHtmlTag\r\n ? createElements(slotConfig)\r\n : () => createElements(slotConfig);\r\n }\r\n\r\n const keyFn = (slotName: string) => (slotName === \":\" ? \"default\" : slotName);\r\n\r\n const valueFn = (slot: configTypes.TSlot) => {\r\n const { items } = slot;\r\n\r\n return (slotProps: any) => {\r\n if (slot.scope) {\r\n const childernSlot = () =>\r\n !!slot.props\r\n ? createSlotPropsContainer(slot.props, slotProps, items)\r\n : createElements(items);\r\n\r\n return h(ScopeContainer, { scope: slot.scope }, childernSlot);\r\n }\r\n\r\n if (slot.props) {\r\n return createSlotPropsContainer(slot.props, slotProps, items);\r\n }\r\n\r\n return createElements(items);\r\n };\r\n };\r\n\r\n const result = objectSystem.mapObjectFor(slotConfig, { keyFn, valueFn });\r\n\r\n return result;\r\n}\r\n\r\nfunction createSlotPropsContainer(\r\n propsInfo: {\r\n id: string;\r\n use: string[];\r\n },\r\n propsValue: any,\r\n items: (configTypes.TComponent | configTypes.TVForComponent)[]\r\n) {\r\n return h(SlotPropContainer, { propsInfo, propsValue }, () =>\r\n createElements(items)\r\n );\r\n}\r\n\r\nfunction createElements(\r\n items: (configTypes.TComponent | configTypes.TVForComponent)[] | undefined\r\n) {\r\n const result = (items ?? []).map((item) => {\r\n return h(Element, {\r\n component: item,\r\n });\r\n });\r\n\r\n return result.length <= 0 ? null : result;\r\n}\r\n","import * as configTypes from \"@/shared/configTypes\";\r\nimport { Ref, vModelDynamic, vShow as _vShow } from \"vue\";\r\nimport { type TSnapshot } from \"@/shared/bindableHelper\";\r\n\r\nexport function collectDirectives(\r\n dirs: configTypes.TComponent[\"dir\"],\r\n snapshot: TSnapshot\r\n) {\r\n const newProps: Record<string, any> = {};\r\n const directiveArray: any[] = [];\r\n\r\n (dirs || []).forEach((directive) => {\r\n const { sys, name, arg, value, mf: modifers } = directive;\r\n\r\n if (name === \"vmodel\") {\r\n const refValue = snapshot.getVueRefObject(value) as Ref<any>;\r\n newProps[`onUpdate:${arg}`] = (value: any) => {\r\n refValue.value = value;\r\n };\r\n\r\n if (sys === 1) {\r\n const mfs = modifers\r\n ? Object.fromEntries(modifers.map((modifier) => [modifier, true]))\r\n : {};\r\n\r\n directiveArray.push([vModelDynamic, refValue.value, void 0, mfs]);\r\n } else {\r\n newProps[arg] = refValue.value;\r\n }\r\n } else if (name === \"vshow\") {\r\n const refValue = snapshot.getVueRefObject(value) as Ref<any>;\r\n directiveArray.push([_vShow, refValue.value]);\r\n } else {\r\n console.warn(`Directive ${name} is not supported yet`);\r\n }\r\n });\r\n\r\n return {\r\n newProps,\r\n directiveArray,\r\n };\r\n}\r\n","import * as configTypes from \"@/shared/configTypes\";\r\nimport { TElementRefSnapshot } from \"@/shared/elementRefStore\";\r\n\r\nexport function handlerElementRef(\r\n component: configTypes.TComponent,\r\n snapshot: TElementRefSnapshot\r\n): Record<string, any> {\r\n const { eRef } = component;\r\n if (eRef === undefined) {\r\n return {};\r\n }\r\n\r\n return { ref: snapshot.getRef(eRef) };\r\n}\r\n","import {\r\n defineComponent,\r\n h,\r\n resolveDynamicComponent,\r\n withDirectives,\r\n normalizeProps as _normalizeProps,\r\n VNode,\r\n RendererNode,\r\n RendererElement,\r\n} from \"vue\";\r\n\r\nimport * as configTypes from \"@/shared/configTypes\";\r\nimport { createEvents } from \"./events\";\r\nimport { handlerStyles } from \"./styles\";\r\nimport { handlerClasses } from \"./classes\";\r\nimport { handlerProps } from \"./props\";\r\nimport { handlerSlots } from \"./slots\";\r\nimport { collectDirectives } from \"./directives\";\r\nimport { handlerElementRef } from \"./elementRef\";\r\nimport { createSnapshot } from \"@/shared/bindableHelper\";\r\nimport { createElementRefSnapshot } from \"@/shared/elementRefStore\";\r\nimport { convertDynamicProperties } from \"@/appUtils\";\r\n\r\ntype TProps = {\r\n component: configTypes.TComponent;\r\n};\r\n\r\ntype TRenderNode = VNode<\r\n RendererNode,\r\n RendererElement,\r\n {\r\n [key: string]: any;\r\n }\r\n>;\r\n\r\ntype TRenderResult = () => TRenderNode;\r\n\r\nexport type TRenderFn = typeof render;\r\n\r\nfunction render(props: TProps): TRenderResult {\r\n // setup\r\n\r\n const snapshot = createSnapshot();\r\n const elementRefSnapshot = createElementRefSnapshot();\r\n\r\n const staticProps = props.component.props ?? {};\r\n convertDynamicProperties(staticProps, true);\r\n\r\n // render\r\n return () => {\r\n const { tag } = props.component;\r\n\r\n const stringTag = configTypes.bindableTools.IsBinding(tag)\r\n ? snapshot.getObjectToValue(tag)\r\n : tag;\r\n\r\n const component = resolveDynamicComponent(stringTag) as any;\r\n const isHtmlTag = typeof component === \"string\";\r\n\r\n const classes = handlerClasses(props.component, snapshot);\r\n const { styles, hasStyle } = handlerStyles(props.component, snapshot);\r\n\r\n const events = createEvents(props.component.events ?? {}, snapshot);\r\n\r\n const slots = handlerSlots(props.component, isHtmlTag);\r\n\r\n const valueProps = handlerProps(props.component, staticProps, snapshot);\r\n\r\n const { newProps, directiveArray } = collectDirectives(\r\n props.component.dir,\r\n snapshot\r\n );\r\n\r\n const elementRefProps = handlerElementRef(\r\n props.component,\r\n elementRefSnapshot\r\n );\r\n\r\n const hProps =\r\n _normalizeProps({\r\n ...valueProps,\r\n ...events,\r\n ...newProps,\r\n ...elementRefProps,\r\n }) || {};\r\n\r\n if (hasStyle) {\r\n hProps.style = styles;\r\n }\r\n\r\n if (classes) {\r\n hProps.class = classes;\r\n }\r\n\r\n const resultNode = h(component as any, { ...hProps }, slots);\r\n\r\n if (directiveArray.length > 0) {\r\n return withDirectives(\r\n // @ts-ignore\r\n resultNode,\r\n directiveArray as any\r\n );\r\n }\r\n\r\n return resultNode;\r\n };\r\n}\r\n\r\nexport default defineComponent(render, {\r\n props: [\"component\"],\r\n});\r\n","import { defineComponent, h, Fragment as _Fragment, onUnmounted } from \"vue\";\r\nimport { TScope, TComponent } from \"@/shared/configTypes\";\r\nimport { createVarStore, removeIndexVars } from \"@/shared/varStore\";\r\nimport {\r\n createElementRefStore,\r\n removeElementRef,\r\n} from \"@/shared/elementRefStore\";\r\nimport { createSnapshot } from \"@/shared/bindableHelper\";\r\nimport { setupWebWatchStore } from \"@/shared/webWatchStore\";\r\nimport {\r\n createJsWatch,\r\n createVueWatch as createVueWatch,\r\n} from \"@/shared/jsWatchStore\";\r\nimport * as vforManager from \"@/shared/vforManager\";\r\nimport Element from \"@/components/element/element\";\r\n\r\ntype TProps = {\r\n scope?: TScope;\r\n};\r\n\r\nfunction setup(scope?: TScope, vforKey?: any) {\r\n if (scope) {\r\n // element refs\r\n const elementRefStoreIndex = createElementRefStore(scope);\r\n\r\n const storeIndex = createVarStore(scope, createSnapshot(vforKey));\r\n const snapshot = createSnapshot(vforKey);\r\n\r\n // web watch\r\n setupWebWatchStore(scope.py_watch, scope.web_computed, snapshot);\r\n scope.vue_watch?.forEach((watch) => createVueWatch(watch, snapshot));\r\n scope.js_watch?.forEach((watch) => createJsWatch(watch, snapshot));\r\n\r\n onUnmounted(() => {\r\n removeIndexVars(scope.id, storeIndex);\r\n removeElementRef(scope.id, elementRefStoreIndex);\r\n });\r\n }\r\n}\r\n\r\nfunction render(props: TProps, { slots }: any) {\r\n // setup\r\n const { scope } = props;\r\n\r\n setup(scope);\r\n\r\n // render\r\n return () => {\r\n return h(_Fragment, null, slots.default());\r\n };\r\n}\r\n\r\nexport default defineComponent(render, {\r\n props: [\"scope\"],\r\n});\r\n\r\nexport const VForScope = defineComponent(\r\n (props: {\r\n scope?: TScope;\r\n items: TComponent[];\r\n vforInfo: {\r\n fid: string;\r\n key: any;\r\n };\r\n }) => {\r\n // setup\r\n const { scope, items, vforInfo } = props;\r\n\r\n vforManager.provideVForKey(vforInfo);\r\n\r\n setup(scope, vforInfo.key);\r\n\r\n const createNodeFn =\r\n items.length === 1\r\n ? () =>\r\n h(Element, {\r\n component: items[0],\r\n })\r\n : () =>\r\n items.map((item) =>\r\n h(Element, {\r\n component: item,\r\n })\r\n );\r\n\r\n // render\r\n return createNodeFn;\r\n },\r\n {\r\n props: [\"scope\", \"items\", \"vforInfo\"],\r\n }\r\n);\r\n","import { TAppConfig } from \"@/shared/configTypes\";\r\nimport { useAsyncState } from \"@vueuse/core\";\r\n\r\nexport function useLoadAppConfig(config?: TAppConfig, url?: string) {\r\n const { state, isReady, isLoading } = useAsyncState(async () => {\r\n let appConfig = config;\r\n const configUrl = url;\r\n if (!appConfig && !configUrl) {\r\n throw new Error(\"Either config or configUrl must be provided\");\r\n }\r\n\r\n if (!appConfig && configUrl) {\r\n appConfig = await (await fetch(configUrl)).json();\r\n }\r\n\r\n if (!appConfig) {\r\n throw new Error(\"Failed to load config\");\r\n }\r\n\r\n return appConfig;\r\n }, {} as TAppConfig);\r\n\r\n return { config: state, isReady, isLoading };\r\n}\r\n\r\nexport function appErrorHandler(err: any, vm: any) {\r\n let componentMessage: string;\r\n if (!vm.component) {\r\n componentMessage = `Error captured from app init`;\r\n } else {\r\n componentMessage = `Error captured from component:tag: ${vm.component.tag} ; id: ${vm.component.id} `;\r\n }\r\n\r\n console.group(componentMessage);\r\n console.error(\"Component:\", vm.component);\r\n console.error(\"Error:\", err);\r\n console.groupEnd();\r\n\r\n return false;\r\n}\r\n","<script setup lang=\"ts\">\r\nimport \"./style.css\";\r\nimport { TAppConfig } from \"@/shared/configTypes\";\r\nimport * as appInfo from \"@/shared/appInfo\";\r\n\r\nimport ScopeContainer from \"@/components/scopeContainer\";\r\nimport Element from \"@/components/element/element\";\r\nimport { onErrorCaptured, watch } from \"vue\";\r\nimport { useLoadAppConfig, appErrorHandler } from \"./app\";\r\nimport { setupDataSender } from \"@/shared/dataSender\";\r\n\r\nconst props = defineProps<{ config?: TAppConfig; configUrl?: string }>();\r\n\r\nconst { config: appConfig, isLoading } = useLoadAppConfig(\r\n props.config,\r\n props.configUrl\r\n);\r\n\r\nlet app = null as TAppConfig | null;\r\n\r\nwatch(appConfig, (appConfig) => {\r\n app = appConfig;\r\n if (appConfig.url) {\r\n appInfo.setup({\r\n mode: appConfig.mode,\r\n version: appConfig.version,\r\n queryPath: appConfig.url.path,\r\n pathParams: appConfig.url.params,\r\n webServerInfo: appConfig.webInfo,\r\n });\r\n\r\n setupDataSender(appConfig);\r\n }\r\n});\r\n\r\nonErrorCaptured(appErrorHandler);\r\n</script>\r\n\r\n<template>\r\n <div class=\"app-box\">\r\n <!-- Loading spinner -->\r\n <div\r\n v-if=\"isLoading\"\r\n style=\"\r\n position: absolute;\r\n top: 50%;\r\n left: 50%;\r\n transform: translate(-50%, -50%);\r\n \"\r\n >\r\n <p style=\"margin: auto\">Loading ...</p>\r\n </div>\r\n\r\n <!-- Main app container -->\r\n <div v-else class=\"insta-main\" :class=\"appConfig.class\">\r\n <ScopeContainer :scope=\"app!.scope\">\r\n <Element\r\n :component=\"component\"\r\n v-for=\"component in app!.items\"\r\n ></Element>\r\n </ScopeContainer>\r\n </div>\r\n </div>\r\n</template>\r\n","import { defineComponent, h } from \"vue\";\r\nimport Element from \"@/components/element/element\";\r\nimport ScopeContainer from \"@/components/scopeContainer\";\r\n\r\nimport { TBindableVar, TScope, TSlot } from \"@/shared/configTypes\";\r\nimport { createSnapshot } from \"@/shared/bindableHelper\";\r\n\r\ntype TProps = {\r\n on: TBindableVar;\r\n scope: TScope;\r\n items: TSlot;\r\n};\r\n\r\nfunction render(props: TProps) {\r\n // setup\r\n const { on, scope, items } = props;\r\n\r\n const snapshot = createSnapshot();\r\n\r\n // render\r\n return () => {\r\n const onValue = typeof on==='boolean'? on : snapshot.getObjectToValue(on!);\r\n\r\n const itemsNode = () =>\r\n onValue\r\n ? (items as unknown as any[]).map((item) =>\r\n h(Element, { component: item })\r\n )\r\n : undefined;\r\n\r\n return h(ScopeContainer, { scope: scope }, itemsNode);\r\n };\r\n}\r\n\r\nexport default defineComponent(render, {\r\n props: [\"on\", \"scope\", \"items\"],\r\n});\r\n","export function range(options: { start?: number; end: number; step?: number }) {\r\n const { start = 0, end, step = 1 } = options;\r\n let array = [];\r\n if (step > 0) {\r\n for (let i = start; i < end; i += step) {\r\n array.push(i);\r\n }\r\n } else {\r\n for (let i = start; i > end; i += step) {\r\n array.push(i);\r\n }\r\n }\r\n return array;\r\n}\r\n","import {\r\n defineComponent,\r\n h,\r\n Fragment as _Fragment,\r\n onUnmounted,\r\n TransitionGroup as _TransitionGroup,\r\n} from \"vue\";\r\n\r\nimport * as numberSystem from \"@/systems/numberSystem\";\r\nimport * as jsCodeSystem from \"@/systems/jsCodeSystem\";\r\nimport * as configTypes from \"@/shared/configTypes\";\r\nimport { clearScopeVarStore } from \"@/shared/varStore\";\r\nimport * as vforManager from \"@/shared/vforManager\";\r\nimport { createSnapshot } from \"@/shared/bindableHelper\";\r\nimport { VForScope } from \"@/components/scopeContainer\";\r\n\r\ntype TProps = configTypes.TVForComponent[\"props\"];\r\n\r\nfunction render(props: TProps) {\r\n // setup\r\n const { array, bArray, items, fkey, fid, scope, num, tsGroup = {} } = props;\r\n\r\n const isBindRef = array === undefined;\r\n const isLoopNumber = num !== undefined;\r\n const arrayValue = isBindRef ? bArray : array;\r\n const snapshot = createSnapshot();\r\n\r\n // // TODO\r\n vforManager.markArray(fid, arrayValue as any, isBindRef, isLoopNumber);\r\n\r\n const vforKey = fkey ?? \"index\";\r\n const keyFn = createKeyFn(vforKey);\r\n\r\n onUnmounted(() => {\r\n clearScopeVarStore(scope.id);\r\n });\r\n\r\n // render\r\n return () => {\r\n const sourceValue = createSourceValueArray(\r\n isLoopNumber,\r\n isBindRef,\r\n arrayValue,\r\n snapshot,\r\n num\r\n );\r\n\r\n const keysCollector = vforManager.keysCollector(fid);\r\n\r\n const itemsNode = (sourceValue as any[]).map((value, index) => {\r\n const key = keyFn(value, index);\r\n\r\n keysCollector.add(key);\r\n vforManager.markVForIndex(fid, key, index);\r\n\r\n return h(VForScope, {\r\n scope: props.scope,\r\n items: items,\r\n vforInfo: {\r\n fid,\r\n key,\r\n },\r\n key,\r\n });\r\n });\r\n\r\n keysCollector.removeUnusedKeys();\r\n\r\n if (!!tsGroup && Object.keys(tsGroup).length > 0) {\r\n return h(_TransitionGroup, tsGroup, {\r\n default: () => itemsNode,\r\n });\r\n }\r\n\r\n return itemsNode;\r\n };\r\n}\r\n\r\nexport default defineComponent(render, {\r\n props: [\"array\", \"items\", \"fid\", \"bArray\", \"scope\", \"num\", \"fkey\", \"tsGroup\"],\r\n});\r\n\r\nfunction createSourceValueArray(\r\n isLoopNumber: boolean,\r\n isBindRef: boolean,\r\n arrayValue: any,\r\n snapshot: ReturnType<typeof createSnapshot>,\r\n num: TProps[\"num\"]\r\n): any[] {\r\n if (isLoopNumber) {\r\n let numValue = 0;\r\n if (typeof num === \"number\") {\r\n numValue = num;\r\n } else {\r\n numValue = snapshot.getObjectToValue(num!) ?? 0;\r\n }\r\n\r\n return numberSystem.range({\r\n end: Math.max(0, numValue),\r\n });\r\n }\r\n\r\n const source = isBindRef\r\n ? snapshot.getObjectToValue(arrayValue as configTypes.TBinding) || []\r\n : arrayValue;\r\n\r\n return typeof source === \"object\" ? Object.values(source) : source;\r\n}\r\n\r\nconst _item_key_fn = (value: any) => value;\r\nconst _index_key_fn = (_: any, index: number) => index;\r\n\r\nfunction createKeyFn(vforKey: string) {\r\n const fn = jsCodeSystem.tryStringWithColonToFunction(vforKey);\r\n if (typeof fn === \"function\") {\r\n return fn;\r\n }\r\n\r\n return vforKey === \"item\" ? _item_key_fn : _index_key_fn;\r\n}\r\n","import { TScope, TScopeItem, TComponent } from \"@/shared/configTypes\";\r\nimport Element from \"@/components/element/element\";\r\n\r\nimport { defineComponent, h, resolveDynamicComponent, VNode } from \"vue\";\r\n\r\nfunction render(items: TScopeItem[]): VNode[] | VNode {\r\n const cmd = items.map((item) => {\r\n if ((item as any).tag) {\r\n const component = item as TComponent;\r\n return h(Element, { component });\r\n }\r\n\r\n // is scope\r\n const cpNode = resolveDynamicComponent(Scope) as string;\r\n const scopeObj = item as TScope;\r\n\r\n return h(cpNode, {\r\n scope: scopeObj,\r\n });\r\n });\r\n\r\n return cmd;\r\n}\r\n\r\nexport const Scope = defineComponent(\r\n (props: { scope: TScope }) => {\r\n const scope = props.scope;\r\n\r\n // render\r\n return () => {\r\n return render(scope.items ?? []);\r\n };\r\n },\r\n {\r\n props: [\"scope\"],\r\n }\r\n);\r\n","import { TVar, TComponent, TScope, TScopeItem } from \"@/shared/configTypes\";\r\nimport Element from \"@/components/element/element\";\r\nimport * as appInfo from \"@/shared/appInfo\";\r\nimport { createVarStore, removeIndexVars } from \"@/shared/varStore\";\r\n\r\nimport {\r\n defineComponent,\r\n h,\r\n VNode,\r\n watch,\r\n shallowRef,\r\n WatchHandle,\r\n resolveDynamicComponent,\r\n onUnmounted,\r\n} from \"vue\";\r\nimport { Scope } from \"@/components/scope\";\r\nimport { createSnapshot, TSnapshot } from \"@/shared/bindableHelper\";\r\n\r\ntype TProps = {\r\n sid: string;\r\n url: string;\r\n hKey: string;\r\n on: TVar[];\r\n bind: TVar[];\r\n items: TScopeItem[];\r\n scope: TScope;\r\n};\r\n\r\nfunction render(items: TScopeItem[]): VNode[] | VNode {\r\n return items.map((item) => {\r\n if ((item as any).tag) {\r\n const component = item as TComponent;\r\n return h(Element, { component });\r\n }\r\n\r\n // is scope\r\n const cpNode = resolveDynamicComponent(Scope) as string;\r\n const scopeObj = item as TScope;\r\n\r\n return h(cpNode, {\r\n scope: scopeObj,\r\n });\r\n });\r\n}\r\n\r\nexport const Refresh = defineComponent(\r\n (props: TProps) => {\r\n const { scope, on, items } = props;\r\n // setup\r\n const itemsRef = shallowRef<TScopeItem[]>(items);\r\n const storeIndex = createVarStore(scope);\r\n const snapshot = createSnapshot();\r\n\r\n helpers.createDynamicWatchRefresh(on, snapshot, async () => {\r\n const { items, on } = await helpers.fetchRemote(props, snapshot);\r\n itemsRef.value = items;\r\n\r\n return on;\r\n });\r\n\r\n onUnmounted(() => {\r\n removeIndexVars(scope.id, storeIndex);\r\n });\r\n\r\n // render\r\n return () => {\r\n return render(itemsRef.value);\r\n };\r\n },\r\n {\r\n props: [\"sid\", \"url\", \"hKey\", \"on\", \"bind\", \"items\", \"scope\"],\r\n }\r\n);\r\n\r\nnamespace helpers {\r\n export function createDynamicWatchRefresh(\r\n targetOns: TVar[],\r\n snapshot: TSnapshot,\r\n callback: () => Promise<TVar[]>\r\n ) {\r\n let currentWatcher = null as WatchHandle | null;\r\n let currentOns = targetOns;\r\n let targetRefs = currentOns.map((v) => snapshot.getVueRefObject(v));\r\n\r\n function setupWatcher() {\r\n if (currentWatcher) {\r\n currentWatcher();\r\n }\r\n\r\n currentWatcher = watch(\r\n targetRefs,\r\n async () => {\r\n currentOns = await callback();\r\n targetRefs = currentOns.map((v) => snapshot.getVueRefObject(v));\r\n setupWatcher();\r\n },\r\n { deep: true }\r\n );\r\n }\r\n\r\n setupWatcher();\r\n\r\n return () => {\r\n if (currentWatcher) {\r\n currentWatcher();\r\n }\r\n };\r\n }\r\n\r\n export async function fetchRemote(props: TProps, snapshot: TSnapshot) {\r\n const fnParams = Object.values(props.bind).map((p) => {\r\n return {\r\n sid: p.sid,\r\n id: p.id,\r\n value: snapshot.getObjectToValue(p),\r\n };\r\n });\r\n\r\n const fnParamsWithKey = {\r\n sid: props.sid,\r\n bind: fnParams,\r\n hKey: props.hKey,\r\n page: appInfo.getPageInfoPostData(),\r\n };\r\n\r\n const fetchOptions = {\r\n method: \"POST\",\r\n headers: {\r\n \"Content-Type\": \"application/json\",\r\n },\r\n body: JSON.stringify(fnParamsWithKey),\r\n };\r\n\r\n const result = await fetch(props.url, fetchOptions);\r\n\r\n if (!result.ok) {\r\n throw new Error(\"Failed to fetch data\");\r\n }\r\n\r\n const data = (await result.json()) as {\r\n items: TComponent[];\r\n on: TVar[];\r\n };\r\n\r\n return data;\r\n }\r\n}\r\n","import { TScope, TComponent } from \"@/shared/configTypes\";\r\n\r\nimport { defineComponent, h } from \"vue\";\r\nimport Element from \"@/components/element/element\";\r\nimport ScopeContainer from \"@/components/scopeContainer\";\r\n\r\ntype TProps = {\r\n scope: TScope;\r\n items: TComponent[];\r\n};\r\n\r\nfunction render(props: TProps) {\r\n // setup\r\n const { scope, items } = props;\r\n\r\n // render\r\n return () => {\r\n const itemsNode = items.map((item) => h(Element, { component: item }));\r\n\r\n return h(ScopeContainer, { scope }, () => itemsNode);\r\n };\r\n}\r\n\r\nexport default defineComponent(render, {\r\n props: [\"scope\", \"items\"],\r\n});\r\n","import { defineComponent, h, Fragment as _Fragment } from \"vue\";\r\nimport { TScope, TBindableVar, TComponent } from \"@/shared/configTypes\";\r\nimport * as bindableHelper from \"@/shared/bindableHelper\";\r\n\r\nimport MatchCase from \"./matchCase\";\r\n\r\ntype TCase = {\r\n props: {\r\n value: any;\r\n scope: TScope;\r\n items: TComponent[];\r\n };\r\n};\r\n\r\ntype TProps = {\r\n on: TBindableVar;\r\n case: TCase[];\r\n default?: {\r\n props: {\r\n scope: TScope;\r\n items: TComponent[];\r\n };\r\n };\r\n};\r\n\r\nfunction render(props: TProps) {\r\n // setup\r\n const { on, case: caseConfig, default: defaultConfig } = props;\r\n\r\n const snapshot = bindableHelper.createSnapshot();\r\n\r\n // render\r\n return () => {\r\n const onValue = snapshot.getObjectToValue(on);\r\n\r\n const itemsNode = caseConfig\r\n .map((config) => {\r\n const { value, items, scope } = config.props;\r\n if (onValue === value) {\r\n return h(MatchCase, {\r\n scope,\r\n items,\r\n key: [\"case\", value].join(\"-\"),\r\n });\r\n }\r\n })\r\n .filter((node) => node);\r\n\r\n if (defaultConfig && !itemsNode.length) {\r\n const { items, scope } = defaultConfig.props;\r\n itemsNode.push(h(MatchCase, { scope, items, key: \"default\" }));\r\n }\r\n\r\n return h(_Fragment, itemsNode);\r\n };\r\n}\r\n\r\nexport default defineComponent(render, {\r\n props: [\"case\", \"on\", \"default\"],\r\n});\r\n","import { defineComponent, h, TransitionGroup as _TransitionGroup } from \"vue\";\r\n\r\ntype TProps = {\r\n name?: string;\r\n tag?: string;\r\n};\r\n\r\nfunction render(props: TProps, { slots }: any) {\r\n // setup\r\n const { name = \"fade\", tag } = props;\r\n\r\n // render\r\n return () => {\r\n return h(\r\n _TransitionGroup,\r\n { name, tag },\r\n {\r\n default: slots.default,\r\n }\r\n );\r\n };\r\n}\r\n\r\nexport default defineComponent(render, {\r\n props: [\"name\", \"tag\"],\r\n});\r\n","import {\r\n defineComponent,\r\n h,\r\n Fragment as _Fragment,\r\n toDisplayString,\r\n} from \"vue\";\r\nimport * as bindableHelper from \"@/shared/bindableHelper\";\r\n\r\ntype TProps = {\r\n content: any;\r\n r?: number;\r\n};\r\n\r\nfunction render(props: TProps) {\r\n // setup\r\n const { content, r: isRef = 0 } = props;\r\n const snapshot = bindableHelper.createSnapshot();\r\n\r\n const getter =\r\n isRef === 1 ? () => snapshot.getObjectToValue(content) : () => content;\r\n\r\n // render\r\n return () => {\r\n return toDisplayString(getter());\r\n };\r\n}\r\n\r\nexport default defineComponent(render, {\r\n props: [\"content\", \"r\"],\r\n});\r\n","import { h, KeepAlive as _KeepAlive, Fragment as _Fragment } from \"vue\";\r\n\r\nimport ScopeContainer from \"@/components/scopeContainer\";\r\nimport Element from \"@/components/element/element.ts\";\r\nimport { TAppConfig, TScope } from \"./configTypes\";\r\nimport { TVueRouteItem, TRouteRecordConfig } from \"./configTypes/router\";\r\n\r\nexport function extraVueRoutesRecords(app: TAppConfig): any[] {\r\n if (!app.router) {\r\n throw new Error(\"Router config is not provided.\");\r\n }\r\n const { routes, kAlive: isKeepAlive = false } = app.router;\r\n\r\n const vueRoutes = routes.map((routeInfo) =>\r\n _config2vueRouteItem(routeInfo, isKeepAlive)\r\n );\r\n\r\n return vueRoutes;\r\n}\r\n\r\nfunction _config2vueRouteItem(\r\n routeInfo: TRouteRecordConfig,\r\n isKeepAlive: boolean\r\n): Record<string, any> {\r\n const { server: serverLoad = false, vueItem, scope } = routeInfo;\r\n\r\n const fn = () => {\r\n if (serverLoad) {\r\n throw new Error(\"Server-side rendering is not supported yet.\");\r\n }\r\n\r\n return Promise.resolve(_renderByConfig(vueItem, scope, isKeepAlive));\r\n };\r\n\r\n const children = vueItem.children?.map((child) =>\r\n _config2vueRouteItem(child, isKeepAlive)\r\n );\r\n\r\n const result: Record<string, any> = {\r\n ...vueItem,\r\n children,\r\n component: fn,\r\n };\r\n\r\n if (vueItem.component.length === 0) {\r\n delete result.component;\r\n }\r\n\r\n if (children === undefined) {\r\n delete result.children;\r\n }\r\n\r\n return result;\r\n}\r\n\r\nfunction _renderByConfig(\r\n vueItem: TVueRouteItem,\r\n scope: TScope,\r\n isKeepAlive: boolean\r\n) {\r\n const { path, component: items } = vueItem;\r\n\r\n const scopeNode = h(ScopeContainer, { scope, key: path }, () =>\r\n items.map((item) => h(Element, { component: item }))\r\n );\r\n\r\n const renderNode = isKeepAlive\r\n ? h(_KeepAlive, null, () => scopeNode)\r\n : scopeNode;\r\n\r\n return renderNode;\r\n}\r\n","import { App } from \"vue\";\r\nimport {\r\n createWebHashHistory,\r\n createWebHistory,\r\n createMemoryHistory,\r\n createRouter,\r\n} from \"vue-router\";\r\nimport { TAppConfig } from \"@/shared/configTypes\";\r\nimport { extraVueRoutesRecords } from \"@/shared/routerStore\";\r\n\r\nexport function useRouterByAppConfig(app: App, config: TAppConfig) {\r\n const { mode = \"hash\" } = config.router!;\r\n\r\n const history =\r\n mode === \"hash\"\r\n ? createWebHashHistory()\r\n : mode === \"memory\"\r\n ? createMemoryHistory()\r\n : createWebHistory();\r\n\r\n app.use(\r\n createRouter({\r\n history: history,\r\n routes: extraVueRoutesRecords(config),\r\n })\r\n );\r\n}\r\n","import InstaApp from \"./App.vue\";\r\nimport vif from \"./components/vif/vif\";\r\nimport VFor from \"@/components/vfor/vfor\";\r\nimport { Refresh } from \"@/components/refresh\";\r\nimport Match from \"@/components/match\";\r\nimport TransitionGroup from \"@/components/transitionGroup\";\r\nimport Content from \"@/components/content\";\r\nimport { App } from \"vue\";\r\nimport { useRouterByAppConfig } from \"@/shared/routerHelper\";\r\nimport { TAppConfig } from \"./shared/configTypes\";\r\nexport { convertDynamicProperties } from \"@/appUtils\";\r\n\r\nexport function install(app: App, config: TAppConfig) {\r\n app.component(\"insta-ui\", InstaApp);\r\n app.component(\"vif\", vif);\r\n app.component(\"vfor\", VFor);\r\n app.component(\"match\", Match);\r\n app.component(\"refresh\", Refresh);\r\n app.component(\"ts-group\", TransitionGroup);\r\n app.component(\"content\", Content);\r\n\r\n if (config.router) {\r\n useRouterByAppConfig(app, config);\r\n }\r\n}\r\n"],"names":["setupInfo","setup","info","getInfo","getPageInfoPostData","queryPath","pathParams","queryParams","DefaultMap","factory","key","defaultValue","defaultMap","foreachObject","obj","fn","value","mapObjectForValue","valueFn","mapObjectFor","keyFn","index","handleObject","path","getBindableFn","flag","args","newPath","getPath","getByPaths","object","paths","setByPaths","deepClone","Initial","__INITIAL__","isInitial","toRaw","makeRefObjectWithPaths","getterOptions","setterOptions","getterPaths","getterGetBindableValueFn","setterPaths","setterGetBindableValueFn","customRef","objectSystem.getByPaths","toValue","newValue","objectSystem.setByPaths","useDeepCompareRef","track","trigger","computedInit.isInitial","r","unref","noop","promiseTimeout","ms","throwOnTimeout","reason","resolve","reject","createUntil","isNot","toMatch","condition","flush","deep","timeout","stop","promises","watch","v","nextTick","toBe","options","isRef","v1","v2","toBeTruthy","toBeNull","toBeUndefined","toBeNaN","toContains","array","changed","changedTimes","n","count","until","computedAsync","evaluationCallback","initialState","optionsOrRef","lazy","evaluating","shallow","onError","started","ref","current","shallowRef","counter","watchEffect","onInvalidate","counterAtBeginning","hasFinished","result","cancelCallback","e","computed","useAsyncState","promise","immediate","delay","onSuccess","resetOnExecute","throwError","state","isReady","isLoading","error","execute","delay2","_promise","data","shell","waitUntilIsLoaded","onFulfilled","onRejected","createFnFromString","fnCode","params","keys","values","__Vue","tryStringWithColonToFunction","code","isAsyncFunction","func","createRef","varConfig","debugInfo","deepCompare","createVueComputedByStringCode","snapshot","isConsts","refObjs","p","fnSystem.isAsyncFunction","asyncComputed","fnParams","jsCodeSystem.createFnFromString","createJsComputedByStringCode","inputs","slient","asyncInitValue","deepEqOnInput","slients","datas","watchTargets","_","input","getInputValues","computedInit.__INITIAL__","watchOptions","readonly","varSeqFactory","_scopeMap","createVarStore","scope","indexSeq","varMap","createScopeSnapshot","saveToMap","_a","varBuilder.createRef","_b","init","refObj","_c","varBuilder.createVueComputedByStringCode","_d","varBuilder.createJsComputedByStringCode","_e","scopeId","getVueRef","_getVueRef","scopeMap","clearScopeVarStore","removeIndexVars","varMapIndex","indexMap","createElementRefStore","refMap","eRef","refObject","removeElementRef","refMaps","createElementRefSnapshot","snapshotMap","getRef","elementRef","bindableTools","isVar","bindable","isRouterParams","isRouterAction","isJs","isJsOutput","isVForItem","isVForIndex","isSlotProp","isEventContext","isElementRef","IsBinding","_slotMap","SetupCollect","slotId","seq","updateValues","seqIndex","removeSlotInfo","createSnapshot","valueSeq","getPropsValue","vforSourceMap","fid2keyMap","vforSourceLoopNumberMap","VFOR_KEY","provideVForKey","vforInfo","preInfo","injectVForKey","provide","inject","injectVForFid2keyMap","itemMap","fid","markArray","isBindRef","isLoopNumber","arraySourceGetter","BindableArraySourceGetter","arrayValue","ConstArraySourceGetter","markVForIndex","key2indexMap","keysCollector","usedKeys","add","removeUnusedKeys","createVForSnapshot","currentKey","keyMapSnapshot","getVForIndex","createRefObjectWithPaths","isVForLoopNumber","binding","currentVForIndex","__publicField","orgRef","sourceValue","isDictSource","defaultDictPath","newSourceValue","createFn","bindings","isComputed","isNullOrUndefined","getDevtoolsGlobalHook","getTarget","isProxyAvailable","HOOK_SETUP","HOOK_PLUGIN_SETTINGS_SET","supported","perf","isPerformanceSupported","now","ApiProxy","plugin","hook","defaultSettings","id","item","localSettingsSaveId","currentSettings","raw","pluginId","_target","prop","target","setupDevtoolsPlugin","pluginDescriptor","setupFn","descriptor","enableProxy","proxy","isBrowser","isRouteComponent","component","isESModule","assign","applyToParams","newParams","isArray","warn","msg","HASH_RE","AMPERSAND_RE","SLASH_RE","EQUAL_RE","IM_RE","PLUS_RE","ENC_BRACKET_OPEN_RE","ENC_BRACKET_CLOSE_RE","ENC_CARET_RE","ENC_BACKTICK_RE","ENC_CURLY_OPEN_RE","ENC_PIPE_RE","ENC_CURLY_CLOSE_RE","ENC_SPACE_RE","commonEncode","text","encodeHash","encodeQueryValue","encodeQueryKey","encodePath","encodeParam","decode","define_process_env_default","TRAILING_SLASH_RE","removeTrailingSlash","parseURL","parseQuery","location","currentLocation","query","searchString","hash","hashPos","searchPos","resolveRelativePath","stringifyURL","stringifyQuery","stripBase","pathname","base","isSameRouteLocation","a","b","aLastIndex","bLastIndex","isSameRouteRecord","isSameRouteLocationParams","isSameRouteLocationParamsValue","isEquivalentArray","i","to","from","fromSegments","toSegments","lastToSegment","position","toPosition","segment","START_LOCATION_NORMALIZED","NavigationType","NavigationDirection","START","normalizeBase","baseEl","BEFORE_HASH_RE","createHref","getElementPosition","el","offset","docRect","elRect","computeScrollPosition","scrollToPosition","scrollToOptions","positionEl","isIdSelector","foundEl","getScrollKey","delta","scrollPositions","saveScrollPosition","scrollPosition","getSavedScrollPosition","scroll","createBaseLocation","createCurrentLocation","search","slicePos","pathFromHash","useHistoryListeners","historyState","replace","listeners","teardowns","pauseState","popStateHandler","fromState","listener","pauseListeners","listen","callback","teardown","beforeUnloadListener","history","destroy","buildState","back","forward","replaced","computeScroll","useHistoryStateNavigation","changeLocation","hashIndex","url","err","push","currentState","createWebHistory","historyNavigation","historyListeners","go","triggerListeners","routerHistory","createMemoryHistory","queue","setLocation","direction","shouldTrigger","createWebHashHistory","isRouteLocation","route","isRouteName","name","NavigationFailureSymbol","NavigationFailureType","ErrorTypeMessages","stringifyRoute","createRouterError","type","isNavigationFailure","propertiesToLog","BASE_PARAM_PATTERN","BASE_PATH_PARSER_OPTIONS","REGEX_CHARS_RE","tokensToParser","segments","extraOptions","score","pattern","segmentScores","tokenIndex","token","subSegmentScore","repeatable","optional","regexp","re","subPattern","parse","match","stringify","avoidDuplicatedSlash","param","compareScoreArray","diff","comparePathParserScore","aScore","bScore","comp","isLastScoreNegative","last","ROOT_TOKEN","VALID_PARAM_RE","tokenizePath","crash","message","buffer","previousState","tokens","finalizeSegment","char","customRe","consumeBuffer","addCharToBuffer","createRouteRecordMatcher","record","parent","parser","existingKeys","matcher","createRouterMatcher","routes","globalOptions","matchers","matcherMap","mergeOptions","getRecordMatcher","addRoute","originalRecord","isRootAdd","mainNormalizedRecord","normalizeRouteRecord","checkChildMissingNameWithEmptyPath","normalizedRecords","aliases","alias","originalMatcher","normalizedRecord","parentPath","connectingSlash","checkMissingParamsInAbsolutePath","checkSameParams","isAliasRecord","checkSameNameAsAncestor","removeRoute","isMatchable","insertMatcher","children","matcherRef","getRoutes","findInsertionIndex","invalidParams","paramName","k","paramsFromLocation","m","matched","parentMatcher","mergeMetaFields","clearRoutes","normalized","normalizeRecordProps","propsObject","props","meta","defaults","partialOptions","isSameParam","ancestor","lower","upper","mid","insertionAncestor","getInsertionAncestor","searchParams","searchParam","eqPos","currentValue","normalizeQuery","normalizedQuery","matchedRouteKey","viewDepthKey","routerKey","routeLocationKey","routerViewLocationKey","useCallbacks","handlers","handler","reset","guardToPromiseFn","guard","runWithContext","enterCallbackArray","next","valid","guardReturn","canOnlyBeCalledOnce","guardCall","resolvedValue","called","extractComponentsGuards","guardType","guards","rawComponent","componentPromise","resolved","resolvedComponent","useLink","router","currentRoute","hasPrevious","previousTo","activeRecordIndex","length","routeMatched","currentMatched","parentRecordPath","getOriginalPath","isActive","includesParams","isExactActive","navigate","guardEvent","instance","getCurrentInstance","linkContextDevtools","preferSingleVNode","vnodes","RouterLinkImpl","defineComponent","slots","link","reactive","elClass","getLinkClass","h","RouterLink","outer","inner","innerValue","outerValue","propClass","globalClass","defaultClass","RouterViewImpl","attrs","warnDeprecatedUsage","injectedRoute","routeToDisplay","injectedDepth","depth","initialDepth","matchedRoute","matchedRouteRef","viewRef","oldInstance","oldName","currentName","ViewComponent","normalizeSlot","routePropsOption","routeProps","vnode","slot","slotContent","RouterView","parentName","parentSubTreeType","formatRouteLocation","routeLocation","tooltip","copy","omit","formatDisplay","display","routerId","addDevtools","app","api","payload","ctx","node","componentInstance","PINK_500","devtoolsData","label","backgroundColor","ORANGE_400","textColor","RED_100","RED_700","LIME_500","BLUE_600","refreshRoutesView","routerInspectorId","navigationsLayerId","navigationId","failure","activeRoutesPayload","resetMatchStateOnRouteRecord","isRouteMatching","markRouteRecordActive","formatRouteRecordForInspector","formatRouteRecordMatcherForStateInspector","modifierForKey","fields","CYAN_400","DARK","tags","routeRecordId","EXTRACT_REGEXP_RE","childRoute","filter","found","child","decodedPath","ret","createRouter","parseQuery$1","stringifyQuery$1","beforeGuards","beforeResolveGuards","afterGuards","pendingLocation","normalizeParams","paramValue","encodeParams","decodeParams","parentOrRoute","recordMatcher","routeMatcher","hasRoute","rawLocation","locationNormalized","href","matcherLocation","targetParams","fullPath","locationAsObject","checkCanceledNavigation","pushWithRedirect","handleRedirectRecord","lastMatched","redirect","newTargetLocation","redirectedFrom","targetLocation","force","shouldRedirect","toLocation","handleScroll","markAsReady","triggerError","finalizeNavigation","triggerAfterEach","checkCanceledNavigationAndReject","installedApps","leavingRecords","updatingRecords","enteringRecords","extractChangingRecords","canceledNavigationCheck","runGuardQueue","beforeEnter","isPush","isFirstNavigation","removeHistoryListener","setupListeners","_from","readyHandlers","errorListeners","ready","list","scrollBehavior","reactiveRoute","shallowReactive","unmountApp","len","recordFrom","recordTo","useRouter","useRoute","_name","vforKey","scopeSnapshot","slotSnapshot","slotStore.createSnapshot","vforSnapshot","vforManager.createVForSnapshot","elementRefSnapshot","elementRefStore.createElementRefSnapshot","routerSnapshot","routeSnapshot","replaceSnapshot","getObjectToValue","getVueRefObject","vforManager.isVForLoopNumber","bind","fnBindings","objectSystem.mapObjectForValue","val","getVueRefObjectOrValue","jsStrVar.createFn","vueObj","vueSystem.makeRefObjectWithPaths","vforManager.createRefObjectWithPaths","self","getBindingServerInfo","updateRefFromServer","infos","updateOutputsRefFromServer","outputs","valueSystem.isNullOrUndefined","skips","output","routerMethod","elementObj","method","fnOrValue","WebDataSender","eventType","hKey","componentKey","webServerInfo","appInfo.getInfo","keyObj","eProps","response","appInfo.getPageInfoPostData","watchTask","watchType","inputValues","body","WebViewDataSender","fType","eventInfo","currentDataSender","setupDataSender","getDataSender","toWatchConfig","computedConfig","setupWebWatchStore","watchConfig","snapshots","WebWatchManager","watchTasks","createWatchTaskFn","config","WatchTask","webComputed.toWatchConfig","once","watchOption","TaskNode","constDatas","tasks","task","nextNodes","nextNode","others","taskIdsOfOutput","resultIds","const_data","vueRef","nodes","fetch2server","calcTask","responseData","createVueWatch","sources","onData","bindData","onDatas","bindDatas","_toVueWatchTarget","isData","createJsWatch","objectSystem.deepClone","resultValues","createEvents","events","fns","bindBuilder","prepareBindings","createWebEventHandlerFn","createVueEvent","createJsEvent","bindingsBuilder","handleEvent","set","eventFn","outputValues","handlerStyles","style","styles","_normalizeStyle","handlerClasses","classes","_normalizeClass","strClass","mapClass","bindClass","convertDynamicProperties","recursive","attr","tryConvertDynamicProp","isFunc","handlerProps","staticProps","objectSystem.foreachObject","realValue","toPropValue","propName","toDisplayString","render","propNames","slotSeqIndex","slotStore.SetupCollect","onUnmounted","slotStore.removeSlotInfo","propsValue","slotStore.updateValues","_Fragment","SlotPropContainer","handlerSlots","isHtmlTag","slotConfig","createElements","objectSystem.mapObjectFor","slotName","items","slotProps","childernSlot","createSlotPropsContainer","ScopeContainer","propsInfo","Element","collectDirectives","dirs","newProps","directiveArray","directive","sys","arg","modifers","refValue","mfs","modifier","vModelDynamic","_vShow","handlerElementRef","tag","stringTag","configTypes.bindableTools","resolveDynamicComponent","hasStyle","valueProps","elementRefProps","hProps","_normalizeProps","resultNode","withDirectives","elementRefStoreIndex","storeIndex","VForScope","vforManager.provideVForKey","useLoadAppConfig","appConfig","configUrl","appErrorHandler","vm","componentMessage","__props","appInfo.setup","onErrorCaptured","on","onValue","vif","range","start","end","step","bArray","fkey","num","tsGroup","vforManager.markArray","createKeyFn","createSourceValueArray","vforManager.keysCollector","itemsNode","vforManager.markVForIndex","_TransitionGroup","VFor","numValue","numberSystem.range","source","_item_key_fn","_index_key_fn","jsCodeSystem.tryStringWithColonToFunction","cpNode","Scope","Refresh","itemsRef","helpers","createDynamicWatchRefresh","targetOns","currentWatcher","currentOns","targetRefs","setupWatcher","fetchRemote","fnParamsWithKey","fetchOptions","MatchCase","caseConfig","defaultConfig","bindableHelper.createSnapshot","Match","TransitionGroup","content","getter","Content","extraVueRoutesRecords","isKeepAlive","routeInfo","_config2vueRouteItem","serverLoad","vueItem","_renderByConfig","scopeNode","_KeepAlive","useRouterByAppConfig","mode","install","InstaApp"],"mappings":"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","x_google_ignoreList":[5,6,17,18,19,20,21,22]}