{"version":3,"file":"index.cjs","sources":["../src/core/compiler/module-compiler.ts","../src/core/compiler/preview-proxy.ts","../src/core/compiler/preview-iframe.html?raw","../src/playground/constants.ts","../src/core/compiler/preview.ts","../src/core/utils/babel-auto-import.js","../src/core/utils/babel.ts","../src/core/compiler/transform.ts","../../../node_modules/.pnpm/js-base64@3.7.2/node_modules/js-base64/base64.mjs","../src/core/utils/common.ts","../src/core/store.ts","../plugin-vue:export-helper","../src/playground/components/control-button.vue","../src/playground/components/icon.tsx","../src/playground/components/toolbar.vue","../../../node_modules/.pnpm/@vueuse+shared@8.4.1_vue@3.2.33/node_modules/@vueuse/shared/index.mjs","../../../node_modules/.pnpm/@vueuse+core@8.4.1_vue@3.2.33/node_modules/@vueuse/core/index.mjs","../src/playground/hooks/useEditor.ts","../src/playground/utils/common.ts","../src/playground/monaco/worker.ts","../src/playground/monaco/language.ts","../src/playground/monaco/setup.ts","../src/playground/hooks/useMonacoModels.ts","../src/playground/hooks/index.ts","../src/playground/hooks/useMonaco.ts","../src/playground/components/file-manager-bar.vue","../src/playground/components/message.vue","../src/playground/components/editor.vue","../src/playground/components/loading.vue","../src/playground/components/preview.vue","../src/playground/components/portal.ts","../src/playground/playground.type.ts","../src/playground/playground.vue","../src/index.ts"],"sourcesContent":["/* eslint-disable @typescript-eslint/no-explicit-any */\nimport {File, Store} from '../store'\nimport {ExportSpecifier, Identifier, Node} from '@babel/types'\n\nexport function compileModulesForPreview(store: Store) {\n  const seen = new Set<File>()\n  const processed: string[] = []\n  processFile(store, store.state.files[store.state.mainFile], processed, seen)\n\n  // also add css files that are not imported\n  for (const filename in store.state.files) {\n    if (filename.endsWith('.css')) {\n      const file = store.state.files[filename]\n      if (!seen.has(file)) {\n        processed.push(`\\nwindow.__css__ += ${JSON.stringify(file.compiled.css)}`)\n      }\n    }\n  }\n\n  return processed\n}\n\nconst modulesKey = `__modules__`\nconst exportKey = `__export__`\nconst dynamicImportKey = `__dynamic_import__`\nconst moduleKey = `__module__`\n\n// similar logic with Vite's SSR transform, except this is targeting the browser\nfunction processFile(store: Store, file: File, processed: string[], seen: Set<File>) {\n  if (seen.has(file)) {\n    return []\n  }\n  seen.add(file)\n\n  if (file.filename.endsWith('.html')) {\n    return processHtmlFile(store, file.code, file.filename, processed, seen)\n  }\n\n  // eslint-disable-next-line prefer-const\n  let [js, importedFiles] = processModule(store, file.compiled.js, file.filename)\n  // append css\n  if (file.compiled.css) {\n    js += `\\nwindow.__css__ += ${JSON.stringify(file.compiled.css)}`\n  }\n  // crawl child imports\n  if (importedFiles.size) {\n    for (const imported of importedFiles) {\n      processFile(store, store.state.files[imported], processed, seen)\n    }\n  }\n  // push self\n  processed.push(js)\n}\n\nfunction processModule(store: Store, src: string, filename: string): [string, Set<string>] {\n  const s = new store.compiler.MagicString(src)\n\n  const ast = store.compiler.babelParse(src, {\n    sourceFilename: filename,\n    sourceType: 'module'\n  }).program.body\n\n  const idToImportMap = new Map<string, string>()\n  const declaredConst = new Set<string>()\n  const importedFiles = new Set<string>()\n  const importToIdMap = new Map<string, string>()\n\n  function defineImport(node: Node, source: string) {\n    const filename = source.replace(/^\\.\\/+/, '')\n    if (!(filename in store.state.files)) {\n      throw new Error(`File \"${filename}\" does not exist.`)\n    }\n    if (importedFiles.has(filename)) {\n      return importToIdMap.get(filename)!\n    }\n    importedFiles.add(filename)\n    const id = `__import_${importedFiles.size}__`\n    importToIdMap.set(filename, id)\n    s.appendLeft(node.start!, `const ${id} = ${modulesKey}[${JSON.stringify(filename)}]\\n`)\n    return id\n  }\n\n  function defineExport(name: string, local = name) {\n    s.append(`\\n${exportKey}(${moduleKey}, \"${name}\", () => ${local})`)\n  }\n\n  // 0. instantiate module\n  s.prepend(`const ${moduleKey} = __modules__[${JSON.stringify(filename)}] = { [Symbol.toStringTag]: \"Module\" }\\n\\n`)\n\n  // 1. check all import statements and record id -> importName map\n  for (const node of ast) {\n    // import foo from 'foo' --> foo -> __import_foo__.default\n    // import { baz } from 'foo' --> baz -> __import_foo__.baz\n    // import * as ok from 'foo' --> ok -> __import_foo__\n    if (node.type === 'ImportDeclaration') {\n      const source = node.source.value\n      if (source.startsWith('./')) {\n        const importId = defineImport(node, node.source.value)\n        for (const spec of node.specifiers) {\n          if (spec.type === 'ImportSpecifier') {\n            idToImportMap.set(spec.local.name, `${importId}.${(spec.imported as Identifier).name}`)\n          } else if (spec.type === 'ImportDefaultSpecifier') {\n            idToImportMap.set(spec.local.name, `${importId}.default`)\n          } else {\n            // namespace specifier\n            idToImportMap.set(spec.local.name, importId)\n          }\n        }\n        s.remove(node.start!, node.end!)\n      }\n    }\n  }\n\n  // 2. check all export statements and define exports\n  for (const node of ast) {\n    // named exports\n    if (node.type === 'ExportNamedDeclaration') {\n      if (node.declaration) {\n        if (node.declaration.type === 'FunctionDeclaration' || node.declaration.type === 'ClassDeclaration') {\n          // export function foo() {}\n          defineExport(node.declaration.id!.name)\n        } else if (node.declaration.type === 'VariableDeclaration') {\n          // export const foo = 1, bar = 2\n          for (const decl of node.declaration.declarations) {\n            for (const id of store.compiler.extractIdentifiers(decl.id)) {\n              defineExport(id.name)\n            }\n          }\n        }\n        s.remove(node.start!, node.declaration.start!)\n      } else if (node.source) {\n        // export { foo, bar } from './foo'\n        const importId = defineImport(node, node.source.value)\n        for (const spec of node.specifiers) {\n          defineExport((spec.exported as Identifier).name, `${importId}.${(spec as ExportSpecifier).local.name}`)\n        }\n        s.remove(node.start!, node.end!)\n      } else {\n        // export { foo, bar }\n        for (const spec of node.specifiers) {\n          const local = (spec as ExportSpecifier).local.name\n          const binding = idToImportMap.get(local)\n          defineExport((spec.exported as Identifier).name, binding || local)\n        }\n        s.remove(node.start!, node.end!)\n      }\n    }\n\n    // default export\n    if (node.type === 'ExportDefaultDeclaration') {\n      if ('id' in node.declaration && node.declaration.id) {\n        // named hoistable/class exports\n        // export default function foo() {}\n        // export default class A {}\n        const {name} = node.declaration.id\n        s.remove(node.start!, node.start! + 15)\n        s.append(`\\n${exportKey}(${moduleKey}, \"default\", () => ${name})`)\n      } else {\n        // anonymous default exports\n        s.overwrite(node.start!, node.start! + 14, `${moduleKey}.default =`)\n      }\n    }\n\n    // export * from './foo'\n    if (node.type === 'ExportAllDeclaration') {\n      const importId = defineImport(node, node.source.value)\n      s.remove(node.start!, node.end!)\n      s.append(`\\nfor (const key in ${importId}) {\n        if (key !== 'default') {\n          ${exportKey}(${moduleKey}, key, () => ${importId}[key])\n        }\n      }`)\n    }\n  }\n\n  // 3. convert references to import bindings\n  for (const node of ast) {\n    if (node.type === 'ImportDeclaration') continue\n    store.compiler.walkIdentifiers(node, (id, parent, parentStack) => {\n      const binding = idToImportMap.get(id.name)\n      if (!binding) {\n        return\n      }\n      if (store.compiler.isStaticProperty(parent) && parent.shorthand) {\n        // let binding used in a property shorthand\n        // { foo } -> { foo: __import_x__.foo }\n        // skip for destructure patterns\n        if (!(parent as any).inPattern || store.compiler.isInDestructureAssignment(parent, parentStack)) {\n          s.appendLeft(id.end!, `: ${binding}`)\n        }\n      } else if (parent.type === 'ClassDeclaration' && id === parent.superClass) {\n        if (!declaredConst.has(id.name)) {\n          declaredConst.add(id.name)\n          // locate the top-most node containing the class declaration\n          const topNode = parentStack[1]\n          s.prependRight(topNode.start!, `const ${id.name} = ${binding};\\n`)\n        }\n      } else {\n        s.overwrite(id.start!, id.end!, binding)\n      }\n    })\n  }\n\n  // 4. convert dynamic imports\n  ;(store.compiler.walk as any)(ast, {\n    enter(node: Node, parent: Node) {\n      if (node.type === 'Import' && parent.type === 'CallExpression') {\n        const arg = parent.arguments[0]\n        if (arg.type === 'StringLiteral' && arg.value.startsWith('./')) {\n          s.overwrite(node.start!, node.start! + 6, dynamicImportKey)\n          s.overwrite(arg.start!, arg.end!, JSON.stringify(arg.value.replace(/^\\.\\/+/, '')))\n        }\n      }\n    }\n  })\n\n  return [s.toString(), importedFiles]\n}\n\nconst scriptRE = /<script\\b(?:\\s[^>]*>|>)([^]*?)<\\/script>/gi\nconst scriptModuleRE = /<script\\b[^>]*type\\s*=\\s*(?:\"module\"|'module')[^>]*>([^]*?)<\\/script>/gi\n\nfunction processHtmlFile(store: Store, src: string, filename: string, processed: string[], seen: Set<File>) {\n  const deps: string[] = []\n  let jsCode = ''\n  const html = src\n    .replace(scriptModuleRE, (_, content) => {\n      const [code, importedFiles] = processModule(store, content, filename)\n      if (importedFiles.size) {\n        for (const imported of importedFiles) {\n          processFile(store, store.state.files[imported], deps, seen)\n        }\n      }\n      jsCode += '\\n' + code\n      return ''\n    })\n    .replace(scriptRE, (_, content) => {\n      jsCode += '\\n' + content\n      return ''\n    })\n  processed.push(`document.body.innerHTML = ${JSON.stringify(html)}`)\n  processed.push(...deps)\n  processed.push(jsCode)\n}\n","/* eslint-disable @typescript-eslint/no-explicit-any */\n// ReplProxy and srcdoc implementation from Svelte REPL\n// MIT License https://github.com/sveltejs/svelte-repl/blob/master/LICENSE\n\nexport interface PreviewProxyHandler {\n  onFetchProgress?: (e: any) => void\n  onError?: (err: any) => void\n  onUnhandledRejection?: (err: any) => void\n  onConsole?: (e: any) => void\n  onConsoleGroup?: (e: any) => void\n  onConsoleGroupCollapsed?: (e: any) => void\n  onConsoleGroupEnd?: (e: any) => void\n}\n\nexport type PreviewProxyAction =\n  | 'cmd_error'\n  | 'cmd_ok'\n  | 'fetch_progress'\n  | 'error'\n  | 'unhandledrejection'\n  | 'console'\n  | 'console_group'\n  | 'console_group_collapsed'\n  | 'console_group_end'\n\nexport type IframeAction = 'eval' | 'catch_clicks'\n\nexport type PreviewProxyMessageData = {\n  action: PreviewProxyAction\n  cmd_id: number\n  args: {\n    remaining?: any\n  }\n  message?: Error['message']\n  stack?: Error['stack']\n}\nexport type PreviewProxyMessageEvent = MessageEvent<PreviewProxyMessageData>\n\ninterface PreviewProxyOptions {\n  iframe: HTMLIFrameElement\n  handler?: PreviewProxyHandler\n}\n\nexport class PreviewProxy {\n  static uid = 1\n\n  iframe: HTMLIFrameElement\n  handlers?: PreviewProxyHandler\n  pendingActions: Map<number, {resolve: (value: unknown) => void; reject: (reason?: any) => void}>\n  removeMessageListen?: () => void\n\n  constructor(options: PreviewProxyOptions) {\n    this.iframe = options.iframe\n    this.handlers = options.handler\n\n    this.pendingActions = new Map()\n\n    const fn = (e: PreviewProxyMessageEvent) => this.handleReplMessage(e)\n    window.addEventListener('message', fn, false)\n    this.removeMessageListen = () => window.removeEventListener('message', fn)\n  }\n\n  destroy() {\n    this.removeMessageListen?.()\n  }\n\n  dispatchIframeAction(action: IframeAction, args: any) {\n    return new Promise((resolve, reject) => {\n      const cmd_id = PreviewProxy.uid++\n\n      this.pendingActions.set(cmd_id, {resolve, reject})\n\n      this.iframe.contentWindow!.postMessage({action, cmd_id, args}, '*')\n    })\n  }\n\n  handleActionMessage(data: PreviewProxyMessageData) {\n    const {cmd_id: id, action} = data\n    const handler = this.pendingActions.get(id)\n\n    if (handler) {\n      this.pendingActions.delete(id)\n      if (action === 'cmd_error') {\n        const {message, stack} = data\n        const e = new Error(message)\n        e.stack = stack\n        handler.reject(e)\n      }\n\n      if (action === 'cmd_ok') {\n        handler.resolve(data.args)\n      }\n    } else {\n      console.error('action not found', id, data, [...this.pendingActions.keys()])\n    }\n  }\n\n  handleReplMessage(event: PreviewProxyMessageEvent) {\n    if (event.source !== this.iframe.contentWindow) return\n\n    const {action, args} = event.data\n\n    switch (action) {\n      case 'cmd_error':\n      case 'cmd_ok':\n        return this.handleActionMessage(event.data)\n      case 'fetch_progress':\n        return this.handlers?.onFetchProgress?.(args.remaining)\n      case 'error':\n        return this.handlers?.onError?.(event.data)\n      case 'unhandledrejection':\n        return this.handlers?.onUnhandledRejection?.(event.data)\n      case 'console':\n        return this.handlers?.onConsole?.(event.data)\n      case 'console_group':\n        return this.handlers?.onConsoleGroup?.(event.data)\n      case 'console_group_collapsed':\n        return this.handlers?.onConsoleGroupCollapsed?.(event.data)\n      case 'console_group_end':\n        return this.handlers?.onConsoleGroupEnd?.(event.data)\n    }\n  }\n\n  eval(script: string | string[]) {\n    return this.dispatchIframeAction('eval', {script})\n  }\n\n  catchClicks() {\n    return this.dispatchIframeAction('catch_clicks', {})\n  }\n}\n","export default \"<!DOCTYPE html>\\n<html>\\n  <head>\\n    <style>\\n      ::-webkit-scrollbar {\\n        width: 14px;\\n        background: rgba(0, 0, 0, 0);\\n      }\\n      ::-webkit-scrollbar-thumb {\\n        margin: 0 auto;\\n        background-color: #c0c9d1;\\n        background-clip: padding-box;\\n        border: 4px solid rgba(0, 0, 0, 0);\\n        border-radius: 9999px;\\n      }\\n      body {\\n        font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Oxygen, Ubuntu, Cantarell, 'Open Sans',\\n          'Helvetica Neue', sans-serif;\\n      }\\n    </style>\\n    <style id=\\\"__sfc-styles\\\"></style>\\n    <script>\\n      ;(() => {\\n        let scriptEls = []\\n\\n        window.process = {env: {}}\\n        window.__modules__ = {}\\n\\n        window.__export__ = (mod, key, get) => {\\n          Object.defineProperty(mod, key, {\\n            enumerable: true,\\n            configurable: true,\\n            get\\n          })\\n        }\\n\\n        window.__dynamic_import__ = key => {\\n          return Promise.resolve(window.__modules__[key])\\n        }\\n\\n        async function handle_message(ev) {\\n          let {action, cmd_id} = ev.data\\n          const send_message = payload => parent.postMessage({...payload}, ev.origin)\\n          const send_reply = payload => send_message({...payload, cmd_id})\\n          const send_ok = () => send_reply({action: 'cmd_ok'})\\n          const send_error = (message, stack) => send_reply({action: 'cmd_error', message, stack})\\n\\n          if (action === 'eval') {\\n            try {\\n              if (scriptEls.length) {\\n                scriptEls.forEach(el => {\\n                  document.head.removeChild(el)\\n                })\\n                scriptEls.length = 0\\n              }\\n\\n              let {script: scripts} = ev.data.args\\n              if (typeof scripts === 'string') scripts = [scripts]\\n\\n              for (const script of scripts) {\\n                const scriptEl = document.createElement('script')\\n                scriptEl.setAttribute('type', 'module')\\n                // send ok in the module script to ensure sequential evaluation\\n                // of multiple proxy.eval() calls\\n                const done = new Promise(resolve => {\\n                  window.__next__ = resolve\\n                })\\n                scriptEl.innerHTML = script + `\\\\nwindow.__next__()`\\n                document.head.appendChild(scriptEl)\\n                scriptEl.onrror = err => send_error(err.message, err.stack)\\n                scriptEls.push(scriptEl)\\n                await done\\n              }\\n              send_ok()\\n            } catch (e) {\\n              send_error(e.message, e.stack)\\n            }\\n          }\\n\\n          if (action === 'catch_clicks') {\\n            try {\\n              const top_origin = ev.origin\\n              document.body.addEventListener('click', event => {\\n                if (event.which !== 1) return\\n                if (event.metaKey || event.ctrlKey || event.shiftKey) return\\n                if (event.defaultPrevented) return\\n\\n                // ensure target is a link\\n                let el = event.target\\n                while (el && el.nodeName !== 'A') el = el.parentNode\\n                if (!el || el.nodeName !== 'A') return\\n\\n                if (el.hasAttribute('download') || el.getAttribute('rel') === 'external' || el.target) return\\n\\n                event.preventDefault()\\n\\n                if (el.href.startsWith(top_origin)) {\\n                  const url = new URL(el.href)\\n                  if (url.hash[0] === '#') {\\n                    window.location.hash = url.hash\\n                    return\\n                  }\\n                }\\n\\n                window.open(el.href, '_blank')\\n              })\\n              send_ok()\\n            } catch (e) {\\n              send_error(e.message, e.stack)\\n            }\\n          }\\n        }\\n\\n        window.addEventListener('message', handle_message, false)\\n\\n        window.onerror = function (msg, url, lineNo, columnNo, error) {\\n          if (msg.includes('module specifier “vue”')) {\\n            // firefox only error, ignore\\n            return false\\n          }\\n          try {\\n            parent.postMessage({action: 'error', value: error}, '*')\\n          } catch (e) {\\n            parent.postMessage({action: 'error', value: msg}, '*')\\n          }\\n        }\\n\\n        window.addEventListener('unhandledrejection', event => {\\n          if (event.reason.message.includes('Cross-origin')) {\\n            event.preventDefault()\\n            return\\n          }\\n          try {\\n            parent.postMessage({action: 'unhandledrejection', value: event.reason}, '*')\\n          } catch (e) {\\n            parent.postMessage({action: 'unhandledrejection', value: event.reason.message}, '*')\\n          }\\n        })\\n\\n        let previous = {level: null, args: null}\\n\\n        ;['clear', 'log', 'info', 'dir', 'warn', 'error', 'table'].forEach(level => {\\n          const original = console[level]\\n          console[level] = (...args) => {\\n            const msg = String(args[0])\\n            if (\\n              msg.includes('You are running a development build of Vue') ||\\n              msg.includes('You are running the esm-bundler build of Vue')\\n            ) {\\n              return\\n            }\\n            const stringifiedArgs = stringify(args)\\n            if (previous.level === level && previous.args && previous.args === stringifiedArgs) {\\n              parent.postMessage({action: 'console', level, duplicate: true}, '*')\\n            } else {\\n              previous = {level, args: stringifiedArgs}\\n\\n              try {\\n                parent.postMessage({action: 'console', level, args}, '*')\\n              } catch (err) {\\n                parent.postMessage(\\n                  {\\n                    action: 'console',\\n                    level,\\n                    args: args.map(a => {\\n                      return a instanceof Error ? a.message : String(a)\\n                    })\\n                  },\\n                  '*'\\n                )\\n              }\\n            }\\n\\n            original(...args)\\n          }\\n        })\\n        ;[\\n          {method: 'group', action: 'console_group'},\\n          {method: 'groupEnd', action: 'console_group_end'},\\n          {method: 'groupCollapsed', action: 'console_group_collapsed'}\\n        ].forEach(group_action => {\\n          const original = console[group_action.method]\\n          console[group_action.method] = label => {\\n            parent.postMessage({action: group_action.action, label}, '*')\\n\\n            original(label)\\n          }\\n        })\\n\\n        const timers = new Map()\\n        const original_time = console.time\\n        const original_timelog = console.timeLog\\n        const original_timeend = console.timeEnd\\n\\n        console.time = (label = 'default') => {\\n          original_time(label)\\n          timers.set(label, performance.now())\\n        }\\n        console.timeLog = (label = 'default') => {\\n          original_timelog(label)\\n          const now = performance.now()\\n          if (timers.has(label)) {\\n            parent.postMessage(\\n              {action: 'console', level: 'system-log', args: [`${label}: ${now - timers.get(label)}ms`]},\\n              '*'\\n            )\\n          } else {\\n            parent.postMessage(\\n              {action: 'console', level: 'system-warn', args: [`Timer '${label}' does not exist`]},\\n              '*'\\n            )\\n          }\\n        }\\n        console.timeEnd = (label = 'default') => {\\n          original_timeend(label)\\n          const now = performance.now()\\n          if (timers.has(label)) {\\n            parent.postMessage(\\n              {action: 'console', level: 'system-log', args: [`${label}: ${now - timers.get(label)}ms`]},\\n              '*'\\n            )\\n          } else {\\n            parent.postMessage(\\n              {action: 'console', level: 'system-warn', args: [`Timer '${label}' does not exist`]},\\n              '*'\\n            )\\n          }\\n          timers.delete(label)\\n        }\\n\\n        const original_assert = console.assert\\n        console.assert = (condition, ...args) => {\\n          if (condition) {\\n            const stack = new Error().stack\\n            parent.postMessage({action: 'console', level: 'assert', args, stack}, '*')\\n          }\\n          original_assert(condition, ...args)\\n        }\\n\\n        const counter = new Map()\\n        const original_count = console.count\\n        const original_countreset = console.countReset\\n\\n        console.count = (label = 'default') => {\\n          counter.set(label, (counter.get(label) || 0) + 1)\\n          parent.postMessage({action: 'console', level: 'system-log', args: `${label}: ${counter.get(label)}`}, '*')\\n          original_count(label)\\n        }\\n\\n        console.countReset = (label = 'default') => {\\n          if (counter.has(label)) {\\n            counter.set(label, 0)\\n          } else {\\n            parent.postMessage(\\n              {action: 'console', level: 'system-warn', args: `Count for '${label}' does not exist`},\\n              '*'\\n            )\\n          }\\n          original_countreset(label)\\n        }\\n\\n        const original_trace = console.trace\\n\\n        console.trace = (...args) => {\\n          const stack = new Error().stack\\n          parent.postMessage({action: 'console', level: 'trace', args, stack}, '*')\\n          original_trace(...args)\\n        }\\n\\n        function stringify(args) {\\n          try {\\n            return JSON.stringify(args)\\n          } catch (error) {\\n            return null\\n          }\\n        }\\n      })()\\n    </script>\\n\\n    <!-- ES Module Shims: Import maps polyfill for modules browsers without import maps support (all except Chrome 89+) -->\\n    <script async src=\\\"<!--ES_MODULE_SHIMS_CDN-->\\\"></script>\\n    <script type=\\\"importmap\\\">\\n      <!--IMPORT_MAP-->\\n    </script>\\n  </head>\\n  <body></body>\\n</html>\\n\"","import type {MaybeRef} from '@vueuse/core'\nimport type {InjectionKey} from 'vue'\nimport type {Store} from '../core'\nimport type {PlaygroundPkgCdn, PlaygroundTheme} from './utils/types-helper'\n\nexport const DEFAULT_TITLE = 'Demo' as const\nexport const PLAYGROUND_COMPONENT_NAME = 'Playground' as const\nexport const FILE_BASE_URL = 'file:///root/' as const\nexport const PROJECT_ID_PREFIX = 'project' as const\nexport const DEFAULT_FILE_NAME = 'comp.vue' as const\nexport const IMPORT_JSON_NAME = 'import-map.json' as const\nexport const STORE_INJECT_KEY = '__store__' as unknown as InjectionKey<Store>\nexport const CLEAR_CONSOLE_INJECT_KEY = '__clear_console__' as unknown as InjectionKey<MaybeRef<boolean>>\nexport const SHOW_IMPORT_MAP_INJECT_KEY = '__show_import_map__' as unknown as InjectionKey<MaybeRef<boolean>>\nexport const THEME_INJECT_KEY = '__theme__' as unknown as InjectionKey<MaybeRef<PlaygroundTheme>>\nexport const SHOW_DARK_MODE_INJECT_KEY = '__show_dark_mode__' as unknown as InjectionKey<MaybeRef<boolean>>\nexport const PKG_CDN_INJECT_KEY = '__pkg_cdn__' as unknown as InjectionKey<MaybeRef<PlaygroundPkgCdn>>\n\nexport const DEFAULT_THEME_COLOR = '#42b883'\n\nexport const GET_LIGHT_THEME = (theme?: PlaygroundTheme) => {\n  const themeColor = theme?.['--theme-color'] || DEFAULT_THEME_COLOR\n  return {\n    '--editor-theme-name': 'vitesse-light',\n    '--theme-color': themeColor,\n    '--border-color': '#eaecef',\n    '--bg-color': '#fff',\n    '--toolbar-bg-color': '##eeeeee',\n    '--toolbar-text-color': '#2c3e50',\n    '--toolbar-icon-bg-color': '#fff',\n    '--toolbar-icon-color': '#999',\n    '--toolbar-icon-active-color': themeColor,\n    '--preview-bg-color': '#fff',\n    '--preview-text-color': '#2c3e50',\n    '--file-manager-bg-color': '#fff',\n    '--file-manager-text-color': '#94a3b8',\n    '--file-manager-active-bg-color': '#fff',\n    '--file-manager-active-text-color': themeColor,\n    '--file-manager-right-float-bg': 'linear-gradient(90deg, rgba(255, 255, 255, 0) 0%, rgba(255, 255, 255, 1) 25%)',\n    '--message-warn-text-color': '#695f1b',\n    '--message-warn-bg-color': '#f7f0cd',\n    '--message-warn-border-color': '#695f1b',\n    '--message-error-text-color': '#f00',\n    '--message-error-bg-color': '#ffd7d7',\n    '--message-error-border-color': '#f00',\n    '--message-dismiss-text-color': '#fff',\n    '--message-dismiss-bg-color': '#f00',\n    ...theme\n  } as PlaygroundTheme\n}\n\nexport const GET_DARK_THEME = (theme?: PlaygroundTheme) => {\n  const themeColor = theme?.['--theme-color'] || DEFAULT_THEME_COLOR\n  return {\n    '--editor-theme-name': 'vitesse-dark',\n    '--theme-color': themeColor,\n    '--border-color': '#3e4c5a',\n    '--bg-color': '#22272e',\n    '--toolbar-bg-color': '#262c34',\n    '--toolbar-text-color': '#adbac7',\n    '--toolbar-icon-bg-color': '#22272e',\n    '--toolbar-icon-color': '#adbac7',\n    '--toolbar-icon-active-color': themeColor,\n    '--preview-bg-color': '#22272e',\n    '--preview-text-color': '#fff',\n    '--file-manager-bg-color': '#22272e',\n    '--file-manager-text-color': '#94a3b8',\n    '--file-manager-active-bg-color': '#22272e',\n    '--file-manager-active-text-color': themeColor,\n    '--file-manager-right-float-bg': 'linear-gradient(90deg, rgba(34, 39, 46, 0) 0%, rgba(34, 39, 46, 1) 25%)',\n    '--message-warn-text-color': '#695f1b',\n    '--message-warn-bg-color': '#f7f0cd',\n    '--message-warn-border-color': '#695f1b',\n    '--message-error-text-color': '#f00',\n    '--message-error-bg-color': '#ffd7d7',\n    '--message-error-border-color': '#f00',\n    '--message-dismiss-text-color': '#fff',\n    '--message-dismiss-bg-color': '#f00',\n    ...theme\n  } as PlaygroundTheme\n}\n\nexport const DEFAULT_VUE_RUNTIME_DOM_CDN = (version: string) =>\n  `https://unpkg.com/@vue/runtime-dom@${version}/dist/runtime-dom.esm-browser.js`\n\nexport const DEFAULT_VUE_COMPILER_SFC_CDN = (version: string) =>\n  `https://unpkg.com/@vue/compiler-sfc@${version}/dist/compiler-sfc.esm-browser.js`\n\nexport const DEFAULT_ES_MODULE_SHIMS_CDN = 'https://unpkg.com/es-module-shims@0.10.1/dist/es-module-shims.min.js'\n","/* eslint-disable @typescript-eslint/no-explicit-any */\nimport {Store} from '../store'\nimport {PreviewProxy} from './preview-proxy'\nimport PreviewIframe from './preview-iframe.html?raw'\nimport {compileModulesForPreview} from './module-compiler'\nimport {DEFAULT_ES_MODULE_SHIMS_CDN} from '../../playground/constants'\nimport type {PlaygroundPkgCdn} from '../../playground/utils/types-helper'\n\nexport interface PreviewOptions {\n  pkgCdn?: PlaygroundPkgCdn\n  store: Store\n  onBeforeDestroy?: () => void\n  onBeforeLoad?: () => void\n  onLoad?: () => void\n  onWarning?: (msg: string) => void\n  onError?: (errorMsg: string) => void\n}\n\nexport class Preview {\n  sandboxEl?: HTMLIFrameElement\n  previewProxy?: PreviewProxy\n  store!: Store\n  pkgCdn?: PlaygroundPkgCdn\n  onBeforeDestroy?: () => void\n  onBeforeLoad?: () => void\n  onLoad?: () => void\n  onWarning?: (msg: string) => void\n  onError?: (errorMsg: string) => void\n\n  constructor(options: PreviewOptions) {\n    this.store = options.store\n    this.pkgCdn = options.pkgCdn\n    this.onBeforeDestroy = options.onBeforeDestroy\n    this.onBeforeLoad = options.onBeforeLoad\n    this.onLoad = options.onLoad\n    this.onError = options.onError\n  }\n\n  destroy() {\n    this.onBeforeDestroy?.()\n    this.previewProxy?.destroy()\n    this.sandboxEl?.remove()\n  }\n\n  createSandbox(container: HTMLElement) {\n    if (this.sandboxEl) this.destroy()\n    this.onBeforeLoad?.()\n\n    this.sandboxEl = document.createElement('iframe')\n    this.sandboxEl.setAttribute(\n      'sandbox',\n      [\n        'allow-forms',\n        'allow-modals',\n        'allow-pointer-lock',\n        'allow-popups',\n        'allow-same-origin',\n        'allow-scripts',\n        'allow-top-navigation-by-user-activation'\n      ].join(' ')\n    )\n\n    const importMap = this.store.getImportMap()\n    if (!importMap.imports) importMap.imports = {}\n    if (!importMap.imports.vue) importMap.imports.vue = this.store.state.vueRuntimeURL\n\n    this.sandboxEl.srcdoc = PreviewIframe.replace(/<!--IMPORT_MAP-->/, JSON.stringify(importMap)) // inject import map\n      .replace(\n        /<!--ES_MODULE_SHIMS_CDN-->/,\n        this.pkgCdn?.['es-module-shims']?.('0.10.1', '/dist/es-module-shims.min.js') || DEFAULT_ES_MODULE_SHIMS_CDN\n      ) // inject es module shims\n\n    container.appendChild(this.sandboxEl)\n\n    this.previewProxy = new PreviewProxy({\n      iframe: this.sandboxEl,\n      handler: {\n        onError: (event: any) => {\n          const msg = event.value instanceof Error ? event.value.message : event.value\n          if (msg.includes('Failed to resolve module specifier') || msg.includes('Error resolving module specifier')) {\n            const _msg =\n              msg.replace(/\\. Relative references must.*$/, '') +\n              `.\\nTip: add an \"import-map.json\" file to specify import paths for dependencies.`\n            this.onError?.(_msg)\n          } else {\n            this.onError?.(String(event.value))\n          }\n        },\n        onUnhandledRejection: (event: any) => {\n          let error = event.value\n          if (typeof error === 'string') error = {message: error}\n          this.onError?.('Uncaught (in promise): ' + error.message)\n        },\n        onConsole: (log: any) => {\n          if (log.duplicate) return\n          let msg = null\n          if (log.level === 'error') {\n            if (log.args[0] instanceof Error) {\n              msg = log.args[0].message\n            } else {\n              msg = log.args[0]\n            }\n          } else if (log.level === 'warn') {\n            if (log.args[0].toString().includes('[Vue warn]')) {\n              this.onWarning?.(\n                log.args\n                  .join('')\n                  .replace(/\\[Vue warn\\]:/, '')\n                  .trim()\n              )\n            }\n          }\n          if (msg) this.onError?.(msg)\n        }\n      }\n    })\n\n    this.sandboxEl.addEventListener('load', () => {\n      this.previewProxy?.catchClicks()\n      this.onLoad?.()\n    })\n  }\n\n  async updateSandbox() {\n    try {\n      // compile code to simulated module system\n      const modules = compileModulesForPreview(this.store)\n      console.log(`[@vue/repl] successfully compiled ${modules.length} modules.`)\n\n      const codeToEval = [\n        `window.__modules__ = {};window.__css__ = '';` +\n          `if (window.__app__) window.__app__.unmount();` +\n          `document.body.innerHTML = '<div id=\"app\"></div>'`,\n        ...modules,\n        `document.getElementById('__sfc-styles').innerHTML = window.__css__`\n      ]\n\n      // if main file is a vue file, mount it.\n      const mainFile = this.store.state.mainFile\n      if (mainFile.endsWith('.vue')) {\n        codeToEval.push(\n          `import { createApp as _createApp } from \"vue\"\n          const AppComponent = __modules__[\"${mainFile}\"].default\n          const app = window.__app__ = _createApp(AppComponent)\n          app.config.unwrapInjectedRef = true\n          app.config.errorHandler = e => console.error(e)\n          app.mount('#app')`.trim()\n        )\n      }\n\n      // eval code in sandbox\n      await this.previewProxy?.eval(codeToEval)\n    } catch (e) {\n      this.onError?.((e as Error).message)\n    }\n  }\n}\n","//  copy from https://github.com/PavelDymkov/babel-plugin-auto-import/blob/master/src/index.js\n\nconst ImportType = {\n  DEFAULT: 1,\n  MEMBER: 2,\n  ANONYMOUS: 3\n}\n\nconst not = cond => !cond\nconst basename = _path => _path.split('/').pop()\n\nexport default function ({types: t}) {\n  return {\n    visitor: {\n      Identifier(path, {opts: options, file}) {\n        if (not(path.isReferencedIdentifier())) return\n\n        const {node: identifier, scope} = path\n\n        if (isDefined(identifier, scope)) return\n\n        const {declarations} = options\n\n        if (not(Array.isArray(declarations))) return\n\n        const filename = file.opts.filename ? basename(file.opts.filename) : ''\n\n        declarations.some(handleDeclaration, {\n          path,\n          identifier,\n          filename\n        })\n      }\n    }\n  }\n\n  function isDefined(identifier, {bindings, parent}) {\n    const variables = Object.keys(bindings)\n\n    if (variables.some(has, identifier)) return true\n\n    return parent ? isDefined(identifier, parent) : false\n  }\n\n  function has(identifier) {\n    const {name} = this\n\n    return identifier == name\n  }\n\n  function handleDeclaration(declaration) {\n    const {path, identifier, filename} = this\n\n    if (not(declaration)) return\n\n    let importType = null\n\n    if (hasDefault(declaration, identifier)) {\n      importType = ImportType.DEFAULT\n    } else if (hasMember(declaration, identifier)) {\n      importType = ImportType.MEMBER\n    } else if (hasAnonymous(declaration, identifier)) {\n      importType = ImportType.ANONYMOUS\n    }\n\n    if (importType) {\n      const program = path.findParent(isProgram)\n      const pathToModule = getPathToModule(declaration, filename)\n\n      insertImport(program, identifier, importType, pathToModule)\n\n      return true\n    }\n  }\n\n  function hasDefault(declaration, identifier) {\n    return declaration['default'] == identifier.name\n  }\n\n  function hasMember(declaration, identifier) {\n    const members = Array.isArray(declaration.members) ? declaration.members : []\n\n    return members.some(has, identifier)\n  }\n\n  function hasAnonymous(declaration, identifier) {\n    const anonymous = Array.isArray(declaration.anonymous) ? declaration.anonymous : []\n\n    return anonymous.some(has, identifier)\n  }\n\n  function insertImport(program, identifier, type, pathToModule) {\n    const programBody = program.get('body')\n\n    const currentImportDeclarations = programBody.reduce(toImportDeclarations, [])\n\n    let importDidAppend\n\n    importDidAppend = currentImportDeclarations.some(importAlreadyExists, {\n      identifier,\n      type,\n      pathToModule\n    })\n\n    if (importDidAppend) return\n\n    importDidAppend = currentImportDeclarations.some(addToImportDeclaration, {identifier, type, pathToModule})\n\n    if (importDidAppend) return\n\n    const specifiers = []\n\n    if (type == ImportType.DEFAULT) {\n      specifiers.push(t.importDefaultSpecifier(identifier))\n    } else if (type == ImportType.MEMBER) {\n      specifiers.push(t.importSpecifier(identifier, identifier))\n      // eslint-disable-next-line no-empty\n    } else if (type == ImportType.ANONYMOUS) {\n    }\n\n    const importDeclaration = t.importDeclaration(specifiers, t.stringLiteral(pathToModule))\n\n    program.unshiftContainer('body', importDeclaration)\n  }\n\n  function isProgram(path) {\n    return path.isProgram()\n  }\n\n  function toImportDeclarations(list, currentPath) {\n    if (currentPath.isImportDeclaration()) list.push(currentPath)\n\n    return list\n  }\n\n  function importAlreadyExists({node: importDeclaration}) {\n    const {identifier, type, pathToModule} = this\n\n    if (importDeclaration.source.value == pathToModule) {\n      if (type == ImportType.ANONYMOUS) return true\n\n      return importDeclaration.specifiers.some(checkSpecifierLocalName, identifier)\n    }\n  }\n\n  function checkSpecifierLocalName(specifier) {\n    const identifier = this\n\n    return specifier.local.name == identifier.name\n  }\n\n  function addToImportDeclaration(importDeclarationPath) {\n    const {identifier, type, pathToModule} = this\n    const {node} = importDeclarationPath\n\n    if (node.source.value != pathToModule) return false\n\n    const {specifiers} = node\n\n    if (type == ImportType.DEFAULT) {\n      if (not(specifiers.some(hasImportDefaultSpecifier))) {\n        const specifier = t.importDefaultSpecifier(identifier)\n\n        importDeclarationPath.unshiftContainer('specifiers', specifier)\n\n        return true\n      }\n    }\n\n    if (type == ImportType.MEMBER) {\n      if (not(specifiers.some(hasSpecifierWithName, identifier))) {\n        const specifier = t.importSpecifier(identifier, identifier)\n\n        importDeclarationPath.pushContainer('specifiers', specifier)\n\n        return true\n      }\n    }\n  }\n\n  function hasImportDefaultSpecifier(node) {\n    return t.isImportDefaultSpecifier(node)\n  }\n\n  function hasSpecifierWithName(node) {\n    if (not(t.isImportSpecifier(node))) return false\n\n    const {name} = this\n\n    return node.imported.name == name\n  }\n\n  function getPathToModule(declaration, filename) {\n    if (declaration.path.includes('[name]')) {\n      const pattern = declaration.nameReplacePattern || '\\\\.js$'\n      const newSubString = declaration.nameReplaceString || ''\n\n      const name = filename.replace(new RegExp(pattern), newSubString)\n\n      return declaration.path.replace('[name]', name)\n    }\n\n    return declaration.path\n  }\n}\n","import * as Babel from '@babel/standalone'\nimport AutoImport from './babel-auto-import'\n\nBabel.registerPlugin('auto-import', AutoImport)\n\nexport function babelTransformTsJsx(src: string, filename?: string) {\n  return Babel.transform(src || 'export default {};', {\n    sourceType: 'module',\n    filename: filename || 'index.tsx',\n    presets: [\n      [\n        'react',\n        {\n          pragma: 'h',\n          pragmaFrag: 'Fragment'\n        }\n      ],\n      [\n        'typescript',\n        {\n          isTsx: true,\n          jsxPragma: 'preserve',\n          jsxPragmaFrag: 'Fragment'\n        }\n      ]\n    ],\n    plugins: [\n      'proposal-export-namespace-from',\n      'proposal-export-default-from',\n      'proposal-optional-chaining',\n      [\n        'proposal-decorators',\n        {\n          legacy: true\n        }\n      ],\n      [\n        'proposal-class-properties',\n        {\n          loose: true\n        }\n      ],\n      [\n        'auto-import',\n        {\n          declarations: [{members: ['h'], path: 'vue'}]\n        }\n      ]\n    ]\n  }).code\n}\n","/* eslint-disable @typescript-eslint/no-explicit-any */\nimport {Store, File} from '../store'\nimport type {SFCDescriptor, BindingMetadata, CompilerOptions} from '@vue/compiler-sfc'\nimport {babelTransformTsJsx} from '../utils/babel'\n\nexport const COMP_IDENTIFIER = `__sfc__`\n\nasync function transformTsJsx(src: string) {\n  // console.log('compile source: ', src)\n  try {\n    const result = babelTransformTsJsx(src)\n    // console.log('compile result: ', result)\n    return result || ''\n  } catch (e) {\n    console.error('compile error: ', e)\n    throw e\n  }\n}\n\nexport async function compileFile(store: Store, {filename, code, compiled}: File) {\n  if (!code.trim()) {\n    store.state.errors = []\n    return\n  }\n\n  if (filename.endsWith('.css')) {\n    compiled.css = code\n    store.state.errors = []\n    return\n  }\n\n  if (/\\.(jsx?|tsx?)$/.test(filename)) {\n    if (store.compiler.shouldTransformRef(code)) {\n      code = store.compiler.transformRef(code, {filename}).code\n    }\n    if (/\\.(jsx|tsx?)$/.test(filename)) {\n      code = await transformTsJsx(code)\n    }\n    compiled.js = compiled.ssr = code\n    store.state.errors = []\n    return\n  }\n\n  if (!filename.endsWith('.vue')) {\n    store.state.errors = []\n    return\n  }\n\n  const id = await hashId(filename)\n  const {errors, descriptor} = store.compiler.parse(code, {\n    filename,\n    sourceMap: true\n  })\n  if (errors.length) {\n    store.state.errors = errors\n    return\n  }\n\n  if (descriptor.styles.some(s => s.lang) || (descriptor.template && descriptor.template.lang)) {\n    store.state.errors = [`lang=\"x\" pre-processors for <template> or <style> are currently not ` + `supported.`]\n    return\n  }\n\n  const scriptLang =\n    (descriptor.script && descriptor.script.lang) || (descriptor.scriptSetup && descriptor.scriptSetup.lang)\n  const isTS = ['ts', 'tsx'].includes(scriptLang ?? '')\n  if (scriptLang && !isTS) {\n    store.state.errors = [`Only lang=\"ts\" is supported for <script> blocks.`]\n    return\n  }\n\n  const hasScoped = descriptor.styles.some(s => s.scoped)\n  let clientCode = ''\n  let ssrCode = ''\n\n  const appendSharedCode = (code: string) => {\n    clientCode += code\n    ssrCode += code\n  }\n\n  const clientScriptResult = await doCompileScript(store, descriptor, id, false, isTS)\n  if (!clientScriptResult) {\n    return\n  }\n  const [clientScript, bindings] = clientScriptResult\n  clientCode += clientScript\n\n  // script ssr only needs to be performed if using <script setup> where\n  // the render fn is inlined.\n  if (descriptor.scriptSetup) {\n    const ssrScriptResult = await doCompileScript(store, descriptor, id, true, isTS)\n    if (ssrScriptResult) {\n      ssrCode += ssrScriptResult[0]\n    } else {\n      ssrCode = `/* SSR compile error: ${store.state.errors[0]} */`\n    }\n  } else {\n    // when no <script setup> is used, the script result will be identical.\n    ssrCode += clientScript\n  }\n\n  // template\n  // only need dedicated compilation if not using <script setup>\n  if (descriptor.template && !descriptor.scriptSetup) {\n    const clientTemplateResult = doCompileTemplate(store, descriptor, id, bindings, false, isTS)\n    if (!clientTemplateResult) {\n      return\n    }\n    clientCode += clientTemplateResult\n\n    const ssrTemplateResult = doCompileTemplate(store, descriptor, id, bindings, true, isTS)\n    if (ssrTemplateResult) {\n      // ssr compile failure is fine\n      ssrCode += ssrTemplateResult\n    } else {\n      ssrCode = `/* SSR compile error: ${store.state.errors[0]} */`\n    }\n  }\n\n  if (hasScoped) {\n    appendSharedCode(`\\n${COMP_IDENTIFIER}.__scopeId = ${JSON.stringify(`data-v-${id}`)}`)\n  }\n\n  if (clientCode || ssrCode) {\n    appendSharedCode(\n      `\\n${COMP_IDENTIFIER}.__file = ${JSON.stringify(filename)}` + `\\nexport default ${COMP_IDENTIFIER}`\n    )\n    compiled.js = clientCode.trimStart()\n    compiled.ssr = ssrCode.trimStart()\n  }\n\n  // styles\n  let css = ''\n  for (const style of descriptor.styles) {\n    if (style.module) {\n      store.state.errors = [`<style module> is not supported in the playground.`]\n      return\n    }\n\n    const styleResult = await store.compiler.compileStyleAsync({\n      ...store.options?.style,\n      source: style.content,\n      filename,\n      id,\n      scoped: style.scoped,\n      modules: !!style.module\n    })\n    if (styleResult.errors.length) {\n      // postcss uses pathToFileURL which isn't polyfilled in the browser\n      // ignore these errors for now\n      if (!styleResult.errors[0].message.includes('pathToFileURL')) {\n        store.state.errors = styleResult.errors\n      }\n      // proceed even if css compile errors\n    } else {\n      css += styleResult.code + '\\n'\n    }\n  }\n  if (css) {\n    compiled.css = css.trim()\n  } else {\n    compiled.css = '/* No <style> tags present */'\n  }\n\n  // clear errors\n  store.state.errors = []\n}\n\nasync function doCompileScript(\n  store: Store,\n  descriptor: SFCDescriptor,\n  id: string,\n  ssr: boolean,\n  isTS: boolean\n): Promise<[string, BindingMetadata | undefined] | undefined> {\n  if (descriptor.script || descriptor.scriptSetup) {\n    try {\n      const expressionPlugins: CompilerOptions['expressionPlugins'] = isTS ? ['typescript'] : []\n      const compiledScript = store.compiler.compileScript(descriptor, {\n        inlineTemplate: true,\n        ...store.options?.script,\n        id,\n        templateOptions: {\n          ...store.options?.template,\n          ssr,\n          ssrCssVars: descriptor.cssVars,\n          compilerOptions: {\n            ...store.options?.template?.compilerOptions,\n            expressionPlugins: ['jsx', ...expressionPlugins]\n          }\n        }\n      })\n      let code = ''\n      if (compiledScript.bindings) {\n        code += `\\n/* Analyzed bindings: ${JSON.stringify(compiledScript.bindings, null, 2)} */`\n      }\n      code += `\\n` + store.compiler.rewriteDefault(compiledScript.content, COMP_IDENTIFIER, expressionPlugins)\n\n      if (descriptor.script || ['ts', 'tsx', 'jsx'].includes(descriptor.scriptSetup!.lang ?? '')) {\n        code = await transformTsJsx(code)\n      }\n\n      return [code, compiledScript.bindings]\n    } catch (e: any) {\n      store.state.errors = [e.stack.split('\\n').slice(0, 12).join('\\n')]\n      return\n    }\n  } else {\n    return [`\\nconst ${COMP_IDENTIFIER} = {}`, undefined]\n  }\n}\n\nfunction doCompileTemplate(\n  store: Store,\n  descriptor: SFCDescriptor,\n  id: string,\n  bindingMetadata: BindingMetadata | undefined,\n  ssr: boolean,\n  isTS: boolean\n) {\n  const templateResult = store.compiler.compileTemplate({\n    ...store.options?.template,\n    source: descriptor.template!.content,\n    filename: descriptor.filename,\n    id,\n    scoped: descriptor.styles.some(s => s.scoped),\n    slotted: descriptor.slotted,\n    ssr,\n    ssrCssVars: descriptor.cssVars,\n    isProd: false,\n    compilerOptions: {\n      ...store.options?.template?.compilerOptions,\n      bindingMetadata,\n      expressionPlugins: isTS ? ['typescript'] : undefined\n    }\n  })\n  if (templateResult.errors.length) {\n    store.state.errors = templateResult.errors\n    return\n  }\n\n  const fnName = ssr ? `ssrRender` : `render`\n\n  return (\n    `\\n${templateResult.code.replace(/\\nexport (function|const) (render|ssrRender)/, `$1 ${fnName}`)}` +\n    `\\n${COMP_IDENTIFIER}.${fnName} = ${fnName}`\n  )\n}\n\nasync function hashId(filename: string) {\n  const msgUint8 = new TextEncoder().encode(filename) // encode as (utf-8) Uint8Array\n  const hashBuffer = await crypto.subtle.digest('SHA-256', msgUint8) // hash the message\n  const hashArray = Array.from(new Uint8Array(hashBuffer)) // convert buffer to byte array\n  const hashHex = hashArray.map(b => b.toString(16).padStart(2, '0')).join('') // convert bytes to hex string\n  return hashHex.slice(0, 8)\n}\n","/**\n *  base64.ts\n *\n *  Licensed under the BSD 3-Clause License.\n *    http://opensource.org/licenses/BSD-3-Clause\n *\n *  References:\n *    http://en.wikipedia.org/wiki/Base64\n *\n * @author Dan Kogai (https://github.com/dankogai)\n */\nconst version = '3.7.2';\n/**\n * @deprecated use lowercase `version`.\n */\nconst VERSION = version;\nconst _hasatob = typeof atob === 'function';\nconst _hasbtoa = typeof btoa === 'function';\nconst _hasBuffer = typeof Buffer === 'function';\nconst _TD = typeof TextDecoder === 'function' ? new TextDecoder() : undefined;\nconst _TE = typeof TextEncoder === 'function' ? new TextEncoder() : undefined;\nconst b64ch = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=';\nconst b64chs = Array.prototype.slice.call(b64ch);\nconst b64tab = ((a) => {\n    let tab = {};\n    a.forEach((c, i) => tab[c] = i);\n    return tab;\n})(b64chs);\nconst b64re = /^(?:[A-Za-z\\d+\\/]{4})*?(?:[A-Za-z\\d+\\/]{2}(?:==)?|[A-Za-z\\d+\\/]{3}=?)?$/;\nconst _fromCC = String.fromCharCode.bind(String);\nconst _U8Afrom = typeof Uint8Array.from === 'function'\n    ? Uint8Array.from.bind(Uint8Array)\n    : (it, fn = (x) => x) => new Uint8Array(Array.prototype.slice.call(it, 0).map(fn));\nconst _mkUriSafe = (src) => src\n    .replace(/=/g, '').replace(/[+\\/]/g, (m0) => m0 == '+' ? '-' : '_');\nconst _tidyB64 = (s) => s.replace(/[^A-Za-z0-9\\+\\/]/g, '');\n/**\n * polyfill version of `btoa`\n */\nconst btoaPolyfill = (bin) => {\n    // console.log('polyfilled');\n    let u32, c0, c1, c2, asc = '';\n    const pad = bin.length % 3;\n    for (let i = 0; i < bin.length;) {\n        if ((c0 = bin.charCodeAt(i++)) > 255 ||\n            (c1 = bin.charCodeAt(i++)) > 255 ||\n            (c2 = bin.charCodeAt(i++)) > 255)\n            throw new TypeError('invalid character found');\n        u32 = (c0 << 16) | (c1 << 8) | c2;\n        asc += b64chs[u32 >> 18 & 63]\n            + b64chs[u32 >> 12 & 63]\n            + b64chs[u32 >> 6 & 63]\n            + b64chs[u32 & 63];\n    }\n    return pad ? asc.slice(0, pad - 3) + \"===\".substring(pad) : asc;\n};\n/**\n * does what `window.btoa` of web browsers do.\n * @param {String} bin binary string\n * @returns {string} Base64-encoded string\n */\nconst _btoa = _hasbtoa ? (bin) => btoa(bin)\n    : _hasBuffer ? (bin) => Buffer.from(bin, 'binary').toString('base64')\n        : btoaPolyfill;\nconst _fromUint8Array = _hasBuffer\n    ? (u8a) => Buffer.from(u8a).toString('base64')\n    : (u8a) => {\n        // cf. https://stackoverflow.com/questions/12710001/how-to-convert-uint8-array-to-base64-encoded-string/12713326#12713326\n        const maxargs = 0x1000;\n        let strs = [];\n        for (let i = 0, l = u8a.length; i < l; i += maxargs) {\n            strs.push(_fromCC.apply(null, u8a.subarray(i, i + maxargs)));\n        }\n        return _btoa(strs.join(''));\n    };\n/**\n * converts a Uint8Array to a Base64 string.\n * @param {boolean} [urlsafe] URL-and-filename-safe a la RFC4648 §5\n * @returns {string} Base64 string\n */\nconst fromUint8Array = (u8a, urlsafe = false) => urlsafe ? _mkUriSafe(_fromUint8Array(u8a)) : _fromUint8Array(u8a);\n// This trick is found broken https://github.com/dankogai/js-base64/issues/130\n// const utob = (src: string) => unescape(encodeURIComponent(src));\n// reverting good old fationed regexp\nconst cb_utob = (c) => {\n    if (c.length < 2) {\n        var cc = c.charCodeAt(0);\n        return cc < 0x80 ? c\n            : cc < 0x800 ? (_fromCC(0xc0 | (cc >>> 6))\n                + _fromCC(0x80 | (cc & 0x3f)))\n                : (_fromCC(0xe0 | ((cc >>> 12) & 0x0f))\n                    + _fromCC(0x80 | ((cc >>> 6) & 0x3f))\n                    + _fromCC(0x80 | (cc & 0x3f)));\n    }\n    else {\n        var cc = 0x10000\n            + (c.charCodeAt(0) - 0xD800) * 0x400\n            + (c.charCodeAt(1) - 0xDC00);\n        return (_fromCC(0xf0 | ((cc >>> 18) & 0x07))\n            + _fromCC(0x80 | ((cc >>> 12) & 0x3f))\n            + _fromCC(0x80 | ((cc >>> 6) & 0x3f))\n            + _fromCC(0x80 | (cc & 0x3f)));\n    }\n};\nconst re_utob = /[\\uD800-\\uDBFF][\\uDC00-\\uDFFFF]|[^\\x00-\\x7F]/g;\n/**\n * @deprecated should have been internal use only.\n * @param {string} src UTF-8 string\n * @returns {string} UTF-16 string\n */\nconst utob = (u) => u.replace(re_utob, cb_utob);\n//\nconst _encode = _hasBuffer\n    ? (s) => Buffer.from(s, 'utf8').toString('base64')\n    : _TE\n        ? (s) => _fromUint8Array(_TE.encode(s))\n        : (s) => _btoa(utob(s));\n/**\n * converts a UTF-8-encoded string to a Base64 string.\n * @param {boolean} [urlsafe] if `true` make the result URL-safe\n * @returns {string} Base64 string\n */\nconst encode = (src, urlsafe = false) => urlsafe\n    ? _mkUriSafe(_encode(src))\n    : _encode(src);\n/**\n * converts a UTF-8-encoded string to URL-safe Base64 RFC4648 §5.\n * @returns {string} Base64 string\n */\nconst encodeURI = (src) => encode(src, true);\n// This trick is found broken https://github.com/dankogai/js-base64/issues/130\n// const btou = (src: string) => decodeURIComponent(escape(src));\n// reverting good old fationed regexp\nconst re_btou = /[\\xC0-\\xDF][\\x80-\\xBF]|[\\xE0-\\xEF][\\x80-\\xBF]{2}|[\\xF0-\\xF7][\\x80-\\xBF]{3}/g;\nconst cb_btou = (cccc) => {\n    switch (cccc.length) {\n        case 4:\n            var cp = ((0x07 & cccc.charCodeAt(0)) << 18)\n                | ((0x3f & cccc.charCodeAt(1)) << 12)\n                | ((0x3f & cccc.charCodeAt(2)) << 6)\n                | (0x3f & cccc.charCodeAt(3)), offset = cp - 0x10000;\n            return (_fromCC((offset >>> 10) + 0xD800)\n                + _fromCC((offset & 0x3FF) + 0xDC00));\n        case 3:\n            return _fromCC(((0x0f & cccc.charCodeAt(0)) << 12)\n                | ((0x3f & cccc.charCodeAt(1)) << 6)\n                | (0x3f & cccc.charCodeAt(2)));\n        default:\n            return _fromCC(((0x1f & cccc.charCodeAt(0)) << 6)\n                | (0x3f & cccc.charCodeAt(1)));\n    }\n};\n/**\n * @deprecated should have been internal use only.\n * @param {string} src UTF-16 string\n * @returns {string} UTF-8 string\n */\nconst btou = (b) => b.replace(re_btou, cb_btou);\n/**\n * polyfill version of `atob`\n */\nconst atobPolyfill = (asc) => {\n    // console.log('polyfilled');\n    asc = asc.replace(/\\s+/g, '');\n    if (!b64re.test(asc))\n        throw new TypeError('malformed base64.');\n    asc += '=='.slice(2 - (asc.length & 3));\n    let u24, bin = '', r1, r2;\n    for (let i = 0; i < asc.length;) {\n        u24 = b64tab[asc.charAt(i++)] << 18\n            | b64tab[asc.charAt(i++)] << 12\n            | (r1 = b64tab[asc.charAt(i++)]) << 6\n            | (r2 = b64tab[asc.charAt(i++)]);\n        bin += r1 === 64 ? _fromCC(u24 >> 16 & 255)\n            : r2 === 64 ? _fromCC(u24 >> 16 & 255, u24 >> 8 & 255)\n                : _fromCC(u24 >> 16 & 255, u24 >> 8 & 255, u24 & 255);\n    }\n    return bin;\n};\n/**\n * does what `window.atob` of web browsers do.\n * @param {String} asc Base64-encoded string\n * @returns {string} binary string\n */\nconst _atob = _hasatob ? (asc) => atob(_tidyB64(asc))\n    : _hasBuffer ? (asc) => Buffer.from(asc, 'base64').toString('binary')\n        : atobPolyfill;\n//\nconst _toUint8Array = _hasBuffer\n    ? (a) => _U8Afrom(Buffer.from(a, 'base64'))\n    : (a) => _U8Afrom(_atob(a), c => c.charCodeAt(0));\n/**\n * converts a Base64 string to a Uint8Array.\n */\nconst toUint8Array = (a) => _toUint8Array(_unURI(a));\n//\nconst _decode = _hasBuffer\n    ? (a) => Buffer.from(a, 'base64').toString('utf8')\n    : _TD\n        ? (a) => _TD.decode(_toUint8Array(a))\n        : (a) => btou(_atob(a));\nconst _unURI = (a) => _tidyB64(a.replace(/[-_]/g, (m0) => m0 == '-' ? '+' : '/'));\n/**\n * converts a Base64 string to a UTF-8 string.\n * @param {String} src Base64 string.  Both normal and URL-safe are supported\n * @returns {string} UTF-8 string\n */\nconst decode = (src) => _decode(_unURI(src));\n/**\n * check if a value is a valid Base64 string\n * @param {String} src a value to check\n  */\nconst isValid = (src) => {\n    if (typeof src !== 'string')\n        return false;\n    const s = src.replace(/\\s+/g, '').replace(/={0,2}$/, '');\n    return !/[^\\s0-9a-zA-Z\\+/]/.test(s) || !/[^\\s0-9a-zA-Z\\-_]/.test(s);\n};\n//\nconst _noEnum = (v) => {\n    return {\n        value: v, enumerable: false, writable: true, configurable: true\n    };\n};\n/**\n * extend String.prototype with relevant methods\n */\nconst extendString = function () {\n    const _add = (name, body) => Object.defineProperty(String.prototype, name, _noEnum(body));\n    _add('fromBase64', function () { return decode(this); });\n    _add('toBase64', function (urlsafe) { return encode(this, urlsafe); });\n    _add('toBase64URI', function () { return encode(this, true); });\n    _add('toBase64URL', function () { return encode(this, true); });\n    _add('toUint8Array', function () { return toUint8Array(this); });\n};\n/**\n * extend Uint8Array.prototype with relevant methods\n */\nconst extendUint8Array = function () {\n    const _add = (name, body) => Object.defineProperty(Uint8Array.prototype, name, _noEnum(body));\n    _add('toBase64', function (urlsafe) { return fromUint8Array(this, urlsafe); });\n    _add('toBase64URI', function () { return fromUint8Array(this, true); });\n    _add('toBase64URL', function () { return fromUint8Array(this, true); });\n};\n/**\n * extend Builtin prototypes with relevant methods\n */\nconst extendBuiltins = () => {\n    extendString();\n    extendUint8Array();\n};\nconst gBase64 = {\n    version: version,\n    VERSION: VERSION,\n    atob: _atob,\n    atobPolyfill: atobPolyfill,\n    btoa: _btoa,\n    btoaPolyfill: btoaPolyfill,\n    fromBase64: decode,\n    toBase64: encode,\n    encode: encode,\n    encodeURI: encodeURI,\n    encodeURL: encodeURI,\n    utob: utob,\n    btou: btou,\n    decode: decode,\n    isValid: isValid,\n    fromUint8Array: fromUint8Array,\n    toUint8Array: toUint8Array,\n    extendString: extendString,\n    extendUint8Array: extendUint8Array,\n    extendBuiltins: extendBuiltins,\n};\n// makecjs:CUT //\nexport { version };\nexport { VERSION };\nexport { _atob as atob };\nexport { atobPolyfill };\nexport { _btoa as btoa };\nexport { btoaPolyfill };\nexport { decode as fromBase64 };\nexport { encode as toBase64 };\nexport { utob };\nexport { encode };\nexport { encodeURI };\nexport { encodeURI as encodeURL };\nexport { btou };\nexport { decode };\nexport { isValid };\nexport { fromUint8Array };\nexport { toUint8Array };\nexport { extendString };\nexport { extendUint8Array };\nexport { extendBuiltins };\n// and finally,\nexport { gBase64 as Base64 };\n","/* eslint-disable @typescript-eslint/no-explicit-any */\nimport * as base64Js from 'js-base64'\n\nexport function debounce(fn: Function, n = 100) {\n  let handle: any\n  return (...args: any[]) => {\n    if (handle) clearTimeout(handle)\n    handle = setTimeout(() => {\n      fn(...args)\n    }, n)\n  }\n}\n\n// prefer old unicode hacks for backward compatibility\n// https://base64.guru/developers/javascript/examples/unicode-strings\nexport function utoa(data: string): string {\n  return base64Js.encode(encodeURIComponent(data))\n}\n\nexport function atou(base64: string): string {\n  return decodeURIComponent(base64Js.decode(base64))\n}\n\nexport function getPkgUrl(name: string, version = 'latest', ending = '') {\n  return `https://cdn.jsdelivr.net/npm/${name}@${version}${ending}`\n}\n","/* eslint-disable @typescript-eslint/no-explicit-any */\nimport {version, reactive, watchEffect} from 'vue'\nimport * as defaultCompiler from '@vue/compiler-sfc'\nimport {compileFile} from './compiler/transform'\nimport {utoa, atou} from './utils/common'\nimport {ImportMap, OutputModes} from './utils/types-helper'\nimport type {SFCScriptCompileOptions, SFCAsyncStyleCompileOptions, SFCTemplateCompileOptions} from '@vue/compiler-sfc'\nimport {DEFAULT_VUE_RUNTIME_DOM_CDN, DEFAULT_VUE_COMPILER_SFC_CDN} from '../playground/constants'\nimport type {PlaygroundPkgCdn} from '../playground/utils/types-helper'\n\nconst defaultMainFile = 'App.vue'\n\nconst welcomeCode = `\n<script setup>\nimport { ref } from 'vue'\n\nconst msg = ref('Hello World!')\n</script>\n\n<template>\n  <h1>{{ msg }}</h1>\n  <input v-model=\"msg\">\n</template>\n`.trim()\n\nexport class File {\n  filename: string\n  code: string\n  hidden: boolean\n  compiled = {\n    js: '',\n    css: '',\n    ssr: ''\n  }\n\n  constructor(filename: string, code = '', hidden = false) {\n    this.filename = filename\n    this.code = code\n    this.hidden = hidden\n  }\n}\n\nexport interface StoreState {\n  mainFile: string\n  files: Record<string, File>\n  initFiles: Record<string, File>\n  activeFile: File\n  errors: (string | Error)[]\n  vueRuntimeURL: string\n}\n\nexport interface SFCOptions {\n  script?: Omit<SFCScriptCompileOptions, 'id'>\n  style?: SFCAsyncStyleCompileOptions\n  template?: SFCTemplateCompileOptions\n}\n\nexport interface Store {\n  state: StoreState\n  options?: SFCOptions\n  compiler: typeof import('vue/compiler-sfc')\n  setActive: (filename: string) => void\n  addFile: (filename: string | File) => void\n  deleteFile: (filename: string) => void\n  getImportMap: () => any\n  initialShowOutput: boolean\n  initialOutputMode: OutputModes\n}\n\ninterface ReplStoreOptions {\n  serializedState?: string\n  initFiles?: File[]\n  showOutput?: boolean\n  // loose type to allow getting from the URL without inducing a typing error\n  outputMode?: OutputModes | string\n  defaultVueRuntimeURL?: string\n  pkgCdn?: PlaygroundPkgCdn\n  initImportMap?: ImportMap\n}\n\nexport class ReplStore implements Store {\n  state: StoreState\n  compiler = defaultCompiler\n  options?: SFCOptions\n  initialShowOutput: boolean\n  initialOutputMode: OutputModes\n  pkgCdn?: PlaygroundPkgCdn\n\n  private defaultVueRuntimeURL: string\n  private pendingCompiler: Promise<any> | null = null\n\n  constructor({\n    serializedState = '',\n    defaultVueRuntimeURL,\n    showOutput = false,\n    outputMode = 'preview',\n    initFiles,\n    initImportMap,\n    pkgCdn\n  }: ReplStoreOptions = {}) {\n    let files: StoreState['files'] = {}\n\n    if (serializedState) {\n      const saved = JSON.parse(atou(serializedState))\n      for (const filename in saved) {\n        files[filename] = new File(filename, saved[filename])\n      }\n    } else if (initFiles) {\n      for (const file of initFiles) {\n        files[file.filename] = file\n      }\n    } else {\n      files = {\n        [defaultMainFile]: new File(defaultMainFile, welcomeCode)\n      }\n    }\n\n    this.defaultVueRuntimeURL =\n      defaultVueRuntimeURL ||\n      pkgCdn?.['@vue/runtime-dom']?.(version, '/dist/runtime-dom.esm-browser.js') ||\n      DEFAULT_VUE_RUNTIME_DOM_CDN(version)\n\n    this.initialShowOutput = showOutput\n    this.initialOutputMode = outputMode as OutputModes\n    this.pkgCdn = pkgCdn\n\n    let mainFile = defaultMainFile\n    if (!files[mainFile]) {\n      mainFile = Object.keys(files)[0]\n    }\n    this.state = reactive({\n      mainFile,\n      files,\n      initFiles: files,\n      activeFile: files[mainFile],\n      errors: [],\n      vueRuntimeURL: this.defaultVueRuntimeURL\n    })\n\n    this.initImportMap(initImportMap)\n\n    watchEffect(() => compileFile(this, this.state.activeFile))\n\n    for (const file in this.state.files) {\n      if (file !== defaultMainFile) {\n        compileFile(this, this.state.files[file])\n      }\n    }\n  }\n\n  setActive(filename: string) {\n    this.state.activeFile = this.state.files[filename]\n  }\n\n  addFile(fileOrFilename: string | File): void {\n    const file = typeof fileOrFilename === 'string' ? new File(fileOrFilename) : fileOrFilename\n    this.state.files[file.filename] = file\n    if (!file.hidden) this.setActive(file.filename)\n  }\n\n  deleteFile(filename: string) {\n    if (confirm(`Are you sure you want to delete ${filename}?`)) {\n      if (this.state.activeFile.filename === filename) {\n        this.state.activeFile = this.state.files[this.state.mainFile]\n      }\n      delete this.state.files[filename]\n    }\n  }\n\n  serialize() {\n    return '#' + utoa(JSON.stringify(this.getFiles()))\n  }\n\n  getFiles() {\n    const exported: Record<string, string> = {}\n    for (const filename in this.state.files) {\n      exported[filename] = this.state.files[filename].code\n    }\n    return exported\n  }\n\n  async setFiles(newFiles: Record<string, string>, mainFile = defaultMainFile) {\n    const files: Record<string, File> = {}\n    if (mainFile === defaultMainFile && !newFiles[mainFile]) {\n      files[mainFile] = new File(mainFile, welcomeCode)\n    }\n    for (const filename in newFiles) {\n      files[filename] = new File(filename, newFiles[filename])\n    }\n    for (const file in files) {\n      await compileFile(this, files[file])\n    }\n    this.state.mainFile = mainFile\n    this.state.files = files\n    this.initImportMap()\n    this.setActive(mainFile)\n  }\n\n  private initImportMap(initImportMap?: ImportMap) {\n    const map = this.state.files['import-map.json']\n    if (!map) {\n      this.state.files['import-map.json'] = new File(\n        'import-map.json',\n        JSON.stringify(\n          {\n            imports: {\n              vue: this.defaultVueRuntimeURL,\n              ...initImportMap?.imports\n            }\n          },\n          null,\n          2\n        )\n      )\n    } else {\n      try {\n        const json = JSON.parse(map.code)\n        if (!json.imports.vue) {\n          json.imports.vue = this.defaultVueRuntimeURL\n          Object.assign(json.imports, initImportMap?.imports)\n          map.code = JSON.stringify(json, null, 2)\n        }\n      } catch (e) {\n        // ignore\n      }\n    }\n  }\n\n  getImportMap() {\n    try {\n      return JSON.parse(this.state.files['import-map.json'].code)\n    } catch (e) {\n      this.state.errors = [`Syntax error in import-map.json: ${(e as Error).message}`]\n      return {}\n    }\n  }\n\n  setImportMap(map: ImportMap) {\n    this.state.files['import-map.json']!.code = JSON.stringify(map, null, 2)\n  }\n\n  async setVueVersion(version: string) {\n    const compilerUrl =\n      this.pkgCdn?.['@vue/compiler-sfc']?.(version, '/dist/compiler-sfc.esm-browser.js') ||\n      DEFAULT_VUE_COMPILER_SFC_CDN(version)\n\n    const runtimeUrl =\n      this.pkgCdn?.['@vue/runtime-dom']?.(version, '/dist/runtime-dom.esm-browser.js') ||\n      DEFAULT_VUE_RUNTIME_DOM_CDN(version)\n\n    this.pendingCompiler = import(/* @vite-ignore */ compilerUrl)\n    this.compiler = await this.pendingCompiler\n    this.pendingCompiler = null\n    this.state.vueRuntimeURL = runtimeUrl\n    const importMap = this.getImportMap()\n    ;(importMap.imports || (importMap.imports = {})).vue = runtimeUrl\n    this.setImportMap(importMap)\n    console.info(`[@vue/repl] Now using Vue version: ${version}`)\n  }\n\n  resetVueVersion() {\n    this.compiler = defaultCompiler\n    this.state.vueRuntimeURL = this.defaultVueRuntimeURL\n  }\n}\n","\nexport default (sfc, props) => {\n  const target = sfc.__vccOpts || sfc;\n  for (const [key, val] of props) {\n    target[key] = val;\n  }\n  return target;\n}\n","<script lang=\"ts\">\nexport default defineComponent({\n  name: 'ControlButton'\n})\n</script>\n<script setup lang=\"ts\">\nimport {defineComponent} from 'vue'\n\ndefineProps({\n  title: {\n    type: String\n  },\n  active: {\n    type: Boolean,\n    default: false\n  }\n})\n</script>\n<template>\n  <div\n    role=\"button\"\n    :title=\"title\"\n    class=\"vue-playground-control-btn\"\n    :class=\"{'vue-playground-toolbar-direction-active': active}\"\n  >\n    <slot></slot>\n  </div>\n</template>\n<style scoped>\n.vue-playground-control-btn {\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  width: 24px;\n  height: 24px;\n  font-size: 12px;\n  color: var(--toolbar-icon-color);\n  cursor: pointer;\n  background-color: var(--toolbar-icon-bg-color);\n  border: 1px solid var(--toolbar-icon-color);\n  border-radius: 4px;\n  box-shadow: 0 4px 6px -1px rgb(0, 0, 0, 0.1), 0 2px 4px -2px rgb(0, 0, 0, 0.1);\n}\n\n.vue-playground-control-btn.vue-playground-toolbar-direction-active {\n  color: var(--toolbar-icon-active-color);\n  border: 1px solid var(--toolbar-icon-active-color);\n}\n</style>\n","/* eslint-disable @typescript-eslint/no-explicit-any */\nimport {defineComponent, VNode} from 'vue'\n\nconst createComponent = (name: string, render: (props: Record<string, any>) => VNode) =>\n  defineComponent({\n    name,\n    render() {\n      const props = {...this.$props, ...this.$attrs}\n      return render(props)\n    }\n  })\n\nexport const EditorLeftPreviewRightIcon = createComponent('EditorLeftPreviewRightIcon', props => (\n  <svg width=\"1em\" height=\"1em\" viewBox=\"0 0 24 24\" {...props}>\n    <path\n      d=\"M12 5v14h7V5h-7zM4 3h16a1 1 0 0 1 1 1v16a1 1 0 0 1-1 1H4a1 1 0 0 1-1-1V4a1 1 0 0 1 1-1z\"\n      fill=\"currentColor\"\n    ></path>\n  </svg>\n))\n\nexport const EditorTopPreviewBottomIcon = createComponent('EditorTopPreviewBottomIcon', props => (\n  <EditorLeftPreviewRightIcon {...props} style={{transform: 'rotate(90deg)'}} />\n))\n\nexport const EditorRightPreviewLeftIcon = createComponent('EditorRightPreviewLeftIcon', props => (\n  <EditorLeftPreviewRightIcon {...props} style={{transform: 'rotate(180deg)'}} />\n))\n\nexport const EditorBottomPreviewTopIcon = createComponent('EditorBottomPreviewTopIcon', props => (\n  <EditorLeftPreviewRightIcon {...props} style={{transform: 'rotate(270deg)'}} />\n))\n\nexport const ErrorIcon = createComponent('ErrorIcon', props => (\n  <svg width=\"1em\" height=\"1em\" viewBox=\"0 0 24 24\" {...props}>\n    <path\n      d=\"M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10s10-4.48 10-10S17.52 2 12 2zm1 15h-2v-2h2v2zm0-4h-2V7h2v6z\"\n      fill=\"currentColor\"\n    ></path>\n  </svg>\n))\n\nexport const FullscreenIcon = createComponent('FullscreenIcon', props => (\n  <svg width=\"1em\" height=\"1em\" viewBox=\"0 0 24 24\" {...props}>\n    <path d=\"M5 5h5v2H7v3H5V5m9 0h5v5h-2V7h-3V5m3 9h2v5h-5v-2h3v-3m-7 3v2H5v-5h2v3h3z\" fill=\"currentColor\"></path>\n  </svg>\n))\n\nexport const ExitFullscreenIcon = createComponent('ExitFullscreenIcon', props => (\n  <svg width=\"1em\" height=\"1em\" viewBox=\"0 0 24 24\" {...props}>\n    <path d=\"M14 14h5v2h-3v3h-2v-5m-9 0h5v5H8v-3H5v-2m3-9h2v5H5V8h3V5m11 3v2h-5V5h2v3h3z\" fill=\"currentColor\"></path>\n  </svg>\n))\n\nexport const ShowCodeIcon = createComponent('ShowCodeIcon', props => (\n  <svg width=\"1em\" height=\"1em\" viewBox=\"0 0 24 24\" {...props}>\n    <path\n      d=\"M8.7 15.9L4.8 12l3.9-3.9a.984.984 0 0 0 0-1.4a.984.984 0 0 0-1.4 0l-4.59 4.59a.996.996 0 0 0 0 1.41l4.59 4.6c.39.39 1.01.39 1.4 0a.984.984 0 0 0 0-1.4zm6.6 0l3.9-3.9l-3.9-3.9a.984.984 0 0 1 0-1.4a.984.984 0 0 1 1.4 0l4.59 4.59c.39.39.39 1.02 0 1.41l-4.59 4.6a.984.984 0 0 1-1.4 0a.984.984 0 0 1 0-1.4z\"\n      fill=\"currentColor\"\n    ></path>\n  </svg>\n))\n\nexport const HideCodeIcon = createComponent('HideCodeIcon', props => (\n  <svg width=\"1em\" height=\"1em\" viewBox=\"0 0 24 24\" {...props}>\n    <path\n      d=\"M19.17 12l-3.88-3.88a.996.996 0 1 1 1.41-1.41l4.59 4.59c.39.39.39 1.02 0 1.41l-2.88 2.88L17 14.17L19.17 12zM2.1 4.93l3.49 3.49l-2.88 2.88a.996.996 0 0 0 0 1.41L7.3 17.3a.996.996 0 1 0 1.41-1.41L4.83 12L7 9.83L19.07 21.9a.996.996 0 1 0 1.41-1.41L3.51 3.51a.996.996 0 0 0-1.41 0c-.39.4-.39 1.03 0 1.42z\"\n      fill=\"currentColor\"\n    ></path>\n  </svg>\n))\n\nexport const DisconnectedIcon = createComponent('DisconnectedIcon', props => (\n  <svg width=\"1em\" height=\"1em\" viewBox=\"0 0 24 24\" {...props}>\n    <path\n      fill=\"currentColor\"\n      d=\"M21.707 3.707a1 1 0 0 0-1.414-1.414L18.496 4.09a4.252 4.252 0 0 0-5.251.604l-1.068 1.069a1.75 1.75 0 0 0 0 2.474l3.585 3.586a1.75 1.75 0 0 0 2.475 0l1.068-1.068a4.252 4.252 0 0 0 .605-5.25l1.797-1.798Zm-11 8a1 1 0 0 0-1.414-1.414l-1.47 1.47l-.293-.293a.75.75 0 0 0-1.06 0l-1.775 1.775a4.252 4.252 0 0 0-.605 5.25l-1.797 1.798a1 1 0 1 0 1.414 1.414l1.798-1.797a4.252 4.252 0 0 0 5.25-.605l1.775-1.775a.75.75 0 0 0 0-1.06l-.293-.293l1.47-1.47a1 1 0 0 0-1.414-1.414l-1.47 1.47l-1.586-1.586l1.47-1.47Z\"\n    />\n  </svg>\n))\n\nexport const ConnectedIcon = createComponent('ConnectedIcon', props => (\n  <svg width=\"1em\" height=\"1em\" viewBox=\"0 0 20 20\" {...props}>\n    <path\n      fill=\"currentColor\"\n      d=\"M17.78 3.28a.75.75 0 0 0-1.06-1.06l-2.446 2.445a4.037 4.037 0 0 0-5.128.481l-.3.3a1.49 1.49 0 0 0 0 2.108l3.6 3.6a1.49 1.49 0 0 0 2.107 0l.3-.3a4.037 4.037 0 0 0 .482-5.128L17.78 3.28ZM7.554 8.846a1.49 1.49 0 0 0-2.107 0l-.3.3a4.037 4.037 0 0 0-.481 5.128L2.22 16.72a.75.75 0 1 0 1.06 1.06l2.446-2.446a4.037 4.037 0 0 0 5.128-.48l.3-.3a1.49 1.49 0 0 0 0-2.108l-3.6-3.6Z\"\n    />\n  </svg>\n))\n\nexport const LightIcon = createComponent('LightIcon', props => (\n  <svg width=\"1em\" height=\"1em\" viewBox=\"0 0 24 24\" fill=\"currentColor\" {...props}>\n    <path d=\"M12,18c-3.3,0-6-2.7-6-6s2.7-6,6-6s6,2.7,6,6S15.3,18,12,18zM12,8c-2.2,0-4,1.8-4,4c0,2.2,1.8,4,4,4c2.2,0,4-1.8,4-4C16,9.8,14.2,8,12,8z\"></path>\n    <path d=\"M12,4c-0.6,0-1-0.4-1-1V1c0-0.6,0.4-1,1-1s1,0.4,1,1v2C13,3.6,12.6,4,12,4z\"></path>\n    <path d=\"M12,24c-0.6,0-1-0.4-1-1v-2c0-0.6,0.4-1,1-1s1,0.4,1,1v2C13,23.6,12.6,24,12,24z\"></path>\n    <path d=\"M5.6,6.6c-0.3,0-0.5-0.1-0.7-0.3L3.5,4.9c-0.4-0.4-0.4-1,0-1.4s1-0.4,1.4,0l1.4,1.4c0.4,0.4,0.4,1,0,1.4C6.2,6.5,5.9,6.6,5.6,6.6z\"></path>\n    <path d=\"M19.8,20.8c-0.3,0-0.5-0.1-0.7-0.3l-1.4-1.4c-0.4-0.4-0.4-1,0-1.4s1-0.4,1.4,0l1.4,1.4c0.4,0.4,0.4,1,0,1.4C20.3,20.7,20,20.8,19.8,20.8z\"></path>\n    <path d=\"M3,13H1c-0.6,0-1-0.4-1-1s0.4-1,1-1h2c0.6,0,1,0.4,1,1S3.6,13,3,13z\"></path>\n    <path d=\"M23,13h-2c-0.6,0-1-0.4-1-1s0.4-1,1-1h2c0.6,0,1,0.4,1,1S23.6,13,23,13z\"></path>\n    <path d=\"M4.2,20.8c-0.3,0-0.5-0.1-0.7-0.3c-0.4-0.4-0.4-1,0-1.4l1.4-1.4c0.4-0.4,1-0.4,1.4,0s0.4,1,0,1.4l-1.4,1.4C4.7,20.7,4.5,20.8,4.2,20.8z\"></path>\n    <path d=\"M18.4,6.6c-0.3,0-0.5-0.1-0.7-0.3c-0.4-0.4-0.4-1,0-1.4l1.4-1.4c0.4-0.4,1-0.4,1.4,0s0.4,1,0,1.4l-1.4,1.4C18.9,6.5,18.6,6.6,18.4,6.6z\"></path>\n  </svg>\n))\n\nexport const DarkIcon = createComponent('DarkIcon', props => (\n  <svg width=\"1em\" height=\"1em\" viewBox=\"0 0 24 24\" fill=\"currentColor\" {...props}>\n    <path d=\"M12.1,22c-0.3,0-0.6,0-0.9,0c-5.5-0.5-9.5-5.4-9-10.9c0.4-4.8,4.2-8.6,9-9c0.4,0,0.8,0.2,1,0.5c0.2,0.3,0.2,0.8-0.1,1.1c-2,2.7-1.4,6.4,1.3,8.4c2.1,1.6,5,1.6,7.1,0c0.3-0.2,0.7-0.3,1.1-0.1c0.3,0.2,0.5,0.6,0.5,1c-0.2,2.7-1.5,5.1-3.6,6.8C16.6,21.2,14.4,22,12.1,22zM9.3,4.4c-2.9,1-5,3.6-5.2,6.8c-0.4,4.4,2.8,8.3,7.2,8.7c2.1,0.2,4.2-0.4,5.8-1.8c1.1-0.9,1.9-2.1,2.4-3.4c-2.5,0.9-5.3,0.5-7.5-1.1C9.2,11.4,8.1,7.7,9.3,4.4z\"></path>\n  </svg>\n))\n\nexport const LoadingIcon = createComponent('LoadingIcon', props => (\n  <svg\n    focusable=\"false\"\n    class=\"anticon-spin\"\n    data-icon=\"loading\"\n    aria-hidden=\"true\"\n    viewBox=\"0 0 1024 1024\"\n    width=\"1em\"\n    height=\"1em\"\n    fill=\"currentColor\"\n    {...props}\n  >\n    <path d=\"M988 548c-19.9 0-36-16.1-36-36 0-59.4-11.6-117-34.6-171.3a440.45 440.45 0 00-94.3-139.9 437.71 437.71 0 00-139.9-94.3C629 83.6 571.4 72 512 72c-19.9 0-36-16.1-36-36s16.1-36 36-36c69.1 0 136.2 13.5 199.3 40.3C772.3 66 827 103 874 150c47 47 83.9 101.8 109.7 162.7 26.7 63.1 40.2 130.2 40.2 199.3.1 19.9-16 36-35.9 36z\"></path>\n  </svg>\n))\n","<script lang=\"ts\">\nexport default defineComponent({\n  name: 'Toolbar'\n})\n</script>\n<script setup lang=\"ts\">\nimport {defineComponent, PropType} from 'vue'\nimport {LayoutDirection} from '../utils/types-helper'\nimport ControlButton from './control-button.vue'\nimport {\n  EditorBottomPreviewTopIcon,\n  EditorLeftPreviewRightIcon,\n  EditorRightPreviewLeftIcon,\n  EditorTopPreviewBottomIcon,\n  HideCodeIcon,\n  ShowCodeIcon,\n  LightIcon,\n  DarkIcon,\n  ExitFullscreenIcon,\n  FullscreenIcon\n} from './icon'\n\nconst props = defineProps({\n  title: {\n    type: String\n  },\n  showCode: {\n    type: Boolean,\n    default: true\n  },\n  showDark: {\n    type: Boolean,\n    default: false\n  },\n  fullScreen: {\n    type: Boolean,\n    default: false\n  },\n  layoutDirection: {\n    type: String as PropType<LayoutDirection>,\n    default: 'EditorBottomPreviewTop' as LayoutDirection\n  }\n})\n\ninterface Emits {\n  (e: 'update:layoutDirection', value: LayoutDirection): void\n  (e: 'update:showCode', value: boolean): void\n  (e: 'update:fullScreen', value: boolean): void\n  (e: 'update:showDark', value: boolean): void\n}\n\nconst emit = defineEmits<Emits>()\n\nconst layoutDirections: LayoutDirection[] = [\n  'EditorBottomPreviewTop',\n  'EditorRightPreviewLeft',\n  'EditorTopPreviewBottom',\n  'EditorLeftPreviewRight'\n]\n\nfunction handleDirectionIconClick(direction: LayoutDirection) {\n  emit('update:layoutDirection', direction)\n}\n\nfunction handleVisibleCodeIconClick() {\n  emit('update:showCode', !props.showCode)\n}\n\nfunction handleToggleDarkIconClick() {\n  emit('update:showDark', !props.showDark)\n}\n\nfunction handleFullscreenIconClick() {\n  emit('update:fullScreen', !props.fullScreen)\n}\n</script>\n<template>\n  <div class=\"vue-playground-toolbar\">\n    <div class=\"vue-playground-toolbar-title\">{{ title }}</div>\n    <div class=\"vue-playground-toolbar-spacer\"></div>\n    <div class=\"vue-playground-toolbar-actions\">\n      <ControlButton\n        v-for=\"direction in layoutDirections\"\n        :key=\"direction\"\n        title=\"Toggle Layout\"\n        :active=\"layoutDirection === direction\"\n        @click=\"handleDirectionIconClick(direction)\"\n      >\n        <EditorBottomPreviewTopIcon v-if=\"direction === 'EditorBottomPreviewTop'\"></EditorBottomPreviewTopIcon>\n        <EditorRightPreviewLeftIcon v-if=\"direction === 'EditorRightPreviewLeft'\"></EditorRightPreviewLeftIcon>\n        <EditorTopPreviewBottomIcon v-if=\"direction === 'EditorTopPreviewBottom'\"></EditorTopPreviewBottomIcon>\n        <EditorLeftPreviewRightIcon v-if=\"direction === 'EditorLeftPreviewRight'\"></EditorLeftPreviewRightIcon>\n      </ControlButton>\n      <ControlButton title=\"Show/Hide Code Editor\" @click=\"handleVisibleCodeIconClick\">\n        <HideCodeIcon v-if=\"showCode\" />\n        <ShowCodeIcon v-else />\n      </ControlButton>\n      <ControlButton title=\"Toggle Dark Mode\" @click=\"handleToggleDarkIconClick\">\n        <LightIcon v-if=\"!showDark\" />\n        <DarkIcon v-else />\n      </ControlButton>\n      <ControlButton title=\"Toggle fullscreen\" @click=\"handleFullscreenIconClick\">\n        <ExitFullscreenIcon v-if=\"fullScreen\" />\n        <FullscreenIcon v-else />\n      </ControlButton>\n    </div>\n  </div>\n</template>\n\n<style scoped>\n.vue-playground-toolbar {\n  box-sizing: border-box;\n  display: flex;\n  flex-shrink: 0;\n  align-items: center;\n  width: 100%;\n  height: 40px;\n  padding: 0 15px;\n  overflow: hidden;\n  color: var(--toolbar-text-color);\n  background-color: var(--toolbar-bg-color);\n  border-bottom: 1px solid var(--border-color);\n}\n\n.vue-playground-toolbar-title {\n  font-size: 12px;\n  font-weight: 600;\n}\n\n.vue-playground-toolbar-spacer {\n  flex: 1;\n}\n\n.vue-playground-toolbar-actions {\n  display: flex;\n  flex-shrink: 0;\n  white-space: nowrap;\n}\n\n.vue-playground-toolbar-actions :deep(.vue-playground-control-btn) {\n  margin-left: 8px;\n}\n</style>\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, options = {}) {\n  const {\n    truthyValue = true,\n    falsyValue = false\n  } = options;\n  const valueIsRef = isRef(initialValue);\n  const innerValue = ref(initialValue);\n  function toggle(value) {\n    if (arguments.length) {\n      innerValue.value = value;\n      return innerValue.value;\n    } else {\n      innerValue.value = innerValue.value === unref(truthyValue) ? unref(falsyValue) : unref(truthyValue);\n      return innerValue.value;\n    }\n  }\n  if (valueIsRef)\n    return toggle;\n  else\n    return [innerValue, toggle];\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, onMounted, markRaw, getCurrentScope, isVue2, set, del, readonly, onBeforeUpdate } from 'vue-demi';\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 && counterAtBeginning === counter)\n        evaluating.value = false;\n      hasFinished = true;\n    }\n  });\n  if (lazy) {\n    return computed(() => {\n      started.value = true;\n      return current.value;\n    });\n  } else {\n    return current;\n  }\n}\n\nfunction computedInject(key, options, defaultSource, treatDefaultAsFactory) {\n  let source = inject(key);\n  if (defaultSource)\n    source = inject(key, defaultSource);\n  if (treatDefaultAsFactory)\n    source = inject(key, defaultSource, treatDefaultAsFactory);\n  if (typeof options === \"function\") {\n    return computed((ctx) => options(source, ctx));\n  } else {\n    return computed({\n      get: (ctx) => options.get(source, ctx),\n      set: options.set\n    });\n  }\n}\n\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  let fallback;\n  const listener = (event) => {\n    window.clearTimeout(fallback);\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    useEventListener(window, \"pointerup\", (e) => {\n      fallback = window.setTimeout(() => listener(e), 50);\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(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(elementRef, \"pointerdown\", onDown);\n  useEventListener(elementRef, \"pointerup\", clear);\n  useEventListener(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    } finally {\n      isLoading.value = false;\n    }\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 useCurrentElement() {\n  const vm = getCurrentInstance();\n  const count = ref(0);\n  onUpdated(() => {\n    count.value += 1;\n  });\n  onMounted(() => {\n    count.value += 1;\n  });\n  return computed(() => {\n    count.value;\n    return vm.proxy.$el;\n  });\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    immediate = 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  tryOnMounted(() => {\n    if (immediate)\n      update();\n  });\n  return {\n    height,\n    bottom,\n    left,\n    right,\n    top,\n    width,\n    x,\n    y,\n    update\n  };\n}\n\nfunction 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    var _a;\n    const listeners = events.get(key) || [];\n    listeners.push(listener);\n    events.set(key, listeners);\n    const _off = () => off(listener);\n    (_a = scope == null ? void 0 : scope.cleanups) == null ? void 0 : _a.push(_off);\n    return _off;\n  }\n  function once(listener) {\n    function _listener(...args) {\n      off(_listener);\n      listener(...args);\n    }\n    return on(_listener);\n  }\n  function off(listener) {\n    const listeners = events.get(key);\n    if (!listeners)\n      return;\n    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(updateGamepadState);\n  const onGamepadConnected = (gamepad) => {\n    if (!gamepads.value.some(({ index }) => index === gamepad.index)) {\n      gamepads.value.push(stateFromGamepad(gamepad));\n      onConnectedHook.trigger(gamepad.index);\n    }\n    resume();\n  };\n  const onGamepadDisconnected = (gamepad) => {\n    gamepads.value = gamepads.value.filter((x) => x.index !== gamepad.index);\n    onDisconnectedHook.trigger(gamepad.index);\n  };\n  useEventListener(\"gamepadconnected\", (e) => onGamepadConnected(e.gamepad));\n  useEventListener(\"gamepaddisconnected\", (e) => onGamepadDisconnected(e.gamepad));\n  tryOnMounted(() => {\n    const _gamepads = (navigator == null ? void 0 : navigator.getGamepads()) || [];\n    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 && \"MutationObserver\" 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 onlineAt = ref(void 0);\n  const downlink = ref(void 0);\n  const downlinkMax = ref(void 0);\n  const rtt = ref(void 0);\n  const effectiveType = ref(void 0);\n  const type = ref(\"unknown\");\n  const connection = isSupported && navigator.connection;\n  function updateNetworkInformation() {\n    if (!navigator)\n      return;\n    isOnline.value = navigator.onLine;\n    offlineAt.value = isOnline.value ? void 0 : Date.now();\n    onlineAt.value = isOnline.value ? Date.now() : void 0;\n    if (connection) {\n      downlink.value = connection.downlink;\n      downlinkMax.value = connection.downlinkMax;\n      effectiveType.value = connection.effectiveType;\n      rtt.value = connection.rtt;\n      saveData.value = connection.saveData;\n      type.value = connection.type;\n    }\n  }\n  if (window) {\n    useEventListener(window, \"offline\", () => {\n      isOnline.value = false;\n      offlineAt.value = Date.now();\n    });\n    useEventListener(window, \"online\", () => {\n      isOnline.value = true;\n      onlineAt.value = Date.now();\n    });\n  }\n  if (connection)\n    useEventListener(connection, \"change\", updateNetworkInformation, false);\n  updateNetworkInformation();\n  return {\n    isSupported,\n    isOnline,\n    saveData,\n    offlineAt,\n    onlineAt,\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 useScreenOrientation = (options = {}) => {\n  const {\n    window = defaultWindow\n  } = options;\n  const isSupported = !!(window && \"screen\" in window && \"orientation\" in window.screen);\n  const screenOrientation = isSupported ? window.screen.orientation : {};\n  const orientation = ref(screenOrientation.type);\n  const angle = ref(screenOrientation.angle || 0);\n  if (isSupported) {\n    useEventListener(window, \"orientationchange\", () => {\n      orientation.value = screenOrientation.type;\n      angle.value = screenOrientation.angle;\n    });\n  }\n  const lockOrientation = (type) => {\n    if (!isSupported)\n      return Promise.reject(new Error(\"Not supported\"));\n    return screenOrientation.lock(type);\n  };\n  const unlockOrientation = () => {\n    if (isSupported)\n      screenOrientation.unlock();\n  };\n  return {\n    isSupported,\n    orientation,\n    angle,\n    lockOrientation,\n    unlockOrientation\n  };\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    defaultValue\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] || defaultValue);\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        var _a2;\n        return (_a2 = props[key]) != null ? _a2 : defaultValue;\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, useCurrentElement, 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, useScreenOrientation, 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","/* eslint-disable @typescript-eslint/no-explicit-any */\nimport {createEventHook, EventHookOn} from '@vueuse/core'\nimport {MonacoEditor} from '../utils/types-helper'\n\nconst onEditorCreatedHook = createEventHook<{id: string; editor: MonacoEditor.IStandaloneCodeEditor}>()\nconst onEditorDestroyedHook = createEventHook<{id: string}>()\nconst editors: Record<string, MonacoEditor.IStandaloneCodeEditor> = {}\nlet id = 0\n\ninterface EventHookOnParam {\n  id: string\n  editor?: MonacoEditor.IStandaloneCodeEditor\n}\n\n/**\n * Provides a global store of all the monaco editors in the page.\n */\nexport function useEditors() {\n  const removeEditor = (id: string) => {\n    return () => {\n      editors[id]?.dispose?.()\n      delete editors[id]\n      onEditorDestroyedHook.trigger({id})\n    }\n  }\n\n  const addEditor = (editor: MonacoEditor.IStandaloneCodeEditor) => {\n    id++\n    editors[id] = editor\n    onEditorCreatedHook.trigger({id: id.toString(), editor})\n    return removeEditor(id.toString())\n  }\n\n  return {\n    editors,\n    addEditor,\n    onEditorCreated: onEditorCreatedHook.on as EventHookOn<EventHookOnParam>,\n    onEditorDestroyed: onEditorDestroyedHook.on as EventHookOn<EventHookOnParam>\n  }\n}\n","/* eslint-disable @typescript-eslint/no-explicit-any */\nimport {computed, unref} from 'vue'\nimport {MaybeRef} from '@vueuse/core'\nimport {File} from '../../core'\nimport {PROJECT_ID_PREFIX, FILE_BASE_URL} from '../constants'\nimport {Monaco, PromiseFnReturnType} from './types-helper'\n\nexport const getProjectFileBaseUrl = (projectId: string) => `${FILE_BASE_URL}${projectId}/`\n\nexport const getFileUri = (mona: Monaco, projectId: string, filename: string) => {\n  // console.log(mona.Uri.parse(`${getProjectFileBaseUrl(projectId)}${filename}`))\n  return mona.Uri.parse(`${getProjectFileBaseUrl(projectId)}${filename}`)\n}\n\nexport const getFileLanguage = (file: File) => {\n  const ext = file.filename.split('.').pop()\n  switch (ext) {\n    case 'js':\n    case 'jsx':\n      return 'javascript'\n    case 'ts':\n    case 'tsx':\n      return 'typescript'\n    case 'vue':\n      return 'html'\n    case 'css':\n      return 'css'\n    default:\n      return 'plaintext'\n  }\n}\n\nexport const genRandomStr = () =>\n  Math.random()\n    .toString(36)\n    .replace(/[^a-z]+/g, '')\n    .substring(0, 5)\n\nexport const hash = (str: string) => {\n  let hash = 0\n  for (let i = 0; i < str.length; ++i) hash = Math.imul(31, hash) + str.charCodeAt(i)\n\n  return '' + (hash | 0)\n}\n\nexport const safeId = (id?: string) => hash(id ? String(id) : genRandomStr())\n\nexport const generateProjectId = (id?: string) => PROJECT_ID_PREFIX + safeId(id)\n\nexport const mustBeRef = <T>(value: MaybeRef<T>) => computed(() => unref(value))\n\nexport interface SingletonPromiseReturn<Args extends any[], R> {\n  (...args: Args): Promise<R>\n  /**\n   * Reset current staled promise.\n   * Await it to have proper shutdown.\n   */\n  reset: () => Promise<void>\n}\n\nexport function createSingletonPromise<Fn extends (...args: any[]) => Promise<any>>(\n  fn: Fn\n): SingletonPromiseReturn<Parameters<Fn>, PromiseFnReturnType<Fn>> {\n  type R = PromiseFnReturnType<Fn>\n  let _promise: Promise<R> | undefined\n\n  function wrapper(...args: Parameters<Fn>) {\n    if (!_promise) _promise = fn(...args)\n    return _promise\n  }\n  wrapper.reset = async () => {\n    const _prev = _promise\n    _promise = undefined\n    if (_prev) await _prev\n  }\n\n  return wrapper\n}\n","import {Monaco, PlaygroundLifeCycle} from '../utils/types-helper'\nimport {createSingletonPromise} from '../utils/common'\n\nexport const loadWorkers = createSingletonPromise(async (monaco: Monaco, lifeCycle?: PlaygroundLifeCycle) => {\n  await lifeCycle?.loadWorkers?.(monaco, self)\n  // return await Promise.all([\n  //   // load workers\n  //   (async () => {\n  //     const [\n  //       {default: EditorWorker},\n  //       {default: JsonWorker},\n  //       {default: HtmlWorker},\n  //       {default: TsWorker},\n  //       {default: CssWorker}\n  //     ] = await Promise.all([\n  //       import('monaco-editor/esm/vs/editor/editor.worker?worker'),\n  //       import('monaco-editor/esm/vs/language/json/json.worker?worker'),\n  //       import('monaco-editor/esm/vs/language/html/html.worker?worker'),\n  //       import('monaco-editor/esm/vs/language/typescript/ts.worker?worker'),\n  //       import('monaco-editor/esm/vs/language/css/css.worker?worker')\n  //     ])\n\n  //     self.MonacoEnvironment = {\n  //       getWorker: function (workerId, label) {\n  //         switch (label) {\n  //           case 'json':\n  //             return new JsonWorker()\n  //           case 'css':\n  //           case 'scss':\n  //           case 'less':\n  //             return new CssWorker()\n  //           case 'html':\n  //           case 'handlebars':\n  //           case 'razor':\n  //             return new HtmlWorker()\n  //           case 'typescript':\n  //           case 'javascript':\n  //             return new TsWorker()\n  //           default:\n  //             return new EditorWorker()\n  //         }\n  //       }\n  //     }\n  //   })()\n  // ])\n})\n","/* eslint-disable @typescript-eslint/no-explicit-any */\nimport {FILE_BASE_URL} from '../constants'\nimport {Monaco, PlaygroundLifeCycle, Tsconfig, TsLib} from '../utils/types-helper'\n\nexport async function setLanguage(monaco: Monaco, lifeCycle?: PlaygroundLifeCycle) {\n  const defaultTsconfig: Tsconfig = {\n    ...monaco.languages.typescript.typescriptDefaults.getCompilerOptions(),\n    target: monaco.languages.typescript.ScriptTarget.ESNext,\n    baseUrl: FILE_BASE_URL,\n    allowNonTsExtensions: true,\n    moduleResolution: monaco.languages.typescript.ModuleResolutionKind.NodeJs,\n    module: monaco.languages.typescript.ModuleKind.ESNext,\n    noEmit: true,\n    esModuleInterop: true,\n    jsx: monaco.languages.typescript.JsxEmit.Preserve,\n    allowJs: true,\n    skipLibCheck: true,\n    noImplicitThis: true,\n    emitDecoratorMetadata: true,\n    resolveJsonModule: true,\n    allowSyntheticDefaultImports: true,\n    experimentalDecorators: true,\n    noUnusedLocals: false,\n    noUnusedParameters: false,\n    noImplicitAny: false,\n    allowUnreachableCode: true,\n    allowUnusedLabels: true,\n    suppressImplicitAnyIndexErrors: true,\n    strict: false,\n    typeRoots: ['node_modules/@types']\n  }\n\n  const tsconfig = (await lifeCycle?.loadTsconfig?.(monaco, defaultTsconfig)) || defaultTsconfig\n\n  // ts\n  monaco.languages.typescript.typescriptDefaults.setCompilerOptions(tsconfig)\n\n  monaco.languages.typescript.typescriptDefaults.setDiagnosticsOptions({\n    noSemanticValidation: false,\n    noSyntaxValidation: false,\n    // Ignore unused variable warnings\n    diagnosticCodesToIgnore: [6133, 6198, 8006, 8010]\n  })\n\n  //js\n  monaco.languages.typescript.javascriptDefaults.setCompilerOptions(tsconfig)\n\n  monaco.languages.typescript.javascriptDefaults.setDiagnosticsOptions({\n    noSemanticValidation: false,\n    noSyntaxValidation: false\n  })\n\n  const [\n    {default: vueTypes},\n    {default: vueSharedTypes},\n    {default: vueRuntimeDomTypes},\n    {default: vueRuntimeCoreTypes},\n    {default: vueReactivityTypes},\n    {default: runtimeTypes}\n  ] = await Promise.all([\n    import('vue/dist/vue.d.ts?raw'),\n    import('@vue/shared/dist/shared.d.ts?raw'),\n    import('@vue/runtime-dom/dist/runtime-dom.d.ts?raw'),\n    import('@vue/runtime-core/dist/runtime-core.d.ts?raw'),\n    import('@vue/reactivity/dist/reactivity.d.ts?raw'),\n    import('./runtime.d.ts?raw')\n  ])\n\n  const defaultTsLibs: TsLib[] = [\n    {content: runtimeTypes},\n    {content: `declare module '@vue/shared' { ${vueSharedTypes} }`},\n    {content: `declare module '@vue/runtime-core' { ${vueRuntimeCoreTypes} }`},\n    {content: `declare module '@vue/runtime-dom' { ${vueRuntimeDomTypes} }`},\n    {content: `declare module '@vue/reactivity' { ${vueReactivityTypes} }`},\n    {content: `declare module 'vue' { ${vueTypes} }`}\n  ]\n\n  const tsLibs = (await lifeCycle?.loadTsLibs?.(monaco, defaultTsLibs)) || defaultTsLibs\n\n  tsLibs.forEach(lib => {\n    monaco.languages.typescript.typescriptDefaults.addExtraLib(lib.content, lib.filePath)\n  })\n\n  // suggestions\n  monaco.languages.registerCompletionItemProvider('html', {\n    triggerCharacters: ['>'],\n    provideCompletionItems: (model, position) => {\n      const codePre: string = model.getValueInRange({\n        startLineNumber: position.lineNumber,\n        startColumn: 1,\n        endLineNumber: position.lineNumber,\n        endColumn: position.column\n      })\n\n      const tag = codePre.match(/.*<(\\w+)>$/)?.[1]\n\n      if (!tag) return\n\n      const word = model.getWordUntilPosition(position)\n\n      return {\n        suggestions: [\n          {\n            label: `</${tag}>`,\n            kind: monaco.languages.CompletionItemKind.EnumMember,\n            insertText: `</${tag}>`,\n            range: {\n              startLineNumber: position.lineNumber,\n              endLineNumber: position.lineNumber,\n              startColumn: word.startColumn,\n              endColumn: word.endColumn\n            }\n          }\n        ]\n      }\n    }\n  })\n\n  // support emmet\n  const {emmetHTML} = await import('emmet-monaco-es')\n  emmetHTML(monaco as any)\n}\n","// eslint-disable-next-line @typescript-eslint/no-unused-vars\nimport {createSingletonPromise, SingletonPromiseReturn} from '../utils/common'\nimport {Monaco, PlaygroundLifeCycle} from '../utils/types-helper'\nimport {setLanguage} from './language'\nimport {loadWorkers} from './worker'\n\nexport const loadMonacoImport = createSingletonPromise(async () => {\n  if (typeof window !== 'undefined') return (await import('monaco-editor')) as Monaco\n  return null\n})\n\nexport const setupMonaco = createSingletonPromise(async (lifeCycle?: PlaygroundLifeCycle) => {\n  const monaco = await loadMonacoImport()\n  if (!monaco) return {monaco: null}\n\n  await setLanguage(monaco, lifeCycle)\n  await loadWorkers(monaco, lifeCycle)\n\n  return {monaco}\n})\n","import {Monaco, MonacoEditor} from '../utils/types-helper'\nimport {ref, unref, watch} from 'vue'\nimport {MaybeRef, tryOnUnmounted} from '@vueuse/core'\nimport {File} from '../../core'\nimport {getFileLanguage, getFileUri, mustBeRef} from '../utils/common'\n\nexport interface UseMonacoModelsOptions {\n  projectId: MaybeRef<string>\n  files: MaybeRef<File[]>\n  monaco: Monaco\n  getEditor: () => MonacoEditor.IStandaloneCodeEditor | undefined\n  editorUpdateId: MaybeRef<number>\n  isSetup: MaybeRef<boolean>\n}\n\nexport function useMonacoModels(options: UseMonacoModelsOptions) {\n  const {projectId, files, isSetup, monaco, getEditor, editorUpdateId} = options\n  const modelUpdateId = ref(0)\n  let models: MonacoEditor.ITextModel[] | null = []\n  const getModels = () => models\n\n  const setModels = (_models: MonacoEditor.ITextModel[] | null) => {\n    models = _models\n    modelUpdateId.value++\n  }\n\n  tryOnUnmounted(() => {\n    if (models) {\n      models.forEach(model => model.dispose())\n      setModels(null)\n    }\n  })\n\n  watch(\n    [mustBeRef(files), mustBeRef(projectId), mustBeRef(isSetup), mustBeRef(editorUpdateId)],\n    () => {\n      if (!unref(isSetup) || !getEditor() || !unref(projectId)) return\n\n      const findModel = (file: File) =>\n        models?.find(model => getFileUri(monaco, unref(projectId), file.filename).path === model.uri.path)\n\n      if (!models || !models.length || models.length !== unref(files).length) {\n        const newModels = unref(files).map(file => {\n          return (\n            findModel(file) ||\n            monaco.editor.createModel(\n              file.code,\n              getFileLanguage(file),\n              getFileUri(monaco, unref(projectId), file.filename)\n            )\n          )\n        })\n        setModels(newModels)\n      } else {\n        models.forEach(model => {\n          const latestCode = unref(files).find(\n            file => getFileUri(monaco, unref(projectId), file.filename).path === model.uri.path\n          )?.code\n          if (!model.isDisposed() && model.getValue() !== latestCode) {\n            model.setValue(latestCode ?? '')\n          }\n        })\n      }\n    },\n    {\n      deep: true,\n      immediate: true\n    }\n  )\n\n  return {getModels, modelUpdateId}\n}\n","import {useDark, useToggle} from '@vueuse/core'\n\nexport const isDark = useDark({\n  // do not add .dark class name to html\n  // eslint-disable-next-line @typescript-eslint/no-empty-function\n  onChanged: () => {}\n})\nexport const toggleDark = useToggle(isDark)\n","/* eslint-disable @typescript-eslint/no-explicit-any */\n/* eslint-disable @typescript-eslint/no-empty-function */\nimport {ref, Ref, unref, watch} from 'vue'\nimport {tryOnScopeDispose, MaybeRef, createEventHook, tryOnUnmounted, EventHookOn} from '@vueuse/core'\nimport darkTheme from 'theme-vitesse/themes/vitesse-dark.json'\nimport lightTheme from 'theme-vitesse/themes/vitesse-light.json'\nimport {useEditors} from './useEditor'\nimport {setupMonaco} from '../monaco'\nimport {File} from '../../core'\nimport {useMonacoModels} from './useMonacoModels'\nimport {toggleDark, isDark} from './index'\nimport {CreateEditorOptions, MonacoEditor, PlaygroundLifeCycle} from '../utils/types-helper'\nimport {generateProjectId, mustBeRef} from '../utils/common'\n\nexport interface UseMonacoOptions {\n  themeName?: MaybeRef<string | undefined>\n  lifeCycle?: MaybeRef<PlaygroundLifeCycle | undefined>\n  activeFile: MaybeRef<File>\n  files: MaybeRef<File[]>\n}\n\nexport interface ChangeEvent {\n  newCode: string\n  activeFile: File\n}\n\nconst {addEditor} = useEditors()\n\nexport function useMonaco(target: Ref<HTMLElement | undefined>, options: UseMonacoOptions) {\n  const {activeFile, files, themeName} = options\n  const changeEventHook = createEventHook<ChangeEvent>()\n  const isSetup = ref(false)\n  const editorUpdateId = ref(0)\n  const editorStateCacheMap = ref<Map<string, MonacoEditor.ICodeEditorViewState | null>>(new Map())\n  const disposeEditor = ref<() => void>(() => {})\n  const loading = ref(false)\n  let editor: MonacoEditor.IStandaloneCodeEditor\n  const getEditor = () => editor\n\n  const init = async () => {\n    loading.value = true\n    const lifeCycle = unref(options.lifeCycle)\n\n    await lifeCycle?.beforeLoadMonaco?.()\n\n    const {monaco} = await setupMonaco(lifeCycle)\n    if (!monaco) return\n\n    await lifeCycle?.afterLoadMonaco?.(monaco)\n\n    monaco.editor.defineTheme('vitesse-dark', darkTheme as unknown as MonacoEditor.IStandaloneThemeData)\n    monaco.editor.defineTheme('vitesse-light', lightTheme as unknown as MonacoEditor.IStandaloneThemeData)\n\n    const defaultThemeMap = {\n      light: 'vitesse-light',\n      dark: 'vitesse-dark'\n    } as const\n    const getDefaultThemeName = () => defaultThemeMap[isDark.value ? 'dark' : 'light']\n    const getThemeName = () => unref(themeName) || getDefaultThemeName()\n\n    const {getModels, modelUpdateId} = useMonacoModels({\n      projectId: generateProjectId(),\n      files,\n      isSetup,\n      monaco,\n      getEditor,\n      editorUpdateId\n    })\n\n    watch(\n      target,\n      async () => {\n        const el = unref(target)\n        if (!el) return\n\n        await lifeCycle?.beforeCreateEditor?.(monaco)\n\n        const defaultEditorOptions: CreateEditorOptions = {\n          tabSize: 2,\n          insertSpaces: true,\n          autoClosingQuotes: 'always',\n          detectIndentation: false,\n          folding: true,\n          automaticLayout: true,\n          smoothScrolling: true,\n          theme: getThemeName(),\n          minimap: {\n            enabled: true\n          }\n        }\n\n        const editorOptions =\n          (await lifeCycle?.loadEditorOption?.(monaco, defaultEditorOptions)) || defaultEditorOptions\n\n        editor = monaco.editor.create(el, editorOptions) as MonacoEditor.IStandaloneCodeEditor\n\n        const _destroyEditor = addEditor(editor)\n        disposeEditor.value = async () => {\n          await lifeCycle?.beforeDestroyEditor?.(monaco, editor as any)\n          _destroyEditor()\n          await lifeCycle?.afterDestroyEditor?.(monaco)\n        }\n\n        isSetup.value = true\n        editorUpdateId.value++\n\n        await lifeCycle?.afterCreateEditor?.(monaco, editor as any)\n\n        // editor.value.onDidFocusEditorText(() => {\n        //   editor.value?.updateOptions({\n        //     scrollbar: {\n        //       handleMouseWheel: true\n        //     }\n        //   })\n        // })\n\n        // editor.value.onDidBlurEditorText(() => {\n        //   editor.value?.updateOptions({\n        //     scrollbar: {\n        //       handleMouseWheel: false\n        //     }\n        //   })\n        // })\n      },\n      {\n        immediate: true\n      }\n    )\n\n    watch(\n      [mustBeRef(activeFile), disposeEditor, modelUpdateId, editorStateCacheMap],\n      async () => {\n        const activeFileName = unref(activeFile)?.filename\n        const activeModel = getModels()?.find(model => model.uri.path.endsWith(activeFileName))\n\n        if (editor && activeModel && !activeModel.isDisposed() && editor.getModel() !== activeModel) {\n          editor.setModel(activeModel)\n          editor.onDidChangeModelContent(() => {\n            const value = editor!.getValue()\n            changeEventHook.trigger({\n              newCode: value,\n              activeFile: unref(activeFile)\n            })\n          })\n\n          const cacheState = editorStateCacheMap.value.get(activeFileName)\n          if (cacheState) editor.restoreViewState(cacheState)\n        }\n      },\n      {immediate: true}\n    )\n\n    watch(\n      () => unref(themeName),\n      () => {\n        // console.log('themeName', unref(themeName), getThemeName())\n        monaco.editor.setTheme(getThemeName())\n      }\n    )\n\n    // watch(isDark, () => monaco.editor.setTheme(isDark.value ? 'vitesse-dark' : 'vitesse-light'), {immediate: true})\n\n    loading.value = false\n  }\n\n  init()\n\n  tryOnScopeDispose(() => {\n    disposeEditor.value()\n  })\n\n  tryOnUnmounted(() => {\n    editorStateCacheMap.value = new Map()\n    disposeEditor.value()\n  })\n\n  return {\n    getEditor,\n    isDark,\n    loading,\n    toggleDark,\n    disposeEditor,\n    onChange: changeEventHook.on as EventHookOn<ChangeEvent>\n  }\n}\n","<script setup lang=\"ts\">\nimport {computed, inject, ref, VNode} from 'vue'\nimport {DEFAULT_FILE_NAME, IMPORT_JSON_NAME, SHOW_IMPORT_MAP_INJECT_KEY, STORE_INJECT_KEY} from '../constants'\n\nconst store = inject(STORE_INJECT_KEY)!\n\nconst pending = ref(false)\nconst pendingFilename = ref(DEFAULT_FILE_NAME)\nconst importMapFile = IMPORT_JSON_NAME\nconst showImportMap = inject(SHOW_IMPORT_MAP_INJECT_KEY)\nconst fileNames = computed(() =>\n  Object.entries(store.state.files)\n    .filter(([name, file]) => name !== importMapFile && !file.hidden)\n    .map(([name]) => name)\n)\n\nfunction startAddFile() {\n  pending.value = true\n}\n\nfunction cancelAddFile() {\n  pending.value = false\n}\n\nfunction focus({el}: VNode) {\n  ;(el as HTMLInputElement).focus()\n}\n\nfunction doneAddFile() {\n  const filename = pendingFilename.value\n  if (!pending.value) return\n  if (!/\\.(vue|js|ts|css|tsx|jsx)$/.test(filename)) {\n    store.state.errors = [`Playground only supports *.vue, *.js, *.ts, '*.jsx', '*.tsx', *.css files.`]\n    return\n  }\n\n  if (filename in store.state.files) {\n    store.state.errors = [`File \"${filename}\" already exists.`]\n    return\n  }\n\n  store.state.errors = []\n  cancelAddFile()\n  store.addFile(filename)\n  pendingFilename.value = DEFAULT_FILE_NAME\n}\n\nconst fileManagerBarRef = ref(null)\nfunction horizontalScroll(e: WheelEvent) {\n  e.preventDefault()\n  const el = fileManagerBarRef.value! as HTMLElement\n  const direction = Math.abs(e.deltaX) >= Math.abs(e.deltaY) ? e.deltaX : e.deltaY\n  const distance = 30 * (direction > 0 ? 1 : -1)\n  el.scrollTo({\n    left: el.scrollLeft + distance\n  })\n}\n</script>\n\n<template>\n  <div\n    ref=\"fileManagerBarRef\"\n    class=\"vue-playground-file-manager-bar\"\n    :class=\"{'vue-playground-file-manager-bar-has-import-map': showImportMap}\"\n    @wheel=\"horizontalScroll\"\n  >\n    <div\n      v-for=\"(fileName, i) in fileNames\"\n      :key=\"i\"\n      class=\"vue-playground-file-manager-bar-file\"\n      :class=\"{'vue-playground-file-manager-bar-file-active': store.state.activeFile.filename === fileName}\"\n      @click=\"store.setActive(fileName)\"\n    >\n      <span class=\"vue-playground-file-manager-bar-file-filename\">{{\n        fileName === importMapFile ? 'Import Map' : fileName\n      }}</span>\n      <span v-if=\"i > 0\" class=\"vue-playground-file-manager-bar-file-remove\" @click.stop=\"store.deleteFile(fileName)\">\n        <svg class=\"vue-playground-file-manager-bar-file-remove-icon\" width=\"12\" height=\"12\" viewBox=\"0 0 24 24\">\n          <line stroke=\"#999\" x1=\"18\" y1=\"6\" x2=\"6\" y2=\"18\"></line>\n          <line stroke=\"#999\" x1=\"6\" y1=\"6\" x2=\"18\" y2=\"18\"></line>\n        </svg>\n      </span>\n    </div>\n    <div v-if=\"pending\" class=\"vue-playground-file-manager-bar-pending\">\n      <input\n        v-model=\"pendingFilename\"\n        spellcheck=\"false\"\n        @blur=\"doneAddFile\"\n        @keyup.enter=\"doneAddFile\"\n        @keyup.esc=\"cancelAddFile\"\n        @vnodeMounted=\"focus\"\n      />\n    </div>\n\n    <div class=\"vue-playground-file-manager-bar-create-btn\" @click=\"startAddFile\">+</div>\n\n    <div v-if=\"showImportMap\" class=\"vue-playground-file-manager-bar-import-map-wrapper\">\n      <div\n        class=\"vue-playground-file-manager-bar-import-map\"\n        :class=\"{\n          'vue-playground-file-manager-bar-import-map-active': store.state.activeFile.filename === importMapFile\n        }\"\n        @click=\"store.setActive(importMapFile)\"\n      >\n        <span class=\"vue-playground-file-manager-bar-import-map-name\">Import Map</span>\n      </div>\n    </div>\n  </div>\n</template>\n\n<style scoped>\n.vue-playground-file-manager-bar {\n  position: relative;\n  box-sizing: border-box;\n  display: flex;\n  flex-shrink: 0;\n  width: 100%;\n  height: 40px;\n  overflow-x: auto;\n  overflow-y: hidden;\n  white-space: nowrap;\n  background-color: var(--file-manager-bg-color);\n  border-bottom: 1px solid var(--border-color);\n}\n\n.vue-playground-file-manager-bar::-webkit-scrollbar {\n  height: 1px;\n}\n\n.vue-playground-file-manager-bar::-webkit-scrollbar-track {\n  background-color: var(--border-color);\n}\n\n.vue-playground-file-manager-bar::-webkit-scrollbar-thumb {\n  background-color: var(--theme-color);\n}\n\n.vue-playground-file-manager-bar-has-import-map .vue-playground-file-manager-bar-create-btn {\n  margin-right: 10px;\n}\n\n.vue-playground-file-manager-bar-file,\n.vue-playground-file-manager-bar-import-map {\n  box-sizing: border-box;\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  padding: 0 8px;\n  margin: 2px 2px 0;\n  font-size: 12px;\n  font-weight: 600;\n  color: var(--file-manager-text-color);\n  cursor: pointer;\n  user-select: none;\n  background-color: var(--file-manager-bg-color);\n  border-bottom: 3px solid transparent;\n}\n\n.vue-playground-file-manager-bar-import-map {\n  height: 100%;\n}\n\n.vue-playground-file-manager-bar-file-active,\n.vue-playground-file-manager-bar-import-map-active {\n  color: var(--file-manager-active-text-color);\n  cursor: text;\n  background-color: var(--file-manager-active-bg-color);\n  border-bottom: 3px solid var(--file-manager-active-text-color);\n}\n\n.vue-playground-file-manager-bar-file span {\n  display: flex;\n  padding: 8px 10px 6px;\n  line-height: 20px;\n}\n\n.vue-playground-file-manager-bar-file-remove {\n  display: flex;\n  padding-left: 0;\n  line-height: 12px;\n  vertical-align: middle;\n  cursor: pointer;\n}\n\n.vue-playground-file-manager-bar-file-remove-icon {\n  margin-top: -1px;\n}\n\n.vue-playground-file-manager-bar-pending {\n  display: flex;\n  align-items: center;\n  justify-content: center;\n}\n\n.vue-playground-file-manager-bar-pending input {\n  width: 90px;\n  height: 30px;\n  padding: 0 0 0 10px;\n  margin-top: 2px;\n  margin-left: 6px;\n  font-size: 12px;\n  line-height: 30px;\n  color: var(--file-manager-active-text-color);\n  background-color: var(--file-manager-active-bg-color);\n  border: 1px solid var(--file-manager-active-text-color);\n  border-radius: 4px;\n  outline: none;\n}\n\n.vue-playground-file-manager-bar-create-btn {\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  margin-left: 6px;\n  font-size: 18px;\n  color: var(--file-manager-text-color);\n  cursor: pointer;\n}\n\n.vue-playground-file-manager-bar-create-btn:hover {\n  color: var(--file-manager-active-text-color);\n}\n\n.vue-playground-file-manager-bar-import-map-wrapper {\n  position: sticky;\n  top: 0;\n  right: 0;\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  padding: 0 15px;\n  margin-left: auto;\n  font-size: 12px;\n  color: var(--file-manager-text-color);\n  cursor: pointer;\n  background: var(--file-manager-right-float-bg);\n}\n</style>\n","<script lang=\"ts\">\nexport default defineComponent({\n  name: 'Message'\n})\n</script>\n<script setup lang=\"ts\">\nimport {defineComponent, ref, watch} from 'vue'\nimport type {CompilerError} from '@vue/compiler-sfc'\n\nconst props = defineProps({\n  err: null,\n  warn: null\n})\n\nconst dismissed = ref(false)\n\nwatch(\n  () => [props.err, props.warn],\n  () => {\n    dismissed.value = false\n  }\n)\n\nfunction formatMessage(err: string | Error): string {\n  if (typeof err === 'string') {\n    return err\n  } else {\n    let msg = err.message\n    const loc = (err as CompilerError).loc\n    if (loc && loc.start) {\n      msg = `(${loc.start.line}:${loc.start.column}) ` + msg\n    }\n    return msg\n  }\n}\n</script>\n\n<template>\n  <Transition name=\"fade\">\n    <div\n      v-if=\"!dismissed && (err || warn)\"\n      class=\"vue-playground-msg\"\n      :class=\"err ? 'vue-playground-msg-err' : 'vue-playground-msg-warn'\"\n    >\n      <pre>{{ formatMessage(err || warn) }}</pre>\n      <button class=\"vue-playground-dismiss\" @click=\"dismissed = true\">✕</button>\n    </div>\n  </Transition>\n</template>\n\n<style scoped>\n.vue-playground-msg {\n  position: absolute;\n  right: 8px;\n  bottom: 0;\n  z-index: 10;\n  width: 50%;\n  min-height: 40px;\n  margin-bottom: 8px;\n  overflow-x: hidden;\n  overflow-y: auto;\n  border: 1px solid transparent;\n  border-radius: 6px;\n}\n\n.vue-playground-msg pre {\n  padding: 12px 20px;\n  margin: 0;\n  white-space: normal;\n}\n\n.vue-playground-dismiss {\n  position: absolute;\n  top: 2px;\n  right: 2px;\n  display: block;\n  width: 18px;\n  height: 18px;\n  padding: 0;\n  font-size: 9px;\n  line-height: 18px;\n  color: var(--message-dismiss-text-color);\n  text-align: center;\n  cursor: pointer;\n  background-color: var(--message-dismiss-bg-color);\n  border: none;\n  border-radius: 9px;\n}\n\n@media (max-width: 720px) {\n  .vue-playground-dismiss {\n    top: -9px;\n    right: -9px;\n  }\n  .vue-playground-msg {\n    bottom: 50px;\n  }\n}\n\n.vue-playground-msg-err {\n  color: var(--message-error-text-color);\n  background-color: var(--message-error-bg-color);\n  border-color: var(--message-error-border-color);\n}\n\n.vue-playground-msg-warn {\n  color: var(--message-warn-text-color);\n  background-color: var(--message-warn-bg-color);\n  border-color: var(--message-warn-text-color);\n}\n\n.fade-enter-active,\n.fade-leave-active {\n  transition: all 0.15s ease-out;\n}\n.fade-enter-from,\n.fade-leave-to {\n  opacity: 0;\n  transform: translate(0, 10px);\n}\n</style>\n","<script lang=\"ts\">\nexport default defineComponent({\n  name: 'Editor'\n})\n</script>\n<script setup lang=\"ts\">\n/* eslint-disable @typescript-eslint/no-explicit-any */\nimport {ref, defineComponent, inject, computed, PropType, toRefs, unref} from 'vue'\nimport {debounce, File} from '../../core'\nimport {STORE_INJECT_KEY, THEME_INJECT_KEY} from '../constants'\nimport {useMonaco} from '../hooks/useMonaco'\nimport {EditorExpose, PlaygroundLifeCycle} from '../utils/types-helper'\nimport FileManagerBar from './file-manager-bar.vue'\nimport Message from './message.vue'\n\nconst props = defineProps({\n  lifeCycle: {\n    type: Object as PropType<PlaygroundLifeCycle>\n  }\n})\n\ninterface Emits {\n  (e: 'change', value: string): void\n}\n\nconst emit = defineEmits<Emits>()\n\nconst {lifeCycle} = toRefs(props)\nconst store = inject(STORE_INJECT_KEY)!\nconst theme = inject(THEME_INJECT_KEY)\n\nconst editorEl = ref<HTMLElement>()\nconst files = computed(() => Object.values(store.state.files))\nconst activeFile = computed(() => store.state.activeFile)\nconst themeName = computed(() => unref(theme)?.['--editor-theme-name'])\n\nconst {getEditor, onChange, disposeEditor, loading} = useMonaco(editorEl, {\n  themeName,\n  lifeCycle,\n  files,\n  activeFile\n})\n\nconst handleChange = debounce(({newCode, activeFile}: {newCode: string; activeFile: File}) => {\n  store.state.activeFile.code = newCode\n  lifeCycle?.value?.onCodeChange?.({\n    newCode,\n    activeFile\n  })\n  emit('change', newCode)\n}, 250)\n\ndefineExpose({\n  getEditor,\n  disposeEditor,\n  loading\n} as EditorExpose)\n\nonChange(handleChange)\n</script>\n\n<template>\n  <div class=\"vue-playground-editor\">\n    <FileManagerBar />\n    <div class=\"vue-playground-editor-container\">\n      <div ref=\"editorEl\" class=\"vue-playground-editor-monaco\"></div>\n      <Message :err=\"store.state.errors[0]\" />\n    </div>\n  </div>\n</template>\n\n<style scoped>\n.vue-playground-editor {\n  position: relative;\n  flex: 1;\n  width: 100%;\n  min-height: 320px;\n}\n\n.vue-playground-editor-container {\n  position: absolute;\n  top: 40px;\n  flex: 1;\n  width: 100%;\n  height: calc(100% - 40px);\n  overflow: hidden;\n}\n.vue-playground-editor-monaco {\n  top: 0;\n  width: 100%;\n  height: 100%;\n}\n</style>\n","<script lang=\"ts\">\nexport default defineComponent({\n  name: 'Loading'\n})\n</script>\n<script setup lang=\"ts\">\nimport {defineComponent} from 'vue'\nimport {LoadingIcon} from './icon'\n</script>\n<template>\n  <div class=\"vue-playground-loading\">\n    <LoadingIcon class=\"vue-playground-loading-icon\" />\n  </div>\n</template>\n<style scoped>\n.vue-playground-loading {\n  position: absolute;\n  top: 0;\n  left: 0;\n  z-index: 10;\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  width: 100%;\n  height: 100%;\n  color: var(--theme-color);\n  background-color: var(--bg-color);\n}\n.vue-playground-loading-icon {\n  width: 30%;\n  max-width: 40px;\n  height: 30%;\n  max-height: 40px;\n  animation: loadingCircle 1s infinite linear;\n}\n\n@keyframes loadingCircle {\n  to {\n    transform: rotate(360deg);\n  }\n}\n</style>\n","<script lang=\"ts\">\nexport default defineComponent({\n  name: 'Preview'\n})\n</script>\n<script setup lang=\"ts\">\nimport Message from './message.vue'\nimport Loading from './loading.vue'\nimport {\n  defineComponent,\n  ref,\n  onMounted,\n  onUnmounted,\n  watchEffect,\n  watch,\n  WatchStopHandle,\n  inject,\n  computed,\n  unref\n} from 'vue'\nimport {Preview} from '../../core/'\nimport {CLEAR_CONSOLE_INJECT_KEY, PKG_CDN_INJECT_KEY, STORE_INJECT_KEY, THEME_INJECT_KEY} from '../constants'\nimport {PreviewExpose} from '../utils/types-helper'\n\nconst store = inject(STORE_INJECT_KEY)!\nconst _clearConsole = inject(CLEAR_CONSOLE_INJECT_KEY, false)\nconst clearConsole = computed(() => unref(_clearConsole))\nconst theme = inject(THEME_INJECT_KEY)\nconst pkgCdn = inject(PKG_CDN_INJECT_KEY, {})\n\nconst containerRef = ref<HTMLElement>()\nconst runtimeError = ref()\nconst runtimeWarning = ref()\nconst sandboxUpdateId = ref(0)\nconst loading = ref(false)\n\nlet stopUpdateWatcher: WatchStopHandle | undefined\n\nconst preview = new Preview({\n  store: store!,\n  pkgCdn: unref(pkgCdn),\n  onBeforeDestroy() {\n    stopUpdateWatcher?.()\n  },\n  onBeforeLoad() {\n    loading.value = true\n  },\n  onLoad() {\n    stopUpdateWatcher = watchEffect(() => {\n      if (import.meta.env.PROD && clearConsole.value) {\n        console.clear()\n      }\n      preview.updateSandbox()\n      loading.value = false\n      sandboxUpdateId.value++\n    })\n  },\n  onError(err) {\n    runtimeError.value = err\n  },\n  onWarning(warn) {\n    runtimeWarning.value = warn\n  }\n})\n\nconst createSandbox = () => {\n  if (!containerRef.value) return\n  preview.createSandbox(containerRef.value)\n}\n\n// create sandbox on mount\nonMounted(() => {\n  createSandbox()\n})\n\n// reset sandbox when import map changes\nwatch(\n  () => store.state.files['import-map.json'].code,\n  raw => {\n    try {\n      const map = JSON.parse(raw)\n      if (!map.imports) return (store.state.errors = [`import-map.json is missing \"imports\" field.`])\n      createSandbox()\n    } catch (e: unknown) {\n      store.state.errors = [e as Error]\n      return\n    }\n  }\n)\n\n// reset sandbox when version changes\nwatch(\n  () => store.state.vueRuntimeURL,\n  () => createSandbox()\n)\n\nwatch(\n  () => [sandboxUpdateId.value, unref(theme)],\n  () => {\n    if (!preview.sandboxEl?.contentDocument?.documentElement) return\n    const cssVars = unref(theme)\n    const iframeDocument = preview.sandboxEl.contentDocument\n\n    Object.assign(iframeDocument.body.style, {\n      ...cssVars,\n      color: cssVars?.['--preview-text-color'] || '#000',\n      backgroundColor: cssVars?.['--preview-bg-color'] || '#fff'\n    })\n  },\n  {\n    deep: true,\n    immediate: true\n  }\n)\n\nonUnmounted(() => {\n  preview.destroy()\n})\n\ndefineExpose({\n  containerRef,\n  sandboxIframe: preview.sandboxEl,\n  loading\n} as PreviewExpose)\n</script>\n\n<template>\n  <div class=\"vue-playground-preview\">\n    <div ref=\"containerRef\" class=\"vue-playground-preview-iframe-container\"></div>\n    <Message :err=\"runtimeError\" />\n    <Message v-if=\"!runtimeError\" :warn=\"runtimeWarning\" />\n    <Loading v-if=\"loading\" />\n  </div>\n</template>\n\n<style scoped>\n.vue-playground-preview {\n  position: relative;\n  box-sizing: border-box;\n  flex: 1;\n  width: 100%;\n  overflow: hidden;\n}\n.vue-playground-preview-iframe-container,\n.vue-playground-preview-iframe-container :deep(iframe) {\n  width: 100%;\n  height: 100%;\n  min-height: 300px;\n  color: var(--preview-text-color);\n  background-color: var(--preview-bg-color);\n  border: none;\n}\n</style>\n","/* eslint-disable @typescript-eslint/no-explicit-any */\nimport {defineComponent, h, Teleport} from 'vue'\n\nconst vm = defineComponent({\n  name: 'Portal',\n  props: {\n    to: {\n      type: String\n    }\n  },\n  render() {\n    const {to} = this\n    if (!to) return this.$slots.default?.()\n    return h(\n      Teleport as any,\n      {\n        to\n      },\n      this.$slots.default?.()\n    )\n  }\n})\n\nexport default vm\n","import type {PropType, ExtractPropTypes} from 'vue'\nimport type {File, ImportMap} from '../core'\nimport {DEFAULT_TITLE} from './constants'\nimport type {PlaygroundLifeCycle, PlaygroundPkgCdn, PlaygroundThemes} from './utils/types-helper'\n\nexport const playgroundProps = () =>\n  ({\n    title: {\n      type: String,\n      default: DEFAULT_TITLE\n    },\n    files: {\n      type: Array as PropType<File[]>,\n      default: () => []\n    },\n    lifeCycle: {\n      type: Object as PropType<PlaygroundLifeCycle>,\n      default: () => ({})\n    },\n    themes: {\n      type: Object as PropType<PlaygroundThemes>,\n      default: () => ({})\n    },\n    importMap: {\n      type: Object as PropType<ImportMap>,\n      default: () => ({})\n    },\n    pkgCdn: {\n      type: Object as PropType<PlaygroundPkgCdn>,\n      default: () => ({})\n    }\n  } as const)\n\nexport type PlaygroundProps = Readonly<ExtractPropTypes<ReturnType<typeof playgroundProps>>>\n","<script lang=\"ts\">\nexport default defineComponent({\n  name: PLAYGROUND_COMPONENT_NAME\n})\n</script>\n<script lang=\"ts\" setup>\nimport {computed, CSSProperties, defineComponent, inject, onMounted, provide, ref, unref, watch} from 'vue'\nimport {ReplStore} from '../core'\nimport Toolbar from './components/toolbar.vue'\nimport Editor from './components/editor.vue'\nimport Preview from './components/preview.vue'\nimport Loading from './components/loading.vue'\nimport Portal from './components/portal'\nimport {\n  GET_DARK_THEME,\n  GET_LIGHT_THEME,\n  PLAYGROUND_COMPONENT_NAME,\n  SHOW_DARK_MODE_INJECT_KEY,\n  SHOW_IMPORT_MAP_INJECT_KEY,\n  STORE_INJECT_KEY,\n  THEME_INJECT_KEY\n} from './constants'\nimport {EditorExpose, LayoutDirection, PlaygroundExpose, PlaygroundTheme, PreviewExpose} from './utils/types-helper'\nimport {isDark, toggleDark} from './hooks'\nimport {playgroundProps} from './playground.type'\n\nconst props = defineProps(playgroundProps())\n\nconst previewRef = ref<PreviewExpose>()\nconst editorRef = ref<EditorExpose>()\n\nconst store = new ReplStore({\n  initFiles: props.files,\n  initImportMap: props.importMap,\n  pkgCdn: props.pkgCdn\n})\n\nconst showDarkMode = inject(SHOW_DARK_MODE_INJECT_KEY, undefined)\nconst showCode = ref(true)\nconst fullScreen = ref(false)\nconst layoutDirection = ref<LayoutDirection>('EditorBottomPreviewTop')\n\nconst contentStyle = computed<CSSProperties>(() => {\n  const directionStyleMap: Record<LayoutDirection, CSSProperties> = {\n    EditorBottomPreviewTop: {\n      flexDirection: 'column'\n    },\n    EditorRightPreviewLeft: {\n      flexDirection: 'row'\n    },\n    EditorTopPreviewBottom: {\n      flexDirection: 'column-reverse'\n    },\n    EditorLeftPreviewRight: {\n      flexDirection: 'row-reverse'\n    }\n  }\n\n  return {\n    ...directionStyleMap[layoutDirection.value]\n  }\n})\n\nconst theme = computed<CSSProperties>(() => {\n  const lightTheme: PlaygroundTheme = GET_LIGHT_THEME(props?.themes?.light)\n  const darkTheme: PlaygroundTheme = GET_DARK_THEME(props?.themes?.dark)\n  return isDark.value ? darkTheme : lightTheme\n})\n\nwatch(\n  isDark,\n  val => {\n    props?.lifeCycle?.onDarkModeChange?.(val)\n  },\n  {\n    immediate: true\n  }\n)\n\nwatch(\n  () => unref(showDarkMode),\n  val => {\n    if (val !== null && val !== undefined) toggleDark(val)\n  },\n  {\n    immediate: true\n  }\n)\n\nprovide(STORE_INJECT_KEY, store)\nprovide(SHOW_IMPORT_MAP_INJECT_KEY, true)\nprovide(THEME_INJECT_KEY, theme)\nonMounted(() => {\n  console.log('onMounted', store)\n})\n\ndefineExpose({\n  store,\n  preview: previewRef,\n  editor: editorRef,\n  isDark,\n  toggleDark\n} as PlaygroundExpose)\n</script>\n<template>\n  <Portal :to=\"fullScreen ? 'body' : undefined\">\n    <div\n      class=\"vue-playground\"\n      :class=\"{\n        'vue-playground-fullscreen': fullScreen\n      }\"\n      :style=\"theme\"\n    >\n      <Toolbar\n        v-model:showCode=\"showCode\"\n        v-model:fullScreen=\"fullScreen\"\n        v-model:layoutDirection=\"layoutDirection\"\n        v-model:showDark=\"isDark\"\n        :title=\"title\"\n      ></Toolbar>\n      <div class=\"vue-playground-content\" :style=\"contentStyle\">\n        <Preview\n          ref=\"previewRef\"\n          :style=\"{\n            borderTop: layoutDirection === 'EditorTopPreviewBottom' ? '1px solid var(--border-color)' : 'none',\n            borderRight: layoutDirection === 'EditorRightPreviewLeft' ? '1px solid var(--border-color)' : 'none'\n          }\"\n        ></Preview>\n        <Editor\n          v-show=\"showCode\"\n          ref=\"editorRef\"\n          :life-cycle=\"lifeCycle\"\n          :style=\"{\n            borderTop: layoutDirection === 'EditorBottomPreviewTop' ? '1px solid var(--border-color)' : 'none',\n            borderRight: layoutDirection === 'EditorLeftPreviewRight' ? '1px solid var(--border-color)' : 'none'\n          }\"\n        ></Editor>\n      </div>\n      <Loading v-if=\"!editorRef || editorRef.loading\" />\n    </div>\n  </Portal>\n</template>\n<style scoped>\n.vue-playground {\n  position: relative;\n  display: flex;\n  flex-direction: column;\n  width: 100%;\n  overflow: hidden;\n  background-color: var(--bg-color);\n  border: 1px solid var(--border-color);\n  border-radius: 8px;\n}\n\n.vue-playground.vue-playground-fullscreen {\n  position: fixed;\n  top: 0;\n  left: 0;\n  z-index: 99999;\n  width: 100%;\n  height: 100%;\n  overscroll-behavior: none;\n  border: none;\n  border-radius: 0;\n  -ms-scroll-chaining: none;\n}\n\n.vue-playground-content {\n  display: flex;\n  width: 100%;\n  height: 100%;\n}\n</style>\n","export * from './playground'\nexport * from './core/store'\nexport * from './core/utils/types-helper'\n\nexport default {}\n"],"names":["Preview","Babel.registerPlugin","Babel.transform","base64Js.encode","base64Js.decode","defaultCompiler","version","reactive","watchEffect","__default__","defineComponent","createComponent","name","render","props","$props","$attrs","EditorLeftPreviewRightIcon","_createVNode","_mergeProps","EditorTopPreviewBottomIcon","transform","EditorRightPreviewLeftIcon","EditorBottomPreviewTopIcon","FullscreenIcon","ExitFullscreenIcon","ShowCodeIcon","HideCodeIcon","LightIcon","DarkIcon","LoadingIcon","getCurrentScope","onScopeDispose","ref","getCurrentInstance","onBeforeMount","nextTick","onMounted","onUnmounted","isRef","unref","watch","shallowRef","pausableWatch","computed","inject","toRefs","h","Teleport","provide"],"mappings":"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;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;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"}