@waline/client 2.0.6 → 2.0.7
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.
- package/dist/component.js +1 -1
- package/dist/component.js.map +1 -1
- package/dist/legacy.js +1 -1
- package/dist/legacy.js.map +1 -1
- package/dist/pageview.cjs.js +1 -1
- package/dist/pageview.esm.js +1 -1
- package/dist/pageview.js +1 -1
- package/dist/shim.esm.js +1 -1
- package/dist/shim.esm.js.map +1 -1
- package/dist/shim.js +1 -1
- package/dist/shim.js.map +1 -1
- package/dist/waline.cjs.js +1 -1
- package/dist/waline.cjs.js.map +1 -1
- package/dist/waline.esm.js +1 -1
- package/dist/waline.esm.js.map +1 -1
- package/dist/waline.js +1 -1
- package/dist/waline.js.map +1 -1
- package/package.json +1 -1
- package/src/components/CommentBox.vue +1 -0
- package/src/utils/config.ts +1 -2
- package/src/utils/emoji.ts +2 -2
package/dist/shim.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"shim.js","sources":["../src/config/default.ts","../src/config/i18n/generate.ts","../src/config/i18n/en.ts","../src/config/i18n/jp.ts","../src/config/i18n/zh-CN.ts","../src/config/i18n/zh-TW.ts","../src/config/i18n/pt-BR.ts","../src/config/i18n/ru.ts","../src/config/i18n/index.ts","../../../node_modules/@vueuse/shared/index.mjs","../../../node_modules/@vueuse/core/index.mjs","../src/composables/inputs.ts","../src/utils/path.ts","../src/utils/config.ts","../src/utils/darkmode.ts","../src/utils/date.ts","../src/utils/emoji.ts","../src/utils/error.ts","../src/utils/fetch.ts","../src/utils/getRoot.ts","../src/utils/image.ts","../src/utils/markedMathExtension.ts","../src/utils/markdown.ts","../src/utils/query.ts","../src/composables/timeAgo.ts","../src/composables/userInfo.ts","../src/comment.ts","../src/components/Icons.ts","../src/components/CommentBox.vue","../src/utils/wordCount.ts","../src/components/CommentBox.vue?vue&type=template&id=969569c8&lang.js","../src/components/CommentCard.vue","../src/components/CommentCard.vue?vue&type=template&id=5dd9348f&lang.js","../src/components/Waline.vue","../src/components/Waline.vue?vue&type=template&id=222c3e24&lang.js","../src/pageview.ts","../src/widgets/recentComments.ts","../src/init.ts","../src/version.ts"],"sourcesContent":["import type { WalineMeta } from '../typings';\n\nconst availableMeta: WalineMeta[] = ['nick', 'mail', 'link'];\n\nexport const getMeta = (meta: WalineMeta[]): WalineMeta[] =>\n meta.filter((item) => availableMeta.includes(item));\n\nexport const defaultLang = 'zh-CN';\n\nexport const defaultUploadImage = (file: File): Promise<string> =>\n new Promise((resolve, reject) => {\n const reader = new FileReader();\n reader.readAsDataURL(file);\n reader.onload = (): void => resolve(reader.result?.toString() || '');\n reader.onerror = reject;\n });\n\nexport const defaultTexRenderer = (blockMode: boolean): string =>\n blockMode === true\n ? '<p class=\"wl-tex\">Tex is not available in preview</p>'\n : '<span class=\"wl-tex\">Tex is not available in preview</span>';\n","import type { WalineLocale } from '../../typings';\n\nconst localeKeys = [\n 'nick',\n 'nickError',\n 'mail',\n 'mailError',\n 'link',\n 'optional',\n 'placeholder',\n 'sofa',\n 'submit',\n 'reply',\n 'cancelReply',\n 'comment',\n 'refresh',\n 'more',\n 'preview',\n 'emoji',\n 'uploadImage',\n 'seconds',\n 'minutes',\n 'hours',\n 'days',\n 'now',\n 'uploading',\n 'login',\n 'logout',\n 'admin',\n 'sticky',\n 'word',\n 'wordHint',\n 'anonymous',\n];\n\nexport const generateLocale = (locale: string[]): WalineLocale =>\n Object.fromEntries(\n locale.map((item, index) => [localeKeys[index], item])\n ) as unknown as WalineLocale;\n","import { generateLocale } from './generate';\n\nexport default generateLocale([\n 'NickName',\n 'NickName cannot be less than 3 bytes.',\n 'E-Mail',\n 'Please confirm your email address.',\n 'Website',\n 'Optional',\n 'Comment here...',\n 'No comment yet.',\n 'Submit',\n 'Reply',\n 'Cancel reply',\n 'Comments',\n 'Refresh',\n 'Load More...',\n 'Preview',\n 'Emoji',\n 'Upload Image',\n 'seconds ago',\n 'minutes ago',\n 'hours ago',\n 'days ago',\n 'just now',\n 'Uploading',\n 'Login',\n 'logout',\n 'Admin',\n 'Sticky',\n 'Words',\n 'Please input comments between $0 and $1 words!\\n Current word number: $2',\n 'Anonymous',\n]);\n","import { generateLocale } from './generate';\n\nexport default generateLocale([\n 'ニックネーム',\n '3バイト以上のニックネームをご入力ください.',\n 'メールアドレス',\n 'メールアドレスをご確認ください.',\n 'サイト',\n 'オプション',\n 'ここにコメント',\n 'コメントしましょう~',\n '提出する',\n '返信する',\n 'キャンセル',\n 'コメント',\n '更新',\n 'さらに読み込む',\n 'プレビュー',\n '絵文字',\n '画像をアップロード',\n '秒前',\n '分前',\n '時間前',\n '日前',\n 'たっだ今',\n 'アップロード',\n 'ログインする',\n 'ログアウト',\n '管理者',\n 'トップに置く',\n 'ワード',\n 'コメントは $0 から $1 ワードの間でなければなりません!\\n 現在の単語番号: $2',\n '匿名',\n]);\n","import { generateLocale } from './generate';\n\nexport default generateLocale([\n '昵称',\n '昵称不能少于3个字符',\n '邮箱',\n '请填写正确的邮件地址',\n '网址',\n '可选',\n '欢迎评论',\n '来发评论吧~',\n '提交',\n '回复',\n '取消回复',\n '评论',\n '刷新',\n '加载更多...',\n '预览',\n '表情',\n '上传图片',\n '秒前',\n '分钟前',\n '小时前',\n '天前',\n '刚刚',\n '正在上传',\n '登录',\n '退出',\n '博主',\n '置顶',\n '字',\n '评论字数应在 $0 到 $1 字之间!\\n当前字数:$2',\n '匿名',\n]);\n","import { generateLocale } from './generate';\n\nexport default generateLocale([\n '暱稱',\n '郵箱',\n '網址',\n '可選',\n '暱稱不能少於3個字元',\n '請填寫正確的郵件地址',\n '歡迎評論',\n '來發評論吧~',\n '提交',\n '回覆',\n '取消回覆',\n '評論',\n '刷新',\n '載入更多...',\n '預覽',\n '表情',\n '上傳圖片',\n '秒前',\n '分鐘前',\n '小時前',\n '天前',\n '剛剛',\n '正在上傳',\n '登錄',\n '退出',\n '博主',\n '置頂',\n '字',\n '評論字數應在 $0 到 $1 字之間!\\n當前字數:$2',\n '匿名',\n]);\n","import { generateLocale } from './generate';\n\nexport default generateLocale([\n 'Apelido',\n 'Apelido não pode ser menor que 3 bytes.',\n 'E-Mail',\n 'Por favor, confirme seu endereço de e-mail.',\n 'Website',\n 'Opcional',\n 'Comente aqui...',\n 'Nenhum comentário, ainda.',\n 'Enviar',\n 'Responder',\n 'Cancelar resposta',\n 'Comentários',\n 'Refrescar',\n 'Carregar Mais...',\n 'Visualizar',\n 'Emoji',\n 'Enviar Imagem',\n 'segundos atrás',\n 'minutos atrás',\n 'horas atrás',\n 'dias atrás',\n 'agora mesmo',\n 'Enviando',\n 'Entrar',\n 'Sair',\n 'Admin',\n 'Sticky',\n 'Palavras',\n 'Favor enviar comentário com $0 a $1 palavras!\\n Número de palavras atuais: $2',\n 'Anônimo',\n]);\n","import { generateLocale } from './generate';\n\nexport default generateLocale([\n 'Псевдоним',\n 'Никнейм не может быть меньше 3 байт.',\n 'Эл. адрес',\n 'Пожалуйста, подтвердите адрес вашей электронной почты.',\n 'Веб-сайт',\n 'Необязательный',\n 'Комментарий здесь...',\n 'Пока нет комментариев.',\n 'Отправить',\n 'Отвечать',\n 'Отменить ответ',\n 'Комментарии',\n 'Обновить',\n 'Загрузи больше...',\n 'Превью',\n 'эмодзи',\n 'Загрузить изображение',\n 'секунд назад',\n 'несколько минут назад',\n 'несколько часов назад',\n 'дней назад',\n 'прямо сейчас',\n 'Загрузка',\n 'Авторизоваться',\n 'Выход из системы',\n 'Админ',\n 'Липкий',\n 'Слова',\n 'Пожалуйста, введите комментарии от $0 до $1 слов!\\nНомер текущего слова: $2',\n 'Анонимный',\n]);\n","/* eslint-disable @typescript-eslint/naming-convention */\nimport en from './en';\nimport jp from './jp';\nimport zhCN from './zh-CN';\nimport zhTW from './zh-TW';\nimport ptBR from './pt-BR';\nimport ru from './ru';\n\nimport type { WalineLocale } from '../../typings';\n\nexport type Locales = Record<string, WalineLocale>;\n\nexport const locales: Locales = {\n zh: zhCN,\n 'zh-cn': zhCN,\n 'zh-CN': zhCN,\n 'zh-tw': zhTW,\n 'zh-TW': zhTW,\n en: en,\n 'en-US': en,\n 'en-us': en,\n jp: jp,\n 'jp-jp': jp,\n 'jp-JP': jp,\n 'pt-br': ptBR,\n 'pt-BR': ptBR,\n ru: ru,\n 'ru-ru': ru,\n 'ru-RU': ru,\n};\n","import { shallowRef, watchEffect, readonly, ref, watch, customRef, effectScope, provide, inject, getCurrentScope, onScopeDispose, isVue3, isRef, unref, computed, reactive, toRefs as toRefs$1, toRef, isVue2, set as set$1, getCurrentInstance, onBeforeMount, nextTick, onBeforeUnmount, onMounted, onUnmounted } from 'vue-demi';\n\nvar __defProp$8 = Object.defineProperty;\nvar __defProps$5 = Object.defineProperties;\nvar __getOwnPropDescs$5 = Object.getOwnPropertyDescriptors;\nvar __getOwnPropSymbols$a = Object.getOwnPropertySymbols;\nvar __hasOwnProp$a = Object.prototype.hasOwnProperty;\nvar __propIsEnum$a = Object.prototype.propertyIsEnumerable;\nvar __defNormalProp$8 = (obj, key, value) => key in obj ? __defProp$8(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;\nvar __spreadValues$8 = (a, b) => {\n for (var prop in b || (b = {}))\n if (__hasOwnProp$a.call(b, prop))\n __defNormalProp$8(a, prop, b[prop]);\n if (__getOwnPropSymbols$a)\n for (var prop of __getOwnPropSymbols$a(b)) {\n if (__propIsEnum$a.call(b, prop))\n __defNormalProp$8(a, prop, b[prop]);\n }\n return a;\n};\nvar __spreadProps$5 = (a, b) => __defProps$5(a, __getOwnPropDescs$5(b));\nfunction computedEager(fn, options) {\n var _a;\n const result = shallowRef();\n watchEffect(() => {\n result.value = fn();\n }, __spreadProps$5(__spreadValues$8({}, 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 watch(source, () => {\n dirty.value = true;\n trigger();\n }, { flush: \"sync\" });\n return customRef((_track, _trigger) => {\n track = _track;\n trigger = _trigger;\n return {\n get() {\n if (dirty.value) {\n v = fn();\n dirty.value = false;\n }\n track();\n return v;\n },\n set() {\n }\n };\n });\n}\n\nfunction createEventHook() {\n const fns = [];\n const off = (fn) => {\n const index = fns.indexOf(fn);\n if (index !== -1)\n fns.splice(index, 1);\n };\n const on = (fn) => {\n fns.push(fn);\n return {\n off: () => off(fn)\n };\n };\n const trigger = (param) => {\n fns.forEach((fn) => fn(param));\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 () => {\n if (!initialized) {\n state = scope.run(stateFactory);\n initialized = true;\n }\n return state;\n };\n}\n\nfunction createInjectionState(composable) {\n const key = Symbol(\"InjectionState\");\n const useProvidingState = (...args) => {\n provide(key, composable(...args));\n };\n const useInjectedState = () => inject(key);\n return [useProvidingState, useInjectedState];\n}\n\nfunction tryOnScopeDispose(fn) {\n if (getCurrentScope()) {\n onScopeDispose(fn);\n return true;\n }\n return false;\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 (!state) {\n scope = effectScope(true);\n state = scope.run(() => composable(...args));\n }\n tryOnScopeDispose(dispose);\n return state;\n };\n}\n\nfunction __onlyVue3(name = \"this function\") {\n if (isVue3)\n return;\n throw new Error(`[VueUse] ${name} is only works on Vue 3.`);\n}\nconst directiveHooks = {\n mounted: isVue3 ? \"mounted\" : \"inserted\",\n updated: isVue3 ? \"updated\" : \"componentUpdated\",\n unmounted: isVue3 ? \"unmounted\" : \"unbind\"\n};\n\nfunction extendRef(ref, extend, { enumerable = false, unwrap = true } = {}) {\n __onlyVue3();\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 logicAnd(...args) {\n return computed(() => args.every((i) => unref(i)));\n}\n\nfunction logicNot(v) {\n return computed(() => !unref(v));\n}\n\nfunction logicOr(...args) {\n return computed(() => args.some((i) => unref(i)));\n}\n\nvar __defProp$7 = Object.defineProperty;\nvar __getOwnPropSymbols$9 = Object.getOwnPropertySymbols;\nvar __hasOwnProp$9 = Object.prototype.hasOwnProperty;\nvar __propIsEnum$9 = Object.prototype.propertyIsEnumerable;\nvar __defNormalProp$7 = (obj, key, value) => key in obj ? __defProp$7(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;\nvar __spreadValues$7 = (a, b) => {\n for (var prop in b || (b = {}))\n if (__hasOwnProp$9.call(b, prop))\n __defNormalProp$7(a, prop, b[prop]);\n if (__getOwnPropSymbols$9)\n for (var prop of __getOwnPropSymbols$9(b)) {\n if (__propIsEnum$9.call(b, prop))\n __defNormalProp$7(a, prop, b[prop]);\n }\n return a;\n};\nfunction makeDestructurable(obj, arr) {\n if (typeof Symbol !== \"undefined\") {\n const clone = __spreadValues$7({}, 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 reactify(fn) {\n return function(...args) {\n return computed(() => fn.apply(this, args.map((i) => unref(i))));\n };\n}\n\nfunction reactifyObject(obj, optionsOrKeys = {}) {\n let keys = [];\n if (Array.isArray(optionsOrKeys)) {\n keys = optionsOrKeys;\n } else {\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(keys.map((key) => {\n const value = obj[key];\n return [\n key,\n typeof value === \"function\" ? reactify(value.bind(obj)) : value\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 return reactiveComputed(() => Object.fromEntries(Object.entries(toRefs$1(obj)).filter((e) => !keys.includes(e[0]))));\n}\n\nfunction reactivePick(obj, ...keys) {\n return reactive(Object.fromEntries(keys.map((k) => [k, toRef(obj, k)])));\n}\n\nfunction refAutoReset(defaultValue, afterMs = 1e4) {\n return customRef((track, trigger) => {\n let value = defaultValue;\n let timer;\n const resetAfter = () => setTimeout(() => {\n value = defaultValue;\n trigger();\n }, unref(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\nconst isClient = typeof window !== \"undefined\";\nconst isDef = (val) => typeof val !== \"undefined\";\nconst assert = (condition, ...infos) => {\n if (!condition)\n console.warn(...infos);\n};\nconst toString = Object.prototype.toString;\nconst isBoolean = (val) => typeof val === \"boolean\";\nconst isFunction = (val) => typeof val === \"function\";\nconst isNumber = (val) => typeof val === \"number\";\nconst isString = (val) => typeof val === \"string\";\nconst isObject = (val) => toString.call(val) === \"[object Object]\";\nconst isWindow = (val) => typeof window !== \"undefined\" && toString.call(val) === \"[object Window]\";\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};\n\nfunction createFilterWrapper(filter, fn) {\n function wrapper(...args) {\n filter(() => fn.apply(this, args), { fn, thisArg: this, args });\n }\n return wrapper;\n}\nconst bypassFilter = (invoke) => {\n return invoke();\n};\nfunction debounceFilter(ms, options = {}) {\n let timer;\n let maxTimer;\n const filter = (invoke) => {\n const duration = unref(ms);\n const maxDuration = unref(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 invoke();\n }\n if (maxDuration && !maxTimer) {\n maxTimer = setTimeout(() => {\n if (timer)\n clearTimeout(timer);\n maxTimer = null;\n invoke();\n }, maxDuration);\n }\n timer = setTimeout(() => {\n if (maxTimer)\n clearTimeout(maxTimer);\n maxTimer = null;\n invoke();\n }, duration);\n };\n return filter;\n}\nfunction throttleFilter(ms, trailing = true, leading = true) {\n let lastExec = 0;\n let timer;\n let preventLeading = !leading;\n const clear = () => {\n if (timer) {\n clearTimeout(timer);\n timer = void 0;\n }\n };\n const filter = (invoke) => {\n const duration = unref(ms);\n const elapsed = Date.now() - lastExec;\n clear();\n if (duration <= 0) {\n lastExec = Date.now();\n return invoke();\n }\n if (elapsed > duration) {\n lastExec = Date.now();\n if (preventLeading)\n preventLeading = false;\n else\n invoke();\n }\n if (trailing) {\n timer = setTimeout(() => {\n lastExec = Date.now();\n if (!leading)\n preventLeading = true;\n clear();\n invoke();\n }, duration);\n }\n if (!leading && !timer)\n timer = setTimeout(() => preventLeading = true, duration);\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, pause, resume, eventFilter };\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(/^-?[0-9]+\\.?[0-9]*/)) == null ? void 0 : _a[0]) || \"\";\n const unit = target.slice(value.length);\n const result = 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}\n\nfunction useDebounceFn(fn, ms = 200, options = {}) {\n return createFilterWrapper(debounceFilter(ms, options), fn);\n}\n\nfunction refDebounced(value, ms = 200, options = {}) {\n if (ms <= 0)\n return value;\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 = true, leading = true) {\n return createFilterWrapper(throttleFilter(ms, trailing, leading), fn);\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(ref, {\n get,\n set,\n untrackedGet,\n silentSet,\n peek,\n lay\n }, { enumerable: true });\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 if (isVue2) {\n set$1(...args);\n } else {\n const [target, key, value] = args;\n target[key] = value;\n }\n }\n}\n\nfunction syncRef(left, right, options = {}) {\n const {\n flush = \"sync\",\n deep = false,\n immediate = true,\n direction = \"both\"\n } = options;\n let stop1, stop2;\n if (direction === \"both\" || direction === \"ltr\") {\n stop1 = watch(left, (newValue) => right.value = newValue, { flush, deep, immediate });\n }\n if (direction === \"both\" || direction === \"rtl\") {\n stop2 = watch(right, (newValue) => left.value = newValue, { flush, deep, immediate });\n }\n return () => {\n stop1 == null ? void 0 : stop1();\n stop2 == null ? void 0 : stop2();\n };\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(source, (newValue) => targets.forEach((target) => target.value = newValue), { flush, deep, immediate });\n}\n\nvar __defProp$6 = Object.defineProperty;\nvar __defProps$4 = Object.defineProperties;\nvar __getOwnPropDescs$4 = Object.getOwnPropertyDescriptors;\nvar __getOwnPropSymbols$8 = Object.getOwnPropertySymbols;\nvar __hasOwnProp$8 = Object.prototype.hasOwnProperty;\nvar __propIsEnum$8 = Object.prototype.propertyIsEnumerable;\nvar __defNormalProp$6 = (obj, key, value) => key in obj ? __defProp$6(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;\nvar __spreadValues$6 = (a, b) => {\n for (var prop in b || (b = {}))\n if (__hasOwnProp$8.call(b, prop))\n __defNormalProp$6(a, prop, b[prop]);\n if (__getOwnPropSymbols$8)\n for (var prop of __getOwnPropSymbols$8(b)) {\n if (__propIsEnum$8.call(b, prop))\n __defNormalProp$6(a, prop, b[prop]);\n }\n return a;\n};\nvar __spreadProps$4 = (a, b) => __defProps$4(a, __getOwnPropDescs$4(b));\nfunction toRefs(objectRef) {\n if (!isRef(objectRef))\n return toRefs$1(objectRef);\n const result = Array.isArray(objectRef.value) ? new Array(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 if (Array.isArray(objectRef.value)) {\n const copy = [...objectRef.value];\n copy[key] = v;\n objectRef.value = copy;\n } else {\n objectRef.value = __spreadProps$4(__spreadValues$6({}, objectRef.value), { [key]: v });\n }\n }\n }));\n }\n return result;\n}\n\nfunction tryOnBeforeMount(fn, sync = true) {\n if (getCurrentInstance())\n onBeforeMount(fn);\n else if (sync)\n fn();\n else\n nextTick(fn);\n}\n\nfunction tryOnBeforeUnmount(fn) {\n if (getCurrentInstance())\n onBeforeUnmount(fn);\n}\n\nfunction tryOnMounted(fn, sync = true) {\n if (getCurrentInstance())\n onMounted(fn);\n else if (sync)\n fn();\n else\n nextTick(fn);\n}\n\nfunction tryOnUnmounted(fn) {\n if (getCurrentInstance())\n onUnmounted(fn);\n}\n\nfunction until(r) {\n let 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(r, (v) => {\n if (condition(v) === !isNot) {\n stop == null ? void 0 : stop();\n resolve();\n }\n }, {\n flush,\n deep,\n immediate: true\n });\n });\n const promises = [watcher];\n if (timeout) {\n promises.push(promiseTimeout(timeout, throwOnTimeout).finally(() => {\n stop == null ? void 0 : stop();\n }));\n }\n return Promise.race(promises);\n }\n function toBe(value, options) {\n return toMatch((v) => v === unref(value), options);\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(unref(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(unref(r))) {\n const instance = {\n toMatch,\n toContains,\n changed,\n changedTimes,\n get not() {\n isNot = !isNot;\n return this;\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 isNot = !isNot;\n return this;\n }\n };\n return instance;\n }\n}\n\nfunction useCounter(initialValue = 0, options = {}) {\n const count = ref(initialValue);\n const {\n max = Infinity,\n min = -Infinity\n } = options;\n const inc = (delta = 1) => count.value = Math.min(max, count.value + delta);\n const dec = (delta = 1) => count.value = Math.max(min, count.value - delta);\n const get = () => count.value;\n const set = (val) => count.value = 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})[Tt\\s]*(\\d{1,2})?:?(\\d{1,2})?:?(\\d{1,2})?[.:]?(\\d+)?$/;\nconst REGEX_FORMAT = /\\[([^\\]]+)]|Y{1,4}|M{1,4}|D{1,2}|d{1,4}|H{1,2}|h{1,2}|a|A|m{1,2}|s{1,2}|Z{1,2}|SSS/g;\nconst formatDate = (date, formatStr) => {\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 matches = {\n YY: String(years).slice(-2),\n YYYY: years,\n M: month + 1,\n MM: `${month + 1}`.padStart(2, \"0\"),\n D: String(days),\n DD: `${days}`.padStart(2, \"0\"),\n H: String(hours),\n HH: `${hours}`.padStart(2, \"0\"),\n h: `${hours % 12 || 12}`.padStart(1, \"0\"),\n hh: `${hours % 12 || 12}`.padStart(2, \"0\"),\n m: String(minutes),\n mm: `${minutes}`.padStart(2, \"0\"),\n s: String(seconds),\n ss: `${seconds}`.padStart(2, \"0\"),\n SSS: `${milliseconds}`.padStart(3, \"0\"),\n d: day\n };\n return formatStr.replace(REGEX_FORMAT, (match, $1) => $1 || matches[match]);\n};\nconst normalizeDate = (date) => {\n if (date === null)\n return new Date(NaN);\n if (date === void 0)\n return 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\") {\n return computed(() => formatDate(normalizeDate(unref(date)), unref(formatStr)));\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 if (interval <= 0)\n return;\n isActive.value = true;\n if (immediateCallback)\n cb();\n clean();\n timer = setInterval(cb, unref(interval));\n }\n if (immediate && isClient)\n resume();\n if (isRef(interval)) {\n const stopWatch = watch(interval, () => {\n if (immediate && isClient)\n resume();\n });\n tryOnScopeDispose(stopWatch);\n }\n tryOnScopeDispose(pause);\n return {\n isActive,\n pause,\n resume\n };\n}\n\nvar __defProp$5 = Object.defineProperty;\nvar __getOwnPropSymbols$7 = Object.getOwnPropertySymbols;\nvar __hasOwnProp$7 = Object.prototype.hasOwnProperty;\nvar __propIsEnum$7 = Object.prototype.propertyIsEnumerable;\nvar __defNormalProp$5 = (obj, key, value) => key in obj ? __defProp$5(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;\nvar __spreadValues$5 = (a, b) => {\n for (var prop in b || (b = {}))\n if (__hasOwnProp$7.call(b, prop))\n __defNormalProp$5(a, prop, b[prop]);\n if (__getOwnPropSymbols$7)\n for (var prop of __getOwnPropSymbols$7(b)) {\n if (__propIsEnum$7.call(b, prop))\n __defNormalProp$5(a, prop, b[prop]);\n }\n return a;\n};\nfunction useInterval(interval = 1e3, options = {}) {\n const {\n controls: exposeControls = false,\n immediate = true\n } = options;\n const counter = ref(0);\n const controls = useIntervalFn(() => counter.value += 1, interval, { immediate });\n if (exposeControls) {\n return __spreadValues$5({\n counter\n }, controls);\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(source, () => ms.value = timestamp(), options);\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 }, unref(interval));\n }\n if (immediate) {\n isPending.value = true;\n if (isClient)\n start();\n }\n tryOnScopeDispose(stop);\n return {\n isPending,\n start,\n stop\n };\n}\n\nvar __defProp$4 = Object.defineProperty;\nvar __getOwnPropSymbols$6 = Object.getOwnPropertySymbols;\nvar __hasOwnProp$6 = Object.prototype.hasOwnProperty;\nvar __propIsEnum$6 = Object.prototype.propertyIsEnumerable;\nvar __defNormalProp$4 = (obj, key, value) => key in obj ? __defProp$4(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;\nvar __spreadValues$4 = (a, b) => {\n for (var prop in b || (b = {}))\n if (__hasOwnProp$6.call(b, prop))\n __defNormalProp$4(a, prop, b[prop]);\n if (__getOwnPropSymbols$6)\n for (var prop of __getOwnPropSymbols$6(b)) {\n if (__propIsEnum$6.call(b, prop))\n __defNormalProp$4(a, prop, b[prop]);\n }\n return a;\n};\nfunction useTimeout(interval = 1e3, options = {}) {\n const {\n controls: exposeControls = false\n } = options;\n const controls = useTimeoutFn(noop, interval, options);\n const ready = computed(() => !controls.isPending.value);\n if (exposeControls) {\n return __spreadValues$4({\n ready\n }, controls);\n } else {\n return ready;\n }\n}\n\nfunction useToggle(initialValue = false) {\n if (isRef(initialValue)) {\n return (value) => {\n initialValue.value = typeof value === \"boolean\" ? value : !initialValue.value;\n return initialValue.value;\n };\n } else {\n const boolean = ref(initialValue);\n const toggle = (value) => {\n boolean.value = typeof value === \"boolean\" ? value : !boolean.value;\n return boolean.value;\n };\n return [boolean, toggle];\n }\n}\n\nvar __getOwnPropSymbols$5 = Object.getOwnPropertySymbols;\nvar __hasOwnProp$5 = Object.prototype.hasOwnProperty;\nvar __propIsEnum$5 = Object.prototype.propertyIsEnumerable;\nvar __objRest$5 = (source, exclude) => {\n var target = {};\n for (var prop in source)\n if (__hasOwnProp$5.call(source, prop) && exclude.indexOf(prop) < 0)\n target[prop] = source[prop];\n if (source != null && __getOwnPropSymbols$5)\n for (var prop of __getOwnPropSymbols$5(source)) {\n if (exclude.indexOf(prop) < 0 && __propIsEnum$5.call(source, prop))\n target[prop] = source[prop];\n }\n return target;\n};\nfunction watchWithFilter(source, cb, options = {}) {\n const _a = options, {\n eventFilter = bypassFilter\n } = _a, watchOptions = __objRest$5(_a, [\n \"eventFilter\"\n ]);\n return watch(source, createFilterWrapper(eventFilter, cb), watchOptions);\n}\n\nvar __getOwnPropSymbols$4 = Object.getOwnPropertySymbols;\nvar __hasOwnProp$4 = Object.prototype.hasOwnProperty;\nvar __propIsEnum$4 = Object.prototype.propertyIsEnumerable;\nvar __objRest$4 = (source, exclude) => {\n var target = {};\n for (var prop in source)\n if (__hasOwnProp$4.call(source, prop) && exclude.indexOf(prop) < 0)\n target[prop] = source[prop];\n if (source != null && __getOwnPropSymbols$4)\n for (var prop of __getOwnPropSymbols$4(source)) {\n if (exclude.indexOf(prop) < 0 && __propIsEnum$4.call(source, prop))\n target[prop] = source[prop];\n }\n return target;\n};\nfunction watchAtMost(source, cb, options) {\n const _a = options, {\n count\n } = _a, watchOptions = __objRest$4(_a, [\n \"count\"\n ]);\n const current = ref(0);\n const stop = watchWithFilter(source, (...args) => {\n current.value += 1;\n if (current.value >= unref(count))\n nextTick(() => stop());\n cb(...args);\n }, watchOptions);\n return { count: current, stop };\n}\n\nvar __defProp$3 = Object.defineProperty;\nvar __defProps$3 = Object.defineProperties;\nvar __getOwnPropDescs$3 = Object.getOwnPropertyDescriptors;\nvar __getOwnPropSymbols$3 = Object.getOwnPropertySymbols;\nvar __hasOwnProp$3 = Object.prototype.hasOwnProperty;\nvar __propIsEnum$3 = Object.prototype.propertyIsEnumerable;\nvar __defNormalProp$3 = (obj, key, value) => key in obj ? __defProp$3(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;\nvar __spreadValues$3 = (a, b) => {\n for (var prop in b || (b = {}))\n if (__hasOwnProp$3.call(b, prop))\n __defNormalProp$3(a, prop, b[prop]);\n if (__getOwnPropSymbols$3)\n for (var prop of __getOwnPropSymbols$3(b)) {\n if (__propIsEnum$3.call(b, prop))\n __defNormalProp$3(a, prop, b[prop]);\n }\n return a;\n};\nvar __spreadProps$3 = (a, b) => __defProps$3(a, __getOwnPropDescs$3(b));\nvar __objRest$3 = (source, exclude) => {\n var target = {};\n for (var prop in source)\n if (__hasOwnProp$3.call(source, prop) && exclude.indexOf(prop) < 0)\n target[prop] = source[prop];\n if (source != null && __getOwnPropSymbols$3)\n for (var prop of __getOwnPropSymbols$3(source)) {\n if (exclude.indexOf(prop) < 0 && __propIsEnum$3.call(source, prop))\n target[prop] = source[prop];\n }\n return target;\n};\nfunction watchDebounced(source, cb, options = {}) {\n const _a = options, {\n debounce = 0\n } = _a, watchOptions = __objRest$3(_a, [\n \"debounce\"\n ]);\n return watchWithFilter(source, cb, __spreadProps$3(__spreadValues$3({}, watchOptions), {\n eventFilter: debounceFilter(debounce)\n }));\n}\n\nvar __defProp$2 = Object.defineProperty;\nvar __defProps$2 = Object.defineProperties;\nvar __getOwnPropDescs$2 = Object.getOwnPropertyDescriptors;\nvar __getOwnPropSymbols$2 = Object.getOwnPropertySymbols;\nvar __hasOwnProp$2 = Object.prototype.hasOwnProperty;\nvar __propIsEnum$2 = Object.prototype.propertyIsEnumerable;\nvar __defNormalProp$2 = (obj, key, value) => key in obj ? __defProp$2(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;\nvar __spreadValues$2 = (a, b) => {\n for (var prop in b || (b = {}))\n if (__hasOwnProp$2.call(b, prop))\n __defNormalProp$2(a, prop, b[prop]);\n if (__getOwnPropSymbols$2)\n for (var prop of __getOwnPropSymbols$2(b)) {\n if (__propIsEnum$2.call(b, prop))\n __defNormalProp$2(a, prop, b[prop]);\n }\n return a;\n};\nvar __spreadProps$2 = (a, b) => __defProps$2(a, __getOwnPropDescs$2(b));\nvar __objRest$2 = (source, exclude) => {\n var target = {};\n for (var prop in source)\n if (__hasOwnProp$2.call(source, prop) && exclude.indexOf(prop) < 0)\n target[prop] = source[prop];\n if (source != null && __getOwnPropSymbols$2)\n for (var prop of __getOwnPropSymbols$2(source)) {\n if (exclude.indexOf(prop) < 0 && __propIsEnum$2.call(source, prop))\n target[prop] = source[prop];\n }\n return target;\n};\nfunction watchIgnorable(source, cb, options = {}) {\n const _a = options, {\n eventFilter = bypassFilter\n } = _a, watchOptions = __objRest$2(_a, [\n \"eventFilter\"\n ]);\n const filteredCb = createFilterWrapper(eventFilter, cb);\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(source, (...args) => {\n if (!ignore.value)\n filteredCb(...args);\n }, watchOptions);\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(watch(source, () => {\n syncCounter.value++;\n }, __spreadProps$2(__spreadValues$2({}, watchOptions), { flush: \"sync\" })));\n ignoreUpdates = (updater) => {\n const syncCounterPrev = syncCounter.value;\n updater();\n ignoreCounter.value += syncCounter.value - syncCounterPrev;\n };\n disposables.push(watch(source, (...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 }, watchOptions));\n stop = () => {\n disposables.forEach((fn) => fn());\n };\n }\n return { stop, ignoreUpdates, ignorePrevAsyncUpdates };\n}\n\nfunction watchOnce(source, cb, options) {\n const stop = watch(source, (...args) => {\n nextTick(() => stop());\n return cb(...args);\n }, options);\n}\n\nvar __defProp$1 = Object.defineProperty;\nvar __defProps$1 = Object.defineProperties;\nvar __getOwnPropDescs$1 = Object.getOwnPropertyDescriptors;\nvar __getOwnPropSymbols$1 = Object.getOwnPropertySymbols;\nvar __hasOwnProp$1 = Object.prototype.hasOwnProperty;\nvar __propIsEnum$1 = Object.prototype.propertyIsEnumerable;\nvar __defNormalProp$1 = (obj, key, value) => key in obj ? __defProp$1(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;\nvar __spreadValues$1 = (a, b) => {\n for (var prop in b || (b = {}))\n if (__hasOwnProp$1.call(b, prop))\n __defNormalProp$1(a, prop, b[prop]);\n if (__getOwnPropSymbols$1)\n for (var prop of __getOwnPropSymbols$1(b)) {\n if (__propIsEnum$1.call(b, prop))\n __defNormalProp$1(a, prop, b[prop]);\n }\n return a;\n};\nvar __spreadProps$1 = (a, b) => __defProps$1(a, __getOwnPropDescs$1(b));\nvar __objRest$1 = (source, exclude) => {\n var target = {};\n for (var prop in source)\n if (__hasOwnProp$1.call(source, prop) && exclude.indexOf(prop) < 0)\n target[prop] = source[prop];\n if (source != null && __getOwnPropSymbols$1)\n for (var prop of __getOwnPropSymbols$1(source)) {\n if (exclude.indexOf(prop) < 0 && __propIsEnum$1.call(source, prop))\n target[prop] = source[prop];\n }\n return target;\n};\nfunction watchPausable(source, cb, options = {}) {\n const _a = options, {\n eventFilter: filter\n } = _a, watchOptions = __objRest$1(_a, [\n \"eventFilter\"\n ]);\n const { eventFilter, pause, resume, isActive } = pausableFilter(filter);\n const stop = watchWithFilter(source, cb, __spreadProps$1(__spreadValues$1({}, watchOptions), {\n eventFilter\n }));\n return { stop, pause, resume, isActive };\n}\n\nvar __defProp = Object.defineProperty;\nvar __defProps = Object.defineProperties;\nvar __getOwnPropDescs = Object.getOwnPropertyDescriptors;\nvar __getOwnPropSymbols = Object.getOwnPropertySymbols;\nvar __hasOwnProp = Object.prototype.hasOwnProperty;\nvar __propIsEnum = Object.prototype.propertyIsEnumerable;\nvar __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;\nvar __spreadValues = (a, b) => {\n for (var prop in b || (b = {}))\n if (__hasOwnProp.call(b, prop))\n __defNormalProp(a, prop, b[prop]);\n if (__getOwnPropSymbols)\n for (var prop of __getOwnPropSymbols(b)) {\n if (__propIsEnum.call(b, prop))\n __defNormalProp(a, prop, b[prop]);\n }\n return a;\n};\nvar __spreadProps = (a, b) => __defProps(a, __getOwnPropDescs(b));\nvar __objRest = (source, exclude) => {\n var target = {};\n for (var prop in source)\n if (__hasOwnProp.call(source, prop) && exclude.indexOf(prop) < 0)\n target[prop] = source[prop];\n if (source != null && __getOwnPropSymbols)\n for (var prop of __getOwnPropSymbols(source)) {\n if (exclude.indexOf(prop) < 0 && __propIsEnum.call(source, prop))\n target[prop] = source[prop];\n }\n return target;\n};\nfunction watchThrottled(source, cb, options = {}) {\n const _a = options, {\n throttle = 0,\n trailing = true,\n leading = true\n } = _a, watchOptions = __objRest(_a, [\n \"throttle\",\n \"trailing\",\n \"leading\"\n ]);\n return watchWithFilter(source, cb, __spreadProps(__spreadValues({}, watchOptions), {\n eventFilter: throttleFilter(throttle, trailing, leading)\n }));\n}\n\nfunction whenever(source, cb, options) {\n return watch(source, (v, ov, onInvalidate) => {\n if (v)\n cb(v, ov, onInvalidate);\n }, options);\n}\n\nexport { __onlyVue3, logicAnd as and, assert, refAutoReset as autoResetRef, bypassFilter, clamp, computedEager, computedWithControl, containsProp, computedWithControl as controlledComputed, controlledRef, createEventHook, createFilterWrapper, createGlobalState, createInjectionState, reactify as createReactiveFn, createSharedComposable, createSingletonPromise, debounceFilter, refDebounced as debouncedRef, watchDebounced as debouncedWatch, directiveHooks, computedEager as eagerComputed, extendRef, formatDate, get, identity, watchIgnorable as ignorableWatch, increaseWithUnit, invoke, isBoolean, isClient, isDef, isDefined, isFunction, isNumber, isObject, isString, isWindow, logicAnd, logicNot, logicOr, makeDestructurable, noop, normalizeDate, logicNot as not, now, objectPick, logicOr as or, pausableFilter, watchPausable as pausableWatch, promiseTimeout, rand, reactify, reactifyObject, reactiveComputed, reactiveOmit, reactivePick, refAutoReset, refDebounced, refDefault, refThrottled, refWithControl, set, syncRef, syncRefs, throttleFilter, refThrottled as throttledRef, watchThrottled as throttledWatch, timestamp, toReactive, toRefs, tryOnBeforeMount, tryOnBeforeUnmount, tryOnMounted, tryOnScopeDispose, tryOnUnmounted, until, useCounter, useDateFormat, refDebounced as useDebounce, useDebounceFn, useInterval, useIntervalFn, useLastChanged, refThrottled as useThrottle, useThrottleFn, useTimeout, useTimeoutFn, useToggle, watchAtMost, watchDebounced, watchIgnorable, watchOnce, watchPausable, watchThrottled, watchWithFilter, whenever };\n","import { noop, isClient, isString, tryOnScopeDispose, tryOnMounted, promiseTimeout, tryOnBeforeMount, increaseWithUnit, clamp, useTimeoutFn, pausableWatch, createEventHook, isFunction, timestamp, pausableFilter, watchIgnorable, debounceFilter, createFilterWrapper, bypassFilter, createSingletonPromise, toRefs, containsProp, until, throttleFilter, useDebounceFn, useThrottleFn, isObject, isNumber, useIntervalFn, syncRef, objectPick, tryOnUnmounted, watchWithFilter, identity } from '@vueuse/shared';\nexport * from '@vueuse/shared';\nimport { isRef, ref, watchEffect, computed, inject, unref, watch, getCurrentInstance, customRef, onUpdated, reactive, shallowRef, markRaw, getCurrentScope, isVue2, set, del, onMounted, readonly, onBeforeUpdate } from 'vue-demi';\nimport { unrefElement as unrefElement$1, useEventListener as useEventListener$1, useRafFn as useRafFn$1 } from '@vueuse/core';\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 onError = noop\n } = options;\n const started = ref(!lazy);\n const current = 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)\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\nconst createUnrefFn = (fn) => {\n return function(...args) {\n return fn.apply(this, args.map((i) => unref(i)));\n };\n};\n\nfunction unrefElement(elRef) {\n var _a;\n const plain = unref(elRef);\n return (_a = plain == null ? void 0 : plain.$el) != null ? _a : plain;\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 useEventListener(...args) {\n let target;\n let event;\n let listener;\n let options;\n if (isString(args[0])) {\n [event, listener, options] = args;\n target = defaultWindow;\n } else {\n [target, event, listener, options] = args;\n }\n if (!target)\n return noop;\n let cleanup = noop;\n const stopWatch = watch(() => unrefElement(target), (el) => {\n cleanup();\n if (!el)\n return;\n el.addEventListener(event, listener, options);\n cleanup = () => {\n el.removeEventListener(event, listener, options);\n cleanup = noop;\n };\n }, { immediate: true, flush: \"post\" });\n const stop = () => {\n stopWatch();\n cleanup();\n };\n tryOnScopeDispose(stop);\n return stop;\n}\n\nfunction onClickOutside(target, handler, options = {}) {\n const { window = defaultWindow, ignore, capture = true } = options;\n if (!window)\n return;\n const shouldListen = ref(true);\n const listener = (event) => {\n const el = unrefElement(target);\n const composedPath = event.composedPath();\n if (!el || el === event.target || composedPath.includes(el) || !shouldListen.value)\n return;\n if (ignore && ignore.length > 0) {\n if (ignore.some((target2) => {\n const el2 = unrefElement(target2);\n return el2 && (event.target === el2 || composedPath.includes(el2));\n }))\n return;\n }\n handler(event);\n };\n const cleanup = [\n useEventListener(window, \"click\", listener, { passive: true, capture }),\n useEventListener(window, \"pointerdown\", (e) => {\n const el = unrefElement(target);\n shouldListen.value = !!el && !e.composedPath().includes(el);\n }, { passive: true })\n ];\n const stop = () => cleanup.forEach((fn) => fn());\n return stop;\n}\n\nvar __defProp$h = Object.defineProperty;\nvar __defProps$8 = Object.defineProperties;\nvar __getOwnPropDescs$8 = Object.getOwnPropertyDescriptors;\nvar __getOwnPropSymbols$j = Object.getOwnPropertySymbols;\nvar __hasOwnProp$j = Object.prototype.hasOwnProperty;\nvar __propIsEnum$j = Object.prototype.propertyIsEnumerable;\nvar __defNormalProp$h = (obj, key, value) => key in obj ? __defProp$h(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;\nvar __spreadValues$h = (a, b) => {\n for (var prop in b || (b = {}))\n if (__hasOwnProp$j.call(b, prop))\n __defNormalProp$h(a, prop, b[prop]);\n if (__getOwnPropSymbols$j)\n for (var prop of __getOwnPropSymbols$j(b)) {\n if (__propIsEnum$j.call(b, prop))\n __defNormalProp$h(a, prop, b[prop]);\n }\n return a;\n};\nvar __spreadProps$8 = (a, b) => __defProps$8(a, __getOwnPropDescs$8(b));\nconst 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 else if (keyFilter)\n return () => true;\n else\n return () => false;\n};\nfunction onKeyStroke(key, handler, options = {}) {\n const { target = defaultWindow, eventName = \"keydown\", passive = false } = options;\n const predicate = createKeyPredicate(key);\n const listener = (e) => {\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, __spreadProps$8(__spreadValues$h({}, options), { eventName: \"keydown\" }));\n}\nfunction onKeyPressed(key, handler, options = {}) {\n return onKeyStroke(key, handler, __spreadProps$8(__spreadValues$h({}, options), { eventName: \"keypress\" }));\n}\nfunction onKeyUp(key, handler, options = {}) {\n return onKeyStroke(key, handler, __spreadProps$8(__spreadValues$h({}, options), { eventName: \"keyup\" }));\n}\n\nconst DEFAULT_DELAY = 500;\nfunction onLongPress(target, handler, options) {\n const elementRef = computed(() => unrefElement$1(target));\n let timeout = null;\n function clear() {\n if (timeout != null) {\n clearTimeout(timeout);\n timeout = null;\n }\n }\n function onDown(ev) {\n var _a;\n clear();\n timeout = setTimeout(() => handler(ev), (_a = options == null ? void 0 : options.delay) != null ? _a : DEFAULT_DELAY);\n }\n useEventListener$1(elementRef, \"pointerdown\", onDown);\n useEventListener$1(elementRef, \"pointerup\", clear);\n useEventListener$1(elementRef, \"pointerleave\", clear);\n}\n\nconst 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};\nconst isTypedCharValid = ({\n keyCode,\n metaKey,\n ctrlKey,\n altKey\n}) => {\n if (metaKey || ctrlKey || altKey)\n return false;\n if (keyCode >= 48 && keyCode <= 57 || keyCode >= 96 && keyCode <= 105)\n return true;\n if (keyCode >= 65 && keyCode <= 90)\n return true;\n return false;\n};\nfunction onStartTyping(callback, options = {}) {\n const { document: document2 = defaultDocument } = options;\n const keydown = (event) => {\n !isFocusedElementEditable() && isTypedCharValid(event) && callback(event);\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 useActiveElement(options = {}) {\n const { window = defaultWindow } = options;\n const counter = ref(0);\n if (window) {\n useEventListener(window, \"blur\", () => counter.value += 1, true);\n useEventListener(window, \"focus\", () => counter.value += 1, true);\n }\n return computed(() => {\n counter.value;\n return window == null ? void 0 : window.document.activeElement;\n });\n}\n\nfunction useAsyncQueue(tasks, options = {}) {\n const {\n interrupt = true,\n onError = noop,\n onFinished = noop\n } = options;\n const promiseState = {\n pending: \"pending\",\n rejected: \"rejected\",\n fulfilled: \"fulfilled\"\n };\n const initialResult = Array.from(new Array(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 (((_a = result[activeIndex.value]) == null ? void 0 : _a.state) === promiseState.rejected && interrupt) {\n onFinished();\n return;\n }\n return curr(prevRes).then((currentRes) => {\n updateResult(promiseState.fulfilled, currentRes);\n activeIndex.value === tasks.length - 1 && onFinished();\n return currentRes;\n });\n }).catch((e) => {\n updateResult(promiseState.rejected, e);\n onError();\n return e;\n });\n }, Promise.resolve());\n return {\n activeIndex,\n result\n };\n}\n\nfunction useAsyncState(promise, initialState, options) {\n const {\n immediate = true,\n delay = 0,\n onError = noop,\n resetOnExecute = true,\n shallow = true\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 = ref(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 } catch (e) {\n error.value = e;\n onError(e);\n }\n isLoading.value = false;\n return state.value;\n }\n if (immediate)\n execute(delay);\n return {\n state,\n isReady,\n isLoading,\n error,\n execute\n };\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 = unref(target);\n if (_target === void 0 || _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 {\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 watch(target, execute, { immediate: true });\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({ navigator = defaultNavigator } = {}) {\n const events = [\"chargingchange\", \"chargingtimechange\", \"dischargingtimechange\", \"levelchange\"];\n const isSupported = navigator && \"getBattery\" in navigator;\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) {\n navigator.getBattery().then((_battery) => {\n battery = _battery;\n updateBatteryInfo.call(battery);\n for (const event of events)\n useEventListener(battery, event, updateBatteryInfo, { passive: true });\n });\n }\n return {\n isSupported,\n charging,\n chargingTime,\n dischargingTime,\n level\n };\n}\n\nfunction useMediaQuery(query, options = {}) {\n const { window = defaultWindow } = options;\n let mediaQuery;\n const matches = ref(false);\n const update = () => {\n if (!window)\n return;\n if (!mediaQuery)\n mediaQuery = window.matchMedia(query);\n matches.value = mediaQuery.matches;\n };\n tryOnBeforeMount(() => {\n update();\n if (!mediaQuery)\n return;\n if (\"addEventListener\" in mediaQuery)\n mediaQuery.addEventListener(\"change\", update);\n else\n mediaQuery.addListener(update);\n tryOnScopeDispose(() => {\n if (\"removeEventListener\" in mediaQuery)\n mediaQuery.removeEventListener(\"change\", update);\n else\n mediaQuery.removeListener(update);\n });\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 sm: 576,\n md: 768,\n lg: 992,\n xl: 1200,\n xxl: 1400\n};\nconst breakpointsVuetify = {\n xs: 600,\n sm: 960,\n md: 1264,\n lg: 1904\n};\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: 600,\n sm: 1024,\n md: 1440,\n lg: 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};\n\nvar __defProp$g = Object.defineProperty;\nvar __getOwnPropSymbols$i = Object.getOwnPropertySymbols;\nvar __hasOwnProp$i = Object.prototype.hasOwnProperty;\nvar __propIsEnum$i = Object.prototype.propertyIsEnumerable;\nvar __defNormalProp$g = (obj, key, value) => key in obj ? __defProp$g(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;\nvar __spreadValues$g = (a, b) => {\n for (var prop in b || (b = {}))\n if (__hasOwnProp$i.call(b, prop))\n __defNormalProp$g(a, prop, b[prop]);\n if (__getOwnPropSymbols$i)\n for (var prop of __getOwnPropSymbols$i(b)) {\n if (__propIsEnum$i.call(b, prop))\n __defNormalProp$g(a, prop, b[prop]);\n }\n return a;\n};\nfunction useBreakpoints(breakpoints, options = {}) {\n function getValue(k, delta) {\n let v = breakpoints[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 } = options;\n function match(query) {\n if (!window)\n return false;\n return window.matchMedia(query).matches;\n }\n const greater = (k) => {\n return useMediaQuery(`(min-width: ${getValue(k)})`, options);\n };\n const shortcutMethods = Object.keys(breakpoints).reduce((shortcuts, k) => {\n Object.defineProperty(shortcuts, k, {\n get: () => greater(k),\n enumerable: true,\n configurable: true\n });\n return shortcuts;\n }, {});\n return __spreadValues$g({\n greater,\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)})`);\n },\n isSmaller(k) {\n return match(`(max-width: ${getValue(k, -0.1)})`);\n },\n isInBetween(a, b) {\n return match(`(min-width: ${getValue(a)}) and (max-width: ${getValue(b, -0.1)})`);\n }\n }, shortcutMethods);\n}\n\nconst useBroadcastChannel = (options) => {\n const {\n name,\n window = defaultWindow\n } = options;\n const isSupported = window && \"BroadcastChannel\" in window;\n const isClosed = ref(false);\n const channel = ref();\n const data = ref();\n const error = ref(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) {\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\nfunction useBrowserLocation({ window = defaultWindow } = {}) {\n const buildState = (trigger) => {\n const { state: state2, length } = (window == null ? void 0 : window.history) || {};\n const { hash, host, hostname, href, origin, pathname, port, protocol, search } = (window == null ? void 0 : window.location) || {};\n return {\n trigger,\n state: state2,\n length,\n hash,\n host,\n hostname,\n href,\n origin,\n pathname,\n port,\n protocol,\n search\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 useClamp(value, min, max) {\n const _value = ref(value);\n return computed({\n get() {\n return _value.value = clamp(_value.value, unref(min), unref(max));\n },\n set(value2) {\n _value.value = clamp(value2, unref(min), unref(max));\n }\n });\n}\n\nfunction useClipboard(options = {}) {\n const {\n navigator = defaultNavigator,\n read = false,\n source,\n copiedDuring = 1500\n } = options;\n const events = [\"copy\", \"cut\"];\n const isSupported = Boolean(navigator && \"clipboard\" in navigator);\n const text = ref(\"\");\n const copied = ref(false);\n const timeout = useTimeoutFn(() => copied.value = false, copiedDuring);\n function updateText() {\n navigator.clipboard.readText().then((value) => {\n text.value = value;\n });\n }\n if (isSupported && read) {\n for (const event of events)\n useEventListener(event, updateText);\n }\n async function copy(value = unref(source)) {\n if (isSupported && value != null) {\n await navigator.clipboard.writeText(value);\n text.value = value;\n copied.value = true;\n timeout.start();\n }\n }\n return {\n isSupported,\n text,\n copied,\n copy\n };\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__\";\n_global[globalKey] = _global[globalKey] || {};\nconst handlers = _global[globalKey];\nfunction getSSRHandler(key, fallback) {\n return handlers[key] || fallback;\n}\nfunction setSSRHandler(key, fn) {\n handlers[key] = fn;\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\" : Array.isArray(rawInit) ? \"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};\nfunction useStorage(key, initialValue, storage, options = {}) {\n var _a;\n const {\n flush = \"pre\",\n deep = true,\n listenToStorageChanges = true,\n writeDefaults = true,\n shallow,\n window = defaultWindow,\n eventFilter,\n onError = (e) => {\n console.error(e);\n }\n } = options;\n const data = (shallow ? shallowRef : ref)(initialValue);\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 = unref(initialValue);\n const type = guessSerializerType(rawInit);\n const serializer = (_a = options.serializer) != null ? _a : StorageSerializers[type];\n const { pause: pauseWatch, resume: resumeWatch } = pausableWatch(data, () => write(data.value), { flush, deep, eventFilter });\n if (window && listenToStorageChanges)\n useEventListener(window, \"storage\", update);\n update();\n return data;\n function write(v) {\n try {\n if (v == null)\n storage.removeItem(key);\n else\n storage.setItem(key, serializer.write(v));\n } catch (e) {\n onError(e);\n }\n }\n function read(event) {\n if (event && event.key !== key)\n return;\n pauseWatch();\n try {\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 (typeof rawValue !== \"string\") {\n return rawValue;\n } else {\n return serializer.read(rawValue);\n }\n } catch (e) {\n onError(e);\n } finally {\n resumeWatch();\n }\n }\n function update(event) {\n if (event && event.key !== key)\n return;\n data.value = read(event);\n }\n}\n\nfunction usePreferredDark(options) {\n return useMediaQuery(\"(prefers-color-scheme: dark)\", options);\n}\n\nvar __defProp$f = Object.defineProperty;\nvar __getOwnPropSymbols$h = Object.getOwnPropertySymbols;\nvar __hasOwnProp$h = Object.prototype.hasOwnProperty;\nvar __propIsEnum$h = Object.prototype.propertyIsEnumerable;\nvar __defNormalProp$f = (obj, key, value) => key in obj ? __defProp$f(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;\nvar __spreadValues$f = (a, b) => {\n for (var prop in b || (b = {}))\n if (__hasOwnProp$h.call(b, prop))\n __defNormalProp$f(a, prop, b[prop]);\n if (__getOwnPropSymbols$h)\n for (var prop of __getOwnPropSymbols$h(b)) {\n if (__propIsEnum$h.call(b, prop))\n __defNormalProp$f(a, prop, b[prop]);\n }\n return a;\n};\nfunction useColorMode(options = {}) {\n const {\n selector = \"html\",\n attribute = \"class\",\n window = defaultWindow,\n storage,\n storageKey = \"vueuse-color-scheme\",\n listenToStorageChanges = true,\n storageRef\n } = options;\n const modes = __spreadValues$f({\n auto: \"\",\n light: \"light\",\n dark: \"dark\"\n }, options.modes || {});\n const preferredDark = usePreferredDark({ window });\n const preferredMode = computed(() => preferredDark.value ? \"dark\" : \"light\");\n const store = storageRef || (storageKey == null ? ref(\"auto\") : useStorage(storageKey, \"auto\", storage, { window, listenToStorageChanges }));\n const state = computed({\n get() {\n return store.value === \"auto\" ? preferredMode.value : store.value;\n },\n set(v) {\n store.value = v;\n }\n });\n const updateHTMLAttrs = getSSRHandler(\"updateHTMLAttrs\", (selector2, attribute2, value) => {\n const el = window == null ? void 0 : window.document.querySelector(selector2);\n if (!el)\n return;\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 el.classList.add(v);\n else\n el.classList.remove(v);\n });\n } else {\n el.setAttribute(attribute2, value);\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 return 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, { window = defaultWindow } = {}) {\n const variable = ref(\"\");\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 watch([elRef, () => unref(prop)], ([el, prop2]) => {\n if (el && window)\n variable.value = window.getComputedStyle(el).getPropertyValue(prop2);\n }, { immediate: true });\n watch(variable, (val) => {\n var _a;\n if ((_a = elRef.value) == null ? void 0 : _a.style)\n elRef.value.style.setProperty(unref(prop), val);\n });\n return variable;\n}\n\nfunction useCycleList(list, options) {\n var _a;\n const state = shallowRef((_a = options == null ? void 0 : options.initialValue) != null ? _a : list[0]);\n const index = computed({\n get() {\n var _a2;\n let index2 = (options == null ? void 0 : options.getIndexOf) ? options.getIndexOf(state.value, list) : list.indexOf(state.value);\n if (index2 < 0)\n index2 = (_a2 = options == null ? void 0 : options.fallbackIndex) != null ? _a2 : 0;\n return index2;\n },\n set(v) {\n set(v);\n }\n });\n function set(i) {\n const length = list.length;\n const index2 = (i % length + length) % length;\n const value = list[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 return {\n state,\n index,\n next,\n prev\n };\n}\n\nvar __defProp$e = Object.defineProperty;\nvar __defProps$7 = Object.defineProperties;\nvar __getOwnPropDescs$7 = Object.getOwnPropertyDescriptors;\nvar __getOwnPropSymbols$g = Object.getOwnPropertySymbols;\nvar __hasOwnProp$g = Object.prototype.hasOwnProperty;\nvar __propIsEnum$g = Object.prototype.propertyIsEnumerable;\nvar __defNormalProp$e = (obj, key, value) => key in obj ? __defProp$e(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;\nvar __spreadValues$e = (a, b) => {\n for (var prop in b || (b = {}))\n if (__hasOwnProp$g.call(b, prop))\n __defNormalProp$e(a, prop, b[prop]);\n if (__getOwnPropSymbols$g)\n for (var prop of __getOwnPropSymbols$g(b)) {\n if (__propIsEnum$g.call(b, prop))\n __defNormalProp$e(a, prop, b[prop]);\n }\n return a;\n};\nvar __spreadProps$7 = (a, b) => __defProps$7(a, __getOwnPropDescs$7(b));\nfunction useDark(options = {}) {\n const {\n valueDark = \"dark\",\n valueLight = \"\",\n window = defaultWindow\n } = options;\n const mode = useColorMode(__spreadProps$7(__spreadValues$e({}, options), {\n onChanged: (mode2, defaultHandler) => {\n var _a;\n if (options.onChanged)\n (_a = options.onChanged) == null ? void 0 : _a.call(options, mode2 === \"dark\");\n else\n defaultHandler(mode2);\n },\n modes: {\n dark: valueDark,\n light: valueLight\n }\n }));\n const preferredDark = usePreferredDark({ window });\n const isDark = computed({\n get() {\n return mode.value === \"dark\";\n },\n set(v) {\n if (v === preferredDark.value)\n mode.value = \"auto\";\n else\n mode.value = v ? \"dark\" : \"light\";\n }\n });\n return isDark;\n}\n\nconst fnClone = (v) => JSON.parse(JSON.stringify(v));\nconst fnBypass = (v) => v;\nconst fnSetSource = (source, value) => source.value = value;\nfunction defaultDump(clone) {\n return clone ? isFunction(clone) ? clone : fnClone : fnBypass;\n}\nfunction defaultParse(clone) {\n return clone ? isFunction(clone) ? clone : fnClone : 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, 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\nvar __defProp$d = Object.defineProperty;\nvar __defProps$6 = Object.defineProperties;\nvar __getOwnPropDescs$6 = Object.getOwnPropertyDescriptors;\nvar __getOwnPropSymbols$f = Object.getOwnPropertySymbols;\nvar __hasOwnProp$f = Object.prototype.hasOwnProperty;\nvar __propIsEnum$f = Object.prototype.propertyIsEnumerable;\nvar __defNormalProp$d = (obj, key, value) => key in obj ? __defProp$d(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;\nvar __spreadValues$d = (a, b) => {\n for (var prop in b || (b = {}))\n if (__hasOwnProp$f.call(b, prop))\n __defNormalProp$d(a, prop, b[prop]);\n if (__getOwnPropSymbols$f)\n for (var prop of __getOwnPropSymbols$f(b)) {\n if (__propIsEnum$f.call(b, prop))\n __defNormalProp$d(a, prop, b[prop]);\n }\n return a;\n};\nvar __spreadProps$6 = (a, b) => __defProps$6(a, __getOwnPropDescs$6(b));\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(source, commit, { deep, flush, eventFilter: composedFilter });\n function setSource(source2, value) {\n ignorePrevAsyncUpdates();\n ignoreUpdates(() => {\n source2.value = value;\n });\n }\n const manualHistory = useManualRefHistory(source, __spreadProps$6(__spreadValues$d({}, 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 __spreadProps$6(__spreadValues$d({}, manualHistory), {\n isTracking,\n pause,\n resume,\n commit,\n batch,\n dispose\n });\n}\n\nvar __defProp$c = Object.defineProperty;\nvar __defProps$5 = Object.defineProperties;\nvar __getOwnPropDescs$5 = Object.getOwnPropertyDescriptors;\nvar __getOwnPropSymbols$e = Object.getOwnPropertySymbols;\nvar __hasOwnProp$e = Object.prototype.hasOwnProperty;\nvar __propIsEnum$e = Object.prototype.propertyIsEnumerable;\nvar __defNormalProp$c = (obj, key, value) => key in obj ? __defProp$c(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;\nvar __spreadValues$c = (a, b) => {\n for (var prop in b || (b = {}))\n if (__hasOwnProp$e.call(b, prop))\n __defNormalProp$c(a, prop, b[prop]);\n if (__getOwnPropSymbols$e)\n for (var prop of __getOwnPropSymbols$e(b)) {\n if (__propIsEnum$e.call(b, prop))\n __defNormalProp$c(a, prop, b[prop]);\n }\n return a;\n};\nvar __spreadProps$5 = (a, b) => __defProps$5(a, __getOwnPropDescs$5(b));\nfunction useDebouncedRefHistory(source, options = {}) {\n const filter = options.debounce ? debounceFilter(options.debounce) : void 0;\n const history = useRefHistory(source, __spreadProps$5(__spreadValues$c({}, options), { eventFilter: filter }));\n return __spreadValues$c({}, history);\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(eventFilter, (event) => {\n acceleration.value = event.acceleration;\n accelerationIncludingGravity.value = event.accelerationIncludingGravity;\n rotationRate.value = event.rotationRate;\n interval.value = event.interval;\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 = Boolean(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) {\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\nconst DEVICE_PIXEL_RATIO_SCALES = [\n 1,\n 1.325,\n 1.4,\n 1.5,\n 1.8,\n 2,\n 2.4,\n 2.5,\n 2.75,\n 3,\n 3.5,\n 4\n];\nfunction useDevicePixelRatio({\n window = defaultWindow\n} = {}) {\n if (!window) {\n return {\n pixelRatio: ref(1)\n };\n }\n const pixelRatio = ref(window.devicePixelRatio);\n const handleDevicePixelRatio = () => {\n pixelRatio.value = window.devicePixelRatio;\n };\n useEventListener(window, \"resize\", handleDevicePixelRatio, { passive: true });\n DEVICE_PIXEL_RATIO_SCALES.forEach((dppx) => {\n const mqlMin = useMediaQuery(`screen and (min-resolution: ${dppx}dppx)`);\n const mqlMax = useMediaQuery(`screen and (max-resolution: ${dppx}dppx)`);\n watch([mqlMin, mqlMax], handleDevicePixelRatio);\n });\n return { pixelRatio };\n}\n\nfunction usePermission(permissionDesc, options = {}) {\n const {\n controls = false,\n navigator = defaultNavigator\n } = options;\n const isSupported = Boolean(navigator && \"permissions\" in navigator);\n let permissionStatus;\n const desc = typeof permissionDesc === \"string\" ? { name: permissionDesc } : permissionDesc;\n const state = ref();\n const onChange = () => {\n if (permissionStatus)\n state.value = permissionStatus.state;\n };\n const query = createSingletonPromise(async () => {\n if (!isSupported)\n return;\n if (!permissionStatus) {\n try {\n permissionStatus = await navigator.permissions.query(desc);\n useEventListener(permissionStatus, \"change\", onChange);\n onChange();\n } catch (e) {\n state.value = \"prompt\";\n }\n }\n return permissionStatus;\n });\n query();\n if (controls) {\n return {\n state,\n isSupported,\n query\n };\n } else {\n return state;\n }\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 let isSupported = false;\n const permissionGranted = ref(false);\n async function update() {\n if (!isSupported)\n return;\n devices.value = await navigator.mediaDevices.enumerateDevices();\n onUpdated == null ? void 0 : onUpdated(devices.value);\n }\n async function ensurePermissions() {\n if (!isSupported)\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 const stream = await navigator.mediaDevices.getUserMedia(constraints);\n stream.getTracks().forEach((t) => t.stop());\n update();\n permissionGranted.value = true;\n } else {\n permissionGranted.value = true;\n }\n return permissionGranted.value;\n }\n if (navigator) {\n isSupported = Boolean(navigator.mediaDevices && navigator.mediaDevices.enumerateDevices);\n if (isSupported) {\n if (requestPermissions)\n ensurePermissions();\n useEventListener(navigator.mediaDevices, \"devicechange\", update);\n update();\n }\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, _b;\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 = Boolean((_b = navigator == null ? void 0 : navigator.mediaDevices) == null ? void 0 : _b.getDisplayMedia);\n const constraint = { audio, video };\n const stream = shallowRef();\n async function _start() {\n if (!isSupported || stream.value)\n return;\n stream.value = await navigator.mediaDevices.getDisplayMedia(constraint);\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(enabled, (v) => {\n if (v)\n _start();\n else\n _stop();\n }, { immediate: true });\n return {\n isSupported,\n stream,\n start,\n stop,\n enabled\n };\n}\n\nfunction useDocumentVisibility({ document = defaultDocument } = {}) {\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\nvar __defProp$b = Object.defineProperty;\nvar __defProps$4 = Object.defineProperties;\nvar __getOwnPropDescs$4 = Object.getOwnPropertyDescriptors;\nvar __getOwnPropSymbols$d = Object.getOwnPropertySymbols;\nvar __hasOwnProp$d = Object.prototype.hasOwnProperty;\nvar __propIsEnum$d = Object.prototype.propertyIsEnumerable;\nvar __defNormalProp$b = (obj, key, value) => key in obj ? __defProp$b(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;\nvar __spreadValues$b = (a, b) => {\n for (var prop in b || (b = {}))\n if (__hasOwnProp$d.call(b, prop))\n __defNormalProp$b(a, prop, b[prop]);\n if (__getOwnPropSymbols$d)\n for (var prop of __getOwnPropSymbols$d(b)) {\n if (__propIsEnum$d.call(b, prop))\n __defNormalProp$b(a, prop, b[prop]);\n }\n return a;\n};\nvar __spreadProps$4 = (a, b) => __defProps$4(a, __getOwnPropDescs$4(b));\nfunction useDraggable(target, options = {}) {\n var _a, _b;\n const draggingElement = (_a = options.draggingElement) != null ? _a : defaultWindow;\n const position = ref((_b = options.initialValue) != null ? _b : { x: 0, y: 0 });\n const pressedDelta = ref();\n const filterEvent = (e) => {\n if (options.pointerTypes)\n return options.pointerTypes.includes(e.pointerType);\n return true;\n };\n const handleEvent = (e) => {\n if (unref(options.preventDefault))\n e.preventDefault();\n if (unref(options.stopPropagation))\n e.stopPropagation();\n };\n const start = (e) => {\n var _a2;\n if (!filterEvent(e))\n return;\n if (unref(options.exact) && e.target !== unref(target))\n return;\n const rect = unref(target).getBoundingClientRect();\n const pos = {\n x: e.pageX - rect.left,\n y: e.pageY - rect.top\n };\n if (((_a2 = options.onStart) == null ? void 0 : _a2.call(options, pos, e)) === false)\n return;\n pressedDelta.value = pos;\n handleEvent(e);\n };\n const move = (e) => {\n var _a2;\n if (!filterEvent(e))\n return;\n if (!pressedDelta.value)\n return;\n position.value = {\n x: e.pageX - pressedDelta.value.x,\n y: e.pageY - pressedDelta.value.y\n };\n (_a2 = options.onMove) == null ? void 0 : _a2.call(options, position.value, e);\n handleEvent(e);\n };\n const end = (e) => {\n var _a2;\n if (!filterEvent(e))\n return;\n if (!pressedDelta.value)\n return;\n pressedDelta.value = void 0;\n (_a2 = options.onEnd) == null ? void 0 : _a2.call(options, position.value, e);\n handleEvent(e);\n };\n if (isClient) {\n useEventListener(target, \"pointerdown\", start, true);\n useEventListener(draggingElement, \"pointermove\", move, true);\n useEventListener(draggingElement, \"pointerup\", end, true);\n }\n return __spreadProps$4(__spreadValues$b({}, toRefs(position)), {\n position,\n isDragging: computed(() => !!pressedDelta.value),\n style: computed(() => `left:${position.value.x}px;top:${position.value.y}px;`)\n });\n}\n\nvar __getOwnPropSymbols$c = Object.getOwnPropertySymbols;\nvar __hasOwnProp$c = Object.prototype.hasOwnProperty;\nvar __propIsEnum$c = Object.prototype.propertyIsEnumerable;\nvar __objRest$2 = (source, exclude) => {\n var target = {};\n for (var prop in source)\n if (__hasOwnProp$c.call(source, prop) && exclude.indexOf(prop) < 0)\n target[prop] = source[prop];\n if (source != null && __getOwnPropSymbols$c)\n for (var prop of __getOwnPropSymbols$c(source)) {\n if (exclude.indexOf(prop) < 0 && __propIsEnum$c.call(source, prop))\n target[prop] = source[prop];\n }\n return target;\n};\nfunction useResizeObserver(target, callback, options = {}) {\n const _a = options, { window = defaultWindow } = _a, observerOptions = __objRest$2(_a, [\"window\"]);\n let observer;\n const isSupported = window && \"ResizeObserver\" in window;\n const cleanup = () => {\n if (observer) {\n observer.disconnect();\n observer = void 0;\n }\n };\n const stopWatch = watch(() => unrefElement(target), (el) => {\n cleanup();\n if (isSupported && window && el) {\n observer = new ResizeObserver(callback);\n observer.observe(el, observerOptions);\n }\n }, { immediate: true, flush: \"post\" });\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 } = 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 update() {\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 useResizeObserver(target, update);\n watch(() => unrefElement(target), (ele) => !ele && update());\n if (windowScroll)\n useEventListener(\"scroll\", update, { passive: true });\n if (windowResize)\n useEventListener(\"resize\", update, { passive: true });\n return {\n height,\n bottom,\n left,\n right,\n top,\n width,\n x,\n y,\n update\n };\n}\n\nfunction useRafFn(fn, options = {}) {\n const {\n immediate = true,\n window = defaultWindow\n } = options;\n const isActive = ref(false);\n let rafId = null;\n function loop() {\n if (!isActive.value || !window)\n return;\n fn();\n rafId = window.requestAnimationFrame(loop);\n }\n function resume() {\n if (!isActive.value && window) {\n isActive.value = true;\n 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,\n pause,\n resume\n };\n}\n\nvar __defProp$a = Object.defineProperty;\nvar __getOwnPropSymbols$b = Object.getOwnPropertySymbols;\nvar __hasOwnProp$b = Object.prototype.hasOwnProperty;\nvar __propIsEnum$b = Object.prototype.propertyIsEnumerable;\nvar __defNormalProp$a = (obj, key, value) => key in obj ? __defProp$a(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;\nvar __spreadValues$a = (a, b) => {\n for (var prop in b || (b = {}))\n if (__hasOwnProp$b.call(b, prop))\n __defNormalProp$a(a, prop, b[prop]);\n if (__getOwnPropSymbols$b)\n for (var prop of __getOwnPropSymbols$b(b)) {\n if (__propIsEnum$b.call(b, prop))\n __defNormalProp$a(a, prop, b[prop]);\n }\n return a;\n};\nfunction useElementByPoint(options) {\n const element = ref(null);\n const { x, y } = options;\n const controls = useRafFn(() => {\n element.value = document.elementFromPoint(unref(x), unref(y));\n });\n return __spreadValues$a({\n element\n }, controls);\n}\n\nfunction useElementHover(el) {\n const isHovered = ref(false);\n useEventListener(el, \"mouseenter\", () => isHovered.value = true);\n useEventListener(el, \"mouseleave\", () => isHovered.value = false);\n return isHovered;\n}\n\nfunction useElementSize(target, initialSize = { width: 0, height: 0 }, options = {}) {\n const width = ref(initialSize.width);\n const height = ref(initialSize.height);\n useResizeObserver(target, ([entry]) => {\n width.value = entry.contentRect.width;\n height.value = entry.contentRect.height;\n }, options);\n watch(() => unrefElement(target), (ele) => {\n width.value = ele ? initialSize.width : 0;\n height.value = ele ? initialSize.height : 0;\n });\n return {\n width,\n height\n };\n}\n\nfunction useElementVisibility(element, { window = defaultWindow, scrollTarget } = {}) {\n const elementIsVisible = ref(false);\n const testBounding = () => {\n if (!window)\n return;\n const document = window.document;\n if (!unref(element)) {\n elementIsVisible.value = false;\n } else {\n const rect = unref(element).getBoundingClientRect();\n elementIsVisible.value = rect.top <= (window.innerHeight || document.documentElement.clientHeight) && rect.left <= (window.innerWidth || document.documentElement.clientWidth) && rect.bottom >= 0 && rect.right >= 0;\n }\n };\n tryOnMounted(testBounding);\n if (window)\n tryOnMounted(() => useEventListener(unref(scrollTarget) || window, \"scroll\", testBounding, { capture: false, passive: true }));\n return elementIsVisible;\n}\n\nconst events = /* @__PURE__ */ new Map();\n\nfunction useEventBus(key) {\n const scope = getCurrentScope();\n function on(listener) {\n const listeners = events.get(key) || [];\n listeners.push(listener);\n events.set(key, listeners);\n const _off = () => off(listener);\n scope == null ? void 0 : scope.cleanups.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 const index = listeners.indexOf(listener);\n if (index > -1)\n listeners.splice(index, 1);\n if (!listeners.length)\n events.delete(key);\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 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 = ref(null);\n const {\n withCredentials = false\n } = options;\n const close = () => {\n if (eventSource.value) {\n eventSource.value.close();\n eventSource.value = null;\n status.value = \"CLOSED\";\n }\n };\n const es = new EventSource(url, { withCredentials });\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 };\n es.onmessage = (e) => {\n event.value = null;\n data.value = e.data;\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 tryOnScopeDispose(() => {\n close();\n });\n return {\n eventSource,\n event,\n data,\n status,\n error,\n close\n };\n}\n\nfunction useEyeDropper(options = {}) {\n const { initialValue = \"\" } = options;\n const isSupported = Boolean(typeof window !== \"undefined\" && \"EyeDropper\" in window);\n const sRGBHex = ref(initialValue);\n async function open(openOptions) {\n if (!isSupported)\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 = isRef(newIcon) ? newIcon : ref(newIcon);\n const applyIcon = (icon) => {\n document == null ? void 0 : document.head.querySelectorAll(`link[rel*=\"${rel}\"]`).forEach((el) => el.href = `${baseUrl}${icon}`);\n };\n watch(favicon, (i, o) => {\n if (isString(i) && i !== o)\n applyIcon(i);\n }, { immediate: true });\n return favicon;\n}\n\nvar __defProp$9 = Object.defineProperty;\nvar __defProps$3 = Object.defineProperties;\nvar __getOwnPropDescs$3 = Object.getOwnPropertyDescriptors;\nvar __getOwnPropSymbols$a = Object.getOwnPropertySymbols;\nvar __hasOwnProp$a = Object.prototype.hasOwnProperty;\nvar __propIsEnum$a = Object.prototype.propertyIsEnumerable;\nvar __defNormalProp$9 = (obj, key, value) => key in obj ? __defProp$9(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;\nvar __spreadValues$9 = (a, b) => {\n for (var prop in b || (b = {}))\n if (__hasOwnProp$a.call(b, prop))\n __defNormalProp$9(a, prop, b[prop]);\n if (__getOwnPropSymbols$a)\n for (var prop of __getOwnPropSymbols$a(b)) {\n if (__propIsEnum$a.call(b, prop))\n __defNormalProp$9(a, prop, b[prop]);\n }\n return a;\n};\nvar __spreadProps$3 = (a, b) => __defProps$3(a, __getOwnPropDescs$3(b));\nconst payloadMapping = {\n json: \"application/json\",\n text: \"text/plain\",\n formData: \"multipart/form-data\"\n};\nfunction isFetchOptions(obj) {\n return containsProp(obj, \"immediate\", \"refetch\", \"initialData\", \"timeout\", \"beforeFetch\", \"afterFetch\", \"onFetchError\");\n}\nfunction headersToObject(headers) {\n if (headers instanceof Headers)\n return Object.fromEntries([...headers.entries()]);\n return headers;\n}\nfunction createFetch(config = {}) {\n const _options = config.options || {};\n const _fetchOptions = config.fetchOptions || {};\n function useFactoryFetch(url, ...args) {\n const computedUrl = computed(() => config.baseUrl ? joinPaths(unref(config.baseUrl), unref(url)) : unref(url));\n let options = _options;\n let fetchOptions = _fetchOptions;\n if (args.length > 0) {\n if (isFetchOptions(args[0])) {\n options = __spreadValues$9(__spreadValues$9({}, options), args[0]);\n } else {\n fetchOptions = __spreadProps$3(__spreadValues$9(__spreadValues$9({}, fetchOptions), args[0]), {\n headers: __spreadValues$9(__spreadValues$9({}, headersToObject(fetchOptions.headers) || {}), headersToObject(args[0].headers) || {})\n });\n }\n }\n if (args.length > 1 && isFetchOptions(args[1]))\n options = __spreadValues$9(__spreadValues$9({}, options), args[1]);\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 = { immediate: true, refetch: false, timeout: 0 };\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 = __spreadValues$9(__spreadValues$9({}, options), args[0]);\n else\n fetchOptions = args[0];\n }\n if (args.length > 1) {\n if (isFetchOptions(args[1]))\n options = __spreadValues$9(__spreadValues$9({}, 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);\n const canAbort = computed(() => supportsAbort && isFetching.value);\n let controller;\n let timer;\n const abort = () => {\n if (supportsAbort && controller)\n controller.abort();\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 const execute = async (throwOnFailed = false) => {\n var _a2;\n loading(true);\n error.value = null;\n statusCode.value = null;\n aborted.value = false;\n controller = void 0;\n if (supportsAbort) {\n controller = new AbortController();\n controller.signal.onabort = () => aborted.value = true;\n fetchOptions = __spreadProps$3(__spreadValues$9({}, fetchOptions), {\n signal: controller.signal\n });\n }\n const defaultFetchOptions = {\n method: config.method,\n headers: {}\n };\n if (config.payload) {\n const headers = headersToObject(defaultFetchOptions.headers);\n if (config.payloadType)\n headers[\"Content-Type\"] = (_a2 = payloadMapping[config.payloadType]) != null ? _a2 : config.payloadType;\n defaultFetchOptions.body = config.payloadType === \"json\" ? JSON.stringify(unref(config.payload)) : unref(config.payload);\n }\n let isCanceled = false;\n const context = { url: unref(url), options: __spreadValues$9(__spreadValues$9({}, defaultFetchOptions), fetchOptions), cancel: () => {\n isCanceled = true;\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 new Promise((resolve, reject) => {\n var _a3;\n fetch(context.url, __spreadProps$3(__spreadValues$9(__spreadValues$9({}, defaultFetchOptions), context.options), {\n headers: __spreadValues$9(__spreadValues$9({}, headersToObject(defaultFetchOptions.headers)), headersToObject((_a3 = context.options) == null ? void 0 : _a3.headers))\n })).then(async (fetchResponse) => {\n response.value = fetchResponse;\n statusCode.value = fetchResponse.status;\n responseData = await fetchResponse[config.type]();\n if (options.afterFetch && statusCode.value >= 200 && statusCode.value < 300)\n ({ data: responseData } = await options.afterFetch({ data: responseData, response: fetchResponse }));\n data.value = responseData;\n if (!fetchResponse.ok)\n throw new Error(fetchResponse.statusText);\n responseEvent.trigger(fetchResponse);\n return resolve(fetchResponse);\n }).catch(async (fetchError) => {\n let errorData = fetchError.message || fetchError.name;\n if (options.onFetchError)\n ({ data: responseData, error: errorData } = await options.onFetchError({ data: responseData, error: fetchError, response: response.value }));\n data.value = responseData;\n error.value = errorData;\n errorEvent.trigger(fetchError);\n if (throwOnFailed)\n return reject(fetchError);\n return resolve(null);\n }).finally(() => {\n loading(false);\n if (timer)\n timer.stop();\n finallyEvent.trigger(null);\n });\n });\n };\n watch(() => [\n unref(url),\n unref(options.refetch)\n ], () => unref(options.refetch) && execute(), { deep: true });\n const shell = {\n isFinished,\n statusCode,\n response,\n error,\n data,\n isFetching,\n canAbort,\n aborted,\n abort,\n execute,\n onFetchResponse: responseEvent.on,\n onFetchError: errorEvent.on,\n onFetchFinally: finallyEvent.on,\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 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 unref(config.payload),\n unref(options.refetch)\n ], () => unref(options.refetch) && execute(), { deep: true });\n }\n if (!payloadType && unref(payload) && Object.getPrototypeOf(unref(payload)) === Object.prototype)\n config.payloadType = \"json\";\n return shell;\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((error2) => reject(error2));\n });\n }\n function setType(type) {\n return () => {\n if (!isFetching.value) {\n config.type = type;\n return __spreadProps$3(__spreadValues$9({}, 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 setTimeout(execute, 0);\n return __spreadProps$3(__spreadValues$9({}, 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 return `${start}${end}`;\n}\n\nvar __defProp$8 = Object.defineProperty;\nvar __getOwnPropSymbols$9 = Object.getOwnPropertySymbols;\nvar __hasOwnProp$9 = Object.prototype.hasOwnProperty;\nvar __propIsEnum$9 = Object.prototype.propertyIsEnumerable;\nvar __defNormalProp$8 = (obj, key, value) => key in obj ? __defProp$8(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;\nvar __spreadValues$8 = (a, b) => {\n for (var prop in b || (b = {}))\n if (__hasOwnProp$9.call(b, prop))\n __defNormalProp$8(a, prop, b[prop]);\n if (__getOwnPropSymbols$9)\n for (var prop of __getOwnPropSymbols$9(b)) {\n if (__propIsEnum$9.call(b, prop))\n __defNormalProp$8(a, prop, b[prop]);\n }\n return a;\n};\nfunction useFileSystemAccess(options = {}) {\n const {\n window: _window = defaultWindow,\n dataType = \"Text\"\n } = unref(options);\n const window = _window;\n const isSupported = Boolean(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)\n return;\n const [handle] = await window.showOpenFilePicker(__spreadValues$8(__spreadValues$8({}, unref(options)), _options));\n fileHandle.value = handle;\n await updateFile();\n await updateData();\n }\n async function create(_options = {}) {\n if (!isSupported)\n return;\n fileHandle.value = await window.showSaveFilePicker(__spreadValues$8(__spreadValues$8({}, unref(options)), _options));\n data.value = void 0;\n await updateFile();\n await updateData();\n }\n async function save(_options = {}) {\n if (!isSupported)\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)\n return;\n fileHandle.value = await window.showSaveFilePicker(__spreadValues$8(__spreadValues$8({}, unref(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 if (unref(dataType) === \"Text\")\n data.value = await ((_a = file.value) == null ? void 0 : _a.text());\n if (unref(dataType) === \"ArrayBuffer\")\n data.value = await ((_b = file.value) == null ? void 0 : _b.arrayBuffer());\n if (unref(dataType) === \"Blob\")\n data.value = file.value;\n }\n watch(() => unref(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 } = options;\n const activeElement = useActiveElement(options);\n const targetElement = computed(() => unrefElement(target));\n const focused = computed({\n get() {\n return activeElement.value === targetElement.value;\n },\n set(value) {\n var _a, _b;\n if (!value && focused.value)\n (_a = targetElement.value) == null ? void 0 : _a.blur();\n if (value && !focused.value)\n (_b = targetElement.value) == null ? void 0 : _b.focus();\n }\n });\n watch(targetElement, () => {\n focused.value = initialValue;\n }, { immediate: true, flush: \"post\" });\n return { focused };\n}\n\nfunction useFocusWithin(target, options = {}) {\n const activeElement = useActiveElement(options);\n const targetElement = computed(() => unrefElement(target));\n const focused = computed(() => targetElement.value && activeElement.value ? targetElement.value.contains(activeElement.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 functionsMap = [\n [\n \"requestFullscreen\",\n \"exitFullscreen\",\n \"fullscreenElement\",\n \"fullscreenEnabled\",\n \"fullscreenchange\",\n \"fullscreenerror\"\n ],\n [\n \"webkitRequestFullscreen\",\n \"webkitExitFullscreen\",\n \"webkitFullscreenElement\",\n \"webkitFullscreenEnabled\",\n \"webkitfullscreenchange\",\n \"webkitfullscreenerror\"\n ],\n [\n \"webkitRequestFullScreen\",\n \"webkitCancelFullScreen\",\n \"webkitCurrentFullScreenElement\",\n \"webkitCancelFullScreen\",\n \"webkitfullscreenchange\",\n \"webkitfullscreenerror\"\n ],\n [\n \"mozRequestFullScreen\",\n \"mozCancelFullScreen\",\n \"mozFullScreenElement\",\n \"mozFullScreenEnabled\",\n \"mozfullscreenchange\",\n \"mozfullscreenerror\"\n ],\n [\n \"msRequestFullscreen\",\n \"msExitFullscreen\",\n \"msFullscreenElement\",\n \"msFullscreenEnabled\",\n \"MSFullscreenChange\",\n \"MSFullscreenError\"\n ]\n];\nfunction useFullscreen(target, options = {}) {\n const { document = defaultDocument, autoExit = false } = options;\n const targetRef = target || (document == null ? void 0 : document.querySelector(\"html\"));\n const isFullscreen = ref(false);\n let isSupported = false;\n let map = functionsMap[0];\n if (!document) {\n isSupported = false;\n } else {\n for (const m of functionsMap) {\n if (m[1] in document) {\n map = m;\n isSupported = true;\n break;\n }\n }\n }\n const [REQUEST, EXIT, ELEMENT, , EVENT] = map;\n async function exit() {\n if (!isSupported)\n return;\n if (document == null ? void 0 : document[ELEMENT])\n await document[EXIT]();\n isFullscreen.value = false;\n }\n async function enter() {\n if (!isSupported)\n return;\n await exit();\n const target2 = unrefElement(targetRef);\n if (target2) {\n await target2[REQUEST]();\n isFullscreen.value = true;\n }\n }\n async function toggle() {\n if (isFullscreen.value)\n await exit();\n else\n await enter();\n }\n if (document) {\n useEventListener(document, EVENT, () => {\n isFullscreen.value = !!(document == null ? void 0 : document[ELEMENT]);\n }, false);\n }\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 = 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 hapticActuators,\n index: gamepad.index,\n mapping: gamepad.mapping,\n connected: gamepad.connected,\n timestamp: gamepad.timestamp,\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 (let i = 0; i < _gamepads.length; ++i) {\n const gamepad = _gamepads[i];\n if (gamepad) {\n const index = gamepads.value.findIndex(({ index: index2 }) => index2 === gamepad.index);\n if (index > -1)\n gamepads.value[index] = stateFromGamepad(gamepad);\n }\n }\n };\n const { isActive, pause, resume } = useRafFn$1(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$1(\"gamepadconnected\", (e) => onGamepadConnected(e.gamepad));\n useEventListener$1(\"gamepaddisconnected\", (e) => onGamepadDisconnected(e.gamepad));\n tryOnMounted(() => {\n const _gamepads = (navigator == null ? void 0 : navigator.getGamepads()) || [];\n if (_gamepads) {\n for (let i = 0; i < _gamepads.length; ++i) {\n const gamepad = _gamepads[i];\n if (gamepad)\n onGamepadConnected(gamepad);\n }\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 } = options;\n const isSupported = navigator && \"geolocation\" in navigator;\n const locatedAt = ref(null);\n const error = ref(null);\n const coords = ref({\n accuracy: 0,\n latitude: Infinity,\n longitude: 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 if (isSupported) {\n watcher = navigator.geolocation.watchPosition(updatePosition, (err) => error.value = err, {\n enableHighAccuracy,\n maximumAge,\n timeout\n });\n }\n tryOnScopeDispose(() => {\n if (watcher && navigator)\n navigator.geolocation.clearWatch(watcher);\n });\n return {\n isSupported,\n coords,\n locatedAt,\n error\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 onEvent = createFilterWrapper(eventFilter, () => {\n idle.value = false;\n lastActive.value = timestamp();\n clearTimeout(timer);\n timer = setTimeout(() => idle.value = true, timeout);\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 }\n timer = setTimeout(() => idle.value = true, timeout);\n return { idle, lastActive };\n}\n\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 } = options;\n const x = ref(0);\n const y = ref(0);\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 if (element) {\n const onScrollEnd = useDebounceFn((e) => {\n isScrolling.value = false;\n directions.left = false;\n directions.right = false;\n directions.top = false;\n directions.bottom = false;\n onStop(e);\n }, throttle + idle);\n const onScrollHandler = (e) => {\n const eventTarget = e.target === document ? e.target.documentElement : e.target;\n const scrollLeft = eventTarget.scrollLeft;\n directions.left = scrollLeft < x.value;\n directions.right = scrollLeft > x.value;\n arrivedState.left = scrollLeft <= 0 + (offset.left || 0);\n arrivedState.right = scrollLeft + eventTarget.clientWidth >= eventTarget.scrollWidth - (offset.right || 0);\n x.value = scrollLeft;\n const scrollTop = eventTarget.scrollTop;\n directions.top = scrollTop < y.value;\n directions.bottom = scrollTop > y.value;\n arrivedState.top = scrollTop <= 0 + (offset.top || 0);\n arrivedState.bottom = scrollTop + eventTarget.clientHeight >= eventTarget.scrollHeight - (offset.bottom || 0);\n y.value = scrollTop;\n isScrolling.value = true;\n onScrollEnd(e);\n onScroll(e);\n };\n useEventListener(element, \"scroll\", throttle ? useThrottleFn(onScrollHandler, throttle) : onScrollHandler, eventListenerOptions);\n }\n return {\n x,\n y,\n isScrolling,\n arrivedState,\n directions\n };\n}\n\nvar __defProp$7 = Object.defineProperty;\nvar __defProps$2 = Object.defineProperties;\nvar __getOwnPropDescs$2 = Object.getOwnPropertyDescriptors;\nvar __getOwnPropSymbols$8 = Object.getOwnPropertySymbols;\nvar __hasOwnProp$8 = Object.prototype.hasOwnProperty;\nvar __propIsEnum$8 = Object.prototype.propertyIsEnumerable;\nvar __defNormalProp$7 = (obj, key, value) => key in obj ? __defProp$7(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;\nvar __spreadValues$7 = (a, b) => {\n for (var prop in b || (b = {}))\n if (__hasOwnProp$8.call(b, prop))\n __defNormalProp$7(a, prop, b[prop]);\n if (__getOwnPropSymbols$8)\n for (var prop of __getOwnPropSymbols$8(b)) {\n if (__propIsEnum$8.call(b, prop))\n __defNormalProp$7(a, prop, b[prop]);\n }\n return a;\n};\nvar __spreadProps$2 = (a, b) => __defProps$2(a, __getOwnPropDescs$2(b));\nfunction useInfiniteScroll(element, onLoadMore, options = {}) {\n var _a;\n const state = reactive(useScroll(element, __spreadProps$2(__spreadValues$7({}, options), {\n offset: __spreadValues$7({\n bottom: (_a = options.distance) != null ? _a : 0\n }, options.offset)\n })));\n watch(() => state.arrivedState.bottom, (v) => {\n if (v)\n onLoadMore(state);\n });\n}\n\nfunction useIntersectionObserver(target, callback, options = {}) {\n const {\n root,\n rootMargin = \"0px\",\n threshold = 0.1,\n window = defaultWindow\n } = options;\n const isSupported = window && \"IntersectionObserver\" in window;\n let cleanup = noop;\n const stopWatch = isSupported ? watch(() => ({\n el: unrefElement(target),\n root: unrefElement(root)\n }), ({ el, root: root2 }) => {\n cleanup();\n if (!el)\n return;\n const observer = new IntersectionObserver(callback, {\n root: root2,\n rootMargin,\n threshold\n });\n observer.observe(el);\n cleanup = () => {\n observer.disconnect();\n cleanup = noop;\n };\n }, { immediate: true, flush: \"post\" }) : noop;\n const stop = () => {\n cleanup();\n stopWatch();\n };\n tryOnScopeDispose(stop);\n return {\n isSupported,\n stop\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 = { toJSON() {\n return {};\n }, current };\n const refs = useReactive ? reactive(obj) : obj;\n const metaDeps = /* @__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 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 (code) {\n if (value)\n current.add(e.code);\n else\n current.delete(e.code);\n }\n for (const key2 of values)\n setRefs(key2, value);\n if (key === \"meta\" && !value) {\n metaDeps.forEach((key2) => {\n current.delete(key2);\n setRefs(key2, false);\n });\n metaDeps.clear();\n } else if (e.getModifierState(\"Meta\") && value) {\n [...current, ...values].forEach((key2) => metaDeps.add(key2));\n }\n }\n if (target) {\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 }\n const proxy = new Proxy(refs, {\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) => unref(proxy[key])));\n } else {\n refs[prop] = ref(false);\n }\n }\n const r = Reflect.get(target2, prop, rec);\n return useReactive ? unref(r) : r;\n }\n });\n return proxy;\n}\n\nvar __defProp$6 = Object.defineProperty;\nvar __getOwnPropSymbols$7 = Object.getOwnPropertySymbols;\nvar __hasOwnProp$7 = Object.prototype.hasOwnProperty;\nvar __propIsEnum$7 = Object.prototype.propertyIsEnumerable;\nvar __defNormalProp$6 = (obj, key, value) => key in obj ? __defProp$6(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;\nvar __spreadValues$6 = (a, b) => {\n for (var prop in b || (b = {}))\n if (__hasOwnProp$7.call(b, prop))\n __defNormalProp$6(a, prop, b[prop]);\n if (__getOwnPropSymbols$7)\n for (var prop of __getOwnPropSymbols$7(b)) {\n if (__propIsEnum$7.call(b, prop))\n __defNormalProp$6(a, prop, b[prop]);\n }\n return a;\n};\nfunction usingElRef(source, cb) {\n if (unref(source))\n cb(unref(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 options = __spreadValues$6(__spreadValues$6({}, defaultOptions), options);\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 disableTrack = (track) => {\n usingElRef(target, (el) => {\n if (track) {\n const id = isNumber(track) ? 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 = isNumber(track) ? 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 = unref(target);\n if (!el)\n return;\n const src = unref(options.src);\n let sources = [];\n if (!src)\n return;\n if (isString(src))\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 = unref(target);\n if (!el)\n return;\n el.querySelectorAll(\"source\").forEach((e) => e.removeEventListener(\"error\", sourceErrorEvent.trigger));\n });\n watch(volume, (vol) => {\n const el = unref(target);\n if (!el)\n return;\n el.volume = vol;\n });\n watch(muted, (mute) => {\n const el = unref(target);\n if (!el)\n return;\n el.muted = mute;\n });\n watch(rate, (rate2) => {\n const el = unref(target);\n if (!el)\n return;\n el.playbackRate = rate2;\n });\n watchEffect(() => {\n if (!document)\n return;\n const textTracks = unref(options.tracks);\n const el = unref(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 = unref(target);\n if (!el)\n return;\n el.currentTime = time;\n });\n const { ignoreUpdates: ignorePlayingUpdates } = watchIgnorable(playing, (isPlaying) => {\n const el = unref(target);\n if (!el)\n return;\n isPlaying ? el.play() : el.pause();\n });\n useEventListener(target, \"timeupdate\", () => ignoreCurrentTimeUpdates(() => currentTime.value = unref(target).currentTime));\n useEventListener(target, \"durationchange\", () => duration.value = unref(target).duration);\n useEventListener(target, \"progress\", () => buffered.value = timeRangeToArray(unref(target).buffered));\n useEventListener(target, \"seeking\", () => seeking.value = true);\n useEventListener(target, \"seeked\", () => seeking.value = false);\n useEventListener(target, \"waiting\", () => waiting.value = true);\n useEventListener(target, \"playing\", () => waiting.value = false);\n useEventListener(target, \"ratechange\", () => rate.value = unref(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 = unref(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 = unref(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 muted,\n tracks,\n selectedTrack,\n enableTrack,\n disableTrack,\n supportsPictureInPicture,\n togglePictureInPicture,\n isPictureInPicture,\n onSourceError: sourceErrorEvent.on\n };\n}\n\nconst getMapVue2Compat = () => {\n const data = reactive({});\n return {\n get: (key) => data[key],\n set: (key, value) => set(data, key, value),\n has: (key) => Object.prototype.hasOwnProperty.call(data, key),\n delete: (key) => del(data, key),\n clear: () => {\n Object.keys(data).forEach((key) => {\n del(data, key);\n });\n }\n };\n};\nfunction useMemoize(resolver, options) {\n const initCache = () => {\n if (options == null ? void 0 : options.cache)\n return reactive(options.cache);\n if (isVue2)\n return getMapVue2Compat();\n return reactive(/* @__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 = typeof performance !== \"undefined\" && \"memory\" in performance;\n if (isSupported) {\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\nfunction useMounted() {\n const isMounted = ref(false);\n onMounted(() => {\n isMounted.value = true;\n });\n return isMounted;\n}\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 eventFilter\n } = options;\n const x = ref(initialValue.x);\n const y = ref(initialValue.y);\n const sourceType = ref(null);\n const mouseHandler = (event) => {\n if (type === \"page\") {\n x.value = event.pageX;\n y.value = event.pageY;\n } else if (type === \"client\") {\n x.value = event.clientX;\n y.value = event.clientY;\n }\n sourceType.value = \"mouse\";\n };\n const reset = () => {\n x.value = initialValue.x;\n y.value = initialValue.y;\n };\n const touchHandler = (event) => {\n if (event.touches.length > 0) {\n const touch2 = event.touches[0];\n if (type === \"page\") {\n x.value = touch2.pageX;\n y.value = touch2.pageY;\n } else if (type === \"client\") {\n x.value = touch2.clientX;\n y.value = touch2.clientY;\n }\n sourceType.value = \"touch\";\n }\n };\n const mouseHandlerWrapper = (event) => {\n return eventFilter === void 0 ? mouseHandler(event) : eventFilter(() => mouseHandler(event), {});\n };\n const touchHandlerWrapper = (event) => {\n return eventFilter === void 0 ? touchHandler(event) : eventFilter(() => touchHandler(event), {});\n };\n if (window) {\n useEventListener(window, \"mousemove\", mouseHandlerWrapper, { passive: true });\n useEventListener(window, \"dragover\", mouseHandlerWrapper, { passive: true });\n if (touch) {\n useEventListener(window, \"touchstart\", touchHandlerWrapper, { passive: true });\n useEventListener(window, \"touchmove\", touchHandlerWrapper, { passive: true });\n if (resetOnTouchEnds)\n useEventListener(window, \"touchend\", reset, { passive: true });\n }\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 { 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(false);\n let stop = () => {\n };\n if (window) {\n stop = watch([targetRef, x, y], () => {\n const el = unrefElement(targetRef);\n if (!el)\n return;\n const {\n left,\n top,\n width,\n height\n } = el.getBoundingClientRect();\n elementPositionX.value = left + window.pageXOffset;\n elementPositionY.value = top + window.pageYOffset;\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 = elX < 0 || elY < 0 || elX > elementWidth.value || elY > elementHeight.value;\n if (handleOutside || !isOutside.value) {\n elementX.value = elX;\n elementY.value = elY;\n }\n }, { immediate: true });\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 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 });\n useEventListener(window, \"mouseleave\", onReleased, { passive: true });\n useEventListener(window, \"mouseup\", onReleased, { passive: true });\n if (drag) {\n useEventListener(target, \"dragstart\", onPressed(\"mouse\"), { passive: true });\n useEventListener(window, \"drop\", onReleased, { passive: true });\n useEventListener(window, \"dragend\", onReleased, { passive: true });\n }\n if (touch) {\n useEventListener(target, \"touchstart\", onPressed(\"touch\"), { passive: true });\n useEventListener(window, \"touchend\", onReleased, { passive: true });\n useEventListener(window, \"touchcancel\", onReleased, { passive: true });\n }\n return {\n pressed,\n sourceType\n };\n}\n\nvar __getOwnPropSymbols$6 = Object.getOwnPropertySymbols;\nvar __hasOwnProp$6 = Object.prototype.hasOwnProperty;\nvar __propIsEnum$6 = Object.prototype.propertyIsEnumerable;\nvar __objRest$1 = (source, exclude) => {\n var target = {};\n for (var prop in source)\n if (__hasOwnProp$6.call(source, prop) && exclude.indexOf(prop) < 0)\n target[prop] = source[prop];\n if (source != null && __getOwnPropSymbols$6)\n for (var prop of __getOwnPropSymbols$6(source)) {\n if (exclude.indexOf(prop) < 0 && __propIsEnum$6.call(source, prop))\n target[prop] = source[prop];\n }\n return target;\n};\nfunction useMutationObserver(target, callback, options = {}) {\n const _a = options, { window = defaultWindow } = _a, mutationOptions = __objRest$1(_a, [\"window\"]);\n let observer;\n const isSupported = window && \"IntersectionObserver\" in window;\n const cleanup = () => {\n if (observer) {\n observer.disconnect();\n observer = void 0;\n }\n };\n const stopWatch = watch(() => unrefElement(target), (el) => {\n cleanup();\n if (isSupported && window && el) {\n observer = new MutationObserver(callback);\n observer.observe(el, mutationOptions);\n }\n }, { immediate: true });\n const stop = () => {\n cleanup();\n stopWatch();\n };\n tryOnScopeDispose(stop);\n return {\n isSupported,\n stop\n };\n}\n\nconst useNavigatorLanguage = (options = {}) => {\n const { window = defaultWindow } = options;\n const navigator = window == null ? void 0 : window.navigator;\n const isSupported = Boolean(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 = Boolean(navigator && \"connection\" in navigator);\n const isOnline = ref(true);\n const saveData = ref(false);\n const offlineAt = 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 && 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 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 });\n }\n if (connection)\n useEventListener(connection, \"change\", updateNetworkInformation, false);\n updateNetworkInformation();\n return {\n isSupported,\n isOnline,\n saveData,\n offlineAt,\n downlink,\n downlinkMax,\n effectiveType,\n rtt,\n type\n };\n}\n\nvar __defProp$5 = Object.defineProperty;\nvar __getOwnPropSymbols$5 = Object.getOwnPropertySymbols;\nvar __hasOwnProp$5 = Object.prototype.hasOwnProperty;\nvar __propIsEnum$5 = Object.prototype.propertyIsEnumerable;\nvar __defNormalProp$5 = (obj, key, value) => key in obj ? __defProp$5(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;\nvar __spreadValues$5 = (a, b) => {\n for (var prop in b || (b = {}))\n if (__hasOwnProp$5.call(b, prop))\n __defNormalProp$5(a, prop, b[prop]);\n if (__getOwnPropSymbols$5)\n for (var prop of __getOwnPropSymbols$5(b)) {\n if (__propIsEnum$5.call(b, prop))\n __defNormalProp$5(a, prop, b[prop]);\n }\n return a;\n};\nfunction useNow(options = {}) {\n const {\n controls: exposeControls = false,\n interval = \"requestAnimationFrame\"\n } = options;\n const now = ref(new Date());\n const update = () => now.value = new Date();\n const controls = interval === \"requestAnimationFrame\" ? useRafFn(update, { immediate: true }) : useIntervalFn(update, interval, { immediate: true });\n if (exposeControls) {\n return __spreadValues$5({\n now\n }, controls);\n } else {\n return now;\n }\n}\n\nfunction useOffsetPagination(options) {\n const {\n total = Infinity,\n pageSize = 10,\n page = 1,\n onPageChange = noop,\n onPageSizeChange = noop,\n onPageCountChange = noop\n } = options;\n const currentPageSize = useClamp(pageSize, 1, Infinity);\n const pageCount = computed(() => Math.ceil(unref(total) / unref(currentPageSize)));\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 if (isRef(pageSize))\n syncRef(pageSize, currentPageSize);\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 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 {\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 return \"mouse\";\n });\n const roll = computed(() => {\n if (source.value === \"deviceOrientation\") {\n const value = -orientation.beta / 90;\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 const value = orientation.gamma / 90;\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\nvar __defProp$4 = Object.defineProperty;\nvar __defProps$1 = Object.defineProperties;\nvar __getOwnPropDescs$1 = Object.getOwnPropertyDescriptors;\nvar __getOwnPropSymbols$4 = Object.getOwnPropertySymbols;\nvar __hasOwnProp$4 = Object.prototype.hasOwnProperty;\nvar __propIsEnum$4 = Object.prototype.propertyIsEnumerable;\nvar __defNormalProp$4 = (obj, key, value) => key in obj ? __defProp$4(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;\nvar __spreadValues$4 = (a, b) => {\n for (var prop in b || (b = {}))\n if (__hasOwnProp$4.call(b, prop))\n __defNormalProp$4(a, prop, b[prop]);\n if (__getOwnPropSymbols$4)\n for (var prop of __getOwnPropSymbols$4(b)) {\n if (__propIsEnum$4.call(b, prop))\n __defNormalProp$4(a, prop, b[prop]);\n }\n return a;\n};\nvar __spreadProps$1 = (a, b) => __defProps$1(a, __getOwnPropDescs$1(b));\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 useEventListener(target, \"pointerdown\", handler, { passive: true });\n useEventListener(target, \"pointermove\", handler, { passive: true });\n useEventListener(target, \"pointerleave\", () => isInside.value = false, { passive: true });\n }\n return __spreadProps$1(__spreadValues$4({}, toRefs(state)), {\n isInside\n });\n}\n\nvar SwipeDirection = /* @__PURE__ */ ((SwipeDirection2) => {\n SwipeDirection2[\"UP\"] = \"UP\";\n SwipeDirection2[\"RIGHT\"] = \"RIGHT\";\n SwipeDirection2[\"DOWN\"] = \"DOWN\";\n SwipeDirection2[\"LEFT\"] = \"LEFT\";\n SwipeDirection2[\"NONE\"] = \"NONE\";\n return SwipeDirection2;\n})(SwipeDirection || {});\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\" /* NONE */;\n if (abs(diffX.value) > abs(diffY.value)) {\n return diffX.value > 0 ? \"LEFT\" /* LEFT */ : \"RIGHT\" /* RIGHT */;\n } else {\n return diffY.value > 0 ? \"UP\" /* UP */ : \"DOWN\" /* 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 (listenerOptions.capture && !listenerOptions.passive)\n e.preventDefault();\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 const [x, y] = getTouchEventCoords(e);\n updateCoordsEnd(x, y);\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\", onTouchEnd, listenerOptions),\n useEventListener(target, \"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 usePointerSwipe(target, options = {}) {\n const targetRef = ref(target);\n const {\n threshold = 50,\n onSwipe,\n onSwipeEnd,\n onSwipeStart\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 SwipeDirection.NONE;\n if (abs(distanceX.value) > abs(distanceY.value)) {\n return distanceX.value > 0 ? SwipeDirection.LEFT : SwipeDirection.RIGHT;\n } else {\n return distanceY.value > 0 ? SwipeDirection.UP : SwipeDirection.DOWN;\n }\n });\n const filterEvent = (e) => {\n if (options.pointerTypes)\n return options.pointerTypes.includes(e.pointerType);\n return true;\n };\n const stops = [\n useEventListener(target, \"pointerdown\", (e) => {\n var _a, _b;\n if (!filterEvent(e))\n return;\n isPointerDown.value = true;\n (_b = (_a = targetRef.value) == null ? void 0 : _a.style) == null ? void 0 : _b.setProperty(\"touch-action\", \"none\");\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 (!filterEvent(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 var _a, _b;\n if (!filterEvent(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 (_b = (_a = targetRef.value) == null ? void 0 : _a.style) == null ? void 0 : _b.setProperty(\"touch-action\", \"initial\");\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 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\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=\"${src}\"]`);\n if (!el) {\n el = document.createElement(\"script\");\n el.type = type;\n el.async = async;\n el.src = unref(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=\"${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\nvar _a, _b;\nfunction preventDefault(rawEvent) {\n const e = rawEvent || window.event;\n if (e.touches.length > 1)\n return true;\n if (e.preventDefault)\n e.preventDefault();\n return false;\n}\nconst isIOS = isClient && (window == null ? void 0 : window.navigator) && ((_a = window == null ? void 0 : window.navigator) == null ? void 0 : _a.platform) && /iP(ad|hone|od)/.test((_b = window == null ? void 0 : window.navigator) == null ? void 0 : _b.platform);\nfunction useScrollLock(element, initialState = false) {\n const isLocked = ref(initialState);\n let touchMoveListener = null;\n let initialOverflow;\n watch(() => unref(element), (el) => {\n if (el) {\n const ele = el;\n initialOverflow = ele.style.overflow;\n if (isLocked.value)\n ele.style.overflow = \"hidden\";\n }\n }, {\n immediate: true\n });\n const lock = () => {\n const ele = unref(element);\n if (!ele || isLocked.value)\n return;\n if (isIOS) {\n touchMoveListener = useEventListener(document, \"touchmove\", preventDefault, { passive: false });\n }\n ele.style.overflow = \"hidden\";\n isLocked.value = true;\n };\n const unlock = () => {\n const ele = unref(element);\n if (!ele || !isLocked.value)\n return;\n isIOS && (touchMoveListener == null ? void 0 : touchMoveListener());\n ele.style.overflow = initialOverflow;\n isLocked.value = false;\n };\n return computed({\n get() {\n return isLocked.value;\n },\n set(v) {\n if (v)\n lock();\n else\n 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\nvar __defProp$3 = Object.defineProperty;\nvar __getOwnPropSymbols$3 = Object.getOwnPropertySymbols;\nvar __hasOwnProp$3 = Object.prototype.hasOwnProperty;\nvar __propIsEnum$3 = Object.prototype.propertyIsEnumerable;\nvar __defNormalProp$3 = (obj, key, value) => key in obj ? __defProp$3(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;\nvar __spreadValues$3 = (a, b) => {\n for (var prop in b || (b = {}))\n if (__hasOwnProp$3.call(b, prop))\n __defNormalProp$3(a, prop, b[prop]);\n if (__getOwnPropSymbols$3)\n for (var prop of __getOwnPropSymbols$3(b)) {\n if (__propIsEnum$3.call(b, prop))\n __defNormalProp$3(a, prop, b[prop]);\n }\n return a;\n};\nfunction useShare(shareOptions = {}, options = {}) {\n const { navigator = defaultNavigator } = options;\n const _navigator = navigator;\n const isSupported = _navigator && \"canShare\" in _navigator;\n const share = async (overrideOptions = {}) => {\n if (isSupported) {\n const data = __spreadValues$3(__spreadValues$3({}, unref(shareOptions)), unref(overrideOptions));\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\nfunction useSpeechRecognition(options = {}) {\n const {\n interimResults = true,\n continuous = true,\n window = defaultWindow\n } = options;\n const lang = ref(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 = Boolean(SpeechRecognition);\n let recognition;\n if (isSupported) {\n recognition = new SpeechRecognition();\n recognition.continuous = continuous;\n recognition.interimResults = interimResults;\n recognition.lang = unref(lang);\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 transcript = Array.from(event.results).map((result2) => {\n isFinal.value = result2.isFinal;\n return result2[0];\n }).map((result2) => result2.transcript).join(\"\");\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 = unref(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 var _a, _b;\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 = Boolean(synth);\n const isPlaying = ref(false);\n const status = ref(\"init\");\n const voiceInfo = {\n lang: ((_a = options.voice) == null ? void 0 : _a.lang) || \"default\",\n name: ((_b = options.voice) == null ? void 0 : _b.name) || \"\"\n };\n const spokenText = ref(text || \"\");\n const lang = ref(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 = unref(lang);\n options.voice && (utterance2.voice = options.voice);\n utterance2.pitch = pitch;\n utterance2.rate = 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 utterance2.onend = () => {\n isPlaying.value = false;\n utterance2.lang = unref(lang);\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 utterance && synth.speak(utterance.value);\n };\n if (isSupported) {\n bindEventsForUtterance(utterance.value);\n watch(lang, (lang2) => {\n if (utterance.value && !isPlaying.value)\n utterance.value.lang = lang2;\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 voiceInfo,\n utterance,\n error,\n toggle,\n speak\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 shallow,\n window = defaultWindow,\n eventFilter,\n onError = (e) => {\n console.error(e);\n }\n } = options;\n const rawInit = unref(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(\"getDefaultStorage\", () => {\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 {\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) => setTimeout(() => read(e), 0));\n if (storage) {\n watchWithFilter(data, 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 flush,\n deep,\n eventFilter\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 el.type = \"text/css\";\n el.id = id;\n if (options.media)\n el.media = options.media;\n document.head.appendChild(el);\n if (isLoaded.value)\n return;\n stop = watch(cssRef, (value) => {\n el.innerText = value;\n }, { immediate: true });\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 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 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 getRangesFromSelection(selection) {\n var _a;\n const rangeCount = (_a = selection.rangeCount) != null ? _a : 0;\n const ranges = new Array(rangeCount);\n for (let i = 0; i < rangeCount; i++) {\n const range = selection.getRangeAt(i);\n ranges[i] = range;\n }\n return ranges;\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\nvar __defProp$2 = Object.defineProperty;\nvar __defProps = Object.defineProperties;\nvar __getOwnPropDescs = Object.getOwnPropertyDescriptors;\nvar __getOwnPropSymbols$2 = Object.getOwnPropertySymbols;\nvar __hasOwnProp$2 = Object.prototype.hasOwnProperty;\nvar __propIsEnum$2 = Object.prototype.propertyIsEnumerable;\nvar __defNormalProp$2 = (obj, key, value) => key in obj ? __defProp$2(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;\nvar __spreadValues$2 = (a, b) => {\n for (var prop in b || (b = {}))\n if (__hasOwnProp$2.call(b, prop))\n __defNormalProp$2(a, prop, b[prop]);\n if (__getOwnPropSymbols$2)\n for (var prop of __getOwnPropSymbols$2(b)) {\n if (__propIsEnum$2.call(b, prop))\n __defNormalProp$2(a, prop, b[prop]);\n }\n return a;\n};\nvar __spreadProps = (a, b) => __defProps(a, __getOwnPropDescs(b));\nfunction useThrottledRefHistory(source, options = {}) {\n const { throttle = 200, trailing = true } = options;\n const filter = throttleFilter(throttle, trailing);\n const history = useRefHistory(source, __spreadProps(__spreadValues$2({}, options), { eventFilter: filter }));\n return __spreadValues$2({}, history);\n}\n\nvar __defProp$1 = Object.defineProperty;\nvar __getOwnPropSymbols$1 = Object.getOwnPropertySymbols;\nvar __hasOwnProp$1 = Object.prototype.hasOwnProperty;\nvar __propIsEnum$1 = Object.prototype.propertyIsEnumerable;\nvar __defNormalProp$1 = (obj, key, value) => key in obj ? __defProp$1(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;\nvar __spreadValues$1 = (a, b) => {\n for (var prop in b || (b = {}))\n if (__hasOwnProp$1.call(b, prop))\n __defNormalProp$1(a, prop, b[prop]);\n if (__getOwnPropSymbols$1)\n for (var prop of __getOwnPropSymbols$1(b)) {\n if (__propIsEnum$1.call(b, prop))\n __defNormalProp$1(a, prop, b[prop]);\n }\n return a;\n};\nvar __objRest = (source, exclude) => {\n var target = {};\n for (var prop in source)\n if (__hasOwnProp$1.call(source, prop) && exclude.indexOf(prop) < 0)\n target[prop] = source[prop];\n if (source != null && __getOwnPropSymbols$1)\n for (var prop of __getOwnPropSymbols$1(source)) {\n if (exclude.indexOf(prop) < 0 && __propIsEnum$1.call(source, prop))\n target[prop] = source[prop];\n }\n return target;\n};\nconst 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: 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};\nconst DEFAULT_FORMATTER = (date) => date.toISOString().slice(0, 10);\nfunction useTimeAgo(time, options = {}) {\n const {\n controls: exposeControls = false,\n max,\n updateInterval = 3e4,\n messages = DEFAULT_MESSAGES,\n fullDateFormatter = DEFAULT_FORMATTER\n } = options;\n const { abs, round } = Math;\n const _a = useNow({ interval: updateInterval, controls: true }), { now } = _a, controls = __objRest(_a, [\"now\"]);\n function getTimeago(from, now2) {\n var _a2;\n const diff = +now2 - +from;\n const absDiff = abs(diff);\n if (absDiff < 6e4)\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 = (_a2 = UNITS.find((i) => i.name === max)) == null ? void 0 : _a2.max;\n if (unitMax && absDiff > unitMax)\n return fullDateFormatter(new Date(from));\n }\n for (const unit of UNITS) {\n if (absDiff < unit.max)\n return format(diff, unit);\n }\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 function format(diff, unit) {\n const val = round(abs(diff) / unit.value);\n const past = diff > 0;\n const str = applyFormat(unit.name, val, past);\n return applyFormat(past ? \"past\" : \"future\", str, past);\n }\n const timeAgo = computed(() => getTimeago(new Date(unref(time)), unref(now.value)));\n if (exposeControls) {\n return __spreadValues$1({\n timeAgo\n }, controls);\n } else {\n return timeAgo;\n }\n}\n\nfunction useTimeoutPoll(fn, interval, timeoutPollOptions) {\n const { start } = useTimeoutFn(loop, interval);\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\nvar __defProp = Object.defineProperty;\nvar __getOwnPropSymbols = Object.getOwnPropertySymbols;\nvar __hasOwnProp = Object.prototype.hasOwnProperty;\nvar __propIsEnum = Object.prototype.propertyIsEnumerable;\nvar __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;\nvar __spreadValues = (a, b) => {\n for (var prop in b || (b = {}))\n if (__hasOwnProp.call(b, prop))\n __defNormalProp(a, prop, b[prop]);\n if (__getOwnPropSymbols)\n for (var prop of __getOwnPropSymbols(b)) {\n if (__propIsEnum.call(b, prop))\n __defNormalProp(a, prop, b[prop]);\n }\n return a;\n};\nfunction useTimestamp(options = {}) {\n const {\n controls: exposeControls = false,\n offset = 0,\n immediate = true,\n interval = \"requestAnimationFrame\"\n } = options;\n const ts = ref(timestamp() + offset);\n const update = () => ts.value = timestamp() + offset;\n const controls = interval === \"requestAnimationFrame\" ? useRafFn(update, { immediate }) : useIntervalFn(update, interval, { immediate });\n if (exposeControls) {\n return __spreadValues({\n timestamp: ts\n }, controls);\n } else {\n return ts;\n }\n}\n\nfunction useTitle(newTitle = null, options = {}) {\n var _a, _b;\n const {\n document = defaultDocument,\n observe = false,\n titleTemplate = \"%s\"\n } = options;\n const title = ref((_a = newTitle != null ? newTitle : document == null ? void 0 : document.title) != null ? _a : null);\n watch(title, (t, o) => {\n if (isString(t) && t !== o && document)\n document.title = titleTemplate.replace(\"%s\", t);\n }, { immediate: true });\n if (observe && document) {\n useMutationObserver((_b = document.head) == null ? void 0 : _b.querySelector(\"title\"), () => {\n if (document && document.title !== title.value)\n title.value = titleTemplate.replace(\"%s\", document.title);\n }, { childList: true });\n }\n return title;\n}\n\nconst TransitionPresets = {\n linear: identity,\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};\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 useTransition(source, options = {}) {\n const {\n delay = 0,\n disabled = false,\n duration = 1e3,\n onFinished = noop,\n onStarted = noop,\n transition = identity\n } = options;\n const currentTransition = computed(() => {\n const t = unref(transition);\n return isFunction(t) ? t : createEasingFunction(t);\n });\n const sourceValue = computed(() => {\n const s = unref(source);\n return isNumber(s) ? s : s.map(unref);\n });\n const sourceVector = computed(() => isNumber(sourceValue.value) ? [sourceValue.value] : sourceValue.value);\n const outputVector = ref(sourceVector.value.slice(0));\n let currentDuration;\n let diffVector;\n let endAt;\n let startAt;\n let startVector;\n const { resume, pause } = useRafFn(() => {\n const now = Date.now();\n const progress = clamp(1 - (endAt - now) / currentDuration, 0, 1);\n outputVector.value = startVector.map((val, i) => {\n var _a;\n return val + ((_a = diffVector[i]) != null ? _a : 0) * currentTransition.value(progress);\n });\n if (progress >= 1) {\n pause();\n onFinished();\n }\n }, { immediate: false });\n const start = () => {\n pause();\n currentDuration = unref(duration);\n diffVector = outputVector.value.map((n, i) => {\n var _a, _b;\n return ((_a = sourceVector.value[i]) != null ? _a : 0) - ((_b = outputVector.value[i]) != null ? _b : 0);\n });\n startVector = outputVector.value.slice(0);\n startAt = Date.now();\n endAt = startAt + currentDuration;\n resume();\n onStarted();\n };\n const timeout = useTimeoutFn(start, delay, { immediate: false });\n watch(sourceVector, () => {\n if (unref(disabled)) {\n outputVector.value = sourceVector.value.slice(0);\n } else {\n if (unref(delay) <= 0)\n start();\n else\n timeout.start();\n }\n }, { deep: true });\n return computed(() => {\n const targetVector = unref(disabled) ? sourceVector : outputVector;\n return isNumber(sourceValue.value) ? targetVector.value[0] : targetVector.value;\n });\n}\n\nfunction useUrlSearchParams(mode = \"history\", options = {}) {\n const {\n initialValue = {},\n removeNullishValues = true,\n removeFalsyValues = false,\n window = defaultWindow\n } = options;\n if (!window)\n return reactive(initialValue);\n const state = reactive(initialValue);\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}` : \"\"}${location.hash || \"\"}`;\n if (mode === \"hash-params\")\n return `${location.search || \"\"}${stringified ? `#${stringified}` : \"\"}`;\n const hash = window.location.hash || \"#\";\n const index = hash.indexOf(\"?\");\n if (index > 0)\n return `${hash.slice(0, index)}${stringified ? `?${stringified}` : \"\"}`;\n return `${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(state, () => {\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 }, { deep: true });\n function write(params, shouldUpdate) {\n pause();\n if (shouldUpdate)\n updateState(params);\n window.history.replaceState({}, \"\", window.location.pathname + constructQuery(params));\n resume();\n }\n function onChanged() {\n write(read(), true);\n }\n useEventListener(window, \"popstate\", onChanged, false);\n if (mode !== \"history\")\n useEventListener(window, \"hashchange\", onChanged, false);\n updateState(read());\n return state;\n}\n\nfunction useUserMedia(options = {}) {\n var _a, _b, _c;\n const enabled = ref((_a = options.enabled) != null ? _a : false);\n const autoSwitch = ref((_b = options.autoSwitch) != null ? _b : true);\n const videoDeviceId = ref(options.videoDeviceId);\n const audioDeviceId = ref(options.audioDeviceId);\n const { navigator = defaultNavigator } = options;\n const isSupported = Boolean((_c = navigator == null ? void 0 : navigator.mediaDevices) == null ? void 0 : _c.getUserMedia);\n const stream = shallowRef();\n function getDeviceOptions(device) {\n if (device.value === \"none\" || device.value === false)\n return false;\n if (device.value == null)\n return true;\n return {\n deviceId: device.value\n };\n }\n async function _start() {\n if (!isSupported || stream.value)\n return;\n stream.value = await navigator.mediaDevices.getUserMedia({\n video: getDeviceOptions(videoDeviceId),\n audio: getDeviceOptions(audioDeviceId)\n });\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 async function restart() {\n _stop();\n return await start();\n }\n watch(enabled, (v) => {\n if (v)\n _start();\n else\n _stop();\n }, { immediate: true });\n watch([videoDeviceId, audioDeviceId], () => {\n if (autoSwitch.value && stream.value)\n restart();\n }, { immediate: true });\n return {\n isSupported,\n stream,\n start,\n stop,\n restart,\n videoDeviceId,\n audioDeviceId,\n enabled,\n autoSwitch\n };\n}\n\nfunction useVModel(props, key, emit, options = {}) {\n var _a, _b, _c;\n const {\n passive = false,\n eventName,\n deep = false\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));\n let event = eventName;\n if (!key) {\n if (isVue2) {\n const modelOptions = (_c = (_b = vm == null ? void 0 : vm.proxy) == null ? void 0 : _b.$options) == null ? void 0 : _c.model;\n key = (modelOptions == null ? void 0 : modelOptions.value) || \"value\";\n if (!eventName)\n event = (modelOptions == null ? void 0 : modelOptions.event) || \"input\";\n } else {\n key = \"modelValue\";\n }\n }\n event = eventName || event || `update:${key}`;\n if (passive) {\n const proxy = ref(props[key]);\n watch(() => props[key], (v) => proxy.value = v);\n watch(proxy, (v) => {\n if (v !== props[key] || deep)\n _emit(event, v);\n }, {\n deep\n });\n return proxy;\n } else {\n return computed({\n get() {\n return props[key];\n },\n set(value) {\n _emit(event, value);\n }\n });\n }\n}\n\nfunction useVModels(props, emit, options = {}) {\n const ret = {};\n for (const key in props)\n ret[key] = useVModel(props, key, emit, options);\n return ret;\n}\n\nfunction useVibrate(options) {\n const {\n pattern = [],\n interval = 0,\n navigator = defaultNavigator\n } = options || {};\n const isSupported = typeof navigator !== \"undefined\" && \"vibrate\" in navigator;\n const patternRef = ref(pattern);\n let intervalControls;\n const vibrate = (pattern2 = patternRef.value) => {\n if (isSupported)\n navigator.vibrate(pattern2);\n };\n const stop = () => {\n if (isSupported)\n navigator.vibrate(0);\n intervalControls == null ? void 0 : intervalControls.pause();\n };\n if (interval > 0) {\n intervalControls = useIntervalFn(vibrate, interval, {\n immediate: false,\n immediateCallback: false\n });\n }\n return {\n isSupported,\n pattern,\n intervalControls,\n vibrate,\n stop\n };\n}\n\nfunction useVirtualList(list, options) {\n const containerRef = ref();\n const size = useElementSize(containerRef);\n const currentList = ref([]);\n const source = shallowRef(list);\n const state = ref({ start: 0, end: 10 });\n const { itemHeight, overscan = 5 } = options;\n const getViewCapacity = (containerHeight) => {\n if (typeof itemHeight === \"number\")\n return Math.ceil(containerHeight / itemHeight);\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 height = itemHeight(i);\n sum += height;\n if (sum >= containerHeight) {\n capacity = i;\n break;\n }\n }\n return capacity - start;\n };\n const getOffset = (scrollTop) => {\n if (typeof itemHeight === \"number\")\n return Math.floor(scrollTop / itemHeight) + 1;\n let sum = 0;\n let offset = 0;\n for (let i = 0; i < source.value.length; i++) {\n const height = itemHeight(i);\n sum += height;\n if (sum >= scrollTop) {\n offset = i;\n break;\n }\n }\n return offset + 1;\n };\n const calculateRange = () => {\n const element = containerRef.value;\n if (element) {\n const offset = getOffset(element.scrollTop);\n const viewCapacity = getViewCapacity(element.clientHeight);\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 watch([size.width, size.height, list], () => {\n calculateRange();\n });\n const totalHeight = computed(() => {\n if (typeof itemHeight === \"number\")\n return source.value.length * itemHeight;\n return source.value.reduce((sum, _, index) => sum + itemHeight(index), 0);\n });\n const getDistanceTop = (index) => {\n if (typeof itemHeight === \"number\") {\n const height2 = index * itemHeight;\n return height2;\n }\n const height = source.value.slice(0, index).reduce((sum, _, i) => sum + itemHeight(i), 0);\n return height;\n };\n const scrollTo = (index) => {\n if (containerRef.value) {\n containerRef.value.scrollTop = getDistanceTop(index);\n calculateRange();\n }\n };\n const offsetTop = computed(() => getDistanceTop(state.value.start));\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 const containerStyle = { overflowY: \"auto\" };\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}\n\nconst useWakeLock = (options = {}) => {\n const {\n navigator = defaultNavigator,\n document = defaultDocument\n } = options;\n let wakeLock;\n const isSupported = navigator && \"wakeLock\" in navigator;\n const isActive = ref(false);\n async function onVisibilityChange() {\n if (!isSupported || !wakeLock)\n return;\n if (document && document.visibilityState === \"visible\")\n wakeLock = await navigator.wakeLock.request(\"screen\");\n isActive.value = !wakeLock.released;\n }\n if (document)\n useEventListener(document, \"visibilitychange\", onVisibilityChange, { passive: true });\n async function request(type) {\n if (!isSupported)\n return;\n wakeLock = await navigator.wakeLock.request(type);\n isActive.value = !wakeLock.released;\n }\n async function release() {\n if (!isSupported || !wakeLock)\n return;\n await wakeLock.release();\n isActive.value = !wakeLock.released;\n wakeLock = null;\n }\n return {\n isSupported,\n isActive,\n request,\n release\n };\n};\n\nconst useWebNotification = (defaultOptions = {}) => {\n const {\n window = defaultWindow\n } = defaultOptions;\n const isSupported = !!window && \"Notification\" in window;\n const notification = ref(null);\n const requestPermission = async () => {\n if (!isSupported)\n return;\n if (\"permission\" in Notification && Notification.permission !== \"denied\")\n await Notification.requestPermission();\n };\n const onClick = createEventHook();\n const onShow = createEventHook();\n const onError = createEventHook();\n const onClose = createEventHook();\n const show = async (overrides) => {\n if (!isSupported)\n return;\n await requestPermission();\n const options = Object.assign({}, defaultOptions, overrides);\n notification.value = new Notification(options.title || \"\", options);\n notification.value.onclick = (event) => onClick.trigger(event);\n notification.value.onshow = (event) => onShow.trigger(event);\n notification.value.onerror = (event) => onError.trigger(event);\n notification.value.onclose = (event) => onClose.trigger(event);\n return notification.value;\n };\n const close = () => {\n if (notification.value)\n notification.value.close();\n notification.value = null;\n };\n tryOnMounted(async () => {\n if (isSupported)\n await requestPermission();\n });\n tryOnScopeDispose(close);\n if (isSupported && 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 show,\n close,\n onClick,\n onShow,\n onError,\n onClose\n };\n};\n\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(\"CONNECTING\");\n const wsRef = ref();\n let heartbeatPause;\n let heartbeatResume;\n let explicitlyClosed = false;\n let retried = 0;\n let bufferedData = [];\n const close = (code = 1e3, reason) => {\n if (!wsRef.value)\n return;\n explicitlyClosed = true;\n heartbeatPause == null ? void 0 : heartbeatPause();\n wsRef.value.close(code, reason);\n };\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 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 const ws = new WebSocket(url, protocols);\n wsRef.value = ws;\n status.value = \"CONNECTING\";\n explicitlyClosed = false;\n ws.onopen = () => {\n status.value = \"OPEN\";\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 wsRef.value = void 0;\n onDisconnected == null ? void 0 : onDisconnected(ws, ev);\n if (!explicitlyClosed && options.autoReconnect) {\n const {\n retries = -1,\n delay = 1e3,\n onFailed\n } = resolveNestedOptions(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 ws.onerror = (e) => {\n onError == null ? void 0 : onError(ws, e);\n };\n ws.onmessage = (e) => {\n data.value = e.data;\n onMessage == null ? void 0 : onMessage(ws, e);\n };\n };\n if (options.heartbeat) {\n const {\n message = \"ping\",\n interval = 1e3\n } = resolveNestedOptions(options.heartbeat);\n const { pause, resume } = useIntervalFn(() => send(message, false), interval, { immediate: false });\n heartbeatPause = pause;\n heartbeatResume = resume;\n }\n if (immediate)\n _init();\n if (autoClose) {\n useEventListener(window, \"beforeunload\", () => close());\n tryOnScopeDispose(close);\n }\n const open = () => {\n close();\n retried = 0;\n _init();\n };\n return {\n data,\n status,\n close,\n send,\n open,\n ws: wsRef\n };\n}\n\nfunction useWebWorker(url, workerOptions, options = {}) {\n const {\n window = defaultWindow\n } = options;\n const data = ref(null);\n const worker = shallowRef();\n const post = function post2(val) {\n if (!worker.value)\n return;\n worker.value.postMessage(val);\n };\n const terminate = function terminate2() {\n if (!worker.value)\n return;\n worker.value.terminate();\n };\n if (window) {\n worker.value = new Worker(url, workerOptions);\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\nconst jobRunner = (userFunc) => (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\nconst depsParser = (deps) => {\n if (deps.length === 0)\n return \"\";\n const depsString = deps.map((dep) => `'${dep}'`).toString();\n return `importScripts(${depsString})`;\n};\n\nconst createWorkerBlobUrl = (fn, deps) => {\n const blobCode = `${depsParser(deps)}; onmessage=(${jobRunner})(${fn})`;\n const blob = new Blob([blobCode], { type: \"text/javascript\" });\n const url = URL.createObjectURL(blob);\n return url;\n};\n\nconst useWebWorkerFn = (fn, options = {}) => {\n const {\n dependencies = [],\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);\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 reject(e);\n workerTerminate(\"ERROR\");\n };\n if (timeout) {\n timeoutId.value = setTimeout(() => workerTerminate(\"TIMEOUT_EXPIRED\"), timeout);\n }\n return newWorker;\n };\n const callWorker = (...fnArgs) => new Promise((resolve, reject) => {\n promise.value = {\n resolve,\n reject\n };\n worker.value && worker.value.postMessage([[...fnArgs]]);\n workerStatus.value = \"RUNNING\";\n });\n const workerFn = (...fnArgs) => {\n if (workerStatus.value === \"RUNNING\") {\n console.error(\"[useWebWorkerFn] You can only run one instance of the worker at a time.\");\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({ window = defaultWindow } = {}) {\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({ window = defaultWindow } = {}) {\n if (!window) {\n return {\n x: ref(0),\n y: ref(0)\n };\n }\n const x = ref(window.pageXOffset);\n const y = ref(window.pageYOffset);\n useEventListener(\"scroll\", () => {\n x.value = window.pageXOffset;\n y.value = window.pageYOffset;\n }, {\n capture: false,\n passive: true\n });\n return { x, y };\n}\n\nfunction useWindowSize({ window = defaultWindow, initialWidth = Infinity, initialHeight = Infinity } = {}) {\n const width = ref(initialWidth);\n const height = ref(initialHeight);\n const update = () => {\n if (window) {\n width.value = window.innerWidth;\n height.value = window.innerHeight;\n }\n };\n update();\n tryOnMounted(update);\n useEventListener(\"resize\", update, { passive: true });\n return { width, height };\n}\n\nexport { DefaultMagicKeysAliasMap, StorageSerializers, SwipeDirection, TransitionPresets, computedAsync as asyncComputed, breakpointsAntDesign, breakpointsBootstrapV5, breakpointsQuasar, breakpointsSematic, breakpointsTailwind, breakpointsVuetify, computedAsync, computedInject, createFetch, createUnrefFn, defaultDocument, defaultLocation, defaultNavigator, defaultWindow, getSSRHandler, mapGamepadToXbox360Controller, onClickOutside, onKeyDown, onKeyPressed, onKeyStroke, onKeyUp, onLongPress, onStartTyping, setSSRHandler, templateRef, unrefElement, useActiveElement, useAsyncQueue, useAsyncState, useBase64, useBattery, useBreakpoints, useBroadcastChannel, useBrowserLocation, useCached, useClamp, useClipboard, useColorMode, useConfirmDialog, useCssVar, useCycleList, useDark, useDebouncedRefHistory, useDeviceMotion, useDeviceOrientation, useDevicePixelRatio, useDevicesList, useDisplayMedia, useDocumentVisibility, useDraggable, useElementBounding, useElementByPoint, useElementHover, useElementSize, useElementVisibility, useEventBus, useEventListener, useEventSource, useEyeDropper, useFavicon, useFetch, useFileSystemAccess, useFocus, useFocusWithin, useFps, useFullscreen, useGamepad, useGeolocation, useIdle, useInfiniteScroll, useIntersectionObserver, useKeyModifier, useLocalStorage, useMagicKeys, useManualRefHistory, useMediaControls, useMediaQuery, useMemoize, useMemory, useMounted, useMouse, useMouseInElement, useMousePressed, useMutationObserver, useNavigatorLanguage, useNetwork, useNow, useOffsetPagination, useOnline, usePageLeave, useParallax, usePermission, usePointer, usePointerSwipe, usePreferredColorScheme, usePreferredDark, usePreferredLanguages, useRafFn, useRefHistory, useResizeObserver, useScreenSafeArea, useScriptTag, useScroll, useScrollLock, useSessionStorage, useShare, useSpeechRecognition, useSpeechSynthesis, useStorage, useStorageAsync, useStyleTag, useSwipe, useTemplateRefsList, useTextSelection, useThrottledRefHistory, useTimeAgo, useTimeoutPoll, useTimestamp, useTitle, useTransition, useUrlSearchParams, useUserMedia, useVModel, useVModels, useVibrate, useVirtualList, useWakeLock, useWebNotification, useWebSocket, useWebWorker, useWebWorkerFn, useWindowFocus, useWindowScroll, useWindowSize };\n","import { useStorage } from '@vueuse/core';\nimport type { RemovableRef } from '@vueuse/core';\n\nexport interface UserMeta {\n nick: string;\n mail: string;\n link: string;\n}\n\nexport const useUserMeta = (): RemovableRef<UserMeta> =>\n useStorage<UserMeta>('WALINE_USER_META', {\n nick: '',\n mail: '',\n link: '',\n });\n\nexport const useEditor = (): RemovableRef<string> =>\n useStorage<string>('WALINE_COMMENT_BOX_EDITOR', '');\n","export const decodePath = (path: string): string => {\n try {\n path = decodeURI(path);\n } catch (err) {\n // ignore error\n }\n\n return path;\n};\n\nexport const removeEndingSplash = (content = ''): string =>\n content.replace(/\\/$/u, '');\n\nexport const isLinkHttp = (link: string): boolean =>\n /^(https?:)?\\/\\//.test(link);\n","import {\n defaultLang,\n defaultUploadImage,\n defaultTexRenderer,\n getMeta,\n locales,\n} from '../config';\n\nimport { decodePath, isLinkHttp, removeEndingSplash } from './path';\n\nimport type {\n WalineEmojiInfo,\n WalineEmojiMaps,\n WalineLocale,\n WalineProps,\n} from '../typings';\nimport hanabi from 'hanabi';\n\nexport interface WalineEmojiConfig {\n tabs: Pick<WalineEmojiInfo, 'name' | 'icon' | 'items'>[];\n map: WalineEmojiMaps;\n}\n\nexport interface WalineConfig extends Required<Omit<WalineProps, 'wordLimit'>> {\n locale: WalineLocale;\n wordLimit: [number, number] | false;\n // emoji: Promise<EmojiConfig>;\n}\n\nconst getServerURL = (serverURL: string): string => {\n const result = removeEndingSplash(serverURL);\n\n return isLinkHttp(result) ? result : `https://${result}`;\n};\n\nconst getWordLimit = (\n wordLimit: WalineProps['wordLimit']\n): [number, number] | false =>\n Array.isArray(wordLimit) ? wordLimit : wordLimit ? [0, wordLimit] : false;\n\nconst fallback = <T = unknown>(\n value: T | false | undefined,\n fallback: T\n): T | false =>\n typeof value === 'function' ? value : value === false ? false : fallback;\n\nexport const getConfig = ({\n serverURL,\n\n path = location.pathname,\n lang = defaultLang,\n locale,\n emoji = ['//unpkg.com/@waline/emojis@1.0.1/weibo/info.json'],\n meta = ['nick', 'mail', 'link'],\n requiredMeta = [],\n dark = false,\n pageSize = 10,\n wordLimit,\n imageUploader,\n highlighter,\n texRenderer,\n copyright = true,\n login = 'enable',\n ...more\n}: WalineProps): WalineConfig => ({\n serverURL: getServerURL(serverURL),\n path: decodePath(path),\n locale: {\n ...(locales[lang] || locales[defaultLang]),\n ...(typeof locale === 'object' ? locale : {}),\n },\n // emoji: getEmojis(emoji),\n wordLimit: getWordLimit(wordLimit),\n meta: getMeta(meta),\n requiredMeta: getMeta(requiredMeta),\n imageUploader: fallback(imageUploader, defaultUploadImage),\n highlighter: fallback(highlighter, hanabi),\n texRenderer: fallback(texRenderer, defaultTexRenderer),\n lang,\n dark,\n emoji,\n pageSize,\n login,\n copyright,\n ...more,\n});\n","const style = `{--waline-white:#000;--waline-light-grey:#666;--waline-dark-grey:#999;--waline-color:#888;--waline-bgcolor:#1e1e1e;--waline-bgcolor-light:#272727;--waline-bgcolor-hover: #444;--waline-border-color:#333;--waline-disable-bgcolor:#444;--waline-disable-color:#272727;--waline-bq-color:#272727;--waline-info-bgcolor:#272727;--waline-info-color:#666}`;\n\nexport const getDarkStyle = (selector?: string | boolean): string => {\n if (typeof selector === 'string') {\n return selector === 'auto'\n ? `@media(prefers-color-scheme:dark){body${style}}`\n : `${selector}${style}`;\n }\n\n return selector === true ? `:root${style}` : '';\n};\n","const padWithZeros = (vNumber: number, width: number): string => {\n let numAsString = vNumber.toString();\n\n while (numAsString.length < width) {\n numAsString = '0' + numAsString;\n }\n\n return numAsString;\n};\n\nexport const dateFormat = (date: Date): string => {\n const vDay = padWithZeros(date.getDate(), 2);\n const vMonth = padWithZeros(date.getMonth() + 1, 2);\n const vYear = padWithZeros(date.getFullYear(), 2);\n\n return `${vYear}-${vMonth}-${vDay}`;\n};\n","import { useStorage } from '@vueuse/core';\nimport { removeEndingSplash } from './path';\n\nimport type { WalineEmojiConfig } from './config';\nimport type { WalineEmojiInfo } from '../typings';\n\nconst hasVersion = (url: string): boolean =>\n Boolean(/@[0-9]+\\.[0-9]+\\.[0-9]+/.test(url));\n\nconst fetchEmoji = (link: string): Promise<WalineEmojiInfo> => {\n const emojiStore = useStorage<Record<string, WalineEmojiInfo>>(\n 'WALINE_EMOJI',\n {}\n );\n\n const result = hasVersion(link);\n\n if (result) {\n const info = emojiStore.value.link;\n\n if (info) return Promise.resolve(info);\n }\n\n return fetch(`${link}/info.json`)\n .then((resp) => resp.json() as Promise<Omit<WalineEmojiInfo, 'folder'>>)\n .then((emojiInfo) => {\n const info = {\n folder: link,\n ...emojiInfo,\n };\n\n if (result) emojiStore.value.link = info;\n\n return info;\n });\n};\n\nconst getLink = (name: string, folder = '', prefix = '', type = ''): string =>\n `${folder ? `${folder}/` : ''}${prefix}${name}${type ? `.${type}` : ''}`;\n\nexport const getEmojis = (\n emojis: (string | WalineEmojiInfo)[]\n): Promise<WalineEmojiConfig> =>\n Promise.all(\n emojis.map((emoji) =>\n typeof emoji === 'string'\n ? fetchEmoji(removeEndingSplash(emoji))\n : Promise.resolve(emoji)\n )\n ).then((emojiInfos) => {\n const emojiConfig: WalineEmojiConfig = {\n tabs: [],\n map: {},\n };\n\n emojiInfos.forEach((emojiInfo) => {\n const { name, folder, icon, prefix, type, items } = emojiInfo;\n\n emojiConfig.tabs.push({\n name,\n icon: getLink(icon, folder, prefix, type),\n items: items.map((item) => {\n const key = `${prefix || ''}${item}`;\n\n emojiConfig.map[key] = getLink(item, folder, prefix, type);\n\n return key;\n }),\n });\n });\n\n return emojiConfig;\n });\n","export const errorHandler = (err: Error): void => {\n if (err.name !== 'AbortError') console.error(err.message);\n};\n","import type { WalineComment, WalineCommentData } from '../typings';\n\nexport interface FetchErrorData {\n errno: number;\n errmsg: string;\n}\n\nconst errorCheck = <T = unknown>(data: T | FetchErrorData, name = ''): T => {\n if (typeof data === 'object' && (data as FetchErrorData).errno)\n throw new TypeError(\n `Fetch ${name} failed with ${(data as FetchErrorData).errno}: ${\n (data as FetchErrorData).errmsg\n }`\n );\n\n return data as T;\n};\n\nexport interface FetchCountOptions {\n serverURL: string;\n paths: string[];\n signal: AbortSignal;\n token?: string;\n}\n\nexport const fetchCommentCount = ({\n serverURL,\n paths,\n signal,\n token,\n}: FetchCountOptions): Promise<number[]> => {\n const headers: Record<string, string> = {};\n if (token) headers.Authorization = `Bearer ${token}`;\n\n return (\n fetch(\n `${serverURL}/comment?type=count&url=${encodeURIComponent(\n paths.join(',')\n )}`,\n { signal, headers }\n )\n .then((resp) => resp.json() as Promise<number | number[]>)\n .then((data) => errorCheck(data, 'comment count'))\n // TODO: Improve this API\n .then((counts) => (Array.isArray(counts) ? counts : [counts]))\n );\n};\nexport interface FetchRecentOptions {\n serverURL: string;\n count: number;\n signal: AbortSignal;\n token?: string;\n}\n\nexport const fetchRecentComment = ({\n serverURL,\n count,\n signal,\n token,\n}: FetchRecentOptions): Promise<WalineComment[]> => {\n const headers: Record<string, string> = {};\n if (token) headers.Authorization = `Bearer ${token}`;\n\n return fetch(`${serverURL}/comment?type=recent&count=${count}`, {\n signal,\n headers,\n })\n .then((resp) => resp.json() as Promise<WalineComment[]>)\n .then((data) => errorCheck(data, 'recent comment'));\n};\n\nexport interface FetchListOptions {\n serverURL: string;\n path: string;\n page: number;\n pageSize: number;\n signal: AbortSignal;\n token?: string;\n}\n\nexport interface FetchListResult {\n count: number;\n data: WalineComment[];\n totalPages: number;\n}\n\nexport const fetchCommentList = ({\n serverURL,\n path,\n page,\n pageSize,\n signal,\n token,\n}: FetchListOptions): Promise<FetchListResult> => {\n const headers: Record<string, string> = {};\n if (token) headers.Authorization = `Bearer ${token}`;\n\n return fetch(\n `${serverURL}/comment?path=${encodeURIComponent(\n path\n )}&pageSize=${pageSize}&page=${page}`,\n { signal, headers }\n )\n .then((resp) => resp.json() as Promise<FetchListResult>)\n .then((data) => errorCheck(data, 'comment list'));\n};\n\nexport interface PostCommentOptions {\n serverURL: string;\n lang: string;\n token?: string;\n comment: WalineCommentData;\n}\n\nexport interface PostCommentResponse {\n data?: WalineComment;\n errmsg?: string;\n}\n\nexport const postComment = ({\n serverURL,\n lang,\n token,\n comment,\n}: PostCommentOptions): Promise<PostCommentResponse> => {\n const headers: Record<string, string> = {\n // eslint-disable-next-line @typescript-eslint/naming-convention\n 'Content-Type': 'application/json',\n };\n\n if (token) headers.Authorization = `Bearer ${token}`;\n\n return fetch(`${serverURL}/comment?lang=${lang}`, {\n method: 'POST',\n headers,\n body: JSON.stringify(comment),\n }).then((resp) => resp.json() as Promise<PostCommentResponse>);\n};\n\nexport interface FetchPageviewsOptions {\n serverURL: string;\n paths: string[];\n signal: AbortSignal;\n}\n\nexport const fetchPageviews = ({\n serverURL,\n paths,\n signal,\n}: FetchPageviewsOptions): Promise<number[]> =>\n fetch(`${serverURL}/article?path=${encodeURIComponent(paths.join(','))}`, {\n signal,\n })\n .then((resp) => resp.json() as Promise<number[] | number>)\n .then((data) => errorCheck(data, 'visit count'))\n // TODO: Improve this API\n .then((counts) => (Array.isArray(counts) ? counts : [counts]));\n\nexport interface UpdatePageviewsOptions {\n serverURL: string;\n path: string;\n}\n\nexport const updatePageviews = ({\n serverURL,\n path,\n}: UpdatePageviewsOptions): Promise<number> =>\n fetch(`${serverURL}/article`, {\n method: 'POST',\n headers: {\n // eslint-disable-next-line @typescript-eslint/naming-convention\n 'Content-Type': 'application/json',\n },\n body: JSON.stringify({ path }),\n })\n .then((resp) => resp.json() as Promise<number>)\n .then((data) => errorCheck(data, 'visit count'));\n","export const getRoot = (\n el: string | HTMLElement | undefined\n): HTMLElement | null =>\n el instanceof HTMLElement\n ? el\n : typeof el === 'string'\n ? document.querySelector(el)\n : null;\n","const isImage = (item: DataTransferItem): boolean =>\n item.type.includes('image');\n\nexport const getImagefromDataTransfer = (\n items: DataTransferItemList\n): File | null => {\n const image = Array.from(items).find(isImage);\n\n return image ? (image.getAsFile() as File) : null;\n};\n","import type { marked } from 'marked';\nimport type { WalineTexRenderer } from '../typings';\n\nconst inlineMathStart = /\\$.*?\\$/;\nconst inlineMathReg = /^\\$(.*?)\\$/;\nconst blockMathReg = /^(?:\\s{0,3})\\$\\$((?:[^\\n]|\\n[^\\n])+?)\\n{0,1}\\$\\$/;\n\nexport const markedTexExtensions = (\n texRenderer: WalineTexRenderer\n): marked.TokenizerExtension[] => {\n const blockMathExtension: marked.TokenizerExtension = {\n name: 'blockMath',\n level: 'block',\n tokenizer(src: string) {\n const cap = blockMathReg.exec(src);\n\n if (cap !== null) {\n return {\n type: 'html',\n raw: cap[0],\n text: texRenderer(true, cap[1]),\n };\n }\n\n return undefined;\n },\n };\n\n const inlineMathExtension: marked.TokenizerExtension = {\n name: 'inlineMath',\n level: 'inline',\n start(src: string) {\n const idx = src.search(inlineMathStart);\n return idx !== -1 ? idx : src.length;\n },\n tokenizer(src: string) {\n const cap = inlineMathReg.exec(src);\n\n if (cap !== null) {\n return {\n type: 'html',\n raw: cap[0],\n text: texRenderer(false, cap[1]),\n };\n }\n\n return undefined;\n },\n };\n\n return [blockMathExtension, inlineMathExtension];\n};\n","import { marked } from 'marked';\nimport { markedTexExtensions } from './markedMathExtension';\n\nimport type {\n WalineEmojiMaps,\n WalineHighlighter,\n WalineTexRenderer,\n} from '../typings';\n\nexport const parseEmoji = (text = '', emojiMap: WalineEmojiMaps = {}): string =>\n text.replace(/:(.+?):/g, (placeholder, key: string) =>\n emojiMap[key]\n ? `<img class=\"wl-emoji\" src=\"${emojiMap[key]}\" alt=\"${key}\">`\n : placeholder\n );\n\nexport interface ParseMarkdownOptions {\n emojiMap: WalineEmojiMaps;\n highlighter: WalineHighlighter | false;\n texRenderer: WalineTexRenderer | false;\n}\n\nexport const parseMarkdown = (\n content: string,\n { emojiMap, highlighter, texRenderer }: ParseMarkdownOptions\n): string => {\n marked.setOptions({\n highlight: highlighter || undefined,\n breaks: true,\n smartLists: true,\n smartypants: true,\n });\n\n if (texRenderer) {\n const extensions = markedTexExtensions(texRenderer);\n\n marked.use({ extensions });\n }\n\n return marked.parse(parseEmoji(content, emojiMap));\n};\n","export const getQuery = (element: HTMLElement): string | null =>\n element.dataset.path || element.getAttribute('id');\n","import { useNow } from '@vueuse/core';\nimport { computed } from 'vue';\nimport { dateFormat } from '../utils';\n\nimport type { ComputedRef } from 'vue';\nimport type { WalineLocale } from '../typings';\n\nexport const useTimeAgo = (\n date: Date | string,\n locale: WalineLocale\n): ComputedRef<string> => {\n const now = useNow();\n\n return computed(() => {\n if (!date) return '';\n\n const time =\n typeof date === 'string'\n ? new Date(date.indexOf(' ') !== -1 ? date.replace(/-/g, '/') : date)\n : date;\n\n const timepassed = now.value.getTime() - time.getTime();\n\n const days = Math.floor(timepassed / (24 * 3600 * 1000));\n\n if (days === 0) {\n // 计算相差小时数\n\n // 计算天数后剩余的毫秒数\n const leave1 = timepassed % (24 * 3600 * 1000);\n const hours = Math.floor(leave1 / (3600 * 1000));\n\n if (hours === 0) {\n //计算相差分钟数\n\n // 计算小时数后剩余的毫秒数\n const leave2 = leave1 % (3600 * 1000);\n const minutes = Math.floor(leave2 / (60 * 1000));\n\n // 计算相差秒数\n if (minutes === 0) {\n // 计算分钟数后剩余的毫秒数\n const leave3 = leave2 % (60 * 1000);\n const seconds = Math.round(leave3 / 1000);\n\n return `${seconds} ${locale.seconds}`;\n }\n\n return `${minutes} ${locale.minutes}`;\n }\n\n return `${hours} ${locale.hours}`;\n }\n\n if (days < 0) return locale.now;\n\n if (days < 8) return `${days} ${locale.days}`;\n\n return dateFormat(time);\n });\n};\n","import { useStorage } from '@vueuse/core';\n\nimport type { Ref } from 'vue';\n\nexport interface UserInfo {\n // eslint-disable-next-line @typescript-eslint/naming-convention\n display_name: string;\n email: string;\n url: string;\n token: string;\n avatar: string;\n mailMd5: string;\n}\n\nexport const USER_KEY = 'WALINE_USER';\n\nexport type UserInfoRef = Ref<UserInfo | Record<string, never>>;\n\nexport const useUserInfo = (): UserInfoRef =>\n useStorage<UserInfo | Record<string, never>>('USER_KEY', {});\n","import { useUserInfo } from './composables';\nimport { decodePath, errorHandler, fetchCommentCount } from './utils';\nimport type { WalineAbort } from './typings';\n\nexport interface WalineCommentCountOptions {\n /**\n * Waline 服务端地址\n *\n * Waline server url\n */\n serverURL: string;\n\n /**\n * 评论数 CSS 选择器\n *\n * Commment count CSS selector\n *\n * @default '.waline-comment-count'\n */\n selector?: string;\n\n /**\n * 需要获取的默认路径\n *\n * Path to be fetched by default\n *\n * @default window.location.pathname\n */\n path?: string;\n}\n\nexport const commentCount = ({\n serverURL,\n path = window.location.pathname,\n selector = '.waline-comment-count',\n}: // eslint-disable-next-line @typescript-eslint/no-explicit-any\nWalineCommentCountOptions): WalineAbort => {\n const controller = new AbortController();\n\n // comment count\n const elements = document.querySelectorAll<HTMLElement>(selector);\n\n const userInfo = useUserInfo();\n\n if (elements.length)\n void fetchCommentCount({\n serverURL,\n paths: Array.from(elements).map((element) =>\n decodePath(element.dataset.path || element.getAttribute('id') || path)\n ),\n signal: controller.signal,\n token: userInfo.value?.token,\n })\n .then((counts) => {\n elements.forEach((element, index) => {\n element.innerText = counts[index].toString();\n });\n })\n .catch(errorHandler);\n\n return controller.abort.bind(controller);\n};\n","import { h } from 'vue';\nimport type { FunctionalComponent } from 'vue';\n\nexport const CloseIcon: FunctionalComponent<{ size: number }> = ({ size }) =>\n h(\n 'svg',\n {\n class: 'wl-close-icon',\n viewBox: '0 0 1024 1024',\n width: size,\n height: size,\n },\n [\n h('path', {\n d: 'M697.173 85.333h-369.92c-144.64 0-241.92 101.547-241.92 252.587v348.587c0 150.613 97.28 252.16 241.92 252.16h369.92c144.64 0 241.494-101.547 241.494-252.16V337.92c0-151.04-96.854-252.587-241.494-252.587z',\n fill: 'currentColor',\n }),\n h('path', {\n d: 'm640.683 587.52-75.947-75.861 75.904-75.862a37.29 37.29 0 0 0 0-52.778 37.205 37.205 0 0 0-52.779 0l-75.946 75.818-75.862-75.946a37.419 37.419 0 0 0-52.821 0 37.419 37.419 0 0 0 0 52.821l75.947 75.947-75.776 75.733a37.29 37.29 0 1 0 52.778 52.821l75.776-75.776 75.947 75.947a37.376 37.376 0 0 0 52.779-52.821z',\n fill: '#888',\n }),\n ]\n );\n\nexport const EmojiIcon: FunctionalComponent = () =>\n h(\n 'svg',\n { viewBox: '0 0 1024 1024', width: '24', height: '24' },\n h('path', {\n d: 'M563.2 463.3 677 540c1.7 1.2 3.7 1.8 5.8 1.8.7 0 1.4-.1 2-.2 2.7-.5 5.1-2.1 6.6-4.4l25.3-37.8c1.5-2.3 2.1-5.1 1.6-7.8s-2.1-5.1-4.4-6.6l-73.6-49.1 73.6-49.1c2.3-1.5 3.9-3.9 4.4-6.6.5-2.7 0-5.5-1.6-7.8l-25.3-37.8a10.1 10.1 0 0 0-6.6-4.4c-.7-.1-1.3-.2-2-.2-2.1 0-4.1.6-5.8 1.8l-113.8 76.6c-9.2 6.2-14.7 16.4-14.7 27.5.1 11 5.5 21.3 14.7 27.4zM387 348.8h-45.5c-5.7 0-10.4 4.7-10.4 10.4v153.3c0 5.7 4.7 10.4 10.4 10.4H387c5.7 0 10.4-4.7 10.4-10.4V359.2c0-5.7-4.7-10.4-10.4-10.4zm333.8 241.3-41-20a10.3 10.3 0 0 0-8.1-.5c-2.6.9-4.8 2.9-5.9 5.4-30.1 64.9-93.1 109.1-164.4 115.2-5.7.5-9.9 5.5-9.5 11.2l3.9 45.5c.5 5.3 5 9.5 10.3 9.5h.9c94.8-8 178.5-66.5 218.6-152.7 2.4-5 .3-11.2-4.8-13.6zm186-186.1c-11.9-42-30.5-81.4-55.2-117.1-24.1-34.9-53.5-65.6-87.5-91.2-33.9-25.6-71.5-45.5-111.6-59.2-41.2-14-84.1-21.1-127.8-21.1h-1.2c-75.4 0-148.8 21.4-212.5 61.7-63.7 40.3-114.3 97.6-146.5 165.8-32.2 68.1-44.3 143.6-35.1 218.4 9.3 74.8 39.4 145 87.3 203.3.1.2.3.3.4.5l36.2 38.4c1.1 1.2 2.5 2.1 3.9 2.6 73.3 66.7 168.2 103.5 267.5 103.5 73.3 0 145.2-20.3 207.7-58.7 37.3-22.9 70.3-51.5 98.1-85 27.1-32.7 48.7-69.5 64.2-109.1 15.5-39.7 24.4-81.3 26.6-123.8 2.4-43.6-2.5-87-14.5-129zm-60.5 181.1c-8.3 37-22.8 72-43 104-19.7 31.1-44.3 58.6-73.1 81.7-28.8 23.1-61 41-95.7 53.4-35.6 12.7-72.9 19.1-110.9 19.1-82.6 0-161.7-30.6-222.8-86.2l-34.1-35.8c-23.9-29.3-42.4-62.2-55.1-97.7-12.4-34.7-18.8-71-19.2-107.9-.4-36.9 5.4-73.3 17.1-108.2 12-35.8 30-69.2 53.4-99.1 31.7-40.4 71.1-72 117.2-94.1 44.5-21.3 94-32.6 143.4-32.6 49.3 0 97 10.8 141.8 32 34.3 16.3 65.3 38.1 92 64.8 26.1 26 47.5 56 63.6 89.2 16.2 33.2 26.6 68.5 31 105.1 4.6 37.5 2.7 75.3-5.6 112.3z',\n fill: 'currentColor',\n })\n );\n\nexport const ImageIcon: FunctionalComponent = () =>\n h('svg', { viewBox: '0 0 1024 1024', width: '24', height: '24' }, [\n h('path', {\n d: 'M784 112H240c-88 0-160 72-160 160v480c0 88 72 160 160 160h544c88 0 160-72 160-160V272c0-88-72-160-160-160zm96 640c0 52.8-43.2 96-96 96H240c-52.8 0-96-43.2-96-96V272c0-52.8 43.2-96 96-96h544c52.8 0 96 43.2 96 96v480z',\n fill: 'currentColor',\n }),\n h('path', {\n d: 'M352 480c52.8 0 96-43.2 96-96s-43.2-96-96-96-96 43.2-96 96 43.2 96 96 96zm0-128c17.6 0 32 14.4 32 32s-14.4 32-32 32-32-14.4-32-32 14.4-32 32-32zm462.4 379.2-3.2-3.2-177.6-177.6c-25.6-25.6-65.6-25.6-91.2 0l-80 80-36.8-36.8c-25.6-25.6-65.6-25.6-91.2 0L200 728c-4.8 6.4-8 14.4-8 24 0 17.6 14.4 32 32 32 9.6 0 16-3.2 22.4-9.6L380.8 640l134.4 134.4c6.4 6.4 14.4 9.6 24 9.6 17.6 0 32-14.4 32-32 0-9.6-4.8-17.6-9.6-24l-52.8-52.8 80-80L769.6 776c6.4 4.8 12.8 8 20.8 8 17.6 0 32-14.4 32-32 0-8-3.2-16-8-20.8z',\n fill: 'currentColor',\n }),\n ]);\n\nexport const PreviewIcon: FunctionalComponent = () =>\n h('svg', { viewBox: '0 0 1024 1024', width: '24', height: '24' }, [\n h('path', {\n d: 'M710.816 654.301c70.323-96.639 61.084-230.578-23.705-314.843-46.098-46.098-107.183-71.109-172.28-71.109-65.008 0-126.092 25.444-172.28 71.109-45.227 46.098-70.756 107.183-70.756 172.106 0 64.923 25.444 126.007 71.194 172.106 46.099 46.098 107.184 71.109 172.28 71.109 51.414 0 100.648-16.212 142.824-47.404l126.53 126.006c7.058 7.06 16.297 10.979 26.406 10.979 10.105 0 19.343-3.919 26.402-10.979 14.467-14.467 14.467-38.172 0-52.723L710.816 654.301zm-315.107-23.265c-65.88-65.88-65.88-172.54 0-238.42 32.069-32.07 74.245-49.149 119.471-49.149 45.227 0 87.407 17.603 119.472 49.149 65.88 65.879 65.88 172.539 0 238.42-63.612 63.178-175.242 63.178-238.943 0zm0 0',\n fill: 'currentColor',\n }),\n h('path', {\n d: 'M703.319 121.603H321.03c-109.8 0-199.469 89.146-199.469 199.38v382.034c0 109.796 89.236 199.38 199.469 199.38h207.397c20.653 0 37.384-16.645 37.384-37.299 0-20.649-16.731-37.296-37.384-37.296H321.03c-68.582 0-124.352-55.77-124.352-124.267V321.421c0-68.496 55.77-124.267 124.352-124.267h382.289c68.582 0 124.352 55.771 124.352 124.267V524.72c0 20.654 16.736 37.299 37.385 37.299 20.654 0 37.384-16.645 37.384-37.299V320.549c-.085-109.8-89.321-198.946-199.121-198.946zm0 0',\n fill: 'currentColor',\n }),\n ]);\n\nexport const MarkdownIcon: FunctionalComponent = () =>\n h(\n 'svg',\n { width: '16', height: '16', ariaHidden: 'true' },\n h('path', {\n d: 'M14.85 3H1.15C.52 3 0 3.52 0 4.15v7.69C0 12.48.52 13 1.15 13h13.69c.64 0 1.15-.52 1.15-1.15v-7.7C16 3.52 15.48 3 14.85 3zM9 11H7V8L5.5 9.92 4 8v3H2V5h2l1.5 2L7 5h2v6zm2.99.5L9.5 8H11V5h2v3h1.5l-2.51 3.5z',\n fill: 'currentColor',\n })\n );\n\nexport const ReplyIcon: FunctionalComponent = () =>\n h(\n 'svg',\n { viewBox: '0 0 1024 1024', width: '18', height: '18' },\n h('path', {\n d: 'M1019.2 720C1001.6 625.6 968 566.4 904 497.6c-89.6-89.6-214.4-150.4-347.2-176v-120c0-25.6-8-51.2-25.6-64-33.6-30.4-81.6-30.4-112-4.8L33.6 441.6C12.8 459.2 0 484.8 0 510.4c0 25.6 12.8 51.2 30.4 68.8l385.6 312c17.6 12.8 33.6 17.6 51.2 17.6 12.8 0 25.6-4.8 38.4-8C536 888 552 857.6 552 824v-99.2c124.8 20.8 248 86.4 339.2 140.8 25.6 17.6 59.2 17.6 89.6 0 25.6-17.6 43.2-46.4 43.2-76.8 0-33.6 0-56-4.8-68.8zm-500.8-89.6-46.4-4.8v193.6L86.4 510.4 472 201.6V400l38.4 4.8c128 12.8 248 68.8 334.4 153.6 51.2 56 76.8 102.4 94.4 179.2 0 4.8 4.8 20.8 4.8 51.2C835.2 720 672 640 518.4 630.4z',\n fill: 'currentColor',\n })\n );\n\nexport const VerifiedIcon: FunctionalComponent = () =>\n h(\n 'svg',\n {\n class: 'verified-icon',\n viewBox: '0 0 1024 1024',\n width: '14',\n height: '14',\n },\n h('path', {\n d: 'm894.4 461.56-54.4-63.2c-10.4-12-18.8-34.4-18.8-50.4v-68c0-42.4-34.8-77.2-77.2-77.2h-68c-15.6 0-38.4-8.4-50.4-18.8l-63.2-54.4c-27.6-23.6-72.8-23.6-100.8 0l-62.8 54.8c-12 10-34.8 18.4-50.4 18.4h-69.2c-42.4 0-77.2 34.8-77.2 77.2v68.4c0 15.6-8.4 38-18.4 50l-54 63.6c-23.2 27.6-23.2 72.4 0 100l54 63.6c10 12 18.4 34.4 18.4 50v68.4c0 42.4 34.8 77.2 77.2 77.2h69.2c15.6 0 38.4 8.4 50.4 18.8l63.2 54.4c27.6 23.6 72.8 23.6 100.8 0l63.2-54.4c12-10.4 34.4-18.8 50.4-18.8h68c42.4 0 77.2-34.8 77.2-77.2v-68c0-15.6 8.4-38.4 18.8-50.4l54.4-63.2c23.2-27.6 23.2-73.2-.4-100.8zm-216-25.2-193.2 193.2a30 30 0 0 1-42.4 0l-96.8-96.8a30.16 30.16 0 0 1 0-42.4c11.6-11.6 30.8-11.6 42.4 0l75.6 75.6 172-172c11.6-11.6 30.8-11.6 42.4 0 11.6 11.6 11.6 30.8 0 42.4z',\n fill: '#27ae60',\n })\n );\n\nexport const LoadingIcon: FunctionalComponent<{ size: number }> = ({ size }) =>\n h(\n 'svg',\n {\n width: size,\n height: size,\n viewBox: '0 0 100 100',\n preserveAspectRatio: 'xMidYMid',\n },\n h(\n 'circle',\n {\n cx: 50,\n cy: 50,\n fill: 'none',\n stroke: 'currentColor',\n strokeWidth: '4',\n r: '40',\n // eslint-disable-next-line @typescript-eslint/naming-convention\n 'stroke-dasharray': '85 30',\n },\n h('animateTransform', {\n attributeName: 'transform',\n type: 'rotate',\n repeatCount: 'indefinite',\n dur: '1s',\n values: '0 50 50;360 50 50',\n keyTimes: '0;1',\n })\n )\n );\n","<template>\n <div class=\"wl-comment\">\n <div v-if=\"config.login !== 'disable' && isLogin\" class=\"wl-login-info\">\n <div class=\"wl-avatar\">\n <button class=\"wl-logout-btn\" :title=\"locale.logout\" @click=\"onLogout\">\n <CloseIcon :size=\"14\" />\n </button>\n\n <img :src=\"userInfo.avatar\" alt=\"avatar\" />\n </div>\n <a\n href=\"#\"\n class=\"wl-login-nick\"\n aria-label=\"Profile\"\n @click=\"onProfile\"\n v-text=\"userInfo.display_name\"\n />\n </div>\n\n <div class=\"wl-panel\">\n <div\n v-if=\"config.login !== 'force' && config.meta.length && !isLogin\"\n :class=\"['wl-header', `item${config.meta.length}`]\"\n >\n <div v-for=\"kind in config.meta\" class=\"wl-header-item\" :key=\"kind\">\n <label\n :for=\"kind\"\n v-text=\"\n locale[kind] +\n (config.requiredMeta.includes(kind) || !config.requiredMeta.length\n ? ''\n : `(${locale.optional})`)\n \"\n />\n <input\n :ref=\"\n (element) => {\n if (element) inputRefs[kind] = element;\n }\n \"\n :id=\"`wl-${kind}`\"\n :class=\"['wl-input', `wl-${kind}`]\"\n :name=\"kind\"\n :type=\"kind === 'mail' ? 'email' : 'text'\"\n v-model=\"userMeta[kind]\"\n />\n </div>\n </div>\n\n <textarea\n class=\"wl-editor\"\n ref=\"editorRef\"\n id=\"wl-edit\"\n :placeholder=\"replyUser ? `@${replyUser}` : locale.placeholder\"\n v-model=\"editor\"\n @keydown=\"onKeyDown\"\n @drop=\"onDrop\"\n @paste=\"onPaste\"\n />\n\n <div class=\"wl-preview\" v-show=\"showPreview\">\n <hr />\n <h4>{{ locale.preview }}:</h4>\n <div class=\"wl-content\" v-html=\"previewText\" />\n </div>\n\n <div class=\"wl-footer\">\n <div class=\"wl-actions\">\n <a\n href=\"https://guides.github.com/features/mastering-markdown/\"\n title=\"Markdown Guide\"\n aria-label=\"Markdown is supported\"\n class=\"wl-action\"\n target=\"_blank\"\n rel=\"noreferrer\"\n >\n <MarkdownIcon />\n </a>\n\n <button\n ref=\"emojiButtonRef\"\n class=\"wl-action\"\n :class=\"{ actived: showEmoji }\"\n :title=\"locale.emoji\"\n @click=\"showEmoji = !showEmoji\"\n >\n <EmojiIcon />\n </button>\n\n <input\n ref=\"imageUploadRef\"\n class=\"upload\"\n id=\"wl-image-upload\"\n type=\"file\"\n accept=\".png,.jpg,.jpeg,.webp,.bmp,.gif\"\n @change=\"onChange\"\n />\n\n <label\n v-if=\"canUploadImage\"\n for=\"wl-image-upload\"\n class=\"wl-action\"\n :title=\"locale.uploadImage\"\n >\n <ImageIcon />\n </label>\n\n <button\n class=\"wl-action\"\n :class=\"{ actived: showPreview }\"\n :title=\"locale.preview\"\n @click=\"showPreview = !showPreview\"\n >\n <PreviewIcon />\n </button>\n </div>\n\n <div class=\"wl-info\">\n <div class=\"wl-text-number\">\n {{ wordNumber }}\n\n <span v-if=\"config.wordLimit\">\n / \n <span\n :class=\"{ illegal: !isWordNumberLegal }\"\n v-text=\"wordLimit\"\n />\n </span>\n\n {{ locale.word }}\n </div>\n\n <button\n v-if=\"config.login !== 'disable' && !isLogin\"\n class=\"wl-btn\"\n @click=\"onLogin\"\n v-text=\"locale.login\"\n />\n\n <button\n v-if=\"config.login !== 'force' || isLogin\"\n class=\"wl-btn primary\"\n title=\"Cmd|Ctrl + Enter\"\n :disabled=\"isSubmitting\"\n @click=\"submitComment\"\n >\n <LoadingIcon v-if=\"isSubmitting\" :size=\"16\" />\n <template v-else>\n {{ locale.submit }}\n </template>\n </button>\n </div>\n\n <div\n ref=\"emojiPopupRef\"\n class=\"wl-emoji-popup\"\n :class=\"{ display: showEmoji }\"\n >\n <template v-for=\"(config, index) in emoji.tabs\" :key=\"config.name\">\n <div v-if=\"index === emojiTabIndex\" class=\"wl-tab-wrapper\">\n <button\n v-for=\"key in config.items\"\n :key=\"key\"\n :title=\"key\"\n @click=\"insert(`:${key}:`)\"\n >\n <img\n v-if=\"showEmoji\"\n class=\"wl-emoji\"\n :src=\"emoji.map[key]\"\n :alt=\"key\"\n loading=\"lazy\"\n referrerPolicy=\"no-referrer\"\n />\n </button>\n </div>\n </template>\n <div v-if=\"emoji.tabs.length > 1\" class=\"wl-tabs\">\n <button\n v-for=\"(config, index) in emoji.tabs\"\n :key=\"config.name\"\n class=\"wl-tab\"\n :class=\"{ active: emojiTabIndex === index }\"\n @click=\"emojiTabIndex = index\"\n >\n <img\n class=\"wl-emoji\"\n :src=\"config.icon\"\n :alt=\"config.name\"\n :title=\"config.name\"\n loading=\"lazy\"\n referrerPolicy=\"no-referrer\"\n />\n </button>\n </div>\n </div>\n </div>\n </div>\n\n <button\n v-if=\"replyId\"\n class=\"wl-close\"\n :title=\"locale.cancelReply\"\n @click=\"$emit('cancel-reply')\"\n >\n <CloseIcon :size=\"24\" />\n </button>\n </div>\n</template>\n\n<script lang=\"ts\">\nimport autosize from 'autosize';\nimport {\n computed,\n defineComponent,\n inject,\n onMounted,\n onUnmounted,\n ref,\n watch,\n} from 'vue';\n\nimport {\n CloseIcon,\n EmojiIcon,\n ImageIcon,\n MarkdownIcon,\n PreviewIcon,\n LoadingIcon,\n} from './Icons';\nimport { useEditor, useUserMeta, useUserInfo } from '../composables';\nimport {\n getImagefromDataTransfer,\n parseMarkdown,\n getWordNumber,\n parseEmoji,\n postComment,\n getEmojis,\n} from '../utils';\n\nimport type { ComputedRef, DeepReadonly } from 'vue';\nimport type { WalineCommentData, WalineImageUploader } from '../typings';\nimport type { WalineConfig, WalineEmojiConfig } from '../utils';\n\nexport default defineComponent({\n name: 'CommentBox',\n\n components: {\n CloseIcon,\n EmojiIcon,\n ImageIcon,\n MarkdownIcon,\n PreviewIcon,\n LoadingIcon,\n },\n\n props: {\n rootId: {\n type: String,\n default: '',\n },\n replyId: {\n type: String,\n default: '',\n },\n replyUser: {\n type: String,\n default: '',\n },\n },\n\n emits: ['submit', 'cancel-reply'],\n\n setup(props, { emit }) {\n const config = inject<ComputedRef<WalineConfig>>(\n 'config'\n ) as ComputedRef<WalineConfig>;\n\n const editor = useEditor();\n const userMeta = useUserMeta();\n const userInfo = useUserInfo();\n\n const inputRefs = ref<Record<string, HTMLInputElement>>({});\n const editorRef = ref<HTMLTextAreaElement | null>(null);\n const imageUploadRef = ref<HTMLInputElement | null>(null);\n const emojiButtonRef = ref<HTMLDivElement | null>(null);\n const emojiPopupRef = ref<HTMLDivElement | null>(null);\n\n const emoji = ref<DeepReadonly<WalineEmojiConfig>>({ tabs: [], map: {} });\n const emojiTabIndex = ref(0);\n const showEmoji = ref(false);\n const showPreview = ref(false);\n const previewText = ref('');\n const wordNumber = ref(0);\n\n const wordLimit = ref(0);\n const isWordNumberLegal = ref(false);\n\n const content = ref('');\n\n const isSubmitting = ref(false);\n\n const locale = computed(() => config.value.locale);\n\n const isLogin = computed(() => Boolean(userInfo.value?.token));\n\n const canUploadImage = computed(() => config.value.imageUploader !== false);\n\n const insert = (content: string): void => {\n const textArea = editorRef.value as HTMLTextAreaElement;\n const startPosition = textArea.selectionStart;\n const endPosition = textArea.selectionEnd || 0;\n const scrollTop = textArea.scrollTop;\n\n editor.value =\n textArea.value.substring(0, startPosition) +\n content +\n textArea.value.substring(endPosition, textArea.value.length);\n textArea.focus();\n textArea.selectionStart = startPosition + content.length;\n textArea.selectionEnd = startPosition + content.length;\n textArea.scrollTop = scrollTop;\n };\n\n const onKeyDown = (event: KeyboardEvent): void => {\n const key = event.key;\n\n // Shortcut key\n if ((event.ctrlKey || event.metaKey) && key === 'Enter') submitComment();\n };\n\n const uploadImage = (file: File): Promise<void> => {\n const uploadText = `![${config.value.locale.uploading} ${file.name}]()`;\n\n insert(uploadText);\n\n return Promise.resolve()\n .then(() => (config.value.imageUploader as WalineImageUploader)(file))\n .then((url) => {\n editor.value = editor.value.replace(\n uploadText,\n `\\r\\n`\n );\n });\n };\n\n const onDrop = (event: DragEvent): void => {\n if (event.dataTransfer?.items) {\n const file = getImagefromDataTransfer(event.dataTransfer.items);\n\n if (file && canUploadImage.value) {\n uploadImage(file);\n event.preventDefault();\n }\n }\n };\n\n const onPaste = (event: ClipboardEvent): void => {\n if (event.clipboardData) {\n const file = getImagefromDataTransfer(event.clipboardData.items);\n\n if (file && canUploadImage.value) uploadImage(file);\n }\n };\n\n const onChange = (): void => {\n const inputElement = imageUploadRef.value as HTMLInputElement;\n\n if (inputElement.files && canUploadImage.value)\n uploadImage(inputElement.files[0]).then(() => {\n // clear input so a same image can be uploaded later\n inputElement.value = '';\n });\n };\n\n const submitComment = (): void => {\n const { serverURL, lang, login, wordLimit, requiredMeta } = config.value;\n\n const comment: WalineCommentData = {\n comment: content.value,\n nick: userMeta.value.nick,\n mail: userMeta.value.mail,\n link: userMeta.value.link,\n ua: navigator.userAgent,\n url: config.value.path,\n };\n\n if (userInfo.value?.token) {\n // login user\n\n comment.nick = userInfo.value.display_name;\n comment.mail = userInfo.value.email;\n comment.link = userInfo.value.url;\n } else {\n if (login === 'force') return;\n\n // check nick\n if (\n (requiredMeta.indexOf('nick') > -1 || comment.nick) &&\n !comment.nick\n ) {\n inputRefs.value.nick?.focus();\n return alert(locale.value.nickError);\n }\n\n // check mail\n if (requiredMeta.indexOf('mail') > -1 && !comment.mail) {\n inputRefs.value.mail?.focus();\n return alert(locale.value.mailError);\n }\n\n // check comment\n if (!comment.comment) {\n editorRef.value?.focus();\n return;\n }\n\n if (!comment.nick) comment.nick = locale.value.anonymous;\n }\n\n if (!isWordNumberLegal.value)\n return alert(\n locale.value.wordHint\n .replace('$0', (wordLimit as [number, number])[0].toString())\n .replace('$1', (wordLimit as [number, number])[1].toString())\n .replace('$2', wordNumber.value.toString())\n );\n\n comment.comment = parseEmoji(comment.comment, emoji.value.map);\n\n if (props.replyId && props.rootId) {\n comment.pid = props.replyId;\n comment.rid = props.rootId;\n comment.at = props.replyUser;\n }\n\n isSubmitting.value = true;\n\n postComment({\n serverURL,\n lang,\n token: userInfo.value?.token,\n comment,\n })\n .then((resp) => {\n isSubmitting.value = false;\n\n if (resp.errmsg) return alert(resp.errmsg);\n\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n emit('submit', resp.data!);\n\n editor.value = '';\n\n previewText.value = '';\n\n if (props.replyId) emit('cancel-reply');\n })\n .catch((err: TypeError) => {\n isSubmitting.value = false;\n\n alert(err.message);\n });\n };\n\n const onLogin = (event: Event): void => {\n event.preventDefault();\n const { lang, serverURL } = config.value;\n\n const width = 450;\n const height = 450;\n const left = (window.innerWidth - width) / 2;\n const top = (window.innerHeight - height) / 2;\n\n const handler = window.open(\n `${serverURL}/ui/login?lng=${encodeURIComponent(lang)}`,\n '_blank',\n `width=${width},height=${height},left=${left},top=${top},scrollbars=no,resizable=no,status=no,location=no,toolbar=no,menubar=no`\n );\n\n handler?.postMessage({ type: 'TOKEN', data: null }, '*');\n\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const receiver = ({ data }: any): void => {\n if (!data || data.type !== 'userInfo') return;\n\n if (data.data.token) {\n handler?.close();\n userInfo.value = data.data;\n (data.data.remember ? localStorage : sessionStorage).setItem(\n 'WALINE_USER',\n JSON.stringify(data.data)\n );\n\n window.removeEventListener('message', receiver);\n }\n };\n\n window.addEventListener('message', receiver);\n };\n\n const onLogout = (): void => {\n userInfo.value = {};\n localStorage.setItem('WALINE_USER', 'null');\n sessionStorage.setItem('WALINE_USER', 'null');\n };\n\n const onProfile = (event: Event): void => {\n event.preventDefault();\n\n const { lang, serverURL } = config.value;\n\n const width = 800;\n const height = 800;\n const left = (window.innerWidth - width) / 2;\n const top = (window.innerHeight - height) / 2;\n const handler = window.open(\n `${serverURL}/ui/profile?lng=${encodeURIComponent(lang)}`,\n '_blank',\n `width=${width},height=${height},left=${left},top=${top},scrollbars=no,resizable=no,status=no,location=no,toolbar=no,menubar=no`\n );\n\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n handler?.postMessage({ type: 'TOKEN', data: userInfo.value!.token }, '*');\n\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const receiver = ({ data }: any): void => {\n if (!data || data.type !== 'profile') return;\n\n userInfo.value = { ...userInfo.value, ...data };\n\n [localStorage, sessionStorage]\n .filter((store) => store.getItem('WALINE_USER'))\n .forEach((store) =>\n store.setItem('WALINE_USER', JSON.stringify(userInfo))\n );\n window.removeEventListener('message', receiver);\n };\n\n window.addEventListener('message', receiver);\n };\n\n const popupHandler = (event: MouseEvent): void => {\n if (\n !(emojiButtonRef.value as HTMLElement).contains(event.target as Node) &&\n !(emojiPopupRef.value as HTMLElement).contains(event.target as Node)\n )\n showEmoji.value = false;\n };\n\n // update wordNumber\n watch(\n [config, wordNumber],\n ([config, wordNumber]) => {\n const { wordLimit: limit } = config;\n\n if (limit) {\n if (wordNumber < limit[0] && limit[0] !== 0) {\n wordLimit.value = limit[0];\n isWordNumberLegal.value = false;\n } else if (wordNumber > limit[1]) {\n wordLimit.value = limit[1];\n isWordNumberLegal.value = false;\n } else {\n wordLimit.value = limit[1];\n isWordNumberLegal.value = true;\n }\n } else {\n wordLimit.value = 0;\n isWordNumberLegal.value = true;\n }\n },\n { immediate: true }\n );\n\n onMounted(() => {\n document.body.addEventListener('click', popupHandler);\n\n // watch editor\n watch(\n () => editor.value,\n (value) => {\n const { highlighter, texRenderer } = config.value;\n\n content.value = value;\n previewText.value = parseMarkdown(value, {\n emojiMap: emoji.value.map,\n highlighter,\n texRenderer,\n });\n wordNumber.value = getWordNumber(value);\n\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n if (value) autosize(editorRef.value!);\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n else autosize.destroy(editorRef.value!);\n },\n { immediate: true }\n );\n\n // watch emoji value change\n watch(\n () => config.value.emoji,\n (emojiConfig) =>\n getEmojis(emojiConfig).then((config) => {\n emoji.value = config;\n }),\n { immediate: true }\n );\n });\n\n onUnmounted(() => {\n document.body.removeEventListener('click', popupHandler);\n });\n\n return {\n // config\n config,\n locale,\n\n // events\n insert,\n onChange,\n onDrop,\n onKeyDown,\n onPaste,\n onLogin,\n onLogout,\n onProfile,\n submitComment,\n\n isLogin,\n userInfo,\n isSubmitting,\n\n // word\n wordNumber,\n wordLimit,\n isWordNumberLegal,\n\n // inputs\n editor,\n userMeta,\n\n // emoji\n emoji,\n emojiTabIndex,\n showEmoji,\n\n // image\n canUploadImage,\n\n // preview\n previewText,\n showPreview,\n\n // ref\n inputRefs,\n editorRef,\n emojiButtonRef,\n emojiPopupRef,\n imageUploadRef,\n };\n },\n});\n</script>\n","/**\n * The wordCount module should be lightweight as it's packed into client.\n *\n * So We just make a simple implement here\n *\n * Forked from https://github.com/vuepress-theme-hope/vuepress-theme-hope/blob/main/packages/reading-time2/src/node/reading-time.ts\n */\n\nexport const getWords = (content: string): string[] =>\n content.match(/[\\w\\d\\s\\u00C0-\\u024F]+/giu) || [];\n\nexport const getChinese = (content: string): string[] =>\n content.match(/[\\u4E00-\\u9FA5]/gu) || [];\n\nexport const getWordNumber = (content: string): number =>\n getWords(content).reduce(\n (accumulator, word) =>\n accumulator + (word.trim() === '' ? 0 : word.trim().split(/\\s+/u).length),\n 0\n ) + getChinese(content).length;\n","<template>\n <div class=\"wl-comment\">\n <div v-if=\"config.login !== 'disable' && isLogin\" class=\"wl-login-info\">\n <div class=\"wl-avatar\">\n <button class=\"wl-logout-btn\" :title=\"locale.logout\" @click=\"onLogout\">\n <CloseIcon :size=\"14\" />\n </button>\n\n <img :src=\"userInfo.avatar\" alt=\"avatar\" />\n </div>\n <a\n href=\"#\"\n class=\"wl-login-nick\"\n aria-label=\"Profile\"\n @click=\"onProfile\"\n v-text=\"userInfo.display_name\"\n />\n </div>\n\n <div class=\"wl-panel\">\n <div\n v-if=\"config.login !== 'force' && config.meta.length && !isLogin\"\n :class=\"['wl-header', `item${config.meta.length}`]\"\n >\n <div v-for=\"kind in config.meta\" class=\"wl-header-item\" :key=\"kind\">\n <label\n :for=\"kind\"\n v-text=\"\n locale[kind] +\n (config.requiredMeta.includes(kind) || !config.requiredMeta.length\n ? ''\n : `(${locale.optional})`)\n \"\n />\n <input\n :ref=\"\n (element) => {\n if (element) inputRefs[kind] = element;\n }\n \"\n :id=\"`wl-${kind}`\"\n :class=\"['wl-input', `wl-${kind}`]\"\n :name=\"kind\"\n :type=\"kind === 'mail' ? 'email' : 'text'\"\n v-model=\"userMeta[kind]\"\n />\n </div>\n </div>\n\n <textarea\n class=\"wl-editor\"\n ref=\"editorRef\"\n id=\"wl-edit\"\n :placeholder=\"replyUser ? `@${replyUser}` : locale.placeholder\"\n v-model=\"editor\"\n @keydown=\"onKeyDown\"\n @drop=\"onDrop\"\n @paste=\"onPaste\"\n />\n\n <div class=\"wl-preview\" v-show=\"showPreview\">\n <hr />\n <h4>{{ locale.preview }}:</h4>\n <div class=\"wl-content\" v-html=\"previewText\" />\n </div>\n\n <div class=\"wl-footer\">\n <div class=\"wl-actions\">\n <a\n href=\"https://guides.github.com/features/mastering-markdown/\"\n title=\"Markdown Guide\"\n aria-label=\"Markdown is supported\"\n class=\"wl-action\"\n target=\"_blank\"\n rel=\"noreferrer\"\n >\n <MarkdownIcon />\n </a>\n\n <button\n ref=\"emojiButtonRef\"\n class=\"wl-action\"\n :class=\"{ actived: showEmoji }\"\n :title=\"locale.emoji\"\n @click=\"showEmoji = !showEmoji\"\n >\n <EmojiIcon />\n </button>\n\n <input\n ref=\"imageUploadRef\"\n class=\"upload\"\n id=\"wl-image-upload\"\n type=\"file\"\n accept=\".png,.jpg,.jpeg,.webp,.bmp,.gif\"\n @change=\"onChange\"\n />\n\n <label\n v-if=\"canUploadImage\"\n for=\"wl-image-upload\"\n class=\"wl-action\"\n :title=\"locale.uploadImage\"\n >\n <ImageIcon />\n </label>\n\n <button\n class=\"wl-action\"\n :class=\"{ actived: showPreview }\"\n :title=\"locale.preview\"\n @click=\"showPreview = !showPreview\"\n >\n <PreviewIcon />\n </button>\n </div>\n\n <div class=\"wl-info\">\n <div class=\"wl-text-number\">\n {{ wordNumber }}\n\n <span v-if=\"config.wordLimit\">\n / \n <span\n :class=\"{ illegal: !isWordNumberLegal }\"\n v-text=\"wordLimit\"\n />\n </span>\n\n {{ locale.word }}\n </div>\n\n <button\n v-if=\"config.login !== 'disable' && !isLogin\"\n class=\"wl-btn\"\n @click=\"onLogin\"\n v-text=\"locale.login\"\n />\n\n <button\n v-if=\"config.login !== 'force' || isLogin\"\n class=\"wl-btn primary\"\n title=\"Cmd|Ctrl + Enter\"\n :disabled=\"isSubmitting\"\n @click=\"submitComment\"\n >\n <LoadingIcon v-if=\"isSubmitting\" :size=\"16\" />\n <template v-else>\n {{ locale.submit }}\n </template>\n </button>\n </div>\n\n <div\n ref=\"emojiPopupRef\"\n class=\"wl-emoji-popup\"\n :class=\"{ display: showEmoji }\"\n >\n <template v-for=\"(config, index) in emoji.tabs\" :key=\"config.name\">\n <div v-if=\"index === emojiTabIndex\" class=\"wl-tab-wrapper\">\n <button\n v-for=\"key in config.items\"\n :key=\"key\"\n :title=\"key\"\n @click=\"insert(`:${key}:`)\"\n >\n <img\n v-if=\"showEmoji\"\n class=\"wl-emoji\"\n :src=\"emoji.map[key]\"\n :alt=\"key\"\n loading=\"lazy\"\n referrerPolicy=\"no-referrer\"\n />\n </button>\n </div>\n </template>\n <div v-if=\"emoji.tabs.length > 1\" class=\"wl-tabs\">\n <button\n v-for=\"(config, index) in emoji.tabs\"\n :key=\"config.name\"\n class=\"wl-tab\"\n :class=\"{ active: emojiTabIndex === index }\"\n @click=\"emojiTabIndex = index\"\n >\n <img\n class=\"wl-emoji\"\n :src=\"config.icon\"\n :alt=\"config.name\"\n :title=\"config.name\"\n loading=\"lazy\"\n referrerPolicy=\"no-referrer\"\n />\n </button>\n </div>\n </div>\n </div>\n </div>\n\n <button\n v-if=\"replyId\"\n class=\"wl-close\"\n :title=\"locale.cancelReply\"\n @click=\"$emit('cancel-reply')\"\n >\n <CloseIcon :size=\"24\" />\n </button>\n </div>\n</template>\n\n<script lang=\"ts\">\nimport autosize from 'autosize';\nimport {\n computed,\n defineComponent,\n inject,\n onMounted,\n onUnmounted,\n ref,\n watch,\n} from 'vue';\n\nimport {\n CloseIcon,\n EmojiIcon,\n ImageIcon,\n MarkdownIcon,\n PreviewIcon,\n LoadingIcon,\n} from './Icons';\nimport { useEditor, useUserMeta, useUserInfo } from '../composables';\nimport {\n getImagefromDataTransfer,\n parseMarkdown,\n getWordNumber,\n parseEmoji,\n postComment,\n getEmojis,\n} from '../utils';\n\nimport type { ComputedRef, DeepReadonly } from 'vue';\nimport type { WalineCommentData, WalineImageUploader } from '../typings';\nimport type { WalineConfig, WalineEmojiConfig } from '../utils';\n\nexport default defineComponent({\n name: 'CommentBox',\n\n components: {\n CloseIcon,\n EmojiIcon,\n ImageIcon,\n MarkdownIcon,\n PreviewIcon,\n LoadingIcon,\n },\n\n props: {\n rootId: {\n type: String,\n default: '',\n },\n replyId: {\n type: String,\n default: '',\n },\n replyUser: {\n type: String,\n default: '',\n },\n },\n\n emits: ['submit', 'cancel-reply'],\n\n setup(props, { emit }) {\n const config = inject<ComputedRef<WalineConfig>>(\n 'config'\n ) as ComputedRef<WalineConfig>;\n\n const editor = useEditor();\n const userMeta = useUserMeta();\n const userInfo = useUserInfo();\n\n const inputRefs = ref<Record<string, HTMLInputElement>>({});\n const editorRef = ref<HTMLTextAreaElement | null>(null);\n const imageUploadRef = ref<HTMLInputElement | null>(null);\n const emojiButtonRef = ref<HTMLDivElement | null>(null);\n const emojiPopupRef = ref<HTMLDivElement | null>(null);\n\n const emoji = ref<DeepReadonly<WalineEmojiConfig>>({ tabs: [], map: {} });\n const emojiTabIndex = ref(0);\n const showEmoji = ref(false);\n const showPreview = ref(false);\n const previewText = ref('');\n const wordNumber = ref(0);\n\n const wordLimit = ref(0);\n const isWordNumberLegal = ref(false);\n\n const content = ref('');\n\n const isSubmitting = ref(false);\n\n const locale = computed(() => config.value.locale);\n\n const isLogin = computed(() => Boolean(userInfo.value?.token));\n\n const canUploadImage = computed(() => config.value.imageUploader !== false);\n\n const insert = (content: string): void => {\n const textArea = editorRef.value as HTMLTextAreaElement;\n const startPosition = textArea.selectionStart;\n const endPosition = textArea.selectionEnd || 0;\n const scrollTop = textArea.scrollTop;\n\n editor.value =\n textArea.value.substring(0, startPosition) +\n content +\n textArea.value.substring(endPosition, textArea.value.length);\n textArea.focus();\n textArea.selectionStart = startPosition + content.length;\n textArea.selectionEnd = startPosition + content.length;\n textArea.scrollTop = scrollTop;\n };\n\n const onKeyDown = (event: KeyboardEvent): void => {\n const key = event.key;\n\n // Shortcut key\n if ((event.ctrlKey || event.metaKey) && key === 'Enter') submitComment();\n };\n\n const uploadImage = (file: File): Promise<void> => {\n const uploadText = `![${config.value.locale.uploading} ${file.name}]()`;\n\n insert(uploadText);\n\n return Promise.resolve()\n .then(() => (config.value.imageUploader as WalineImageUploader)(file))\n .then((url) => {\n editor.value = editor.value.replace(\n uploadText,\n `\\r\\n`\n );\n });\n };\n\n const onDrop = (event: DragEvent): void => {\n if (event.dataTransfer?.items) {\n const file = getImagefromDataTransfer(event.dataTransfer.items);\n\n if (file && canUploadImage.value) {\n uploadImage(file);\n event.preventDefault();\n }\n }\n };\n\n const onPaste = (event: ClipboardEvent): void => {\n if (event.clipboardData) {\n const file = getImagefromDataTransfer(event.clipboardData.items);\n\n if (file && canUploadImage.value) uploadImage(file);\n }\n };\n\n const onChange = (): void => {\n const inputElement = imageUploadRef.value as HTMLInputElement;\n\n if (inputElement.files && canUploadImage.value)\n uploadImage(inputElement.files[0]).then(() => {\n // clear input so a same image can be uploaded later\n inputElement.value = '';\n });\n };\n\n const submitComment = (): void => {\n const { serverURL, lang, login, wordLimit, requiredMeta } = config.value;\n\n const comment: WalineCommentData = {\n comment: content.value,\n nick: userMeta.value.nick,\n mail: userMeta.value.mail,\n link: userMeta.value.link,\n ua: navigator.userAgent,\n url: config.value.path,\n };\n\n if (userInfo.value?.token) {\n // login user\n\n comment.nick = userInfo.value.display_name;\n comment.mail = userInfo.value.email;\n comment.link = userInfo.value.url;\n } else {\n if (login === 'force') return;\n\n // check nick\n if (\n (requiredMeta.indexOf('nick') > -1 || comment.nick) &&\n !comment.nick\n ) {\n inputRefs.value.nick?.focus();\n return alert(locale.value.nickError);\n }\n\n // check mail\n if (requiredMeta.indexOf('mail') > -1 && !comment.mail) {\n inputRefs.value.mail?.focus();\n return alert(locale.value.mailError);\n }\n\n // check comment\n if (!comment.comment) {\n editorRef.value?.focus();\n return;\n }\n\n if (!comment.nick) comment.nick = locale.value.anonymous;\n }\n\n if (!isWordNumberLegal.value)\n return alert(\n locale.value.wordHint\n .replace('$0', (wordLimit as [number, number])[0].toString())\n .replace('$1', (wordLimit as [number, number])[1].toString())\n .replace('$2', wordNumber.value.toString())\n );\n\n comment.comment = parseEmoji(comment.comment, emoji.value.map);\n\n if (props.replyId && props.rootId) {\n comment.pid = props.replyId;\n comment.rid = props.rootId;\n comment.at = props.replyUser;\n }\n\n isSubmitting.value = true;\n\n postComment({\n serverURL,\n lang,\n token: userInfo.value?.token,\n comment,\n })\n .then((resp) => {\n isSubmitting.value = false;\n\n if (resp.errmsg) return alert(resp.errmsg);\n\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n emit('submit', resp.data!);\n\n editor.value = '';\n\n previewText.value = '';\n\n if (props.replyId) emit('cancel-reply');\n })\n .catch((err: TypeError) => {\n isSubmitting.value = false;\n\n alert(err.message);\n });\n };\n\n const onLogin = (event: Event): void => {\n event.preventDefault();\n const { lang, serverURL } = config.value;\n\n const width = 450;\n const height = 450;\n const left = (window.innerWidth - width) / 2;\n const top = (window.innerHeight - height) / 2;\n\n const handler = window.open(\n `${serverURL}/ui/login?lng=${encodeURIComponent(lang)}`,\n '_blank',\n `width=${width},height=${height},left=${left},top=${top},scrollbars=no,resizable=no,status=no,location=no,toolbar=no,menubar=no`\n );\n\n handler?.postMessage({ type: 'TOKEN', data: null }, '*');\n\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const receiver = ({ data }: any): void => {\n if (!data || data.type !== 'userInfo') return;\n\n if (data.data.token) {\n handler?.close();\n userInfo.value = data.data;\n (data.data.remember ? localStorage : sessionStorage).setItem(\n 'WALINE_USER',\n JSON.stringify(data.data)\n );\n\n window.removeEventListener('message', receiver);\n }\n };\n\n window.addEventListener('message', receiver);\n };\n\n const onLogout = (): void => {\n userInfo.value = {};\n localStorage.setItem('WALINE_USER', 'null');\n sessionStorage.setItem('WALINE_USER', 'null');\n };\n\n const onProfile = (event: Event): void => {\n event.preventDefault();\n\n const { lang, serverURL } = config.value;\n\n const width = 800;\n const height = 800;\n const left = (window.innerWidth - width) / 2;\n const top = (window.innerHeight - height) / 2;\n const handler = window.open(\n `${serverURL}/ui/profile?lng=${encodeURIComponent(lang)}`,\n '_blank',\n `width=${width},height=${height},left=${left},top=${top},scrollbars=no,resizable=no,status=no,location=no,toolbar=no,menubar=no`\n );\n\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n handler?.postMessage({ type: 'TOKEN', data: userInfo.value!.token }, '*');\n\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const receiver = ({ data }: any): void => {\n if (!data || data.type !== 'profile') return;\n\n userInfo.value = { ...userInfo.value, ...data };\n\n [localStorage, sessionStorage]\n .filter((store) => store.getItem('WALINE_USER'))\n .forEach((store) =>\n store.setItem('WALINE_USER', JSON.stringify(userInfo))\n );\n window.removeEventListener('message', receiver);\n };\n\n window.addEventListener('message', receiver);\n };\n\n const popupHandler = (event: MouseEvent): void => {\n if (\n !(emojiButtonRef.value as HTMLElement).contains(event.target as Node) &&\n !(emojiPopupRef.value as HTMLElement).contains(event.target as Node)\n )\n showEmoji.value = false;\n };\n\n // update wordNumber\n watch(\n [config, wordNumber],\n ([config, wordNumber]) => {\n const { wordLimit: limit } = config;\n\n if (limit) {\n if (wordNumber < limit[0] && limit[0] !== 0) {\n wordLimit.value = limit[0];\n isWordNumberLegal.value = false;\n } else if (wordNumber > limit[1]) {\n wordLimit.value = limit[1];\n isWordNumberLegal.value = false;\n } else {\n wordLimit.value = limit[1];\n isWordNumberLegal.value = true;\n }\n } else {\n wordLimit.value = 0;\n isWordNumberLegal.value = true;\n }\n },\n { immediate: true }\n );\n\n onMounted(() => {\n document.body.addEventListener('click', popupHandler);\n\n // watch editor\n watch(\n () => editor.value,\n (value) => {\n const { highlighter, texRenderer } = config.value;\n\n content.value = value;\n previewText.value = parseMarkdown(value, {\n emojiMap: emoji.value.map,\n highlighter,\n texRenderer,\n });\n wordNumber.value = getWordNumber(value);\n\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n if (value) autosize(editorRef.value!);\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n else autosize.destroy(editorRef.value!);\n },\n { immediate: true }\n );\n\n // watch emoji value change\n watch(\n () => config.value.emoji,\n (emojiConfig) =>\n getEmojis(emojiConfig).then((config) => {\n emoji.value = config;\n }),\n { immediate: true }\n );\n });\n\n onUnmounted(() => {\n document.body.removeEventListener('click', popupHandler);\n });\n\n return {\n // config\n config,\n locale,\n\n // events\n insert,\n onChange,\n onDrop,\n onKeyDown,\n onPaste,\n onLogin,\n onLogout,\n onProfile,\n submitComment,\n\n isLogin,\n userInfo,\n isSubmitting,\n\n // word\n wordNumber,\n wordLimit,\n isWordNumberLegal,\n\n // inputs\n editor,\n userMeta,\n\n // emoji\n emoji,\n emojiTabIndex,\n showEmoji,\n\n // image\n canUploadImage,\n\n // preview\n previewText,\n showPreview,\n\n // ref\n inputRefs,\n editorRef,\n emojiButtonRef,\n emojiPopupRef,\n imageUploadRef,\n };\n },\n});\n</script>\n","<template>\n <div class=\"wl-item\" :id=\"comment.objectId\">\n <div class=\"wl-user\" aria-hidden=\"true\">\n <img v-if=\"comment.avatar\" :src=\"comment.avatar\" />\n <VerifiedIcon v-if=\"comment.type\" />\n </div>\n\n <div class=\"wl-card\">\n <div class=\"wl-head\">\n <a\n v-if=\"link\"\n class=\"wl-nick\"\n :href=\"link\"\n target=\"_blank\"\n rel=\"nofollow noreferrer\"\n >{{ comment.nick }}</a\n >\n <span v-else class=\"wl-nick\">{{ comment.nick }}</span>\n\n <span\n v-if=\"comment.type === 'administrator'\"\n class=\"wl-badge\"\n v-text=\"locale.admin\"\n />\n <span v-if=\"comment.sticky\" class=\"wl-badge\" v-text=\"locale.sticky\" />\n\n <span class=\"wl-time\" v-text=\"time\" />\n\n <button\n class=\"wl-reply\"\n :class=\"{ active: isReplyingCurrent }\"\n :title=\"isReplyingCurrent ? locale.cancelReply : locale.reply\"\n @click=\"$emit('reply', isReplyingCurrent ? null : comment)\"\n >\n <ReplyIcon />\n </button>\n </div>\n <div class=\"wl-meta\" aria-hidden=\"true\">\n <span v-if=\"comment.browser\" v-text=\"comment.browser\" />\n <span v-if=\"comment.os\" v-text=\"comment.os\" />\n </div>\n <div class=\"wl-content\" v-html=\"comment.comment\" />\n\n <div v-if=\"isReplyingCurrent\" class=\"wl-reply-wrapper\">\n <CommentBox\n :replyId=\"comment.objectId\"\n :replyUser=\"comment.nick\"\n :rootId=\"rootId\"\n @submit=\"$emit('submit', $event)\"\n @cancel-reply=\"$emit('reply', null)\"\n />\n </div>\n <div v-if=\"comment.children\" class=\"wl-quote\">\n <CommentCard\n v-for=\"child in comment.children\"\n :key=\"child.objectId\"\n :comment=\"child\"\n :reply=\"reply\"\n :rootId=\"rootId\"\n @reply=\"$emit('reply', $event)\"\n @submit=\"$emit('submit', $event)\"\n />\n </div>\n </div>\n </div>\n</template>\n\n<script lang=\"ts\">\nimport { computed, defineComponent, inject } from 'vue';\nimport CommentBox from './CommentBox.vue';\nimport { ReplyIcon, VerifiedIcon } from './Icons';\nimport { isLinkHttp } from '../utils';\nimport { useTimeAgo } from '../composables';\n\nimport type { ComputedRef, PropType } from 'vue';\nimport type { WalineConfig } from '../utils';\nimport type { WalineComment } from '../typings';\n\nexport default defineComponent({\n props: {\n comment: {\n type: Object as PropType<WalineComment>,\n required: true,\n },\n rootId: {\n type: String,\n required: true,\n },\n reply: {\n type: Object as PropType<WalineComment | null>,\n },\n },\n\n components: {\n CommentBox,\n ReplyIcon,\n VerifiedIcon,\n },\n\n emits: ['submit', 'reply'],\n\n setup(props) {\n const config = inject<ComputedRef<WalineConfig>>(\n 'config'\n ) as ComputedRef<WalineConfig>;\n const locale = computed(() => config.value.locale);\n\n const link = computed(() => {\n let { link } = props.comment;\n\n return link ? (isLinkHttp(link) ? link : `https://${link}`) : '';\n });\n\n const time = useTimeAgo(props.comment.insertedAt, locale.value);\n\n const isReplyingCurrent = computed(\n () => props.comment.objectId === props.reply?.objectId\n );\n\n return {\n config,\n locale,\n\n isReplyingCurrent,\n link,\n time,\n };\n },\n});\n</script>\n","<template>\n <div class=\"wl-item\" :id=\"comment.objectId\">\n <div class=\"wl-user\" aria-hidden=\"true\">\n <img v-if=\"comment.avatar\" :src=\"comment.avatar\" />\n <VerifiedIcon v-if=\"comment.type\" />\n </div>\n\n <div class=\"wl-card\">\n <div class=\"wl-head\">\n <a\n v-if=\"link\"\n class=\"wl-nick\"\n :href=\"link\"\n target=\"_blank\"\n rel=\"nofollow noreferrer\"\n >{{ comment.nick }}</a\n >\n <span v-else class=\"wl-nick\">{{ comment.nick }}</span>\n\n <span\n v-if=\"comment.type === 'administrator'\"\n class=\"wl-badge\"\n v-text=\"locale.admin\"\n />\n <span v-if=\"comment.sticky\" class=\"wl-badge\" v-text=\"locale.sticky\" />\n\n <span class=\"wl-time\" v-text=\"time\" />\n\n <button\n class=\"wl-reply\"\n :class=\"{ active: isReplyingCurrent }\"\n :title=\"isReplyingCurrent ? locale.cancelReply : locale.reply\"\n @click=\"$emit('reply', isReplyingCurrent ? null : comment)\"\n >\n <ReplyIcon />\n </button>\n </div>\n <div class=\"wl-meta\" aria-hidden=\"true\">\n <span v-if=\"comment.browser\" v-text=\"comment.browser\" />\n <span v-if=\"comment.os\" v-text=\"comment.os\" />\n </div>\n <div class=\"wl-content\" v-html=\"comment.comment\" />\n\n <div v-if=\"isReplyingCurrent\" class=\"wl-reply-wrapper\">\n <CommentBox\n :replyId=\"comment.objectId\"\n :replyUser=\"comment.nick\"\n :rootId=\"rootId\"\n @submit=\"$emit('submit', $event)\"\n @cancel-reply=\"$emit('reply', null)\"\n />\n </div>\n <div v-if=\"comment.children\" class=\"wl-quote\">\n <CommentCard\n v-for=\"child in comment.children\"\n :key=\"child.objectId\"\n :comment=\"child\"\n :reply=\"reply\"\n :rootId=\"rootId\"\n @reply=\"$emit('reply', $event)\"\n @submit=\"$emit('submit', $event)\"\n />\n </div>\n </div>\n </div>\n</template>\n\n<script lang=\"ts\">\nimport { computed, defineComponent, inject } from 'vue';\nimport CommentBox from './CommentBox.vue';\nimport { ReplyIcon, VerifiedIcon } from './Icons';\nimport { isLinkHttp } from '../utils';\nimport { useTimeAgo } from '../composables';\n\nimport type { ComputedRef, PropType } from 'vue';\nimport type { WalineConfig } from '../utils';\nimport type { WalineComment } from '../typings';\n\nexport default defineComponent({\n props: {\n comment: {\n type: Object as PropType<WalineComment>,\n required: true,\n },\n rootId: {\n type: String,\n required: true,\n },\n reply: {\n type: Object as PropType<WalineComment | null>,\n },\n },\n\n components: {\n CommentBox,\n ReplyIcon,\n VerifiedIcon,\n },\n\n emits: ['submit', 'reply'],\n\n setup(props) {\n const config = inject<ComputedRef<WalineConfig>>(\n 'config'\n ) as ComputedRef<WalineConfig>;\n const locale = computed(() => config.value.locale);\n\n const link = computed(() => {\n let { link } = props.comment;\n\n return link ? (isLinkHttp(link) ? link : `https://${link}`) : '';\n });\n\n const time = useTimeAgo(props.comment.insertedAt, locale.value);\n\n const isReplyingCurrent = computed(\n () => props.comment.objectId === props.reply?.objectId\n );\n\n return {\n config,\n locale,\n\n isReplyingCurrent,\n link,\n time,\n };\n },\n});\n</script>\n","<template>\n <div data-waline>\n <CommentBox v-if=\"!reply\" @submit=\"onSubmit\" />\n <div class=\"wl-count\">\n <span v-if=\"count\" class=\"wl-num\" v-text=\"count\" />\n {{ i18n.comment }}\n </div>\n\n <div class=\"wl-cards\">\n <CommentCard\n v-for=\"comment in data\"\n :key=\"comment.objectId\"\n :root-id=\"comment.objectId\"\n :comment=\"comment\"\n :reply=\"reply\"\n @reply=\"onReply\"\n @submit=\"onSubmit\"\n />\n </div>\n\n <div v-if=\"status === 'error'\" class=\"wl-operation\">\n <button\n type=\"button\"\n class=\"wl-btn\"\n @click=\"refresh\"\n v-text=\"i18n.refresh\"\n />\n </div>\n\n <template v-else>\n <div v-if=\"status === 'loading'\" class=\"wl-loading\">\n <LoadingIcon :size=\"30\" />\n </div>\n\n <div v-else-if=\"!data.length\" class=\"wl-empty\" v-text=\"i18n.sofa\" />\n\n <!-- Load more button -->\n <div v-else-if=\"page < totalPages\" class=\"wl-operation\">\n <button\n type=\"button\"\n class=\"wl-btn\"\n @click=\"loadMore\"\n v-text=\"i18n.more\"\n />\n </div>\n </template>\n\n <!-- Copyright Information -->\n <div v-if=\"config.copyright\" class=\"wl-power\">\n Powered by\n <a\n href=\"https://github.com/walinejs/waline\"\n target=\"_blank\"\n rel=\"noreferrer\"\n >\n Waline\n </a>\n v{{ version }}\n </div>\n </div>\n</template>\n\n<script lang=\"ts\">\nimport {\n computed,\n defineComponent,\n onBeforeUnmount,\n onMounted,\n provide,\n ref,\n watch,\n watchEffect,\n} from 'vue';\nimport CommentBox from './CommentBox.vue';\nimport CommentCard from './CommentCard.vue';\nimport { LoadingIcon } from './Icons';\nimport { useUserInfo } from '../composables';\nimport { locales } from '../config';\nimport { fetchCommentList, getConfig, getDarkStyle } from '../utils';\n\nimport type { PropType } from 'vue';\nimport type {\n WalineComment,\n WalineEmojiInfo,\n WalineHighlighter,\n WalineTexRenderer,\n WalineImageUploader,\n WalineLocale,\n WalineProps,\n} from '../typings';\n\ndeclare const SHOULD_VALIDATE: boolean;\ndeclare const VERSION: string;\n\nexport default defineComponent({\n name: 'WalineRoot',\n\n components: {\n CommentBox,\n CommentCard,\n LoadingIcon,\n },\n\n props: {\n serverURL: {\n type: String,\n required: true,\n },\n\n path: {\n type: String,\n required: true,\n },\n\n meta: {\n type: Array,\n ...(SHOULD_VALIDATE\n ? {\n validator: (value: unknown): boolean =>\n Array.isArray(value) &&\n value.every((item) => ['nick', 'mail', 'link'].includes(item)),\n }\n : {}),\n },\n\n requiredMeta: {\n type: Array,\n ...(SHOULD_VALIDATE\n ? {\n validator: (value: unknown): boolean =>\n Array.isArray(value) &&\n value.every((item) => ['nick', 'mail', 'link'].includes(item)),\n }\n : {}),\n },\n\n dark: {\n type: [String, Boolean],\n },\n\n lang: {\n type: String,\n ...(SHOULD_VALIDATE\n ? {\n validator: (value: unknown): boolean =>\n Object.keys(locales).includes(value as string),\n }\n : {}),\n },\n\n locale: {\n type: Object as PropType<Partial<WalineLocale>>,\n },\n\n pageSize: {\n type: Number,\n },\n\n wordLimit: {\n type: [Number, Array] as PropType<number | [number, number]>,\n // default: 0,\n ...(SHOULD_VALIDATE\n ? {\n validator: (value: unknown): boolean =>\n typeof value === 'number' ||\n (Array.isArray(value) &&\n value.length === 2 &&\n value.every((item) => typeof item === 'number')),\n }\n : {}),\n },\n\n emoji: {\n type: Array as PropType<(string | WalineEmojiInfo)[]>,\n ...(SHOULD_VALIDATE\n ? {\n validator: (value: unknown): boolean =>\n Array.isArray(value) &&\n value.every(\n (item) =>\n typeof item === 'string' ||\n (typeof item === 'object' &&\n typeof item.name === 'string' &&\n typeof item.folder === 'string' &&\n typeof item.icon === 'string' &&\n Array.isArray(item.items) &&\n (item.items as unknown[]).every(\n (icon) => typeof icon === 'string'\n ))\n ),\n }\n : {}),\n },\n\n login: {\n type: String as PropType<'enable' | 'disable' | 'force'>,\n },\n\n highlighter: {\n type: Function as PropType<WalineHighlighter>,\n },\n\n imageUploader: {\n type: [Function, Boolean] as PropType<WalineImageUploader | false>,\n },\n\n texRenderer: {\n type: [Function, Boolean] as PropType<WalineTexRenderer | false>,\n },\n },\n\n setup(props) {\n const config = computed(() => getConfig(props as WalineProps));\n\n const userInfo = useUserInfo();\n\n const status = ref<'loading' | 'success' | 'error'>('loading');\n\n const count = ref(0);\n const page = ref(1);\n const totalPages = ref(0);\n\n const data = ref<WalineComment[]>([]);\n const reply = ref<WalineComment | null>(null);\n\n const darkmodeStyle = computed(() => getDarkStyle(config.value.dark));\n\n // eslint-disable-next-line vue/no-setup-props-destructure\n let abort: () => void;\n let stop: () => void;\n\n const fetchComment = (pageNumber: number): void => {\n const { serverURL, path, pageSize } = config.value;\n const controller = new AbortController();\n\n status.value = 'loading';\n\n abort?.();\n\n fetchCommentList({\n serverURL,\n path,\n pageSize,\n page: pageNumber,\n signal: controller.signal,\n token: userInfo.value?.token,\n })\n .then((resp) => {\n status.value = 'success';\n count.value = resp.count;\n data.value.push(...resp.data);\n page.value = pageNumber;\n totalPages.value = resp.totalPages;\n })\n .catch((err) => {\n if (err.name !== 'AbortError') {\n console.error(err.message);\n status.value = 'error';\n }\n });\n\n abort = controller.abort.bind(controller);\n };\n\n const loadMore = (): void => fetchComment(page.value + 1);\n\n const refresh = (): void => {\n count.value = 0;\n data.value = [];\n fetchComment(1);\n };\n\n const onReply = (comment: WalineComment | null): void => {\n reply.value = comment;\n };\n\n const onSubmit = (comment: WalineComment): void => {\n if (comment.rid) {\n const repliedComment = data.value.find(\n ({ objectId }) => objectId === comment.rid\n );\n\n if (!repliedComment) return;\n\n if (!Array.isArray(repliedComment.children))\n repliedComment.children = [];\n\n repliedComment.children.push(comment);\n } else data.value.unshift(comment);\n };\n\n provide('config', config);\n\n watch(() => props.path, refresh);\n\n onMounted(() => {\n refresh();\n\n const style = document.createElement('style');\n\n style.innerText = darkmodeStyle.value;\n\n document.querySelector('[data-waline]')?.appendChild(style);\n\n stop = watchEffect(() => {\n style.innerText = darkmodeStyle.value;\n });\n });\n\n onBeforeUnmount(() => stop());\n\n return {\n config,\n darkmodeStyle,\n i18n: computed(() => config.value.locale),\n\n status,\n count,\n page,\n totalPages,\n data,\n reply,\n\n loadMore,\n refresh,\n onReply,\n onSubmit,\n\n version: VERSION,\n };\n },\n});\n</script>\n","<template>\n <div data-waline>\n <CommentBox v-if=\"!reply\" @submit=\"onSubmit\" />\n <div class=\"wl-count\">\n <span v-if=\"count\" class=\"wl-num\" v-text=\"count\" />\n {{ i18n.comment }}\n </div>\n\n <div class=\"wl-cards\">\n <CommentCard\n v-for=\"comment in data\"\n :key=\"comment.objectId\"\n :root-id=\"comment.objectId\"\n :comment=\"comment\"\n :reply=\"reply\"\n @reply=\"onReply\"\n @submit=\"onSubmit\"\n />\n </div>\n\n <div v-if=\"status === 'error'\" class=\"wl-operation\">\n <button\n type=\"button\"\n class=\"wl-btn\"\n @click=\"refresh\"\n v-text=\"i18n.refresh\"\n />\n </div>\n\n <template v-else>\n <div v-if=\"status === 'loading'\" class=\"wl-loading\">\n <LoadingIcon :size=\"30\" />\n </div>\n\n <div v-else-if=\"!data.length\" class=\"wl-empty\" v-text=\"i18n.sofa\" />\n\n <!-- Load more button -->\n <div v-else-if=\"page < totalPages\" class=\"wl-operation\">\n <button\n type=\"button\"\n class=\"wl-btn\"\n @click=\"loadMore\"\n v-text=\"i18n.more\"\n />\n </div>\n </template>\n\n <!-- Copyright Information -->\n <div v-if=\"config.copyright\" class=\"wl-power\">\n Powered by\n <a\n href=\"https://github.com/walinejs/waline\"\n target=\"_blank\"\n rel=\"noreferrer\"\n >\n Waline\n </a>\n v{{ version }}\n </div>\n </div>\n</template>\n\n<script lang=\"ts\">\nimport {\n computed,\n defineComponent,\n onBeforeUnmount,\n onMounted,\n provide,\n ref,\n watch,\n watchEffect,\n} from 'vue';\nimport CommentBox from './CommentBox.vue';\nimport CommentCard from './CommentCard.vue';\nimport { LoadingIcon } from './Icons';\nimport { useUserInfo } from '../composables';\nimport { locales } from '../config';\nimport { fetchCommentList, getConfig, getDarkStyle } from '../utils';\n\nimport type { PropType } from 'vue';\nimport type {\n WalineComment,\n WalineEmojiInfo,\n WalineHighlighter,\n WalineTexRenderer,\n WalineImageUploader,\n WalineLocale,\n WalineProps,\n} from '../typings';\n\ndeclare const SHOULD_VALIDATE: boolean;\ndeclare const VERSION: string;\n\nexport default defineComponent({\n name: 'WalineRoot',\n\n components: {\n CommentBox,\n CommentCard,\n LoadingIcon,\n },\n\n props: {\n serverURL: {\n type: String,\n required: true,\n },\n\n path: {\n type: String,\n required: true,\n },\n\n meta: {\n type: Array,\n ...(SHOULD_VALIDATE\n ? {\n validator: (value: unknown): boolean =>\n Array.isArray(value) &&\n value.every((item) => ['nick', 'mail', 'link'].includes(item)),\n }\n : {}),\n },\n\n requiredMeta: {\n type: Array,\n ...(SHOULD_VALIDATE\n ? {\n validator: (value: unknown): boolean =>\n Array.isArray(value) &&\n value.every((item) => ['nick', 'mail', 'link'].includes(item)),\n }\n : {}),\n },\n\n dark: {\n type: [String, Boolean],\n },\n\n lang: {\n type: String,\n ...(SHOULD_VALIDATE\n ? {\n validator: (value: unknown): boolean =>\n Object.keys(locales).includes(value as string),\n }\n : {}),\n },\n\n locale: {\n type: Object as PropType<Partial<WalineLocale>>,\n },\n\n pageSize: {\n type: Number,\n },\n\n wordLimit: {\n type: [Number, Array] as PropType<number | [number, number]>,\n // default: 0,\n ...(SHOULD_VALIDATE\n ? {\n validator: (value: unknown): boolean =>\n typeof value === 'number' ||\n (Array.isArray(value) &&\n value.length === 2 &&\n value.every((item) => typeof item === 'number')),\n }\n : {}),\n },\n\n emoji: {\n type: Array as PropType<(string | WalineEmojiInfo)[]>,\n ...(SHOULD_VALIDATE\n ? {\n validator: (value: unknown): boolean =>\n Array.isArray(value) &&\n value.every(\n (item) =>\n typeof item === 'string' ||\n (typeof item === 'object' &&\n typeof item.name === 'string' &&\n typeof item.folder === 'string' &&\n typeof item.icon === 'string' &&\n Array.isArray(item.items) &&\n (item.items as unknown[]).every(\n (icon) => typeof icon === 'string'\n ))\n ),\n }\n : {}),\n },\n\n login: {\n type: String as PropType<'enable' | 'disable' | 'force'>,\n },\n\n highlighter: {\n type: Function as PropType<WalineHighlighter>,\n },\n\n imageUploader: {\n type: [Function, Boolean] as PropType<WalineImageUploader | false>,\n },\n\n texRenderer: {\n type: [Function, Boolean] as PropType<WalineTexRenderer | false>,\n },\n },\n\n setup(props) {\n const config = computed(() => getConfig(props as WalineProps));\n\n const userInfo = useUserInfo();\n\n const status = ref<'loading' | 'success' | 'error'>('loading');\n\n const count = ref(0);\n const page = ref(1);\n const totalPages = ref(0);\n\n const data = ref<WalineComment[]>([]);\n const reply = ref<WalineComment | null>(null);\n\n const darkmodeStyle = computed(() => getDarkStyle(config.value.dark));\n\n // eslint-disable-next-line vue/no-setup-props-destructure\n let abort: () => void;\n let stop: () => void;\n\n const fetchComment = (pageNumber: number): void => {\n const { serverURL, path, pageSize } = config.value;\n const controller = new AbortController();\n\n status.value = 'loading';\n\n abort?.();\n\n fetchCommentList({\n serverURL,\n path,\n pageSize,\n page: pageNumber,\n signal: controller.signal,\n token: userInfo.value?.token,\n })\n .then((resp) => {\n status.value = 'success';\n count.value = resp.count;\n data.value.push(...resp.data);\n page.value = pageNumber;\n totalPages.value = resp.totalPages;\n })\n .catch((err) => {\n if (err.name !== 'AbortError') {\n console.error(err.message);\n status.value = 'error';\n }\n });\n\n abort = controller.abort.bind(controller);\n };\n\n const loadMore = (): void => fetchComment(page.value + 1);\n\n const refresh = (): void => {\n count.value = 0;\n data.value = [];\n fetchComment(1);\n };\n\n const onReply = (comment: WalineComment | null): void => {\n reply.value = comment;\n };\n\n const onSubmit = (comment: WalineComment): void => {\n if (comment.rid) {\n const repliedComment = data.value.find(\n ({ objectId }) => objectId === comment.rid\n );\n\n if (!repliedComment) return;\n\n if (!Array.isArray(repliedComment.children))\n repliedComment.children = [];\n\n repliedComment.children.push(comment);\n } else data.value.unshift(comment);\n };\n\n provide('config', config);\n\n watch(() => props.path, refresh);\n\n onMounted(() => {\n refresh();\n\n const style = document.createElement('style');\n\n style.innerText = darkmodeStyle.value;\n\n document.querySelector('[data-waline]')?.appendChild(style);\n\n stop = watchEffect(() => {\n style.innerText = darkmodeStyle.value;\n });\n });\n\n onBeforeUnmount(() => stop());\n\n return {\n config,\n darkmodeStyle,\n i18n: computed(() => config.value.locale),\n\n status,\n count,\n page,\n totalPages,\n data,\n reply,\n\n loadMore,\n refresh,\n onReply,\n onSubmit,\n\n version: VERSION,\n };\n },\n});\n</script>\n","import {\n errorHandler,\n fetchPageviews,\n getQuery,\n updatePageviews,\n} from './utils';\n\nimport type { WalineAbort } from './typings';\n\nexport interface WalinePageviewCountOptions {\n /**\n * Waline 服务端地址\n *\n * Waline server url\n */\n serverURL: string;\n\n /**\n * 浏览量 CSS 选择器\n *\n * Pageview CSS selector\n *\n * @default '.waline-pageview-count'\n */\n selector?: string;\n\n /**\n * 需要更新和获取的路径\n *\n * Path to be fetched and updated\n *\n * @default window.location.pathname\n */\n path?: string;\n\n /**\n * 是否在查询时更新 path 的浏览量\n *\n * Whether update pageviews when fetching path result\n *\n * @default true\n */\n update?: boolean;\n}\n\nconst renderVisitorCount = (\n counts: number[],\n countElements: HTMLElement[]\n): void => {\n countElements.forEach((element, index) => {\n element.innerText = counts[index].toString();\n });\n};\n\nexport const pageviewCount = ({\n serverURL,\n path = window.location.pathname,\n selector = '.waline-pageview-count',\n update = true,\n}: WalinePageviewCountOptions): WalineAbort => {\n const controller = new AbortController();\n\n const elements = Array.from(\n // pageview selectors\n document.querySelectorAll<HTMLElement>(selector)\n );\n\n const filter = (element: HTMLElement): boolean => {\n const query = getQuery(element);\n\n return query !== null && path !== query;\n };\n\n const fetch = (elements: HTMLElement[]): Promise<void> =>\n fetchPageviews({\n serverURL,\n paths: elements.map((element) => getQuery(element) || path),\n signal: controller.signal,\n })\n .then((counts) => renderVisitorCount(counts, elements))\n .catch(errorHandler);\n\n // we should update pageviews\n if (update) {\n const normalElements = elements.filter((element) => !filter(element));\n const elementsNeedstoBeFetched = elements.filter(filter);\n\n void updatePageviews({ serverURL, path }).then((count) =>\n renderVisitorCount(\n new Array<number>(normalElements.length).fill(count),\n normalElements\n )\n );\n\n // if we should fetch count of other pages\n if (elementsNeedstoBeFetched.length) {\n void fetch(elementsNeedstoBeFetched);\n }\n }\n // we should not update pageviews\n else {\n void fetch(elements);\n }\n\n return controller.abort.bind(controller);\n};\n","import { useUserInfo } from '../composables';\nimport { fetchRecentComment, getRoot } from '../utils';\n\nimport type { WalineComment } from '../typings';\n\nexport interface WalineRecentCommentsOptions {\n /**\n * Waline 服务端地址\n *\n * Waline serverURL\n */\n serverURL: string;\n\n /**\n * 获取最新评论的数量\n *\n * fetch number of latest comments\n */\n count: number;\n\n /**\n * 需要挂载的元素\n *\n * Element to be mounted\n */\n el?: string | HTMLElement;\n}\n\nexport interface WalineRecentCommentsResult {\n /**\n * 评论数据\n *\n * Comment Data\n */\n comments: WalineComment[];\n\n /**\n * 取消挂载挂件\n *\n * Umount widget\n */\n destroy: () => void;\n}\n\nexport const RecentComments = ({\n el,\n serverURL,\n count,\n}: WalineRecentCommentsOptions): Promise<WalineRecentCommentsResult> => {\n const userInfo = useUserInfo();\n const root = getRoot(el);\n const controller = new AbortController();\n\n return fetchRecentComment({\n serverURL,\n count,\n signal: controller.signal,\n token: userInfo.value?.token,\n }).then((comments) => {\n if (root && comments.length) {\n root.innerHTML = `<ul class=\"wl-recent-list\">${comments\n .map(\n (comment) =>\n `<li class=\"wl-recent-item\"><a href=\"${comment.url}\">${comment.nick}</a>:${comment.comment}</li>`\n )\n .join('')}</ul>`;\n\n return {\n comments,\n destroy: (): void => {\n controller.abort();\n root.innerHTML = '';\n },\n };\n }\n\n return {\n comments,\n destroy: (): void => controller.abort(),\n };\n });\n};\n","import { createApp, h, reactive, watchEffect } from 'vue';\n\nimport Waline from './components/Waline.vue';\nimport { commentCount } from './comment';\nimport { pageviewCount } from './pageview';\nimport { getRoot } from './utils';\n\nimport type { WalineInitOptions } from './typings';\n\nexport interface WalineInstance {\n /**\n * Waline 被挂载到的元素\n *\n * @description 当通过 `el: null` 初始化,值为 `null`\n *\n * Element where Waline is mounted\n *\n * @description when initialized with `el: null`, it will be `null`\n */\n el: HTMLElement | null;\n\n /**\n * 更新 Waline 实例\n *\n * @description 只要不设置`path` 选项,更新时它就会被重置为 `windows.location.pathname`\n *\n * Update Waline instance\n *\n * @description when not setting `path` option, it will be reset to `window.location.pathname`\n */\n update: (newOptions: Partial<Omit<WalineInitOptions, 'el'>>) => void;\n\n /**\n * 取消挂载并摧毁 Waline 实例\n *\n * Unmount and destroy Waline instance\n */\n destroy: () => void;\n}\n\nexport const init = ({\n el = '#waline',\n path = window.location.pathname,\n comment = false,\n pageview = false,\n ...initProps\n}: WalineInitOptions): WalineInstance | null => {\n // check el element\n const root = el ? getRoot(el) : null;\n\n // check root\n if (el && !root) throw new Error(`Option 'el' do not match any domElement!`);\n\n // check serverURL\n if (!initProps.serverURL) throw new Error(\"Option 'serverURL' is missing!\");\n\n const props = reactive({ ...initProps });\n const state = reactive({ comment, pageview, path });\n\n const updateCommentCount = (): void => {\n if (state.comment)\n commentCount({\n serverURL: props.serverURL,\n path: state.path,\n selector: typeof state.comment === 'string' ? state.comment : undefined,\n });\n };\n\n const updatePageviewCount = (): void => {\n if (state.pageview)\n pageviewCount({\n serverURL: props.serverURL,\n path: state.path,\n selector:\n typeof state.pageview === 'string' ? state.pageview : undefined,\n });\n };\n\n const app = root\n ? createApp(() => h(Waline, { path: state.path, ...props }))\n : null;\n\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n if (app) app.mount(root!);\n\n updateCommentCount();\n updatePageviewCount();\n\n const stopComment = watchEffect(updateCommentCount);\n const stopPageview = watchEffect(updatePageviewCount);\n\n return {\n el: root,\n update: ({\n comment,\n pageview,\n path = window.location.pathname,\n ...newProps\n }: Partial<Omit<WalineInitOptions, 'el'>>): void => {\n Object.entries(newProps).forEach(([key, value]) => {\n // eslint-disable-next-line @typescript-eslint/ban-ts-comment\n // @ts-ignore\n // eslint-disable-next-line\n props[key] = value;\n });\n\n state.path = path;\n if (comment !== undefined) state.comment = comment;\n if (pageview !== undefined) state.pageview = pageview;\n },\n destroy: (): void => {\n app?.unmount();\n stopComment();\n stopPageview();\n },\n };\n};\n","declare const VERSION: string;\n\nexport const version = VERSION;\n"],"names":["availableMeta","getMeta","meta","filter","item","includes","defaultUploadImage","file","Promise","resolve","reject","reader","FileReader","readAsDataURL","onload","_a","result","toString","onerror","defaultTexRenderer","blockMode","localeKeys","generateLocale","locale","Object","fromEntries","map","index","en","jp","zhCN","zhTW","ptBR","ru","locales","zh","tryOnScopeDispose","fn","getCurrentScope","onScopeDispose","isClient","window","noop","bypassFilter","invoke","__getOwnPropSymbols$5","getOwnPropertySymbols","__hasOwnProp$5","prototype","hasOwnProperty","__propIsEnum$5","propertyIsEnumerable","watchWithFilter","source","cb","options","eventFilter","watchOptions","exclude","target","prop","call","indexOf","__objRest$5","watch","args","apply","this","thisArg","__defProp$1","defineProperty","__defProps$1","defineProperties","__getOwnPropDescs$1","getOwnPropertyDescriptors","__getOwnPropSymbols$1","__hasOwnProp$1","__propIsEnum$1","__defNormalProp$1","obj","key","value","enumerable","configurable","writable","watchPausable","__objRest$1","pause","resume","isActive","extendFilter","ref","pausableFilter","stop","a","b","__spreadValues$1","defaultWindow","useEventListener","event","listener","cleanup","stopWatch","elRef","plain","unref","$el","unrefElement","el","addEventListener","removeEventListener","immediate","flush","document","navigator","location","_global","globalThis","global","self","globalKey","handlers","StorageSerializers","boolean","read","v","write","String","object","JSON","parse","stringify","number","Number","parseFloat","any","string","Map","Array","from","entries","set","Set","date","Date","toISOString","useStorage","initialValue","storage","deep","listenToStorageChanges","writeDefaults","shallow","onError","e","console","error","data","shallowRef","fallback","getSSRHandler","_a2","localStorage","rawInit","type","isArray","isNaN","guessSerializerType","serializer","pauseWatch","resumeWatch","pausableWatch","removeItem","setItem","update","rawValue","newValue","getItem","_b","__defProp$5","__defNormalProp$5","useNow","controls","exposeControls","interval","now","rafId","loop","requestAnimationFrame","cancelAnimationFrame","useRafFn","immediateCallback","timer","clean","clearInterval","setInterval","isRef","useIntervalFn","__spreadValues$5","platform","test","decodePath","path","decodeURI","err","removeEndingSplash","content","replace","isLinkHttp","link","getServerURL","serverURL","getWordLimit","wordLimit","style","padWithZeros","vNumber","width","numAsString","length","fetchEmoji","emojiStore","Boolean","info","fetch","then","resp","json","emojiInfo","folder","getLink","name","prefix","errorHandler","message","errorCheck","errno","TypeError","errmsg","fetchPageviews","paths","signal","encodeURIComponent","join","counts","updatePageviews","method","headers","body","getRoot","HTMLElement","querySelector","isImage","getImagefromDataTransfer","items","image","find","getAsFile","inlineMathStart","inlineMathReg","blockMathReg","parseEmoji","text","emojiMap","placeholder","parseMarkdown","highlighter","texRenderer","marked","setOptions","highlight","undefined","breaks","smartLists","smartypants","extensions","level","tokenizer","src","cap","exec","raw","start","idx","search","markedTexExtensions","use","getQuery","element","dataset","getAttribute","useTimeAgo","computed","time","timepassed","getTime","days","Math","floor","leave1","hours","leave2","minutes","leave3","round","seconds","vDay","getDate","vMonth","getMonth","getFullYear","dateFormat","useUserInfo","commentCount","pathname","selector","controller","AbortController","elements","querySelectorAll","userInfo","token","Authorization","fetchCommentCount","forEach","innerText","catch","abort","bind","LoadingIcon","size","h","height","viewBox","preserveAspectRatio","cx","cy","fill","stroke","strokeWidth","r","attributeName","repeatCount","dur","values","keyTimes","script$2","defineComponent","components","CloseIcon","class","d","EmojiIcon","ImageIcon","MarkdownIcon","ariaHidden","PreviewIcon","props","rootId","default","replyId","replyUser","emits","setup","emit","config","inject","editor","userMeta","nick","mail","inputRefs","editorRef","imageUploadRef","emojiButtonRef","emojiPopupRef","emoji","tabs","emojiTabIndex","showEmoji","showPreview","previewText","wordNumber","isWordNumberLegal","isSubmitting","isLogin","canUploadImage","imageUploader","insert","textArea","startPosition","selectionStart","endPosition","selectionEnd","scrollTop","substring","focus","uploadImage","uploadText","uploading","url","submitComment","lang","login","requiredMeta","comment","ua","userAgent","display_name","email","alert","nickError","_c","mailError","_d","anonymous","wordHint","pid","rid","at","postComment","_e","popupHandler","contains","limit","onMounted","match","getWords","reduce","accumulator","word","trim","split","getChinese","getWordNumber","autosize","destroy","emojiConfig","getEmojis","emojis","all","emojiInfos","icon","push","onUnmounted","onChange","inputElement","files","onDrop","dataTransfer","preventDefault","onKeyDown","ctrlKey","metaKey","onPaste","clipboardData","onLogin","left","innerWidth","top","innerHeight","handler","open","postMessage","receiver","close","remember","sessionStorage","onLogout","onProfile","store","_hoisted_1","_hoisted_3","_hoisted_7","_hoisted_11","_createElementVNode","createElementVNode","_hoisted_14","_hoisted_15","href","title","rel","_hoisted_20","_hoisted_21","_openBlock","_createElementBlock","_ctx","_hoisted_2","logout","onClick","_createVNode","_component_CloseIcon","avatar","alt","_toDisplayString","toDisplayString","createElementBlock","_normalizeClass","normalizeClass","_Fragment","_renderList","renderList","kind","for","optional","id","$event","_vModelDynamic","onKeydown","_withDirectives","_hoisted_12","preview","innerHTML","_hoisted_16","_component_MarkdownIcon","actived","_cache","_component_EmojiIcon","accept","_component_ImageIcon","_component_PreviewIcon","_createTextVNode","createTextVNode","_hoisted_22","textContent","disabled","_createBlock","createBlock","_component_LoadingIcon","submit","display","_hoisted_27","Fragment","loading","referrerPolicy","_hoisted_30","active","cancelReply","$emit","script$1","required","reply","CommentBox","ReplyIcon","VerifiedIcon","insertedAt","isReplyingCurrent","objectId","_hoisted_4","_hoisted_5","_component_VerifiedIcon","admin","sticky","_component_ReplyIcon","browser","os","_component_CommentBox","onSubmit","onCancelReply","_hoisted_17","children","child","_component_CommentCard","onReply","script","CommentCard","dark","pageSize","Function","copyright","more","hanabi","getConfig","status","count","page","totalPages","darkmodeStyle","getDarkStyle","fetchComment","pageNumber","fetchCommentList","refresh","provide","createElement","appendChild","watchEffect","onBeforeUnmount","i18n","loadMore","repliedComment","unshift","version","_hoisted_9","_createCommentVNode","sofa","_hoisted_13","renderVisitorCount","countElements","pageviewCount","query","normalElements","elementsNeedstoBeFetched","root","fetchRecentComment","comments","pageview","initProps","Error","reactive","state","updateCommentCount","updatePageviewCount","app","createApp","Waline","mount","stopComment","stopPageview","newProps","unmount"],"mappings":"iPAEA,MAAMA,EAA8B,CAAC,OAAQ,OAAQ,QAExCC,EAAWC,GACtBA,EAAKC,QAAQC,GAASJ,EAAcK,SAASD,KAIlCE,EAAsBC,GACjC,IAAIC,SAAQ,CAACC,EAASC,KACpB,MAAMC,EAAS,IAAIC,WACnBD,EAAOE,cAAcN,GACrBI,EAAOG,OAAS,KAAY,IAAAC,EAAA,OAAAN,WAAQM,EAAAJ,EAAOK,6BAAQC,aAAc,KACjEN,EAAOO,QAAUR,KAGRS,EAAsBC,IACnB,IAAdA,EACI,wDACA,8DClBAC,EAAa,CACjB,OACA,YACA,OACA,YACA,OACA,WACA,cACA,OACA,SACA,QACA,cACA,UACA,UACA,OACA,UACA,QACA,cACA,UACA,UACA,QACA,OACA,MACA,YACA,QACA,SACA,QACA,SACA,OACA,WACA,aAGWC,EAAkBC,GAC7BC,OAAOC,YACLF,EAAOG,KAAI,CAACtB,EAAMuB,IAAU,CAACN,EAAWM,GAAQvB,MCnCpD,IAAAwB,EAAeN,EAAe,CAC5B,WACA,wCACA,SACA,qCACA,UACA,WACA,kBACA,kBACA,SACA,QACA,eACA,WACA,UACA,eACA,UACA,QACA,eACA,cACA,cACA,YACA,WACA,WACA,YACA,QACA,SACA,QACA,SACA,QACA,2EACA,cC9BFO,EAAeP,EAAe,CAC5B,SACA,yBACA,UACA,mBACA,MACA,QACA,UACA,aACA,OACA,OACA,QACA,OACA,KACA,UACA,QACA,MACA,YACA,KACA,KACA,MACA,KACA,OACA,SACA,SACA,QACA,MACA,SACA,MACA,gDACA,OC9BFQ,EAAeR,EAAe,CAC5B,KACA,aACA,KACA,aACA,KACA,KACA,OACA,SACA,KACA,KACA,OACA,KACA,KACA,UACA,KACA,KACA,OACA,KACA,MACA,MACA,KACA,KACA,OACA,KACA,KACA,KACA,KACA,IACA,+BACA,OC9BFS,EAAeT,EAAe,CAC5B,KACA,KACA,KACA,KACA,aACA,aACA,OACA,SACA,KACA,KACA,OACA,KACA,KACA,UACA,KACA,KACA,OACA,KACA,MACA,MACA,KACA,KACA,OACA,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"}
|
|
1
|
+
{"version":3,"file":"shim.js","sources":["../src/config/default.ts","../src/config/i18n/generate.ts","../src/config/i18n/en.ts","../src/config/i18n/jp.ts","../src/config/i18n/zh-CN.ts","../src/config/i18n/zh-TW.ts","../src/config/i18n/pt-BR.ts","../src/config/i18n/ru.ts","../src/config/i18n/index.ts","../../../node_modules/@vueuse/shared/index.mjs","../../../node_modules/@vueuse/core/index.mjs","../src/composables/inputs.ts","../src/utils/path.ts","../src/utils/config.ts","../src/utils/darkmode.ts","../src/utils/date.ts","../src/utils/emoji.ts","../src/utils/error.ts","../src/utils/fetch.ts","../src/utils/getRoot.ts","../src/utils/image.ts","../src/utils/markedMathExtension.ts","../src/utils/markdown.ts","../src/utils/query.ts","../src/composables/timeAgo.ts","../src/composables/userInfo.ts","../src/comment.ts","../src/components/Icons.ts","../src/components/CommentBox.vue","../src/utils/wordCount.ts","../src/components/CommentBox.vue?vue&type=template&id=969569c8&lang.js","../src/components/CommentCard.vue","../src/components/CommentCard.vue?vue&type=template&id=5dd9348f&lang.js","../src/components/Waline.vue","../src/components/Waline.vue?vue&type=template&id=222c3e24&lang.js","../src/pageview.ts","../src/widgets/recentComments.ts","../src/init.ts","../src/version.ts"],"sourcesContent":["import type { WalineMeta } from '../typings';\n\nconst availableMeta: WalineMeta[] = ['nick', 'mail', 'link'];\n\nexport const getMeta = (meta: WalineMeta[]): WalineMeta[] =>\n meta.filter((item) => availableMeta.includes(item));\n\nexport const defaultLang = 'zh-CN';\n\nexport const defaultUploadImage = (file: File): Promise<string> =>\n new Promise((resolve, reject) => {\n const reader = new FileReader();\n reader.readAsDataURL(file);\n reader.onload = (): void => resolve(reader.result?.toString() || '');\n reader.onerror = reject;\n });\n\nexport const defaultTexRenderer = (blockMode: boolean): string =>\n blockMode === true\n ? '<p class=\"wl-tex\">Tex is not available in preview</p>'\n : '<span class=\"wl-tex\">Tex is not available in preview</span>';\n","import type { WalineLocale } from '../../typings';\n\nconst localeKeys = [\n 'nick',\n 'nickError',\n 'mail',\n 'mailError',\n 'link',\n 'optional',\n 'placeholder',\n 'sofa',\n 'submit',\n 'reply',\n 'cancelReply',\n 'comment',\n 'refresh',\n 'more',\n 'preview',\n 'emoji',\n 'uploadImage',\n 'seconds',\n 'minutes',\n 'hours',\n 'days',\n 'now',\n 'uploading',\n 'login',\n 'logout',\n 'admin',\n 'sticky',\n 'word',\n 'wordHint',\n 'anonymous',\n];\n\nexport const generateLocale = (locale: string[]): WalineLocale =>\n Object.fromEntries(\n locale.map((item, index) => [localeKeys[index], item])\n ) as unknown as WalineLocale;\n","import { generateLocale } from './generate';\n\nexport default generateLocale([\n 'NickName',\n 'NickName cannot be less than 3 bytes.',\n 'E-Mail',\n 'Please confirm your email address.',\n 'Website',\n 'Optional',\n 'Comment here...',\n 'No comment yet.',\n 'Submit',\n 'Reply',\n 'Cancel reply',\n 'Comments',\n 'Refresh',\n 'Load More...',\n 'Preview',\n 'Emoji',\n 'Upload Image',\n 'seconds ago',\n 'minutes ago',\n 'hours ago',\n 'days ago',\n 'just now',\n 'Uploading',\n 'Login',\n 'logout',\n 'Admin',\n 'Sticky',\n 'Words',\n 'Please input comments between $0 and $1 words!\\n Current word number: $2',\n 'Anonymous',\n]);\n","import { generateLocale } from './generate';\n\nexport default generateLocale([\n 'ニックネーム',\n '3バイト以上のニックネームをご入力ください.',\n 'メールアドレス',\n 'メールアドレスをご確認ください.',\n 'サイト',\n 'オプション',\n 'ここにコメント',\n 'コメントしましょう~',\n '提出する',\n '返信する',\n 'キャンセル',\n 'コメント',\n '更新',\n 'さらに読み込む',\n 'プレビュー',\n '絵文字',\n '画像をアップロード',\n '秒前',\n '分前',\n '時間前',\n '日前',\n 'たっだ今',\n 'アップロード',\n 'ログインする',\n 'ログアウト',\n '管理者',\n 'トップに置く',\n 'ワード',\n 'コメントは $0 から $1 ワードの間でなければなりません!\\n 現在の単語番号: $2',\n '匿名',\n]);\n","import { generateLocale } from './generate';\n\nexport default generateLocale([\n '昵称',\n '昵称不能少于3个字符',\n '邮箱',\n '请填写正确的邮件地址',\n '网址',\n '可选',\n '欢迎评论',\n '来发评论吧~',\n '提交',\n '回复',\n '取消回复',\n '评论',\n '刷新',\n '加载更多...',\n '预览',\n '表情',\n '上传图片',\n '秒前',\n '分钟前',\n '小时前',\n '天前',\n '刚刚',\n '正在上传',\n '登录',\n '退出',\n '博主',\n '置顶',\n '字',\n '评论字数应在 $0 到 $1 字之间!\\n当前字数:$2',\n '匿名',\n]);\n","import { generateLocale } from './generate';\n\nexport default generateLocale([\n '暱稱',\n '郵箱',\n '網址',\n '可選',\n '暱稱不能少於3個字元',\n '請填寫正確的郵件地址',\n '歡迎評論',\n '來發評論吧~',\n '提交',\n '回覆',\n '取消回覆',\n '評論',\n '刷新',\n '載入更多...',\n '預覽',\n '表情',\n '上傳圖片',\n '秒前',\n '分鐘前',\n '小時前',\n '天前',\n '剛剛',\n '正在上傳',\n '登錄',\n '退出',\n '博主',\n '置頂',\n '字',\n '評論字數應在 $0 到 $1 字之間!\\n當前字數:$2',\n '匿名',\n]);\n","import { generateLocale } from './generate';\n\nexport default generateLocale([\n 'Apelido',\n 'Apelido não pode ser menor que 3 bytes.',\n 'E-Mail',\n 'Por favor, confirme seu endereço de e-mail.',\n 'Website',\n 'Opcional',\n 'Comente aqui...',\n 'Nenhum comentário, ainda.',\n 'Enviar',\n 'Responder',\n 'Cancelar resposta',\n 'Comentários',\n 'Refrescar',\n 'Carregar Mais...',\n 'Visualizar',\n 'Emoji',\n 'Enviar Imagem',\n 'segundos atrás',\n 'minutos atrás',\n 'horas atrás',\n 'dias atrás',\n 'agora mesmo',\n 'Enviando',\n 'Entrar',\n 'Sair',\n 'Admin',\n 'Sticky',\n 'Palavras',\n 'Favor enviar comentário com $0 a $1 palavras!\\n Número de palavras atuais: $2',\n 'Anônimo',\n]);\n","import { generateLocale } from './generate';\n\nexport default generateLocale([\n 'Псевдоним',\n 'Никнейм не может быть меньше 3 байт.',\n 'Эл. адрес',\n 'Пожалуйста, подтвердите адрес вашей электронной почты.',\n 'Веб-сайт',\n 'Необязательный',\n 'Комментарий здесь...',\n 'Пока нет комментариев.',\n 'Отправить',\n 'Отвечать',\n 'Отменить ответ',\n 'Комментарии',\n 'Обновить',\n 'Загрузи больше...',\n 'Превью',\n 'эмодзи',\n 'Загрузить изображение',\n 'секунд назад',\n 'несколько минут назад',\n 'несколько часов назад',\n 'дней назад',\n 'прямо сейчас',\n 'Загрузка',\n 'Авторизоваться',\n 'Выход из системы',\n 'Админ',\n 'Липкий',\n 'Слова',\n 'Пожалуйста, введите комментарии от $0 до $1 слов!\\nНомер текущего слова: $2',\n 'Анонимный',\n]);\n","/* eslint-disable @typescript-eslint/naming-convention */\nimport en from './en';\nimport jp from './jp';\nimport zhCN from './zh-CN';\nimport zhTW from './zh-TW';\nimport ptBR from './pt-BR';\nimport ru from './ru';\n\nimport type { WalineLocale } from '../../typings';\n\nexport type Locales = Record<string, WalineLocale>;\n\nexport const locales: Locales = {\n zh: zhCN,\n 'zh-cn': zhCN,\n 'zh-CN': zhCN,\n 'zh-tw': zhTW,\n 'zh-TW': zhTW,\n en: en,\n 'en-US': en,\n 'en-us': en,\n jp: jp,\n 'jp-jp': jp,\n 'jp-JP': jp,\n 'pt-br': ptBR,\n 'pt-BR': ptBR,\n ru: ru,\n 'ru-ru': ru,\n 'ru-RU': ru,\n};\n","import { shallowRef, watchEffect, readonly, ref, watch, customRef, effectScope, provide, inject, getCurrentScope, onScopeDispose, isVue3, isRef, unref, computed, reactive, toRefs as toRefs$1, toRef, isVue2, set as set$1, getCurrentInstance, onBeforeMount, nextTick, onBeforeUnmount, onMounted, onUnmounted } from 'vue-demi';\n\nvar __defProp$8 = Object.defineProperty;\nvar __defProps$5 = Object.defineProperties;\nvar __getOwnPropDescs$5 = Object.getOwnPropertyDescriptors;\nvar __getOwnPropSymbols$a = Object.getOwnPropertySymbols;\nvar __hasOwnProp$a = Object.prototype.hasOwnProperty;\nvar __propIsEnum$a = Object.prototype.propertyIsEnumerable;\nvar __defNormalProp$8 = (obj, key, value) => key in obj ? __defProp$8(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;\nvar __spreadValues$8 = (a, b) => {\n for (var prop in b || (b = {}))\n if (__hasOwnProp$a.call(b, prop))\n __defNormalProp$8(a, prop, b[prop]);\n if (__getOwnPropSymbols$a)\n for (var prop of __getOwnPropSymbols$a(b)) {\n if (__propIsEnum$a.call(b, prop))\n __defNormalProp$8(a, prop, b[prop]);\n }\n return a;\n};\nvar __spreadProps$5 = (a, b) => __defProps$5(a, __getOwnPropDescs$5(b));\nfunction computedEager(fn, options) {\n var _a;\n const result = shallowRef();\n watchEffect(() => {\n result.value = fn();\n }, __spreadProps$5(__spreadValues$8({}, 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 watch(source, () => {\n dirty.value = true;\n trigger();\n }, { flush: \"sync\" });\n return customRef((_track, _trigger) => {\n track = _track;\n trigger = _trigger;\n return {\n get() {\n if (dirty.value) {\n v = fn();\n dirty.value = false;\n }\n track();\n return v;\n },\n set() {\n }\n };\n });\n}\n\nfunction createEventHook() {\n const fns = [];\n const off = (fn) => {\n const index = fns.indexOf(fn);\n if (index !== -1)\n fns.splice(index, 1);\n };\n const on = (fn) => {\n fns.push(fn);\n return {\n off: () => off(fn)\n };\n };\n const trigger = (param) => {\n fns.forEach((fn) => fn(param));\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 () => {\n if (!initialized) {\n state = scope.run(stateFactory);\n initialized = true;\n }\n return state;\n };\n}\n\nfunction createInjectionState(composable) {\n const key = Symbol(\"InjectionState\");\n const useProvidingState = (...args) => {\n provide(key, composable(...args));\n };\n const useInjectedState = () => inject(key);\n return [useProvidingState, useInjectedState];\n}\n\nfunction tryOnScopeDispose(fn) {\n if (getCurrentScope()) {\n onScopeDispose(fn);\n return true;\n }\n return false;\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 (!state) {\n scope = effectScope(true);\n state = scope.run(() => composable(...args));\n }\n tryOnScopeDispose(dispose);\n return state;\n };\n}\n\nfunction __onlyVue3(name = \"this function\") {\n if (isVue3)\n return;\n throw new Error(`[VueUse] ${name} is only works on Vue 3.`);\n}\nconst directiveHooks = {\n mounted: isVue3 ? \"mounted\" : \"inserted\",\n updated: isVue3 ? \"updated\" : \"componentUpdated\",\n unmounted: isVue3 ? \"unmounted\" : \"unbind\"\n};\n\nfunction extendRef(ref, extend, { enumerable = false, unwrap = true } = {}) {\n __onlyVue3();\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 logicAnd(...args) {\n return computed(() => args.every((i) => unref(i)));\n}\n\nfunction logicNot(v) {\n return computed(() => !unref(v));\n}\n\nfunction logicOr(...args) {\n return computed(() => args.some((i) => unref(i)));\n}\n\nvar __defProp$7 = Object.defineProperty;\nvar __getOwnPropSymbols$9 = Object.getOwnPropertySymbols;\nvar __hasOwnProp$9 = Object.prototype.hasOwnProperty;\nvar __propIsEnum$9 = Object.prototype.propertyIsEnumerable;\nvar __defNormalProp$7 = (obj, key, value) => key in obj ? __defProp$7(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;\nvar __spreadValues$7 = (a, b) => {\n for (var prop in b || (b = {}))\n if (__hasOwnProp$9.call(b, prop))\n __defNormalProp$7(a, prop, b[prop]);\n if (__getOwnPropSymbols$9)\n for (var prop of __getOwnPropSymbols$9(b)) {\n if (__propIsEnum$9.call(b, prop))\n __defNormalProp$7(a, prop, b[prop]);\n }\n return a;\n};\nfunction makeDestructurable(obj, arr) {\n if (typeof Symbol !== \"undefined\") {\n const clone = __spreadValues$7({}, 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 reactify(fn) {\n return function(...args) {\n return computed(() => fn.apply(this, args.map((i) => unref(i))));\n };\n}\n\nfunction reactifyObject(obj, optionsOrKeys = {}) {\n let keys = [];\n if (Array.isArray(optionsOrKeys)) {\n keys = optionsOrKeys;\n } else {\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(keys.map((key) => {\n const value = obj[key];\n return [\n key,\n typeof value === \"function\" ? reactify(value.bind(obj)) : value\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 return reactiveComputed(() => Object.fromEntries(Object.entries(toRefs$1(obj)).filter((e) => !keys.includes(e[0]))));\n}\n\nfunction reactivePick(obj, ...keys) {\n return reactive(Object.fromEntries(keys.map((k) => [k, toRef(obj, k)])));\n}\n\nfunction refAutoReset(defaultValue, afterMs = 1e4) {\n return customRef((track, trigger) => {\n let value = defaultValue;\n let timer;\n const resetAfter = () => setTimeout(() => {\n value = defaultValue;\n trigger();\n }, unref(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\nconst isClient = typeof window !== \"undefined\";\nconst isDef = (val) => typeof val !== \"undefined\";\nconst assert = (condition, ...infos) => {\n if (!condition)\n console.warn(...infos);\n};\nconst toString = Object.prototype.toString;\nconst isBoolean = (val) => typeof val === \"boolean\";\nconst isFunction = (val) => typeof val === \"function\";\nconst isNumber = (val) => typeof val === \"number\";\nconst isString = (val) => typeof val === \"string\";\nconst isObject = (val) => toString.call(val) === \"[object Object]\";\nconst isWindow = (val) => typeof window !== \"undefined\" && toString.call(val) === \"[object Window]\";\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};\n\nfunction createFilterWrapper(filter, fn) {\n function wrapper(...args) {\n filter(() => fn.apply(this, args), { fn, thisArg: this, args });\n }\n return wrapper;\n}\nconst bypassFilter = (invoke) => {\n return invoke();\n};\nfunction debounceFilter(ms, options = {}) {\n let timer;\n let maxTimer;\n const filter = (invoke) => {\n const duration = unref(ms);\n const maxDuration = unref(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 invoke();\n }\n if (maxDuration && !maxTimer) {\n maxTimer = setTimeout(() => {\n if (timer)\n clearTimeout(timer);\n maxTimer = null;\n invoke();\n }, maxDuration);\n }\n timer = setTimeout(() => {\n if (maxTimer)\n clearTimeout(maxTimer);\n maxTimer = null;\n invoke();\n }, duration);\n };\n return filter;\n}\nfunction throttleFilter(ms, trailing = true, leading = true) {\n let lastExec = 0;\n let timer;\n let preventLeading = !leading;\n const clear = () => {\n if (timer) {\n clearTimeout(timer);\n timer = void 0;\n }\n };\n const filter = (invoke) => {\n const duration = unref(ms);\n const elapsed = Date.now() - lastExec;\n clear();\n if (duration <= 0) {\n lastExec = Date.now();\n return invoke();\n }\n if (elapsed > duration) {\n lastExec = Date.now();\n if (preventLeading)\n preventLeading = false;\n else\n invoke();\n }\n if (trailing) {\n timer = setTimeout(() => {\n lastExec = Date.now();\n if (!leading)\n preventLeading = true;\n clear();\n invoke();\n }, duration);\n }\n if (!leading && !timer)\n timer = setTimeout(() => preventLeading = true, duration);\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, pause, resume, eventFilter };\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(/^-?[0-9]+\\.?[0-9]*/)) == null ? void 0 : _a[0]) || \"\";\n const unit = target.slice(value.length);\n const result = 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}\n\nfunction useDebounceFn(fn, ms = 200, options = {}) {\n return createFilterWrapper(debounceFilter(ms, options), fn);\n}\n\nfunction refDebounced(value, ms = 200, options = {}) {\n if (ms <= 0)\n return value;\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 = true, leading = true) {\n return createFilterWrapper(throttleFilter(ms, trailing, leading), fn);\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(ref, {\n get,\n set,\n untrackedGet,\n silentSet,\n peek,\n lay\n }, { enumerable: true });\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 if (isVue2) {\n set$1(...args);\n } else {\n const [target, key, value] = args;\n target[key] = value;\n }\n }\n}\n\nfunction syncRef(left, right, options = {}) {\n const {\n flush = \"sync\",\n deep = false,\n immediate = true,\n direction = \"both\"\n } = options;\n let stop1, stop2;\n if (direction === \"both\" || direction === \"ltr\") {\n stop1 = watch(left, (newValue) => right.value = newValue, { flush, deep, immediate });\n }\n if (direction === \"both\" || direction === \"rtl\") {\n stop2 = watch(right, (newValue) => left.value = newValue, { flush, deep, immediate });\n }\n return () => {\n stop1 == null ? void 0 : stop1();\n stop2 == null ? void 0 : stop2();\n };\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(source, (newValue) => targets.forEach((target) => target.value = newValue), { flush, deep, immediate });\n}\n\nvar __defProp$6 = Object.defineProperty;\nvar __defProps$4 = Object.defineProperties;\nvar __getOwnPropDescs$4 = Object.getOwnPropertyDescriptors;\nvar __getOwnPropSymbols$8 = Object.getOwnPropertySymbols;\nvar __hasOwnProp$8 = Object.prototype.hasOwnProperty;\nvar __propIsEnum$8 = Object.prototype.propertyIsEnumerable;\nvar __defNormalProp$6 = (obj, key, value) => key in obj ? __defProp$6(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;\nvar __spreadValues$6 = (a, b) => {\n for (var prop in b || (b = {}))\n if (__hasOwnProp$8.call(b, prop))\n __defNormalProp$6(a, prop, b[prop]);\n if (__getOwnPropSymbols$8)\n for (var prop of __getOwnPropSymbols$8(b)) {\n if (__propIsEnum$8.call(b, prop))\n __defNormalProp$6(a, prop, b[prop]);\n }\n return a;\n};\nvar __spreadProps$4 = (a, b) => __defProps$4(a, __getOwnPropDescs$4(b));\nfunction toRefs(objectRef) {\n if (!isRef(objectRef))\n return toRefs$1(objectRef);\n const result = Array.isArray(objectRef.value) ? new Array(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 if (Array.isArray(objectRef.value)) {\n const copy = [...objectRef.value];\n copy[key] = v;\n objectRef.value = copy;\n } else {\n objectRef.value = __spreadProps$4(__spreadValues$6({}, objectRef.value), { [key]: v });\n }\n }\n }));\n }\n return result;\n}\n\nfunction tryOnBeforeMount(fn, sync = true) {\n if (getCurrentInstance())\n onBeforeMount(fn);\n else if (sync)\n fn();\n else\n nextTick(fn);\n}\n\nfunction tryOnBeforeUnmount(fn) {\n if (getCurrentInstance())\n onBeforeUnmount(fn);\n}\n\nfunction tryOnMounted(fn, sync = true) {\n if (getCurrentInstance())\n onMounted(fn);\n else if (sync)\n fn();\n else\n nextTick(fn);\n}\n\nfunction tryOnUnmounted(fn) {\n if (getCurrentInstance())\n onUnmounted(fn);\n}\n\nfunction until(r) {\n let 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(r, (v) => {\n if (condition(v) === !isNot) {\n stop == null ? void 0 : stop();\n resolve();\n }\n }, {\n flush,\n deep,\n immediate: true\n });\n });\n const promises = [watcher];\n if (timeout) {\n promises.push(promiseTimeout(timeout, throwOnTimeout).finally(() => {\n stop == null ? void 0 : stop();\n }));\n }\n return Promise.race(promises);\n }\n function toBe(value, options) {\n return toMatch((v) => v === unref(value), options);\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(unref(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(unref(r))) {\n const instance = {\n toMatch,\n toContains,\n changed,\n changedTimes,\n get not() {\n isNot = !isNot;\n return this;\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 isNot = !isNot;\n return this;\n }\n };\n return instance;\n }\n}\n\nfunction useCounter(initialValue = 0, options = {}) {\n const count = ref(initialValue);\n const {\n max = Infinity,\n min = -Infinity\n } = options;\n const inc = (delta = 1) => count.value = Math.min(max, count.value + delta);\n const dec = (delta = 1) => count.value = Math.max(min, count.value - delta);\n const get = () => count.value;\n const set = (val) => count.value = 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})[Tt\\s]*(\\d{1,2})?:?(\\d{1,2})?:?(\\d{1,2})?[.:]?(\\d+)?$/;\nconst REGEX_FORMAT = /\\[([^\\]]+)]|Y{1,4}|M{1,4}|D{1,2}|d{1,4}|H{1,2}|h{1,2}|a|A|m{1,2}|s{1,2}|Z{1,2}|SSS/g;\nconst formatDate = (date, formatStr) => {\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 matches = {\n YY: String(years).slice(-2),\n YYYY: years,\n M: month + 1,\n MM: `${month + 1}`.padStart(2, \"0\"),\n D: String(days),\n DD: `${days}`.padStart(2, \"0\"),\n H: String(hours),\n HH: `${hours}`.padStart(2, \"0\"),\n h: `${hours % 12 || 12}`.padStart(1, \"0\"),\n hh: `${hours % 12 || 12}`.padStart(2, \"0\"),\n m: String(minutes),\n mm: `${minutes}`.padStart(2, \"0\"),\n s: String(seconds),\n ss: `${seconds}`.padStart(2, \"0\"),\n SSS: `${milliseconds}`.padStart(3, \"0\"),\n d: day\n };\n return formatStr.replace(REGEX_FORMAT, (match, $1) => $1 || matches[match]);\n};\nconst normalizeDate = (date) => {\n if (date === null)\n return new Date(NaN);\n if (date === void 0)\n return 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\") {\n return computed(() => formatDate(normalizeDate(unref(date)), unref(formatStr)));\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 if (interval <= 0)\n return;\n isActive.value = true;\n if (immediateCallback)\n cb();\n clean();\n timer = setInterval(cb, unref(interval));\n }\n if (immediate && isClient)\n resume();\n if (isRef(interval)) {\n const stopWatch = watch(interval, () => {\n if (immediate && isClient)\n resume();\n });\n tryOnScopeDispose(stopWatch);\n }\n tryOnScopeDispose(pause);\n return {\n isActive,\n pause,\n resume\n };\n}\n\nvar __defProp$5 = Object.defineProperty;\nvar __getOwnPropSymbols$7 = Object.getOwnPropertySymbols;\nvar __hasOwnProp$7 = Object.prototype.hasOwnProperty;\nvar __propIsEnum$7 = Object.prototype.propertyIsEnumerable;\nvar __defNormalProp$5 = (obj, key, value) => key in obj ? __defProp$5(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;\nvar __spreadValues$5 = (a, b) => {\n for (var prop in b || (b = {}))\n if (__hasOwnProp$7.call(b, prop))\n __defNormalProp$5(a, prop, b[prop]);\n if (__getOwnPropSymbols$7)\n for (var prop of __getOwnPropSymbols$7(b)) {\n if (__propIsEnum$7.call(b, prop))\n __defNormalProp$5(a, prop, b[prop]);\n }\n return a;\n};\nfunction useInterval(interval = 1e3, options = {}) {\n const {\n controls: exposeControls = false,\n immediate = true\n } = options;\n const counter = ref(0);\n const controls = useIntervalFn(() => counter.value += 1, interval, { immediate });\n if (exposeControls) {\n return __spreadValues$5({\n counter\n }, controls);\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(source, () => ms.value = timestamp(), options);\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 }, unref(interval));\n }\n if (immediate) {\n isPending.value = true;\n if (isClient)\n start();\n }\n tryOnScopeDispose(stop);\n return {\n isPending,\n start,\n stop\n };\n}\n\nvar __defProp$4 = Object.defineProperty;\nvar __getOwnPropSymbols$6 = Object.getOwnPropertySymbols;\nvar __hasOwnProp$6 = Object.prototype.hasOwnProperty;\nvar __propIsEnum$6 = Object.prototype.propertyIsEnumerable;\nvar __defNormalProp$4 = (obj, key, value) => key in obj ? __defProp$4(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;\nvar __spreadValues$4 = (a, b) => {\n for (var prop in b || (b = {}))\n if (__hasOwnProp$6.call(b, prop))\n __defNormalProp$4(a, prop, b[prop]);\n if (__getOwnPropSymbols$6)\n for (var prop of __getOwnPropSymbols$6(b)) {\n if (__propIsEnum$6.call(b, prop))\n __defNormalProp$4(a, prop, b[prop]);\n }\n return a;\n};\nfunction useTimeout(interval = 1e3, options = {}) {\n const {\n controls: exposeControls = false\n } = options;\n const controls = useTimeoutFn(noop, interval, options);\n const ready = computed(() => !controls.isPending.value);\n if (exposeControls) {\n return __spreadValues$4({\n ready\n }, controls);\n } else {\n return ready;\n }\n}\n\nfunction useToggle(initialValue = false) {\n if (isRef(initialValue)) {\n return (value) => {\n initialValue.value = typeof value === \"boolean\" ? value : !initialValue.value;\n return initialValue.value;\n };\n } else {\n const boolean = ref(initialValue);\n const toggle = (value) => {\n boolean.value = typeof value === \"boolean\" ? value : !boolean.value;\n return boolean.value;\n };\n return [boolean, toggle];\n }\n}\n\nvar __getOwnPropSymbols$5 = Object.getOwnPropertySymbols;\nvar __hasOwnProp$5 = Object.prototype.hasOwnProperty;\nvar __propIsEnum$5 = Object.prototype.propertyIsEnumerable;\nvar __objRest$5 = (source, exclude) => {\n var target = {};\n for (var prop in source)\n if (__hasOwnProp$5.call(source, prop) && exclude.indexOf(prop) < 0)\n target[prop] = source[prop];\n if (source != null && __getOwnPropSymbols$5)\n for (var prop of __getOwnPropSymbols$5(source)) {\n if (exclude.indexOf(prop) < 0 && __propIsEnum$5.call(source, prop))\n target[prop] = source[prop];\n }\n return target;\n};\nfunction watchWithFilter(source, cb, options = {}) {\n const _a = options, {\n eventFilter = bypassFilter\n } = _a, watchOptions = __objRest$5(_a, [\n \"eventFilter\"\n ]);\n return watch(source, createFilterWrapper(eventFilter, cb), watchOptions);\n}\n\nvar __getOwnPropSymbols$4 = Object.getOwnPropertySymbols;\nvar __hasOwnProp$4 = Object.prototype.hasOwnProperty;\nvar __propIsEnum$4 = Object.prototype.propertyIsEnumerable;\nvar __objRest$4 = (source, exclude) => {\n var target = {};\n for (var prop in source)\n if (__hasOwnProp$4.call(source, prop) && exclude.indexOf(prop) < 0)\n target[prop] = source[prop];\n if (source != null && __getOwnPropSymbols$4)\n for (var prop of __getOwnPropSymbols$4(source)) {\n if (exclude.indexOf(prop) < 0 && __propIsEnum$4.call(source, prop))\n target[prop] = source[prop];\n }\n return target;\n};\nfunction watchAtMost(source, cb, options) {\n const _a = options, {\n count\n } = _a, watchOptions = __objRest$4(_a, [\n \"count\"\n ]);\n const current = ref(0);\n const stop = watchWithFilter(source, (...args) => {\n current.value += 1;\n if (current.value >= unref(count))\n nextTick(() => stop());\n cb(...args);\n }, watchOptions);\n return { count: current, stop };\n}\n\nvar __defProp$3 = Object.defineProperty;\nvar __defProps$3 = Object.defineProperties;\nvar __getOwnPropDescs$3 = Object.getOwnPropertyDescriptors;\nvar __getOwnPropSymbols$3 = Object.getOwnPropertySymbols;\nvar __hasOwnProp$3 = Object.prototype.hasOwnProperty;\nvar __propIsEnum$3 = Object.prototype.propertyIsEnumerable;\nvar __defNormalProp$3 = (obj, key, value) => key in obj ? __defProp$3(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;\nvar __spreadValues$3 = (a, b) => {\n for (var prop in b || (b = {}))\n if (__hasOwnProp$3.call(b, prop))\n __defNormalProp$3(a, prop, b[prop]);\n if (__getOwnPropSymbols$3)\n for (var prop of __getOwnPropSymbols$3(b)) {\n if (__propIsEnum$3.call(b, prop))\n __defNormalProp$3(a, prop, b[prop]);\n }\n return a;\n};\nvar __spreadProps$3 = (a, b) => __defProps$3(a, __getOwnPropDescs$3(b));\nvar __objRest$3 = (source, exclude) => {\n var target = {};\n for (var prop in source)\n if (__hasOwnProp$3.call(source, prop) && exclude.indexOf(prop) < 0)\n target[prop] = source[prop];\n if (source != null && __getOwnPropSymbols$3)\n for (var prop of __getOwnPropSymbols$3(source)) {\n if (exclude.indexOf(prop) < 0 && __propIsEnum$3.call(source, prop))\n target[prop] = source[prop];\n }\n return target;\n};\nfunction watchDebounced(source, cb, options = {}) {\n const _a = options, {\n debounce = 0\n } = _a, watchOptions = __objRest$3(_a, [\n \"debounce\"\n ]);\n return watchWithFilter(source, cb, __spreadProps$3(__spreadValues$3({}, watchOptions), {\n eventFilter: debounceFilter(debounce)\n }));\n}\n\nvar __defProp$2 = Object.defineProperty;\nvar __defProps$2 = Object.defineProperties;\nvar __getOwnPropDescs$2 = Object.getOwnPropertyDescriptors;\nvar __getOwnPropSymbols$2 = Object.getOwnPropertySymbols;\nvar __hasOwnProp$2 = Object.prototype.hasOwnProperty;\nvar __propIsEnum$2 = Object.prototype.propertyIsEnumerable;\nvar __defNormalProp$2 = (obj, key, value) => key in obj ? __defProp$2(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;\nvar __spreadValues$2 = (a, b) => {\n for (var prop in b || (b = {}))\n if (__hasOwnProp$2.call(b, prop))\n __defNormalProp$2(a, prop, b[prop]);\n if (__getOwnPropSymbols$2)\n for (var prop of __getOwnPropSymbols$2(b)) {\n if (__propIsEnum$2.call(b, prop))\n __defNormalProp$2(a, prop, b[prop]);\n }\n return a;\n};\nvar __spreadProps$2 = (a, b) => __defProps$2(a, __getOwnPropDescs$2(b));\nvar __objRest$2 = (source, exclude) => {\n var target = {};\n for (var prop in source)\n if (__hasOwnProp$2.call(source, prop) && exclude.indexOf(prop) < 0)\n target[prop] = source[prop];\n if (source != null && __getOwnPropSymbols$2)\n for (var prop of __getOwnPropSymbols$2(source)) {\n if (exclude.indexOf(prop) < 0 && __propIsEnum$2.call(source, prop))\n target[prop] = source[prop];\n }\n return target;\n};\nfunction watchIgnorable(source, cb, options = {}) {\n const _a = options, {\n eventFilter = bypassFilter\n } = _a, watchOptions = __objRest$2(_a, [\n \"eventFilter\"\n ]);\n const filteredCb = createFilterWrapper(eventFilter, cb);\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(source, (...args) => {\n if (!ignore.value)\n filteredCb(...args);\n }, watchOptions);\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(watch(source, () => {\n syncCounter.value++;\n }, __spreadProps$2(__spreadValues$2({}, watchOptions), { flush: \"sync\" })));\n ignoreUpdates = (updater) => {\n const syncCounterPrev = syncCounter.value;\n updater();\n ignoreCounter.value += syncCounter.value - syncCounterPrev;\n };\n disposables.push(watch(source, (...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 }, watchOptions));\n stop = () => {\n disposables.forEach((fn) => fn());\n };\n }\n return { stop, ignoreUpdates, ignorePrevAsyncUpdates };\n}\n\nfunction watchOnce(source, cb, options) {\n const stop = watch(source, (...args) => {\n nextTick(() => stop());\n return cb(...args);\n }, options);\n}\n\nvar __defProp$1 = Object.defineProperty;\nvar __defProps$1 = Object.defineProperties;\nvar __getOwnPropDescs$1 = Object.getOwnPropertyDescriptors;\nvar __getOwnPropSymbols$1 = Object.getOwnPropertySymbols;\nvar __hasOwnProp$1 = Object.prototype.hasOwnProperty;\nvar __propIsEnum$1 = Object.prototype.propertyIsEnumerable;\nvar __defNormalProp$1 = (obj, key, value) => key in obj ? __defProp$1(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;\nvar __spreadValues$1 = (a, b) => {\n for (var prop in b || (b = {}))\n if (__hasOwnProp$1.call(b, prop))\n __defNormalProp$1(a, prop, b[prop]);\n if (__getOwnPropSymbols$1)\n for (var prop of __getOwnPropSymbols$1(b)) {\n if (__propIsEnum$1.call(b, prop))\n __defNormalProp$1(a, prop, b[prop]);\n }\n return a;\n};\nvar __spreadProps$1 = (a, b) => __defProps$1(a, __getOwnPropDescs$1(b));\nvar __objRest$1 = (source, exclude) => {\n var target = {};\n for (var prop in source)\n if (__hasOwnProp$1.call(source, prop) && exclude.indexOf(prop) < 0)\n target[prop] = source[prop];\n if (source != null && __getOwnPropSymbols$1)\n for (var prop of __getOwnPropSymbols$1(source)) {\n if (exclude.indexOf(prop) < 0 && __propIsEnum$1.call(source, prop))\n target[prop] = source[prop];\n }\n return target;\n};\nfunction watchPausable(source, cb, options = {}) {\n const _a = options, {\n eventFilter: filter\n } = _a, watchOptions = __objRest$1(_a, [\n \"eventFilter\"\n ]);\n const { eventFilter, pause, resume, isActive } = pausableFilter(filter);\n const stop = watchWithFilter(source, cb, __spreadProps$1(__spreadValues$1({}, watchOptions), {\n eventFilter\n }));\n return { stop, pause, resume, isActive };\n}\n\nvar __defProp = Object.defineProperty;\nvar __defProps = Object.defineProperties;\nvar __getOwnPropDescs = Object.getOwnPropertyDescriptors;\nvar __getOwnPropSymbols = Object.getOwnPropertySymbols;\nvar __hasOwnProp = Object.prototype.hasOwnProperty;\nvar __propIsEnum = Object.prototype.propertyIsEnumerable;\nvar __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;\nvar __spreadValues = (a, b) => {\n for (var prop in b || (b = {}))\n if (__hasOwnProp.call(b, prop))\n __defNormalProp(a, prop, b[prop]);\n if (__getOwnPropSymbols)\n for (var prop of __getOwnPropSymbols(b)) {\n if (__propIsEnum.call(b, prop))\n __defNormalProp(a, prop, b[prop]);\n }\n return a;\n};\nvar __spreadProps = (a, b) => __defProps(a, __getOwnPropDescs(b));\nvar __objRest = (source, exclude) => {\n var target = {};\n for (var prop in source)\n if (__hasOwnProp.call(source, prop) && exclude.indexOf(prop) < 0)\n target[prop] = source[prop];\n if (source != null && __getOwnPropSymbols)\n for (var prop of __getOwnPropSymbols(source)) {\n if (exclude.indexOf(prop) < 0 && __propIsEnum.call(source, prop))\n target[prop] = source[prop];\n }\n return target;\n};\nfunction watchThrottled(source, cb, options = {}) {\n const _a = options, {\n throttle = 0,\n trailing = true,\n leading = true\n } = _a, watchOptions = __objRest(_a, [\n \"throttle\",\n \"trailing\",\n \"leading\"\n ]);\n return watchWithFilter(source, cb, __spreadProps(__spreadValues({}, watchOptions), {\n eventFilter: throttleFilter(throttle, trailing, leading)\n }));\n}\n\nfunction whenever(source, cb, options) {\n return watch(source, (v, ov, onInvalidate) => {\n if (v)\n cb(v, ov, onInvalidate);\n }, options);\n}\n\nexport { __onlyVue3, logicAnd as and, assert, refAutoReset as autoResetRef, bypassFilter, clamp, computedEager, computedWithControl, containsProp, computedWithControl as controlledComputed, controlledRef, createEventHook, createFilterWrapper, createGlobalState, createInjectionState, reactify as createReactiveFn, createSharedComposable, createSingletonPromise, debounceFilter, refDebounced as debouncedRef, watchDebounced as debouncedWatch, directiveHooks, computedEager as eagerComputed, extendRef, formatDate, get, identity, watchIgnorable as ignorableWatch, increaseWithUnit, invoke, isBoolean, isClient, isDef, isDefined, isFunction, isNumber, isObject, isString, isWindow, logicAnd, logicNot, logicOr, makeDestructurable, noop, normalizeDate, logicNot as not, now, objectPick, logicOr as or, pausableFilter, watchPausable as pausableWatch, promiseTimeout, rand, reactify, reactifyObject, reactiveComputed, reactiveOmit, reactivePick, refAutoReset, refDebounced, refDefault, refThrottled, refWithControl, set, syncRef, syncRefs, throttleFilter, refThrottled as throttledRef, watchThrottled as throttledWatch, timestamp, toReactive, toRefs, tryOnBeforeMount, tryOnBeforeUnmount, tryOnMounted, tryOnScopeDispose, tryOnUnmounted, until, useCounter, useDateFormat, refDebounced as useDebounce, useDebounceFn, useInterval, useIntervalFn, useLastChanged, refThrottled as useThrottle, useThrottleFn, useTimeout, useTimeoutFn, useToggle, watchAtMost, watchDebounced, watchIgnorable, watchOnce, watchPausable, watchThrottled, watchWithFilter, whenever };\n","import { noop, isClient, isString, tryOnScopeDispose, tryOnMounted, promiseTimeout, tryOnBeforeMount, increaseWithUnit, clamp, useTimeoutFn, pausableWatch, createEventHook, isFunction, timestamp, pausableFilter, watchIgnorable, debounceFilter, createFilterWrapper, bypassFilter, createSingletonPromise, toRefs, containsProp, until, throttleFilter, useDebounceFn, useThrottleFn, isObject, isNumber, useIntervalFn, syncRef, objectPick, tryOnUnmounted, watchWithFilter, identity } from '@vueuse/shared';\nexport * from '@vueuse/shared';\nimport { isRef, ref, watchEffect, computed, inject, unref, watch, getCurrentInstance, customRef, onUpdated, reactive, shallowRef, markRaw, getCurrentScope, isVue2, set, del, onMounted, readonly, onBeforeUpdate } from 'vue-demi';\nimport { unrefElement as unrefElement$1, useEventListener as useEventListener$1, useRafFn as useRafFn$1 } from '@vueuse/core';\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 onError = noop\n } = options;\n const started = ref(!lazy);\n const current = 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)\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\nconst createUnrefFn = (fn) => {\n return function(...args) {\n return fn.apply(this, args.map((i) => unref(i)));\n };\n};\n\nfunction unrefElement(elRef) {\n var _a;\n const plain = unref(elRef);\n return (_a = plain == null ? void 0 : plain.$el) != null ? _a : plain;\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 useEventListener(...args) {\n let target;\n let event;\n let listener;\n let options;\n if (isString(args[0])) {\n [event, listener, options] = args;\n target = defaultWindow;\n } else {\n [target, event, listener, options] = args;\n }\n if (!target)\n return noop;\n let cleanup = noop;\n const stopWatch = watch(() => unrefElement(target), (el) => {\n cleanup();\n if (!el)\n return;\n el.addEventListener(event, listener, options);\n cleanup = () => {\n el.removeEventListener(event, listener, options);\n cleanup = noop;\n };\n }, { immediate: true, flush: \"post\" });\n const stop = () => {\n stopWatch();\n cleanup();\n };\n tryOnScopeDispose(stop);\n return stop;\n}\n\nfunction onClickOutside(target, handler, options = {}) {\n const { window = defaultWindow, ignore, capture = true } = options;\n if (!window)\n return;\n const shouldListen = ref(true);\n const listener = (event) => {\n const el = unrefElement(target);\n const composedPath = event.composedPath();\n if (!el || el === event.target || composedPath.includes(el) || !shouldListen.value)\n return;\n if (ignore && ignore.length > 0) {\n if (ignore.some((target2) => {\n const el2 = unrefElement(target2);\n return el2 && (event.target === el2 || composedPath.includes(el2));\n }))\n return;\n }\n handler(event);\n };\n const cleanup = [\n useEventListener(window, \"click\", listener, { passive: true, capture }),\n useEventListener(window, \"pointerdown\", (e) => {\n const el = unrefElement(target);\n shouldListen.value = !!el && !e.composedPath().includes(el);\n }, { passive: true })\n ];\n const stop = () => cleanup.forEach((fn) => fn());\n return stop;\n}\n\nvar __defProp$h = Object.defineProperty;\nvar __defProps$8 = Object.defineProperties;\nvar __getOwnPropDescs$8 = Object.getOwnPropertyDescriptors;\nvar __getOwnPropSymbols$j = Object.getOwnPropertySymbols;\nvar __hasOwnProp$j = Object.prototype.hasOwnProperty;\nvar __propIsEnum$j = Object.prototype.propertyIsEnumerable;\nvar __defNormalProp$h = (obj, key, value) => key in obj ? __defProp$h(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;\nvar __spreadValues$h = (a, b) => {\n for (var prop in b || (b = {}))\n if (__hasOwnProp$j.call(b, prop))\n __defNormalProp$h(a, prop, b[prop]);\n if (__getOwnPropSymbols$j)\n for (var prop of __getOwnPropSymbols$j(b)) {\n if (__propIsEnum$j.call(b, prop))\n __defNormalProp$h(a, prop, b[prop]);\n }\n return a;\n};\nvar __spreadProps$8 = (a, b) => __defProps$8(a, __getOwnPropDescs$8(b));\nconst 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 else if (keyFilter)\n return () => true;\n else\n return () => false;\n};\nfunction onKeyStroke(key, handler, options = {}) {\n const { target = defaultWindow, eventName = \"keydown\", passive = false } = options;\n const predicate = createKeyPredicate(key);\n const listener = (e) => {\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, __spreadProps$8(__spreadValues$h({}, options), { eventName: \"keydown\" }));\n}\nfunction onKeyPressed(key, handler, options = {}) {\n return onKeyStroke(key, handler, __spreadProps$8(__spreadValues$h({}, options), { eventName: \"keypress\" }));\n}\nfunction onKeyUp(key, handler, options = {}) {\n return onKeyStroke(key, handler, __spreadProps$8(__spreadValues$h({}, options), { eventName: \"keyup\" }));\n}\n\nconst DEFAULT_DELAY = 500;\nfunction onLongPress(target, handler, options) {\n const elementRef = computed(() => unrefElement$1(target));\n let timeout = null;\n function clear() {\n if (timeout != null) {\n clearTimeout(timeout);\n timeout = null;\n }\n }\n function onDown(ev) {\n var _a;\n clear();\n timeout = setTimeout(() => handler(ev), (_a = options == null ? void 0 : options.delay) != null ? _a : DEFAULT_DELAY);\n }\n useEventListener$1(elementRef, \"pointerdown\", onDown);\n useEventListener$1(elementRef, \"pointerup\", clear);\n useEventListener$1(elementRef, \"pointerleave\", clear);\n}\n\nconst 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};\nconst isTypedCharValid = ({\n keyCode,\n metaKey,\n ctrlKey,\n altKey\n}) => {\n if (metaKey || ctrlKey || altKey)\n return false;\n if (keyCode >= 48 && keyCode <= 57 || keyCode >= 96 && keyCode <= 105)\n return true;\n if (keyCode >= 65 && keyCode <= 90)\n return true;\n return false;\n};\nfunction onStartTyping(callback, options = {}) {\n const { document: document2 = defaultDocument } = options;\n const keydown = (event) => {\n !isFocusedElementEditable() && isTypedCharValid(event) && callback(event);\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 useActiveElement(options = {}) {\n const { window = defaultWindow } = options;\n const counter = ref(0);\n if (window) {\n useEventListener(window, \"blur\", () => counter.value += 1, true);\n useEventListener(window, \"focus\", () => counter.value += 1, true);\n }\n return computed(() => {\n counter.value;\n return window == null ? void 0 : window.document.activeElement;\n });\n}\n\nfunction useAsyncQueue(tasks, options = {}) {\n const {\n interrupt = true,\n onError = noop,\n onFinished = noop\n } = options;\n const promiseState = {\n pending: \"pending\",\n rejected: \"rejected\",\n fulfilled: \"fulfilled\"\n };\n const initialResult = Array.from(new Array(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 (((_a = result[activeIndex.value]) == null ? void 0 : _a.state) === promiseState.rejected && interrupt) {\n onFinished();\n return;\n }\n return curr(prevRes).then((currentRes) => {\n updateResult(promiseState.fulfilled, currentRes);\n activeIndex.value === tasks.length - 1 && onFinished();\n return currentRes;\n });\n }).catch((e) => {\n updateResult(promiseState.rejected, e);\n onError();\n return e;\n });\n }, Promise.resolve());\n return {\n activeIndex,\n result\n };\n}\n\nfunction useAsyncState(promise, initialState, options) {\n const {\n immediate = true,\n delay = 0,\n onError = noop,\n resetOnExecute = true,\n shallow = true\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 = ref(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 } catch (e) {\n error.value = e;\n onError(e);\n }\n isLoading.value = false;\n return state.value;\n }\n if (immediate)\n execute(delay);\n return {\n state,\n isReady,\n isLoading,\n error,\n execute\n };\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 = unref(target);\n if (_target === void 0 || _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 {\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 watch(target, execute, { immediate: true });\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({ navigator = defaultNavigator } = {}) {\n const events = [\"chargingchange\", \"chargingtimechange\", \"dischargingtimechange\", \"levelchange\"];\n const isSupported = navigator && \"getBattery\" in navigator;\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) {\n navigator.getBattery().then((_battery) => {\n battery = _battery;\n updateBatteryInfo.call(battery);\n for (const event of events)\n useEventListener(battery, event, updateBatteryInfo, { passive: true });\n });\n }\n return {\n isSupported,\n charging,\n chargingTime,\n dischargingTime,\n level\n };\n}\n\nfunction useMediaQuery(query, options = {}) {\n const { window = defaultWindow } = options;\n let mediaQuery;\n const matches = ref(false);\n const update = () => {\n if (!window)\n return;\n if (!mediaQuery)\n mediaQuery = window.matchMedia(query);\n matches.value = mediaQuery.matches;\n };\n tryOnBeforeMount(() => {\n update();\n if (!mediaQuery)\n return;\n if (\"addEventListener\" in mediaQuery)\n mediaQuery.addEventListener(\"change\", update);\n else\n mediaQuery.addListener(update);\n tryOnScopeDispose(() => {\n if (\"removeEventListener\" in mediaQuery)\n mediaQuery.removeEventListener(\"change\", update);\n else\n mediaQuery.removeListener(update);\n });\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 sm: 576,\n md: 768,\n lg: 992,\n xl: 1200,\n xxl: 1400\n};\nconst breakpointsVuetify = {\n xs: 600,\n sm: 960,\n md: 1264,\n lg: 1904\n};\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: 600,\n sm: 1024,\n md: 1440,\n lg: 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};\n\nvar __defProp$g = Object.defineProperty;\nvar __getOwnPropSymbols$i = Object.getOwnPropertySymbols;\nvar __hasOwnProp$i = Object.prototype.hasOwnProperty;\nvar __propIsEnum$i = Object.prototype.propertyIsEnumerable;\nvar __defNormalProp$g = (obj, key, value) => key in obj ? __defProp$g(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;\nvar __spreadValues$g = (a, b) => {\n for (var prop in b || (b = {}))\n if (__hasOwnProp$i.call(b, prop))\n __defNormalProp$g(a, prop, b[prop]);\n if (__getOwnPropSymbols$i)\n for (var prop of __getOwnPropSymbols$i(b)) {\n if (__propIsEnum$i.call(b, prop))\n __defNormalProp$g(a, prop, b[prop]);\n }\n return a;\n};\nfunction useBreakpoints(breakpoints, options = {}) {\n function getValue(k, delta) {\n let v = breakpoints[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 } = options;\n function match(query) {\n if (!window)\n return false;\n return window.matchMedia(query).matches;\n }\n const greater = (k) => {\n return useMediaQuery(`(min-width: ${getValue(k)})`, options);\n };\n const shortcutMethods = Object.keys(breakpoints).reduce((shortcuts, k) => {\n Object.defineProperty(shortcuts, k, {\n get: () => greater(k),\n enumerable: true,\n configurable: true\n });\n return shortcuts;\n }, {});\n return __spreadValues$g({\n greater,\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)})`);\n },\n isSmaller(k) {\n return match(`(max-width: ${getValue(k, -0.1)})`);\n },\n isInBetween(a, b) {\n return match(`(min-width: ${getValue(a)}) and (max-width: ${getValue(b, -0.1)})`);\n }\n }, shortcutMethods);\n}\n\nconst useBroadcastChannel = (options) => {\n const {\n name,\n window = defaultWindow\n } = options;\n const isSupported = window && \"BroadcastChannel\" in window;\n const isClosed = ref(false);\n const channel = ref();\n const data = ref();\n const error = ref(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) {\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\nfunction useBrowserLocation({ window = defaultWindow } = {}) {\n const buildState = (trigger) => {\n const { state: state2, length } = (window == null ? void 0 : window.history) || {};\n const { hash, host, hostname, href, origin, pathname, port, protocol, search } = (window == null ? void 0 : window.location) || {};\n return {\n trigger,\n state: state2,\n length,\n hash,\n host,\n hostname,\n href,\n origin,\n pathname,\n port,\n protocol,\n search\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 useClamp(value, min, max) {\n const _value = ref(value);\n return computed({\n get() {\n return _value.value = clamp(_value.value, unref(min), unref(max));\n },\n set(value2) {\n _value.value = clamp(value2, unref(min), unref(max));\n }\n });\n}\n\nfunction useClipboard(options = {}) {\n const {\n navigator = defaultNavigator,\n read = false,\n source,\n copiedDuring = 1500\n } = options;\n const events = [\"copy\", \"cut\"];\n const isSupported = Boolean(navigator && \"clipboard\" in navigator);\n const text = ref(\"\");\n const copied = ref(false);\n const timeout = useTimeoutFn(() => copied.value = false, copiedDuring);\n function updateText() {\n navigator.clipboard.readText().then((value) => {\n text.value = value;\n });\n }\n if (isSupported && read) {\n for (const event of events)\n useEventListener(event, updateText);\n }\n async function copy(value = unref(source)) {\n if (isSupported && value != null) {\n await navigator.clipboard.writeText(value);\n text.value = value;\n copied.value = true;\n timeout.start();\n }\n }\n return {\n isSupported,\n text,\n copied,\n copy\n };\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__\";\n_global[globalKey] = _global[globalKey] || {};\nconst handlers = _global[globalKey];\nfunction getSSRHandler(key, fallback) {\n return handlers[key] || fallback;\n}\nfunction setSSRHandler(key, fn) {\n handlers[key] = fn;\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\" : Array.isArray(rawInit) ? \"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};\nfunction useStorage(key, initialValue, storage, options = {}) {\n var _a;\n const {\n flush = \"pre\",\n deep = true,\n listenToStorageChanges = true,\n writeDefaults = true,\n shallow,\n window = defaultWindow,\n eventFilter,\n onError = (e) => {\n console.error(e);\n }\n } = options;\n const data = (shallow ? shallowRef : ref)(initialValue);\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 = unref(initialValue);\n const type = guessSerializerType(rawInit);\n const serializer = (_a = options.serializer) != null ? _a : StorageSerializers[type];\n const { pause: pauseWatch, resume: resumeWatch } = pausableWatch(data, () => write(data.value), { flush, deep, eventFilter });\n if (window && listenToStorageChanges)\n useEventListener(window, \"storage\", update);\n update();\n return data;\n function write(v) {\n try {\n if (v == null)\n storage.removeItem(key);\n else\n storage.setItem(key, serializer.write(v));\n } catch (e) {\n onError(e);\n }\n }\n function read(event) {\n if (event && event.key !== key)\n return;\n pauseWatch();\n try {\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 (typeof rawValue !== \"string\") {\n return rawValue;\n } else {\n return serializer.read(rawValue);\n }\n } catch (e) {\n onError(e);\n } finally {\n resumeWatch();\n }\n }\n function update(event) {\n if (event && event.key !== key)\n return;\n data.value = read(event);\n }\n}\n\nfunction usePreferredDark(options) {\n return useMediaQuery(\"(prefers-color-scheme: dark)\", options);\n}\n\nvar __defProp$f = Object.defineProperty;\nvar __getOwnPropSymbols$h = Object.getOwnPropertySymbols;\nvar __hasOwnProp$h = Object.prototype.hasOwnProperty;\nvar __propIsEnum$h = Object.prototype.propertyIsEnumerable;\nvar __defNormalProp$f = (obj, key, value) => key in obj ? __defProp$f(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;\nvar __spreadValues$f = (a, b) => {\n for (var prop in b || (b = {}))\n if (__hasOwnProp$h.call(b, prop))\n __defNormalProp$f(a, prop, b[prop]);\n if (__getOwnPropSymbols$h)\n for (var prop of __getOwnPropSymbols$h(b)) {\n if (__propIsEnum$h.call(b, prop))\n __defNormalProp$f(a, prop, b[prop]);\n }\n return a;\n};\nfunction useColorMode(options = {}) {\n const {\n selector = \"html\",\n attribute = \"class\",\n window = defaultWindow,\n storage,\n storageKey = \"vueuse-color-scheme\",\n listenToStorageChanges = true,\n storageRef\n } = options;\n const modes = __spreadValues$f({\n auto: \"\",\n light: \"light\",\n dark: \"dark\"\n }, options.modes || {});\n const preferredDark = usePreferredDark({ window });\n const preferredMode = computed(() => preferredDark.value ? \"dark\" : \"light\");\n const store = storageRef || (storageKey == null ? ref(\"auto\") : useStorage(storageKey, \"auto\", storage, { window, listenToStorageChanges }));\n const state = computed({\n get() {\n return store.value === \"auto\" ? preferredMode.value : store.value;\n },\n set(v) {\n store.value = v;\n }\n });\n const updateHTMLAttrs = getSSRHandler(\"updateHTMLAttrs\", (selector2, attribute2, value) => {\n const el = window == null ? void 0 : window.document.querySelector(selector2);\n if (!el)\n return;\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 el.classList.add(v);\n else\n el.classList.remove(v);\n });\n } else {\n el.setAttribute(attribute2, value);\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 return 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, { window = defaultWindow } = {}) {\n const variable = ref(\"\");\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 watch([elRef, () => unref(prop)], ([el, prop2]) => {\n if (el && window)\n variable.value = window.getComputedStyle(el).getPropertyValue(prop2);\n }, { immediate: true });\n watch(variable, (val) => {\n var _a;\n if ((_a = elRef.value) == null ? void 0 : _a.style)\n elRef.value.style.setProperty(unref(prop), val);\n });\n return variable;\n}\n\nfunction useCycleList(list, options) {\n var _a;\n const state = shallowRef((_a = options == null ? void 0 : options.initialValue) != null ? _a : list[0]);\n const index = computed({\n get() {\n var _a2;\n let index2 = (options == null ? void 0 : options.getIndexOf) ? options.getIndexOf(state.value, list) : list.indexOf(state.value);\n if (index2 < 0)\n index2 = (_a2 = options == null ? void 0 : options.fallbackIndex) != null ? _a2 : 0;\n return index2;\n },\n set(v) {\n set(v);\n }\n });\n function set(i) {\n const length = list.length;\n const index2 = (i % length + length) % length;\n const value = list[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 return {\n state,\n index,\n next,\n prev\n };\n}\n\nvar __defProp$e = Object.defineProperty;\nvar __defProps$7 = Object.defineProperties;\nvar __getOwnPropDescs$7 = Object.getOwnPropertyDescriptors;\nvar __getOwnPropSymbols$g = Object.getOwnPropertySymbols;\nvar __hasOwnProp$g = Object.prototype.hasOwnProperty;\nvar __propIsEnum$g = Object.prototype.propertyIsEnumerable;\nvar __defNormalProp$e = (obj, key, value) => key in obj ? __defProp$e(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;\nvar __spreadValues$e = (a, b) => {\n for (var prop in b || (b = {}))\n if (__hasOwnProp$g.call(b, prop))\n __defNormalProp$e(a, prop, b[prop]);\n if (__getOwnPropSymbols$g)\n for (var prop of __getOwnPropSymbols$g(b)) {\n if (__propIsEnum$g.call(b, prop))\n __defNormalProp$e(a, prop, b[prop]);\n }\n return a;\n};\nvar __spreadProps$7 = (a, b) => __defProps$7(a, __getOwnPropDescs$7(b));\nfunction useDark(options = {}) {\n const {\n valueDark = \"dark\",\n valueLight = \"\",\n window = defaultWindow\n } = options;\n const mode = useColorMode(__spreadProps$7(__spreadValues$e({}, options), {\n onChanged: (mode2, defaultHandler) => {\n var _a;\n if (options.onChanged)\n (_a = options.onChanged) == null ? void 0 : _a.call(options, mode2 === \"dark\");\n else\n defaultHandler(mode2);\n },\n modes: {\n dark: valueDark,\n light: valueLight\n }\n }));\n const preferredDark = usePreferredDark({ window });\n const isDark = computed({\n get() {\n return mode.value === \"dark\";\n },\n set(v) {\n if (v === preferredDark.value)\n mode.value = \"auto\";\n else\n mode.value = v ? \"dark\" : \"light\";\n }\n });\n return isDark;\n}\n\nconst fnClone = (v) => JSON.parse(JSON.stringify(v));\nconst fnBypass = (v) => v;\nconst fnSetSource = (source, value) => source.value = value;\nfunction defaultDump(clone) {\n return clone ? isFunction(clone) ? clone : fnClone : fnBypass;\n}\nfunction defaultParse(clone) {\n return clone ? isFunction(clone) ? clone : fnClone : 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, 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\nvar __defProp$d = Object.defineProperty;\nvar __defProps$6 = Object.defineProperties;\nvar __getOwnPropDescs$6 = Object.getOwnPropertyDescriptors;\nvar __getOwnPropSymbols$f = Object.getOwnPropertySymbols;\nvar __hasOwnProp$f = Object.prototype.hasOwnProperty;\nvar __propIsEnum$f = Object.prototype.propertyIsEnumerable;\nvar __defNormalProp$d = (obj, key, value) => key in obj ? __defProp$d(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;\nvar __spreadValues$d = (a, b) => {\n for (var prop in b || (b = {}))\n if (__hasOwnProp$f.call(b, prop))\n __defNormalProp$d(a, prop, b[prop]);\n if (__getOwnPropSymbols$f)\n for (var prop of __getOwnPropSymbols$f(b)) {\n if (__propIsEnum$f.call(b, prop))\n __defNormalProp$d(a, prop, b[prop]);\n }\n return a;\n};\nvar __spreadProps$6 = (a, b) => __defProps$6(a, __getOwnPropDescs$6(b));\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(source, commit, { deep, flush, eventFilter: composedFilter });\n function setSource(source2, value) {\n ignorePrevAsyncUpdates();\n ignoreUpdates(() => {\n source2.value = value;\n });\n }\n const manualHistory = useManualRefHistory(source, __spreadProps$6(__spreadValues$d({}, 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 __spreadProps$6(__spreadValues$d({}, manualHistory), {\n isTracking,\n pause,\n resume,\n commit,\n batch,\n dispose\n });\n}\n\nvar __defProp$c = Object.defineProperty;\nvar __defProps$5 = Object.defineProperties;\nvar __getOwnPropDescs$5 = Object.getOwnPropertyDescriptors;\nvar __getOwnPropSymbols$e = Object.getOwnPropertySymbols;\nvar __hasOwnProp$e = Object.prototype.hasOwnProperty;\nvar __propIsEnum$e = Object.prototype.propertyIsEnumerable;\nvar __defNormalProp$c = (obj, key, value) => key in obj ? __defProp$c(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;\nvar __spreadValues$c = (a, b) => {\n for (var prop in b || (b = {}))\n if (__hasOwnProp$e.call(b, prop))\n __defNormalProp$c(a, prop, b[prop]);\n if (__getOwnPropSymbols$e)\n for (var prop of __getOwnPropSymbols$e(b)) {\n if (__propIsEnum$e.call(b, prop))\n __defNormalProp$c(a, prop, b[prop]);\n }\n return a;\n};\nvar __spreadProps$5 = (a, b) => __defProps$5(a, __getOwnPropDescs$5(b));\nfunction useDebouncedRefHistory(source, options = {}) {\n const filter = options.debounce ? debounceFilter(options.debounce) : void 0;\n const history = useRefHistory(source, __spreadProps$5(__spreadValues$c({}, options), { eventFilter: filter }));\n return __spreadValues$c({}, history);\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(eventFilter, (event) => {\n acceleration.value = event.acceleration;\n accelerationIncludingGravity.value = event.accelerationIncludingGravity;\n rotationRate.value = event.rotationRate;\n interval.value = event.interval;\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 = Boolean(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) {\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\nconst DEVICE_PIXEL_RATIO_SCALES = [\n 1,\n 1.325,\n 1.4,\n 1.5,\n 1.8,\n 2,\n 2.4,\n 2.5,\n 2.75,\n 3,\n 3.5,\n 4\n];\nfunction useDevicePixelRatio({\n window = defaultWindow\n} = {}) {\n if (!window) {\n return {\n pixelRatio: ref(1)\n };\n }\n const pixelRatio = ref(window.devicePixelRatio);\n const handleDevicePixelRatio = () => {\n pixelRatio.value = window.devicePixelRatio;\n };\n useEventListener(window, \"resize\", handleDevicePixelRatio, { passive: true });\n DEVICE_PIXEL_RATIO_SCALES.forEach((dppx) => {\n const mqlMin = useMediaQuery(`screen and (min-resolution: ${dppx}dppx)`);\n const mqlMax = useMediaQuery(`screen and (max-resolution: ${dppx}dppx)`);\n watch([mqlMin, mqlMax], handleDevicePixelRatio);\n });\n return { pixelRatio };\n}\n\nfunction usePermission(permissionDesc, options = {}) {\n const {\n controls = false,\n navigator = defaultNavigator\n } = options;\n const isSupported = Boolean(navigator && \"permissions\" in navigator);\n let permissionStatus;\n const desc = typeof permissionDesc === \"string\" ? { name: permissionDesc } : permissionDesc;\n const state = ref();\n const onChange = () => {\n if (permissionStatus)\n state.value = permissionStatus.state;\n };\n const query = createSingletonPromise(async () => {\n if (!isSupported)\n return;\n if (!permissionStatus) {\n try {\n permissionStatus = await navigator.permissions.query(desc);\n useEventListener(permissionStatus, \"change\", onChange);\n onChange();\n } catch (e) {\n state.value = \"prompt\";\n }\n }\n return permissionStatus;\n });\n query();\n if (controls) {\n return {\n state,\n isSupported,\n query\n };\n } else {\n return state;\n }\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 let isSupported = false;\n const permissionGranted = ref(false);\n async function update() {\n if (!isSupported)\n return;\n devices.value = await navigator.mediaDevices.enumerateDevices();\n onUpdated == null ? void 0 : onUpdated(devices.value);\n }\n async function ensurePermissions() {\n if (!isSupported)\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 const stream = await navigator.mediaDevices.getUserMedia(constraints);\n stream.getTracks().forEach((t) => t.stop());\n update();\n permissionGranted.value = true;\n } else {\n permissionGranted.value = true;\n }\n return permissionGranted.value;\n }\n if (navigator) {\n isSupported = Boolean(navigator.mediaDevices && navigator.mediaDevices.enumerateDevices);\n if (isSupported) {\n if (requestPermissions)\n ensurePermissions();\n useEventListener(navigator.mediaDevices, \"devicechange\", update);\n update();\n }\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, _b;\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 = Boolean((_b = navigator == null ? void 0 : navigator.mediaDevices) == null ? void 0 : _b.getDisplayMedia);\n const constraint = { audio, video };\n const stream = shallowRef();\n async function _start() {\n if (!isSupported || stream.value)\n return;\n stream.value = await navigator.mediaDevices.getDisplayMedia(constraint);\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(enabled, (v) => {\n if (v)\n _start();\n else\n _stop();\n }, { immediate: true });\n return {\n isSupported,\n stream,\n start,\n stop,\n enabled\n };\n}\n\nfunction useDocumentVisibility({ document = defaultDocument } = {}) {\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\nvar __defProp$b = Object.defineProperty;\nvar __defProps$4 = Object.defineProperties;\nvar __getOwnPropDescs$4 = Object.getOwnPropertyDescriptors;\nvar __getOwnPropSymbols$d = Object.getOwnPropertySymbols;\nvar __hasOwnProp$d = Object.prototype.hasOwnProperty;\nvar __propIsEnum$d = Object.prototype.propertyIsEnumerable;\nvar __defNormalProp$b = (obj, key, value) => key in obj ? __defProp$b(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;\nvar __spreadValues$b = (a, b) => {\n for (var prop in b || (b = {}))\n if (__hasOwnProp$d.call(b, prop))\n __defNormalProp$b(a, prop, b[prop]);\n if (__getOwnPropSymbols$d)\n for (var prop of __getOwnPropSymbols$d(b)) {\n if (__propIsEnum$d.call(b, prop))\n __defNormalProp$b(a, prop, b[prop]);\n }\n return a;\n};\nvar __spreadProps$4 = (a, b) => __defProps$4(a, __getOwnPropDescs$4(b));\nfunction useDraggable(target, options = {}) {\n var _a, _b;\n const draggingElement = (_a = options.draggingElement) != null ? _a : defaultWindow;\n const position = ref((_b = options.initialValue) != null ? _b : { x: 0, y: 0 });\n const pressedDelta = ref();\n const filterEvent = (e) => {\n if (options.pointerTypes)\n return options.pointerTypes.includes(e.pointerType);\n return true;\n };\n const handleEvent = (e) => {\n if (unref(options.preventDefault))\n e.preventDefault();\n if (unref(options.stopPropagation))\n e.stopPropagation();\n };\n const start = (e) => {\n var _a2;\n if (!filterEvent(e))\n return;\n if (unref(options.exact) && e.target !== unref(target))\n return;\n const rect = unref(target).getBoundingClientRect();\n const pos = {\n x: e.pageX - rect.left,\n y: e.pageY - rect.top\n };\n if (((_a2 = options.onStart) == null ? void 0 : _a2.call(options, pos, e)) === false)\n return;\n pressedDelta.value = pos;\n handleEvent(e);\n };\n const move = (e) => {\n var _a2;\n if (!filterEvent(e))\n return;\n if (!pressedDelta.value)\n return;\n position.value = {\n x: e.pageX - pressedDelta.value.x,\n y: e.pageY - pressedDelta.value.y\n };\n (_a2 = options.onMove) == null ? void 0 : _a2.call(options, position.value, e);\n handleEvent(e);\n };\n const end = (e) => {\n var _a2;\n if (!filterEvent(e))\n return;\n if (!pressedDelta.value)\n return;\n pressedDelta.value = void 0;\n (_a2 = options.onEnd) == null ? void 0 : _a2.call(options, position.value, e);\n handleEvent(e);\n };\n if (isClient) {\n useEventListener(target, \"pointerdown\", start, true);\n useEventListener(draggingElement, \"pointermove\", move, true);\n useEventListener(draggingElement, \"pointerup\", end, true);\n }\n return __spreadProps$4(__spreadValues$b({}, toRefs(position)), {\n position,\n isDragging: computed(() => !!pressedDelta.value),\n style: computed(() => `left:${position.value.x}px;top:${position.value.y}px;`)\n });\n}\n\nvar __getOwnPropSymbols$c = Object.getOwnPropertySymbols;\nvar __hasOwnProp$c = Object.prototype.hasOwnProperty;\nvar __propIsEnum$c = Object.prototype.propertyIsEnumerable;\nvar __objRest$2 = (source, exclude) => {\n var target = {};\n for (var prop in source)\n if (__hasOwnProp$c.call(source, prop) && exclude.indexOf(prop) < 0)\n target[prop] = source[prop];\n if (source != null && __getOwnPropSymbols$c)\n for (var prop of __getOwnPropSymbols$c(source)) {\n if (exclude.indexOf(prop) < 0 && __propIsEnum$c.call(source, prop))\n target[prop] = source[prop];\n }\n return target;\n};\nfunction useResizeObserver(target, callback, options = {}) {\n const _a = options, { window = defaultWindow } = _a, observerOptions = __objRest$2(_a, [\"window\"]);\n let observer;\n const isSupported = window && \"ResizeObserver\" in window;\n const cleanup = () => {\n if (observer) {\n observer.disconnect();\n observer = void 0;\n }\n };\n const stopWatch = watch(() => unrefElement(target), (el) => {\n cleanup();\n if (isSupported && window && el) {\n observer = new ResizeObserver(callback);\n observer.observe(el, observerOptions);\n }\n }, { immediate: true, flush: \"post\" });\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 } = 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 update() {\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 useResizeObserver(target, update);\n watch(() => unrefElement(target), (ele) => !ele && update());\n if (windowScroll)\n useEventListener(\"scroll\", update, { passive: true });\n if (windowResize)\n useEventListener(\"resize\", update, { passive: true });\n return {\n height,\n bottom,\n left,\n right,\n top,\n width,\n x,\n y,\n update\n };\n}\n\nfunction useRafFn(fn, options = {}) {\n const {\n immediate = true,\n window = defaultWindow\n } = options;\n const isActive = ref(false);\n let rafId = null;\n function loop() {\n if (!isActive.value || !window)\n return;\n fn();\n rafId = window.requestAnimationFrame(loop);\n }\n function resume() {\n if (!isActive.value && window) {\n isActive.value = true;\n 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,\n pause,\n resume\n };\n}\n\nvar __defProp$a = Object.defineProperty;\nvar __getOwnPropSymbols$b = Object.getOwnPropertySymbols;\nvar __hasOwnProp$b = Object.prototype.hasOwnProperty;\nvar __propIsEnum$b = Object.prototype.propertyIsEnumerable;\nvar __defNormalProp$a = (obj, key, value) => key in obj ? __defProp$a(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;\nvar __spreadValues$a = (a, b) => {\n for (var prop in b || (b = {}))\n if (__hasOwnProp$b.call(b, prop))\n __defNormalProp$a(a, prop, b[prop]);\n if (__getOwnPropSymbols$b)\n for (var prop of __getOwnPropSymbols$b(b)) {\n if (__propIsEnum$b.call(b, prop))\n __defNormalProp$a(a, prop, b[prop]);\n }\n return a;\n};\nfunction useElementByPoint(options) {\n const element = ref(null);\n const { x, y } = options;\n const controls = useRafFn(() => {\n element.value = document.elementFromPoint(unref(x), unref(y));\n });\n return __spreadValues$a({\n element\n }, controls);\n}\n\nfunction useElementHover(el) {\n const isHovered = ref(false);\n useEventListener(el, \"mouseenter\", () => isHovered.value = true);\n useEventListener(el, \"mouseleave\", () => isHovered.value = false);\n return isHovered;\n}\n\nfunction useElementSize(target, initialSize = { width: 0, height: 0 }, options = {}) {\n const width = ref(initialSize.width);\n const height = ref(initialSize.height);\n useResizeObserver(target, ([entry]) => {\n width.value = entry.contentRect.width;\n height.value = entry.contentRect.height;\n }, options);\n watch(() => unrefElement(target), (ele) => {\n width.value = ele ? initialSize.width : 0;\n height.value = ele ? initialSize.height : 0;\n });\n return {\n width,\n height\n };\n}\n\nfunction useElementVisibility(element, { window = defaultWindow, scrollTarget } = {}) {\n const elementIsVisible = ref(false);\n const testBounding = () => {\n if (!window)\n return;\n const document = window.document;\n if (!unref(element)) {\n elementIsVisible.value = false;\n } else {\n const rect = unref(element).getBoundingClientRect();\n elementIsVisible.value = rect.top <= (window.innerHeight || document.documentElement.clientHeight) && rect.left <= (window.innerWidth || document.documentElement.clientWidth) && rect.bottom >= 0 && rect.right >= 0;\n }\n };\n tryOnMounted(testBounding);\n if (window)\n tryOnMounted(() => useEventListener(unref(scrollTarget) || window, \"scroll\", testBounding, { capture: false, passive: true }));\n return elementIsVisible;\n}\n\nconst events = /* @__PURE__ */ new Map();\n\nfunction useEventBus(key) {\n const scope = getCurrentScope();\n function on(listener) {\n const listeners = events.get(key) || [];\n listeners.push(listener);\n events.set(key, listeners);\n const _off = () => off(listener);\n scope == null ? void 0 : scope.cleanups.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 const index = listeners.indexOf(listener);\n if (index > -1)\n listeners.splice(index, 1);\n if (!listeners.length)\n events.delete(key);\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 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 = ref(null);\n const {\n withCredentials = false\n } = options;\n const close = () => {\n if (eventSource.value) {\n eventSource.value.close();\n eventSource.value = null;\n status.value = \"CLOSED\";\n }\n };\n const es = new EventSource(url, { withCredentials });\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 };\n es.onmessage = (e) => {\n event.value = null;\n data.value = e.data;\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 tryOnScopeDispose(() => {\n close();\n });\n return {\n eventSource,\n event,\n data,\n status,\n error,\n close\n };\n}\n\nfunction useEyeDropper(options = {}) {\n const { initialValue = \"\" } = options;\n const isSupported = Boolean(typeof window !== \"undefined\" && \"EyeDropper\" in window);\n const sRGBHex = ref(initialValue);\n async function open(openOptions) {\n if (!isSupported)\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 = isRef(newIcon) ? newIcon : ref(newIcon);\n const applyIcon = (icon) => {\n document == null ? void 0 : document.head.querySelectorAll(`link[rel*=\"${rel}\"]`).forEach((el) => el.href = `${baseUrl}${icon}`);\n };\n watch(favicon, (i, o) => {\n if (isString(i) && i !== o)\n applyIcon(i);\n }, { immediate: true });\n return favicon;\n}\n\nvar __defProp$9 = Object.defineProperty;\nvar __defProps$3 = Object.defineProperties;\nvar __getOwnPropDescs$3 = Object.getOwnPropertyDescriptors;\nvar __getOwnPropSymbols$a = Object.getOwnPropertySymbols;\nvar __hasOwnProp$a = Object.prototype.hasOwnProperty;\nvar __propIsEnum$a = Object.prototype.propertyIsEnumerable;\nvar __defNormalProp$9 = (obj, key, value) => key in obj ? __defProp$9(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;\nvar __spreadValues$9 = (a, b) => {\n for (var prop in b || (b = {}))\n if (__hasOwnProp$a.call(b, prop))\n __defNormalProp$9(a, prop, b[prop]);\n if (__getOwnPropSymbols$a)\n for (var prop of __getOwnPropSymbols$a(b)) {\n if (__propIsEnum$a.call(b, prop))\n __defNormalProp$9(a, prop, b[prop]);\n }\n return a;\n};\nvar __spreadProps$3 = (a, b) => __defProps$3(a, __getOwnPropDescs$3(b));\nconst payloadMapping = {\n json: \"application/json\",\n text: \"text/plain\",\n formData: \"multipart/form-data\"\n};\nfunction isFetchOptions(obj) {\n return containsProp(obj, \"immediate\", \"refetch\", \"initialData\", \"timeout\", \"beforeFetch\", \"afterFetch\", \"onFetchError\");\n}\nfunction headersToObject(headers) {\n if (headers instanceof Headers)\n return Object.fromEntries([...headers.entries()]);\n return headers;\n}\nfunction createFetch(config = {}) {\n const _options = config.options || {};\n const _fetchOptions = config.fetchOptions || {};\n function useFactoryFetch(url, ...args) {\n const computedUrl = computed(() => config.baseUrl ? joinPaths(unref(config.baseUrl), unref(url)) : unref(url));\n let options = _options;\n let fetchOptions = _fetchOptions;\n if (args.length > 0) {\n if (isFetchOptions(args[0])) {\n options = __spreadValues$9(__spreadValues$9({}, options), args[0]);\n } else {\n fetchOptions = __spreadProps$3(__spreadValues$9(__spreadValues$9({}, fetchOptions), args[0]), {\n headers: __spreadValues$9(__spreadValues$9({}, headersToObject(fetchOptions.headers) || {}), headersToObject(args[0].headers) || {})\n });\n }\n }\n if (args.length > 1 && isFetchOptions(args[1]))\n options = __spreadValues$9(__spreadValues$9({}, options), args[1]);\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 = { immediate: true, refetch: false, timeout: 0 };\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 = __spreadValues$9(__spreadValues$9({}, options), args[0]);\n else\n fetchOptions = args[0];\n }\n if (args.length > 1) {\n if (isFetchOptions(args[1]))\n options = __spreadValues$9(__spreadValues$9({}, 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);\n const canAbort = computed(() => supportsAbort && isFetching.value);\n let controller;\n let timer;\n const abort = () => {\n if (supportsAbort && controller)\n controller.abort();\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 const execute = async (throwOnFailed = false) => {\n var _a2;\n loading(true);\n error.value = null;\n statusCode.value = null;\n aborted.value = false;\n controller = void 0;\n if (supportsAbort) {\n controller = new AbortController();\n controller.signal.onabort = () => aborted.value = true;\n fetchOptions = __spreadProps$3(__spreadValues$9({}, fetchOptions), {\n signal: controller.signal\n });\n }\n const defaultFetchOptions = {\n method: config.method,\n headers: {}\n };\n if (config.payload) {\n const headers = headersToObject(defaultFetchOptions.headers);\n if (config.payloadType)\n headers[\"Content-Type\"] = (_a2 = payloadMapping[config.payloadType]) != null ? _a2 : config.payloadType;\n defaultFetchOptions.body = config.payloadType === \"json\" ? JSON.stringify(unref(config.payload)) : unref(config.payload);\n }\n let isCanceled = false;\n const context = { url: unref(url), options: __spreadValues$9(__spreadValues$9({}, defaultFetchOptions), fetchOptions), cancel: () => {\n isCanceled = true;\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 new Promise((resolve, reject) => {\n var _a3;\n fetch(context.url, __spreadProps$3(__spreadValues$9(__spreadValues$9({}, defaultFetchOptions), context.options), {\n headers: __spreadValues$9(__spreadValues$9({}, headersToObject(defaultFetchOptions.headers)), headersToObject((_a3 = context.options) == null ? void 0 : _a3.headers))\n })).then(async (fetchResponse) => {\n response.value = fetchResponse;\n statusCode.value = fetchResponse.status;\n responseData = await fetchResponse[config.type]();\n if (options.afterFetch && statusCode.value >= 200 && statusCode.value < 300)\n ({ data: responseData } = await options.afterFetch({ data: responseData, response: fetchResponse }));\n data.value = responseData;\n if (!fetchResponse.ok)\n throw new Error(fetchResponse.statusText);\n responseEvent.trigger(fetchResponse);\n return resolve(fetchResponse);\n }).catch(async (fetchError) => {\n let errorData = fetchError.message || fetchError.name;\n if (options.onFetchError)\n ({ data: responseData, error: errorData } = await options.onFetchError({ data: responseData, error: fetchError, response: response.value }));\n data.value = responseData;\n error.value = errorData;\n errorEvent.trigger(fetchError);\n if (throwOnFailed)\n return reject(fetchError);\n return resolve(null);\n }).finally(() => {\n loading(false);\n if (timer)\n timer.stop();\n finallyEvent.trigger(null);\n });\n });\n };\n watch(() => [\n unref(url),\n unref(options.refetch)\n ], () => unref(options.refetch) && execute(), { deep: true });\n const shell = {\n isFinished,\n statusCode,\n response,\n error,\n data,\n isFetching,\n canAbort,\n aborted,\n abort,\n execute,\n onFetchResponse: responseEvent.on,\n onFetchError: errorEvent.on,\n onFetchFinally: finallyEvent.on,\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 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 unref(config.payload),\n unref(options.refetch)\n ], () => unref(options.refetch) && execute(), { deep: true });\n }\n if (!payloadType && unref(payload) && Object.getPrototypeOf(unref(payload)) === Object.prototype)\n config.payloadType = \"json\";\n return shell;\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((error2) => reject(error2));\n });\n }\n function setType(type) {\n return () => {\n if (!isFetching.value) {\n config.type = type;\n return __spreadProps$3(__spreadValues$9({}, 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 setTimeout(execute, 0);\n return __spreadProps$3(__spreadValues$9({}, 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 return `${start}${end}`;\n}\n\nvar __defProp$8 = Object.defineProperty;\nvar __getOwnPropSymbols$9 = Object.getOwnPropertySymbols;\nvar __hasOwnProp$9 = Object.prototype.hasOwnProperty;\nvar __propIsEnum$9 = Object.prototype.propertyIsEnumerable;\nvar __defNormalProp$8 = (obj, key, value) => key in obj ? __defProp$8(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;\nvar __spreadValues$8 = (a, b) => {\n for (var prop in b || (b = {}))\n if (__hasOwnProp$9.call(b, prop))\n __defNormalProp$8(a, prop, b[prop]);\n if (__getOwnPropSymbols$9)\n for (var prop of __getOwnPropSymbols$9(b)) {\n if (__propIsEnum$9.call(b, prop))\n __defNormalProp$8(a, prop, b[prop]);\n }\n return a;\n};\nfunction useFileSystemAccess(options = {}) {\n const {\n window: _window = defaultWindow,\n dataType = \"Text\"\n } = unref(options);\n const window = _window;\n const isSupported = Boolean(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)\n return;\n const [handle] = await window.showOpenFilePicker(__spreadValues$8(__spreadValues$8({}, unref(options)), _options));\n fileHandle.value = handle;\n await updateFile();\n await updateData();\n }\n async function create(_options = {}) {\n if (!isSupported)\n return;\n fileHandle.value = await window.showSaveFilePicker(__spreadValues$8(__spreadValues$8({}, unref(options)), _options));\n data.value = void 0;\n await updateFile();\n await updateData();\n }\n async function save(_options = {}) {\n if (!isSupported)\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)\n return;\n fileHandle.value = await window.showSaveFilePicker(__spreadValues$8(__spreadValues$8({}, unref(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 if (unref(dataType) === \"Text\")\n data.value = await ((_a = file.value) == null ? void 0 : _a.text());\n if (unref(dataType) === \"ArrayBuffer\")\n data.value = await ((_b = file.value) == null ? void 0 : _b.arrayBuffer());\n if (unref(dataType) === \"Blob\")\n data.value = file.value;\n }\n watch(() => unref(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 } = options;\n const activeElement = useActiveElement(options);\n const targetElement = computed(() => unrefElement(target));\n const focused = computed({\n get() {\n return activeElement.value === targetElement.value;\n },\n set(value) {\n var _a, _b;\n if (!value && focused.value)\n (_a = targetElement.value) == null ? void 0 : _a.blur();\n if (value && !focused.value)\n (_b = targetElement.value) == null ? void 0 : _b.focus();\n }\n });\n watch(targetElement, () => {\n focused.value = initialValue;\n }, { immediate: true, flush: \"post\" });\n return { focused };\n}\n\nfunction useFocusWithin(target, options = {}) {\n const activeElement = useActiveElement(options);\n const targetElement = computed(() => unrefElement(target));\n const focused = computed(() => targetElement.value && activeElement.value ? targetElement.value.contains(activeElement.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 functionsMap = [\n [\n \"requestFullscreen\",\n \"exitFullscreen\",\n \"fullscreenElement\",\n \"fullscreenEnabled\",\n \"fullscreenchange\",\n \"fullscreenerror\"\n ],\n [\n \"webkitRequestFullscreen\",\n \"webkitExitFullscreen\",\n \"webkitFullscreenElement\",\n \"webkitFullscreenEnabled\",\n \"webkitfullscreenchange\",\n \"webkitfullscreenerror\"\n ],\n [\n \"webkitRequestFullScreen\",\n \"webkitCancelFullScreen\",\n \"webkitCurrentFullScreenElement\",\n \"webkitCancelFullScreen\",\n \"webkitfullscreenchange\",\n \"webkitfullscreenerror\"\n ],\n [\n \"mozRequestFullScreen\",\n \"mozCancelFullScreen\",\n \"mozFullScreenElement\",\n \"mozFullScreenEnabled\",\n \"mozfullscreenchange\",\n \"mozfullscreenerror\"\n ],\n [\n \"msRequestFullscreen\",\n \"msExitFullscreen\",\n \"msFullscreenElement\",\n \"msFullscreenEnabled\",\n \"MSFullscreenChange\",\n \"MSFullscreenError\"\n ]\n];\nfunction useFullscreen(target, options = {}) {\n const { document = defaultDocument, autoExit = false } = options;\n const targetRef = target || (document == null ? void 0 : document.querySelector(\"html\"));\n const isFullscreen = ref(false);\n let isSupported = false;\n let map = functionsMap[0];\n if (!document) {\n isSupported = false;\n } else {\n for (const m of functionsMap) {\n if (m[1] in document) {\n map = m;\n isSupported = true;\n break;\n }\n }\n }\n const [REQUEST, EXIT, ELEMENT, , EVENT] = map;\n async function exit() {\n if (!isSupported)\n return;\n if (document == null ? void 0 : document[ELEMENT])\n await document[EXIT]();\n isFullscreen.value = false;\n }\n async function enter() {\n if (!isSupported)\n return;\n await exit();\n const target2 = unrefElement(targetRef);\n if (target2) {\n await target2[REQUEST]();\n isFullscreen.value = true;\n }\n }\n async function toggle() {\n if (isFullscreen.value)\n await exit();\n else\n await enter();\n }\n if (document) {\n useEventListener(document, EVENT, () => {\n isFullscreen.value = !!(document == null ? void 0 : document[ELEMENT]);\n }, false);\n }\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 = 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 hapticActuators,\n index: gamepad.index,\n mapping: gamepad.mapping,\n connected: gamepad.connected,\n timestamp: gamepad.timestamp,\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 (let i = 0; i < _gamepads.length; ++i) {\n const gamepad = _gamepads[i];\n if (gamepad) {\n const index = gamepads.value.findIndex(({ index: index2 }) => index2 === gamepad.index);\n if (index > -1)\n gamepads.value[index] = stateFromGamepad(gamepad);\n }\n }\n };\n const { isActive, pause, resume } = useRafFn$1(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$1(\"gamepadconnected\", (e) => onGamepadConnected(e.gamepad));\n useEventListener$1(\"gamepaddisconnected\", (e) => onGamepadDisconnected(e.gamepad));\n tryOnMounted(() => {\n const _gamepads = (navigator == null ? void 0 : navigator.getGamepads()) || [];\n if (_gamepads) {\n for (let i = 0; i < _gamepads.length; ++i) {\n const gamepad = _gamepads[i];\n if (gamepad)\n onGamepadConnected(gamepad);\n }\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 } = options;\n const isSupported = navigator && \"geolocation\" in navigator;\n const locatedAt = ref(null);\n const error = ref(null);\n const coords = ref({\n accuracy: 0,\n latitude: Infinity,\n longitude: 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 if (isSupported) {\n watcher = navigator.geolocation.watchPosition(updatePosition, (err) => error.value = err, {\n enableHighAccuracy,\n maximumAge,\n timeout\n });\n }\n tryOnScopeDispose(() => {\n if (watcher && navigator)\n navigator.geolocation.clearWatch(watcher);\n });\n return {\n isSupported,\n coords,\n locatedAt,\n error\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 onEvent = createFilterWrapper(eventFilter, () => {\n idle.value = false;\n lastActive.value = timestamp();\n clearTimeout(timer);\n timer = setTimeout(() => idle.value = true, timeout);\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 }\n timer = setTimeout(() => idle.value = true, timeout);\n return { idle, lastActive };\n}\n\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 } = options;\n const x = ref(0);\n const y = ref(0);\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 if (element) {\n const onScrollEnd = useDebounceFn((e) => {\n isScrolling.value = false;\n directions.left = false;\n directions.right = false;\n directions.top = false;\n directions.bottom = false;\n onStop(e);\n }, throttle + idle);\n const onScrollHandler = (e) => {\n const eventTarget = e.target === document ? e.target.documentElement : e.target;\n const scrollLeft = eventTarget.scrollLeft;\n directions.left = scrollLeft < x.value;\n directions.right = scrollLeft > x.value;\n arrivedState.left = scrollLeft <= 0 + (offset.left || 0);\n arrivedState.right = scrollLeft + eventTarget.clientWidth >= eventTarget.scrollWidth - (offset.right || 0);\n x.value = scrollLeft;\n const scrollTop = eventTarget.scrollTop;\n directions.top = scrollTop < y.value;\n directions.bottom = scrollTop > y.value;\n arrivedState.top = scrollTop <= 0 + (offset.top || 0);\n arrivedState.bottom = scrollTop + eventTarget.clientHeight >= eventTarget.scrollHeight - (offset.bottom || 0);\n y.value = scrollTop;\n isScrolling.value = true;\n onScrollEnd(e);\n onScroll(e);\n };\n useEventListener(element, \"scroll\", throttle ? useThrottleFn(onScrollHandler, throttle) : onScrollHandler, eventListenerOptions);\n }\n return {\n x,\n y,\n isScrolling,\n arrivedState,\n directions\n };\n}\n\nvar __defProp$7 = Object.defineProperty;\nvar __defProps$2 = Object.defineProperties;\nvar __getOwnPropDescs$2 = Object.getOwnPropertyDescriptors;\nvar __getOwnPropSymbols$8 = Object.getOwnPropertySymbols;\nvar __hasOwnProp$8 = Object.prototype.hasOwnProperty;\nvar __propIsEnum$8 = Object.prototype.propertyIsEnumerable;\nvar __defNormalProp$7 = (obj, key, value) => key in obj ? __defProp$7(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;\nvar __spreadValues$7 = (a, b) => {\n for (var prop in b || (b = {}))\n if (__hasOwnProp$8.call(b, prop))\n __defNormalProp$7(a, prop, b[prop]);\n if (__getOwnPropSymbols$8)\n for (var prop of __getOwnPropSymbols$8(b)) {\n if (__propIsEnum$8.call(b, prop))\n __defNormalProp$7(a, prop, b[prop]);\n }\n return a;\n};\nvar __spreadProps$2 = (a, b) => __defProps$2(a, __getOwnPropDescs$2(b));\nfunction useInfiniteScroll(element, onLoadMore, options = {}) {\n var _a;\n const state = reactive(useScroll(element, __spreadProps$2(__spreadValues$7({}, options), {\n offset: __spreadValues$7({\n bottom: (_a = options.distance) != null ? _a : 0\n }, options.offset)\n })));\n watch(() => state.arrivedState.bottom, (v) => {\n if (v)\n onLoadMore(state);\n });\n}\n\nfunction useIntersectionObserver(target, callback, options = {}) {\n const {\n root,\n rootMargin = \"0px\",\n threshold = 0.1,\n window = defaultWindow\n } = options;\n const isSupported = window && \"IntersectionObserver\" in window;\n let cleanup = noop;\n const stopWatch = isSupported ? watch(() => ({\n el: unrefElement(target),\n root: unrefElement(root)\n }), ({ el, root: root2 }) => {\n cleanup();\n if (!el)\n return;\n const observer = new IntersectionObserver(callback, {\n root: root2,\n rootMargin,\n threshold\n });\n observer.observe(el);\n cleanup = () => {\n observer.disconnect();\n cleanup = noop;\n };\n }, { immediate: true, flush: \"post\" }) : noop;\n const stop = () => {\n cleanup();\n stopWatch();\n };\n tryOnScopeDispose(stop);\n return {\n isSupported,\n stop\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 = { toJSON() {\n return {};\n }, current };\n const refs = useReactive ? reactive(obj) : obj;\n const metaDeps = /* @__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 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 (code) {\n if (value)\n current.add(e.code);\n else\n current.delete(e.code);\n }\n for (const key2 of values)\n setRefs(key2, value);\n if (key === \"meta\" && !value) {\n metaDeps.forEach((key2) => {\n current.delete(key2);\n setRefs(key2, false);\n });\n metaDeps.clear();\n } else if (e.getModifierState(\"Meta\") && value) {\n [...current, ...values].forEach((key2) => metaDeps.add(key2));\n }\n }\n if (target) {\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 }\n const proxy = new Proxy(refs, {\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) => unref(proxy[key])));\n } else {\n refs[prop] = ref(false);\n }\n }\n const r = Reflect.get(target2, prop, rec);\n return useReactive ? unref(r) : r;\n }\n });\n return proxy;\n}\n\nvar __defProp$6 = Object.defineProperty;\nvar __getOwnPropSymbols$7 = Object.getOwnPropertySymbols;\nvar __hasOwnProp$7 = Object.prototype.hasOwnProperty;\nvar __propIsEnum$7 = Object.prototype.propertyIsEnumerable;\nvar __defNormalProp$6 = (obj, key, value) => key in obj ? __defProp$6(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;\nvar __spreadValues$6 = (a, b) => {\n for (var prop in b || (b = {}))\n if (__hasOwnProp$7.call(b, prop))\n __defNormalProp$6(a, prop, b[prop]);\n if (__getOwnPropSymbols$7)\n for (var prop of __getOwnPropSymbols$7(b)) {\n if (__propIsEnum$7.call(b, prop))\n __defNormalProp$6(a, prop, b[prop]);\n }\n return a;\n};\nfunction usingElRef(source, cb) {\n if (unref(source))\n cb(unref(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 options = __spreadValues$6(__spreadValues$6({}, defaultOptions), options);\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 disableTrack = (track) => {\n usingElRef(target, (el) => {\n if (track) {\n const id = isNumber(track) ? 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 = isNumber(track) ? 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 = unref(target);\n if (!el)\n return;\n const src = unref(options.src);\n let sources = [];\n if (!src)\n return;\n if (isString(src))\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 = unref(target);\n if (!el)\n return;\n el.querySelectorAll(\"source\").forEach((e) => e.removeEventListener(\"error\", sourceErrorEvent.trigger));\n });\n watch(volume, (vol) => {\n const el = unref(target);\n if (!el)\n return;\n el.volume = vol;\n });\n watch(muted, (mute) => {\n const el = unref(target);\n if (!el)\n return;\n el.muted = mute;\n });\n watch(rate, (rate2) => {\n const el = unref(target);\n if (!el)\n return;\n el.playbackRate = rate2;\n });\n watchEffect(() => {\n if (!document)\n return;\n const textTracks = unref(options.tracks);\n const el = unref(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 = unref(target);\n if (!el)\n return;\n el.currentTime = time;\n });\n const { ignoreUpdates: ignorePlayingUpdates } = watchIgnorable(playing, (isPlaying) => {\n const el = unref(target);\n if (!el)\n return;\n isPlaying ? el.play() : el.pause();\n });\n useEventListener(target, \"timeupdate\", () => ignoreCurrentTimeUpdates(() => currentTime.value = unref(target).currentTime));\n useEventListener(target, \"durationchange\", () => duration.value = unref(target).duration);\n useEventListener(target, \"progress\", () => buffered.value = timeRangeToArray(unref(target).buffered));\n useEventListener(target, \"seeking\", () => seeking.value = true);\n useEventListener(target, \"seeked\", () => seeking.value = false);\n useEventListener(target, \"waiting\", () => waiting.value = true);\n useEventListener(target, \"playing\", () => waiting.value = false);\n useEventListener(target, \"ratechange\", () => rate.value = unref(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 = unref(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 = unref(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 muted,\n tracks,\n selectedTrack,\n enableTrack,\n disableTrack,\n supportsPictureInPicture,\n togglePictureInPicture,\n isPictureInPicture,\n onSourceError: sourceErrorEvent.on\n };\n}\n\nconst getMapVue2Compat = () => {\n const data = reactive({});\n return {\n get: (key) => data[key],\n set: (key, value) => set(data, key, value),\n has: (key) => Object.prototype.hasOwnProperty.call(data, key),\n delete: (key) => del(data, key),\n clear: () => {\n Object.keys(data).forEach((key) => {\n del(data, key);\n });\n }\n };\n};\nfunction useMemoize(resolver, options) {\n const initCache = () => {\n if (options == null ? void 0 : options.cache)\n return reactive(options.cache);\n if (isVue2)\n return getMapVue2Compat();\n return reactive(/* @__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 = typeof performance !== \"undefined\" && \"memory\" in performance;\n if (isSupported) {\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\nfunction useMounted() {\n const isMounted = ref(false);\n onMounted(() => {\n isMounted.value = true;\n });\n return isMounted;\n}\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 eventFilter\n } = options;\n const x = ref(initialValue.x);\n const y = ref(initialValue.y);\n const sourceType = ref(null);\n const mouseHandler = (event) => {\n if (type === \"page\") {\n x.value = event.pageX;\n y.value = event.pageY;\n } else if (type === \"client\") {\n x.value = event.clientX;\n y.value = event.clientY;\n }\n sourceType.value = \"mouse\";\n };\n const reset = () => {\n x.value = initialValue.x;\n y.value = initialValue.y;\n };\n const touchHandler = (event) => {\n if (event.touches.length > 0) {\n const touch2 = event.touches[0];\n if (type === \"page\") {\n x.value = touch2.pageX;\n y.value = touch2.pageY;\n } else if (type === \"client\") {\n x.value = touch2.clientX;\n y.value = touch2.clientY;\n }\n sourceType.value = \"touch\";\n }\n };\n const mouseHandlerWrapper = (event) => {\n return eventFilter === void 0 ? mouseHandler(event) : eventFilter(() => mouseHandler(event), {});\n };\n const touchHandlerWrapper = (event) => {\n return eventFilter === void 0 ? touchHandler(event) : eventFilter(() => touchHandler(event), {});\n };\n if (window) {\n useEventListener(window, \"mousemove\", mouseHandlerWrapper, { passive: true });\n useEventListener(window, \"dragover\", mouseHandlerWrapper, { passive: true });\n if (touch) {\n useEventListener(window, \"touchstart\", touchHandlerWrapper, { passive: true });\n useEventListener(window, \"touchmove\", touchHandlerWrapper, { passive: true });\n if (resetOnTouchEnds)\n useEventListener(window, \"touchend\", reset, { passive: true });\n }\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 { 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(false);\n let stop = () => {\n };\n if (window) {\n stop = watch([targetRef, x, y], () => {\n const el = unrefElement(targetRef);\n if (!el)\n return;\n const {\n left,\n top,\n width,\n height\n } = el.getBoundingClientRect();\n elementPositionX.value = left + window.pageXOffset;\n elementPositionY.value = top + window.pageYOffset;\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 = elX < 0 || elY < 0 || elX > elementWidth.value || elY > elementHeight.value;\n if (handleOutside || !isOutside.value) {\n elementX.value = elX;\n elementY.value = elY;\n }\n }, { immediate: true });\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 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 });\n useEventListener(window, \"mouseleave\", onReleased, { passive: true });\n useEventListener(window, \"mouseup\", onReleased, { passive: true });\n if (drag) {\n useEventListener(target, \"dragstart\", onPressed(\"mouse\"), { passive: true });\n useEventListener(window, \"drop\", onReleased, { passive: true });\n useEventListener(window, \"dragend\", onReleased, { passive: true });\n }\n if (touch) {\n useEventListener(target, \"touchstart\", onPressed(\"touch\"), { passive: true });\n useEventListener(window, \"touchend\", onReleased, { passive: true });\n useEventListener(window, \"touchcancel\", onReleased, { passive: true });\n }\n return {\n pressed,\n sourceType\n };\n}\n\nvar __getOwnPropSymbols$6 = Object.getOwnPropertySymbols;\nvar __hasOwnProp$6 = Object.prototype.hasOwnProperty;\nvar __propIsEnum$6 = Object.prototype.propertyIsEnumerable;\nvar __objRest$1 = (source, exclude) => {\n var target = {};\n for (var prop in source)\n if (__hasOwnProp$6.call(source, prop) && exclude.indexOf(prop) < 0)\n target[prop] = source[prop];\n if (source != null && __getOwnPropSymbols$6)\n for (var prop of __getOwnPropSymbols$6(source)) {\n if (exclude.indexOf(prop) < 0 && __propIsEnum$6.call(source, prop))\n target[prop] = source[prop];\n }\n return target;\n};\nfunction useMutationObserver(target, callback, options = {}) {\n const _a = options, { window = defaultWindow } = _a, mutationOptions = __objRest$1(_a, [\"window\"]);\n let observer;\n const isSupported = window && \"IntersectionObserver\" in window;\n const cleanup = () => {\n if (observer) {\n observer.disconnect();\n observer = void 0;\n }\n };\n const stopWatch = watch(() => unrefElement(target), (el) => {\n cleanup();\n if (isSupported && window && el) {\n observer = new MutationObserver(callback);\n observer.observe(el, mutationOptions);\n }\n }, { immediate: true });\n const stop = () => {\n cleanup();\n stopWatch();\n };\n tryOnScopeDispose(stop);\n return {\n isSupported,\n stop\n };\n}\n\nconst useNavigatorLanguage = (options = {}) => {\n const { window = defaultWindow } = options;\n const navigator = window == null ? void 0 : window.navigator;\n const isSupported = Boolean(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 = Boolean(navigator && \"connection\" in navigator);\n const isOnline = ref(true);\n const saveData = ref(false);\n const offlineAt = 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 && 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 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 });\n }\n if (connection)\n useEventListener(connection, \"change\", updateNetworkInformation, false);\n updateNetworkInformation();\n return {\n isSupported,\n isOnline,\n saveData,\n offlineAt,\n downlink,\n downlinkMax,\n effectiveType,\n rtt,\n type\n };\n}\n\nvar __defProp$5 = Object.defineProperty;\nvar __getOwnPropSymbols$5 = Object.getOwnPropertySymbols;\nvar __hasOwnProp$5 = Object.prototype.hasOwnProperty;\nvar __propIsEnum$5 = Object.prototype.propertyIsEnumerable;\nvar __defNormalProp$5 = (obj, key, value) => key in obj ? __defProp$5(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;\nvar __spreadValues$5 = (a, b) => {\n for (var prop in b || (b = {}))\n if (__hasOwnProp$5.call(b, prop))\n __defNormalProp$5(a, prop, b[prop]);\n if (__getOwnPropSymbols$5)\n for (var prop of __getOwnPropSymbols$5(b)) {\n if (__propIsEnum$5.call(b, prop))\n __defNormalProp$5(a, prop, b[prop]);\n }\n return a;\n};\nfunction useNow(options = {}) {\n const {\n controls: exposeControls = false,\n interval = \"requestAnimationFrame\"\n } = options;\n const now = ref(new Date());\n const update = () => now.value = new Date();\n const controls = interval === \"requestAnimationFrame\" ? useRafFn(update, { immediate: true }) : useIntervalFn(update, interval, { immediate: true });\n if (exposeControls) {\n return __spreadValues$5({\n now\n }, controls);\n } else {\n return now;\n }\n}\n\nfunction useOffsetPagination(options) {\n const {\n total = Infinity,\n pageSize = 10,\n page = 1,\n onPageChange = noop,\n onPageSizeChange = noop,\n onPageCountChange = noop\n } = options;\n const currentPageSize = useClamp(pageSize, 1, Infinity);\n const pageCount = computed(() => Math.ceil(unref(total) / unref(currentPageSize)));\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 if (isRef(pageSize))\n syncRef(pageSize, currentPageSize);\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 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 {\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 return \"mouse\";\n });\n const roll = computed(() => {\n if (source.value === \"deviceOrientation\") {\n const value = -orientation.beta / 90;\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 const value = orientation.gamma / 90;\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\nvar __defProp$4 = Object.defineProperty;\nvar __defProps$1 = Object.defineProperties;\nvar __getOwnPropDescs$1 = Object.getOwnPropertyDescriptors;\nvar __getOwnPropSymbols$4 = Object.getOwnPropertySymbols;\nvar __hasOwnProp$4 = Object.prototype.hasOwnProperty;\nvar __propIsEnum$4 = Object.prototype.propertyIsEnumerable;\nvar __defNormalProp$4 = (obj, key, value) => key in obj ? __defProp$4(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;\nvar __spreadValues$4 = (a, b) => {\n for (var prop in b || (b = {}))\n if (__hasOwnProp$4.call(b, prop))\n __defNormalProp$4(a, prop, b[prop]);\n if (__getOwnPropSymbols$4)\n for (var prop of __getOwnPropSymbols$4(b)) {\n if (__propIsEnum$4.call(b, prop))\n __defNormalProp$4(a, prop, b[prop]);\n }\n return a;\n};\nvar __spreadProps$1 = (a, b) => __defProps$1(a, __getOwnPropDescs$1(b));\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 useEventListener(target, \"pointerdown\", handler, { passive: true });\n useEventListener(target, \"pointermove\", handler, { passive: true });\n useEventListener(target, \"pointerleave\", () => isInside.value = false, { passive: true });\n }\n return __spreadProps$1(__spreadValues$4({}, toRefs(state)), {\n isInside\n });\n}\n\nvar SwipeDirection = /* @__PURE__ */ ((SwipeDirection2) => {\n SwipeDirection2[\"UP\"] = \"UP\";\n SwipeDirection2[\"RIGHT\"] = \"RIGHT\";\n SwipeDirection2[\"DOWN\"] = \"DOWN\";\n SwipeDirection2[\"LEFT\"] = \"LEFT\";\n SwipeDirection2[\"NONE\"] = \"NONE\";\n return SwipeDirection2;\n})(SwipeDirection || {});\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\" /* NONE */;\n if (abs(diffX.value) > abs(diffY.value)) {\n return diffX.value > 0 ? \"LEFT\" /* LEFT */ : \"RIGHT\" /* RIGHT */;\n } else {\n return diffY.value > 0 ? \"UP\" /* UP */ : \"DOWN\" /* 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 (listenerOptions.capture && !listenerOptions.passive)\n e.preventDefault();\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 const [x, y] = getTouchEventCoords(e);\n updateCoordsEnd(x, y);\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\", onTouchEnd, listenerOptions),\n useEventListener(target, \"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 usePointerSwipe(target, options = {}) {\n const targetRef = ref(target);\n const {\n threshold = 50,\n onSwipe,\n onSwipeEnd,\n onSwipeStart\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 SwipeDirection.NONE;\n if (abs(distanceX.value) > abs(distanceY.value)) {\n return distanceX.value > 0 ? SwipeDirection.LEFT : SwipeDirection.RIGHT;\n } else {\n return distanceY.value > 0 ? SwipeDirection.UP : SwipeDirection.DOWN;\n }\n });\n const filterEvent = (e) => {\n if (options.pointerTypes)\n return options.pointerTypes.includes(e.pointerType);\n return true;\n };\n const stops = [\n useEventListener(target, \"pointerdown\", (e) => {\n var _a, _b;\n if (!filterEvent(e))\n return;\n isPointerDown.value = true;\n (_b = (_a = targetRef.value) == null ? void 0 : _a.style) == null ? void 0 : _b.setProperty(\"touch-action\", \"none\");\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 (!filterEvent(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 var _a, _b;\n if (!filterEvent(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 (_b = (_a = targetRef.value) == null ? void 0 : _a.style) == null ? void 0 : _b.setProperty(\"touch-action\", \"initial\");\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 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\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=\"${src}\"]`);\n if (!el) {\n el = document.createElement(\"script\");\n el.type = type;\n el.async = async;\n el.src = unref(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=\"${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\nvar _a, _b;\nfunction preventDefault(rawEvent) {\n const e = rawEvent || window.event;\n if (e.touches.length > 1)\n return true;\n if (e.preventDefault)\n e.preventDefault();\n return false;\n}\nconst isIOS = isClient && (window == null ? void 0 : window.navigator) && ((_a = window == null ? void 0 : window.navigator) == null ? void 0 : _a.platform) && /iP(ad|hone|od)/.test((_b = window == null ? void 0 : window.navigator) == null ? void 0 : _b.platform);\nfunction useScrollLock(element, initialState = false) {\n const isLocked = ref(initialState);\n let touchMoveListener = null;\n let initialOverflow;\n watch(() => unref(element), (el) => {\n if (el) {\n const ele = el;\n initialOverflow = ele.style.overflow;\n if (isLocked.value)\n ele.style.overflow = \"hidden\";\n }\n }, {\n immediate: true\n });\n const lock = () => {\n const ele = unref(element);\n if (!ele || isLocked.value)\n return;\n if (isIOS) {\n touchMoveListener = useEventListener(document, \"touchmove\", preventDefault, { passive: false });\n }\n ele.style.overflow = \"hidden\";\n isLocked.value = true;\n };\n const unlock = () => {\n const ele = unref(element);\n if (!ele || !isLocked.value)\n return;\n isIOS && (touchMoveListener == null ? void 0 : touchMoveListener());\n ele.style.overflow = initialOverflow;\n isLocked.value = false;\n };\n return computed({\n get() {\n return isLocked.value;\n },\n set(v) {\n if (v)\n lock();\n else\n 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\nvar __defProp$3 = Object.defineProperty;\nvar __getOwnPropSymbols$3 = Object.getOwnPropertySymbols;\nvar __hasOwnProp$3 = Object.prototype.hasOwnProperty;\nvar __propIsEnum$3 = Object.prototype.propertyIsEnumerable;\nvar __defNormalProp$3 = (obj, key, value) => key in obj ? __defProp$3(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;\nvar __spreadValues$3 = (a, b) => {\n for (var prop in b || (b = {}))\n if (__hasOwnProp$3.call(b, prop))\n __defNormalProp$3(a, prop, b[prop]);\n if (__getOwnPropSymbols$3)\n for (var prop of __getOwnPropSymbols$3(b)) {\n if (__propIsEnum$3.call(b, prop))\n __defNormalProp$3(a, prop, b[prop]);\n }\n return a;\n};\nfunction useShare(shareOptions = {}, options = {}) {\n const { navigator = defaultNavigator } = options;\n const _navigator = navigator;\n const isSupported = _navigator && \"canShare\" in _navigator;\n const share = async (overrideOptions = {}) => {\n if (isSupported) {\n const data = __spreadValues$3(__spreadValues$3({}, unref(shareOptions)), unref(overrideOptions));\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\nfunction useSpeechRecognition(options = {}) {\n const {\n interimResults = true,\n continuous = true,\n window = defaultWindow\n } = options;\n const lang = ref(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 = Boolean(SpeechRecognition);\n let recognition;\n if (isSupported) {\n recognition = new SpeechRecognition();\n recognition.continuous = continuous;\n recognition.interimResults = interimResults;\n recognition.lang = unref(lang);\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 transcript = Array.from(event.results).map((result2) => {\n isFinal.value = result2.isFinal;\n return result2[0];\n }).map((result2) => result2.transcript).join(\"\");\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 = unref(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 var _a, _b;\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 = Boolean(synth);\n const isPlaying = ref(false);\n const status = ref(\"init\");\n const voiceInfo = {\n lang: ((_a = options.voice) == null ? void 0 : _a.lang) || \"default\",\n name: ((_b = options.voice) == null ? void 0 : _b.name) || \"\"\n };\n const spokenText = ref(text || \"\");\n const lang = ref(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 = unref(lang);\n options.voice && (utterance2.voice = options.voice);\n utterance2.pitch = pitch;\n utterance2.rate = 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 utterance2.onend = () => {\n isPlaying.value = false;\n utterance2.lang = unref(lang);\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 utterance && synth.speak(utterance.value);\n };\n if (isSupported) {\n bindEventsForUtterance(utterance.value);\n watch(lang, (lang2) => {\n if (utterance.value && !isPlaying.value)\n utterance.value.lang = lang2;\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 voiceInfo,\n utterance,\n error,\n toggle,\n speak\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 shallow,\n window = defaultWindow,\n eventFilter,\n onError = (e) => {\n console.error(e);\n }\n } = options;\n const rawInit = unref(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(\"getDefaultStorage\", () => {\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 {\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) => setTimeout(() => read(e), 0));\n if (storage) {\n watchWithFilter(data, 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 flush,\n deep,\n eventFilter\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 el.type = \"text/css\";\n el.id = id;\n if (options.media)\n el.media = options.media;\n document.head.appendChild(el);\n if (isLoaded.value)\n return;\n stop = watch(cssRef, (value) => {\n el.innerText = value;\n }, { immediate: true });\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 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 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 getRangesFromSelection(selection) {\n var _a;\n const rangeCount = (_a = selection.rangeCount) != null ? _a : 0;\n const ranges = new Array(rangeCount);\n for (let i = 0; i < rangeCount; i++) {\n const range = selection.getRangeAt(i);\n ranges[i] = range;\n }\n return ranges;\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\nvar __defProp$2 = Object.defineProperty;\nvar __defProps = Object.defineProperties;\nvar __getOwnPropDescs = Object.getOwnPropertyDescriptors;\nvar __getOwnPropSymbols$2 = Object.getOwnPropertySymbols;\nvar __hasOwnProp$2 = Object.prototype.hasOwnProperty;\nvar __propIsEnum$2 = Object.prototype.propertyIsEnumerable;\nvar __defNormalProp$2 = (obj, key, value) => key in obj ? __defProp$2(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;\nvar __spreadValues$2 = (a, b) => {\n for (var prop in b || (b = {}))\n if (__hasOwnProp$2.call(b, prop))\n __defNormalProp$2(a, prop, b[prop]);\n if (__getOwnPropSymbols$2)\n for (var prop of __getOwnPropSymbols$2(b)) {\n if (__propIsEnum$2.call(b, prop))\n __defNormalProp$2(a, prop, b[prop]);\n }\n return a;\n};\nvar __spreadProps = (a, b) => __defProps(a, __getOwnPropDescs(b));\nfunction useThrottledRefHistory(source, options = {}) {\n const { throttle = 200, trailing = true } = options;\n const filter = throttleFilter(throttle, trailing);\n const history = useRefHistory(source, __spreadProps(__spreadValues$2({}, options), { eventFilter: filter }));\n return __spreadValues$2({}, history);\n}\n\nvar __defProp$1 = Object.defineProperty;\nvar __getOwnPropSymbols$1 = Object.getOwnPropertySymbols;\nvar __hasOwnProp$1 = Object.prototype.hasOwnProperty;\nvar __propIsEnum$1 = Object.prototype.propertyIsEnumerable;\nvar __defNormalProp$1 = (obj, key, value) => key in obj ? __defProp$1(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;\nvar __spreadValues$1 = (a, b) => {\n for (var prop in b || (b = {}))\n if (__hasOwnProp$1.call(b, prop))\n __defNormalProp$1(a, prop, b[prop]);\n if (__getOwnPropSymbols$1)\n for (var prop of __getOwnPropSymbols$1(b)) {\n if (__propIsEnum$1.call(b, prop))\n __defNormalProp$1(a, prop, b[prop]);\n }\n return a;\n};\nvar __objRest = (source, exclude) => {\n var target = {};\n for (var prop in source)\n if (__hasOwnProp$1.call(source, prop) && exclude.indexOf(prop) < 0)\n target[prop] = source[prop];\n if (source != null && __getOwnPropSymbols$1)\n for (var prop of __getOwnPropSymbols$1(source)) {\n if (exclude.indexOf(prop) < 0 && __propIsEnum$1.call(source, prop))\n target[prop] = source[prop];\n }\n return target;\n};\nconst 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: 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};\nconst DEFAULT_FORMATTER = (date) => date.toISOString().slice(0, 10);\nfunction useTimeAgo(time, options = {}) {\n const {\n controls: exposeControls = false,\n max,\n updateInterval = 3e4,\n messages = DEFAULT_MESSAGES,\n fullDateFormatter = DEFAULT_FORMATTER\n } = options;\n const { abs, round } = Math;\n const _a = useNow({ interval: updateInterval, controls: true }), { now } = _a, controls = __objRest(_a, [\"now\"]);\n function getTimeago(from, now2) {\n var _a2;\n const diff = +now2 - +from;\n const absDiff = abs(diff);\n if (absDiff < 6e4)\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 = (_a2 = UNITS.find((i) => i.name === max)) == null ? void 0 : _a2.max;\n if (unitMax && absDiff > unitMax)\n return fullDateFormatter(new Date(from));\n }\n for (const unit of UNITS) {\n if (absDiff < unit.max)\n return format(diff, unit);\n }\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 function format(diff, unit) {\n const val = round(abs(diff) / unit.value);\n const past = diff > 0;\n const str = applyFormat(unit.name, val, past);\n return applyFormat(past ? \"past\" : \"future\", str, past);\n }\n const timeAgo = computed(() => getTimeago(new Date(unref(time)), unref(now.value)));\n if (exposeControls) {\n return __spreadValues$1({\n timeAgo\n }, controls);\n } else {\n return timeAgo;\n }\n}\n\nfunction useTimeoutPoll(fn, interval, timeoutPollOptions) {\n const { start } = useTimeoutFn(loop, interval);\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\nvar __defProp = Object.defineProperty;\nvar __getOwnPropSymbols = Object.getOwnPropertySymbols;\nvar __hasOwnProp = Object.prototype.hasOwnProperty;\nvar __propIsEnum = Object.prototype.propertyIsEnumerable;\nvar __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;\nvar __spreadValues = (a, b) => {\n for (var prop in b || (b = {}))\n if (__hasOwnProp.call(b, prop))\n __defNormalProp(a, prop, b[prop]);\n if (__getOwnPropSymbols)\n for (var prop of __getOwnPropSymbols(b)) {\n if (__propIsEnum.call(b, prop))\n __defNormalProp(a, prop, b[prop]);\n }\n return a;\n};\nfunction useTimestamp(options = {}) {\n const {\n controls: exposeControls = false,\n offset = 0,\n immediate = true,\n interval = \"requestAnimationFrame\"\n } = options;\n const ts = ref(timestamp() + offset);\n const update = () => ts.value = timestamp() + offset;\n const controls = interval === \"requestAnimationFrame\" ? useRafFn(update, { immediate }) : useIntervalFn(update, interval, { immediate });\n if (exposeControls) {\n return __spreadValues({\n timestamp: ts\n }, controls);\n } else {\n return ts;\n }\n}\n\nfunction useTitle(newTitle = null, options = {}) {\n var _a, _b;\n const {\n document = defaultDocument,\n observe = false,\n titleTemplate = \"%s\"\n } = options;\n const title = ref((_a = newTitle != null ? newTitle : document == null ? void 0 : document.title) != null ? _a : null);\n watch(title, (t, o) => {\n if (isString(t) && t !== o && document)\n document.title = titleTemplate.replace(\"%s\", t);\n }, { immediate: true });\n if (observe && document) {\n useMutationObserver((_b = document.head) == null ? void 0 : _b.querySelector(\"title\"), () => {\n if (document && document.title !== title.value)\n title.value = titleTemplate.replace(\"%s\", document.title);\n }, { childList: true });\n }\n return title;\n}\n\nconst TransitionPresets = {\n linear: identity,\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};\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 useTransition(source, options = {}) {\n const {\n delay = 0,\n disabled = false,\n duration = 1e3,\n onFinished = noop,\n onStarted = noop,\n transition = identity\n } = options;\n const currentTransition = computed(() => {\n const t = unref(transition);\n return isFunction(t) ? t : createEasingFunction(t);\n });\n const sourceValue = computed(() => {\n const s = unref(source);\n return isNumber(s) ? s : s.map(unref);\n });\n const sourceVector = computed(() => isNumber(sourceValue.value) ? [sourceValue.value] : sourceValue.value);\n const outputVector = ref(sourceVector.value.slice(0));\n let currentDuration;\n let diffVector;\n let endAt;\n let startAt;\n let startVector;\n const { resume, pause } = useRafFn(() => {\n const now = Date.now();\n const progress = clamp(1 - (endAt - now) / currentDuration, 0, 1);\n outputVector.value = startVector.map((val, i) => {\n var _a;\n return val + ((_a = diffVector[i]) != null ? _a : 0) * currentTransition.value(progress);\n });\n if (progress >= 1) {\n pause();\n onFinished();\n }\n }, { immediate: false });\n const start = () => {\n pause();\n currentDuration = unref(duration);\n diffVector = outputVector.value.map((n, i) => {\n var _a, _b;\n return ((_a = sourceVector.value[i]) != null ? _a : 0) - ((_b = outputVector.value[i]) != null ? _b : 0);\n });\n startVector = outputVector.value.slice(0);\n startAt = Date.now();\n endAt = startAt + currentDuration;\n resume();\n onStarted();\n };\n const timeout = useTimeoutFn(start, delay, { immediate: false });\n watch(sourceVector, () => {\n if (unref(disabled)) {\n outputVector.value = sourceVector.value.slice(0);\n } else {\n if (unref(delay) <= 0)\n start();\n else\n timeout.start();\n }\n }, { deep: true });\n return computed(() => {\n const targetVector = unref(disabled) ? sourceVector : outputVector;\n return isNumber(sourceValue.value) ? targetVector.value[0] : targetVector.value;\n });\n}\n\nfunction useUrlSearchParams(mode = \"history\", options = {}) {\n const {\n initialValue = {},\n removeNullishValues = true,\n removeFalsyValues = false,\n window = defaultWindow\n } = options;\n if (!window)\n return reactive(initialValue);\n const state = reactive(initialValue);\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}` : \"\"}${location.hash || \"\"}`;\n if (mode === \"hash-params\")\n return `${location.search || \"\"}${stringified ? `#${stringified}` : \"\"}`;\n const hash = window.location.hash || \"#\";\n const index = hash.indexOf(\"?\");\n if (index > 0)\n return `${hash.slice(0, index)}${stringified ? `?${stringified}` : \"\"}`;\n return `${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(state, () => {\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 }, { deep: true });\n function write(params, shouldUpdate) {\n pause();\n if (shouldUpdate)\n updateState(params);\n window.history.replaceState({}, \"\", window.location.pathname + constructQuery(params));\n resume();\n }\n function onChanged() {\n write(read(), true);\n }\n useEventListener(window, \"popstate\", onChanged, false);\n if (mode !== \"history\")\n useEventListener(window, \"hashchange\", onChanged, false);\n updateState(read());\n return state;\n}\n\nfunction useUserMedia(options = {}) {\n var _a, _b, _c;\n const enabled = ref((_a = options.enabled) != null ? _a : false);\n const autoSwitch = ref((_b = options.autoSwitch) != null ? _b : true);\n const videoDeviceId = ref(options.videoDeviceId);\n const audioDeviceId = ref(options.audioDeviceId);\n const { navigator = defaultNavigator } = options;\n const isSupported = Boolean((_c = navigator == null ? void 0 : navigator.mediaDevices) == null ? void 0 : _c.getUserMedia);\n const stream = shallowRef();\n function getDeviceOptions(device) {\n if (device.value === \"none\" || device.value === false)\n return false;\n if (device.value == null)\n return true;\n return {\n deviceId: device.value\n };\n }\n async function _start() {\n if (!isSupported || stream.value)\n return;\n stream.value = await navigator.mediaDevices.getUserMedia({\n video: getDeviceOptions(videoDeviceId),\n audio: getDeviceOptions(audioDeviceId)\n });\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 async function restart() {\n _stop();\n return await start();\n }\n watch(enabled, (v) => {\n if (v)\n _start();\n else\n _stop();\n }, { immediate: true });\n watch([videoDeviceId, audioDeviceId], () => {\n if (autoSwitch.value && stream.value)\n restart();\n }, { immediate: true });\n return {\n isSupported,\n stream,\n start,\n stop,\n restart,\n videoDeviceId,\n audioDeviceId,\n enabled,\n autoSwitch\n };\n}\n\nfunction useVModel(props, key, emit, options = {}) {\n var _a, _b, _c;\n const {\n passive = false,\n eventName,\n deep = false\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));\n let event = eventName;\n if (!key) {\n if (isVue2) {\n const modelOptions = (_c = (_b = vm == null ? void 0 : vm.proxy) == null ? void 0 : _b.$options) == null ? void 0 : _c.model;\n key = (modelOptions == null ? void 0 : modelOptions.value) || \"value\";\n if (!eventName)\n event = (modelOptions == null ? void 0 : modelOptions.event) || \"input\";\n } else {\n key = \"modelValue\";\n }\n }\n event = eventName || event || `update:${key}`;\n if (passive) {\n const proxy = ref(props[key]);\n watch(() => props[key], (v) => proxy.value = v);\n watch(proxy, (v) => {\n if (v !== props[key] || deep)\n _emit(event, v);\n }, {\n deep\n });\n return proxy;\n } else {\n return computed({\n get() {\n return props[key];\n },\n set(value) {\n _emit(event, value);\n }\n });\n }\n}\n\nfunction useVModels(props, emit, options = {}) {\n const ret = {};\n for (const key in props)\n ret[key] = useVModel(props, key, emit, options);\n return ret;\n}\n\nfunction useVibrate(options) {\n const {\n pattern = [],\n interval = 0,\n navigator = defaultNavigator\n } = options || {};\n const isSupported = typeof navigator !== \"undefined\" && \"vibrate\" in navigator;\n const patternRef = ref(pattern);\n let intervalControls;\n const vibrate = (pattern2 = patternRef.value) => {\n if (isSupported)\n navigator.vibrate(pattern2);\n };\n const stop = () => {\n if (isSupported)\n navigator.vibrate(0);\n intervalControls == null ? void 0 : intervalControls.pause();\n };\n if (interval > 0) {\n intervalControls = useIntervalFn(vibrate, interval, {\n immediate: false,\n immediateCallback: false\n });\n }\n return {\n isSupported,\n pattern,\n intervalControls,\n vibrate,\n stop\n };\n}\n\nfunction useVirtualList(list, options) {\n const containerRef = ref();\n const size = useElementSize(containerRef);\n const currentList = ref([]);\n const source = shallowRef(list);\n const state = ref({ start: 0, end: 10 });\n const { itemHeight, overscan = 5 } = options;\n const getViewCapacity = (containerHeight) => {\n if (typeof itemHeight === \"number\")\n return Math.ceil(containerHeight / itemHeight);\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 height = itemHeight(i);\n sum += height;\n if (sum >= containerHeight) {\n capacity = i;\n break;\n }\n }\n return capacity - start;\n };\n const getOffset = (scrollTop) => {\n if (typeof itemHeight === \"number\")\n return Math.floor(scrollTop / itemHeight) + 1;\n let sum = 0;\n let offset = 0;\n for (let i = 0; i < source.value.length; i++) {\n const height = itemHeight(i);\n sum += height;\n if (sum >= scrollTop) {\n offset = i;\n break;\n }\n }\n return offset + 1;\n };\n const calculateRange = () => {\n const element = containerRef.value;\n if (element) {\n const offset = getOffset(element.scrollTop);\n const viewCapacity = getViewCapacity(element.clientHeight);\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 watch([size.width, size.height, list], () => {\n calculateRange();\n });\n const totalHeight = computed(() => {\n if (typeof itemHeight === \"number\")\n return source.value.length * itemHeight;\n return source.value.reduce((sum, _, index) => sum + itemHeight(index), 0);\n });\n const getDistanceTop = (index) => {\n if (typeof itemHeight === \"number\") {\n const height2 = index * itemHeight;\n return height2;\n }\n const height = source.value.slice(0, index).reduce((sum, _, i) => sum + itemHeight(i), 0);\n return height;\n };\n const scrollTo = (index) => {\n if (containerRef.value) {\n containerRef.value.scrollTop = getDistanceTop(index);\n calculateRange();\n }\n };\n const offsetTop = computed(() => getDistanceTop(state.value.start));\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 const containerStyle = { overflowY: \"auto\" };\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}\n\nconst useWakeLock = (options = {}) => {\n const {\n navigator = defaultNavigator,\n document = defaultDocument\n } = options;\n let wakeLock;\n const isSupported = navigator && \"wakeLock\" in navigator;\n const isActive = ref(false);\n async function onVisibilityChange() {\n if (!isSupported || !wakeLock)\n return;\n if (document && document.visibilityState === \"visible\")\n wakeLock = await navigator.wakeLock.request(\"screen\");\n isActive.value = !wakeLock.released;\n }\n if (document)\n useEventListener(document, \"visibilitychange\", onVisibilityChange, { passive: true });\n async function request(type) {\n if (!isSupported)\n return;\n wakeLock = await navigator.wakeLock.request(type);\n isActive.value = !wakeLock.released;\n }\n async function release() {\n if (!isSupported || !wakeLock)\n return;\n await wakeLock.release();\n isActive.value = !wakeLock.released;\n wakeLock = null;\n }\n return {\n isSupported,\n isActive,\n request,\n release\n };\n};\n\nconst useWebNotification = (defaultOptions = {}) => {\n const {\n window = defaultWindow\n } = defaultOptions;\n const isSupported = !!window && \"Notification\" in window;\n const notification = ref(null);\n const requestPermission = async () => {\n if (!isSupported)\n return;\n if (\"permission\" in Notification && Notification.permission !== \"denied\")\n await Notification.requestPermission();\n };\n const onClick = createEventHook();\n const onShow = createEventHook();\n const onError = createEventHook();\n const onClose = createEventHook();\n const show = async (overrides) => {\n if (!isSupported)\n return;\n await requestPermission();\n const options = Object.assign({}, defaultOptions, overrides);\n notification.value = new Notification(options.title || \"\", options);\n notification.value.onclick = (event) => onClick.trigger(event);\n notification.value.onshow = (event) => onShow.trigger(event);\n notification.value.onerror = (event) => onError.trigger(event);\n notification.value.onclose = (event) => onClose.trigger(event);\n return notification.value;\n };\n const close = () => {\n if (notification.value)\n notification.value.close();\n notification.value = null;\n };\n tryOnMounted(async () => {\n if (isSupported)\n await requestPermission();\n });\n tryOnScopeDispose(close);\n if (isSupported && 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 show,\n close,\n onClick,\n onShow,\n onError,\n onClose\n };\n};\n\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(\"CONNECTING\");\n const wsRef = ref();\n let heartbeatPause;\n let heartbeatResume;\n let explicitlyClosed = false;\n let retried = 0;\n let bufferedData = [];\n const close = (code = 1e3, reason) => {\n if (!wsRef.value)\n return;\n explicitlyClosed = true;\n heartbeatPause == null ? void 0 : heartbeatPause();\n wsRef.value.close(code, reason);\n };\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 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 const ws = new WebSocket(url, protocols);\n wsRef.value = ws;\n status.value = \"CONNECTING\";\n explicitlyClosed = false;\n ws.onopen = () => {\n status.value = \"OPEN\";\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 wsRef.value = void 0;\n onDisconnected == null ? void 0 : onDisconnected(ws, ev);\n if (!explicitlyClosed && options.autoReconnect) {\n const {\n retries = -1,\n delay = 1e3,\n onFailed\n } = resolveNestedOptions(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 ws.onerror = (e) => {\n onError == null ? void 0 : onError(ws, e);\n };\n ws.onmessage = (e) => {\n data.value = e.data;\n onMessage == null ? void 0 : onMessage(ws, e);\n };\n };\n if (options.heartbeat) {\n const {\n message = \"ping\",\n interval = 1e3\n } = resolveNestedOptions(options.heartbeat);\n const { pause, resume } = useIntervalFn(() => send(message, false), interval, { immediate: false });\n heartbeatPause = pause;\n heartbeatResume = resume;\n }\n if (immediate)\n _init();\n if (autoClose) {\n useEventListener(window, \"beforeunload\", () => close());\n tryOnScopeDispose(close);\n }\n const open = () => {\n close();\n retried = 0;\n _init();\n };\n return {\n data,\n status,\n close,\n send,\n open,\n ws: wsRef\n };\n}\n\nfunction useWebWorker(url, workerOptions, options = {}) {\n const {\n window = defaultWindow\n } = options;\n const data = ref(null);\n const worker = shallowRef();\n const post = function post2(val) {\n if (!worker.value)\n return;\n worker.value.postMessage(val);\n };\n const terminate = function terminate2() {\n if (!worker.value)\n return;\n worker.value.terminate();\n };\n if (window) {\n worker.value = new Worker(url, workerOptions);\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\nconst jobRunner = (userFunc) => (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\nconst depsParser = (deps) => {\n if (deps.length === 0)\n return \"\";\n const depsString = deps.map((dep) => `'${dep}'`).toString();\n return `importScripts(${depsString})`;\n};\n\nconst createWorkerBlobUrl = (fn, deps) => {\n const blobCode = `${depsParser(deps)}; onmessage=(${jobRunner})(${fn})`;\n const blob = new Blob([blobCode], { type: \"text/javascript\" });\n const url = URL.createObjectURL(blob);\n return url;\n};\n\nconst useWebWorkerFn = (fn, options = {}) => {\n const {\n dependencies = [],\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);\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 reject(e);\n workerTerminate(\"ERROR\");\n };\n if (timeout) {\n timeoutId.value = setTimeout(() => workerTerminate(\"TIMEOUT_EXPIRED\"), timeout);\n }\n return newWorker;\n };\n const callWorker = (...fnArgs) => new Promise((resolve, reject) => {\n promise.value = {\n resolve,\n reject\n };\n worker.value && worker.value.postMessage([[...fnArgs]]);\n workerStatus.value = \"RUNNING\";\n });\n const workerFn = (...fnArgs) => {\n if (workerStatus.value === \"RUNNING\") {\n console.error(\"[useWebWorkerFn] You can only run one instance of the worker at a time.\");\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({ window = defaultWindow } = {}) {\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({ window = defaultWindow } = {}) {\n if (!window) {\n return {\n x: ref(0),\n y: ref(0)\n };\n }\n const x = ref(window.pageXOffset);\n const y = ref(window.pageYOffset);\n useEventListener(\"scroll\", () => {\n x.value = window.pageXOffset;\n y.value = window.pageYOffset;\n }, {\n capture: false,\n passive: true\n });\n return { x, y };\n}\n\nfunction useWindowSize({ window = defaultWindow, initialWidth = Infinity, initialHeight = Infinity } = {}) {\n const width = ref(initialWidth);\n const height = ref(initialHeight);\n const update = () => {\n if (window) {\n width.value = window.innerWidth;\n height.value = window.innerHeight;\n }\n };\n update();\n tryOnMounted(update);\n useEventListener(\"resize\", update, { passive: true });\n return { width, height };\n}\n\nexport { DefaultMagicKeysAliasMap, StorageSerializers, SwipeDirection, TransitionPresets, computedAsync as asyncComputed, breakpointsAntDesign, breakpointsBootstrapV5, breakpointsQuasar, breakpointsSematic, breakpointsTailwind, breakpointsVuetify, computedAsync, computedInject, createFetch, createUnrefFn, defaultDocument, defaultLocation, defaultNavigator, defaultWindow, getSSRHandler, mapGamepadToXbox360Controller, onClickOutside, onKeyDown, onKeyPressed, onKeyStroke, onKeyUp, onLongPress, onStartTyping, setSSRHandler, templateRef, unrefElement, useActiveElement, useAsyncQueue, useAsyncState, useBase64, useBattery, useBreakpoints, useBroadcastChannel, useBrowserLocation, useCached, useClamp, useClipboard, useColorMode, useConfirmDialog, useCssVar, useCycleList, useDark, useDebouncedRefHistory, useDeviceMotion, useDeviceOrientation, useDevicePixelRatio, useDevicesList, useDisplayMedia, useDocumentVisibility, useDraggable, useElementBounding, useElementByPoint, useElementHover, useElementSize, useElementVisibility, useEventBus, useEventListener, useEventSource, useEyeDropper, useFavicon, useFetch, useFileSystemAccess, useFocus, useFocusWithin, useFps, useFullscreen, useGamepad, useGeolocation, useIdle, useInfiniteScroll, useIntersectionObserver, useKeyModifier, useLocalStorage, useMagicKeys, useManualRefHistory, useMediaControls, useMediaQuery, useMemoize, useMemory, useMounted, useMouse, useMouseInElement, useMousePressed, useMutationObserver, useNavigatorLanguage, useNetwork, useNow, useOffsetPagination, useOnline, usePageLeave, useParallax, usePermission, usePointer, usePointerSwipe, usePreferredColorScheme, usePreferredDark, usePreferredLanguages, useRafFn, useRefHistory, useResizeObserver, useScreenSafeArea, useScriptTag, useScroll, useScrollLock, useSessionStorage, useShare, useSpeechRecognition, useSpeechSynthesis, useStorage, useStorageAsync, useStyleTag, useSwipe, useTemplateRefsList, useTextSelection, useThrottledRefHistory, useTimeAgo, useTimeoutPoll, useTimestamp, useTitle, useTransition, useUrlSearchParams, useUserMedia, useVModel, useVModels, useVibrate, useVirtualList, useWakeLock, useWebNotification, useWebSocket, useWebWorker, useWebWorkerFn, useWindowFocus, useWindowScroll, useWindowSize };\n","import { useStorage } from '@vueuse/core';\nimport type { RemovableRef } from '@vueuse/core';\n\nexport interface UserMeta {\n nick: string;\n mail: string;\n link: string;\n}\n\nexport const useUserMeta = (): RemovableRef<UserMeta> =>\n useStorage<UserMeta>('WALINE_USER_META', {\n nick: '',\n mail: '',\n link: '',\n });\n\nexport const useEditor = (): RemovableRef<string> =>\n useStorage<string>('WALINE_COMMENT_BOX_EDITOR', '');\n","export const decodePath = (path: string): string => {\n try {\n path = decodeURI(path);\n } catch (err) {\n // ignore error\n }\n\n return path;\n};\n\nexport const removeEndingSplash = (content = ''): string =>\n content.replace(/\\/$/u, '');\n\nexport const isLinkHttp = (link: string): boolean =>\n /^(https?:)?\\/\\//.test(link);\n","import {\n defaultLang,\n defaultUploadImage,\n defaultTexRenderer,\n getMeta,\n locales,\n} from '../config';\n\nimport { decodePath, isLinkHttp, removeEndingSplash } from './path';\n\nimport type {\n WalineEmojiInfo,\n WalineEmojiMaps,\n WalineLocale,\n WalineProps,\n} from '../typings';\nimport hanabi from 'hanabi';\n\nexport interface WalineEmojiConfig {\n tabs: Pick<WalineEmojiInfo, 'name' | 'icon' | 'items'>[];\n map: WalineEmojiMaps;\n}\n\nexport interface WalineConfig extends Required<Omit<WalineProps, 'wordLimit'>> {\n locale: WalineLocale;\n wordLimit: [number, number] | false;\n // emoji: Promise<EmojiConfig>;\n}\n\nconst getServerURL = (serverURL: string): string => {\n const result = removeEndingSplash(serverURL);\n\n return isLinkHttp(result) ? result : `https://${result}`;\n};\n\nconst getWordLimit = (\n wordLimit: WalineProps['wordLimit']\n): [number, number] | false =>\n Array.isArray(wordLimit) ? wordLimit : wordLimit ? [0, wordLimit] : false;\n\nconst fallback = <T = unknown>(\n value: T | false | undefined,\n fallback: T\n): T | false =>\n typeof value === 'function' ? value : value === false ? false : fallback;\n\nexport const getConfig = ({\n serverURL,\n\n path = location.pathname,\n lang = defaultLang,\n locale,\n emoji = ['//unpkg.com/@waline/emojis@1.0.1/weibo'],\n meta = ['nick', 'mail', 'link'],\n requiredMeta = [],\n dark = false,\n pageSize = 10,\n wordLimit,\n imageUploader,\n highlighter,\n texRenderer,\n copyright = true,\n login = 'enable',\n ...more\n}: WalineProps): WalineConfig => ({\n serverURL: getServerURL(serverURL),\n path: decodePath(path),\n locale: {\n ...(locales[lang] || locales[defaultLang]),\n ...(typeof locale === 'object' ? locale : {}),\n },\n wordLimit: getWordLimit(wordLimit),\n meta: getMeta(meta),\n requiredMeta: getMeta(requiredMeta),\n imageUploader: fallback(imageUploader, defaultUploadImage),\n highlighter: fallback(highlighter, hanabi),\n texRenderer: fallback(texRenderer, defaultTexRenderer),\n lang,\n dark,\n emoji,\n pageSize,\n login,\n copyright,\n ...more,\n});\n","const style = `{--waline-white:#000;--waline-light-grey:#666;--waline-dark-grey:#999;--waline-color:#888;--waline-bgcolor:#1e1e1e;--waline-bgcolor-light:#272727;--waline-bgcolor-hover: #444;--waline-border-color:#333;--waline-disable-bgcolor:#444;--waline-disable-color:#272727;--waline-bq-color:#272727;--waline-info-bgcolor:#272727;--waline-info-color:#666}`;\n\nexport const getDarkStyle = (selector?: string | boolean): string => {\n if (typeof selector === 'string') {\n return selector === 'auto'\n ? `@media(prefers-color-scheme:dark){body${style}}`\n : `${selector}${style}`;\n }\n\n return selector === true ? `:root${style}` : '';\n};\n","const padWithZeros = (vNumber: number, width: number): string => {\n let numAsString = vNumber.toString();\n\n while (numAsString.length < width) {\n numAsString = '0' + numAsString;\n }\n\n return numAsString;\n};\n\nexport const dateFormat = (date: Date): string => {\n const vDay = padWithZeros(date.getDate(), 2);\n const vMonth = padWithZeros(date.getMonth() + 1, 2);\n const vYear = padWithZeros(date.getFullYear(), 2);\n\n return `${vYear}-${vMonth}-${vDay}`;\n};\n","import { useStorage } from '@vueuse/core';\nimport { removeEndingSplash } from './path';\n\nimport type { WalineEmojiConfig } from './config';\nimport type { WalineEmojiInfo } from '../typings';\n\nconst hasVersion = (url: string): boolean =>\n Boolean(/@[0-9]+\\.[0-9]+\\.[0-9]+/.test(url));\n\nconst fetchEmoji = (link: string): Promise<WalineEmojiInfo> => {\n const emojiStore = useStorage<Record<string, WalineEmojiInfo>>(\n 'WALINE_EMOJI',\n {}\n );\n\n const result = hasVersion(link);\n\n if (result) {\n const info = emojiStore.value[link];\n\n if (info) return Promise.resolve(info);\n }\n\n return fetch(`${link}/info.json`)\n .then((resp) => resp.json() as Promise<Omit<WalineEmojiInfo, 'folder'>>)\n .then((emojiInfo) => {\n const info = {\n folder: link,\n ...emojiInfo,\n };\n\n if (result) emojiStore.value[link] = info;\n\n return info;\n });\n};\n\nconst getLink = (name: string, folder = '', prefix = '', type = ''): string =>\n `${folder ? `${folder}/` : ''}${prefix}${name}${type ? `.${type}` : ''}`;\n\nexport const getEmojis = (\n emojis: (string | WalineEmojiInfo)[]\n): Promise<WalineEmojiConfig> =>\n Promise.all(\n emojis.map((emoji) =>\n typeof emoji === 'string'\n ? fetchEmoji(removeEndingSplash(emoji))\n : Promise.resolve(emoji)\n )\n ).then((emojiInfos) => {\n const emojiConfig: WalineEmojiConfig = {\n tabs: [],\n map: {},\n };\n\n emojiInfos.forEach((emojiInfo) => {\n const { name, folder, icon, prefix, type, items } = emojiInfo;\n\n emojiConfig.tabs.push({\n name,\n icon: getLink(icon, folder, prefix, type),\n items: items.map((item) => {\n const key = `${prefix || ''}${item}`;\n\n emojiConfig.map[key] = getLink(item, folder, prefix, type);\n\n return key;\n }),\n });\n });\n\n return emojiConfig;\n });\n","export const errorHandler = (err: Error): void => {\n if (err.name !== 'AbortError') console.error(err.message);\n};\n","import type { WalineComment, WalineCommentData } from '../typings';\n\nexport interface FetchErrorData {\n errno: number;\n errmsg: string;\n}\n\nconst errorCheck = <T = unknown>(data: T | FetchErrorData, name = ''): T => {\n if (typeof data === 'object' && (data as FetchErrorData).errno)\n throw new TypeError(\n `Fetch ${name} failed with ${(data as FetchErrorData).errno}: ${\n (data as FetchErrorData).errmsg\n }`\n );\n\n return data as T;\n};\n\nexport interface FetchCountOptions {\n serverURL: string;\n paths: string[];\n signal: AbortSignal;\n token?: string;\n}\n\nexport const fetchCommentCount = ({\n serverURL,\n paths,\n signal,\n token,\n}: FetchCountOptions): Promise<number[]> => {\n const headers: Record<string, string> = {};\n if (token) headers.Authorization = `Bearer ${token}`;\n\n return (\n fetch(\n `${serverURL}/comment?type=count&url=${encodeURIComponent(\n paths.join(',')\n )}`,\n { signal, headers }\n )\n .then((resp) => resp.json() as Promise<number | number[]>)\n .then((data) => errorCheck(data, 'comment count'))\n // TODO: Improve this API\n .then((counts) => (Array.isArray(counts) ? counts : [counts]))\n );\n};\nexport interface FetchRecentOptions {\n serverURL: string;\n count: number;\n signal: AbortSignal;\n token?: string;\n}\n\nexport const fetchRecentComment = ({\n serverURL,\n count,\n signal,\n token,\n}: FetchRecentOptions): Promise<WalineComment[]> => {\n const headers: Record<string, string> = {};\n if (token) headers.Authorization = `Bearer ${token}`;\n\n return fetch(`${serverURL}/comment?type=recent&count=${count}`, {\n signal,\n headers,\n })\n .then((resp) => resp.json() as Promise<WalineComment[]>)\n .then((data) => errorCheck(data, 'recent comment'));\n};\n\nexport interface FetchListOptions {\n serverURL: string;\n path: string;\n page: number;\n pageSize: number;\n signal: AbortSignal;\n token?: string;\n}\n\nexport interface FetchListResult {\n count: number;\n data: WalineComment[];\n totalPages: number;\n}\n\nexport const fetchCommentList = ({\n serverURL,\n path,\n page,\n pageSize,\n signal,\n token,\n}: FetchListOptions): Promise<FetchListResult> => {\n const headers: Record<string, string> = {};\n if (token) headers.Authorization = `Bearer ${token}`;\n\n return fetch(\n `${serverURL}/comment?path=${encodeURIComponent(\n path\n )}&pageSize=${pageSize}&page=${page}`,\n { signal, headers }\n )\n .then((resp) => resp.json() as Promise<FetchListResult>)\n .then((data) => errorCheck(data, 'comment list'));\n};\n\nexport interface PostCommentOptions {\n serverURL: string;\n lang: string;\n token?: string;\n comment: WalineCommentData;\n}\n\nexport interface PostCommentResponse {\n data?: WalineComment;\n errmsg?: string;\n}\n\nexport const postComment = ({\n serverURL,\n lang,\n token,\n comment,\n}: PostCommentOptions): Promise<PostCommentResponse> => {\n const headers: Record<string, string> = {\n // eslint-disable-next-line @typescript-eslint/naming-convention\n 'Content-Type': 'application/json',\n };\n\n if (token) headers.Authorization = `Bearer ${token}`;\n\n return fetch(`${serverURL}/comment?lang=${lang}`, {\n method: 'POST',\n headers,\n body: JSON.stringify(comment),\n }).then((resp) => resp.json() as Promise<PostCommentResponse>);\n};\n\nexport interface FetchPageviewsOptions {\n serverURL: string;\n paths: string[];\n signal: AbortSignal;\n}\n\nexport const fetchPageviews = ({\n serverURL,\n paths,\n signal,\n}: FetchPageviewsOptions): Promise<number[]> =>\n fetch(`${serverURL}/article?path=${encodeURIComponent(paths.join(','))}`, {\n signal,\n })\n .then((resp) => resp.json() as Promise<number[] | number>)\n .then((data) => errorCheck(data, 'visit count'))\n // TODO: Improve this API\n .then((counts) => (Array.isArray(counts) ? counts : [counts]));\n\nexport interface UpdatePageviewsOptions {\n serverURL: string;\n path: string;\n}\n\nexport const updatePageviews = ({\n serverURL,\n path,\n}: UpdatePageviewsOptions): Promise<number> =>\n fetch(`${serverURL}/article`, {\n method: 'POST',\n headers: {\n // eslint-disable-next-line @typescript-eslint/naming-convention\n 'Content-Type': 'application/json',\n },\n body: JSON.stringify({ path }),\n })\n .then((resp) => resp.json() as Promise<number>)\n .then((data) => errorCheck(data, 'visit count'));\n","export const getRoot = (\n el: string | HTMLElement | undefined\n): HTMLElement | null =>\n el instanceof HTMLElement\n ? el\n : typeof el === 'string'\n ? document.querySelector(el)\n : null;\n","const isImage = (item: DataTransferItem): boolean =>\n item.type.includes('image');\n\nexport const getImagefromDataTransfer = (\n items: DataTransferItemList\n): File | null => {\n const image = Array.from(items).find(isImage);\n\n return image ? (image.getAsFile() as File) : null;\n};\n","import type { marked } from 'marked';\nimport type { WalineTexRenderer } from '../typings';\n\nconst inlineMathStart = /\\$.*?\\$/;\nconst inlineMathReg = /^\\$(.*?)\\$/;\nconst blockMathReg = /^(?:\\s{0,3})\\$\\$((?:[^\\n]|\\n[^\\n])+?)\\n{0,1}\\$\\$/;\n\nexport const markedTexExtensions = (\n texRenderer: WalineTexRenderer\n): marked.TokenizerExtension[] => {\n const blockMathExtension: marked.TokenizerExtension = {\n name: 'blockMath',\n level: 'block',\n tokenizer(src: string) {\n const cap = blockMathReg.exec(src);\n\n if (cap !== null) {\n return {\n type: 'html',\n raw: cap[0],\n text: texRenderer(true, cap[1]),\n };\n }\n\n return undefined;\n },\n };\n\n const inlineMathExtension: marked.TokenizerExtension = {\n name: 'inlineMath',\n level: 'inline',\n start(src: string) {\n const idx = src.search(inlineMathStart);\n return idx !== -1 ? idx : src.length;\n },\n tokenizer(src: string) {\n const cap = inlineMathReg.exec(src);\n\n if (cap !== null) {\n return {\n type: 'html',\n raw: cap[0],\n text: texRenderer(false, cap[1]),\n };\n }\n\n return undefined;\n },\n };\n\n return [blockMathExtension, inlineMathExtension];\n};\n","import { marked } from 'marked';\nimport { markedTexExtensions } from './markedMathExtension';\n\nimport type {\n WalineEmojiMaps,\n WalineHighlighter,\n WalineTexRenderer,\n} from '../typings';\n\nexport const parseEmoji = (text = '', emojiMap: WalineEmojiMaps = {}): string =>\n text.replace(/:(.+?):/g, (placeholder, key: string) =>\n emojiMap[key]\n ? `<img class=\"wl-emoji\" src=\"${emojiMap[key]}\" alt=\"${key}\">`\n : placeholder\n );\n\nexport interface ParseMarkdownOptions {\n emojiMap: WalineEmojiMaps;\n highlighter: WalineHighlighter | false;\n texRenderer: WalineTexRenderer | false;\n}\n\nexport const parseMarkdown = (\n content: string,\n { emojiMap, highlighter, texRenderer }: ParseMarkdownOptions\n): string => {\n marked.setOptions({\n highlight: highlighter || undefined,\n breaks: true,\n smartLists: true,\n smartypants: true,\n });\n\n if (texRenderer) {\n const extensions = markedTexExtensions(texRenderer);\n\n marked.use({ extensions });\n }\n\n return marked.parse(parseEmoji(content, emojiMap));\n};\n","export const getQuery = (element: HTMLElement): string | null =>\n element.dataset.path || element.getAttribute('id');\n","import { useNow } from '@vueuse/core';\nimport { computed } from 'vue';\nimport { dateFormat } from '../utils';\n\nimport type { ComputedRef } from 'vue';\nimport type { WalineLocale } from '../typings';\n\nexport const useTimeAgo = (\n date: Date | string,\n locale: WalineLocale\n): ComputedRef<string> => {\n const now = useNow();\n\n return computed(() => {\n if (!date) return '';\n\n const time =\n typeof date === 'string'\n ? new Date(date.indexOf(' ') !== -1 ? date.replace(/-/g, '/') : date)\n : date;\n\n const timepassed = now.value.getTime() - time.getTime();\n\n const days = Math.floor(timepassed / (24 * 3600 * 1000));\n\n if (days === 0) {\n // 计算相差小时数\n\n // 计算天数后剩余的毫秒数\n const leave1 = timepassed % (24 * 3600 * 1000);\n const hours = Math.floor(leave1 / (3600 * 1000));\n\n if (hours === 0) {\n //计算相差分钟数\n\n // 计算小时数后剩余的毫秒数\n const leave2 = leave1 % (3600 * 1000);\n const minutes = Math.floor(leave2 / (60 * 1000));\n\n // 计算相差秒数\n if (minutes === 0) {\n // 计算分钟数后剩余的毫秒数\n const leave3 = leave2 % (60 * 1000);\n const seconds = Math.round(leave3 / 1000);\n\n return `${seconds} ${locale.seconds}`;\n }\n\n return `${minutes} ${locale.minutes}`;\n }\n\n return `${hours} ${locale.hours}`;\n }\n\n if (days < 0) return locale.now;\n\n if (days < 8) return `${days} ${locale.days}`;\n\n return dateFormat(time);\n });\n};\n","import { useStorage } from '@vueuse/core';\n\nimport type { Ref } from 'vue';\n\nexport interface UserInfo {\n // eslint-disable-next-line @typescript-eslint/naming-convention\n display_name: string;\n email: string;\n url: string;\n token: string;\n avatar: string;\n mailMd5: string;\n}\n\nexport const USER_KEY = 'WALINE_USER';\n\nexport type UserInfoRef = Ref<UserInfo | Record<string, never>>;\n\nexport const useUserInfo = (): UserInfoRef =>\n useStorage<UserInfo | Record<string, never>>('USER_KEY', {});\n","import { useUserInfo } from './composables';\nimport { decodePath, errorHandler, fetchCommentCount } from './utils';\nimport type { WalineAbort } from './typings';\n\nexport interface WalineCommentCountOptions {\n /**\n * Waline 服务端地址\n *\n * Waline server url\n */\n serverURL: string;\n\n /**\n * 评论数 CSS 选择器\n *\n * Commment count CSS selector\n *\n * @default '.waline-comment-count'\n */\n selector?: string;\n\n /**\n * 需要获取的默认路径\n *\n * Path to be fetched by default\n *\n * @default window.location.pathname\n */\n path?: string;\n}\n\nexport const commentCount = ({\n serverURL,\n path = window.location.pathname,\n selector = '.waline-comment-count',\n}: // eslint-disable-next-line @typescript-eslint/no-explicit-any\nWalineCommentCountOptions): WalineAbort => {\n const controller = new AbortController();\n\n // comment count\n const elements = document.querySelectorAll<HTMLElement>(selector);\n\n const userInfo = useUserInfo();\n\n if (elements.length)\n void fetchCommentCount({\n serverURL,\n paths: Array.from(elements).map((element) =>\n decodePath(element.dataset.path || element.getAttribute('id') || path)\n ),\n signal: controller.signal,\n token: userInfo.value?.token,\n })\n .then((counts) => {\n elements.forEach((element, index) => {\n element.innerText = counts[index].toString();\n });\n })\n .catch(errorHandler);\n\n return controller.abort.bind(controller);\n};\n","import { h } from 'vue';\nimport type { FunctionalComponent } from 'vue';\n\nexport const CloseIcon: FunctionalComponent<{ size: number }> = ({ size }) =>\n h(\n 'svg',\n {\n class: 'wl-close-icon',\n viewBox: '0 0 1024 1024',\n width: size,\n height: size,\n },\n [\n h('path', {\n d: 'M697.173 85.333h-369.92c-144.64 0-241.92 101.547-241.92 252.587v348.587c0 150.613 97.28 252.16 241.92 252.16h369.92c144.64 0 241.494-101.547 241.494-252.16V337.92c0-151.04-96.854-252.587-241.494-252.587z',\n fill: 'currentColor',\n }),\n h('path', {\n d: 'm640.683 587.52-75.947-75.861 75.904-75.862a37.29 37.29 0 0 0 0-52.778 37.205 37.205 0 0 0-52.779 0l-75.946 75.818-75.862-75.946a37.419 37.419 0 0 0-52.821 0 37.419 37.419 0 0 0 0 52.821l75.947 75.947-75.776 75.733a37.29 37.29 0 1 0 52.778 52.821l75.776-75.776 75.947 75.947a37.376 37.376 0 0 0 52.779-52.821z',\n fill: '#888',\n }),\n ]\n );\n\nexport const EmojiIcon: FunctionalComponent = () =>\n h(\n 'svg',\n { viewBox: '0 0 1024 1024', width: '24', height: '24' },\n h('path', {\n d: 'M563.2 463.3 677 540c1.7 1.2 3.7 1.8 5.8 1.8.7 0 1.4-.1 2-.2 2.7-.5 5.1-2.1 6.6-4.4l25.3-37.8c1.5-2.3 2.1-5.1 1.6-7.8s-2.1-5.1-4.4-6.6l-73.6-49.1 73.6-49.1c2.3-1.5 3.9-3.9 4.4-6.6.5-2.7 0-5.5-1.6-7.8l-25.3-37.8a10.1 10.1 0 0 0-6.6-4.4c-.7-.1-1.3-.2-2-.2-2.1 0-4.1.6-5.8 1.8l-113.8 76.6c-9.2 6.2-14.7 16.4-14.7 27.5.1 11 5.5 21.3 14.7 27.4zM387 348.8h-45.5c-5.7 0-10.4 4.7-10.4 10.4v153.3c0 5.7 4.7 10.4 10.4 10.4H387c5.7 0 10.4-4.7 10.4-10.4V359.2c0-5.7-4.7-10.4-10.4-10.4zm333.8 241.3-41-20a10.3 10.3 0 0 0-8.1-.5c-2.6.9-4.8 2.9-5.9 5.4-30.1 64.9-93.1 109.1-164.4 115.2-5.7.5-9.9 5.5-9.5 11.2l3.9 45.5c.5 5.3 5 9.5 10.3 9.5h.9c94.8-8 178.5-66.5 218.6-152.7 2.4-5 .3-11.2-4.8-13.6zm186-186.1c-11.9-42-30.5-81.4-55.2-117.1-24.1-34.9-53.5-65.6-87.5-91.2-33.9-25.6-71.5-45.5-111.6-59.2-41.2-14-84.1-21.1-127.8-21.1h-1.2c-75.4 0-148.8 21.4-212.5 61.7-63.7 40.3-114.3 97.6-146.5 165.8-32.2 68.1-44.3 143.6-35.1 218.4 9.3 74.8 39.4 145 87.3 203.3.1.2.3.3.4.5l36.2 38.4c1.1 1.2 2.5 2.1 3.9 2.6 73.3 66.7 168.2 103.5 267.5 103.5 73.3 0 145.2-20.3 207.7-58.7 37.3-22.9 70.3-51.5 98.1-85 27.1-32.7 48.7-69.5 64.2-109.1 15.5-39.7 24.4-81.3 26.6-123.8 2.4-43.6-2.5-87-14.5-129zm-60.5 181.1c-8.3 37-22.8 72-43 104-19.7 31.1-44.3 58.6-73.1 81.7-28.8 23.1-61 41-95.7 53.4-35.6 12.7-72.9 19.1-110.9 19.1-82.6 0-161.7-30.6-222.8-86.2l-34.1-35.8c-23.9-29.3-42.4-62.2-55.1-97.7-12.4-34.7-18.8-71-19.2-107.9-.4-36.9 5.4-73.3 17.1-108.2 12-35.8 30-69.2 53.4-99.1 31.7-40.4 71.1-72 117.2-94.1 44.5-21.3 94-32.6 143.4-32.6 49.3 0 97 10.8 141.8 32 34.3 16.3 65.3 38.1 92 64.8 26.1 26 47.5 56 63.6 89.2 16.2 33.2 26.6 68.5 31 105.1 4.6 37.5 2.7 75.3-5.6 112.3z',\n fill: 'currentColor',\n })\n );\n\nexport const ImageIcon: FunctionalComponent = () =>\n h('svg', { viewBox: '0 0 1024 1024', width: '24', height: '24' }, [\n h('path', {\n d: 'M784 112H240c-88 0-160 72-160 160v480c0 88 72 160 160 160h544c88 0 160-72 160-160V272c0-88-72-160-160-160zm96 640c0 52.8-43.2 96-96 96H240c-52.8 0-96-43.2-96-96V272c0-52.8 43.2-96 96-96h544c52.8 0 96 43.2 96 96v480z',\n fill: 'currentColor',\n }),\n h('path', {\n d: 'M352 480c52.8 0 96-43.2 96-96s-43.2-96-96-96-96 43.2-96 96 43.2 96 96 96zm0-128c17.6 0 32 14.4 32 32s-14.4 32-32 32-32-14.4-32-32 14.4-32 32-32zm462.4 379.2-3.2-3.2-177.6-177.6c-25.6-25.6-65.6-25.6-91.2 0l-80 80-36.8-36.8c-25.6-25.6-65.6-25.6-91.2 0L200 728c-4.8 6.4-8 14.4-8 24 0 17.6 14.4 32 32 32 9.6 0 16-3.2 22.4-9.6L380.8 640l134.4 134.4c6.4 6.4 14.4 9.6 24 9.6 17.6 0 32-14.4 32-32 0-9.6-4.8-17.6-9.6-24l-52.8-52.8 80-80L769.6 776c6.4 4.8 12.8 8 20.8 8 17.6 0 32-14.4 32-32 0-8-3.2-16-8-20.8z',\n fill: 'currentColor',\n }),\n ]);\n\nexport const PreviewIcon: FunctionalComponent = () =>\n h('svg', { viewBox: '0 0 1024 1024', width: '24', height: '24' }, [\n h('path', {\n d: 'M710.816 654.301c70.323-96.639 61.084-230.578-23.705-314.843-46.098-46.098-107.183-71.109-172.28-71.109-65.008 0-126.092 25.444-172.28 71.109-45.227 46.098-70.756 107.183-70.756 172.106 0 64.923 25.444 126.007 71.194 172.106 46.099 46.098 107.184 71.109 172.28 71.109 51.414 0 100.648-16.212 142.824-47.404l126.53 126.006c7.058 7.06 16.297 10.979 26.406 10.979 10.105 0 19.343-3.919 26.402-10.979 14.467-14.467 14.467-38.172 0-52.723L710.816 654.301zm-315.107-23.265c-65.88-65.88-65.88-172.54 0-238.42 32.069-32.07 74.245-49.149 119.471-49.149 45.227 0 87.407 17.603 119.472 49.149 65.88 65.879 65.88 172.539 0 238.42-63.612 63.178-175.242 63.178-238.943 0zm0 0',\n fill: 'currentColor',\n }),\n h('path', {\n d: 'M703.319 121.603H321.03c-109.8 0-199.469 89.146-199.469 199.38v382.034c0 109.796 89.236 199.38 199.469 199.38h207.397c20.653 0 37.384-16.645 37.384-37.299 0-20.649-16.731-37.296-37.384-37.296H321.03c-68.582 0-124.352-55.77-124.352-124.267V321.421c0-68.496 55.77-124.267 124.352-124.267h382.289c68.582 0 124.352 55.771 124.352 124.267V524.72c0 20.654 16.736 37.299 37.385 37.299 20.654 0 37.384-16.645 37.384-37.299V320.549c-.085-109.8-89.321-198.946-199.121-198.946zm0 0',\n fill: 'currentColor',\n }),\n ]);\n\nexport const MarkdownIcon: FunctionalComponent = () =>\n h(\n 'svg',\n { width: '16', height: '16', ariaHidden: 'true' },\n h('path', {\n d: 'M14.85 3H1.15C.52 3 0 3.52 0 4.15v7.69C0 12.48.52 13 1.15 13h13.69c.64 0 1.15-.52 1.15-1.15v-7.7C16 3.52 15.48 3 14.85 3zM9 11H7V8L5.5 9.92 4 8v3H2V5h2l1.5 2L7 5h2v6zm2.99.5L9.5 8H11V5h2v3h1.5l-2.51 3.5z',\n fill: 'currentColor',\n })\n );\n\nexport const ReplyIcon: FunctionalComponent = () =>\n h(\n 'svg',\n { viewBox: '0 0 1024 1024', width: '18', height: '18' },\n h('path', {\n d: 'M1019.2 720C1001.6 625.6 968 566.4 904 497.6c-89.6-89.6-214.4-150.4-347.2-176v-120c0-25.6-8-51.2-25.6-64-33.6-30.4-81.6-30.4-112-4.8L33.6 441.6C12.8 459.2 0 484.8 0 510.4c0 25.6 12.8 51.2 30.4 68.8l385.6 312c17.6 12.8 33.6 17.6 51.2 17.6 12.8 0 25.6-4.8 38.4-8C536 888 552 857.6 552 824v-99.2c124.8 20.8 248 86.4 339.2 140.8 25.6 17.6 59.2 17.6 89.6 0 25.6-17.6 43.2-46.4 43.2-76.8 0-33.6 0-56-4.8-68.8zm-500.8-89.6-46.4-4.8v193.6L86.4 510.4 472 201.6V400l38.4 4.8c128 12.8 248 68.8 334.4 153.6 51.2 56 76.8 102.4 94.4 179.2 0 4.8 4.8 20.8 4.8 51.2C835.2 720 672 640 518.4 630.4z',\n fill: 'currentColor',\n })\n );\n\nexport const VerifiedIcon: FunctionalComponent = () =>\n h(\n 'svg',\n {\n class: 'verified-icon',\n viewBox: '0 0 1024 1024',\n width: '14',\n height: '14',\n },\n h('path', {\n d: 'm894.4 461.56-54.4-63.2c-10.4-12-18.8-34.4-18.8-50.4v-68c0-42.4-34.8-77.2-77.2-77.2h-68c-15.6 0-38.4-8.4-50.4-18.8l-63.2-54.4c-27.6-23.6-72.8-23.6-100.8 0l-62.8 54.8c-12 10-34.8 18.4-50.4 18.4h-69.2c-42.4 0-77.2 34.8-77.2 77.2v68.4c0 15.6-8.4 38-18.4 50l-54 63.6c-23.2 27.6-23.2 72.4 0 100l54 63.6c10 12 18.4 34.4 18.4 50v68.4c0 42.4 34.8 77.2 77.2 77.2h69.2c15.6 0 38.4 8.4 50.4 18.8l63.2 54.4c27.6 23.6 72.8 23.6 100.8 0l63.2-54.4c12-10.4 34.4-18.8 50.4-18.8h68c42.4 0 77.2-34.8 77.2-77.2v-68c0-15.6 8.4-38.4 18.8-50.4l54.4-63.2c23.2-27.6 23.2-73.2-.4-100.8zm-216-25.2-193.2 193.2a30 30 0 0 1-42.4 0l-96.8-96.8a30.16 30.16 0 0 1 0-42.4c11.6-11.6 30.8-11.6 42.4 0l75.6 75.6 172-172c11.6-11.6 30.8-11.6 42.4 0 11.6 11.6 11.6 30.8 0 42.4z',\n fill: '#27ae60',\n })\n );\n\nexport const LoadingIcon: FunctionalComponent<{ size: number }> = ({ size }) =>\n h(\n 'svg',\n {\n width: size,\n height: size,\n viewBox: '0 0 100 100',\n preserveAspectRatio: 'xMidYMid',\n },\n h(\n 'circle',\n {\n cx: 50,\n cy: 50,\n fill: 'none',\n stroke: 'currentColor',\n strokeWidth: '4',\n r: '40',\n // eslint-disable-next-line @typescript-eslint/naming-convention\n 'stroke-dasharray': '85 30',\n },\n h('animateTransform', {\n attributeName: 'transform',\n type: 'rotate',\n repeatCount: 'indefinite',\n dur: '1s',\n values: '0 50 50;360 50 50',\n keyTimes: '0;1',\n })\n )\n );\n","<template>\n <div class=\"wl-comment\">\n <div v-if=\"config.login !== 'disable' && isLogin\" class=\"wl-login-info\">\n <div class=\"wl-avatar\">\n <button class=\"wl-logout-btn\" :title=\"locale.logout\" @click=\"onLogout\">\n <CloseIcon :size=\"14\" />\n </button>\n\n <img :src=\"userInfo.avatar\" alt=\"avatar\" />\n </div>\n <a\n href=\"#\"\n class=\"wl-login-nick\"\n aria-label=\"Profile\"\n @click=\"onProfile\"\n v-text=\"userInfo.display_name\"\n />\n </div>\n\n <div class=\"wl-panel\">\n <div\n v-if=\"config.login !== 'force' && config.meta.length && !isLogin\"\n :class=\"['wl-header', `item${config.meta.length}`]\"\n >\n <div v-for=\"kind in config.meta\" class=\"wl-header-item\" :key=\"kind\">\n <label\n :for=\"kind\"\n v-text=\"\n locale[kind] +\n (config.requiredMeta.includes(kind) || !config.requiredMeta.length\n ? ''\n : `(${locale.optional})`)\n \"\n />\n <input\n :ref=\"\n (element) => {\n if (element) inputRefs[kind] = element;\n }\n \"\n :id=\"`wl-${kind}`\"\n :class=\"['wl-input', `wl-${kind}`]\"\n :name=\"kind\"\n :type=\"kind === 'mail' ? 'email' : 'text'\"\n v-model=\"userMeta[kind]\"\n />\n </div>\n </div>\n\n <textarea\n class=\"wl-editor\"\n ref=\"editorRef\"\n id=\"wl-edit\"\n :placeholder=\"replyUser ? `@${replyUser}` : locale.placeholder\"\n v-model=\"editor\"\n @keydown=\"onKeyDown\"\n @drop=\"onDrop\"\n @paste=\"onPaste\"\n />\n\n <div class=\"wl-preview\" v-show=\"showPreview\">\n <hr />\n <h4>{{ locale.preview }}:</h4>\n <div class=\"wl-content\" v-html=\"previewText\" />\n </div>\n\n <div class=\"wl-footer\">\n <div class=\"wl-actions\">\n <a\n href=\"https://guides.github.com/features/mastering-markdown/\"\n title=\"Markdown Guide\"\n aria-label=\"Markdown is supported\"\n class=\"wl-action\"\n target=\"_blank\"\n rel=\"noreferrer\"\n >\n <MarkdownIcon />\n </a>\n\n <button\n v-show=\"config.emoji.length\"\n ref=\"emojiButtonRef\"\n class=\"wl-action\"\n :class=\"{ actived: showEmoji }\"\n :title=\"locale.emoji\"\n @click=\"showEmoji = !showEmoji\"\n >\n <EmojiIcon />\n </button>\n\n <input\n ref=\"imageUploadRef\"\n class=\"upload\"\n id=\"wl-image-upload\"\n type=\"file\"\n accept=\".png,.jpg,.jpeg,.webp,.bmp,.gif\"\n @change=\"onChange\"\n />\n\n <label\n v-if=\"canUploadImage\"\n for=\"wl-image-upload\"\n class=\"wl-action\"\n :title=\"locale.uploadImage\"\n >\n <ImageIcon />\n </label>\n\n <button\n class=\"wl-action\"\n :class=\"{ actived: showPreview }\"\n :title=\"locale.preview\"\n @click=\"showPreview = !showPreview\"\n >\n <PreviewIcon />\n </button>\n </div>\n\n <div class=\"wl-info\">\n <div class=\"wl-text-number\">\n {{ wordNumber }}\n\n <span v-if=\"config.wordLimit\">\n / \n <span\n :class=\"{ illegal: !isWordNumberLegal }\"\n v-text=\"wordLimit\"\n />\n </span>\n\n {{ locale.word }}\n </div>\n\n <button\n v-if=\"config.login !== 'disable' && !isLogin\"\n class=\"wl-btn\"\n @click=\"onLogin\"\n v-text=\"locale.login\"\n />\n\n <button\n v-if=\"config.login !== 'force' || isLogin\"\n class=\"wl-btn primary\"\n title=\"Cmd|Ctrl + Enter\"\n :disabled=\"isSubmitting\"\n @click=\"submitComment\"\n >\n <LoadingIcon v-if=\"isSubmitting\" :size=\"16\" />\n <template v-else>\n {{ locale.submit }}\n </template>\n </button>\n </div>\n\n <div\n ref=\"emojiPopupRef\"\n class=\"wl-emoji-popup\"\n :class=\"{ display: showEmoji }\"\n >\n <template v-for=\"(config, index) in emoji.tabs\" :key=\"config.name\">\n <div v-if=\"index === emojiTabIndex\" class=\"wl-tab-wrapper\">\n <button\n v-for=\"key in config.items\"\n :key=\"key\"\n :title=\"key\"\n @click=\"insert(`:${key}:`)\"\n >\n <img\n v-if=\"showEmoji\"\n class=\"wl-emoji\"\n :src=\"emoji.map[key]\"\n :alt=\"key\"\n loading=\"lazy\"\n referrerPolicy=\"no-referrer\"\n />\n </button>\n </div>\n </template>\n <div v-if=\"emoji.tabs.length > 1\" class=\"wl-tabs\">\n <button\n v-for=\"(config, index) in emoji.tabs\"\n :key=\"config.name\"\n class=\"wl-tab\"\n :class=\"{ active: emojiTabIndex === index }\"\n @click=\"emojiTabIndex = index\"\n >\n <img\n class=\"wl-emoji\"\n :src=\"config.icon\"\n :alt=\"config.name\"\n :title=\"config.name\"\n loading=\"lazy\"\n referrerPolicy=\"no-referrer\"\n />\n </button>\n </div>\n </div>\n </div>\n </div>\n\n <button\n v-if=\"replyId\"\n class=\"wl-close\"\n :title=\"locale.cancelReply\"\n @click=\"$emit('cancel-reply')\"\n >\n <CloseIcon :size=\"24\" />\n </button>\n </div>\n</template>\n\n<script lang=\"ts\">\nimport autosize from 'autosize';\nimport {\n computed,\n defineComponent,\n inject,\n onMounted,\n onUnmounted,\n ref,\n watch,\n} from 'vue';\n\nimport {\n CloseIcon,\n EmojiIcon,\n ImageIcon,\n MarkdownIcon,\n PreviewIcon,\n LoadingIcon,\n} from './Icons';\nimport { useEditor, useUserMeta, useUserInfo } from '../composables';\nimport {\n getImagefromDataTransfer,\n parseMarkdown,\n getWordNumber,\n parseEmoji,\n postComment,\n getEmojis,\n} from '../utils';\n\nimport type { ComputedRef, DeepReadonly } from 'vue';\nimport type { WalineCommentData, WalineImageUploader } from '../typings';\nimport type { WalineConfig, WalineEmojiConfig } from '../utils';\n\nexport default defineComponent({\n name: 'CommentBox',\n\n components: {\n CloseIcon,\n EmojiIcon,\n ImageIcon,\n MarkdownIcon,\n PreviewIcon,\n LoadingIcon,\n },\n\n props: {\n rootId: {\n type: String,\n default: '',\n },\n replyId: {\n type: String,\n default: '',\n },\n replyUser: {\n type: String,\n default: '',\n },\n },\n\n emits: ['submit', 'cancel-reply'],\n\n setup(props, { emit }) {\n const config = inject<ComputedRef<WalineConfig>>(\n 'config'\n ) as ComputedRef<WalineConfig>;\n\n const editor = useEditor();\n const userMeta = useUserMeta();\n const userInfo = useUserInfo();\n\n const inputRefs = ref<Record<string, HTMLInputElement>>({});\n const editorRef = ref<HTMLTextAreaElement | null>(null);\n const imageUploadRef = ref<HTMLInputElement | null>(null);\n const emojiButtonRef = ref<HTMLDivElement | null>(null);\n const emojiPopupRef = ref<HTMLDivElement | null>(null);\n\n const emoji = ref<DeepReadonly<WalineEmojiConfig>>({ tabs: [], map: {} });\n const emojiTabIndex = ref(0);\n const showEmoji = ref(false);\n const showPreview = ref(false);\n const previewText = ref('');\n const wordNumber = ref(0);\n\n const wordLimit = ref(0);\n const isWordNumberLegal = ref(false);\n\n const content = ref('');\n\n const isSubmitting = ref(false);\n\n const locale = computed(() => config.value.locale);\n\n const isLogin = computed(() => Boolean(userInfo.value?.token));\n\n const canUploadImage = computed(() => config.value.imageUploader !== false);\n\n const insert = (content: string): void => {\n const textArea = editorRef.value as HTMLTextAreaElement;\n const startPosition = textArea.selectionStart;\n const endPosition = textArea.selectionEnd || 0;\n const scrollTop = textArea.scrollTop;\n\n editor.value =\n textArea.value.substring(0, startPosition) +\n content +\n textArea.value.substring(endPosition, textArea.value.length);\n textArea.focus();\n textArea.selectionStart = startPosition + content.length;\n textArea.selectionEnd = startPosition + content.length;\n textArea.scrollTop = scrollTop;\n };\n\n const onKeyDown = (event: KeyboardEvent): void => {\n const key = event.key;\n\n // Shortcut key\n if ((event.ctrlKey || event.metaKey) && key === 'Enter') submitComment();\n };\n\n const uploadImage = (file: File): Promise<void> => {\n const uploadText = `![${config.value.locale.uploading} ${file.name}]()`;\n\n insert(uploadText);\n\n return Promise.resolve()\n .then(() => (config.value.imageUploader as WalineImageUploader)(file))\n .then((url) => {\n editor.value = editor.value.replace(\n uploadText,\n `\\r\\n`\n );\n });\n };\n\n const onDrop = (event: DragEvent): void => {\n if (event.dataTransfer?.items) {\n const file = getImagefromDataTransfer(event.dataTransfer.items);\n\n if (file && canUploadImage.value) {\n uploadImage(file);\n event.preventDefault();\n }\n }\n };\n\n const onPaste = (event: ClipboardEvent): void => {\n if (event.clipboardData) {\n const file = getImagefromDataTransfer(event.clipboardData.items);\n\n if (file && canUploadImage.value) uploadImage(file);\n }\n };\n\n const onChange = (): void => {\n const inputElement = imageUploadRef.value as HTMLInputElement;\n\n if (inputElement.files && canUploadImage.value)\n uploadImage(inputElement.files[0]).then(() => {\n // clear input so a same image can be uploaded later\n inputElement.value = '';\n });\n };\n\n const submitComment = (): void => {\n const { serverURL, lang, login, wordLimit, requiredMeta } = config.value;\n\n const comment: WalineCommentData = {\n comment: content.value,\n nick: userMeta.value.nick,\n mail: userMeta.value.mail,\n link: userMeta.value.link,\n ua: navigator.userAgent,\n url: config.value.path,\n };\n\n if (userInfo.value?.token) {\n // login user\n\n comment.nick = userInfo.value.display_name;\n comment.mail = userInfo.value.email;\n comment.link = userInfo.value.url;\n } else {\n if (login === 'force') return;\n\n // check nick\n if (\n (requiredMeta.indexOf('nick') > -1 || comment.nick) &&\n !comment.nick\n ) {\n inputRefs.value.nick?.focus();\n return alert(locale.value.nickError);\n }\n\n // check mail\n if (requiredMeta.indexOf('mail') > -1 && !comment.mail) {\n inputRefs.value.mail?.focus();\n return alert(locale.value.mailError);\n }\n\n // check comment\n if (!comment.comment) {\n editorRef.value?.focus();\n return;\n }\n\n if (!comment.nick) comment.nick = locale.value.anonymous;\n }\n\n if (!isWordNumberLegal.value)\n return alert(\n locale.value.wordHint\n .replace('$0', (wordLimit as [number, number])[0].toString())\n .replace('$1', (wordLimit as [number, number])[1].toString())\n .replace('$2', wordNumber.value.toString())\n );\n\n comment.comment = parseEmoji(comment.comment, emoji.value.map);\n\n if (props.replyId && props.rootId) {\n comment.pid = props.replyId;\n comment.rid = props.rootId;\n comment.at = props.replyUser;\n }\n\n isSubmitting.value = true;\n\n postComment({\n serverURL,\n lang,\n token: userInfo.value?.token,\n comment,\n })\n .then((resp) => {\n isSubmitting.value = false;\n\n if (resp.errmsg) return alert(resp.errmsg);\n\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n emit('submit', resp.data!);\n\n editor.value = '';\n\n previewText.value = '';\n\n if (props.replyId) emit('cancel-reply');\n })\n .catch((err: TypeError) => {\n isSubmitting.value = false;\n\n alert(err.message);\n });\n };\n\n const onLogin = (event: Event): void => {\n event.preventDefault();\n const { lang, serverURL } = config.value;\n\n const width = 450;\n const height = 450;\n const left = (window.innerWidth - width) / 2;\n const top = (window.innerHeight - height) / 2;\n\n const handler = window.open(\n `${serverURL}/ui/login?lng=${encodeURIComponent(lang)}`,\n '_blank',\n `width=${width},height=${height},left=${left},top=${top},scrollbars=no,resizable=no,status=no,location=no,toolbar=no,menubar=no`\n );\n\n handler?.postMessage({ type: 'TOKEN', data: null }, '*');\n\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const receiver = ({ data }: any): void => {\n if (!data || data.type !== 'userInfo') return;\n\n if (data.data.token) {\n handler?.close();\n userInfo.value = data.data;\n (data.data.remember ? localStorage : sessionStorage).setItem(\n 'WALINE_USER',\n JSON.stringify(data.data)\n );\n\n window.removeEventListener('message', receiver);\n }\n };\n\n window.addEventListener('message', receiver);\n };\n\n const onLogout = (): void => {\n userInfo.value = {};\n localStorage.setItem('WALINE_USER', 'null');\n sessionStorage.setItem('WALINE_USER', 'null');\n };\n\n const onProfile = (event: Event): void => {\n event.preventDefault();\n\n const { lang, serverURL } = config.value;\n\n const width = 800;\n const height = 800;\n const left = (window.innerWidth - width) / 2;\n const top = (window.innerHeight - height) / 2;\n const handler = window.open(\n `${serverURL}/ui/profile?lng=${encodeURIComponent(lang)}`,\n '_blank',\n `width=${width},height=${height},left=${left},top=${top},scrollbars=no,resizable=no,status=no,location=no,toolbar=no,menubar=no`\n );\n\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n handler?.postMessage({ type: 'TOKEN', data: userInfo.value!.token }, '*');\n\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const receiver = ({ data }: any): void => {\n if (!data || data.type !== 'profile') return;\n\n userInfo.value = { ...userInfo.value, ...data };\n\n [localStorage, sessionStorage]\n .filter((store) => store.getItem('WALINE_USER'))\n .forEach((store) =>\n store.setItem('WALINE_USER', JSON.stringify(userInfo))\n );\n window.removeEventListener('message', receiver);\n };\n\n window.addEventListener('message', receiver);\n };\n\n const popupHandler = (event: MouseEvent): void => {\n if (\n !(emojiButtonRef.value as HTMLElement).contains(event.target as Node) &&\n !(emojiPopupRef.value as HTMLElement).contains(event.target as Node)\n )\n showEmoji.value = false;\n };\n\n // update wordNumber\n watch(\n [config, wordNumber],\n ([config, wordNumber]) => {\n const { wordLimit: limit } = config;\n\n if (limit) {\n if (wordNumber < limit[0] && limit[0] !== 0) {\n wordLimit.value = limit[0];\n isWordNumberLegal.value = false;\n } else if (wordNumber > limit[1]) {\n wordLimit.value = limit[1];\n isWordNumberLegal.value = false;\n } else {\n wordLimit.value = limit[1];\n isWordNumberLegal.value = true;\n }\n } else {\n wordLimit.value = 0;\n isWordNumberLegal.value = true;\n }\n },\n { immediate: true }\n );\n\n onMounted(() => {\n document.body.addEventListener('click', popupHandler);\n\n // watch editor\n watch(\n () => editor.value,\n (value) => {\n const { highlighter, texRenderer } = config.value;\n\n content.value = value;\n previewText.value = parseMarkdown(value, {\n emojiMap: emoji.value.map,\n highlighter,\n texRenderer,\n });\n wordNumber.value = getWordNumber(value);\n\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n if (value) autosize(editorRef.value!);\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n else autosize.destroy(editorRef.value!);\n },\n { immediate: true }\n );\n\n // watch emoji value change\n watch(\n () => config.value.emoji,\n (emojiConfig) =>\n getEmojis(emojiConfig).then((config) => {\n emoji.value = config;\n }),\n { immediate: true }\n );\n });\n\n onUnmounted(() => {\n document.body.removeEventListener('click', popupHandler);\n });\n\n return {\n // config\n config,\n locale,\n\n // events\n insert,\n onChange,\n onDrop,\n onKeyDown,\n onPaste,\n onLogin,\n onLogout,\n onProfile,\n submitComment,\n\n isLogin,\n userInfo,\n isSubmitting,\n\n // word\n wordNumber,\n wordLimit,\n isWordNumberLegal,\n\n // inputs\n editor,\n userMeta,\n\n // emoji\n emoji,\n emojiTabIndex,\n showEmoji,\n\n // image\n canUploadImage,\n\n // preview\n previewText,\n showPreview,\n\n // ref\n inputRefs,\n editorRef,\n emojiButtonRef,\n emojiPopupRef,\n imageUploadRef,\n };\n },\n});\n</script>\n","/**\n * The wordCount module should be lightweight as it's packed into client.\n *\n * So We just make a simple implement here\n *\n * Forked from https://github.com/vuepress-theme-hope/vuepress-theme-hope/blob/main/packages/reading-time2/src/node/reading-time.ts\n */\n\nexport const getWords = (content: string): string[] =>\n content.match(/[\\w\\d\\s\\u00C0-\\u024F]+/giu) || [];\n\nexport const getChinese = (content: string): string[] =>\n content.match(/[\\u4E00-\\u9FA5]/gu) || [];\n\nexport const getWordNumber = (content: string): number =>\n getWords(content).reduce(\n (accumulator, word) =>\n accumulator + (word.trim() === '' ? 0 : word.trim().split(/\\s+/u).length),\n 0\n ) + getChinese(content).length;\n","<template>\n <div class=\"wl-comment\">\n <div v-if=\"config.login !== 'disable' && isLogin\" class=\"wl-login-info\">\n <div class=\"wl-avatar\">\n <button class=\"wl-logout-btn\" :title=\"locale.logout\" @click=\"onLogout\">\n <CloseIcon :size=\"14\" />\n </button>\n\n <img :src=\"userInfo.avatar\" alt=\"avatar\" />\n </div>\n <a\n href=\"#\"\n class=\"wl-login-nick\"\n aria-label=\"Profile\"\n @click=\"onProfile\"\n v-text=\"userInfo.display_name\"\n />\n </div>\n\n <div class=\"wl-panel\">\n <div\n v-if=\"config.login !== 'force' && config.meta.length && !isLogin\"\n :class=\"['wl-header', `item${config.meta.length}`]\"\n >\n <div v-for=\"kind in config.meta\" class=\"wl-header-item\" :key=\"kind\">\n <label\n :for=\"kind\"\n v-text=\"\n locale[kind] +\n (config.requiredMeta.includes(kind) || !config.requiredMeta.length\n ? ''\n : `(${locale.optional})`)\n \"\n />\n <input\n :ref=\"\n (element) => {\n if (element) inputRefs[kind] = element;\n }\n \"\n :id=\"`wl-${kind}`\"\n :class=\"['wl-input', `wl-${kind}`]\"\n :name=\"kind\"\n :type=\"kind === 'mail' ? 'email' : 'text'\"\n v-model=\"userMeta[kind]\"\n />\n </div>\n </div>\n\n <textarea\n class=\"wl-editor\"\n ref=\"editorRef\"\n id=\"wl-edit\"\n :placeholder=\"replyUser ? `@${replyUser}` : locale.placeholder\"\n v-model=\"editor\"\n @keydown=\"onKeyDown\"\n @drop=\"onDrop\"\n @paste=\"onPaste\"\n />\n\n <div class=\"wl-preview\" v-show=\"showPreview\">\n <hr />\n <h4>{{ locale.preview }}:</h4>\n <div class=\"wl-content\" v-html=\"previewText\" />\n </div>\n\n <div class=\"wl-footer\">\n <div class=\"wl-actions\">\n <a\n href=\"https://guides.github.com/features/mastering-markdown/\"\n title=\"Markdown Guide\"\n aria-label=\"Markdown is supported\"\n class=\"wl-action\"\n target=\"_blank\"\n rel=\"noreferrer\"\n >\n <MarkdownIcon />\n </a>\n\n <button\n v-show=\"config.emoji.length\"\n ref=\"emojiButtonRef\"\n class=\"wl-action\"\n :class=\"{ actived: showEmoji }\"\n :title=\"locale.emoji\"\n @click=\"showEmoji = !showEmoji\"\n >\n <EmojiIcon />\n </button>\n\n <input\n ref=\"imageUploadRef\"\n class=\"upload\"\n id=\"wl-image-upload\"\n type=\"file\"\n accept=\".png,.jpg,.jpeg,.webp,.bmp,.gif\"\n @change=\"onChange\"\n />\n\n <label\n v-if=\"canUploadImage\"\n for=\"wl-image-upload\"\n class=\"wl-action\"\n :title=\"locale.uploadImage\"\n >\n <ImageIcon />\n </label>\n\n <button\n class=\"wl-action\"\n :class=\"{ actived: showPreview }\"\n :title=\"locale.preview\"\n @click=\"showPreview = !showPreview\"\n >\n <PreviewIcon />\n </button>\n </div>\n\n <div class=\"wl-info\">\n <div class=\"wl-text-number\">\n {{ wordNumber }}\n\n <span v-if=\"config.wordLimit\">\n / \n <span\n :class=\"{ illegal: !isWordNumberLegal }\"\n v-text=\"wordLimit\"\n />\n </span>\n\n {{ locale.word }}\n </div>\n\n <button\n v-if=\"config.login !== 'disable' && !isLogin\"\n class=\"wl-btn\"\n @click=\"onLogin\"\n v-text=\"locale.login\"\n />\n\n <button\n v-if=\"config.login !== 'force' || isLogin\"\n class=\"wl-btn primary\"\n title=\"Cmd|Ctrl + Enter\"\n :disabled=\"isSubmitting\"\n @click=\"submitComment\"\n >\n <LoadingIcon v-if=\"isSubmitting\" :size=\"16\" />\n <template v-else>\n {{ locale.submit }}\n </template>\n </button>\n </div>\n\n <div\n ref=\"emojiPopupRef\"\n class=\"wl-emoji-popup\"\n :class=\"{ display: showEmoji }\"\n >\n <template v-for=\"(config, index) in emoji.tabs\" :key=\"config.name\">\n <div v-if=\"index === emojiTabIndex\" class=\"wl-tab-wrapper\">\n <button\n v-for=\"key in config.items\"\n :key=\"key\"\n :title=\"key\"\n @click=\"insert(`:${key}:`)\"\n >\n <img\n v-if=\"showEmoji\"\n class=\"wl-emoji\"\n :src=\"emoji.map[key]\"\n :alt=\"key\"\n loading=\"lazy\"\n referrerPolicy=\"no-referrer\"\n />\n </button>\n </div>\n </template>\n <div v-if=\"emoji.tabs.length > 1\" class=\"wl-tabs\">\n <button\n v-for=\"(config, index) in emoji.tabs\"\n :key=\"config.name\"\n class=\"wl-tab\"\n :class=\"{ active: emojiTabIndex === index }\"\n @click=\"emojiTabIndex = index\"\n >\n <img\n class=\"wl-emoji\"\n :src=\"config.icon\"\n :alt=\"config.name\"\n :title=\"config.name\"\n loading=\"lazy\"\n referrerPolicy=\"no-referrer\"\n />\n </button>\n </div>\n </div>\n </div>\n </div>\n\n <button\n v-if=\"replyId\"\n class=\"wl-close\"\n :title=\"locale.cancelReply\"\n @click=\"$emit('cancel-reply')\"\n >\n <CloseIcon :size=\"24\" />\n </button>\n </div>\n</template>\n\n<script lang=\"ts\">\nimport autosize from 'autosize';\nimport {\n computed,\n defineComponent,\n inject,\n onMounted,\n onUnmounted,\n ref,\n watch,\n} from 'vue';\n\nimport {\n CloseIcon,\n EmojiIcon,\n ImageIcon,\n MarkdownIcon,\n PreviewIcon,\n LoadingIcon,\n} from './Icons';\nimport { useEditor, useUserMeta, useUserInfo } from '../composables';\nimport {\n getImagefromDataTransfer,\n parseMarkdown,\n getWordNumber,\n parseEmoji,\n postComment,\n getEmojis,\n} from '../utils';\n\nimport type { ComputedRef, DeepReadonly } from 'vue';\nimport type { WalineCommentData, WalineImageUploader } from '../typings';\nimport type { WalineConfig, WalineEmojiConfig } from '../utils';\n\nexport default defineComponent({\n name: 'CommentBox',\n\n components: {\n CloseIcon,\n EmojiIcon,\n ImageIcon,\n MarkdownIcon,\n PreviewIcon,\n LoadingIcon,\n },\n\n props: {\n rootId: {\n type: String,\n default: '',\n },\n replyId: {\n type: String,\n default: '',\n },\n replyUser: {\n type: String,\n default: '',\n },\n },\n\n emits: ['submit', 'cancel-reply'],\n\n setup(props, { emit }) {\n const config = inject<ComputedRef<WalineConfig>>(\n 'config'\n ) as ComputedRef<WalineConfig>;\n\n const editor = useEditor();\n const userMeta = useUserMeta();\n const userInfo = useUserInfo();\n\n const inputRefs = ref<Record<string, HTMLInputElement>>({});\n const editorRef = ref<HTMLTextAreaElement | null>(null);\n const imageUploadRef = ref<HTMLInputElement | null>(null);\n const emojiButtonRef = ref<HTMLDivElement | null>(null);\n const emojiPopupRef = ref<HTMLDivElement | null>(null);\n\n const emoji = ref<DeepReadonly<WalineEmojiConfig>>({ tabs: [], map: {} });\n const emojiTabIndex = ref(0);\n const showEmoji = ref(false);\n const showPreview = ref(false);\n const previewText = ref('');\n const wordNumber = ref(0);\n\n const wordLimit = ref(0);\n const isWordNumberLegal = ref(false);\n\n const content = ref('');\n\n const isSubmitting = ref(false);\n\n const locale = computed(() => config.value.locale);\n\n const isLogin = computed(() => Boolean(userInfo.value?.token));\n\n const canUploadImage = computed(() => config.value.imageUploader !== false);\n\n const insert = (content: string): void => {\n const textArea = editorRef.value as HTMLTextAreaElement;\n const startPosition = textArea.selectionStart;\n const endPosition = textArea.selectionEnd || 0;\n const scrollTop = textArea.scrollTop;\n\n editor.value =\n textArea.value.substring(0, startPosition) +\n content +\n textArea.value.substring(endPosition, textArea.value.length);\n textArea.focus();\n textArea.selectionStart = startPosition + content.length;\n textArea.selectionEnd = startPosition + content.length;\n textArea.scrollTop = scrollTop;\n };\n\n const onKeyDown = (event: KeyboardEvent): void => {\n const key = event.key;\n\n // Shortcut key\n if ((event.ctrlKey || event.metaKey) && key === 'Enter') submitComment();\n };\n\n const uploadImage = (file: File): Promise<void> => {\n const uploadText = `![${config.value.locale.uploading} ${file.name}]()`;\n\n insert(uploadText);\n\n return Promise.resolve()\n .then(() => (config.value.imageUploader as WalineImageUploader)(file))\n .then((url) => {\n editor.value = editor.value.replace(\n uploadText,\n `\\r\\n`\n );\n });\n };\n\n const onDrop = (event: DragEvent): void => {\n if (event.dataTransfer?.items) {\n const file = getImagefromDataTransfer(event.dataTransfer.items);\n\n if (file && canUploadImage.value) {\n uploadImage(file);\n event.preventDefault();\n }\n }\n };\n\n const onPaste = (event: ClipboardEvent): void => {\n if (event.clipboardData) {\n const file = getImagefromDataTransfer(event.clipboardData.items);\n\n if (file && canUploadImage.value) uploadImage(file);\n }\n };\n\n const onChange = (): void => {\n const inputElement = imageUploadRef.value as HTMLInputElement;\n\n if (inputElement.files && canUploadImage.value)\n uploadImage(inputElement.files[0]).then(() => {\n // clear input so a same image can be uploaded later\n inputElement.value = '';\n });\n };\n\n const submitComment = (): void => {\n const { serverURL, lang, login, wordLimit, requiredMeta } = config.value;\n\n const comment: WalineCommentData = {\n comment: content.value,\n nick: userMeta.value.nick,\n mail: userMeta.value.mail,\n link: userMeta.value.link,\n ua: navigator.userAgent,\n url: config.value.path,\n };\n\n if (userInfo.value?.token) {\n // login user\n\n comment.nick = userInfo.value.display_name;\n comment.mail = userInfo.value.email;\n comment.link = userInfo.value.url;\n } else {\n if (login === 'force') return;\n\n // check nick\n if (\n (requiredMeta.indexOf('nick') > -1 || comment.nick) &&\n !comment.nick\n ) {\n inputRefs.value.nick?.focus();\n return alert(locale.value.nickError);\n }\n\n // check mail\n if (requiredMeta.indexOf('mail') > -1 && !comment.mail) {\n inputRefs.value.mail?.focus();\n return alert(locale.value.mailError);\n }\n\n // check comment\n if (!comment.comment) {\n editorRef.value?.focus();\n return;\n }\n\n if (!comment.nick) comment.nick = locale.value.anonymous;\n }\n\n if (!isWordNumberLegal.value)\n return alert(\n locale.value.wordHint\n .replace('$0', (wordLimit as [number, number])[0].toString())\n .replace('$1', (wordLimit as [number, number])[1].toString())\n .replace('$2', wordNumber.value.toString())\n );\n\n comment.comment = parseEmoji(comment.comment, emoji.value.map);\n\n if (props.replyId && props.rootId) {\n comment.pid = props.replyId;\n comment.rid = props.rootId;\n comment.at = props.replyUser;\n }\n\n isSubmitting.value = true;\n\n postComment({\n serverURL,\n lang,\n token: userInfo.value?.token,\n comment,\n })\n .then((resp) => {\n isSubmitting.value = false;\n\n if (resp.errmsg) return alert(resp.errmsg);\n\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n emit('submit', resp.data!);\n\n editor.value = '';\n\n previewText.value = '';\n\n if (props.replyId) emit('cancel-reply');\n })\n .catch((err: TypeError) => {\n isSubmitting.value = false;\n\n alert(err.message);\n });\n };\n\n const onLogin = (event: Event): void => {\n event.preventDefault();\n const { lang, serverURL } = config.value;\n\n const width = 450;\n const height = 450;\n const left = (window.innerWidth - width) / 2;\n const top = (window.innerHeight - height) / 2;\n\n const handler = window.open(\n `${serverURL}/ui/login?lng=${encodeURIComponent(lang)}`,\n '_blank',\n `width=${width},height=${height},left=${left},top=${top},scrollbars=no,resizable=no,status=no,location=no,toolbar=no,menubar=no`\n );\n\n handler?.postMessage({ type: 'TOKEN', data: null }, '*');\n\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const receiver = ({ data }: any): void => {\n if (!data || data.type !== 'userInfo') return;\n\n if (data.data.token) {\n handler?.close();\n userInfo.value = data.data;\n (data.data.remember ? localStorage : sessionStorage).setItem(\n 'WALINE_USER',\n JSON.stringify(data.data)\n );\n\n window.removeEventListener('message', receiver);\n }\n };\n\n window.addEventListener('message', receiver);\n };\n\n const onLogout = (): void => {\n userInfo.value = {};\n localStorage.setItem('WALINE_USER', 'null');\n sessionStorage.setItem('WALINE_USER', 'null');\n };\n\n const onProfile = (event: Event): void => {\n event.preventDefault();\n\n const { lang, serverURL } = config.value;\n\n const width = 800;\n const height = 800;\n const left = (window.innerWidth - width) / 2;\n const top = (window.innerHeight - height) / 2;\n const handler = window.open(\n `${serverURL}/ui/profile?lng=${encodeURIComponent(lang)}`,\n '_blank',\n `width=${width},height=${height},left=${left},top=${top},scrollbars=no,resizable=no,status=no,location=no,toolbar=no,menubar=no`\n );\n\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n handler?.postMessage({ type: 'TOKEN', data: userInfo.value!.token }, '*');\n\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const receiver = ({ data }: any): void => {\n if (!data || data.type !== 'profile') return;\n\n userInfo.value = { ...userInfo.value, ...data };\n\n [localStorage, sessionStorage]\n .filter((store) => store.getItem('WALINE_USER'))\n .forEach((store) =>\n store.setItem('WALINE_USER', JSON.stringify(userInfo))\n );\n window.removeEventListener('message', receiver);\n };\n\n window.addEventListener('message', receiver);\n };\n\n const popupHandler = (event: MouseEvent): void => {\n if (\n !(emojiButtonRef.value as HTMLElement).contains(event.target as Node) &&\n !(emojiPopupRef.value as HTMLElement).contains(event.target as Node)\n )\n showEmoji.value = false;\n };\n\n // update wordNumber\n watch(\n [config, wordNumber],\n ([config, wordNumber]) => {\n const { wordLimit: limit } = config;\n\n if (limit) {\n if (wordNumber < limit[0] && limit[0] !== 0) {\n wordLimit.value = limit[0];\n isWordNumberLegal.value = false;\n } else if (wordNumber > limit[1]) {\n wordLimit.value = limit[1];\n isWordNumberLegal.value = false;\n } else {\n wordLimit.value = limit[1];\n isWordNumberLegal.value = true;\n }\n } else {\n wordLimit.value = 0;\n isWordNumberLegal.value = true;\n }\n },\n { immediate: true }\n );\n\n onMounted(() => {\n document.body.addEventListener('click', popupHandler);\n\n // watch editor\n watch(\n () => editor.value,\n (value) => {\n const { highlighter, texRenderer } = config.value;\n\n content.value = value;\n previewText.value = parseMarkdown(value, {\n emojiMap: emoji.value.map,\n highlighter,\n texRenderer,\n });\n wordNumber.value = getWordNumber(value);\n\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n if (value) autosize(editorRef.value!);\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n else autosize.destroy(editorRef.value!);\n },\n { immediate: true }\n );\n\n // watch emoji value change\n watch(\n () => config.value.emoji,\n (emojiConfig) =>\n getEmojis(emojiConfig).then((config) => {\n emoji.value = config;\n }),\n { immediate: true }\n );\n });\n\n onUnmounted(() => {\n document.body.removeEventListener('click', popupHandler);\n });\n\n return {\n // config\n config,\n locale,\n\n // events\n insert,\n onChange,\n onDrop,\n onKeyDown,\n onPaste,\n onLogin,\n onLogout,\n onProfile,\n submitComment,\n\n isLogin,\n userInfo,\n isSubmitting,\n\n // word\n wordNumber,\n wordLimit,\n isWordNumberLegal,\n\n // inputs\n editor,\n userMeta,\n\n // emoji\n emoji,\n emojiTabIndex,\n showEmoji,\n\n // image\n canUploadImage,\n\n // preview\n previewText,\n showPreview,\n\n // ref\n inputRefs,\n editorRef,\n emojiButtonRef,\n emojiPopupRef,\n imageUploadRef,\n };\n },\n});\n</script>\n","<template>\n <div class=\"wl-item\" :id=\"comment.objectId\">\n <div class=\"wl-user\" aria-hidden=\"true\">\n <img v-if=\"comment.avatar\" :src=\"comment.avatar\" />\n <VerifiedIcon v-if=\"comment.type\" />\n </div>\n\n <div class=\"wl-card\">\n <div class=\"wl-head\">\n <a\n v-if=\"link\"\n class=\"wl-nick\"\n :href=\"link\"\n target=\"_blank\"\n rel=\"nofollow noreferrer\"\n >{{ comment.nick }}</a\n >\n <span v-else class=\"wl-nick\">{{ comment.nick }}</span>\n\n <span\n v-if=\"comment.type === 'administrator'\"\n class=\"wl-badge\"\n v-text=\"locale.admin\"\n />\n <span v-if=\"comment.sticky\" class=\"wl-badge\" v-text=\"locale.sticky\" />\n\n <span class=\"wl-time\" v-text=\"time\" />\n\n <button\n class=\"wl-reply\"\n :class=\"{ active: isReplyingCurrent }\"\n :title=\"isReplyingCurrent ? locale.cancelReply : locale.reply\"\n @click=\"$emit('reply', isReplyingCurrent ? null : comment)\"\n >\n <ReplyIcon />\n </button>\n </div>\n <div class=\"wl-meta\" aria-hidden=\"true\">\n <span v-if=\"comment.browser\" v-text=\"comment.browser\" />\n <span v-if=\"comment.os\" v-text=\"comment.os\" />\n </div>\n <div class=\"wl-content\" v-html=\"comment.comment\" />\n\n <div v-if=\"isReplyingCurrent\" class=\"wl-reply-wrapper\">\n <CommentBox\n :replyId=\"comment.objectId\"\n :replyUser=\"comment.nick\"\n :rootId=\"rootId\"\n @submit=\"$emit('submit', $event)\"\n @cancel-reply=\"$emit('reply', null)\"\n />\n </div>\n <div v-if=\"comment.children\" class=\"wl-quote\">\n <CommentCard\n v-for=\"child in comment.children\"\n :key=\"child.objectId\"\n :comment=\"child\"\n :reply=\"reply\"\n :rootId=\"rootId\"\n @reply=\"$emit('reply', $event)\"\n @submit=\"$emit('submit', $event)\"\n />\n </div>\n </div>\n </div>\n</template>\n\n<script lang=\"ts\">\nimport { computed, defineComponent, inject } from 'vue';\nimport CommentBox from './CommentBox.vue';\nimport { ReplyIcon, VerifiedIcon } from './Icons';\nimport { isLinkHttp } from '../utils';\nimport { useTimeAgo } from '../composables';\n\nimport type { ComputedRef, PropType } from 'vue';\nimport type { WalineConfig } from '../utils';\nimport type { WalineComment } from '../typings';\n\nexport default defineComponent({\n props: {\n comment: {\n type: Object as PropType<WalineComment>,\n required: true,\n },\n rootId: {\n type: String,\n required: true,\n },\n reply: {\n type: Object as PropType<WalineComment | null>,\n },\n },\n\n components: {\n CommentBox,\n ReplyIcon,\n VerifiedIcon,\n },\n\n emits: ['submit', 'reply'],\n\n setup(props) {\n const config = inject<ComputedRef<WalineConfig>>(\n 'config'\n ) as ComputedRef<WalineConfig>;\n const locale = computed(() => config.value.locale);\n\n const link = computed(() => {\n let { link } = props.comment;\n\n return link ? (isLinkHttp(link) ? link : `https://${link}`) : '';\n });\n\n const time = useTimeAgo(props.comment.insertedAt, locale.value);\n\n const isReplyingCurrent = computed(\n () => props.comment.objectId === props.reply?.objectId\n );\n\n return {\n config,\n locale,\n\n isReplyingCurrent,\n link,\n time,\n };\n },\n});\n</script>\n","<template>\n <div class=\"wl-item\" :id=\"comment.objectId\">\n <div class=\"wl-user\" aria-hidden=\"true\">\n <img v-if=\"comment.avatar\" :src=\"comment.avatar\" />\n <VerifiedIcon v-if=\"comment.type\" />\n </div>\n\n <div class=\"wl-card\">\n <div class=\"wl-head\">\n <a\n v-if=\"link\"\n class=\"wl-nick\"\n :href=\"link\"\n target=\"_blank\"\n rel=\"nofollow noreferrer\"\n >{{ comment.nick }}</a\n >\n <span v-else class=\"wl-nick\">{{ comment.nick }}</span>\n\n <span\n v-if=\"comment.type === 'administrator'\"\n class=\"wl-badge\"\n v-text=\"locale.admin\"\n />\n <span v-if=\"comment.sticky\" class=\"wl-badge\" v-text=\"locale.sticky\" />\n\n <span class=\"wl-time\" v-text=\"time\" />\n\n <button\n class=\"wl-reply\"\n :class=\"{ active: isReplyingCurrent }\"\n :title=\"isReplyingCurrent ? locale.cancelReply : locale.reply\"\n @click=\"$emit('reply', isReplyingCurrent ? null : comment)\"\n >\n <ReplyIcon />\n </button>\n </div>\n <div class=\"wl-meta\" aria-hidden=\"true\">\n <span v-if=\"comment.browser\" v-text=\"comment.browser\" />\n <span v-if=\"comment.os\" v-text=\"comment.os\" />\n </div>\n <div class=\"wl-content\" v-html=\"comment.comment\" />\n\n <div v-if=\"isReplyingCurrent\" class=\"wl-reply-wrapper\">\n <CommentBox\n :replyId=\"comment.objectId\"\n :replyUser=\"comment.nick\"\n :rootId=\"rootId\"\n @submit=\"$emit('submit', $event)\"\n @cancel-reply=\"$emit('reply', null)\"\n />\n </div>\n <div v-if=\"comment.children\" class=\"wl-quote\">\n <CommentCard\n v-for=\"child in comment.children\"\n :key=\"child.objectId\"\n :comment=\"child\"\n :reply=\"reply\"\n :rootId=\"rootId\"\n @reply=\"$emit('reply', $event)\"\n @submit=\"$emit('submit', $event)\"\n />\n </div>\n </div>\n </div>\n</template>\n\n<script lang=\"ts\">\nimport { computed, defineComponent, inject } from 'vue';\nimport CommentBox from './CommentBox.vue';\nimport { ReplyIcon, VerifiedIcon } from './Icons';\nimport { isLinkHttp } from '../utils';\nimport { useTimeAgo } from '../composables';\n\nimport type { ComputedRef, PropType } from 'vue';\nimport type { WalineConfig } from '../utils';\nimport type { WalineComment } from '../typings';\n\nexport default defineComponent({\n props: {\n comment: {\n type: Object as PropType<WalineComment>,\n required: true,\n },\n rootId: {\n type: String,\n required: true,\n },\n reply: {\n type: Object as PropType<WalineComment | null>,\n },\n },\n\n components: {\n CommentBox,\n ReplyIcon,\n VerifiedIcon,\n },\n\n emits: ['submit', 'reply'],\n\n setup(props) {\n const config = inject<ComputedRef<WalineConfig>>(\n 'config'\n ) as ComputedRef<WalineConfig>;\n const locale = computed(() => config.value.locale);\n\n const link = computed(() => {\n let { link } = props.comment;\n\n return link ? (isLinkHttp(link) ? link : `https://${link}`) : '';\n });\n\n const time = useTimeAgo(props.comment.insertedAt, locale.value);\n\n const isReplyingCurrent = computed(\n () => props.comment.objectId === props.reply?.objectId\n );\n\n return {\n config,\n locale,\n\n isReplyingCurrent,\n link,\n time,\n };\n },\n});\n</script>\n","<template>\n <div data-waline>\n <CommentBox v-if=\"!reply\" @submit=\"onSubmit\" />\n <div class=\"wl-count\">\n <span v-if=\"count\" class=\"wl-num\" v-text=\"count\" />\n {{ i18n.comment }}\n </div>\n\n <div class=\"wl-cards\">\n <CommentCard\n v-for=\"comment in data\"\n :key=\"comment.objectId\"\n :root-id=\"comment.objectId\"\n :comment=\"comment\"\n :reply=\"reply\"\n @reply=\"onReply\"\n @submit=\"onSubmit\"\n />\n </div>\n\n <div v-if=\"status === 'error'\" class=\"wl-operation\">\n <button\n type=\"button\"\n class=\"wl-btn\"\n @click=\"refresh\"\n v-text=\"i18n.refresh\"\n />\n </div>\n\n <template v-else>\n <div v-if=\"status === 'loading'\" class=\"wl-loading\">\n <LoadingIcon :size=\"30\" />\n </div>\n\n <div v-else-if=\"!data.length\" class=\"wl-empty\" v-text=\"i18n.sofa\" />\n\n <!-- Load more button -->\n <div v-else-if=\"page < totalPages\" class=\"wl-operation\">\n <button\n type=\"button\"\n class=\"wl-btn\"\n @click=\"loadMore\"\n v-text=\"i18n.more\"\n />\n </div>\n </template>\n\n <!-- Copyright Information -->\n <div v-if=\"config.copyright\" class=\"wl-power\">\n Powered by\n <a\n href=\"https://github.com/walinejs/waline\"\n target=\"_blank\"\n rel=\"noreferrer\"\n >\n Waline\n </a>\n v{{ version }}\n </div>\n </div>\n</template>\n\n<script lang=\"ts\">\nimport {\n computed,\n defineComponent,\n onBeforeUnmount,\n onMounted,\n provide,\n ref,\n watch,\n watchEffect,\n} from 'vue';\nimport CommentBox from './CommentBox.vue';\nimport CommentCard from './CommentCard.vue';\nimport { LoadingIcon } from './Icons';\nimport { useUserInfo } from '../composables';\nimport { locales } from '../config';\nimport { fetchCommentList, getConfig, getDarkStyle } from '../utils';\n\nimport type { PropType } from 'vue';\nimport type {\n WalineComment,\n WalineEmojiInfo,\n WalineHighlighter,\n WalineTexRenderer,\n WalineImageUploader,\n WalineLocale,\n WalineProps,\n} from '../typings';\n\ndeclare const SHOULD_VALIDATE: boolean;\ndeclare const VERSION: string;\n\nexport default defineComponent({\n name: 'WalineRoot',\n\n components: {\n CommentBox,\n CommentCard,\n LoadingIcon,\n },\n\n props: {\n serverURL: {\n type: String,\n required: true,\n },\n\n path: {\n type: String,\n required: true,\n },\n\n meta: {\n type: Array,\n ...(SHOULD_VALIDATE\n ? {\n validator: (value: unknown): boolean =>\n Array.isArray(value) &&\n value.every((item) => ['nick', 'mail', 'link'].includes(item)),\n }\n : {}),\n },\n\n requiredMeta: {\n type: Array,\n ...(SHOULD_VALIDATE\n ? {\n validator: (value: unknown): boolean =>\n Array.isArray(value) &&\n value.every((item) => ['nick', 'mail', 'link'].includes(item)),\n }\n : {}),\n },\n\n dark: {\n type: [String, Boolean],\n },\n\n lang: {\n type: String,\n ...(SHOULD_VALIDATE\n ? {\n validator: (value: unknown): boolean =>\n Object.keys(locales).includes(value as string),\n }\n : {}),\n },\n\n locale: {\n type: Object as PropType<Partial<WalineLocale>>,\n },\n\n pageSize: {\n type: Number,\n },\n\n wordLimit: {\n type: [Number, Array] as PropType<number | [number, number]>,\n // default: 0,\n ...(SHOULD_VALIDATE\n ? {\n validator: (value: unknown): boolean =>\n typeof value === 'number' ||\n (Array.isArray(value) &&\n value.length === 2 &&\n value.every((item) => typeof item === 'number')),\n }\n : {}),\n },\n\n emoji: {\n type: Array as PropType<(string | WalineEmojiInfo)[]>,\n ...(SHOULD_VALIDATE\n ? {\n validator: (value: unknown): boolean =>\n Array.isArray(value) &&\n value.every(\n (item) =>\n typeof item === 'string' ||\n (typeof item === 'object' &&\n typeof item.name === 'string' &&\n typeof item.folder === 'string' &&\n typeof item.icon === 'string' &&\n Array.isArray(item.items) &&\n (item.items as unknown[]).every(\n (icon) => typeof icon === 'string'\n ))\n ),\n }\n : {}),\n },\n\n login: {\n type: String as PropType<'enable' | 'disable' | 'force'>,\n },\n\n highlighter: {\n type: Function as PropType<WalineHighlighter>,\n },\n\n imageUploader: {\n type: [Function, Boolean] as PropType<WalineImageUploader | false>,\n },\n\n texRenderer: {\n type: [Function, Boolean] as PropType<WalineTexRenderer | false>,\n },\n },\n\n setup(props) {\n const config = computed(() => getConfig(props as WalineProps));\n\n const userInfo = useUserInfo();\n\n const status = ref<'loading' | 'success' | 'error'>('loading');\n\n const count = ref(0);\n const page = ref(1);\n const totalPages = ref(0);\n\n const data = ref<WalineComment[]>([]);\n const reply = ref<WalineComment | null>(null);\n\n const darkmodeStyle = computed(() => getDarkStyle(config.value.dark));\n\n // eslint-disable-next-line vue/no-setup-props-destructure\n let abort: () => void;\n let stop: () => void;\n\n const fetchComment = (pageNumber: number): void => {\n const { serverURL, path, pageSize } = config.value;\n const controller = new AbortController();\n\n status.value = 'loading';\n\n abort?.();\n\n fetchCommentList({\n serverURL,\n path,\n pageSize,\n page: pageNumber,\n signal: controller.signal,\n token: userInfo.value?.token,\n })\n .then((resp) => {\n status.value = 'success';\n count.value = resp.count;\n data.value.push(...resp.data);\n page.value = pageNumber;\n totalPages.value = resp.totalPages;\n })\n .catch((err) => {\n if (err.name !== 'AbortError') {\n console.error(err.message);\n status.value = 'error';\n }\n });\n\n abort = controller.abort.bind(controller);\n };\n\n const loadMore = (): void => fetchComment(page.value + 1);\n\n const refresh = (): void => {\n count.value = 0;\n data.value = [];\n fetchComment(1);\n };\n\n const onReply = (comment: WalineComment | null): void => {\n reply.value = comment;\n };\n\n const onSubmit = (comment: WalineComment): void => {\n if (comment.rid) {\n const repliedComment = data.value.find(\n ({ objectId }) => objectId === comment.rid\n );\n\n if (!repliedComment) return;\n\n if (!Array.isArray(repliedComment.children))\n repliedComment.children = [];\n\n repliedComment.children.push(comment);\n } else data.value.unshift(comment);\n };\n\n provide('config', config);\n\n watch(() => props.path, refresh);\n\n onMounted(() => {\n refresh();\n\n const style = document.createElement('style');\n\n style.innerText = darkmodeStyle.value;\n\n document.querySelector('[data-waline]')?.appendChild(style);\n\n stop = watchEffect(() => {\n style.innerText = darkmodeStyle.value;\n });\n });\n\n onBeforeUnmount(() => stop());\n\n return {\n config,\n darkmodeStyle,\n i18n: computed(() => config.value.locale),\n\n status,\n count,\n page,\n totalPages,\n data,\n reply,\n\n loadMore,\n refresh,\n onReply,\n onSubmit,\n\n version: VERSION,\n };\n },\n});\n</script>\n","<template>\n <div data-waline>\n <CommentBox v-if=\"!reply\" @submit=\"onSubmit\" />\n <div class=\"wl-count\">\n <span v-if=\"count\" class=\"wl-num\" v-text=\"count\" />\n {{ i18n.comment }}\n </div>\n\n <div class=\"wl-cards\">\n <CommentCard\n v-for=\"comment in data\"\n :key=\"comment.objectId\"\n :root-id=\"comment.objectId\"\n :comment=\"comment\"\n :reply=\"reply\"\n @reply=\"onReply\"\n @submit=\"onSubmit\"\n />\n </div>\n\n <div v-if=\"status === 'error'\" class=\"wl-operation\">\n <button\n type=\"button\"\n class=\"wl-btn\"\n @click=\"refresh\"\n v-text=\"i18n.refresh\"\n />\n </div>\n\n <template v-else>\n <div v-if=\"status === 'loading'\" class=\"wl-loading\">\n <LoadingIcon :size=\"30\" />\n </div>\n\n <div v-else-if=\"!data.length\" class=\"wl-empty\" v-text=\"i18n.sofa\" />\n\n <!-- Load more button -->\n <div v-else-if=\"page < totalPages\" class=\"wl-operation\">\n <button\n type=\"button\"\n class=\"wl-btn\"\n @click=\"loadMore\"\n v-text=\"i18n.more\"\n />\n </div>\n </template>\n\n <!-- Copyright Information -->\n <div v-if=\"config.copyright\" class=\"wl-power\">\n Powered by\n <a\n href=\"https://github.com/walinejs/waline\"\n target=\"_blank\"\n rel=\"noreferrer\"\n >\n Waline\n </a>\n v{{ version }}\n </div>\n </div>\n</template>\n\n<script lang=\"ts\">\nimport {\n computed,\n defineComponent,\n onBeforeUnmount,\n onMounted,\n provide,\n ref,\n watch,\n watchEffect,\n} from 'vue';\nimport CommentBox from './CommentBox.vue';\nimport CommentCard from './CommentCard.vue';\nimport { LoadingIcon } from './Icons';\nimport { useUserInfo } from '../composables';\nimport { locales } from '../config';\nimport { fetchCommentList, getConfig, getDarkStyle } from '../utils';\n\nimport type { PropType } from 'vue';\nimport type {\n WalineComment,\n WalineEmojiInfo,\n WalineHighlighter,\n WalineTexRenderer,\n WalineImageUploader,\n WalineLocale,\n WalineProps,\n} from '../typings';\n\ndeclare const SHOULD_VALIDATE: boolean;\ndeclare const VERSION: string;\n\nexport default defineComponent({\n name: 'WalineRoot',\n\n components: {\n CommentBox,\n CommentCard,\n LoadingIcon,\n },\n\n props: {\n serverURL: {\n type: String,\n required: true,\n },\n\n path: {\n type: String,\n required: true,\n },\n\n meta: {\n type: Array,\n ...(SHOULD_VALIDATE\n ? {\n validator: (value: unknown): boolean =>\n Array.isArray(value) &&\n value.every((item) => ['nick', 'mail', 'link'].includes(item)),\n }\n : {}),\n },\n\n requiredMeta: {\n type: Array,\n ...(SHOULD_VALIDATE\n ? {\n validator: (value: unknown): boolean =>\n Array.isArray(value) &&\n value.every((item) => ['nick', 'mail', 'link'].includes(item)),\n }\n : {}),\n },\n\n dark: {\n type: [String, Boolean],\n },\n\n lang: {\n type: String,\n ...(SHOULD_VALIDATE\n ? {\n validator: (value: unknown): boolean =>\n Object.keys(locales).includes(value as string),\n }\n : {}),\n },\n\n locale: {\n type: Object as PropType<Partial<WalineLocale>>,\n },\n\n pageSize: {\n type: Number,\n },\n\n wordLimit: {\n type: [Number, Array] as PropType<number | [number, number]>,\n // default: 0,\n ...(SHOULD_VALIDATE\n ? {\n validator: (value: unknown): boolean =>\n typeof value === 'number' ||\n (Array.isArray(value) &&\n value.length === 2 &&\n value.every((item) => typeof item === 'number')),\n }\n : {}),\n },\n\n emoji: {\n type: Array as PropType<(string | WalineEmojiInfo)[]>,\n ...(SHOULD_VALIDATE\n ? {\n validator: (value: unknown): boolean =>\n Array.isArray(value) &&\n value.every(\n (item) =>\n typeof item === 'string' ||\n (typeof item === 'object' &&\n typeof item.name === 'string' &&\n typeof item.folder === 'string' &&\n typeof item.icon === 'string' &&\n Array.isArray(item.items) &&\n (item.items as unknown[]).every(\n (icon) => typeof icon === 'string'\n ))\n ),\n }\n : {}),\n },\n\n login: {\n type: String as PropType<'enable' | 'disable' | 'force'>,\n },\n\n highlighter: {\n type: Function as PropType<WalineHighlighter>,\n },\n\n imageUploader: {\n type: [Function, Boolean] as PropType<WalineImageUploader | false>,\n },\n\n texRenderer: {\n type: [Function, Boolean] as PropType<WalineTexRenderer | false>,\n },\n },\n\n setup(props) {\n const config = computed(() => getConfig(props as WalineProps));\n\n const userInfo = useUserInfo();\n\n const status = ref<'loading' | 'success' | 'error'>('loading');\n\n const count = ref(0);\n const page = ref(1);\n const totalPages = ref(0);\n\n const data = ref<WalineComment[]>([]);\n const reply = ref<WalineComment | null>(null);\n\n const darkmodeStyle = computed(() => getDarkStyle(config.value.dark));\n\n // eslint-disable-next-line vue/no-setup-props-destructure\n let abort: () => void;\n let stop: () => void;\n\n const fetchComment = (pageNumber: number): void => {\n const { serverURL, path, pageSize } = config.value;\n const controller = new AbortController();\n\n status.value = 'loading';\n\n abort?.();\n\n fetchCommentList({\n serverURL,\n path,\n pageSize,\n page: pageNumber,\n signal: controller.signal,\n token: userInfo.value?.token,\n })\n .then((resp) => {\n status.value = 'success';\n count.value = resp.count;\n data.value.push(...resp.data);\n page.value = pageNumber;\n totalPages.value = resp.totalPages;\n })\n .catch((err) => {\n if (err.name !== 'AbortError') {\n console.error(err.message);\n status.value = 'error';\n }\n });\n\n abort = controller.abort.bind(controller);\n };\n\n const loadMore = (): void => fetchComment(page.value + 1);\n\n const refresh = (): void => {\n count.value = 0;\n data.value = [];\n fetchComment(1);\n };\n\n const onReply = (comment: WalineComment | null): void => {\n reply.value = comment;\n };\n\n const onSubmit = (comment: WalineComment): void => {\n if (comment.rid) {\n const repliedComment = data.value.find(\n ({ objectId }) => objectId === comment.rid\n );\n\n if (!repliedComment) return;\n\n if (!Array.isArray(repliedComment.children))\n repliedComment.children = [];\n\n repliedComment.children.push(comment);\n } else data.value.unshift(comment);\n };\n\n provide('config', config);\n\n watch(() => props.path, refresh);\n\n onMounted(() => {\n refresh();\n\n const style = document.createElement('style');\n\n style.innerText = darkmodeStyle.value;\n\n document.querySelector('[data-waline]')?.appendChild(style);\n\n stop = watchEffect(() => {\n style.innerText = darkmodeStyle.value;\n });\n });\n\n onBeforeUnmount(() => stop());\n\n return {\n config,\n darkmodeStyle,\n i18n: computed(() => config.value.locale),\n\n status,\n count,\n page,\n totalPages,\n data,\n reply,\n\n loadMore,\n refresh,\n onReply,\n onSubmit,\n\n version: VERSION,\n };\n },\n});\n</script>\n","import {\n errorHandler,\n fetchPageviews,\n getQuery,\n updatePageviews,\n} from './utils';\n\nimport type { WalineAbort } from './typings';\n\nexport interface WalinePageviewCountOptions {\n /**\n * Waline 服务端地址\n *\n * Waline server url\n */\n serverURL: string;\n\n /**\n * 浏览量 CSS 选择器\n *\n * Pageview CSS selector\n *\n * @default '.waline-pageview-count'\n */\n selector?: string;\n\n /**\n * 需要更新和获取的路径\n *\n * Path to be fetched and updated\n *\n * @default window.location.pathname\n */\n path?: string;\n\n /**\n * 是否在查询时更新 path 的浏览量\n *\n * Whether update pageviews when fetching path result\n *\n * @default true\n */\n update?: boolean;\n}\n\nconst renderVisitorCount = (\n counts: number[],\n countElements: HTMLElement[]\n): void => {\n countElements.forEach((element, index) => {\n element.innerText = counts[index].toString();\n });\n};\n\nexport const pageviewCount = ({\n serverURL,\n path = window.location.pathname,\n selector = '.waline-pageview-count',\n update = true,\n}: WalinePageviewCountOptions): WalineAbort => {\n const controller = new AbortController();\n\n const elements = Array.from(\n // pageview selectors\n document.querySelectorAll<HTMLElement>(selector)\n );\n\n const filter = (element: HTMLElement): boolean => {\n const query = getQuery(element);\n\n return query !== null && path !== query;\n };\n\n const fetch = (elements: HTMLElement[]): Promise<void> =>\n fetchPageviews({\n serverURL,\n paths: elements.map((element) => getQuery(element) || path),\n signal: controller.signal,\n })\n .then((counts) => renderVisitorCount(counts, elements))\n .catch(errorHandler);\n\n // we should update pageviews\n if (update) {\n const normalElements = elements.filter((element) => !filter(element));\n const elementsNeedstoBeFetched = elements.filter(filter);\n\n void updatePageviews({ serverURL, path }).then((count) =>\n renderVisitorCount(\n new Array<number>(normalElements.length).fill(count),\n normalElements\n )\n );\n\n // if we should fetch count of other pages\n if (elementsNeedstoBeFetched.length) {\n void fetch(elementsNeedstoBeFetched);\n }\n }\n // we should not update pageviews\n else {\n void fetch(elements);\n }\n\n return controller.abort.bind(controller);\n};\n","import { useUserInfo } from '../composables';\nimport { fetchRecentComment, getRoot } from '../utils';\n\nimport type { WalineComment } from '../typings';\n\nexport interface WalineRecentCommentsOptions {\n /**\n * Waline 服务端地址\n *\n * Waline serverURL\n */\n serverURL: string;\n\n /**\n * 获取最新评论的数量\n *\n * fetch number of latest comments\n */\n count: number;\n\n /**\n * 需要挂载的元素\n *\n * Element to be mounted\n */\n el?: string | HTMLElement;\n}\n\nexport interface WalineRecentCommentsResult {\n /**\n * 评论数据\n *\n * Comment Data\n */\n comments: WalineComment[];\n\n /**\n * 取消挂载挂件\n *\n * Umount widget\n */\n destroy: () => void;\n}\n\nexport const RecentComments = ({\n el,\n serverURL,\n count,\n}: WalineRecentCommentsOptions): Promise<WalineRecentCommentsResult> => {\n const userInfo = useUserInfo();\n const root = getRoot(el);\n const controller = new AbortController();\n\n return fetchRecentComment({\n serverURL,\n count,\n signal: controller.signal,\n token: userInfo.value?.token,\n }).then((comments) => {\n if (root && comments.length) {\n root.innerHTML = `<ul class=\"wl-recent-list\">${comments\n .map(\n (comment) =>\n `<li class=\"wl-recent-item\"><a href=\"${comment.url}\">${comment.nick}</a>:${comment.comment}</li>`\n )\n .join('')}</ul>`;\n\n return {\n comments,\n destroy: (): void => {\n controller.abort();\n root.innerHTML = '';\n },\n };\n }\n\n return {\n comments,\n destroy: (): void => controller.abort(),\n };\n });\n};\n","import { createApp, h, reactive, watchEffect } from 'vue';\n\nimport Waline from './components/Waline.vue';\nimport { commentCount } from './comment';\nimport { pageviewCount } from './pageview';\nimport { getRoot } from './utils';\n\nimport type { WalineInitOptions } from './typings';\n\nexport interface WalineInstance {\n /**\n * Waline 被挂载到的元素\n *\n * @description 当通过 `el: null` 初始化,值为 `null`\n *\n * Element where Waline is mounted\n *\n * @description when initialized with `el: null`, it will be `null`\n */\n el: HTMLElement | null;\n\n /**\n * 更新 Waline 实例\n *\n * @description 只要不设置`path` 选项,更新时它就会被重置为 `windows.location.pathname`\n *\n * Update Waline instance\n *\n * @description when not setting `path` option, it will be reset to `window.location.pathname`\n */\n update: (newOptions: Partial<Omit<WalineInitOptions, 'el'>>) => void;\n\n /**\n * 取消挂载并摧毁 Waline 实例\n *\n * Unmount and destroy Waline instance\n */\n destroy: () => void;\n}\n\nexport const init = ({\n el = '#waline',\n path = window.location.pathname,\n comment = false,\n pageview = false,\n ...initProps\n}: WalineInitOptions): WalineInstance | null => {\n // check el element\n const root = el ? getRoot(el) : null;\n\n // check root\n if (el && !root) throw new Error(`Option 'el' do not match any domElement!`);\n\n // check serverURL\n if (!initProps.serverURL) throw new Error(\"Option 'serverURL' is missing!\");\n\n const props = reactive({ ...initProps });\n const state = reactive({ comment, pageview, path });\n\n const updateCommentCount = (): void => {\n if (state.comment)\n commentCount({\n serverURL: props.serverURL,\n path: state.path,\n selector: typeof state.comment === 'string' ? state.comment : undefined,\n });\n };\n\n const updatePageviewCount = (): void => {\n if (state.pageview)\n pageviewCount({\n serverURL: props.serverURL,\n path: state.path,\n selector:\n typeof state.pageview === 'string' ? state.pageview : undefined,\n });\n };\n\n const app = root\n ? createApp(() => h(Waline, { path: state.path, ...props }))\n : null;\n\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n if (app) app.mount(root!);\n\n updateCommentCount();\n updatePageviewCount();\n\n const stopComment = watchEffect(updateCommentCount);\n const stopPageview = watchEffect(updatePageviewCount);\n\n return {\n el: root,\n update: ({\n comment,\n pageview,\n path = window.location.pathname,\n ...newProps\n }: Partial<Omit<WalineInitOptions, 'el'>>): void => {\n Object.entries(newProps).forEach(([key, value]) => {\n // eslint-disable-next-line @typescript-eslint/ban-ts-comment\n // @ts-ignore\n // eslint-disable-next-line\n props[key] = value;\n });\n\n state.path = path;\n if (comment !== undefined) state.comment = comment;\n if (pageview !== undefined) state.pageview = pageview;\n },\n destroy: (): void => {\n app?.unmount();\n stopComment();\n stopPageview();\n },\n };\n};\n","declare const VERSION: string;\n\nexport const version = VERSION;\n"],"names":["availableMeta","getMeta","meta","filter","item","includes","defaultUploadImage","file","Promise","resolve","reject","reader","FileReader","readAsDataURL","onload","_a","result","toString","onerror","defaultTexRenderer","blockMode","localeKeys","generateLocale","locale","Object","fromEntries","map","index","en","jp","zhCN","zhTW","ptBR","ru","locales","zh","tryOnScopeDispose","fn","getCurrentScope","onScopeDispose","isClient","window","noop","bypassFilter","invoke","__getOwnPropSymbols$5","getOwnPropertySymbols","__hasOwnProp$5","prototype","hasOwnProperty","__propIsEnum$5","propertyIsEnumerable","watchWithFilter","source","cb","options","eventFilter","watchOptions","exclude","target","prop","call","indexOf","__objRest$5","watch","args","apply","this","thisArg","__defProp$1","defineProperty","__defProps$1","defineProperties","__getOwnPropDescs$1","getOwnPropertyDescriptors","__getOwnPropSymbols$1","__hasOwnProp$1","__propIsEnum$1","__defNormalProp$1","obj","key","value","enumerable","configurable","writable","watchPausable","__objRest$1","pause","resume","isActive","extendFilter","ref","pausableFilter","stop","a","b","__spreadValues$1","defaultWindow","useEventListener","event","listener","cleanup","stopWatch","elRef","plain","unref","$el","unrefElement","el","addEventListener","removeEventListener","immediate","flush","document","navigator","location","_global","globalThis","global","self","globalKey","handlers","StorageSerializers","boolean","read","v","write","String","object","JSON","parse","stringify","number","Number","parseFloat","any","string","Map","Array","from","entries","set","Set","date","Date","toISOString","useStorage","initialValue","storage","deep","listenToStorageChanges","writeDefaults","shallow","onError","e","console","error","data","shallowRef","fallback","getSSRHandler","_a2","localStorage","rawInit","type","isArray","isNaN","guessSerializerType","serializer","pauseWatch","resumeWatch","pausableWatch","removeItem","setItem","update","rawValue","newValue","getItem","_b","__defProp$5","__defNormalProp$5","useNow","controls","exposeControls","interval","now","rafId","loop","requestAnimationFrame","cancelAnimationFrame","useRafFn","immediateCallback","timer","clean","clearInterval","setInterval","isRef","useIntervalFn","__spreadValues$5","platform","test","decodePath","path","decodeURI","err","removeEndingSplash","content","replace","isLinkHttp","link","getServerURL","serverURL","getWordLimit","wordLimit","style","padWithZeros","vNumber","width","numAsString","length","fetchEmoji","emojiStore","Boolean","info","fetch","then","resp","json","emojiInfo","folder","getLink","name","prefix","errorHandler","message","errorCheck","errno","TypeError","errmsg","fetchPageviews","paths","signal","encodeURIComponent","join","counts","updatePageviews","method","headers","body","getRoot","HTMLElement","querySelector","isImage","getImagefromDataTransfer","items","image","find","getAsFile","inlineMathStart","inlineMathReg","blockMathReg","parseEmoji","text","emojiMap","placeholder","parseMarkdown","highlighter","texRenderer","marked","setOptions","highlight","undefined","breaks","smartLists","smartypants","extensions","level","tokenizer","src","cap","exec","raw","start","idx","search","markedTexExtensions","use","getQuery","element","dataset","getAttribute","useTimeAgo","computed","time","timepassed","getTime","days","Math","floor","leave1","hours","leave2","minutes","leave3","round","seconds","vDay","getDate","vMonth","getMonth","getFullYear","dateFormat","useUserInfo","commentCount","pathname","selector","controller","AbortController","elements","querySelectorAll","userInfo","token","Authorization","fetchCommentCount","forEach","innerText","catch","abort","bind","LoadingIcon","size","h","height","viewBox","preserveAspectRatio","cx","cy","fill","stroke","strokeWidth","r","attributeName","repeatCount","dur","values","keyTimes","script$2","defineComponent","components","CloseIcon","class","d","EmojiIcon","ImageIcon","MarkdownIcon","ariaHidden","PreviewIcon","props","rootId","default","replyId","replyUser","emits","setup","emit","config","inject","editor","userMeta","nick","mail","inputRefs","editorRef","imageUploadRef","emojiButtonRef","emojiPopupRef","emoji","tabs","emojiTabIndex","showEmoji","showPreview","previewText","wordNumber","isWordNumberLegal","isSubmitting","isLogin","canUploadImage","imageUploader","insert","textArea","startPosition","selectionStart","endPosition","selectionEnd","scrollTop","substring","focus","uploadImage","uploadText","uploading","url","submitComment","lang","login","requiredMeta","comment","ua","userAgent","display_name","email","alert","nickError","_c","mailError","_d","anonymous","wordHint","pid","rid","at","postComment","_e","popupHandler","contains","limit","onMounted","match","getWords","reduce","accumulator","word","trim","split","getChinese","getWordNumber","autosize","destroy","emojiConfig","getEmojis","emojis","all","emojiInfos","icon","push","onUnmounted","onChange","inputElement","files","onDrop","dataTransfer","preventDefault","onKeyDown","ctrlKey","metaKey","onPaste","clipboardData","onLogin","left","innerWidth","top","innerHeight","handler","open","postMessage","receiver","close","remember","sessionStorage","onLogout","onProfile","store","_hoisted_1","_hoisted_3","_hoisted_7","_hoisted_11","_createElementVNode","createElementVNode","_hoisted_14","_hoisted_15","href","title","rel","_hoisted_20","_hoisted_21","_openBlock","_createElementBlock","_ctx","_hoisted_2","logout","onClick","_createVNode","_component_CloseIcon","avatar","alt","_toDisplayString","toDisplayString","createElementBlock","_normalizeClass","normalizeClass","_Fragment","_renderList","renderList","kind","for","optional","id","$event","_vModelDynamic","onKeydown","_withDirectives","_hoisted_12","preview","innerHTML","_hoisted_16","_component_MarkdownIcon","actived","_cache","_component_EmojiIcon","accept","_component_ImageIcon","_component_PreviewIcon","_createTextVNode","createTextVNode","_hoisted_22","textContent","disabled","_createBlock","createBlock","_component_LoadingIcon","submit","display","_hoisted_27","Fragment","loading","referrerPolicy","_hoisted_30","active","cancelReply","$emit","script$1","required","reply","CommentBox","ReplyIcon","VerifiedIcon","insertedAt","isReplyingCurrent","objectId","_hoisted_4","_hoisted_5","_component_VerifiedIcon","admin","sticky","_component_ReplyIcon","browser","os","_component_CommentBox","onSubmit","onCancelReply","_hoisted_17","children","child","_component_CommentCard","onReply","script","CommentCard","dark","pageSize","Function","copyright","more","hanabi","getConfig","status","count","page","totalPages","darkmodeStyle","getDarkStyle","fetchComment","pageNumber","fetchCommentList","refresh","provide","createElement","appendChild","watchEffect","onBeforeUnmount","i18n","loadMore","repliedComment","unshift","version","_hoisted_9","_createCommentVNode","sofa","_hoisted_13","renderVisitorCount","countElements","pageviewCount","query","normalElements","elementsNeedstoBeFetched","root","fetchRecentComment","comments","pageview","initProps","Error","reactive","state","updateCommentCount","updatePageviewCount","app","createApp","Waline","mount","stopComment","stopPageview","newProps","unmount"],"mappings":"iPAEA,MAAMA,EAA8B,CAAC,OAAQ,OAAQ,QAExCC,EAAWC,GACtBA,EAAKC,QAAQC,GAASJ,EAAcK,SAASD,KAIlCE,EAAsBC,GACjC,IAAIC,SAAQ,CAACC,EAASC,KACpB,MAAMC,EAAS,IAAIC,WACnBD,EAAOE,cAAcN,GACrBI,EAAOG,OAAS,KAAY,IAAAC,EAAA,OAAAN,WAAQM,EAAAJ,EAAOK,6BAAQC,aAAc,KACjEN,EAAOO,QAAUR,KAGRS,EAAsBC,IACnB,IAAdA,EACI,wDACA,8DClBAC,EAAa,CACjB,OACA,YACA,OACA,YACA,OACA,WACA,cACA,OACA,SACA,QACA,cACA,UACA,UACA,OACA,UACA,QACA,cACA,UACA,UACA,QACA,OACA,MACA,YACA,QACA,SACA,QACA,SACA,OACA,WACA,aAGWC,EAAkBC,GAC7BC,OAAOC,YACLF,EAAOG,KAAI,CAACtB,EAAMuB,IAAU,CAACN,EAAWM,GAAQvB,MCnCpD,IAAAwB,EAAeN,EAAe,CAC5B,WACA,wCACA,SACA,qCACA,UACA,WACA,kBACA,kBACA,SACA,QACA,eACA,WACA,UACA,eACA,UACA,QACA,eACA,cACA,cACA,YACA,WACA,WACA,YACA,QACA,SACA,QACA,SACA,QACA,2EACA,cC9BFO,EAAeP,EAAe,CAC5B,SACA,yBACA,UACA,mBACA,MACA,QACA,UACA,aACA,OACA,OACA,QACA,OACA,KACA,UACA,QACA,MACA,YACA,KACA,KACA,MACA,KACA,OACA,SACA,SACA,QACA,MACA,SACA,MACA,gDACA,OC9BFQ,EAAeR,EAAe,CAC5B,KACA,aACA,KACA,aACA,KACA,KACA,OACA,SACA,KACA,KACA,OACA,KACA,KACA,UACA,KACA,KACA,OACA,KACA,MACA,MACA,KACA,KACA,OACA,KACA,KACA,KACA,KACA,IACA,+BACA,OC9BFS,EAAeT,EAAe,CAC5B,KACA,KACA,KACA,KACA,aACA,aACA,OACA,SACA,KACA,KACA,OACA,KACA,KACA,UACA,KACA,KACA,OACA,KACA,MACA,MACA,KACA,KACA,OACA,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"}
|