@waline/client 2.5.1 → 2.6.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/component.esm.js +1 -1
- package/dist/component.esm.js.map +1 -1
- package/dist/component.js +1 -1
- package/dist/component.js.map +1 -1
- package/dist/legacy.d.ts +41 -0
- package/dist/legacy.js +1 -1
- package/dist/legacy.js.map +1 -1
- package/dist/pageview.cjs.js +1 -1
- package/dist/pageview.cjs.js.map +1 -1
- package/dist/pageview.esm.js +1 -1
- package/dist/pageview.esm.js.map +1 -1
- package/dist/pageview.js +1 -1
- package/dist/pageview.js.map +1 -1
- package/dist/shim.d.ts +42 -1
- package/dist/shim.esm.d.ts +42 -1
- package/dist/shim.esm.js +1 -1
- package/dist/shim.esm.js.map +1 -1
- package/dist/shim.js +1 -1
- package/dist/shim.js.map +1 -1
- package/dist/waline.cjs.d.ts +42 -1
- package/dist/waline.cjs.js +1 -1
- package/dist/waline.cjs.js.map +1 -1
- package/dist/waline.css +1 -1
- package/dist/waline.css.map +1 -1
- package/dist/waline.d.ts +42 -1
- package/dist/waline.esm.d.ts +42 -1
- package/dist/waline.esm.js +1 -1
- package/dist/waline.esm.js.map +1 -1
- package/dist/waline.js +1 -1
- package/dist/waline.js.map +1 -1
- package/package.json +31 -32
- package/src/comment.ts +7 -2
- package/src/components/CommentBox.vue +88 -71
- package/src/components/CommentCard.vue +19 -17
- package/src/components/ImageWall.vue +34 -22
- package/src/composables/userInfo.ts +1 -1
- package/src/config/default.ts +93 -1
- package/src/config/i18n/en.ts +1 -0
- package/src/config/i18n/generate.ts +1 -0
- package/src/config/i18n/jp.ts +1 -0
- package/src/config/i18n/pt-BR.ts +1 -0
- package/src/config/i18n/ru.ts +1 -0
- package/src/config/i18n/vi-VN.ts +1 -0
- package/src/config/i18n/zh-CN.ts +1 -0
- package/src/config/i18n/zh-TW.ts +3 -2
- package/src/init.ts +0 -4
- package/src/pageview.ts +7 -2
- package/src/styles/emoji.scss +23 -0
- package/src/styles/gif.scss +6 -5
- package/src/typings/base.ts +40 -0
- package/src/typings/locale.ts +1 -0
- package/src/typings/waline.ts +8 -0
- package/src/utils/config.ts +5 -2
- package/src/utils/fetch.ts +3 -0
- package/src/utils/index.ts +0 -2
- package/src/utils/markedMathExtension.ts +1 -0
- package/LICENSE +0 -339
- package/src/utils/fetchGif.ts +0 -63
- package/src/utils/throttle.ts +0 -15
package/dist/waline.esm.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"waline.esm.js","sources":["../src/config/default.ts","../src/config/highlighter.ts","../src/config/i18n/generate.ts","../src/config/i18n/en.ts","../src/config/i18n/jp.ts","../src/config/i18n/zh-CN.ts","../src/config/i18n/zh-TW.ts","../src/config/i18n/pt-BR.ts","../src/config/i18n/ru.ts","../src/config/i18n/index.ts","../../../node_modules/.pnpm/@vue+shared@3.2.35/node_modules/@vue/shared/dist/shared.esm-bundler.js","../../../node_modules/.pnpm/@vue+reactivity@3.2.35/node_modules/@vue/reactivity/dist/reactivity.esm-bundler.js","../../../node_modules/.pnpm/@vue+runtime-core@3.2.35/node_modules/@vue/runtime-core/dist/runtime-core.esm-bundler.js","../../../node_modules/.pnpm/@vue+runtime-dom@3.2.35/node_modules/@vue/runtime-dom/dist/runtime-dom.esm-bundler.js","../../../node_modules/.pnpm/@vueuse+shared@8.5.0_vue@3.2.35/node_modules/@vueuse/shared/index.mjs","../../../node_modules/.pnpm/@vueuse+core@8.5.0_vue@3.2.35/node_modules/@vueuse/core/index.mjs","../src/composables/inputs.ts","../src/utils/path.ts","../src/utils/config.ts","../src/utils/darkmode.ts","../src/utils/date.ts","../src/utils/emoji.ts","../src/utils/error.ts","../src/utils/fetch.ts","../src/utils/getRoot.ts","../src/utils/image.ts","../../../node_modules/.pnpm/marked@4.0.16/node_modules/marked/lib/marked.esm.js","../src/utils/markedMathExtension.ts","../src/utils/markdown.ts","../src/utils/query.ts","../src/utils/fetchGif.ts","../src/composables/userInfo.ts","../src/composables/like.ts","../src/comment.ts","../../../node_modules/.pnpm/autosize@5.0.1/node_modules/autosize/dist/autosize.esm.js","../plugin-vue:export-helper","../src/components/ImageWall.vue","../src/components/Icons.ts","../src/components/CommentBox.vue","../src/utils/throttle.ts","../src/utils/wordCount.ts","../src/components/CommentCard.vue","../src/composables/timeAgo.ts","../src/components/Waline.vue","../src/pageview.ts","../src/init.ts","../src/version.ts","../src/widgets/recentComments.ts"],"sourcesContent":["import type { WalineMeta } from '../typings';\n\nconst availableMeta: WalineMeta[] = ['nick', 'mail', 'link'];\n\nexport const getMeta = (meta: WalineMeta[]): WalineMeta[] =>\n meta.filter((item) => availableMeta.includes(item));\n\nexport const defaultLang = 'zh-CN';\n\nexport const defaultUploadImage = (file: File): Promise<string> =>\n new Promise((resolve, reject) => {\n const reader = new FileReader();\n reader.readAsDataURL(file);\n reader.onload = (): void => resolve(reader.result?.toString() || '');\n reader.onerror = reject;\n });\n\nexport const defaultTexRenderer = (blockMode: boolean): string =>\n blockMode === true\n ? '<p class=\"wl-tex\">Tex is not available in preview</p>'\n : '<span class=\"wl-tex\">Tex is not available in preview</span>';\n","/**\n * The MIT License (MIT)\n *\n * Copyright (c) egoist <0x142857@gmail.com> (https://egoistian.com)\n *\n * Permission is hereby granted, free of charge, to any person obtaining a copy\n * of this software and associated documentation files (the \"Software\"), to deal\n * in the Software without restriction, including without limitation the rights\n * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n * copies of the Software, and to permit persons to whom the Software is\n * furnished to do so, subject to the following conditions:\n *\n * The above copyright notice and this permission notice shall be included in\n * all copies or substantial portions of the Software.\n *\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n * THE SOFTWARE.\n *\n */\n\nconst WORD_REGEXP =\n /[\\u4E00-\\u9FFF\\u3400-\\u4dbf\\uf900-\\ufaff\\u3040-\\u309f\\uac00-\\ud7af\\u0400-\\u04FF]+|\\w+/;\nconst LEFT_ANGLE_REGEXP = /</;\nconst LINE_COMMENT_REGEXP = /(?:^|\\s)\\/\\/(.+?)$/gm;\nconst BLOCK_COMMENT_REGEXP = /\\/\\*([\\S\\s]*?)\\*\\//gm;\nconst REGEXP = new RegExp(\n `(${WORD_REGEXP.source}|${LEFT_ANGLE_REGEXP.source})|((?:${LINE_COMMENT_REGEXP.source})|(?:${BLOCK_COMMENT_REGEXP.source}))`,\n 'gmi'\n);\n\nconst COLORS = [\n '23AC69',\n '91C132',\n 'F19726',\n 'E8552D',\n '1AAB8E',\n 'E1147F',\n '2980C1',\n '1BA1E6',\n '9FA0A0',\n 'F19726',\n 'E30B20',\n 'E30B20',\n 'A3338B',\n];\nconst cache: Record<string, string> = {};\n\nexport const defaultHighlighter = (input: string): string => {\n let index = 0;\n\n return input.replace(REGEXP, (_match, word: string, comment: string) => {\n if (comment) return `<span style=\"color: slategray\">${comment}</span>`;\n if (word === '<') return '<';\n\n let color: string;\n\n if (cache[word]) color = cache[word];\n else {\n color = COLORS[index];\n cache[word] = color;\n }\n\n const out = `<span style=\"color: #${color}\">${word}</span>`;\n\n index = ++index % COLORS.length;\n\n return out;\n });\n};\n","import type { WalineLocale } from '../../typings';\n\nconst localeKeys = [\n 'nick',\n 'nickError',\n 'mail',\n 'mailError',\n 'link',\n 'optional',\n 'placeholder',\n 'sofa',\n 'submit',\n 'like',\n 'cancelLike',\n 'reply',\n 'cancelReply',\n 'comment',\n 'refresh',\n 'more',\n 'preview',\n 'emoji',\n 'uploadImage',\n 'seconds',\n 'minutes',\n 'hours',\n 'days',\n 'now',\n 'uploading',\n 'login',\n 'logout',\n 'admin',\n 'sticky',\n 'word',\n 'wordHint',\n 'anonymous',\n 'level0',\n 'level1',\n 'level2',\n 'level3',\n 'level4',\n 'level5',\n 'gif',\n 'gifSearchPlaceholder',\n];\n\nexport const generateLocale = (locale: string[]): WalineLocale =>\n Object.fromEntries(\n locale.map((item, index) => [localeKeys[index], item])\n ) as unknown as WalineLocale;\n","import { generateLocale } from './generate';\n\nexport default generateLocale([\n 'NickName',\n 'NickName cannot be less than 3 bytes.',\n 'E-Mail',\n 'Please confirm your email address.',\n 'Website',\n 'Optional',\n 'Comment here...',\n 'No comment yet.',\n 'Submit',\n 'Like',\n 'Cancel like',\n 'Reply',\n 'Cancel reply',\n 'Comments',\n 'Refresh',\n 'Load More...',\n 'Preview',\n 'Emoji',\n 'Upload Image',\n 'seconds ago',\n 'minutes ago',\n 'hours ago',\n 'days ago',\n 'just now',\n 'Uploading',\n 'Login',\n 'logout',\n 'Admin',\n 'Sticky',\n 'Words',\n 'Please input comments between $0 and $1 words!\\n Current word number: $2',\n 'Anonymous',\n 'Dwarves',\n 'Hobbits',\n 'Ents',\n 'Wizards',\n 'Elves',\n 'Maiar',\n 'GIF',\n 'Search GIF',\n]);\n","import { generateLocale } from './generate';\n\nexport default generateLocale([\n 'ニックネーム',\n '3バイト以上のニックネームをご入力ください.',\n 'メールアドレス',\n 'メールアドレスをご確認ください.',\n 'サイト',\n 'オプション',\n 'ここにコメント',\n 'コメントしましょう~',\n '提出する',\n 'Like',\n 'Cancel like',\n '返信する',\n 'キャンセル',\n 'コメント',\n '更新',\n 'さらに読み込む',\n 'プレビュー',\n '絵文字',\n '画像をアップロード',\n '秒前',\n '分前',\n '時間前',\n '日前',\n 'たっだ今',\n 'アップロード',\n 'ログインする',\n 'ログアウト',\n '管理者',\n 'トップに置く',\n 'ワード',\n 'コメントは $0 から $1 ワードの間でなければなりません!\\n 現在の単語番号: $2',\n '匿名',\n 'うえにん',\n 'なかにん',\n 'しもおし',\n '特にしもおし',\n 'かげ',\n 'なぬし',\n 'GIF',\n '探す GIF',\n]);\n","import { generateLocale } from './generate';\n\nexport default generateLocale([\n '昵称',\n '昵称不能少于3个字符',\n '邮箱',\n '请填写正确的邮件地址',\n '网址',\n '可选',\n '欢迎评论',\n '来发评论吧~',\n '提交',\n '喜欢',\n '取消喜欢',\n '回复',\n '取消回复',\n '评论',\n '刷新',\n '加载更多...',\n '预览',\n '表情',\n '上传图片',\n '秒前',\n '分钟前',\n '小时前',\n '天前',\n '刚刚',\n '正在上传',\n '登录',\n '退出',\n '博主',\n '置顶',\n '字',\n '评论字数应在 $0 到 $1 字之间!\\n当前字数:$2',\n '匿名',\n '潜水',\n '冒泡',\n '吐槽',\n '活跃',\n '话痨',\n '传说',\n '表情包',\n '搜索表情包',\n]);\n","import { generateLocale } from './generate';\n\nexport default generateLocale([\n '暱稱',\n '郵箱',\n '網址',\n '可選',\n '暱稱不能少於3個字元',\n '請填寫正確的郵件地址',\n '歡迎評論',\n '來發評論吧~',\n '提交',\n '喜歡',\n '取消喜歡',\n '回覆',\n '取消回覆',\n '評論',\n '刷新',\n '載入更多...',\n '預覽',\n '表情',\n '上傳圖片',\n '秒前',\n '分鐘前',\n '小時前',\n '天前',\n '剛剛',\n '正在上傳',\n '登錄',\n '退出',\n '博主',\n '置頂',\n '字',\n '評論字數應在 $0 到 $1 字之間!\\n當前字數:$2',\n '匿名',\n '潛水',\n '冒泡',\n '吐槽',\n '活躍',\n '話癆',\n '傳說',\n '表情包',\n '搜索表情包',\n]);\n","import { generateLocale } from './generate';\n\nexport default generateLocale([\n 'Apelido',\n 'Apelido não pode ser menor que 3 bytes.',\n 'E-Mail',\n 'Por favor, confirme seu endereço de e-mail.',\n 'Website',\n 'Opcional',\n 'Comente aqui...',\n 'Nenhum comentário, ainda.',\n 'Enviar',\n 'Like',\n 'Cancel like',\n 'Responder',\n 'Cancelar resposta',\n 'Comentários',\n 'Refrescar',\n 'Carregar Mais...',\n 'Visualizar',\n 'Emoji',\n 'Enviar Imagem',\n 'segundos atrás',\n 'minutos atrás',\n 'horas atrás',\n 'dias atrás',\n 'agora mesmo',\n 'Enviando',\n 'Entrar',\n 'Sair',\n 'Admin',\n 'Sticky',\n 'Palavras',\n 'Favor enviar comentário com $0 a $1 palavras!\\n Número de palavras atuais: $2',\n 'Anônimo',\n 'Dwarves',\n 'Hobbits',\n 'Ents',\n 'Wizards',\n 'Elves',\n 'Maiar',\n 'GIF',\n 'Pesquisar GIF',\n]);\n","import { generateLocale } from './generate';\n\nexport default generateLocale([\n 'Псевдоним',\n 'Никнейм не может быть меньше 3 байт.',\n 'Эл. адрес',\n 'Пожалуйста, подтвердите адрес вашей электронной почты.',\n 'Веб-сайт',\n 'Необязательный',\n 'Комментарий здесь...',\n 'Пока нет комментариев.',\n 'Отправить',\n 'Like',\n 'Cancel like',\n 'Отвечать',\n 'Отменить ответ',\n 'Комментарии',\n 'Обновить',\n 'Загрузи больше...',\n 'Превью',\n 'эмодзи',\n 'Загрузить изображение',\n 'секунд назад',\n 'несколько минут назад',\n 'несколько часов назад',\n 'дней назад',\n 'прямо сейчас',\n 'Загрузка',\n 'Авторизоваться',\n 'Выход из системы',\n 'Админ',\n 'Липкий',\n 'Слова',\n 'Пожалуйста, введите комментарии от $0 до $1 слов!\\nНомер текущего слова: $2',\n 'Анонимный',\n 'Dwarves',\n 'Hobbits',\n 'Ents',\n 'Wizards',\n 'Elves',\n 'Maiar',\n 'GIF',\n 'Поиск GIF',\n]);\n","/* eslint-disable @typescript-eslint/naming-convention */\nimport en from './en';\nimport jp from './jp';\nimport zhCN from './zh-CN';\nimport zhTW from './zh-TW';\nimport ptBR from './pt-BR';\nimport ru from './ru';\n\nimport type { WalineLocale } from '../../typings';\n\nexport type Locales = Record<string, WalineLocale>;\n\nexport const defaultLocales: Locales = {\n zh: zhCN,\n 'zh-cn': zhCN,\n 'zh-CN': zhCN,\n 'zh-tw': zhTW,\n 'zh-TW': zhTW,\n en: en,\n 'en-US': en,\n 'en-us': en,\n jp: jp,\n 'jp-jp': jp,\n 'jp-JP': jp,\n 'pt-br': ptBR,\n 'pt-BR': ptBR,\n ru: ru,\n 'ru-ru': ru,\n 'ru-RU': ru,\n};\n","/**\r\n * Make a map and return a function for checking if a key\r\n * is in that map.\r\n * IMPORTANT: all calls of this function must be prefixed with\r\n * \\/\\*#\\_\\_PURE\\_\\_\\*\\/\r\n * So that rollup can tree-shake them if necessary.\r\n */\r\nfunction makeMap(str, expectsLowerCase) {\r\n const map = Object.create(null);\r\n const list = str.split(',');\r\n for (let i = 0; i < list.length; i++) {\r\n map[list[i]] = true;\r\n }\r\n return expectsLowerCase ? val => !!map[val.toLowerCase()] : val => !!map[val];\r\n}\n\n/**\r\n * dev only flag -> name mapping\r\n */\r\nconst PatchFlagNames = {\r\n [1 /* TEXT */]: `TEXT`,\r\n [2 /* CLASS */]: `CLASS`,\r\n [4 /* STYLE */]: `STYLE`,\r\n [8 /* PROPS */]: `PROPS`,\r\n [16 /* FULL_PROPS */]: `FULL_PROPS`,\r\n [32 /* HYDRATE_EVENTS */]: `HYDRATE_EVENTS`,\r\n [64 /* STABLE_FRAGMENT */]: `STABLE_FRAGMENT`,\r\n [128 /* KEYED_FRAGMENT */]: `KEYED_FRAGMENT`,\r\n [256 /* UNKEYED_FRAGMENT */]: `UNKEYED_FRAGMENT`,\r\n [512 /* NEED_PATCH */]: `NEED_PATCH`,\r\n [1024 /* DYNAMIC_SLOTS */]: `DYNAMIC_SLOTS`,\r\n [2048 /* DEV_ROOT_FRAGMENT */]: `DEV_ROOT_FRAGMENT`,\r\n [-1 /* HOISTED */]: `HOISTED`,\r\n [-2 /* BAIL */]: `BAIL`\r\n};\n\n/**\r\n * Dev only\r\n */\r\nconst slotFlagsText = {\r\n [1 /* STABLE */]: 'STABLE',\r\n [2 /* DYNAMIC */]: 'DYNAMIC',\r\n [3 /* FORWARDED */]: 'FORWARDED'\r\n};\n\nconst GLOBALS_WHITE_LISTED = 'Infinity,undefined,NaN,isFinite,isNaN,parseFloat,parseInt,decodeURI,' +\r\n 'decodeURIComponent,encodeURI,encodeURIComponent,Math,Number,Date,Array,' +\r\n 'Object,Boolean,String,RegExp,Map,Set,JSON,Intl,BigInt';\r\nconst isGloballyWhitelisted = /*#__PURE__*/ makeMap(GLOBALS_WHITE_LISTED);\n\nconst range = 2;\r\nfunction generateCodeFrame(source, start = 0, end = source.length) {\r\n // Split the content into individual lines but capture the newline sequence\r\n // that separated each line. This is important because the actual sequence is\r\n // needed to properly take into account the full line length for offset\r\n // comparison\r\n let lines = source.split(/(\\r?\\n)/);\r\n // Separate the lines and newline sequences into separate arrays for easier referencing\r\n const newlineSequences = lines.filter((_, idx) => idx % 2 === 1);\r\n lines = lines.filter((_, idx) => idx % 2 === 0);\r\n let count = 0;\r\n const res = [];\r\n for (let i = 0; i < lines.length; i++) {\r\n count +=\r\n lines[i].length +\r\n ((newlineSequences[i] && newlineSequences[i].length) || 0);\r\n if (count >= start) {\r\n for (let j = i - range; j <= i + range || end > count; j++) {\r\n if (j < 0 || j >= lines.length)\r\n continue;\r\n const line = j + 1;\r\n res.push(`${line}${' '.repeat(Math.max(3 - String(line).length, 0))}| ${lines[j]}`);\r\n const lineLength = lines[j].length;\r\n const newLineSeqLength = (newlineSequences[j] && newlineSequences[j].length) || 0;\r\n if (j === i) {\r\n // push underline\r\n const pad = start - (count - (lineLength + newLineSeqLength));\r\n const length = Math.max(1, end > count ? lineLength - pad : end - start);\r\n res.push(` | ` + ' '.repeat(pad) + '^'.repeat(length));\r\n }\r\n else if (j > i) {\r\n if (end > count) {\r\n const length = Math.max(Math.min(end - count, lineLength), 1);\r\n res.push(` | ` + '^'.repeat(length));\r\n }\r\n count += lineLength + newLineSeqLength;\r\n }\r\n }\r\n break;\r\n }\r\n }\r\n return res.join('\\n');\r\n}\n\n/**\r\n * On the client we only need to offer special cases for boolean attributes that\r\n * have different names from their corresponding dom properties:\r\n * - itemscope -> N/A\r\n * - allowfullscreen -> allowFullscreen\r\n * - formnovalidate -> formNoValidate\r\n * - ismap -> isMap\r\n * - nomodule -> noModule\r\n * - novalidate -> noValidate\r\n * - readonly -> readOnly\r\n */\r\nconst specialBooleanAttrs = `itemscope,allowfullscreen,formnovalidate,ismap,nomodule,novalidate,readonly`;\r\nconst isSpecialBooleanAttr = /*#__PURE__*/ makeMap(specialBooleanAttrs);\r\n/**\r\n * The full list is needed during SSR to produce the correct initial markup.\r\n */\r\nconst isBooleanAttr = /*#__PURE__*/ makeMap(specialBooleanAttrs +\r\n `,async,autofocus,autoplay,controls,default,defer,disabled,hidden,` +\r\n `loop,open,required,reversed,scoped,seamless,` +\r\n `checked,muted,multiple,selected`);\r\n/**\r\n * Boolean attributes should be included if the value is truthy or ''.\r\n * e.g. `<select multiple>` compiles to `{ multiple: '' }`\r\n */\r\nfunction includeBooleanAttr(value) {\r\n return !!value || value === '';\r\n}\r\nconst unsafeAttrCharRE = /[>/=\"'\\u0009\\u000a\\u000c\\u0020]/;\r\nconst attrValidationCache = {};\r\nfunction isSSRSafeAttrName(name) {\r\n if (attrValidationCache.hasOwnProperty(name)) {\r\n return attrValidationCache[name];\r\n }\r\n const isUnsafe = unsafeAttrCharRE.test(name);\r\n if (isUnsafe) {\r\n console.error(`unsafe attribute name: ${name}`);\r\n }\r\n return (attrValidationCache[name] = !isUnsafe);\r\n}\r\nconst propsToAttrMap = {\r\n acceptCharset: 'accept-charset',\r\n className: 'class',\r\n htmlFor: 'for',\r\n httpEquiv: 'http-equiv'\r\n};\r\n/**\r\n * CSS properties that accept plain numbers\r\n */\r\nconst isNoUnitNumericStyleProp = /*#__PURE__*/ makeMap(`animation-iteration-count,border-image-outset,border-image-slice,` +\r\n `border-image-width,box-flex,box-flex-group,box-ordinal-group,column-count,` +\r\n `columns,flex,flex-grow,flex-positive,flex-shrink,flex-negative,flex-order,` +\r\n `grid-row,grid-row-end,grid-row-span,grid-row-start,grid-column,` +\r\n `grid-column-end,grid-column-span,grid-column-start,font-weight,line-clamp,` +\r\n `line-height,opacity,order,orphans,tab-size,widows,z-index,zoom,` +\r\n // SVG\r\n `fill-opacity,flood-opacity,stop-opacity,stroke-dasharray,stroke-dashoffset,` +\r\n `stroke-miterlimit,stroke-opacity,stroke-width`);\r\n/**\r\n * Known attributes, this is used for stringification of runtime static nodes\r\n * so that we don't stringify bindings that cannot be set from HTML.\r\n * Don't also forget to allow `data-*` and `aria-*`!\r\n * Generated from https://developer.mozilla.org/en-US/docs/Web/HTML/Attributes\r\n */\r\nconst isKnownHtmlAttr = /*#__PURE__*/ makeMap(`accept,accept-charset,accesskey,action,align,allow,alt,async,` +\r\n `autocapitalize,autocomplete,autofocus,autoplay,background,bgcolor,` +\r\n `border,buffered,capture,challenge,charset,checked,cite,class,code,` +\r\n `codebase,color,cols,colspan,content,contenteditable,contextmenu,controls,` +\r\n `coords,crossorigin,csp,data,datetime,decoding,default,defer,dir,dirname,` +\r\n `disabled,download,draggable,dropzone,enctype,enterkeyhint,for,form,` +\r\n `formaction,formenctype,formmethod,formnovalidate,formtarget,headers,` +\r\n `height,hidden,high,href,hreflang,http-equiv,icon,id,importance,integrity,` +\r\n `ismap,itemprop,keytype,kind,label,lang,language,loading,list,loop,low,` +\r\n `manifest,max,maxlength,minlength,media,min,multiple,muted,name,novalidate,` +\r\n `open,optimum,pattern,ping,placeholder,poster,preload,radiogroup,readonly,` +\r\n `referrerpolicy,rel,required,reversed,rows,rowspan,sandbox,scope,scoped,` +\r\n `selected,shape,size,sizes,slot,span,spellcheck,src,srcdoc,srclang,srcset,` +\r\n `start,step,style,summary,tabindex,target,title,translate,type,usemap,` +\r\n `value,width,wrap`);\r\n/**\r\n * Generated from https://developer.mozilla.org/en-US/docs/Web/SVG/Attribute\r\n */\r\nconst isKnownSvgAttr = /*#__PURE__*/ makeMap(`xmlns,accent-height,accumulate,additive,alignment-baseline,alphabetic,amplitude,` +\r\n `arabic-form,ascent,attributeName,attributeType,azimuth,baseFrequency,` +\r\n `baseline-shift,baseProfile,bbox,begin,bias,by,calcMode,cap-height,class,` +\r\n `clip,clipPathUnits,clip-path,clip-rule,color,color-interpolation,` +\r\n `color-interpolation-filters,color-profile,color-rendering,` +\r\n `contentScriptType,contentStyleType,crossorigin,cursor,cx,cy,d,decelerate,` +\r\n `descent,diffuseConstant,direction,display,divisor,dominant-baseline,dur,dx,` +\r\n `dy,edgeMode,elevation,enable-background,end,exponent,fill,fill-opacity,` +\r\n `fill-rule,filter,filterRes,filterUnits,flood-color,flood-opacity,` +\r\n `font-family,font-size,font-size-adjust,font-stretch,font-style,` +\r\n `font-variant,font-weight,format,from,fr,fx,fy,g1,g2,glyph-name,` +\r\n `glyph-orientation-horizontal,glyph-orientation-vertical,glyphRef,` +\r\n `gradientTransform,gradientUnits,hanging,height,href,hreflang,horiz-adv-x,` +\r\n `horiz-origin-x,id,ideographic,image-rendering,in,in2,intercept,k,k1,k2,k3,` +\r\n `k4,kernelMatrix,kernelUnitLength,kerning,keyPoints,keySplines,keyTimes,` +\r\n `lang,lengthAdjust,letter-spacing,lighting-color,limitingConeAngle,local,` +\r\n `marker-end,marker-mid,marker-start,markerHeight,markerUnits,markerWidth,` +\r\n `mask,maskContentUnits,maskUnits,mathematical,max,media,method,min,mode,` +\r\n `name,numOctaves,offset,opacity,operator,order,orient,orientation,origin,` +\r\n `overflow,overline-position,overline-thickness,panose-1,paint-order,path,` +\r\n `pathLength,patternContentUnits,patternTransform,patternUnits,ping,` +\r\n `pointer-events,points,pointsAtX,pointsAtY,pointsAtZ,preserveAlpha,` +\r\n `preserveAspectRatio,primitiveUnits,r,radius,referrerPolicy,refX,refY,rel,` +\r\n `rendering-intent,repeatCount,repeatDur,requiredExtensions,requiredFeatures,` +\r\n `restart,result,rotate,rx,ry,scale,seed,shape-rendering,slope,spacing,` +\r\n `specularConstant,specularExponent,speed,spreadMethod,startOffset,` +\r\n `stdDeviation,stemh,stemv,stitchTiles,stop-color,stop-opacity,` +\r\n `strikethrough-position,strikethrough-thickness,string,stroke,` +\r\n `stroke-dasharray,stroke-dashoffset,stroke-linecap,stroke-linejoin,` +\r\n `stroke-miterlimit,stroke-opacity,stroke-width,style,surfaceScale,` +\r\n `systemLanguage,tabindex,tableValues,target,targetX,targetY,text-anchor,` +\r\n `text-decoration,text-rendering,textLength,to,transform,transform-origin,` +\r\n `type,u1,u2,underline-position,underline-thickness,unicode,unicode-bidi,` +\r\n `unicode-range,units-per-em,v-alphabetic,v-hanging,v-ideographic,` +\r\n `v-mathematical,values,vector-effect,version,vert-adv-y,vert-origin-x,` +\r\n `vert-origin-y,viewBox,viewTarget,visibility,width,widths,word-spacing,` +\r\n `writing-mode,x,x-height,x1,x2,xChannelSelector,xlink:actuate,xlink:arcrole,` +\r\n `xlink:href,xlink:role,xlink:show,xlink:title,xlink:type,xml:base,xml:lang,` +\r\n `xml:space,y,y1,y2,yChannelSelector,z,zoomAndPan`);\n\nfunction normalizeStyle(value) {\r\n if (isArray(value)) {\r\n const res = {};\r\n for (let i = 0; i < value.length; i++) {\r\n const item = value[i];\r\n const normalized = isString(item)\r\n ? parseStringStyle(item)\r\n : normalizeStyle(item);\r\n if (normalized) {\r\n for (const key in normalized) {\r\n res[key] = normalized[key];\r\n }\r\n }\r\n }\r\n return res;\r\n }\r\n else if (isString(value)) {\r\n return value;\r\n }\r\n else if (isObject(value)) {\r\n return value;\r\n }\r\n}\r\nconst listDelimiterRE = /;(?![^(]*\\))/g;\r\nconst propertyDelimiterRE = /:(.+)/;\r\nfunction parseStringStyle(cssText) {\r\n const ret = {};\r\n cssText.split(listDelimiterRE).forEach(item => {\r\n if (item) {\r\n const tmp = item.split(propertyDelimiterRE);\r\n tmp.length > 1 && (ret[tmp[0].trim()] = tmp[1].trim());\r\n }\r\n });\r\n return ret;\r\n}\r\nfunction stringifyStyle(styles) {\r\n let ret = '';\r\n if (!styles || isString(styles)) {\r\n return ret;\r\n }\r\n for (const key in styles) {\r\n const value = styles[key];\r\n const normalizedKey = key.startsWith(`--`) ? key : hyphenate(key);\r\n if (isString(value) ||\r\n (typeof value === 'number' && isNoUnitNumericStyleProp(normalizedKey))) {\r\n // only render valid values\r\n ret += `${normalizedKey}:${value};`;\r\n }\r\n }\r\n return ret;\r\n}\r\nfunction normalizeClass(value) {\r\n let res = '';\r\n if (isString(value)) {\r\n res = value;\r\n }\r\n else if (isArray(value)) {\r\n for (let i = 0; i < value.length; i++) {\r\n const normalized = normalizeClass(value[i]);\r\n if (normalized) {\r\n res += normalized + ' ';\r\n }\r\n }\r\n }\r\n else if (isObject(value)) {\r\n for (const name in value) {\r\n if (value[name]) {\r\n res += name + ' ';\r\n }\r\n }\r\n }\r\n return res.trim();\r\n}\r\nfunction normalizeProps(props) {\r\n if (!props)\r\n return null;\r\n let { class: klass, style } = props;\r\n if (klass && !isString(klass)) {\r\n props.class = normalizeClass(klass);\r\n }\r\n if (style) {\r\n props.style = normalizeStyle(style);\r\n }\r\n return props;\r\n}\n\n// These tag configs are shared between compiler-dom and runtime-dom, so they\r\n// https://developer.mozilla.org/en-US/docs/Web/HTML/Element\r\nconst HTML_TAGS = 'html,body,base,head,link,meta,style,title,address,article,aside,footer,' +\r\n 'header,h1,h2,h3,h4,h5,h6,nav,section,div,dd,dl,dt,figcaption,' +\r\n 'figure,picture,hr,img,li,main,ol,p,pre,ul,a,b,abbr,bdi,bdo,br,cite,code,' +\r\n 'data,dfn,em,i,kbd,mark,q,rp,rt,ruby,s,samp,small,span,strong,sub,sup,' +\r\n 'time,u,var,wbr,area,audio,map,track,video,embed,object,param,source,' +\r\n 'canvas,script,noscript,del,ins,caption,col,colgroup,table,thead,tbody,td,' +\r\n 'th,tr,button,datalist,fieldset,form,input,label,legend,meter,optgroup,' +\r\n 'option,output,progress,select,textarea,details,dialog,menu,' +\r\n 'summary,template,blockquote,iframe,tfoot';\r\n// https://developer.mozilla.org/en-US/docs/Web/SVG/Element\r\nconst SVG_TAGS = 'svg,animate,animateMotion,animateTransform,circle,clipPath,color-profile,' +\r\n 'defs,desc,discard,ellipse,feBlend,feColorMatrix,feComponentTransfer,' +\r\n 'feComposite,feConvolveMatrix,feDiffuseLighting,feDisplacementMap,' +\r\n 'feDistanceLight,feDropShadow,feFlood,feFuncA,feFuncB,feFuncG,feFuncR,' +\r\n 'feGaussianBlur,feImage,feMerge,feMergeNode,feMorphology,feOffset,' +\r\n 'fePointLight,feSpecularLighting,feSpotLight,feTile,feTurbulence,filter,' +\r\n 'foreignObject,g,hatch,hatchpath,image,line,linearGradient,marker,mask,' +\r\n 'mesh,meshgradient,meshpatch,meshrow,metadata,mpath,path,pattern,' +\r\n 'polygon,polyline,radialGradient,rect,set,solidcolor,stop,switch,symbol,' +\r\n 'text,textPath,title,tspan,unknown,use,view';\r\nconst VOID_TAGS = 'area,base,br,col,embed,hr,img,input,link,meta,param,source,track,wbr';\r\n/**\r\n * Compiler only.\r\n * Do NOT use in runtime code paths unless behind `(process.env.NODE_ENV !== 'production')` flag.\r\n */\r\nconst isHTMLTag = /*#__PURE__*/ makeMap(HTML_TAGS);\r\n/**\r\n * Compiler only.\r\n * Do NOT use in runtime code paths unless behind `(process.env.NODE_ENV !== 'production')` flag.\r\n */\r\nconst isSVGTag = /*#__PURE__*/ makeMap(SVG_TAGS);\r\n/**\r\n * Compiler only.\r\n * Do NOT use in runtime code paths unless behind `(process.env.NODE_ENV !== 'production')` flag.\r\n */\r\nconst isVoidTag = /*#__PURE__*/ makeMap(VOID_TAGS);\n\nconst escapeRE = /[\"'&<>]/;\r\nfunction escapeHtml(string) {\r\n const str = '' + string;\r\n const match = escapeRE.exec(str);\r\n if (!match) {\r\n return str;\r\n }\r\n let html = '';\r\n let escaped;\r\n let index;\r\n let lastIndex = 0;\r\n for (index = match.index; index < str.length; index++) {\r\n switch (str.charCodeAt(index)) {\r\n case 34: // \"\r\n escaped = '"';\r\n break;\r\n case 38: // &\r\n escaped = '&';\r\n break;\r\n case 39: // '\r\n escaped = ''';\r\n break;\r\n case 60: // <\r\n escaped = '<';\r\n break;\r\n case 62: // >\r\n escaped = '>';\r\n break;\r\n default:\r\n continue;\r\n }\r\n if (lastIndex !== index) {\r\n html += str.slice(lastIndex, index);\r\n }\r\n lastIndex = index + 1;\r\n html += escaped;\r\n }\r\n return lastIndex !== index ? html + str.slice(lastIndex, index) : html;\r\n}\r\n// https://www.w3.org/TR/html52/syntax.html#comments\r\nconst commentStripRE = /^-?>|<!--|-->|--!>|<!-$/g;\r\nfunction escapeHtmlComment(src) {\r\n return src.replace(commentStripRE, '');\r\n}\n\nfunction looseCompareArrays(a, b) {\r\n if (a.length !== b.length)\r\n return false;\r\n let equal = true;\r\n for (let i = 0; equal && i < a.length; i++) {\r\n equal = looseEqual(a[i], b[i]);\r\n }\r\n return equal;\r\n}\r\nfunction looseEqual(a, b) {\r\n if (a === b)\r\n return true;\r\n let aValidType = isDate(a);\r\n let bValidType = isDate(b);\r\n if (aValidType || bValidType) {\r\n return aValidType && bValidType ? a.getTime() === b.getTime() : false;\r\n }\r\n aValidType = isSymbol(a);\r\n bValidType = isSymbol(b);\r\n if (aValidType || bValidType) {\r\n return a === b;\r\n }\r\n aValidType = isArray(a);\r\n bValidType = isArray(b);\r\n if (aValidType || bValidType) {\r\n return aValidType && bValidType ? looseCompareArrays(a, b) : false;\r\n }\r\n aValidType = isObject(a);\r\n bValidType = isObject(b);\r\n if (aValidType || bValidType) {\r\n /* istanbul ignore if: this if will probably never be called */\r\n if (!aValidType || !bValidType) {\r\n return false;\r\n }\r\n const aKeysCount = Object.keys(a).length;\r\n const bKeysCount = Object.keys(b).length;\r\n if (aKeysCount !== bKeysCount) {\r\n return false;\r\n }\r\n for (const key in a) {\r\n const aHasKey = a.hasOwnProperty(key);\r\n const bHasKey = b.hasOwnProperty(key);\r\n if ((aHasKey && !bHasKey) ||\r\n (!aHasKey && bHasKey) ||\r\n !looseEqual(a[key], b[key])) {\r\n return false;\r\n }\r\n }\r\n }\r\n return String(a) === String(b);\r\n}\r\nfunction looseIndexOf(arr, val) {\r\n return arr.findIndex(item => looseEqual(item, val));\r\n}\n\n/**\r\n * For converting {{ interpolation }} values to displayed strings.\r\n * @private\r\n */\r\nconst toDisplayString = (val) => {\r\n return isString(val)\r\n ? val\r\n : val == null\r\n ? ''\r\n : isArray(val) ||\r\n (isObject(val) &&\r\n (val.toString === objectToString || !isFunction(val.toString)))\r\n ? JSON.stringify(val, replacer, 2)\r\n : String(val);\r\n};\r\nconst replacer = (_key, val) => {\r\n // can't use isRef here since @vue/shared has no deps\r\n if (val && val.__v_isRef) {\r\n return replacer(_key, val.value);\r\n }\r\n else if (isMap(val)) {\r\n return {\r\n [`Map(${val.size})`]: [...val.entries()].reduce((entries, [key, val]) => {\r\n entries[`${key} =>`] = val;\r\n return entries;\r\n }, {})\r\n };\r\n }\r\n else if (isSet(val)) {\r\n return {\r\n [`Set(${val.size})`]: [...val.values()]\r\n };\r\n }\r\n else if (isObject(val) && !isArray(val) && !isPlainObject(val)) {\r\n return String(val);\r\n }\r\n return val;\r\n};\n\nconst EMPTY_OBJ = (process.env.NODE_ENV !== 'production')\r\n ? Object.freeze({})\r\n : {};\r\nconst EMPTY_ARR = (process.env.NODE_ENV !== 'production') ? Object.freeze([]) : [];\r\nconst NOOP = () => { };\r\n/**\r\n * Always return false.\r\n */\r\nconst NO = () => false;\r\nconst onRE = /^on[^a-z]/;\r\nconst isOn = (key) => onRE.test(key);\r\nconst isModelListener = (key) => key.startsWith('onUpdate:');\r\nconst extend = Object.assign;\r\nconst remove = (arr, el) => {\r\n const i = arr.indexOf(el);\r\n if (i > -1) {\r\n arr.splice(i, 1);\r\n }\r\n};\r\nconst hasOwnProperty = Object.prototype.hasOwnProperty;\r\nconst hasOwn = (val, key) => hasOwnProperty.call(val, key);\r\nconst isArray = Array.isArray;\r\nconst isMap = (val) => toTypeString(val) === '[object Map]';\r\nconst isSet = (val) => toTypeString(val) === '[object Set]';\r\nconst isDate = (val) => toTypeString(val) === '[object Date]';\r\nconst isFunction = (val) => typeof val === 'function';\r\nconst isString = (val) => typeof val === 'string';\r\nconst isSymbol = (val) => typeof val === 'symbol';\r\nconst isObject = (val) => val !== null && typeof val === 'object';\r\nconst isPromise = (val) => {\r\n return isObject(val) && isFunction(val.then) && isFunction(val.catch);\r\n};\r\nconst objectToString = Object.prototype.toString;\r\nconst toTypeString = (value) => objectToString.call(value);\r\nconst toRawType = (value) => {\r\n // extract \"RawType\" from strings like \"[object RawType]\"\r\n return toTypeString(value).slice(8, -1);\r\n};\r\nconst isPlainObject = (val) => toTypeString(val) === '[object Object]';\r\nconst isIntegerKey = (key) => isString(key) &&\r\n key !== 'NaN' &&\r\n key[0] !== '-' &&\r\n '' + parseInt(key, 10) === key;\r\nconst isReservedProp = /*#__PURE__*/ makeMap(\r\n// the leading comma is intentional so empty string \"\" is also included\r\n',key,ref,ref_for,ref_key,' +\r\n 'onVnodeBeforeMount,onVnodeMounted,' +\r\n 'onVnodeBeforeUpdate,onVnodeUpdated,' +\r\n 'onVnodeBeforeUnmount,onVnodeUnmounted');\r\nconst isBuiltInDirective = /*#__PURE__*/ makeMap('bind,cloak,else-if,else,for,html,if,model,on,once,pre,show,slot,text,memo');\r\nconst cacheStringFunction = (fn) => {\r\n const cache = Object.create(null);\r\n return ((str) => {\r\n const hit = cache[str];\r\n return hit || (cache[str] = fn(str));\r\n });\r\n};\r\nconst camelizeRE = /-(\\w)/g;\r\n/**\r\n * @private\r\n */\r\nconst camelize = cacheStringFunction((str) => {\r\n return str.replace(camelizeRE, (_, c) => (c ? c.toUpperCase() : ''));\r\n});\r\nconst hyphenateRE = /\\B([A-Z])/g;\r\n/**\r\n * @private\r\n */\r\nconst hyphenate = cacheStringFunction((str) => str.replace(hyphenateRE, '-$1').toLowerCase());\r\n/**\r\n * @private\r\n */\r\nconst capitalize = cacheStringFunction((str) => str.charAt(0).toUpperCase() + str.slice(1));\r\n/**\r\n * @private\r\n */\r\nconst toHandlerKey = cacheStringFunction((str) => str ? `on${capitalize(str)}` : ``);\r\n// compare whether a value has changed, accounting for NaN.\r\nconst hasChanged = (value, oldValue) => !Object.is(value, oldValue);\r\nconst invokeArrayFns = (fns, arg) => {\r\n for (let i = 0; i < fns.length; i++) {\r\n fns[i](arg);\r\n }\r\n};\r\nconst def = (obj, key, value) => {\r\n Object.defineProperty(obj, key, {\r\n configurable: true,\r\n enumerable: false,\r\n value\r\n });\r\n};\r\nconst toNumber = (val) => {\r\n const n = parseFloat(val);\r\n return isNaN(n) ? val : n;\r\n};\r\nlet _globalThis;\r\nconst getGlobalThis = () => {\r\n return (_globalThis ||\r\n (_globalThis =\r\n typeof globalThis !== 'undefined'\r\n ? globalThis\r\n : typeof self !== 'undefined'\r\n ? self\r\n : typeof window !== 'undefined'\r\n ? window\r\n : typeof global !== 'undefined'\r\n ? global\r\n : {}));\r\n};\r\nconst identRE = /^[_$a-zA-Z\\xA0-\\uFFFF][_$a-zA-Z0-9\\xA0-\\uFFFF]*$/;\r\nfunction genPropsAccessExp(name) {\r\n return identRE.test(name)\r\n ? `__props.${name}`\r\n : `__props[${JSON.stringify(name)}]`;\r\n}\n\nexport { EMPTY_ARR, EMPTY_OBJ, NO, NOOP, PatchFlagNames, camelize, capitalize, def, escapeHtml, escapeHtmlComment, extend, genPropsAccessExp, generateCodeFrame, getGlobalThis, hasChanged, hasOwn, hyphenate, includeBooleanAttr, invokeArrayFns, isArray, isBooleanAttr, isBuiltInDirective, isDate, isFunction, isGloballyWhitelisted, isHTMLTag, isIntegerKey, isKnownHtmlAttr, isKnownSvgAttr, isMap, isModelListener, isNoUnitNumericStyleProp, isObject, isOn, isPlainObject, isPromise, isReservedProp, isSSRSafeAttrName, isSVGTag, isSet, isSpecialBooleanAttr, isString, isSymbol, isVoidTag, looseEqual, looseIndexOf, makeMap, normalizeClass, normalizeProps, normalizeStyle, objectToString, parseStringStyle, propsToAttrMap, remove, slotFlagsText, stringifyStyle, toDisplayString, toHandlerKey, toNumber, toRawType, toTypeString };\n","import { extend, isArray, isMap, isIntegerKey, hasOwn, isSymbol, isObject, hasChanged, makeMap, capitalize, toRawType, def, isFunction, NOOP } from '@vue/shared';\n\nfunction warn(msg, ...args) {\r\n console.warn(`[Vue warn] ${msg}`, ...args);\r\n}\n\nlet activeEffectScope;\r\nclass EffectScope {\r\n constructor(detached = false) {\r\n /**\r\n * @internal\r\n */\r\n this.active = true;\r\n /**\r\n * @internal\r\n */\r\n this.effects = [];\r\n /**\r\n * @internal\r\n */\r\n this.cleanups = [];\r\n if (!detached && activeEffectScope) {\r\n this.parent = activeEffectScope;\r\n this.index =\r\n (activeEffectScope.scopes || (activeEffectScope.scopes = [])).push(this) - 1;\r\n }\r\n }\r\n run(fn) {\r\n if (this.active) {\r\n const currentEffectScope = activeEffectScope;\r\n try {\r\n activeEffectScope = this;\r\n return fn();\r\n }\r\n finally {\r\n activeEffectScope = currentEffectScope;\r\n }\r\n }\r\n else if ((process.env.NODE_ENV !== 'production')) {\r\n warn(`cannot run an inactive effect scope.`);\r\n }\r\n }\r\n /**\r\n * This should only be called on non-detached scopes\r\n * @internal\r\n */\r\n on() {\r\n activeEffectScope = this;\r\n }\r\n /**\r\n * This should only be called on non-detached scopes\r\n * @internal\r\n */\r\n off() {\r\n activeEffectScope = this.parent;\r\n }\r\n stop(fromParent) {\r\n if (this.active) {\r\n let i, l;\r\n for (i = 0, l = this.effects.length; i < l; i++) {\r\n this.effects[i].stop();\r\n }\r\n for (i = 0, l = this.cleanups.length; i < l; i++) {\r\n this.cleanups[i]();\r\n }\r\n if (this.scopes) {\r\n for (i = 0, l = this.scopes.length; i < l; i++) {\r\n this.scopes[i].stop(true);\r\n }\r\n }\r\n // nested scope, dereference from parent to avoid memory leaks\r\n if (this.parent && !fromParent) {\r\n // optimized O(1) removal\r\n const last = this.parent.scopes.pop();\r\n if (last && last !== this) {\r\n this.parent.scopes[this.index] = last;\r\n last.index = this.index;\r\n }\r\n }\r\n this.active = false;\r\n }\r\n }\r\n}\r\nfunction effectScope(detached) {\r\n return new EffectScope(detached);\r\n}\r\nfunction recordEffectScope(effect, scope = activeEffectScope) {\r\n if (scope && scope.active) {\r\n scope.effects.push(effect);\r\n }\r\n}\r\nfunction getCurrentScope() {\r\n return activeEffectScope;\r\n}\r\nfunction onScopeDispose(fn) {\r\n if (activeEffectScope) {\r\n activeEffectScope.cleanups.push(fn);\r\n }\r\n else if ((process.env.NODE_ENV !== 'production')) {\r\n warn(`onScopeDispose() is called when there is no active effect scope` +\r\n ` to be associated with.`);\r\n }\r\n}\n\nconst createDep = (effects) => {\r\n const dep = new Set(effects);\r\n dep.w = 0;\r\n dep.n = 0;\r\n return dep;\r\n};\r\nconst wasTracked = (dep) => (dep.w & trackOpBit) > 0;\r\nconst newTracked = (dep) => (dep.n & trackOpBit) > 0;\r\nconst initDepMarkers = ({ deps }) => {\r\n if (deps.length) {\r\n for (let i = 0; i < deps.length; i++) {\r\n deps[i].w |= trackOpBit; // set was tracked\r\n }\r\n }\r\n};\r\nconst finalizeDepMarkers = (effect) => {\r\n const { deps } = effect;\r\n if (deps.length) {\r\n let ptr = 0;\r\n for (let i = 0; i < deps.length; i++) {\r\n const dep = deps[i];\r\n if (wasTracked(dep) && !newTracked(dep)) {\r\n dep.delete(effect);\r\n }\r\n else {\r\n deps[ptr++] = dep;\r\n }\r\n // clear bits\r\n dep.w &= ~trackOpBit;\r\n dep.n &= ~trackOpBit;\r\n }\r\n deps.length = ptr;\r\n }\r\n};\n\nconst targetMap = new WeakMap();\r\n// The number of effects currently being tracked recursively.\r\nlet effectTrackDepth = 0;\r\nlet trackOpBit = 1;\r\n/**\r\n * The bitwise track markers support at most 30 levels of recursion.\r\n * This value is chosen to enable modern JS engines to use a SMI on all platforms.\r\n * When recursion depth is greater, fall back to using a full cleanup.\r\n */\r\nconst maxMarkerBits = 30;\r\nlet activeEffect;\r\nconst ITERATE_KEY = Symbol((process.env.NODE_ENV !== 'production') ? 'iterate' : '');\r\nconst MAP_KEY_ITERATE_KEY = Symbol((process.env.NODE_ENV !== 'production') ? 'Map key iterate' : '');\r\nclass ReactiveEffect {\r\n constructor(fn, scheduler = null, scope) {\r\n this.fn = fn;\r\n this.scheduler = scheduler;\r\n this.active = true;\r\n this.deps = [];\r\n this.parent = undefined;\r\n recordEffectScope(this, scope);\r\n }\r\n run() {\r\n if (!this.active) {\r\n return this.fn();\r\n }\r\n let parent = activeEffect;\r\n let lastShouldTrack = shouldTrack;\r\n while (parent) {\r\n if (parent === this) {\r\n return;\r\n }\r\n parent = parent.parent;\r\n }\r\n try {\r\n this.parent = activeEffect;\r\n activeEffect = this;\r\n shouldTrack = true;\r\n trackOpBit = 1 << ++effectTrackDepth;\r\n if (effectTrackDepth <= maxMarkerBits) {\r\n initDepMarkers(this);\r\n }\r\n else {\r\n cleanupEffect(this);\r\n }\r\n return this.fn();\r\n }\r\n finally {\r\n if (effectTrackDepth <= maxMarkerBits) {\r\n finalizeDepMarkers(this);\r\n }\r\n trackOpBit = 1 << --effectTrackDepth;\r\n activeEffect = this.parent;\r\n shouldTrack = lastShouldTrack;\r\n this.parent = undefined;\r\n if (this.deferStop) {\r\n this.stop();\r\n }\r\n }\r\n }\r\n stop() {\r\n // stopped while running itself - defer the cleanup\r\n if (activeEffect === this) {\r\n this.deferStop = true;\r\n }\r\n else if (this.active) {\r\n cleanupEffect(this);\r\n if (this.onStop) {\r\n this.onStop();\r\n }\r\n this.active = false;\r\n }\r\n }\r\n}\r\nfunction cleanupEffect(effect) {\r\n const { deps } = effect;\r\n if (deps.length) {\r\n for (let i = 0; i < deps.length; i++) {\r\n deps[i].delete(effect);\r\n }\r\n deps.length = 0;\r\n }\r\n}\r\nfunction effect(fn, options) {\r\n if (fn.effect) {\r\n fn = fn.effect.fn;\r\n }\r\n const _effect = new ReactiveEffect(fn);\r\n if (options) {\r\n extend(_effect, options);\r\n if (options.scope)\r\n recordEffectScope(_effect, options.scope);\r\n }\r\n if (!options || !options.lazy) {\r\n _effect.run();\r\n }\r\n const runner = _effect.run.bind(_effect);\r\n runner.effect = _effect;\r\n return runner;\r\n}\r\nfunction stop(runner) {\r\n runner.effect.stop();\r\n}\r\nlet shouldTrack = true;\r\nconst trackStack = [];\r\nfunction pauseTracking() {\r\n trackStack.push(shouldTrack);\r\n shouldTrack = false;\r\n}\r\nfunction enableTracking() {\r\n trackStack.push(shouldTrack);\r\n shouldTrack = true;\r\n}\r\nfunction resetTracking() {\r\n const last = trackStack.pop();\r\n shouldTrack = last === undefined ? true : last;\r\n}\r\nfunction track(target, type, key) {\r\n if (shouldTrack && activeEffect) {\r\n let depsMap = targetMap.get(target);\r\n if (!depsMap) {\r\n targetMap.set(target, (depsMap = new Map()));\r\n }\r\n let dep = depsMap.get(key);\r\n if (!dep) {\r\n depsMap.set(key, (dep = createDep()));\r\n }\r\n const eventInfo = (process.env.NODE_ENV !== 'production')\r\n ? { effect: activeEffect, target, type, key }\r\n : undefined;\r\n trackEffects(dep, eventInfo);\r\n }\r\n}\r\nfunction trackEffects(dep, debuggerEventExtraInfo) {\r\n let shouldTrack = false;\r\n if (effectTrackDepth <= maxMarkerBits) {\r\n if (!newTracked(dep)) {\r\n dep.n |= trackOpBit; // set newly tracked\r\n shouldTrack = !wasTracked(dep);\r\n }\r\n }\r\n else {\r\n // Full cleanup mode.\r\n shouldTrack = !dep.has(activeEffect);\r\n }\r\n if (shouldTrack) {\r\n dep.add(activeEffect);\r\n activeEffect.deps.push(dep);\r\n if ((process.env.NODE_ENV !== 'production') && activeEffect.onTrack) {\r\n activeEffect.onTrack(Object.assign({ effect: activeEffect }, debuggerEventExtraInfo));\r\n }\r\n }\r\n}\r\nfunction trigger(target, type, key, newValue, oldValue, oldTarget) {\r\n const depsMap = targetMap.get(target);\r\n if (!depsMap) {\r\n // never been tracked\r\n return;\r\n }\r\n let deps = [];\r\n if (type === \"clear\" /* CLEAR */) {\r\n // collection being cleared\r\n // trigger all effects for target\r\n deps = [...depsMap.values()];\r\n }\r\n else if (key === 'length' && isArray(target)) {\r\n depsMap.forEach((dep, key) => {\r\n if (key === 'length' || key >= newValue) {\r\n deps.push(dep);\r\n }\r\n });\r\n }\r\n else {\r\n // schedule runs for SET | ADD | DELETE\r\n if (key !== void 0) {\r\n deps.push(depsMap.get(key));\r\n }\r\n // also run for iteration key on ADD | DELETE | Map.SET\r\n switch (type) {\r\n case \"add\" /* ADD */:\r\n if (!isArray(target)) {\r\n deps.push(depsMap.get(ITERATE_KEY));\r\n if (isMap(target)) {\r\n deps.push(depsMap.get(MAP_KEY_ITERATE_KEY));\r\n }\r\n }\r\n else if (isIntegerKey(key)) {\r\n // new index added to array -> length changes\r\n deps.push(depsMap.get('length'));\r\n }\r\n break;\r\n case \"delete\" /* DELETE */:\r\n if (!isArray(target)) {\r\n deps.push(depsMap.get(ITERATE_KEY));\r\n if (isMap(target)) {\r\n deps.push(depsMap.get(MAP_KEY_ITERATE_KEY));\r\n }\r\n }\r\n break;\r\n case \"set\" /* SET */:\r\n if (isMap(target)) {\r\n deps.push(depsMap.get(ITERATE_KEY));\r\n }\r\n break;\r\n }\r\n }\r\n const eventInfo = (process.env.NODE_ENV !== 'production')\r\n ? { target, type, key, newValue, oldValue, oldTarget }\r\n : undefined;\r\n if (deps.length === 1) {\r\n if (deps[0]) {\r\n if ((process.env.NODE_ENV !== 'production')) {\r\n triggerEffects(deps[0], eventInfo);\r\n }\r\n else {\r\n triggerEffects(deps[0]);\r\n }\r\n }\r\n }\r\n else {\r\n const effects = [];\r\n for (const dep of deps) {\r\n if (dep) {\r\n effects.push(...dep);\r\n }\r\n }\r\n if ((process.env.NODE_ENV !== 'production')) {\r\n triggerEffects(createDep(effects), eventInfo);\r\n }\r\n else {\r\n triggerEffects(createDep(effects));\r\n }\r\n }\r\n}\r\nfunction triggerEffects(dep, debuggerEventExtraInfo) {\r\n // spread into array for stabilization\r\n const effects = isArray(dep) ? dep : [...dep];\r\n for (const effect of effects) {\r\n if (effect.computed) {\r\n triggerEffect(effect, debuggerEventExtraInfo);\r\n }\r\n }\r\n for (const effect of effects) {\r\n if (!effect.computed) {\r\n triggerEffect(effect, debuggerEventExtraInfo);\r\n }\r\n }\r\n}\r\nfunction triggerEffect(effect, debuggerEventExtraInfo) {\r\n if (effect !== activeEffect || effect.allowRecurse) {\r\n if ((process.env.NODE_ENV !== 'production') && effect.onTrigger) {\r\n effect.onTrigger(extend({ effect }, debuggerEventExtraInfo));\r\n }\r\n if (effect.scheduler) {\r\n effect.scheduler();\r\n }\r\n else {\r\n effect.run();\r\n }\r\n }\r\n}\n\nconst isNonTrackableKeys = /*#__PURE__*/ makeMap(`__proto__,__v_isRef,__isVue`);\r\nconst builtInSymbols = new Set(\r\n/*#__PURE__*/\r\nObject.getOwnPropertyNames(Symbol)\r\n // ios10.x Object.getOwnPropertyNames(Symbol) can enumerate 'arguments' and 'caller'\r\n // but accessing them on Symbol leads to TypeError because Symbol is a strict mode\r\n // function\r\n .filter(key => key !== 'arguments' && key !== 'caller')\r\n .map(key => Symbol[key])\r\n .filter(isSymbol));\r\nconst get = /*#__PURE__*/ createGetter();\r\nconst shallowGet = /*#__PURE__*/ createGetter(false, true);\r\nconst readonlyGet = /*#__PURE__*/ createGetter(true);\r\nconst shallowReadonlyGet = /*#__PURE__*/ createGetter(true, true);\r\nconst arrayInstrumentations = /*#__PURE__*/ createArrayInstrumentations();\r\nfunction createArrayInstrumentations() {\r\n const instrumentations = {};\r\n ['includes', 'indexOf', 'lastIndexOf'].forEach(key => {\r\n instrumentations[key] = function (...args) {\r\n const arr = toRaw(this);\r\n for (let i = 0, l = this.length; i < l; i++) {\r\n track(arr, \"get\" /* GET */, i + '');\r\n }\r\n // we run the method using the original args first (which may be reactive)\r\n const res = arr[key](...args);\r\n if (res === -1 || res === false) {\r\n // if that didn't work, run it again using raw values.\r\n return arr[key](...args.map(toRaw));\r\n }\r\n else {\r\n return res;\r\n }\r\n };\r\n });\r\n ['push', 'pop', 'shift', 'unshift', 'splice'].forEach(key => {\r\n instrumentations[key] = function (...args) {\r\n pauseTracking();\r\n const res = toRaw(this)[key].apply(this, args);\r\n resetTracking();\r\n return res;\r\n };\r\n });\r\n return instrumentations;\r\n}\r\nfunction createGetter(isReadonly = false, shallow = false) {\r\n return function get(target, key, receiver) {\r\n if (key === \"__v_isReactive\" /* IS_REACTIVE */) {\r\n return !isReadonly;\r\n }\r\n else if (key === \"__v_isReadonly\" /* IS_READONLY */) {\r\n return isReadonly;\r\n }\r\n else if (key === \"__v_isShallow\" /* IS_SHALLOW */) {\r\n return shallow;\r\n }\r\n else if (key === \"__v_raw\" /* RAW */ &&\r\n receiver ===\r\n (isReadonly\r\n ? shallow\r\n ? shallowReadonlyMap\r\n : readonlyMap\r\n : shallow\r\n ? shallowReactiveMap\r\n : reactiveMap).get(target)) {\r\n return target;\r\n }\r\n const targetIsArray = isArray(target);\r\n if (!isReadonly && targetIsArray && hasOwn(arrayInstrumentations, key)) {\r\n return Reflect.get(arrayInstrumentations, key, receiver);\r\n }\r\n const res = Reflect.get(target, key, receiver);\r\n if (isSymbol(key) ? builtInSymbols.has(key) : isNonTrackableKeys(key)) {\r\n return res;\r\n }\r\n if (!isReadonly) {\r\n track(target, \"get\" /* GET */, key);\r\n }\r\n if (shallow) {\r\n return res;\r\n }\r\n if (isRef(res)) {\r\n // ref unwrapping - skip unwrap for Array + integer key.\r\n return targetIsArray && isIntegerKey(key) ? res : res.value;\r\n }\r\n if (isObject(res)) {\r\n // Convert returned value into a proxy as well. we do the isObject check\r\n // here to avoid invalid value warning. Also need to lazy access readonly\r\n // and reactive here to avoid circular dependency.\r\n return isReadonly ? readonly(res) : reactive(res);\r\n }\r\n return res;\r\n };\r\n}\r\nconst set = /*#__PURE__*/ createSetter();\r\nconst shallowSet = /*#__PURE__*/ createSetter(true);\r\nfunction createSetter(shallow = false) {\r\n return function set(target, key, value, receiver) {\r\n let oldValue = target[key];\r\n if (isReadonly(oldValue) && isRef(oldValue) && !isRef(value)) {\r\n return false;\r\n }\r\n if (!shallow && !isReadonly(value)) {\r\n if (!isShallow(value)) {\r\n value = toRaw(value);\r\n oldValue = toRaw(oldValue);\r\n }\r\n if (!isArray(target) && isRef(oldValue) && !isRef(value)) {\r\n oldValue.value = value;\r\n return true;\r\n }\r\n }\r\n const hadKey = isArray(target) && isIntegerKey(key)\r\n ? Number(key) < target.length\r\n : hasOwn(target, key);\r\n const result = Reflect.set(target, key, value, receiver);\r\n // don't trigger if target is something up in the prototype chain of original\r\n if (target === toRaw(receiver)) {\r\n if (!hadKey) {\r\n trigger(target, \"add\" /* ADD */, key, value);\r\n }\r\n else if (hasChanged(value, oldValue)) {\r\n trigger(target, \"set\" /* SET */, key, value, oldValue);\r\n }\r\n }\r\n return result;\r\n };\r\n}\r\nfunction deleteProperty(target, key) {\r\n const hadKey = hasOwn(target, key);\r\n const oldValue = target[key];\r\n const result = Reflect.deleteProperty(target, key);\r\n if (result && hadKey) {\r\n trigger(target, \"delete\" /* DELETE */, key, undefined, oldValue);\r\n }\r\n return result;\r\n}\r\nfunction has(target, key) {\r\n const result = Reflect.has(target, key);\r\n if (!isSymbol(key) || !builtInSymbols.has(key)) {\r\n track(target, \"has\" /* HAS */, key);\r\n }\r\n return result;\r\n}\r\nfunction ownKeys(target) {\r\n track(target, \"iterate\" /* ITERATE */, isArray(target) ? 'length' : ITERATE_KEY);\r\n return Reflect.ownKeys(target);\r\n}\r\nconst mutableHandlers = {\r\n get,\r\n set,\r\n deleteProperty,\r\n has,\r\n ownKeys\r\n};\r\nconst readonlyHandlers = {\r\n get: readonlyGet,\r\n set(target, key) {\r\n if ((process.env.NODE_ENV !== 'production')) {\r\n warn(`Set operation on key \"${String(key)}\" failed: target is readonly.`, target);\r\n }\r\n return true;\r\n },\r\n deleteProperty(target, key) {\r\n if ((process.env.NODE_ENV !== 'production')) {\r\n warn(`Delete operation on key \"${String(key)}\" failed: target is readonly.`, target);\r\n }\r\n return true;\r\n }\r\n};\r\nconst shallowReactiveHandlers = /*#__PURE__*/ extend({}, mutableHandlers, {\r\n get: shallowGet,\r\n set: shallowSet\r\n});\r\n// Props handlers are special in the sense that it should not unwrap top-level\r\n// refs (in order to allow refs to be explicitly passed down), but should\r\n// retain the reactivity of the normal readonly object.\r\nconst shallowReadonlyHandlers = /*#__PURE__*/ extend({}, readonlyHandlers, {\r\n get: shallowReadonlyGet\r\n});\n\nconst toShallow = (value) => value;\r\nconst getProto = (v) => Reflect.getPrototypeOf(v);\r\nfunction get$1(target, key, isReadonly = false, isShallow = false) {\r\n // #1772: readonly(reactive(Map)) should return readonly + reactive version\r\n // of the value\r\n target = target[\"__v_raw\" /* RAW */];\r\n const rawTarget = toRaw(target);\r\n const rawKey = toRaw(key);\r\n if (!isReadonly) {\r\n if (key !== rawKey) {\r\n track(rawTarget, \"get\" /* GET */, key);\r\n }\r\n track(rawTarget, \"get\" /* GET */, rawKey);\r\n }\r\n const { has } = getProto(rawTarget);\r\n const wrap = isShallow ? toShallow : isReadonly ? toReadonly : toReactive;\r\n if (has.call(rawTarget, key)) {\r\n return wrap(target.get(key));\r\n }\r\n else if (has.call(rawTarget, rawKey)) {\r\n return wrap(target.get(rawKey));\r\n }\r\n else if (target !== rawTarget) {\r\n // #3602 readonly(reactive(Map))\r\n // ensure that the nested reactive `Map` can do tracking for itself\r\n target.get(key);\r\n }\r\n}\r\nfunction has$1(key, isReadonly = false) {\r\n const target = this[\"__v_raw\" /* RAW */];\r\n const rawTarget = toRaw(target);\r\n const rawKey = toRaw(key);\r\n if (!isReadonly) {\r\n if (key !== rawKey) {\r\n track(rawTarget, \"has\" /* HAS */, key);\r\n }\r\n track(rawTarget, \"has\" /* HAS */, rawKey);\r\n }\r\n return key === rawKey\r\n ? target.has(key)\r\n : target.has(key) || target.has(rawKey);\r\n}\r\nfunction size(target, isReadonly = false) {\r\n target = target[\"__v_raw\" /* RAW */];\r\n !isReadonly && track(toRaw(target), \"iterate\" /* ITERATE */, ITERATE_KEY);\r\n return Reflect.get(target, 'size', target);\r\n}\r\nfunction add(value) {\r\n value = toRaw(value);\r\n const target = toRaw(this);\r\n const proto = getProto(target);\r\n const hadKey = proto.has.call(target, value);\r\n if (!hadKey) {\r\n target.add(value);\r\n trigger(target, \"add\" /* ADD */, value, value);\r\n }\r\n return this;\r\n}\r\nfunction set$1(key, value) {\r\n value = toRaw(value);\r\n const target = toRaw(this);\r\n const { has, get } = getProto(target);\r\n let hadKey = has.call(target, key);\r\n if (!hadKey) {\r\n key = toRaw(key);\r\n hadKey = has.call(target, key);\r\n }\r\n else if ((process.env.NODE_ENV !== 'production')) {\r\n checkIdentityKeys(target, has, key);\r\n }\r\n const oldValue = get.call(target, key);\r\n target.set(key, value);\r\n if (!hadKey) {\r\n trigger(target, \"add\" /* ADD */, key, value);\r\n }\r\n else if (hasChanged(value, oldValue)) {\r\n trigger(target, \"set\" /* SET */, key, value, oldValue);\r\n }\r\n return this;\r\n}\r\nfunction deleteEntry(key) {\r\n const target = toRaw(this);\r\n const { has, get } = getProto(target);\r\n let hadKey = has.call(target, key);\r\n if (!hadKey) {\r\n key = toRaw(key);\r\n hadKey = has.call(target, key);\r\n }\r\n else if ((process.env.NODE_ENV !== 'production')) {\r\n checkIdentityKeys(target, has, key);\r\n }\r\n const oldValue = get ? get.call(target, key) : undefined;\r\n // forward the operation before queueing reactions\r\n const result = target.delete(key);\r\n if (hadKey) {\r\n trigger(target, \"delete\" /* DELETE */, key, undefined, oldValue);\r\n }\r\n return result;\r\n}\r\nfunction clear() {\r\n const target = toRaw(this);\r\n const hadItems = target.size !== 0;\r\n const oldTarget = (process.env.NODE_ENV !== 'production')\r\n ? isMap(target)\r\n ? new Map(target)\r\n : new Set(target)\r\n : undefined;\r\n // forward the operation before queueing reactions\r\n const result = target.clear();\r\n if (hadItems) {\r\n trigger(target, \"clear\" /* CLEAR */, undefined, undefined, oldTarget);\r\n }\r\n return result;\r\n}\r\nfunction createForEach(isReadonly, isShallow) {\r\n return function forEach(callback, thisArg) {\r\n const observed = this;\r\n const target = observed[\"__v_raw\" /* RAW */];\r\n const rawTarget = toRaw(target);\r\n const wrap = isShallow ? toShallow : isReadonly ? toReadonly : toReactive;\r\n !isReadonly && track(rawTarget, \"iterate\" /* ITERATE */, ITERATE_KEY);\r\n return target.forEach((value, key) => {\r\n // important: make sure the callback is\r\n // 1. invoked with the reactive map as `this` and 3rd arg\r\n // 2. the value received should be a corresponding reactive/readonly.\r\n return callback.call(thisArg, wrap(value), wrap(key), observed);\r\n });\r\n };\r\n}\r\nfunction createIterableMethod(method, isReadonly, isShallow) {\r\n return function (...args) {\r\n const target = this[\"__v_raw\" /* RAW */];\r\n const rawTarget = toRaw(target);\r\n const targetIsMap = isMap(rawTarget);\r\n const isPair = method === 'entries' || (method === Symbol.iterator && targetIsMap);\r\n const isKeyOnly = method === 'keys' && targetIsMap;\r\n const innerIterator = target[method](...args);\r\n const wrap = isShallow ? toShallow : isReadonly ? toReadonly : toReactive;\r\n !isReadonly &&\r\n track(rawTarget, \"iterate\" /* ITERATE */, isKeyOnly ? MAP_KEY_ITERATE_KEY : ITERATE_KEY);\r\n // return a wrapped iterator which returns observed versions of the\r\n // values emitted from the real iterator\r\n return {\r\n // iterator protocol\r\n next() {\r\n const { value, done } = innerIterator.next();\r\n return done\r\n ? { value, done }\r\n : {\r\n value: isPair ? [wrap(value[0]), wrap(value[1])] : wrap(value),\r\n done\r\n };\r\n },\r\n // iterable protocol\r\n [Symbol.iterator]() {\r\n return this;\r\n }\r\n };\r\n };\r\n}\r\nfunction createReadonlyMethod(type) {\r\n return function (...args) {\r\n if ((process.env.NODE_ENV !== 'production')) {\r\n const key = args[0] ? `on key \"${args[0]}\" ` : ``;\r\n console.warn(`${capitalize(type)} operation ${key}failed: target is readonly.`, toRaw(this));\r\n }\r\n return type === \"delete\" /* DELETE */ ? false : this;\r\n };\r\n}\r\nfunction createInstrumentations() {\r\n const mutableInstrumentations = {\r\n get(key) {\r\n return get$1(this, key);\r\n },\r\n get size() {\r\n return size(this);\r\n },\r\n has: has$1,\r\n add,\r\n set: set$1,\r\n delete: deleteEntry,\r\n clear,\r\n forEach: createForEach(false, false)\r\n };\r\n const shallowInstrumentations = {\r\n get(key) {\r\n return get$1(this, key, false, true);\r\n },\r\n get size() {\r\n return size(this);\r\n },\r\n has: has$1,\r\n add,\r\n set: set$1,\r\n delete: deleteEntry,\r\n clear,\r\n forEach: createForEach(false, true)\r\n };\r\n const readonlyInstrumentations = {\r\n get(key) {\r\n return get$1(this, key, true);\r\n },\r\n get size() {\r\n return size(this, true);\r\n },\r\n has(key) {\r\n return has$1.call(this, key, true);\r\n },\r\n add: createReadonlyMethod(\"add\" /* ADD */),\r\n set: createReadonlyMethod(\"set\" /* SET */),\r\n delete: createReadonlyMethod(\"delete\" /* DELETE */),\r\n clear: createReadonlyMethod(\"clear\" /* CLEAR */),\r\n forEach: createForEach(true, false)\r\n };\r\n const shallowReadonlyInstrumentations = {\r\n get(key) {\r\n return get$1(this, key, true, true);\r\n },\r\n get size() {\r\n return size(this, true);\r\n },\r\n has(key) {\r\n return has$1.call(this, key, true);\r\n },\r\n add: createReadonlyMethod(\"add\" /* ADD */),\r\n set: createReadonlyMethod(\"set\" /* SET */),\r\n delete: createReadonlyMethod(\"delete\" /* DELETE */),\r\n clear: createReadonlyMethod(\"clear\" /* CLEAR */),\r\n forEach: createForEach(true, true)\r\n };\r\n const iteratorMethods = ['keys', 'values', 'entries', Symbol.iterator];\r\n iteratorMethods.forEach(method => {\r\n mutableInstrumentations[method] = createIterableMethod(method, false, false);\r\n readonlyInstrumentations[method] = createIterableMethod(method, true, false);\r\n shallowInstrumentations[method] = createIterableMethod(method, false, true);\r\n shallowReadonlyInstrumentations[method] = createIterableMethod(method, true, true);\r\n });\r\n return [\r\n mutableInstrumentations,\r\n readonlyInstrumentations,\r\n shallowInstrumentations,\r\n shallowReadonlyInstrumentations\r\n ];\r\n}\r\nconst [mutableInstrumentations, readonlyInstrumentations, shallowInstrumentations, shallowReadonlyInstrumentations] = /* #__PURE__*/ createInstrumentations();\r\nfunction createInstrumentationGetter(isReadonly, shallow) {\r\n const instrumentations = shallow\r\n ? isReadonly\r\n ? shallowReadonlyInstrumentations\r\n : shallowInstrumentations\r\n : isReadonly\r\n ? readonlyInstrumentations\r\n : mutableInstrumentations;\r\n return (target, key, receiver) => {\r\n if (key === \"__v_isReactive\" /* IS_REACTIVE */) {\r\n return !isReadonly;\r\n }\r\n else if (key === \"__v_isReadonly\" /* IS_READONLY */) {\r\n return isReadonly;\r\n }\r\n else if (key === \"__v_raw\" /* RAW */) {\r\n return target;\r\n }\r\n return Reflect.get(hasOwn(instrumentations, key) && key in target\r\n ? instrumentations\r\n : target, key, receiver);\r\n };\r\n}\r\nconst mutableCollectionHandlers = {\r\n get: /*#__PURE__*/ createInstrumentationGetter(false, false)\r\n};\r\nconst shallowCollectionHandlers = {\r\n get: /*#__PURE__*/ createInstrumentationGetter(false, true)\r\n};\r\nconst readonlyCollectionHandlers = {\r\n get: /*#__PURE__*/ createInstrumentationGetter(true, false)\r\n};\r\nconst shallowReadonlyCollectionHandlers = {\r\n get: /*#__PURE__*/ createInstrumentationGetter(true, true)\r\n};\r\nfunction checkIdentityKeys(target, has, key) {\r\n const rawKey = toRaw(key);\r\n if (rawKey !== key && has.call(target, rawKey)) {\r\n const type = toRawType(target);\r\n console.warn(`Reactive ${type} contains both the raw and reactive ` +\r\n `versions of the same object${type === `Map` ? ` as keys` : ``}, ` +\r\n `which can lead to inconsistencies. ` +\r\n `Avoid differentiating between the raw and reactive versions ` +\r\n `of an object and only use the reactive version if possible.`);\r\n }\r\n}\n\nconst reactiveMap = new WeakMap();\r\nconst shallowReactiveMap = new WeakMap();\r\nconst readonlyMap = new WeakMap();\r\nconst shallowReadonlyMap = new WeakMap();\r\nfunction targetTypeMap(rawType) {\r\n switch (rawType) {\r\n case 'Object':\r\n case 'Array':\r\n return 1 /* COMMON */;\r\n case 'Map':\r\n case 'Set':\r\n case 'WeakMap':\r\n case 'WeakSet':\r\n return 2 /* COLLECTION */;\r\n default:\r\n return 0 /* INVALID */;\r\n }\r\n}\r\nfunction getTargetType(value) {\r\n return value[\"__v_skip\" /* SKIP */] || !Object.isExtensible(value)\r\n ? 0 /* INVALID */\r\n : targetTypeMap(toRawType(value));\r\n}\r\nfunction reactive(target) {\r\n // if trying to observe a readonly proxy, return the readonly version.\r\n if (isReadonly(target)) {\r\n return target;\r\n }\r\n return createReactiveObject(target, false, mutableHandlers, mutableCollectionHandlers, reactiveMap);\r\n}\r\n/**\r\n * Return a shallowly-reactive copy of the original object, where only the root\r\n * level properties are reactive. It also does not auto-unwrap refs (even at the\r\n * root level).\r\n */\r\nfunction shallowReactive(target) {\r\n return createReactiveObject(target, false, shallowReactiveHandlers, shallowCollectionHandlers, shallowReactiveMap);\r\n}\r\n/**\r\n * Creates a readonly copy of the original object. Note the returned copy is not\r\n * made reactive, but `readonly` can be called on an already reactive object.\r\n */\r\nfunction readonly(target) {\r\n return createReactiveObject(target, true, readonlyHandlers, readonlyCollectionHandlers, readonlyMap);\r\n}\r\n/**\r\n * Returns a reactive-copy of the original object, where only the root level\r\n * properties are readonly, and does NOT unwrap refs nor recursively convert\r\n * returned properties.\r\n * This is used for creating the props proxy object for stateful components.\r\n */\r\nfunction shallowReadonly(target) {\r\n return createReactiveObject(target, true, shallowReadonlyHandlers, shallowReadonlyCollectionHandlers, shallowReadonlyMap);\r\n}\r\nfunction createReactiveObject(target, isReadonly, baseHandlers, collectionHandlers, proxyMap) {\r\n if (!isObject(target)) {\r\n if ((process.env.NODE_ENV !== 'production')) {\r\n console.warn(`value cannot be made reactive: ${String(target)}`);\r\n }\r\n return target;\r\n }\r\n // target is already a Proxy, return it.\r\n // exception: calling readonly() on a reactive object\r\n if (target[\"__v_raw\" /* RAW */] &&\r\n !(isReadonly && target[\"__v_isReactive\" /* IS_REACTIVE */])) {\r\n return target;\r\n }\r\n // target already has corresponding Proxy\r\n const existingProxy = proxyMap.get(target);\r\n if (existingProxy) {\r\n return existingProxy;\r\n }\r\n // only specific value types can be observed.\r\n const targetType = getTargetType(target);\r\n if (targetType === 0 /* INVALID */) {\r\n return target;\r\n }\r\n const proxy = new Proxy(target, targetType === 2 /* COLLECTION */ ? collectionHandlers : baseHandlers);\r\n proxyMap.set(target, proxy);\r\n return proxy;\r\n}\r\nfunction isReactive(value) {\r\n if (isReadonly(value)) {\r\n return isReactive(value[\"__v_raw\" /* RAW */]);\r\n }\r\n return !!(value && value[\"__v_isReactive\" /* IS_REACTIVE */]);\r\n}\r\nfunction isReadonly(value) {\r\n return !!(value && value[\"__v_isReadonly\" /* IS_READONLY */]);\r\n}\r\nfunction isShallow(value) {\r\n return !!(value && value[\"__v_isShallow\" /* IS_SHALLOW */]);\r\n}\r\nfunction isProxy(value) {\r\n return isReactive(value) || isReadonly(value);\r\n}\r\nfunction toRaw(observed) {\r\n const raw = observed && observed[\"__v_raw\" /* RAW */];\r\n return raw ? toRaw(raw) : observed;\r\n}\r\nfunction markRaw(value) {\r\n def(value, \"__v_skip\" /* SKIP */, true);\r\n return value;\r\n}\r\nconst toReactive = (value) => isObject(value) ? reactive(value) : value;\r\nconst toReadonly = (value) => isObject(value) ? readonly(value) : value;\n\nfunction trackRefValue(ref) {\r\n if (shouldTrack && activeEffect) {\r\n ref = toRaw(ref);\r\n if ((process.env.NODE_ENV !== 'production')) {\r\n trackEffects(ref.dep || (ref.dep = createDep()), {\r\n target: ref,\r\n type: \"get\" /* GET */,\r\n key: 'value'\r\n });\r\n }\r\n else {\r\n trackEffects(ref.dep || (ref.dep = createDep()));\r\n }\r\n }\r\n}\r\nfunction triggerRefValue(ref, newVal) {\r\n ref = toRaw(ref);\r\n if (ref.dep) {\r\n if ((process.env.NODE_ENV !== 'production')) {\r\n triggerEffects(ref.dep, {\r\n target: ref,\r\n type: \"set\" /* SET */,\r\n key: 'value',\r\n newValue: newVal\r\n });\r\n }\r\n else {\r\n triggerEffects(ref.dep);\r\n }\r\n }\r\n}\r\nfunction isRef(r) {\r\n return !!(r && r.__v_isRef === true);\r\n}\r\nfunction ref(value) {\r\n return createRef(value, false);\r\n}\r\nfunction shallowRef(value) {\r\n return createRef(value, true);\r\n}\r\nfunction createRef(rawValue, shallow) {\r\n if (isRef(rawValue)) {\r\n return rawValue;\r\n }\r\n return new RefImpl(rawValue, shallow);\r\n}\r\nclass RefImpl {\r\n constructor(value, __v_isShallow) {\r\n this.__v_isShallow = __v_isShallow;\r\n this.dep = undefined;\r\n this.__v_isRef = true;\r\n this._rawValue = __v_isShallow ? value : toRaw(value);\r\n this._value = __v_isShallow ? value : toReactive(value);\r\n }\r\n get value() {\r\n trackRefValue(this);\r\n return this._value;\r\n }\r\n set value(newVal) {\r\n newVal = this.__v_isShallow ? newVal : toRaw(newVal);\r\n if (hasChanged(newVal, this._rawValue)) {\r\n this._rawValue = newVal;\r\n this._value = this.__v_isShallow ? newVal : toReactive(newVal);\r\n triggerRefValue(this, newVal);\r\n }\r\n }\r\n}\r\nfunction triggerRef(ref) {\r\n triggerRefValue(ref, (process.env.NODE_ENV !== 'production') ? ref.value : void 0);\r\n}\r\nfunction unref(ref) {\r\n return isRef(ref) ? ref.value : ref;\r\n}\r\nconst shallowUnwrapHandlers = {\r\n get: (target, key, receiver) => unref(Reflect.get(target, key, receiver)),\r\n set: (target, key, value, receiver) => {\r\n const oldValue = target[key];\r\n if (isRef(oldValue) && !isRef(value)) {\r\n oldValue.value = value;\r\n return true;\r\n }\r\n else {\r\n return Reflect.set(target, key, value, receiver);\r\n }\r\n }\r\n};\r\nfunction proxyRefs(objectWithRefs) {\r\n return isReactive(objectWithRefs)\r\n ? objectWithRefs\r\n : new Proxy(objectWithRefs, shallowUnwrapHandlers);\r\n}\r\nclass CustomRefImpl {\r\n constructor(factory) {\r\n this.dep = undefined;\r\n this.__v_isRef = true;\r\n const { get, set } = factory(() => trackRefValue(this), () => triggerRefValue(this));\r\n this._get = get;\r\n this._set = set;\r\n }\r\n get value() {\r\n return this._get();\r\n }\r\n set value(newVal) {\r\n this._set(newVal);\r\n }\r\n}\r\nfunction customRef(factory) {\r\n return new CustomRefImpl(factory);\r\n}\r\nfunction toRefs(object) {\r\n if ((process.env.NODE_ENV !== 'production') && !isProxy(object)) {\r\n console.warn(`toRefs() expects a reactive object but received a plain one.`);\r\n }\r\n const ret = isArray(object) ? new Array(object.length) : {};\r\n for (const key in object) {\r\n ret[key] = toRef(object, key);\r\n }\r\n return ret;\r\n}\r\nclass ObjectRefImpl {\r\n constructor(_object, _key, _defaultValue) {\r\n this._object = _object;\r\n this._key = _key;\r\n this._defaultValue = _defaultValue;\r\n this.__v_isRef = true;\r\n }\r\n get value() {\r\n const val = this._object[this._key];\r\n return val === undefined ? this._defaultValue : val;\r\n }\r\n set value(newVal) {\r\n this._object[this._key] = newVal;\r\n }\r\n}\r\nfunction toRef(object, key, defaultValue) {\r\n const val = object[key];\r\n return isRef(val)\r\n ? val\r\n : new ObjectRefImpl(object, key, defaultValue);\r\n}\n\nclass ComputedRefImpl {\r\n constructor(getter, _setter, isReadonly, isSSR) {\r\n this._setter = _setter;\r\n this.dep = undefined;\r\n this.__v_isRef = true;\r\n this._dirty = true;\r\n this.effect = new ReactiveEffect(getter, () => {\r\n if (!this._dirty) {\r\n this._dirty = true;\r\n triggerRefValue(this);\r\n }\r\n });\r\n this.effect.computed = this;\r\n this.effect.active = this._cacheable = !isSSR;\r\n this[\"__v_isReadonly\" /* IS_READONLY */] = isReadonly;\r\n }\r\n get value() {\r\n // the computed ref may get wrapped by other proxies e.g. readonly() #3376\r\n const self = toRaw(this);\r\n trackRefValue(self);\r\n if (self._dirty || !self._cacheable) {\r\n self._dirty = false;\r\n self._value = self.effect.run();\r\n }\r\n return self._value;\r\n }\r\n set value(newValue) {\r\n this._setter(newValue);\r\n }\r\n}\r\nfunction computed(getterOrOptions, debugOptions, isSSR = false) {\r\n let getter;\r\n let setter;\r\n const onlyGetter = isFunction(getterOrOptions);\r\n if (onlyGetter) {\r\n getter = getterOrOptions;\r\n setter = (process.env.NODE_ENV !== 'production')\r\n ? () => {\r\n console.warn('Write operation failed: computed value is readonly');\r\n }\r\n : NOOP;\r\n }\r\n else {\r\n getter = getterOrOptions.get;\r\n setter = getterOrOptions.set;\r\n }\r\n const cRef = new ComputedRefImpl(getter, setter, onlyGetter || !setter, isSSR);\r\n if ((process.env.NODE_ENV !== 'production') && debugOptions && !isSSR) {\r\n cRef.effect.onTrack = debugOptions.onTrack;\r\n cRef.effect.onTrigger = debugOptions.onTrigger;\r\n }\r\n return cRef;\r\n}\n\nvar _a;\r\nconst tick = /*#__PURE__*/ Promise.resolve();\r\nconst queue = [];\r\nlet queued = false;\r\nconst scheduler = (fn) => {\r\n queue.push(fn);\r\n if (!queued) {\r\n queued = true;\r\n tick.then(flush);\r\n }\r\n};\r\nconst flush = () => {\r\n for (let i = 0; i < queue.length; i++) {\r\n queue[i]();\r\n }\r\n queue.length = 0;\r\n queued = false;\r\n};\r\nclass DeferredComputedRefImpl {\r\n constructor(getter) {\r\n this.dep = undefined;\r\n this._dirty = true;\r\n this.__v_isRef = true;\r\n this[_a] = true;\r\n let compareTarget;\r\n let hasCompareTarget = false;\r\n let scheduled = false;\r\n this.effect = new ReactiveEffect(getter, (computedTrigger) => {\r\n if (this.dep) {\r\n if (computedTrigger) {\r\n compareTarget = this._value;\r\n hasCompareTarget = true;\r\n }\r\n else if (!scheduled) {\r\n const valueToCompare = hasCompareTarget ? compareTarget : this._value;\r\n scheduled = true;\r\n hasCompareTarget = false;\r\n scheduler(() => {\r\n if (this.effect.active && this._get() !== valueToCompare) {\r\n triggerRefValue(this);\r\n }\r\n scheduled = false;\r\n });\r\n }\r\n // chained upstream computeds are notified synchronously to ensure\r\n // value invalidation in case of sync access; normal effects are\r\n // deferred to be triggered in scheduler.\r\n for (const e of this.dep) {\r\n if (e.computed instanceof DeferredComputedRefImpl) {\r\n e.scheduler(true /* computedTrigger */);\r\n }\r\n }\r\n }\r\n this._dirty = true;\r\n });\r\n this.effect.computed = this;\r\n }\r\n _get() {\r\n if (this._dirty) {\r\n this._dirty = false;\r\n return (this._value = this.effect.run());\r\n }\r\n return this._value;\r\n }\r\n get value() {\r\n trackRefValue(this);\r\n // the computed ref may get wrapped by other proxies e.g. readonly() #3376\r\n return toRaw(this)._get();\r\n }\r\n}\r\n_a = \"__v_isReadonly\" /* IS_READONLY */;\r\nfunction deferredComputed(getter) {\r\n return new DeferredComputedRefImpl(getter);\r\n}\n\nexport { EffectScope, ITERATE_KEY, ReactiveEffect, computed, customRef, deferredComputed, effect, effectScope, enableTracking, getCurrentScope, isProxy, isReactive, isReadonly, isRef, isShallow, markRaw, onScopeDispose, pauseTracking, proxyRefs, reactive, readonly, ref, resetTracking, shallowReactive, shallowReadonly, shallowRef, stop, toRaw, toRef, toRefs, track, trigger, triggerRef, unref };\n","import { pauseTracking, resetTracking, isRef, toRaw, isShallow as isShallow$1, isReactive, ReactiveEffect, ref, shallowReadonly, track, reactive, shallowReactive, trigger, isProxy, EffectScope, markRaw, proxyRefs, computed as computed$1, isReadonly } from '@vue/reactivity';\nexport { EffectScope, ReactiveEffect, customRef, effect, effectScope, getCurrentScope, isProxy, isReactive, isReadonly, isRef, isShallow, markRaw, onScopeDispose, proxyRefs, reactive, readonly, ref, shallowReactive, shallowReadonly, shallowRef, stop, toRaw, toRef, toRefs, triggerRef, unref } from '@vue/reactivity';\nimport { isString, isFunction, isPromise, isArray, NOOP, getGlobalThis, extend, EMPTY_OBJ, toHandlerKey, toNumber, hyphenate, camelize, isOn, hasOwn, isModelListener, hasChanged, remove, isObject, isSet, isMap, isPlainObject, invokeArrayFns, isBuiltInDirective, capitalize, isGloballyWhitelisted, def, isReservedProp, EMPTY_ARR, toRawType, makeMap, NO, normalizeClass, normalizeStyle } from '@vue/shared';\nexport { camelize, capitalize, normalizeClass, normalizeProps, normalizeStyle, toDisplayString, toHandlerKey } from '@vue/shared';\n\nconst stack = [];\r\nfunction pushWarningContext(vnode) {\r\n stack.push(vnode);\r\n}\r\nfunction popWarningContext() {\r\n stack.pop();\r\n}\r\nfunction warn(msg, ...args) {\r\n // avoid props formatting or warn handler tracking deps that might be mutated\r\n // during patch, leading to infinite recursion.\r\n pauseTracking();\r\n const instance = stack.length ? stack[stack.length - 1].component : null;\r\n const appWarnHandler = instance && instance.appContext.config.warnHandler;\r\n const trace = getComponentTrace();\r\n if (appWarnHandler) {\r\n callWithErrorHandling(appWarnHandler, instance, 11 /* APP_WARN_HANDLER */, [\r\n msg + args.join(''),\r\n instance && instance.proxy,\r\n trace\r\n .map(({ vnode }) => `at <${formatComponentName(instance, vnode.type)}>`)\r\n .join('\\n'),\r\n trace\r\n ]);\r\n }\r\n else {\r\n const warnArgs = [`[Vue warn]: ${msg}`, ...args];\r\n /* istanbul ignore if */\r\n if (trace.length &&\r\n // avoid spamming console during tests\r\n !false) {\r\n warnArgs.push(`\\n`, ...formatTrace(trace));\r\n }\r\n console.warn(...warnArgs);\r\n }\r\n resetTracking();\r\n}\r\nfunction getComponentTrace() {\r\n let currentVNode = stack[stack.length - 1];\r\n if (!currentVNode) {\r\n return [];\r\n }\r\n // we can't just use the stack because it will be incomplete during updates\r\n // that did not start from the root. Re-construct the parent chain using\r\n // instance parent pointers.\r\n const normalizedStack = [];\r\n while (currentVNode) {\r\n const last = normalizedStack[0];\r\n if (last && last.vnode === currentVNode) {\r\n last.recurseCount++;\r\n }\r\n else {\r\n normalizedStack.push({\r\n vnode: currentVNode,\r\n recurseCount: 0\r\n });\r\n }\r\n const parentInstance = currentVNode.component && currentVNode.component.parent;\r\n currentVNode = parentInstance && parentInstance.vnode;\r\n }\r\n return normalizedStack;\r\n}\r\n/* istanbul ignore next */\r\nfunction formatTrace(trace) {\r\n const logs = [];\r\n trace.forEach((entry, i) => {\r\n logs.push(...(i === 0 ? [] : [`\\n`]), ...formatTraceEntry(entry));\r\n });\r\n return logs;\r\n}\r\nfunction formatTraceEntry({ vnode, recurseCount }) {\r\n const postfix = recurseCount > 0 ? `... (${recurseCount} recursive calls)` : ``;\r\n const isRoot = vnode.component ? vnode.component.parent == null : false;\r\n const open = ` at <${formatComponentName(vnode.component, vnode.type, isRoot)}`;\r\n const close = `>` + postfix;\r\n return vnode.props\r\n ? [open, ...formatProps(vnode.props), close]\r\n : [open + close];\r\n}\r\n/* istanbul ignore next */\r\nfunction formatProps(props) {\r\n const res = [];\r\n const keys = Object.keys(props);\r\n keys.slice(0, 3).forEach(key => {\r\n res.push(...formatProp(key, props[key]));\r\n });\r\n if (keys.length > 3) {\r\n res.push(` ...`);\r\n }\r\n return res;\r\n}\r\n/* istanbul ignore next */\r\nfunction formatProp(key, value, raw) {\r\n if (isString(value)) {\r\n value = JSON.stringify(value);\r\n return raw ? value : [`${key}=${value}`];\r\n }\r\n else if (typeof value === 'number' ||\r\n typeof value === 'boolean' ||\r\n value == null) {\r\n return raw ? value : [`${key}=${value}`];\r\n }\r\n else if (isRef(value)) {\r\n value = formatProp(key, toRaw(value.value), true);\r\n return raw ? value : [`${key}=Ref<`, value, `>`];\r\n }\r\n else if (isFunction(value)) {\r\n return [`${key}=fn${value.name ? `<${value.name}>` : ``}`];\r\n }\r\n else {\r\n value = toRaw(value);\r\n return raw ? value : [`${key}=`, value];\r\n }\r\n}\n\nconst ErrorTypeStrings = {\r\n [\"sp\" /* SERVER_PREFETCH */]: 'serverPrefetch hook',\r\n [\"bc\" /* BEFORE_CREATE */]: 'beforeCreate hook',\r\n [\"c\" /* CREATED */]: 'created hook',\r\n [\"bm\" /* BEFORE_MOUNT */]: 'beforeMount hook',\r\n [\"m\" /* MOUNTED */]: 'mounted hook',\r\n [\"bu\" /* BEFORE_UPDATE */]: 'beforeUpdate hook',\r\n [\"u\" /* UPDATED */]: 'updated',\r\n [\"bum\" /* BEFORE_UNMOUNT */]: 'beforeUnmount hook',\r\n [\"um\" /* UNMOUNTED */]: 'unmounted hook',\r\n [\"a\" /* ACTIVATED */]: 'activated hook',\r\n [\"da\" /* DEACTIVATED */]: 'deactivated hook',\r\n [\"ec\" /* ERROR_CAPTURED */]: 'errorCaptured hook',\r\n [\"rtc\" /* RENDER_TRACKED */]: 'renderTracked hook',\r\n [\"rtg\" /* RENDER_TRIGGERED */]: 'renderTriggered hook',\r\n [0 /* SETUP_FUNCTION */]: 'setup function',\r\n [1 /* RENDER_FUNCTION */]: 'render function',\r\n [2 /* WATCH_GETTER */]: 'watcher getter',\r\n [3 /* WATCH_CALLBACK */]: 'watcher callback',\r\n [4 /* WATCH_CLEANUP */]: 'watcher cleanup function',\r\n [5 /* NATIVE_EVENT_HANDLER */]: 'native event handler',\r\n [6 /* COMPONENT_EVENT_HANDLER */]: 'component event handler',\r\n [7 /* VNODE_HOOK */]: 'vnode hook',\r\n [8 /* DIRECTIVE_HOOK */]: 'directive hook',\r\n [9 /* TRANSITION_HOOK */]: 'transition hook',\r\n [10 /* APP_ERROR_HANDLER */]: 'app errorHandler',\r\n [11 /* APP_WARN_HANDLER */]: 'app warnHandler',\r\n [12 /* FUNCTION_REF */]: 'ref function',\r\n [13 /* ASYNC_COMPONENT_LOADER */]: 'async component loader',\r\n [14 /* SCHEDULER */]: 'scheduler flush. This is likely a Vue internals bug. ' +\r\n 'Please open an issue at https://new-issue.vuejs.org/?repo=vuejs/core'\r\n};\r\nfunction callWithErrorHandling(fn, instance, type, args) {\r\n let res;\r\n try {\r\n res = args ? fn(...args) : fn();\r\n }\r\n catch (err) {\r\n handleError(err, instance, type);\r\n }\r\n return res;\r\n}\r\nfunction callWithAsyncErrorHandling(fn, instance, type, args) {\r\n if (isFunction(fn)) {\r\n const res = callWithErrorHandling(fn, instance, type, args);\r\n if (res && isPromise(res)) {\r\n res.catch(err => {\r\n handleError(err, instance, type);\r\n });\r\n }\r\n return res;\r\n }\r\n const values = [];\r\n for (let i = 0; i < fn.length; i++) {\r\n values.push(callWithAsyncErrorHandling(fn[i], instance, type, args));\r\n }\r\n return values;\r\n}\r\nfunction handleError(err, instance, type, throwInDev = true) {\r\n const contextVNode = instance ? instance.vnode : null;\r\n if (instance) {\r\n let cur = instance.parent;\r\n // the exposed instance is the render proxy to keep it consistent with 2.x\r\n const exposedInstance = instance.proxy;\r\n // in production the hook receives only the error code\r\n const errorInfo = (process.env.NODE_ENV !== 'production') ? ErrorTypeStrings[type] : type;\r\n while (cur) {\r\n const errorCapturedHooks = cur.ec;\r\n if (errorCapturedHooks) {\r\n for (let i = 0; i < errorCapturedHooks.length; i++) {\r\n if (errorCapturedHooks[i](err, exposedInstance, errorInfo) === false) {\r\n return;\r\n }\r\n }\r\n }\r\n cur = cur.parent;\r\n }\r\n // app-level handling\r\n const appErrorHandler = instance.appContext.config.errorHandler;\r\n if (appErrorHandler) {\r\n callWithErrorHandling(appErrorHandler, null, 10 /* APP_ERROR_HANDLER */, [err, exposedInstance, errorInfo]);\r\n return;\r\n }\r\n }\r\n logError(err, type, contextVNode, throwInDev);\r\n}\r\nfunction logError(err, type, contextVNode, throwInDev = true) {\r\n if ((process.env.NODE_ENV !== 'production')) {\r\n const info = ErrorTypeStrings[type];\r\n if (contextVNode) {\r\n pushWarningContext(contextVNode);\r\n }\r\n warn(`Unhandled error${info ? ` during execution of ${info}` : ``}`);\r\n if (contextVNode) {\r\n popWarningContext();\r\n }\r\n // crash in dev by default so it's more noticeable\r\n if (throwInDev) {\r\n throw err;\r\n }\r\n else {\r\n console.error(err);\r\n }\r\n }\r\n else {\r\n // recover in prod to reduce the impact on end-user\r\n console.error(err);\r\n }\r\n}\n\nlet isFlushing = false;\r\nlet isFlushPending = false;\r\nconst queue = [];\r\nlet flushIndex = 0;\r\nconst pendingPreFlushCbs = [];\r\nlet activePreFlushCbs = null;\r\nlet preFlushIndex = 0;\r\nconst pendingPostFlushCbs = [];\r\nlet activePostFlushCbs = null;\r\nlet postFlushIndex = 0;\r\nconst resolvedPromise = /*#__PURE__*/ Promise.resolve();\r\nlet currentFlushPromise = null;\r\nlet currentPreFlushParentJob = null;\r\nconst RECURSION_LIMIT = 100;\r\nfunction nextTick(fn) {\r\n const p = currentFlushPromise || resolvedPromise;\r\n return fn ? p.then(this ? fn.bind(this) : fn) : p;\r\n}\r\n// #2768\r\n// Use binary-search to find a suitable position in the queue,\r\n// so that the queue maintains the increasing order of job's id,\r\n// which can prevent the job from being skipped and also can avoid repeated patching.\r\nfunction findInsertionIndex(id) {\r\n // the start index should be `flushIndex + 1`\r\n let start = flushIndex + 1;\r\n let end = queue.length;\r\n while (start < end) {\r\n const middle = (start + end) >>> 1;\r\n const middleJobId = getId(queue[middle]);\r\n middleJobId < id ? (start = middle + 1) : (end = middle);\r\n }\r\n return start;\r\n}\r\nfunction queueJob(job) {\r\n // the dedupe search uses the startIndex argument of Array.includes()\r\n // by default the search index includes the current job that is being run\r\n // so it cannot recursively trigger itself again.\r\n // if the job is a watch() callback, the search will start with a +1 index to\r\n // allow it recursively trigger itself - it is the user's responsibility to\r\n // ensure it doesn't end up in an infinite loop.\r\n if ((!queue.length ||\r\n !queue.includes(job, isFlushing && job.allowRecurse ? flushIndex + 1 : flushIndex)) &&\r\n job !== currentPreFlushParentJob) {\r\n if (job.id == null) {\r\n queue.push(job);\r\n }\r\n else {\r\n queue.splice(findInsertionIndex(job.id), 0, job);\r\n }\r\n queueFlush();\r\n }\r\n}\r\nfunction queueFlush() {\r\n if (!isFlushing && !isFlushPending) {\r\n isFlushPending = true;\r\n currentFlushPromise = resolvedPromise.then(flushJobs);\r\n }\r\n}\r\nfunction invalidateJob(job) {\r\n const i = queue.indexOf(job);\r\n if (i > flushIndex) {\r\n queue.splice(i, 1);\r\n }\r\n}\r\nfunction queueCb(cb, activeQueue, pendingQueue, index) {\r\n if (!isArray(cb)) {\r\n if (!activeQueue ||\r\n !activeQueue.includes(cb, cb.allowRecurse ? index + 1 : index)) {\r\n pendingQueue.push(cb);\r\n }\r\n }\r\n else {\r\n // if cb is an array, it is a component lifecycle hook which can only be\r\n // triggered by a job, which is already deduped in the main queue, so\r\n // we can skip duplicate check here to improve perf\r\n pendingQueue.push(...cb);\r\n }\r\n queueFlush();\r\n}\r\nfunction queuePreFlushCb(cb) {\r\n queueCb(cb, activePreFlushCbs, pendingPreFlushCbs, preFlushIndex);\r\n}\r\nfunction queuePostFlushCb(cb) {\r\n queueCb(cb, activePostFlushCbs, pendingPostFlushCbs, postFlushIndex);\r\n}\r\nfunction flushPreFlushCbs(seen, parentJob = null) {\r\n if (pendingPreFlushCbs.length) {\r\n currentPreFlushParentJob = parentJob;\r\n activePreFlushCbs = [...new Set(pendingPreFlushCbs)];\r\n pendingPreFlushCbs.length = 0;\r\n if ((process.env.NODE_ENV !== 'production')) {\r\n seen = seen || new Map();\r\n }\r\n for (preFlushIndex = 0; preFlushIndex < activePreFlushCbs.length; preFlushIndex++) {\r\n if ((process.env.NODE_ENV !== 'production') &&\r\n checkRecursiveUpdates(seen, activePreFlushCbs[preFlushIndex])) {\r\n continue;\r\n }\r\n activePreFlushCbs[preFlushIndex]();\r\n }\r\n activePreFlushCbs = null;\r\n preFlushIndex = 0;\r\n currentPreFlushParentJob = null;\r\n // recursively flush until it drains\r\n flushPreFlushCbs(seen, parentJob);\r\n }\r\n}\r\nfunction flushPostFlushCbs(seen) {\r\n // flush any pre cbs queued during the flush (e.g. pre watchers)\r\n flushPreFlushCbs();\r\n if (pendingPostFlushCbs.length) {\r\n const deduped = [...new Set(pendingPostFlushCbs)];\r\n pendingPostFlushCbs.length = 0;\r\n // #1947 already has active queue, nested flushPostFlushCbs call\r\n if (activePostFlushCbs) {\r\n activePostFlushCbs.push(...deduped);\r\n return;\r\n }\r\n activePostFlushCbs = deduped;\r\n if ((process.env.NODE_ENV !== 'production')) {\r\n seen = seen || new Map();\r\n }\r\n activePostFlushCbs.sort((a, b) => getId(a) - getId(b));\r\n for (postFlushIndex = 0; postFlushIndex < activePostFlushCbs.length; postFlushIndex++) {\r\n if ((process.env.NODE_ENV !== 'production') &&\r\n checkRecursiveUpdates(seen, activePostFlushCbs[postFlushIndex])) {\r\n continue;\r\n }\r\n activePostFlushCbs[postFlushIndex]();\r\n }\r\n activePostFlushCbs = null;\r\n postFlushIndex = 0;\r\n }\r\n}\r\nconst getId = (job) => job.id == null ? Infinity : job.id;\r\nfunction flushJobs(seen) {\r\n isFlushPending = false;\r\n isFlushing = true;\r\n if ((process.env.NODE_ENV !== 'production')) {\r\n seen = seen || new Map();\r\n }\r\n flushPreFlushCbs(seen);\r\n // Sort queue before flush.\r\n // This ensures that:\r\n // 1. Components are updated from parent to child. (because parent is always\r\n // created before the child so its render effect will have smaller\r\n // priority number)\r\n // 2. If a component is unmounted during a parent component's update,\r\n // its update can be skipped.\r\n queue.sort((a, b) => getId(a) - getId(b));\r\n // conditional usage of checkRecursiveUpdate must be determined out of\r\n // try ... catch block since Rollup by default de-optimizes treeshaking\r\n // inside try-catch. This can leave all warning code unshaked. Although\r\n // they would get eventually shaken by a minifier like terser, some minifiers\r\n // would fail to do that (e.g. https://github.com/evanw/esbuild/issues/1610)\r\n const check = (process.env.NODE_ENV !== 'production')\r\n ? (job) => checkRecursiveUpdates(seen, job)\r\n : NOOP;\r\n try {\r\n for (flushIndex = 0; flushIndex < queue.length; flushIndex++) {\r\n const job = queue[flushIndex];\r\n if (job && job.active !== false) {\r\n if ((process.env.NODE_ENV !== 'production') && check(job)) {\r\n continue;\r\n }\r\n // console.log(`running:`, job.id)\r\n callWithErrorHandling(job, null, 14 /* SCHEDULER */);\r\n }\r\n }\r\n }\r\n finally {\r\n flushIndex = 0;\r\n queue.length = 0;\r\n flushPostFlushCbs(seen);\r\n isFlushing = false;\r\n currentFlushPromise = null;\r\n // some postFlushCb queued jobs!\r\n // keep flushing until it drains.\r\n if (queue.length ||\r\n pendingPreFlushCbs.length ||\r\n pendingPostFlushCbs.length) {\r\n flushJobs(seen);\r\n }\r\n }\r\n}\r\nfunction checkRecursiveUpdates(seen, fn) {\r\n if (!seen.has(fn)) {\r\n seen.set(fn, 1);\r\n }\r\n else {\r\n const count = seen.get(fn);\r\n if (count > RECURSION_LIMIT) {\r\n const instance = fn.ownerInstance;\r\n const componentName = instance && getComponentName(instance.type);\r\n warn(`Maximum recursive updates exceeded${componentName ? ` in component <${componentName}>` : ``}. ` +\r\n `This means you have a reactive effect that is mutating its own ` +\r\n `dependencies and thus recursively triggering itself. Possible sources ` +\r\n `include component template, render function, updated hook or ` +\r\n `watcher source function.`);\r\n return true;\r\n }\r\n else {\r\n seen.set(fn, count + 1);\r\n }\r\n }\r\n}\n\n/* eslint-disable no-restricted-globals */\r\nlet isHmrUpdating = false;\r\nconst hmrDirtyComponents = new Set();\r\n// Expose the HMR runtime on the global object\r\n// This makes it entirely tree-shakable without polluting the exports and makes\r\n// it easier to be used in toolings like vue-loader\r\n// Note: for a component to be eligible for HMR it also needs the __hmrId option\r\n// to be set so that its instances can be registered / removed.\r\nif ((process.env.NODE_ENV !== 'production')) {\r\n getGlobalThis().__VUE_HMR_RUNTIME__ = {\r\n createRecord: tryWrap(createRecord),\r\n rerender: tryWrap(rerender),\r\n reload: tryWrap(reload)\r\n };\r\n}\r\nconst map = new Map();\r\nfunction registerHMR(instance) {\r\n const id = instance.type.__hmrId;\r\n let record = map.get(id);\r\n if (!record) {\r\n createRecord(id, instance.type);\r\n record = map.get(id);\r\n }\r\n record.instances.add(instance);\r\n}\r\nfunction unregisterHMR(instance) {\r\n map.get(instance.type.__hmrId).instances.delete(instance);\r\n}\r\nfunction createRecord(id, initialDef) {\r\n if (map.has(id)) {\r\n return false;\r\n }\r\n map.set(id, {\r\n initialDef: normalizeClassComponent(initialDef),\r\n instances: new Set()\r\n });\r\n return true;\r\n}\r\nfunction normalizeClassComponent(component) {\r\n return isClassComponent(component) ? component.__vccOpts : component;\r\n}\r\nfunction rerender(id, newRender) {\r\n const record = map.get(id);\r\n if (!record) {\r\n return;\r\n }\r\n // update initial record (for not-yet-rendered component)\r\n record.initialDef.render = newRender;\r\n [...record.instances].forEach(instance => {\r\n if (newRender) {\r\n instance.render = newRender;\r\n normalizeClassComponent(instance.type).render = newRender;\r\n }\r\n instance.renderCache = [];\r\n // this flag forces child components with slot content to update\r\n isHmrUpdating = true;\r\n instance.update();\r\n isHmrUpdating = false;\r\n });\r\n}\r\nfunction reload(id, newComp) {\r\n const record = map.get(id);\r\n if (!record)\r\n return;\r\n newComp = normalizeClassComponent(newComp);\r\n // update initial def (for not-yet-rendered components)\r\n updateComponentDef(record.initialDef, newComp);\r\n // create a snapshot which avoids the set being mutated during updates\r\n const instances = [...record.instances];\r\n for (const instance of instances) {\r\n const oldComp = normalizeClassComponent(instance.type);\r\n if (!hmrDirtyComponents.has(oldComp)) {\r\n // 1. Update existing comp definition to match new one\r\n if (oldComp !== record.initialDef) {\r\n updateComponentDef(oldComp, newComp);\r\n }\r\n // 2. mark definition dirty. This forces the renderer to replace the\r\n // component on patch.\r\n hmrDirtyComponents.add(oldComp);\r\n }\r\n // 3. invalidate options resolution cache\r\n instance.appContext.optionsCache.delete(instance.type);\r\n // 4. actually update\r\n if (instance.ceReload) {\r\n // custom element\r\n hmrDirtyComponents.add(oldComp);\r\n instance.ceReload(newComp.styles);\r\n hmrDirtyComponents.delete(oldComp);\r\n }\r\n else if (instance.parent) {\r\n // 4. Force the parent instance to re-render. This will cause all updated\r\n // components to be unmounted and re-mounted. Queue the update so that we\r\n // don't end up forcing the same parent to re-render multiple times.\r\n queueJob(instance.parent.update);\r\n // instance is the inner component of an async custom element\r\n // invoke to reset styles\r\n if (instance.parent.type.__asyncLoader &&\r\n instance.parent.ceReload) {\r\n instance.parent.ceReload(newComp.styles);\r\n }\r\n }\r\n else if (instance.appContext.reload) {\r\n // root instance mounted via createApp() has a reload method\r\n instance.appContext.reload();\r\n }\r\n else if (typeof window !== 'undefined') {\r\n // root instance inside tree created via raw render(). Force reload.\r\n window.location.reload();\r\n }\r\n else {\r\n console.warn('[HMR] Root or manually mounted instance modified. Full reload required.');\r\n }\r\n }\r\n // 5. make sure to cleanup dirty hmr components after update\r\n queuePostFlushCb(() => {\r\n for (const instance of instances) {\r\n hmrDirtyComponents.delete(normalizeClassComponent(instance.type));\r\n }\r\n });\r\n}\r\nfunction updateComponentDef(oldComp, newComp) {\r\n extend(oldComp, newComp);\r\n for (const key in oldComp) {\r\n if (key !== '__file' && !(key in newComp)) {\r\n delete oldComp[key];\r\n }\r\n }\r\n}\r\nfunction tryWrap(fn) {\r\n return (id, arg) => {\r\n try {\r\n return fn(id, arg);\r\n }\r\n catch (e) {\r\n console.error(e);\r\n console.warn(`[HMR] Something went wrong during Vue component hot-reload. ` +\r\n `Full reload required.`);\r\n }\r\n };\r\n}\n\nlet devtools;\r\nlet buffer = [];\r\nlet devtoolsNotInstalled = false;\r\nfunction emit(event, ...args) {\r\n if (devtools) {\r\n devtools.emit(event, ...args);\r\n }\r\n else if (!devtoolsNotInstalled) {\r\n buffer.push({ event, args });\r\n }\r\n}\r\nfunction setDevtoolsHook(hook, target) {\r\n var _a, _b;\r\n devtools = hook;\r\n if (devtools) {\r\n devtools.enabled = true;\r\n buffer.forEach(({ event, args }) => devtools.emit(event, ...args));\r\n buffer = [];\r\n }\r\n else if (\r\n // handle late devtools injection - only do this if we are in an actual\r\n // browser environment to avoid the timer handle stalling test runner exit\r\n // (#4815)\r\n typeof window !== 'undefined' &&\r\n // some envs mock window but not fully\r\n window.HTMLElement &&\r\n // also exclude jsdom\r\n !((_b = (_a = window.navigator) === null || _a === void 0 ? void 0 : _a.userAgent) === null || _b === void 0 ? void 0 : _b.includes('jsdom'))) {\r\n const replay = (target.__VUE_DEVTOOLS_HOOK_REPLAY__ =\r\n target.__VUE_DEVTOOLS_HOOK_REPLAY__ || []);\r\n replay.push((newHook) => {\r\n setDevtoolsHook(newHook, target);\r\n });\r\n // clear buffer after 3s - the user probably doesn't have devtools installed\r\n // at all, and keeping the buffer will cause memory leaks (#4738)\r\n setTimeout(() => {\r\n if (!devtools) {\r\n target.__VUE_DEVTOOLS_HOOK_REPLAY__ = null;\r\n devtoolsNotInstalled = true;\r\n buffer = [];\r\n }\r\n }, 3000);\r\n }\r\n else {\r\n // non-browser env, assume not installed\r\n devtoolsNotInstalled = true;\r\n buffer = [];\r\n }\r\n}\r\nfunction devtoolsInitApp(app, version) {\r\n emit(\"app:init\" /* APP_INIT */, app, version, {\r\n Fragment,\r\n Text,\r\n Comment,\r\n Static\r\n });\r\n}\r\nfunction devtoolsUnmountApp(app) {\r\n emit(\"app:unmount\" /* APP_UNMOUNT */, app);\r\n}\r\nconst devtoolsComponentAdded = /*#__PURE__*/ createDevtoolsComponentHook(\"component:added\" /* COMPONENT_ADDED */);\r\nconst devtoolsComponentUpdated = \r\n/*#__PURE__*/ createDevtoolsComponentHook(\"component:updated\" /* COMPONENT_UPDATED */);\r\nconst devtoolsComponentRemoved = \r\n/*#__PURE__*/ createDevtoolsComponentHook(\"component:removed\" /* COMPONENT_REMOVED */);\r\nfunction createDevtoolsComponentHook(hook) {\r\n return (component) => {\r\n emit(hook, component.appContext.app, component.uid, component.parent ? component.parent.uid : undefined, component);\r\n };\r\n}\r\nconst devtoolsPerfStart = /*#__PURE__*/ createDevtoolsPerformanceHook(\"perf:start\" /* PERFORMANCE_START */);\r\nconst devtoolsPerfEnd = /*#__PURE__*/ createDevtoolsPerformanceHook(\"perf:end\" /* PERFORMANCE_END */);\r\nfunction createDevtoolsPerformanceHook(hook) {\r\n return (component, type, time) => {\r\n emit(hook, component.appContext.app, component.uid, component, type, time);\r\n };\r\n}\r\nfunction devtoolsComponentEmit(component, event, params) {\r\n emit(\"component:emit\" /* COMPONENT_EMIT */, component.appContext.app, component, event, params);\r\n}\n\nfunction emit$1(instance, event, ...rawArgs) {\r\n if (instance.isUnmounted)\r\n return;\r\n const props = instance.vnode.props || EMPTY_OBJ;\r\n if ((process.env.NODE_ENV !== 'production')) {\r\n const { emitsOptions, propsOptions: [propsOptions] } = instance;\r\n if (emitsOptions) {\r\n if (!(event in emitsOptions) &&\r\n !(false )) {\r\n if (!propsOptions || !(toHandlerKey(event) in propsOptions)) {\r\n warn(`Component emitted event \"${event}\" but it is neither declared in ` +\r\n `the emits option nor as an \"${toHandlerKey(event)}\" prop.`);\r\n }\r\n }\r\n else {\r\n const validator = emitsOptions[event];\r\n if (isFunction(validator)) {\r\n const isValid = validator(...rawArgs);\r\n if (!isValid) {\r\n warn(`Invalid event arguments: event validation failed for event \"${event}\".`);\r\n }\r\n }\r\n }\r\n }\r\n }\r\n let args = rawArgs;\r\n const isModelListener = event.startsWith('update:');\r\n // for v-model update:xxx events, apply modifiers on args\r\n const modelArg = isModelListener && event.slice(7);\r\n if (modelArg && modelArg in props) {\r\n const modifiersKey = `${modelArg === 'modelValue' ? 'model' : modelArg}Modifiers`;\r\n const { number, trim } = props[modifiersKey] || EMPTY_OBJ;\r\n if (trim) {\r\n args = rawArgs.map(a => a.trim());\r\n }\r\n if (number) {\r\n args = rawArgs.map(toNumber);\r\n }\r\n }\r\n if ((process.env.NODE_ENV !== 'production') || __VUE_PROD_DEVTOOLS__) {\r\n devtoolsComponentEmit(instance, event, args);\r\n }\r\n if ((process.env.NODE_ENV !== 'production')) {\r\n const lowerCaseEvent = event.toLowerCase();\r\n if (lowerCaseEvent !== event && props[toHandlerKey(lowerCaseEvent)]) {\r\n warn(`Event \"${lowerCaseEvent}\" is emitted in component ` +\r\n `${formatComponentName(instance, instance.type)} but the handler is registered for \"${event}\". ` +\r\n `Note that HTML attributes are case-insensitive and you cannot use ` +\r\n `v-on to listen to camelCase events when using in-DOM templates. ` +\r\n `You should probably use \"${hyphenate(event)}\" instead of \"${event}\".`);\r\n }\r\n }\r\n let handlerName;\r\n let handler = props[(handlerName = toHandlerKey(event))] ||\r\n // also try camelCase event handler (#2249)\r\n props[(handlerName = toHandlerKey(camelize(event)))];\r\n // for v-model update:xxx events, also trigger kebab-case equivalent\r\n // for props passed via kebab-case\r\n if (!handler && isModelListener) {\r\n handler = props[(handlerName = toHandlerKey(hyphenate(event)))];\r\n }\r\n if (handler) {\r\n callWithAsyncErrorHandling(handler, instance, 6 /* COMPONENT_EVENT_HANDLER */, args);\r\n }\r\n const onceHandler = props[handlerName + `Once`];\r\n if (onceHandler) {\r\n if (!instance.emitted) {\r\n instance.emitted = {};\r\n }\r\n else if (instance.emitted[handlerName]) {\r\n return;\r\n }\r\n instance.emitted[handlerName] = true;\r\n callWithAsyncErrorHandling(onceHandler, instance, 6 /* COMPONENT_EVENT_HANDLER */, args);\r\n }\r\n}\r\nfunction normalizeEmitsOptions(comp, appContext, asMixin = false) {\r\n const cache = appContext.emitsCache;\r\n const cached = cache.get(comp);\r\n if (cached !== undefined) {\r\n return cached;\r\n }\r\n const raw = comp.emits;\r\n let normalized = {};\r\n // apply mixin/extends props\r\n let hasExtends = false;\r\n if (__VUE_OPTIONS_API__ && !isFunction(comp)) {\r\n const extendEmits = (raw) => {\r\n const normalizedFromExtend = normalizeEmitsOptions(raw, appContext, true);\r\n if (normalizedFromExtend) {\r\n hasExtends = true;\r\n extend(normalized, normalizedFromExtend);\r\n }\r\n };\r\n if (!asMixin && appContext.mixins.length) {\r\n appContext.mixins.forEach(extendEmits);\r\n }\r\n if (comp.extends) {\r\n extendEmits(comp.extends);\r\n }\r\n if (comp.mixins) {\r\n comp.mixins.forEach(extendEmits);\r\n }\r\n }\r\n if (!raw && !hasExtends) {\r\n cache.set(comp, null);\r\n return null;\r\n }\r\n if (isArray(raw)) {\r\n raw.forEach(key => (normalized[key] = null));\r\n }\r\n else {\r\n extend(normalized, raw);\r\n }\r\n cache.set(comp, normalized);\r\n return normalized;\r\n}\r\n// Check if an incoming prop key is a declared emit event listener.\r\n// e.g. With `emits: { click: null }`, props named `onClick` and `onclick` are\r\n// both considered matched listeners.\r\nfunction isEmitListener(options, key) {\r\n if (!options || !isOn(key)) {\r\n return false;\r\n }\r\n key = key.slice(2).replace(/Once$/, '');\r\n return (hasOwn(options, key[0].toLowerCase() + key.slice(1)) ||\r\n hasOwn(options, hyphenate(key)) ||\r\n hasOwn(options, key));\r\n}\n\n/**\r\n * mark the current rendering instance for asset resolution (e.g.\r\n * resolveComponent, resolveDirective) during render\r\n */\r\nlet currentRenderingInstance = null;\r\nlet currentScopeId = null;\r\n/**\r\n * Note: rendering calls maybe nested. The function returns the parent rendering\r\n * instance if present, which should be restored after the render is done:\r\n *\r\n * ```js\r\n * const prev = setCurrentRenderingInstance(i)\r\n * // ...render\r\n * setCurrentRenderingInstance(prev)\r\n * ```\r\n */\r\nfunction setCurrentRenderingInstance(instance) {\r\n const prev = currentRenderingInstance;\r\n currentRenderingInstance = instance;\r\n currentScopeId = (instance && instance.type.__scopeId) || null;\r\n return prev;\r\n}\r\n/**\r\n * Set scope id when creating hoisted vnodes.\r\n * @private compiler helper\r\n */\r\nfunction pushScopeId(id) {\r\n currentScopeId = id;\r\n}\r\n/**\r\n * Technically we no longer need this after 3.0.8 but we need to keep the same\r\n * API for backwards compat w/ code generated by compilers.\r\n * @private\r\n */\r\nfunction popScopeId() {\r\n currentScopeId = null;\r\n}\r\n/**\r\n * Only for backwards compat\r\n * @private\r\n */\r\nconst withScopeId = (_id) => withCtx;\r\n/**\r\n * Wrap a slot function to memoize current rendering instance\r\n * @private compiler helper\r\n */\r\nfunction withCtx(fn, ctx = currentRenderingInstance, isNonScopedSlot // false only\r\n) {\r\n if (!ctx)\r\n return fn;\r\n // already normalized\r\n if (fn._n) {\r\n return fn;\r\n }\r\n const renderFnWithContext = (...args) => {\r\n // If a user calls a compiled slot inside a template expression (#1745), it\r\n // can mess up block tracking, so by default we disable block tracking and\r\n // force bail out when invoking a compiled slot (indicated by the ._d flag).\r\n // This isn't necessary if rendering a compiled `<slot>`, so we flip the\r\n // ._d flag off when invoking the wrapped fn inside `renderSlot`.\r\n if (renderFnWithContext._d) {\r\n setBlockTracking(-1);\r\n }\r\n const prevInstance = setCurrentRenderingInstance(ctx);\r\n const res = fn(...args);\r\n setCurrentRenderingInstance(prevInstance);\r\n if (renderFnWithContext._d) {\r\n setBlockTracking(1);\r\n }\r\n if ((process.env.NODE_ENV !== 'production') || __VUE_PROD_DEVTOOLS__) {\r\n devtoolsComponentUpdated(ctx);\r\n }\r\n return res;\r\n };\r\n // mark normalized to avoid duplicated wrapping\r\n renderFnWithContext._n = true;\r\n // mark this as compiled by default\r\n // this is used in vnode.ts -> normalizeChildren() to set the slot\r\n // rendering flag.\r\n renderFnWithContext._c = true;\r\n // disable block tracking by default\r\n renderFnWithContext._d = true;\r\n return renderFnWithContext;\r\n}\n\n/**\r\n * dev only flag to track whether $attrs was used during render.\r\n * If $attrs was used during render then the warning for failed attrs\r\n * fallthrough can be suppressed.\r\n */\r\nlet accessedAttrs = false;\r\nfunction markAttrsAccessed() {\r\n accessedAttrs = true;\r\n}\r\nfunction renderComponentRoot(instance) {\r\n const { type: Component, vnode, proxy, withProxy, props, propsOptions: [propsOptions], slots, attrs, emit, render, renderCache, data, setupState, ctx, inheritAttrs } = instance;\r\n let result;\r\n let fallthroughAttrs;\r\n const prev = setCurrentRenderingInstance(instance);\r\n if ((process.env.NODE_ENV !== 'production')) {\r\n accessedAttrs = false;\r\n }\r\n try {\r\n if (vnode.shapeFlag & 4 /* STATEFUL_COMPONENT */) {\r\n // withProxy is a proxy with a different `has` trap only for\r\n // runtime-compiled render functions using `with` block.\r\n const proxyToUse = withProxy || proxy;\r\n result = normalizeVNode(render.call(proxyToUse, proxyToUse, renderCache, props, setupState, data, ctx));\r\n fallthroughAttrs = attrs;\r\n }\r\n else {\r\n // functional\r\n const render = Component;\r\n // in dev, mark attrs accessed if optional props (attrs === props)\r\n if ((process.env.NODE_ENV !== 'production') && attrs === props) {\r\n markAttrsAccessed();\r\n }\r\n result = normalizeVNode(render.length > 1\r\n ? render(props, (process.env.NODE_ENV !== 'production')\r\n ? {\r\n get attrs() {\r\n markAttrsAccessed();\r\n return attrs;\r\n },\r\n slots,\r\n emit\r\n }\r\n : { attrs, slots, emit })\r\n : render(props, null /* we know it doesn't need it */));\r\n fallthroughAttrs = Component.props\r\n ? attrs\r\n : getFunctionalFallthrough(attrs);\r\n }\r\n }\r\n catch (err) {\r\n blockStack.length = 0;\r\n handleError(err, instance, 1 /* RENDER_FUNCTION */);\r\n result = createVNode(Comment);\r\n }\r\n // attr merging\r\n // in dev mode, comments are preserved, and it's possible for a template\r\n // to have comments along side the root element which makes it a fragment\r\n let root = result;\r\n let setRoot = undefined;\r\n if ((process.env.NODE_ENV !== 'production') &&\r\n result.patchFlag > 0 &&\r\n result.patchFlag & 2048 /* DEV_ROOT_FRAGMENT */) {\r\n [root, setRoot] = getChildRoot(result);\r\n }\r\n if (fallthroughAttrs && inheritAttrs !== false) {\r\n const keys = Object.keys(fallthroughAttrs);\r\n const { shapeFlag } = root;\r\n if (keys.length) {\r\n if (shapeFlag & (1 /* ELEMENT */ | 6 /* COMPONENT */)) {\r\n if (propsOptions && keys.some(isModelListener)) {\r\n // If a v-model listener (onUpdate:xxx) has a corresponding declared\r\n // prop, it indicates this component expects to handle v-model and\r\n // it should not fallthrough.\r\n // related: #1543, #1643, #1989\r\n fallthroughAttrs = filterModelListeners(fallthroughAttrs, propsOptions);\r\n }\r\n root = cloneVNode(root, fallthroughAttrs);\r\n }\r\n else if ((process.env.NODE_ENV !== 'production') && !accessedAttrs && root.type !== Comment) {\r\n const allAttrs = Object.keys(attrs);\r\n const eventAttrs = [];\r\n const extraAttrs = [];\r\n for (let i = 0, l = allAttrs.length; i < l; i++) {\r\n const key = allAttrs[i];\r\n if (isOn(key)) {\r\n // ignore v-model handlers when they fail to fallthrough\r\n if (!isModelListener(key)) {\r\n // remove `on`, lowercase first letter to reflect event casing\r\n // accurately\r\n eventAttrs.push(key[2].toLowerCase() + key.slice(3));\r\n }\r\n }\r\n else {\r\n extraAttrs.push(key);\r\n }\r\n }\r\n if (extraAttrs.length) {\r\n warn(`Extraneous non-props attributes (` +\r\n `${extraAttrs.join(', ')}) ` +\r\n `were passed to component but could not be automatically inherited ` +\r\n `because component renders fragment or text root nodes.`);\r\n }\r\n if (eventAttrs.length) {\r\n warn(`Extraneous non-emits event listeners (` +\r\n `${eventAttrs.join(', ')}) ` +\r\n `were passed to component but could not be automatically inherited ` +\r\n `because component renders fragment or text root nodes. ` +\r\n `If the listener is intended to be a component custom event listener only, ` +\r\n `declare it using the \"emits\" option.`);\r\n }\r\n }\r\n }\r\n }\r\n // inherit directives\r\n if (vnode.dirs) {\r\n if ((process.env.NODE_ENV !== 'production') && !isElementRoot(root)) {\r\n warn(`Runtime directive used on component with non-element root node. ` +\r\n `The directives will not function as intended.`);\r\n }\r\n // clone before mutating since the root may be a hoisted vnode\r\n root = cloneVNode(root);\r\n root.dirs = root.dirs ? root.dirs.concat(vnode.dirs) : vnode.dirs;\r\n }\r\n // inherit transition data\r\n if (vnode.transition) {\r\n if ((process.env.NODE_ENV !== 'production') && !isElementRoot(root)) {\r\n warn(`Component inside <Transition> renders non-element root node ` +\r\n `that cannot be animated.`);\r\n }\r\n root.transition = vnode.transition;\r\n }\r\n if ((process.env.NODE_ENV !== 'production') && setRoot) {\r\n setRoot(root);\r\n }\r\n else {\r\n result = root;\r\n }\r\n setCurrentRenderingInstance(prev);\r\n return result;\r\n}\r\n/**\r\n * dev only\r\n * In dev mode, template root level comments are rendered, which turns the\r\n * template into a fragment root, but we need to locate the single element\r\n * root for attrs and scope id processing.\r\n */\r\nconst getChildRoot = (vnode) => {\r\n const rawChildren = vnode.children;\r\n const dynamicChildren = vnode.dynamicChildren;\r\n const childRoot = filterSingleRoot(rawChildren);\r\n if (!childRoot) {\r\n return [vnode, undefined];\r\n }\r\n const index = rawChildren.indexOf(childRoot);\r\n const dynamicIndex = dynamicChildren ? dynamicChildren.indexOf(childRoot) : -1;\r\n const setRoot = (updatedRoot) => {\r\n rawChildren[index] = updatedRoot;\r\n if (dynamicChildren) {\r\n if (dynamicIndex > -1) {\r\n dynamicChildren[dynamicIndex] = updatedRoot;\r\n }\r\n else if (updatedRoot.patchFlag > 0) {\r\n vnode.dynamicChildren = [...dynamicChildren, updatedRoot];\r\n }\r\n }\r\n };\r\n return [normalizeVNode(childRoot), setRoot];\r\n};\r\nfunction filterSingleRoot(children) {\r\n let singleRoot;\r\n for (let i = 0; i < children.length; i++) {\r\n const child = children[i];\r\n if (isVNode(child)) {\r\n // ignore user comment\r\n if (child.type !== Comment || child.children === 'v-if') {\r\n if (singleRoot) {\r\n // has more than 1 non-comment child, return now\r\n return;\r\n }\r\n else {\r\n singleRoot = child;\r\n }\r\n }\r\n }\r\n else {\r\n return;\r\n }\r\n }\r\n return singleRoot;\r\n}\r\nconst getFunctionalFallthrough = (attrs) => {\r\n let res;\r\n for (const key in attrs) {\r\n if (key === 'class' || key === 'style' || isOn(key)) {\r\n (res || (res = {}))[key] = attrs[key];\r\n }\r\n }\r\n return res;\r\n};\r\nconst filterModelListeners = (attrs, props) => {\r\n const res = {};\r\n for (const key in attrs) {\r\n if (!isModelListener(key) || !(key.slice(9) in props)) {\r\n res[key] = attrs[key];\r\n }\r\n }\r\n return res;\r\n};\r\nconst isElementRoot = (vnode) => {\r\n return (vnode.shapeFlag & (6 /* COMPONENT */ | 1 /* ELEMENT */) ||\r\n vnode.type === Comment // potential v-if branch switch\r\n );\r\n};\r\nfunction shouldUpdateComponent(prevVNode, nextVNode, optimized) {\r\n const { props: prevProps, children: prevChildren, component } = prevVNode;\r\n const { props: nextProps, children: nextChildren, patchFlag } = nextVNode;\r\n const emits = component.emitsOptions;\r\n // Parent component's render function was hot-updated. Since this may have\r\n // caused the child component's slots content to have changed, we need to\r\n // force the child to update as well.\r\n if ((process.env.NODE_ENV !== 'production') && (prevChildren || nextChildren) && isHmrUpdating) {\r\n return true;\r\n }\r\n // force child update for runtime directive or transition on component vnode.\r\n if (nextVNode.dirs || nextVNode.transition) {\r\n return true;\r\n }\r\n if (optimized && patchFlag >= 0) {\r\n if (patchFlag & 1024 /* DYNAMIC_SLOTS */) {\r\n // slot content that references values that might have changed,\r\n // e.g. in a v-for\r\n return true;\r\n }\r\n if (patchFlag & 16 /* FULL_PROPS */) {\r\n if (!prevProps) {\r\n return !!nextProps;\r\n }\r\n // presence of this flag indicates props are always non-null\r\n return hasPropsChanged(prevProps, nextProps, emits);\r\n }\r\n else if (patchFlag & 8 /* PROPS */) {\r\n const dynamicProps = nextVNode.dynamicProps;\r\n for (let i = 0; i < dynamicProps.length; i++) {\r\n const key = dynamicProps[i];\r\n if (nextProps[key] !== prevProps[key] &&\r\n !isEmitListener(emits, key)) {\r\n return true;\r\n }\r\n }\r\n }\r\n }\r\n else {\r\n // this path is only taken by manually written render functions\r\n // so presence of any children leads to a forced update\r\n if (prevChildren || nextChildren) {\r\n if (!nextChildren || !nextChildren.$stable) {\r\n return true;\r\n }\r\n }\r\n if (prevProps === nextProps) {\r\n return false;\r\n }\r\n if (!prevProps) {\r\n return !!nextProps;\r\n }\r\n if (!nextProps) {\r\n return true;\r\n }\r\n return hasPropsChanged(prevProps, nextProps, emits);\r\n }\r\n return false;\r\n}\r\nfunction hasPropsChanged(prevProps, nextProps, emitsOptions) {\r\n const nextKeys = Object.keys(nextProps);\r\n if (nextKeys.length !== Object.keys(prevProps).length) {\r\n return true;\r\n }\r\n for (let i = 0; i < nextKeys.length; i++) {\r\n const key = nextKeys[i];\r\n if (nextProps[key] !== prevProps[key] &&\r\n !isEmitListener(emitsOptions, key)) {\r\n return true;\r\n }\r\n }\r\n return false;\r\n}\r\nfunction updateHOCHostEl({ vnode, parent }, el // HostNode\r\n) {\r\n while (parent && parent.subTree === vnode) {\r\n (vnode = parent.vnode).el = el;\r\n parent = parent.parent;\r\n }\r\n}\n\nconst isSuspense = (type) => type.__isSuspense;\r\n// Suspense exposes a component-like API, and is treated like a component\r\n// in the compiler, but internally it's a special built-in type that hooks\r\n// directly into the renderer.\r\nconst SuspenseImpl = {\r\n name: 'Suspense',\r\n // In order to make Suspense tree-shakable, we need to avoid importing it\r\n // directly in the renderer. The renderer checks for the __isSuspense flag\r\n // on a vnode's type and calls the `process` method, passing in renderer\r\n // internals.\r\n __isSuspense: true,\r\n process(n1, n2, container, anchor, parentComponent, parentSuspense, isSVG, slotScopeIds, optimized, \r\n // platform-specific impl passed from renderer\r\n rendererInternals) {\r\n if (n1 == null) {\r\n mountSuspense(n2, container, anchor, parentComponent, parentSuspense, isSVG, slotScopeIds, optimized, rendererInternals);\r\n }\r\n else {\r\n patchSuspense(n1, n2, container, anchor, parentComponent, isSVG, slotScopeIds, optimized, rendererInternals);\r\n }\r\n },\r\n hydrate: hydrateSuspense,\r\n create: createSuspenseBoundary,\r\n normalize: normalizeSuspenseChildren\r\n};\r\n// Force-casted public typing for h and TSX props inference\r\nconst Suspense = (SuspenseImpl );\r\nfunction triggerEvent(vnode, name) {\r\n const eventListener = vnode.props && vnode.props[name];\r\n if (isFunction(eventListener)) {\r\n eventListener();\r\n }\r\n}\r\nfunction mountSuspense(vnode, container, anchor, parentComponent, parentSuspense, isSVG, slotScopeIds, optimized, rendererInternals) {\r\n const { p: patch, o: { createElement } } = rendererInternals;\r\n const hiddenContainer = createElement('div');\r\n const suspense = (vnode.suspense = createSuspenseBoundary(vnode, parentSuspense, parentComponent, container, hiddenContainer, anchor, isSVG, slotScopeIds, optimized, rendererInternals));\r\n // start mounting the content subtree in an off-dom container\r\n patch(null, (suspense.pendingBranch = vnode.ssContent), hiddenContainer, null, parentComponent, suspense, isSVG, slotScopeIds);\r\n // now check if we have encountered any async deps\r\n if (suspense.deps > 0) {\r\n // has async\r\n // invoke @fallback event\r\n triggerEvent(vnode, 'onPending');\r\n triggerEvent(vnode, 'onFallback');\r\n // mount the fallback tree\r\n patch(null, vnode.ssFallback, container, anchor, parentComponent, null, // fallback tree will not have suspense context\r\n isSVG, slotScopeIds);\r\n setActiveBranch(suspense, vnode.ssFallback);\r\n }\r\n else {\r\n // Suspense has no async deps. Just resolve.\r\n suspense.resolve();\r\n }\r\n}\r\nfunction patchSuspense(n1, n2, container, anchor, parentComponent, isSVG, slotScopeIds, optimized, { p: patch, um: unmount, o: { createElement } }) {\r\n const suspense = (n2.suspense = n1.suspense);\r\n suspense.vnode = n2;\r\n n2.el = n1.el;\r\n const newBranch = n2.ssContent;\r\n const newFallback = n2.ssFallback;\r\n const { activeBranch, pendingBranch, isInFallback, isHydrating } = suspense;\r\n if (pendingBranch) {\r\n suspense.pendingBranch = newBranch;\r\n if (isSameVNodeType(newBranch, pendingBranch)) {\r\n // same root type but content may have changed.\r\n patch(pendingBranch, newBranch, suspense.hiddenContainer, null, parentComponent, suspense, isSVG, slotScopeIds, optimized);\r\n if (suspense.deps <= 0) {\r\n suspense.resolve();\r\n }\r\n else if (isInFallback) {\r\n patch(activeBranch, newFallback, container, anchor, parentComponent, null, // fallback tree will not have suspense context\r\n isSVG, slotScopeIds, optimized);\r\n setActiveBranch(suspense, newFallback);\r\n }\r\n }\r\n else {\r\n // toggled before pending tree is resolved\r\n suspense.pendingId++;\r\n if (isHydrating) {\r\n // if toggled before hydration is finished, the current DOM tree is\r\n // no longer valid. set it as the active branch so it will be unmounted\r\n // when resolved\r\n suspense.isHydrating = false;\r\n suspense.activeBranch = pendingBranch;\r\n }\r\n else {\r\n unmount(pendingBranch, parentComponent, suspense);\r\n }\r\n // increment pending ID. this is used to invalidate async callbacks\r\n // reset suspense state\r\n suspense.deps = 0;\r\n // discard effects from pending branch\r\n suspense.effects.length = 0;\r\n // discard previous container\r\n suspense.hiddenContainer = createElement('div');\r\n if (isInFallback) {\r\n // already in fallback state\r\n patch(null, newBranch, suspense.hiddenContainer, null, parentComponent, suspense, isSVG, slotScopeIds, optimized);\r\n if (suspense.deps <= 0) {\r\n suspense.resolve();\r\n }\r\n else {\r\n patch(activeBranch, newFallback, container, anchor, parentComponent, null, // fallback tree will not have suspense context\r\n isSVG, slotScopeIds, optimized);\r\n setActiveBranch(suspense, newFallback);\r\n }\r\n }\r\n else if (activeBranch && isSameVNodeType(newBranch, activeBranch)) {\r\n // toggled \"back\" to current active branch\r\n patch(activeBranch, newBranch, container, anchor, parentComponent, suspense, isSVG, slotScopeIds, optimized);\r\n // force resolve\r\n suspense.resolve(true);\r\n }\r\n else {\r\n // switched to a 3rd branch\r\n patch(null, newBranch, suspense.hiddenContainer, null, parentComponent, suspense, isSVG, slotScopeIds, optimized);\r\n if (suspense.deps <= 0) {\r\n suspense.resolve();\r\n }\r\n }\r\n }\r\n }\r\n else {\r\n if (activeBranch && isSameVNodeType(newBranch, activeBranch)) {\r\n // root did not change, just normal patch\r\n patch(activeBranch, newBranch, container, anchor, parentComponent, suspense, isSVG, slotScopeIds, optimized);\r\n setActiveBranch(suspense, newBranch);\r\n }\r\n else {\r\n // root node toggled\r\n // invoke @pending event\r\n triggerEvent(n2, 'onPending');\r\n // mount pending branch in off-dom container\r\n suspense.pendingBranch = newBranch;\r\n suspense.pendingId++;\r\n patch(null, newBranch, suspense.hiddenContainer, null, parentComponent, suspense, isSVG, slotScopeIds, optimized);\r\n if (suspense.deps <= 0) {\r\n // incoming branch has no async deps, resolve now.\r\n suspense.resolve();\r\n }\r\n else {\r\n const { timeout, pendingId } = suspense;\r\n if (timeout > 0) {\r\n setTimeout(() => {\r\n if (suspense.pendingId === pendingId) {\r\n suspense.fallback(newFallback);\r\n }\r\n }, timeout);\r\n }\r\n else if (timeout === 0) {\r\n suspense.fallback(newFallback);\r\n }\r\n }\r\n }\r\n }\r\n}\r\nlet hasWarned = false;\r\nfunction createSuspenseBoundary(vnode, parent, parentComponent, container, hiddenContainer, anchor, isSVG, slotScopeIds, optimized, rendererInternals, isHydrating = false) {\r\n /* istanbul ignore if */\r\n if ((process.env.NODE_ENV !== 'production') && !false && !hasWarned) {\r\n hasWarned = true;\r\n // @ts-ignore `console.info` cannot be null error\r\n console[console.info ? 'info' : 'log'](`<Suspense> is an experimental feature and its API will likely change.`);\r\n }\r\n const { p: patch, m: move, um: unmount, n: next, o: { parentNode, remove } } = rendererInternals;\r\n const timeout = toNumber(vnode.props && vnode.props.timeout);\r\n const suspense = {\r\n vnode,\r\n parent,\r\n parentComponent,\r\n isSVG,\r\n container,\r\n hiddenContainer,\r\n anchor,\r\n deps: 0,\r\n pendingId: 0,\r\n timeout: typeof timeout === 'number' ? timeout : -1,\r\n activeBranch: null,\r\n pendingBranch: null,\r\n isInFallback: true,\r\n isHydrating,\r\n isUnmounted: false,\r\n effects: [],\r\n resolve(resume = false) {\r\n if ((process.env.NODE_ENV !== 'production')) {\r\n if (!resume && !suspense.pendingBranch) {\r\n throw new Error(`suspense.resolve() is called without a pending branch.`);\r\n }\r\n if (suspense.isUnmounted) {\r\n throw new Error(`suspense.resolve() is called on an already unmounted suspense boundary.`);\r\n }\r\n }\r\n const { vnode, activeBranch, pendingBranch, pendingId, effects, parentComponent, container } = suspense;\r\n if (suspense.isHydrating) {\r\n suspense.isHydrating = false;\r\n }\r\n else if (!resume) {\r\n const delayEnter = activeBranch &&\r\n pendingBranch.transition &&\r\n pendingBranch.transition.mode === 'out-in';\r\n if (delayEnter) {\r\n activeBranch.transition.afterLeave = () => {\r\n if (pendingId === suspense.pendingId) {\r\n move(pendingBranch, container, anchor, 0 /* ENTER */);\r\n }\r\n };\r\n }\r\n // this is initial anchor on mount\r\n let { anchor } = suspense;\r\n // unmount current active tree\r\n if (activeBranch) {\r\n // if the fallback tree was mounted, it may have been moved\r\n // as part of a parent suspense. get the latest anchor for insertion\r\n anchor = next(activeBranch);\r\n unmount(activeBranch, parentComponent, suspense, true);\r\n }\r\n if (!delayEnter) {\r\n // move content from off-dom container to actual container\r\n move(pendingBranch, container, anchor, 0 /* ENTER */);\r\n }\r\n }\r\n setActiveBranch(suspense, pendingBranch);\r\n suspense.pendingBranch = null;\r\n suspense.isInFallback = false;\r\n // flush buffered effects\r\n // check if there is a pending parent suspense\r\n let parent = suspense.parent;\r\n let hasUnresolvedAncestor = false;\r\n while (parent) {\r\n if (parent.pendingBranch) {\r\n // found a pending parent suspense, merge buffered post jobs\r\n // into that parent\r\n parent.effects.push(...effects);\r\n hasUnresolvedAncestor = true;\r\n break;\r\n }\r\n parent = parent.parent;\r\n }\r\n // no pending parent suspense, flush all jobs\r\n if (!hasUnresolvedAncestor) {\r\n queuePostFlushCb(effects);\r\n }\r\n suspense.effects = [];\r\n // invoke @resolve event\r\n triggerEvent(vnode, 'onResolve');\r\n },\r\n fallback(fallbackVNode) {\r\n if (!suspense.pendingBranch) {\r\n return;\r\n }\r\n const { vnode, activeBranch, parentComponent, container, isSVG } = suspense;\r\n // invoke @fallback event\r\n triggerEvent(vnode, 'onFallback');\r\n const anchor = next(activeBranch);\r\n const mountFallback = () => {\r\n if (!suspense.isInFallback) {\r\n return;\r\n }\r\n // mount the fallback tree\r\n patch(null, fallbackVNode, container, anchor, parentComponent, null, // fallback tree will not have suspense context\r\n isSVG, slotScopeIds, optimized);\r\n setActiveBranch(suspense, fallbackVNode);\r\n };\r\n const delayEnter = fallbackVNode.transition && fallbackVNode.transition.mode === 'out-in';\r\n if (delayEnter) {\r\n activeBranch.transition.afterLeave = mountFallback;\r\n }\r\n suspense.isInFallback = true;\r\n // unmount current active branch\r\n unmount(activeBranch, parentComponent, null, // no suspense so unmount hooks fire now\r\n true // shouldRemove\r\n );\r\n if (!delayEnter) {\r\n mountFallback();\r\n }\r\n },\r\n move(container, anchor, type) {\r\n suspense.activeBranch &&\r\n move(suspense.activeBranch, container, anchor, type);\r\n suspense.container = container;\r\n },\r\n next() {\r\n return suspense.activeBranch && next(suspense.activeBranch);\r\n },\r\n registerDep(instance, setupRenderEffect) {\r\n const isInPendingSuspense = !!suspense.pendingBranch;\r\n if (isInPendingSuspense) {\r\n suspense.deps++;\r\n }\r\n const hydratedEl = instance.vnode.el;\r\n instance\r\n .asyncDep.catch(err => {\r\n handleError(err, instance, 0 /* SETUP_FUNCTION */);\r\n })\r\n .then(asyncSetupResult => {\r\n // retry when the setup() promise resolves.\r\n // component may have been unmounted before resolve.\r\n if (instance.isUnmounted ||\r\n suspense.isUnmounted ||\r\n suspense.pendingId !== instance.suspenseId) {\r\n return;\r\n }\r\n // retry from this component\r\n instance.asyncResolved = true;\r\n const { vnode } = instance;\r\n if ((process.env.NODE_ENV !== 'production')) {\r\n pushWarningContext(vnode);\r\n }\r\n handleSetupResult(instance, asyncSetupResult, false);\r\n if (hydratedEl) {\r\n // vnode may have been replaced if an update happened before the\r\n // async dep is resolved.\r\n vnode.el = hydratedEl;\r\n }\r\n const placeholder = !hydratedEl && instance.subTree.el;\r\n setupRenderEffect(instance, vnode, \r\n // component may have been moved before resolve.\r\n // if this is not a hydration, instance.subTree will be the comment\r\n // placeholder.\r\n parentNode(hydratedEl || instance.subTree.el), \r\n // anchor will not be used if this is hydration, so only need to\r\n // consider the comment placeholder case.\r\n hydratedEl ? null : next(instance.subTree), suspense, isSVG, optimized);\r\n if (placeholder) {\r\n remove(placeholder);\r\n }\r\n updateHOCHostEl(instance, vnode.el);\r\n if ((process.env.NODE_ENV !== 'production')) {\r\n popWarningContext();\r\n }\r\n // only decrease deps count if suspense is not already resolved\r\n if (isInPendingSuspense && --suspense.deps === 0) {\r\n suspense.resolve();\r\n }\r\n });\r\n },\r\n unmount(parentSuspense, doRemove) {\r\n suspense.isUnmounted = true;\r\n if (suspense.activeBranch) {\r\n unmount(suspense.activeBranch, parentComponent, parentSuspense, doRemove);\r\n }\r\n if (suspense.pendingBranch) {\r\n unmount(suspense.pendingBranch, parentComponent, parentSuspense, doRemove);\r\n }\r\n }\r\n };\r\n return suspense;\r\n}\r\nfunction hydrateSuspense(node, vnode, parentComponent, parentSuspense, isSVG, slotScopeIds, optimized, rendererInternals, hydrateNode) {\r\n /* eslint-disable no-restricted-globals */\r\n const suspense = (vnode.suspense = createSuspenseBoundary(vnode, parentSuspense, parentComponent, node.parentNode, document.createElement('div'), null, isSVG, slotScopeIds, optimized, rendererInternals, true /* hydrating */));\r\n // there are two possible scenarios for server-rendered suspense:\r\n // - success: ssr content should be fully resolved\r\n // - failure: ssr content should be the fallback branch.\r\n // however, on the client we don't really know if it has failed or not\r\n // attempt to hydrate the DOM assuming it has succeeded, but we still\r\n // need to construct a suspense boundary first\r\n const result = hydrateNode(node, (suspense.pendingBranch = vnode.ssContent), parentComponent, suspense, slotScopeIds, optimized);\r\n if (suspense.deps === 0) {\r\n suspense.resolve();\r\n }\r\n return result;\r\n /* eslint-enable no-restricted-globals */\r\n}\r\nfunction normalizeSuspenseChildren(vnode) {\r\n const { shapeFlag, children } = vnode;\r\n const isSlotChildren = shapeFlag & 32 /* SLOTS_CHILDREN */;\r\n vnode.ssContent = normalizeSuspenseSlot(isSlotChildren ? children.default : children);\r\n vnode.ssFallback = isSlotChildren\r\n ? normalizeSuspenseSlot(children.fallback)\r\n : createVNode(Comment);\r\n}\r\nfunction normalizeSuspenseSlot(s) {\r\n let block;\r\n if (isFunction(s)) {\r\n const trackBlock = isBlockTreeEnabled && s._c;\r\n if (trackBlock) {\r\n // disableTracking: false\r\n // allow block tracking for compiled slots\r\n // (see ./componentRenderContext.ts)\r\n s._d = false;\r\n openBlock();\r\n }\r\n s = s();\r\n if (trackBlock) {\r\n s._d = true;\r\n block = currentBlock;\r\n closeBlock();\r\n }\r\n }\r\n if (isArray(s)) {\r\n const singleChild = filterSingleRoot(s);\r\n if ((process.env.NODE_ENV !== 'production') && !singleChild) {\r\n warn(`<Suspense> slots expect a single root node.`);\r\n }\r\n s = singleChild;\r\n }\r\n s = normalizeVNode(s);\r\n if (block && !s.dynamicChildren) {\r\n s.dynamicChildren = block.filter(c => c !== s);\r\n }\r\n return s;\r\n}\r\nfunction queueEffectWithSuspense(fn, suspense) {\r\n if (suspense && suspense.pendingBranch) {\r\n if (isArray(fn)) {\r\n suspense.effects.push(...fn);\r\n }\r\n else {\r\n suspense.effects.push(fn);\r\n }\r\n }\r\n else {\r\n queuePostFlushCb(fn);\r\n }\r\n}\r\nfunction setActiveBranch(suspense, branch) {\r\n suspense.activeBranch = branch;\r\n const { vnode, parentComponent } = suspense;\r\n const el = (vnode.el = branch.el);\r\n // in case suspense is the root node of a component,\r\n // recursively update the HOC el\r\n if (parentComponent && parentComponent.subTree === vnode) {\r\n parentComponent.vnode.el = el;\r\n updateHOCHostEl(parentComponent, el);\r\n }\r\n}\n\nfunction provide(key, value) {\r\n if (!currentInstance) {\r\n if ((process.env.NODE_ENV !== 'production')) {\r\n warn(`provide() can only be used inside setup().`);\r\n }\r\n }\r\n else {\r\n let provides = currentInstance.provides;\r\n // by default an instance inherits its parent's provides object\r\n // but when it needs to provide values of its own, it creates its\r\n // own provides object using parent provides object as prototype.\r\n // this way in `inject` we can simply look up injections from direct\r\n // parent and let the prototype chain do the work.\r\n const parentProvides = currentInstance.parent && currentInstance.parent.provides;\r\n if (parentProvides === provides) {\r\n provides = currentInstance.provides = Object.create(parentProvides);\r\n }\r\n // TS doesn't allow symbol as index type\r\n provides[key] = value;\r\n }\r\n}\r\nfunction inject(key, defaultValue, treatDefaultAsFactory = false) {\r\n // fallback to `currentRenderingInstance` so that this can be called in\r\n // a functional component\r\n const instance = currentInstance || currentRenderingInstance;\r\n if (instance) {\r\n // #2400\r\n // to support `app.use` plugins,\r\n // fallback to appContext's `provides` if the instance is at root\r\n const provides = instance.parent == null\r\n ? instance.vnode.appContext && instance.vnode.appContext.provides\r\n : instance.parent.provides;\r\n if (provides && key in provides) {\r\n // TS doesn't allow symbol as index type\r\n return provides[key];\r\n }\r\n else if (arguments.length > 1) {\r\n return treatDefaultAsFactory && isFunction(defaultValue)\r\n ? defaultValue.call(instance.proxy)\r\n : defaultValue;\r\n }\r\n else if ((process.env.NODE_ENV !== 'production')) {\r\n warn(`injection \"${String(key)}\" not found.`);\r\n }\r\n }\r\n else if ((process.env.NODE_ENV !== 'production')) {\r\n warn(`inject() can only be used inside setup() or functional components.`);\r\n }\r\n}\n\n// Simple effect.\r\nfunction watchEffect(effect, options) {\r\n return doWatch(effect, null, options);\r\n}\r\nfunction watchPostEffect(effect, options) {\r\n return doWatch(effect, null, ((process.env.NODE_ENV !== 'production')\r\n ? Object.assign(Object.assign({}, options), { flush: 'post' }) : { flush: 'post' }));\r\n}\r\nfunction watchSyncEffect(effect, options) {\r\n return doWatch(effect, null, ((process.env.NODE_ENV !== 'production')\r\n ? Object.assign(Object.assign({}, options), { flush: 'sync' }) : { flush: 'sync' }));\r\n}\r\n// initial value for watchers to trigger on undefined initial values\r\nconst INITIAL_WATCHER_VALUE = {};\r\n// implementation\r\nfunction watch(source, cb, options) {\r\n if ((process.env.NODE_ENV !== 'production') && !isFunction(cb)) {\r\n warn(`\\`watch(fn, options?)\\` signature has been moved to a separate API. ` +\r\n `Use \\`watchEffect(fn, options?)\\` instead. \\`watch\\` now only ` +\r\n `supports \\`watch(source, cb, options?) signature.`);\r\n }\r\n return doWatch(source, cb, options);\r\n}\r\nfunction doWatch(source, cb, { immediate, deep, flush, onTrack, onTrigger } = EMPTY_OBJ) {\r\n if ((process.env.NODE_ENV !== 'production') && !cb) {\r\n if (immediate !== undefined) {\r\n warn(`watch() \"immediate\" option is only respected when using the ` +\r\n `watch(source, callback, options?) signature.`);\r\n }\r\n if (deep !== undefined) {\r\n warn(`watch() \"deep\" option is only respected when using the ` +\r\n `watch(source, callback, options?) signature.`);\r\n }\r\n }\r\n const warnInvalidSource = (s) => {\r\n warn(`Invalid watch source: `, s, `A watch source can only be a getter/effect function, a ref, ` +\r\n `a reactive object, or an array of these types.`);\r\n };\r\n const instance = currentInstance;\r\n let getter;\r\n let forceTrigger = false;\r\n let isMultiSource = false;\r\n if (isRef(source)) {\r\n getter = () => source.value;\r\n forceTrigger = isShallow$1(source);\r\n }\r\n else if (isReactive(source)) {\r\n getter = () => source;\r\n deep = true;\r\n }\r\n else if (isArray(source)) {\r\n isMultiSource = true;\r\n forceTrigger = source.some(s => isReactive(s) || isShallow$1(s));\r\n getter = () => source.map(s => {\r\n if (isRef(s)) {\r\n return s.value;\r\n }\r\n else if (isReactive(s)) {\r\n return traverse(s);\r\n }\r\n else if (isFunction(s)) {\r\n return callWithErrorHandling(s, instance, 2 /* WATCH_GETTER */);\r\n }\r\n else {\r\n (process.env.NODE_ENV !== 'production') && warnInvalidSource(s);\r\n }\r\n });\r\n }\r\n else if (isFunction(source)) {\r\n if (cb) {\r\n // getter with cb\r\n getter = () => callWithErrorHandling(source, instance, 2 /* WATCH_GETTER */);\r\n }\r\n else {\r\n // no cb -> simple effect\r\n getter = () => {\r\n if (instance && instance.isUnmounted) {\r\n return;\r\n }\r\n if (cleanup) {\r\n cleanup();\r\n }\r\n return callWithAsyncErrorHandling(source, instance, 3 /* WATCH_CALLBACK */, [onCleanup]);\r\n };\r\n }\r\n }\r\n else {\r\n getter = NOOP;\r\n (process.env.NODE_ENV !== 'production') && warnInvalidSource(source);\r\n }\r\n if (cb && deep) {\r\n const baseGetter = getter;\r\n getter = () => traverse(baseGetter());\r\n }\r\n let cleanup;\r\n let onCleanup = (fn) => {\r\n cleanup = effect.onStop = () => {\r\n callWithErrorHandling(fn, instance, 4 /* WATCH_CLEANUP */);\r\n };\r\n };\r\n // in SSR there is no need to setup an actual effect, and it should be noop\r\n // unless it's eager\r\n if (isInSSRComponentSetup) {\r\n // we will also not call the invalidate callback (+ runner is not set up)\r\n onCleanup = NOOP;\r\n if (!cb) {\r\n getter();\r\n }\r\n else if (immediate) {\r\n callWithAsyncErrorHandling(cb, instance, 3 /* WATCH_CALLBACK */, [\r\n getter(),\r\n isMultiSource ? [] : undefined,\r\n onCleanup\r\n ]);\r\n }\r\n return NOOP;\r\n }\r\n let oldValue = isMultiSource ? [] : INITIAL_WATCHER_VALUE;\r\n const job = () => {\r\n if (!effect.active) {\r\n return;\r\n }\r\n if (cb) {\r\n // watch(source, cb)\r\n const newValue = effect.run();\r\n if (deep ||\r\n forceTrigger ||\r\n (isMultiSource\r\n ? newValue.some((v, i) => hasChanged(v, oldValue[i]))\r\n : hasChanged(newValue, oldValue)) ||\r\n (false )) {\r\n // cleanup before running cb again\r\n if (cleanup) {\r\n cleanup();\r\n }\r\n callWithAsyncErrorHandling(cb, instance, 3 /* WATCH_CALLBACK */, [\r\n newValue,\r\n // pass undefined as the old value when it's changed for the first time\r\n oldValue === INITIAL_WATCHER_VALUE ? undefined : oldValue,\r\n onCleanup\r\n ]);\r\n oldValue = newValue;\r\n }\r\n }\r\n else {\r\n // watchEffect\r\n effect.run();\r\n }\r\n };\r\n // important: mark the job as a watcher callback so that scheduler knows\r\n // it is allowed to self-trigger (#1727)\r\n job.allowRecurse = !!cb;\r\n let scheduler;\r\n if (flush === 'sync') {\r\n scheduler = job; // the scheduler function gets called directly\r\n }\r\n else if (flush === 'post') {\r\n scheduler = () => queuePostRenderEffect(job, instance && instance.suspense);\r\n }\r\n else {\r\n // default: 'pre'\r\n scheduler = () => queuePreFlushCb(job);\r\n }\r\n const effect = new ReactiveEffect(getter, scheduler);\r\n if ((process.env.NODE_ENV !== 'production')) {\r\n effect.onTrack = onTrack;\r\n effect.onTrigger = onTrigger;\r\n }\r\n // initial run\r\n if (cb) {\r\n if (immediate) {\r\n job();\r\n }\r\n else {\r\n oldValue = effect.run();\r\n }\r\n }\r\n else if (flush === 'post') {\r\n queuePostRenderEffect(effect.run.bind(effect), instance && instance.suspense);\r\n }\r\n else {\r\n effect.run();\r\n }\r\n return () => {\r\n effect.stop();\r\n if (instance && instance.scope) {\r\n remove(instance.scope.effects, effect);\r\n }\r\n };\r\n}\r\n// this.$watch\r\nfunction instanceWatch(source, value, options) {\r\n const publicThis = this.proxy;\r\n const getter = isString(source)\r\n ? source.includes('.')\r\n ? createPathGetter(publicThis, source)\r\n : () => publicThis[source]\r\n : source.bind(publicThis, publicThis);\r\n let cb;\r\n if (isFunction(value)) {\r\n cb = value;\r\n }\r\n else {\r\n cb = value.handler;\r\n options = value;\r\n }\r\n const cur = currentInstance;\r\n setCurrentInstance(this);\r\n const res = doWatch(getter, cb.bind(publicThis), options);\r\n if (cur) {\r\n setCurrentInstance(cur);\r\n }\r\n else {\r\n unsetCurrentInstance();\r\n }\r\n return res;\r\n}\r\nfunction createPathGetter(ctx, path) {\r\n const segments = path.split('.');\r\n return () => {\r\n let cur = ctx;\r\n for (let i = 0; i < segments.length && cur; i++) {\r\n cur = cur[segments[i]];\r\n }\r\n return cur;\r\n };\r\n}\r\nfunction traverse(value, seen) {\r\n if (!isObject(value) || value[\"__v_skip\" /* SKIP */]) {\r\n return value;\r\n }\r\n seen = seen || new Set();\r\n if (seen.has(value)) {\r\n return value;\r\n }\r\n seen.add(value);\r\n if (isRef(value)) {\r\n traverse(value.value, seen);\r\n }\r\n else if (isArray(value)) {\r\n for (let i = 0; i < value.length; i++) {\r\n traverse(value[i], seen);\r\n }\r\n }\r\n else if (isSet(value) || isMap(value)) {\r\n value.forEach((v) => {\r\n traverse(v, seen);\r\n });\r\n }\r\n else if (isPlainObject(value)) {\r\n for (const key in value) {\r\n traverse(value[key], seen);\r\n }\r\n }\r\n return value;\r\n}\n\nfunction useTransitionState() {\r\n const state = {\r\n isMounted: false,\r\n isLeaving: false,\r\n isUnmounting: false,\r\n leavingVNodes: new Map()\r\n };\r\n onMounted(() => {\r\n state.isMounted = true;\r\n });\r\n onBeforeUnmount(() => {\r\n state.isUnmounting = true;\r\n });\r\n return state;\r\n}\r\nconst TransitionHookValidator = [Function, Array];\r\nconst BaseTransitionImpl = {\r\n name: `BaseTransition`,\r\n props: {\r\n mode: String,\r\n appear: Boolean,\r\n persisted: Boolean,\r\n // enter\r\n onBeforeEnter: TransitionHookValidator,\r\n onEnter: TransitionHookValidator,\r\n onAfterEnter: TransitionHookValidator,\r\n onEnterCancelled: TransitionHookValidator,\r\n // leave\r\n onBeforeLeave: TransitionHookValidator,\r\n onLeave: TransitionHookValidator,\r\n onAfterLeave: TransitionHookValidator,\r\n onLeaveCancelled: TransitionHookValidator,\r\n // appear\r\n onBeforeAppear: TransitionHookValidator,\r\n onAppear: TransitionHookValidator,\r\n onAfterAppear: TransitionHookValidator,\r\n onAppearCancelled: TransitionHookValidator\r\n },\r\n setup(props, { slots }) {\r\n const instance = getCurrentInstance();\r\n const state = useTransitionState();\r\n let prevTransitionKey;\r\n return () => {\r\n const children = slots.default && getTransitionRawChildren(slots.default(), true);\r\n if (!children || !children.length) {\r\n return;\r\n }\r\n let child = children[0];\r\n if (children.length > 1) {\r\n let hasFound = false;\r\n // locate first non-comment child\r\n for (const c of children) {\r\n if (c.type !== Comment) {\r\n if ((process.env.NODE_ENV !== 'production') && hasFound) {\r\n // warn more than one non-comment child\r\n warn('<transition> can only be used on a single element or component. ' +\r\n 'Use <transition-group> for lists.');\r\n break;\r\n }\r\n child = c;\r\n hasFound = true;\r\n if (!(process.env.NODE_ENV !== 'production'))\r\n break;\r\n }\r\n }\r\n }\r\n // there's no need to track reactivity for these props so use the raw\r\n // props for a bit better perf\r\n const rawProps = toRaw(props);\r\n const { mode } = rawProps;\r\n // check mode\r\n if ((process.env.NODE_ENV !== 'production') &&\r\n mode &&\r\n mode !== 'in-out' &&\r\n mode !== 'out-in' &&\r\n mode !== 'default') {\r\n warn(`invalid <transition> mode: ${mode}`);\r\n }\r\n if (state.isLeaving) {\r\n return emptyPlaceholder(child);\r\n }\r\n // in the case of <transition><keep-alive/></transition>, we need to\r\n // compare the type of the kept-alive children.\r\n const innerChild = getKeepAliveChild(child);\r\n if (!innerChild) {\r\n return emptyPlaceholder(child);\r\n }\r\n const enterHooks = resolveTransitionHooks(innerChild, rawProps, state, instance);\r\n setTransitionHooks(innerChild, enterHooks);\r\n const oldChild = instance.subTree;\r\n const oldInnerChild = oldChild && getKeepAliveChild(oldChild);\r\n let transitionKeyChanged = false;\r\n const { getTransitionKey } = innerChild.type;\r\n if (getTransitionKey) {\r\n const key = getTransitionKey();\r\n if (prevTransitionKey === undefined) {\r\n prevTransitionKey = key;\r\n }\r\n else if (key !== prevTransitionKey) {\r\n prevTransitionKey = key;\r\n transitionKeyChanged = true;\r\n }\r\n }\r\n // handle mode\r\n if (oldInnerChild &&\r\n oldInnerChild.type !== Comment &&\r\n (!isSameVNodeType(innerChild, oldInnerChild) || transitionKeyChanged)) {\r\n const leavingHooks = resolveTransitionHooks(oldInnerChild, rawProps, state, instance);\r\n // update old tree's hooks in case of dynamic transition\r\n setTransitionHooks(oldInnerChild, leavingHooks);\r\n // switching between different views\r\n if (mode === 'out-in') {\r\n state.isLeaving = true;\r\n // return placeholder node and queue update when leave finishes\r\n leavingHooks.afterLeave = () => {\r\n state.isLeaving = false;\r\n instance.update();\r\n };\r\n return emptyPlaceholder(child);\r\n }\r\n else if (mode === 'in-out' && innerChild.type !== Comment) {\r\n leavingHooks.delayLeave = (el, earlyRemove, delayedLeave) => {\r\n const leavingVNodesCache = getLeavingNodesForType(state, oldInnerChild);\r\n leavingVNodesCache[String(oldInnerChild.key)] = oldInnerChild;\r\n // early removal callback\r\n el._leaveCb = () => {\r\n earlyRemove();\r\n el._leaveCb = undefined;\r\n delete enterHooks.delayedLeave;\r\n };\r\n enterHooks.delayedLeave = delayedLeave;\r\n };\r\n }\r\n }\r\n return child;\r\n };\r\n }\r\n};\r\n// export the public type for h/tsx inference\r\n// also to avoid inline import() in generated d.ts files\r\nconst BaseTransition = BaseTransitionImpl;\r\nfunction getLeavingNodesForType(state, vnode) {\r\n const { leavingVNodes } = state;\r\n let leavingVNodesCache = leavingVNodes.get(vnode.type);\r\n if (!leavingVNodesCache) {\r\n leavingVNodesCache = Object.create(null);\r\n leavingVNodes.set(vnode.type, leavingVNodesCache);\r\n }\r\n return leavingVNodesCache;\r\n}\r\n// The transition hooks are attached to the vnode as vnode.transition\r\n// and will be called at appropriate timing in the renderer.\r\nfunction resolveTransitionHooks(vnode, props, state, instance) {\r\n const { appear, mode, persisted = false, onBeforeEnter, onEnter, onAfterEnter, onEnterCancelled, onBeforeLeave, onLeave, onAfterLeave, onLeaveCancelled, onBeforeAppear, onAppear, onAfterAppear, onAppearCancelled } = props;\r\n const key = String(vnode.key);\r\n const leavingVNodesCache = getLeavingNodesForType(state, vnode);\r\n const callHook = (hook, args) => {\r\n hook &&\r\n callWithAsyncErrorHandling(hook, instance, 9 /* TRANSITION_HOOK */, args);\r\n };\r\n const callAsyncHook = (hook, args) => {\r\n const done = args[1];\r\n callHook(hook, args);\r\n if (isArray(hook)) {\r\n if (hook.every(hook => hook.length <= 1))\r\n done();\r\n }\r\n else if (hook.length <= 1) {\r\n done();\r\n }\r\n };\r\n const hooks = {\r\n mode,\r\n persisted,\r\n beforeEnter(el) {\r\n let hook = onBeforeEnter;\r\n if (!state.isMounted) {\r\n if (appear) {\r\n hook = onBeforeAppear || onBeforeEnter;\r\n }\r\n else {\r\n return;\r\n }\r\n }\r\n // for same element (v-show)\r\n if (el._leaveCb) {\r\n el._leaveCb(true /* cancelled */);\r\n }\r\n // for toggled element with same key (v-if)\r\n const leavingVNode = leavingVNodesCache[key];\r\n if (leavingVNode &&\r\n isSameVNodeType(vnode, leavingVNode) &&\r\n leavingVNode.el._leaveCb) {\r\n // force early removal (not cancelled)\r\n leavingVNode.el._leaveCb();\r\n }\r\n callHook(hook, [el]);\r\n },\r\n enter(el) {\r\n let hook = onEnter;\r\n let afterHook = onAfterEnter;\r\n let cancelHook = onEnterCancelled;\r\n if (!state.isMounted) {\r\n if (appear) {\r\n hook = onAppear || onEnter;\r\n afterHook = onAfterAppear || onAfterEnter;\r\n cancelHook = onAppearCancelled || onEnterCancelled;\r\n }\r\n else {\r\n return;\r\n }\r\n }\r\n let called = false;\r\n const done = (el._enterCb = (cancelled) => {\r\n if (called)\r\n return;\r\n called = true;\r\n if (cancelled) {\r\n callHook(cancelHook, [el]);\r\n }\r\n else {\r\n callHook(afterHook, [el]);\r\n }\r\n if (hooks.delayedLeave) {\r\n hooks.delayedLeave();\r\n }\r\n el._enterCb = undefined;\r\n });\r\n if (hook) {\r\n callAsyncHook(hook, [el, done]);\r\n }\r\n else {\r\n done();\r\n }\r\n },\r\n leave(el, remove) {\r\n const key = String(vnode.key);\r\n if (el._enterCb) {\r\n el._enterCb(true /* cancelled */);\r\n }\r\n if (state.isUnmounting) {\r\n return remove();\r\n }\r\n callHook(onBeforeLeave, [el]);\r\n let called = false;\r\n const done = (el._leaveCb = (cancelled) => {\r\n if (called)\r\n return;\r\n called = true;\r\n remove();\r\n if (cancelled) {\r\n callHook(onLeaveCancelled, [el]);\r\n }\r\n else {\r\n callHook(onAfterLeave, [el]);\r\n }\r\n el._leaveCb = undefined;\r\n if (leavingVNodesCache[key] === vnode) {\r\n delete leavingVNodesCache[key];\r\n }\r\n });\r\n leavingVNodesCache[key] = vnode;\r\n if (onLeave) {\r\n callAsyncHook(onLeave, [el, done]);\r\n }\r\n else {\r\n done();\r\n }\r\n },\r\n clone(vnode) {\r\n return resolveTransitionHooks(vnode, props, state, instance);\r\n }\r\n };\r\n return hooks;\r\n}\r\n// the placeholder really only handles one special case: KeepAlive\r\n// in the case of a KeepAlive in a leave phase we need to return a KeepAlive\r\n// placeholder with empty content to avoid the KeepAlive instance from being\r\n// unmounted.\r\nfunction emptyPlaceholder(vnode) {\r\n if (isKeepAlive(vnode)) {\r\n vnode = cloneVNode(vnode);\r\n vnode.children = null;\r\n return vnode;\r\n }\r\n}\r\nfunction getKeepAliveChild(vnode) {\r\n return isKeepAlive(vnode)\r\n ? vnode.children\r\n ? vnode.children[0]\r\n : undefined\r\n : vnode;\r\n}\r\nfunction setTransitionHooks(vnode, hooks) {\r\n if (vnode.shapeFlag & 6 /* COMPONENT */ && vnode.component) {\r\n setTransitionHooks(vnode.component.subTree, hooks);\r\n }\r\n else if (vnode.shapeFlag & 128 /* SUSPENSE */) {\r\n vnode.ssContent.transition = hooks.clone(vnode.ssContent);\r\n vnode.ssFallback.transition = hooks.clone(vnode.ssFallback);\r\n }\r\n else {\r\n vnode.transition = hooks;\r\n }\r\n}\r\nfunction getTransitionRawChildren(children, keepComment = false, parentKey) {\r\n let ret = [];\r\n let keyedFragmentCount = 0;\r\n for (let i = 0; i < children.length; i++) {\r\n let child = children[i];\r\n // #5360 inherit parent key in case of <template v-for>\r\n const key = parentKey == null\r\n ? child.key\r\n : String(parentKey) + String(child.key != null ? child.key : i);\r\n // handle fragment children case, e.g. v-for\r\n if (child.type === Fragment) {\r\n if (child.patchFlag & 128 /* KEYED_FRAGMENT */)\r\n keyedFragmentCount++;\r\n ret = ret.concat(getTransitionRawChildren(child.children, keepComment, key));\r\n }\r\n // comment placeholders should be skipped, e.g. v-if\r\n else if (keepComment || child.type !== Comment) {\r\n ret.push(key != null ? cloneVNode(child, { key }) : child);\r\n }\r\n }\r\n // #1126 if a transition children list contains multiple sub fragments, these\r\n // fragments will be merged into a flat children array. Since each v-for\r\n // fragment may contain different static bindings inside, we need to de-op\r\n // these children to force full diffs to ensure correct behavior.\r\n if (keyedFragmentCount > 1) {\r\n for (let i = 0; i < ret.length; i++) {\r\n ret[i].patchFlag = -2 /* BAIL */;\r\n }\r\n }\r\n return ret;\r\n}\n\n// implementation, close to no-op\r\nfunction defineComponent(options) {\r\n return isFunction(options) ? { setup: options, name: options.name } : options;\r\n}\n\nconst isAsyncWrapper = (i) => !!i.type.__asyncLoader;\r\nfunction defineAsyncComponent(source) {\r\n if (isFunction(source)) {\r\n source = { loader: source };\r\n }\r\n const { loader, loadingComponent, errorComponent, delay = 200, timeout, // undefined = never times out\r\n suspensible = true, onError: userOnError } = source;\r\n let pendingRequest = null;\r\n let resolvedComp;\r\n let retries = 0;\r\n const retry = () => {\r\n retries++;\r\n pendingRequest = null;\r\n return load();\r\n };\r\n const load = () => {\r\n let thisRequest;\r\n return (pendingRequest ||\r\n (thisRequest = pendingRequest =\r\n loader()\r\n .catch(err => {\r\n err = err instanceof Error ? err : new Error(String(err));\r\n if (userOnError) {\r\n return new Promise((resolve, reject) => {\r\n const userRetry = () => resolve(retry());\r\n const userFail = () => reject(err);\r\n userOnError(err, userRetry, userFail, retries + 1);\r\n });\r\n }\r\n else {\r\n throw err;\r\n }\r\n })\r\n .then((comp) => {\r\n if (thisRequest !== pendingRequest && pendingRequest) {\r\n return pendingRequest;\r\n }\r\n if ((process.env.NODE_ENV !== 'production') && !comp) {\r\n warn(`Async component loader resolved to undefined. ` +\r\n `If you are using retry(), make sure to return its return value.`);\r\n }\r\n // interop module default\r\n if (comp &&\r\n (comp.__esModule || comp[Symbol.toStringTag] === 'Module')) {\r\n comp = comp.default;\r\n }\r\n if ((process.env.NODE_ENV !== 'production') && comp && !isObject(comp) && !isFunction(comp)) {\r\n throw new Error(`Invalid async component load result: ${comp}`);\r\n }\r\n resolvedComp = comp;\r\n return comp;\r\n })));\r\n };\r\n return defineComponent({\r\n name: 'AsyncComponentWrapper',\r\n __asyncLoader: load,\r\n get __asyncResolved() {\r\n return resolvedComp;\r\n },\r\n setup() {\r\n const instance = currentInstance;\r\n // already resolved\r\n if (resolvedComp) {\r\n return () => createInnerComp(resolvedComp, instance);\r\n }\r\n const onError = (err) => {\r\n pendingRequest = null;\r\n handleError(err, instance, 13 /* ASYNC_COMPONENT_LOADER */, !errorComponent /* do not throw in dev if user provided error component */);\r\n };\r\n // suspense-controlled or SSR.\r\n if ((suspensible && instance.suspense) ||\r\n (isInSSRComponentSetup)) {\r\n return load()\r\n .then(comp => {\r\n return () => createInnerComp(comp, instance);\r\n })\r\n .catch(err => {\r\n onError(err);\r\n return () => errorComponent\r\n ? createVNode(errorComponent, {\r\n error: err\r\n })\r\n : null;\r\n });\r\n }\r\n const loaded = ref(false);\r\n const error = ref();\r\n const delayed = ref(!!delay);\r\n if (delay) {\r\n setTimeout(() => {\r\n delayed.value = false;\r\n }, delay);\r\n }\r\n if (timeout != null) {\r\n setTimeout(() => {\r\n if (!loaded.value && !error.value) {\r\n const err = new Error(`Async component timed out after ${timeout}ms.`);\r\n onError(err);\r\n error.value = err;\r\n }\r\n }, timeout);\r\n }\r\n load()\r\n .then(() => {\r\n loaded.value = true;\r\n if (instance.parent && isKeepAlive(instance.parent.vnode)) {\r\n // parent is keep-alive, force update so the loaded component's\r\n // name is taken into account\r\n queueJob(instance.parent.update);\r\n }\r\n })\r\n .catch(err => {\r\n onError(err);\r\n error.value = err;\r\n });\r\n return () => {\r\n if (loaded.value && resolvedComp) {\r\n return createInnerComp(resolvedComp, instance);\r\n }\r\n else if (error.value && errorComponent) {\r\n return createVNode(errorComponent, {\r\n error: error.value\r\n });\r\n }\r\n else if (loadingComponent && !delayed.value) {\r\n return createVNode(loadingComponent);\r\n }\r\n };\r\n }\r\n });\r\n}\r\nfunction createInnerComp(comp, { vnode: { ref, props, children, shapeFlag }, parent }) {\r\n const vnode = createVNode(comp, props, children);\r\n // ensure inner component inherits the async wrapper's ref owner\r\n vnode.ref = ref;\r\n return vnode;\r\n}\n\nconst isKeepAlive = (vnode) => vnode.type.__isKeepAlive;\r\nconst KeepAliveImpl = {\r\n name: `KeepAlive`,\r\n // Marker for special handling inside the renderer. We are not using a ===\r\n // check directly on KeepAlive in the renderer, because importing it directly\r\n // would prevent it from being tree-shaken.\r\n __isKeepAlive: true,\r\n props: {\r\n include: [String, RegExp, Array],\r\n exclude: [String, RegExp, Array],\r\n max: [String, Number]\r\n },\r\n setup(props, { slots }) {\r\n const instance = getCurrentInstance();\r\n // KeepAlive communicates with the instantiated renderer via the\r\n // ctx where the renderer passes in its internals,\r\n // and the KeepAlive instance exposes activate/deactivate implementations.\r\n // The whole point of this is to avoid importing KeepAlive directly in the\r\n // renderer to facilitate tree-shaking.\r\n const sharedContext = instance.ctx;\r\n // if the internal renderer is not registered, it indicates that this is server-side rendering,\r\n // for KeepAlive, we just need to render its children\r\n if (!sharedContext.renderer) {\r\n return () => {\r\n const children = slots.default && slots.default();\r\n return children && children.length === 1 ? children[0] : children;\r\n };\r\n }\r\n const cache = new Map();\r\n const keys = new Set();\r\n let current = null;\r\n if ((process.env.NODE_ENV !== 'production') || __VUE_PROD_DEVTOOLS__) {\r\n instance.__v_cache = cache;\r\n }\r\n const parentSuspense = instance.suspense;\r\n const { renderer: { p: patch, m: move, um: _unmount, o: { createElement } } } = sharedContext;\r\n const storageContainer = createElement('div');\r\n sharedContext.activate = (vnode, container, anchor, isSVG, optimized) => {\r\n const instance = vnode.component;\r\n move(vnode, container, anchor, 0 /* ENTER */, parentSuspense);\r\n // in case props have changed\r\n patch(instance.vnode, vnode, container, anchor, instance, parentSuspense, isSVG, vnode.slotScopeIds, optimized);\r\n queuePostRenderEffect(() => {\r\n instance.isDeactivated = false;\r\n if (instance.a) {\r\n invokeArrayFns(instance.a);\r\n }\r\n const vnodeHook = vnode.props && vnode.props.onVnodeMounted;\r\n if (vnodeHook) {\r\n invokeVNodeHook(vnodeHook, instance.parent, vnode);\r\n }\r\n }, parentSuspense);\r\n if ((process.env.NODE_ENV !== 'production') || __VUE_PROD_DEVTOOLS__) {\r\n // Update components tree\r\n devtoolsComponentAdded(instance);\r\n }\r\n };\r\n sharedContext.deactivate = (vnode) => {\r\n const instance = vnode.component;\r\n move(vnode, storageContainer, null, 1 /* LEAVE */, parentSuspense);\r\n queuePostRenderEffect(() => {\r\n if (instance.da) {\r\n invokeArrayFns(instance.da);\r\n }\r\n const vnodeHook = vnode.props && vnode.props.onVnodeUnmounted;\r\n if (vnodeHook) {\r\n invokeVNodeHook(vnodeHook, instance.parent, vnode);\r\n }\r\n instance.isDeactivated = true;\r\n }, parentSuspense);\r\n if ((process.env.NODE_ENV !== 'production') || __VUE_PROD_DEVTOOLS__) {\r\n // Update components tree\r\n devtoolsComponentAdded(instance);\r\n }\r\n };\r\n function unmount(vnode) {\r\n // reset the shapeFlag so it can be properly unmounted\r\n resetShapeFlag(vnode);\r\n _unmount(vnode, instance, parentSuspense, true);\r\n }\r\n function pruneCache(filter) {\r\n cache.forEach((vnode, key) => {\r\n const name = getComponentName(vnode.type);\r\n if (name && (!filter || !filter(name))) {\r\n pruneCacheEntry(key);\r\n }\r\n });\r\n }\r\n function pruneCacheEntry(key) {\r\n const cached = cache.get(key);\r\n if (!current || cached.type !== current.type) {\r\n unmount(cached);\r\n }\r\n else if (current) {\r\n // current active instance should no longer be kept-alive.\r\n // we can't unmount it now but it might be later, so reset its flag now.\r\n resetShapeFlag(current);\r\n }\r\n cache.delete(key);\r\n keys.delete(key);\r\n }\r\n // prune cache on include/exclude prop change\r\n watch(() => [props.include, props.exclude], ([include, exclude]) => {\r\n include && pruneCache(name => matches(include, name));\r\n exclude && pruneCache(name => !matches(exclude, name));\r\n }, \r\n // prune post-render after `current` has been updated\r\n { flush: 'post', deep: true });\r\n // cache sub tree after render\r\n let pendingCacheKey = null;\r\n const cacheSubtree = () => {\r\n // fix #1621, the pendingCacheKey could be 0\r\n if (pendingCacheKey != null) {\r\n cache.set(pendingCacheKey, getInnerChild(instance.subTree));\r\n }\r\n };\r\n onMounted(cacheSubtree);\r\n onUpdated(cacheSubtree);\r\n onBeforeUnmount(() => {\r\n cache.forEach(cached => {\r\n const { subTree, suspense } = instance;\r\n const vnode = getInnerChild(subTree);\r\n if (cached.type === vnode.type) {\r\n // current instance will be unmounted as part of keep-alive's unmount\r\n resetShapeFlag(vnode);\r\n // but invoke its deactivated hook here\r\n const da = vnode.component.da;\r\n da && queuePostRenderEffect(da, suspense);\r\n return;\r\n }\r\n unmount(cached);\r\n });\r\n });\r\n return () => {\r\n pendingCacheKey = null;\r\n if (!slots.default) {\r\n return null;\r\n }\r\n const children = slots.default();\r\n const rawVNode = children[0];\r\n if (children.length > 1) {\r\n if ((process.env.NODE_ENV !== 'production')) {\r\n warn(`KeepAlive should contain exactly one component child.`);\r\n }\r\n current = null;\r\n return children;\r\n }\r\n else if (!isVNode(rawVNode) ||\r\n (!(rawVNode.shapeFlag & 4 /* STATEFUL_COMPONENT */) &&\r\n !(rawVNode.shapeFlag & 128 /* SUSPENSE */))) {\r\n current = null;\r\n return rawVNode;\r\n }\r\n let vnode = getInnerChild(rawVNode);\r\n const comp = vnode.type;\r\n // for async components, name check should be based in its loaded\r\n // inner component if available\r\n const name = getComponentName(isAsyncWrapper(vnode)\r\n ? vnode.type.__asyncResolved || {}\r\n : comp);\r\n const { include, exclude, max } = props;\r\n if ((include && (!name || !matches(include, name))) ||\r\n (exclude && name && matches(exclude, name))) {\r\n current = vnode;\r\n return rawVNode;\r\n }\r\n const key = vnode.key == null ? comp : vnode.key;\r\n const cachedVNode = cache.get(key);\r\n // clone vnode if it's reused because we are going to mutate it\r\n if (vnode.el) {\r\n vnode = cloneVNode(vnode);\r\n if (rawVNode.shapeFlag & 128 /* SUSPENSE */) {\r\n rawVNode.ssContent = vnode;\r\n }\r\n }\r\n // #1513 it's possible for the returned vnode to be cloned due to attr\r\n // fallthrough or scopeId, so the vnode here may not be the final vnode\r\n // that is mounted. Instead of caching it directly, we store the pending\r\n // key and cache `instance.subTree` (the normalized vnode) in\r\n // beforeMount/beforeUpdate hooks.\r\n pendingCacheKey = key;\r\n if (cachedVNode) {\r\n // copy over mounted state\r\n vnode.el = cachedVNode.el;\r\n vnode.component = cachedVNode.component;\r\n if (vnode.transition) {\r\n // recursively update transition hooks on subTree\r\n setTransitionHooks(vnode, vnode.transition);\r\n }\r\n // avoid vnode being mounted as fresh\r\n vnode.shapeFlag |= 512 /* COMPONENT_KEPT_ALIVE */;\r\n // make this key the freshest\r\n keys.delete(key);\r\n keys.add(key);\r\n }\r\n else {\r\n keys.add(key);\r\n // prune oldest entry\r\n if (max && keys.size > parseInt(max, 10)) {\r\n pruneCacheEntry(keys.values().next().value);\r\n }\r\n }\r\n // avoid vnode being unmounted\r\n vnode.shapeFlag |= 256 /* COMPONENT_SHOULD_KEEP_ALIVE */;\r\n current = vnode;\r\n return isSuspense(rawVNode.type) ? rawVNode : vnode;\r\n };\r\n }\r\n};\r\n// export the public type for h/tsx inference\r\n// also to avoid inline import() in generated d.ts files\r\nconst KeepAlive = KeepAliveImpl;\r\nfunction matches(pattern, name) {\r\n if (isArray(pattern)) {\r\n return pattern.some((p) => matches(p, name));\r\n }\r\n else if (isString(pattern)) {\r\n return pattern.split(',').includes(name);\r\n }\r\n else if (pattern.test) {\r\n return pattern.test(name);\r\n }\r\n /* istanbul ignore next */\r\n return false;\r\n}\r\nfunction onActivated(hook, target) {\r\n registerKeepAliveHook(hook, \"a\" /* ACTIVATED */, target);\r\n}\r\nfunction onDeactivated(hook, target) {\r\n registerKeepAliveHook(hook, \"da\" /* DEACTIVATED */, target);\r\n}\r\nfunction registerKeepAliveHook(hook, type, target = currentInstance) {\r\n // cache the deactivate branch check wrapper for injected hooks so the same\r\n // hook can be properly deduped by the scheduler. \"__wdc\" stands for \"with\r\n // deactivation check\".\r\n const wrappedHook = hook.__wdc ||\r\n (hook.__wdc = () => {\r\n // only fire the hook if the target instance is NOT in a deactivated branch.\r\n let current = target;\r\n while (current) {\r\n if (current.isDeactivated) {\r\n return;\r\n }\r\n current = current.parent;\r\n }\r\n return hook();\r\n });\r\n injectHook(type, wrappedHook, target);\r\n // In addition to registering it on the target instance, we walk up the parent\r\n // chain and register it on all ancestor instances that are keep-alive roots.\r\n // This avoids the need to walk the entire component tree when invoking these\r\n // hooks, and more importantly, avoids the need to track child components in\r\n // arrays.\r\n if (target) {\r\n let current = target.parent;\r\n while (current && current.parent) {\r\n if (isKeepAlive(current.parent.vnode)) {\r\n injectToKeepAliveRoot(wrappedHook, type, target, current);\r\n }\r\n current = current.parent;\r\n }\r\n }\r\n}\r\nfunction injectToKeepAliveRoot(hook, type, target, keepAliveRoot) {\r\n // injectHook wraps the original for error handling, so make sure to remove\r\n // the wrapped version.\r\n const injected = injectHook(type, hook, keepAliveRoot, true /* prepend */);\r\n onUnmounted(() => {\r\n remove(keepAliveRoot[type], injected);\r\n }, target);\r\n}\r\nfunction resetShapeFlag(vnode) {\r\n let shapeFlag = vnode.shapeFlag;\r\n if (shapeFlag & 256 /* COMPONENT_SHOULD_KEEP_ALIVE */) {\r\n shapeFlag -= 256 /* COMPONENT_SHOULD_KEEP_ALIVE */;\r\n }\r\n if (shapeFlag & 512 /* COMPONENT_KEPT_ALIVE */) {\r\n shapeFlag -= 512 /* COMPONENT_KEPT_ALIVE */;\r\n }\r\n vnode.shapeFlag = shapeFlag;\r\n}\r\nfunction getInnerChild(vnode) {\r\n return vnode.shapeFlag & 128 /* SUSPENSE */ ? vnode.ssContent : vnode;\r\n}\n\nfunction injectHook(type, hook, target = currentInstance, prepend = false) {\r\n if (target) {\r\n const hooks = target[type] || (target[type] = []);\r\n // cache the error handling wrapper for injected hooks so the same hook\r\n // can be properly deduped by the scheduler. \"__weh\" stands for \"with error\r\n // handling\".\r\n const wrappedHook = hook.__weh ||\r\n (hook.__weh = (...args) => {\r\n if (target.isUnmounted) {\r\n return;\r\n }\r\n // disable tracking inside all lifecycle hooks\r\n // since they can potentially be called inside effects.\r\n pauseTracking();\r\n // Set currentInstance during hook invocation.\r\n // This assumes the hook does not synchronously trigger other hooks, which\r\n // can only be false when the user does something really funky.\r\n setCurrentInstance(target);\r\n const res = callWithAsyncErrorHandling(hook, target, type, args);\r\n unsetCurrentInstance();\r\n resetTracking();\r\n return res;\r\n });\r\n if (prepend) {\r\n hooks.unshift(wrappedHook);\r\n }\r\n else {\r\n hooks.push(wrappedHook);\r\n }\r\n return wrappedHook;\r\n }\r\n else if ((process.env.NODE_ENV !== 'production')) {\r\n const apiName = toHandlerKey(ErrorTypeStrings[type].replace(/ hook$/, ''));\r\n warn(`${apiName} is called when there is no active component instance to be ` +\r\n `associated with. ` +\r\n `Lifecycle injection APIs can only be used during execution of setup().` +\r\n (` If you are using async setup(), make sure to register lifecycle ` +\r\n `hooks before the first await statement.`\r\n ));\r\n }\r\n}\r\nconst createHook = (lifecycle) => (hook, target = currentInstance) => \r\n// post-create lifecycle registrations are noops during SSR (except for serverPrefetch)\r\n(!isInSSRComponentSetup || lifecycle === \"sp\" /* SERVER_PREFETCH */) &&\r\n injectHook(lifecycle, hook, target);\r\nconst onBeforeMount = createHook(\"bm\" /* BEFORE_MOUNT */);\r\nconst onMounted = createHook(\"m\" /* MOUNTED */);\r\nconst onBeforeUpdate = createHook(\"bu\" /* BEFORE_UPDATE */);\r\nconst onUpdated = createHook(\"u\" /* UPDATED */);\r\nconst onBeforeUnmount = createHook(\"bum\" /* BEFORE_UNMOUNT */);\r\nconst onUnmounted = createHook(\"um\" /* UNMOUNTED */);\r\nconst onServerPrefetch = createHook(\"sp\" /* SERVER_PREFETCH */);\r\nconst onRenderTriggered = createHook(\"rtg\" /* RENDER_TRIGGERED */);\r\nconst onRenderTracked = createHook(\"rtc\" /* RENDER_TRACKED */);\r\nfunction onErrorCaptured(hook, target = currentInstance) {\r\n injectHook(\"ec\" /* ERROR_CAPTURED */, hook, target);\r\n}\n\n/**\r\nRuntime helper for applying directives to a vnode. Example usage:\r\n\nconst comp = resolveComponent('comp')\r\nconst foo = resolveDirective('foo')\r\nconst bar = resolveDirective('bar')\r\n\nreturn withDirectives(h(comp), [\r\n [foo, this.x],\r\n [bar, this.y]\r\n])\r\n*/\r\nfunction validateDirectiveName(name) {\r\n if (isBuiltInDirective(name)) {\r\n warn('Do not use built-in directive ids as custom directive id: ' + name);\r\n }\r\n}\r\n/**\r\n * Adds directives to a VNode.\r\n */\r\nfunction withDirectives(vnode, directives) {\r\n const internalInstance = currentRenderingInstance;\r\n if (internalInstance === null) {\r\n (process.env.NODE_ENV !== 'production') && warn(`withDirectives can only be used inside render functions.`);\r\n return vnode;\r\n }\r\n const instance = getExposeProxy(internalInstance) ||\r\n internalInstance.proxy;\r\n const bindings = vnode.dirs || (vnode.dirs = []);\r\n for (let i = 0; i < directives.length; i++) {\r\n let [dir, value, arg, modifiers = EMPTY_OBJ] = directives[i];\r\n if (isFunction(dir)) {\r\n dir = {\r\n mounted: dir,\r\n updated: dir\r\n };\r\n }\r\n if (dir.deep) {\r\n traverse(value);\r\n }\r\n bindings.push({\r\n dir,\r\n instance,\r\n value,\r\n oldValue: void 0,\r\n arg,\r\n modifiers\r\n });\r\n }\r\n return vnode;\r\n}\r\nfunction invokeDirectiveHook(vnode, prevVNode, instance, name) {\r\n const bindings = vnode.dirs;\r\n const oldBindings = prevVNode && prevVNode.dirs;\r\n for (let i = 0; i < bindings.length; i++) {\r\n const binding = bindings[i];\r\n if (oldBindings) {\r\n binding.oldValue = oldBindings[i].value;\r\n }\r\n let hook = binding.dir[name];\r\n if (hook) {\r\n // disable tracking inside all lifecycle hooks\r\n // since they can potentially be called inside effects.\r\n pauseTracking();\r\n callWithAsyncErrorHandling(hook, instance, 8 /* DIRECTIVE_HOOK */, [\r\n vnode.el,\r\n binding,\r\n vnode,\r\n prevVNode\r\n ]);\r\n resetTracking();\r\n }\r\n }\r\n}\n\nconst COMPONENTS = 'components';\r\nconst DIRECTIVES = 'directives';\r\n/**\r\n * @private\r\n */\r\nfunction resolveComponent(name, maybeSelfReference) {\r\n return resolveAsset(COMPONENTS, name, true, maybeSelfReference) || name;\r\n}\r\nconst NULL_DYNAMIC_COMPONENT = Symbol();\r\n/**\r\n * @private\r\n */\r\nfunction resolveDynamicComponent(component) {\r\n if (isString(component)) {\r\n return resolveAsset(COMPONENTS, component, false) || component;\r\n }\r\n else {\r\n // invalid types will fallthrough to createVNode and raise warning\r\n return (component || NULL_DYNAMIC_COMPONENT);\r\n }\r\n}\r\n/**\r\n * @private\r\n */\r\nfunction resolveDirective(name) {\r\n return resolveAsset(DIRECTIVES, name);\r\n}\r\n// implementation\r\nfunction resolveAsset(type, name, warnMissing = true, maybeSelfReference = false) {\r\n const instance = currentRenderingInstance || currentInstance;\r\n if (instance) {\r\n const Component = instance.type;\r\n // explicit self name has highest priority\r\n if (type === COMPONENTS) {\r\n const selfName = getComponentName(Component);\r\n if (selfName &&\r\n (selfName === name ||\r\n selfName === camelize(name) ||\r\n selfName === capitalize(camelize(name)))) {\r\n return Component;\r\n }\r\n }\r\n const res = \r\n // local registration\r\n // check instance[type] first which is resolved for options API\r\n resolve(instance[type] || Component[type], name) ||\r\n // global registration\r\n resolve(instance.appContext[type], name);\r\n if (!res && maybeSelfReference) {\r\n // fallback to implicit self-reference\r\n return Component;\r\n }\r\n if ((process.env.NODE_ENV !== 'production') && warnMissing && !res) {\r\n const extra = type === COMPONENTS\r\n ? `\\nIf this is a native custom element, make sure to exclude it from ` +\r\n `component resolution via compilerOptions.isCustomElement.`\r\n : ``;\r\n warn(`Failed to resolve ${type.slice(0, -1)}: ${name}${extra}`);\r\n }\r\n return res;\r\n }\r\n else if ((process.env.NODE_ENV !== 'production')) {\r\n warn(`resolve${capitalize(type.slice(0, -1))} ` +\r\n `can only be used in render() or setup().`);\r\n }\r\n}\r\nfunction resolve(registry, name) {\r\n return (registry &&\r\n (registry[name] ||\r\n registry[camelize(name)] ||\r\n registry[capitalize(camelize(name))]));\r\n}\n\n/**\r\n * Actual implementation\r\n */\r\nfunction renderList(source, renderItem, cache, index) {\r\n let ret;\r\n const cached = (cache && cache[index]);\r\n if (isArray(source) || isString(source)) {\r\n ret = new Array(source.length);\r\n for (let i = 0, l = source.length; i < l; i++) {\r\n ret[i] = renderItem(source[i], i, undefined, cached && cached[i]);\r\n }\r\n }\r\n else if (typeof source === 'number') {\r\n if ((process.env.NODE_ENV !== 'production') && !Number.isInteger(source)) {\r\n warn(`The v-for range expect an integer value but got ${source}.`);\r\n }\r\n ret = new Array(source);\r\n for (let i = 0; i < source; i++) {\r\n ret[i] = renderItem(i + 1, i, undefined, cached && cached[i]);\r\n }\r\n }\r\n else if (isObject(source)) {\r\n if (source[Symbol.iterator]) {\r\n ret = Array.from(source, (item, i) => renderItem(item, i, undefined, cached && cached[i]));\r\n }\r\n else {\r\n const keys = Object.keys(source);\r\n ret = new Array(keys.length);\r\n for (let i = 0, l = keys.length; i < l; i++) {\r\n const key = keys[i];\r\n ret[i] = renderItem(source[key], key, i, cached && cached[i]);\r\n }\r\n }\r\n }\r\n else {\r\n ret = [];\r\n }\r\n if (cache) {\r\n cache[index] = ret;\r\n }\r\n return ret;\r\n}\n\n/**\r\n * Compiler runtime helper for creating dynamic slots object\r\n * @private\r\n */\r\nfunction createSlots(slots, dynamicSlots) {\r\n for (let i = 0; i < dynamicSlots.length; i++) {\r\n const slot = dynamicSlots[i];\r\n // array of dynamic slot generated by <template v-for=\"...\" #[...]>\r\n if (isArray(slot)) {\r\n for (let j = 0; j < slot.length; j++) {\r\n slots[slot[j].name] = slot[j].fn;\r\n }\r\n }\r\n else if (slot) {\r\n // conditional single slot generated by <template v-if=\"...\" #foo>\r\n slots[slot.name] = slot.fn;\r\n }\r\n }\r\n return slots;\r\n}\n\n/**\r\n * Compiler runtime helper for rendering `<slot/>`\r\n * @private\r\n */\r\nfunction renderSlot(slots, name, props = {}, \r\n// this is not a user-facing function, so the fallback is always generated by\r\n// the compiler and guaranteed to be a function returning an array\r\nfallback, noSlotted) {\r\n if (currentRenderingInstance.isCE ||\r\n (currentRenderingInstance.parent &&\r\n isAsyncWrapper(currentRenderingInstance.parent) &&\r\n currentRenderingInstance.parent.isCE)) {\r\n return createVNode('slot', name === 'default' ? null : { name }, fallback && fallback());\r\n }\r\n let slot = slots[name];\r\n if ((process.env.NODE_ENV !== 'production') && slot && slot.length > 1) {\r\n warn(`SSR-optimized slot function detected in a non-SSR-optimized render ` +\r\n `function. You need to mark this component with $dynamic-slots in the ` +\r\n `parent template.`);\r\n slot = () => [];\r\n }\r\n // a compiled slot disables block tracking by default to avoid manual\r\n // invocation interfering with template-based block tracking, but in\r\n // `renderSlot` we can be sure that it's template-based so we can force\r\n // enable it.\r\n if (slot && slot._c) {\r\n slot._d = false;\r\n }\r\n openBlock();\r\n const validSlotContent = slot && ensureValidVNode(slot(props));\r\n const rendered = createBlock(Fragment, { key: props.key || `_${name}` }, validSlotContent || (fallback ? fallback() : []), validSlotContent && slots._ === 1 /* STABLE */\r\n ? 64 /* STABLE_FRAGMENT */\r\n : -2 /* BAIL */);\r\n if (!noSlotted && rendered.scopeId) {\r\n rendered.slotScopeIds = [rendered.scopeId + '-s'];\r\n }\r\n if (slot && slot._c) {\r\n slot._d = true;\r\n }\r\n return rendered;\r\n}\r\nfunction ensureValidVNode(vnodes) {\r\n return vnodes.some(child => {\r\n if (!isVNode(child))\r\n return true;\r\n if (child.type === Comment)\r\n return false;\r\n if (child.type === Fragment &&\r\n !ensureValidVNode(child.children))\r\n return false;\r\n return true;\r\n })\r\n ? vnodes\r\n : null;\r\n}\n\n/**\r\n * For prefixing keys in v-on=\"obj\" with \"on\"\r\n * @private\r\n */\r\nfunction toHandlers(obj) {\r\n const ret = {};\r\n if ((process.env.NODE_ENV !== 'production') && !isObject(obj)) {\r\n warn(`v-on with no argument expects an object value.`);\r\n return ret;\r\n }\r\n for (const key in obj) {\r\n ret[toHandlerKey(key)] = obj[key];\r\n }\r\n return ret;\r\n}\n\n/**\r\n * #2437 In Vue 3, functional components do not have a public instance proxy but\r\n * they exist in the internal parent chain. For code that relies on traversing\r\n * public $parent chains, skip functional ones and go to the parent instead.\r\n */\r\nconst getPublicInstance = (i) => {\r\n if (!i)\r\n return null;\r\n if (isStatefulComponent(i))\r\n return getExposeProxy(i) || i.proxy;\r\n return getPublicInstance(i.parent);\r\n};\r\nconst publicPropertiesMap = \r\n// Move PURE marker to new line to workaround compiler discarding it\r\n// due to type annotation\r\n/*#__PURE__*/ extend(Object.create(null), {\r\n $: i => i,\r\n $el: i => i.vnode.el,\r\n $data: i => i.data,\r\n $props: i => ((process.env.NODE_ENV !== 'production') ? shallowReadonly(i.props) : i.props),\r\n $attrs: i => ((process.env.NODE_ENV !== 'production') ? shallowReadonly(i.attrs) : i.attrs),\r\n $slots: i => ((process.env.NODE_ENV !== 'production') ? shallowReadonly(i.slots) : i.slots),\r\n $refs: i => ((process.env.NODE_ENV !== 'production') ? shallowReadonly(i.refs) : i.refs),\r\n $parent: i => getPublicInstance(i.parent),\r\n $root: i => getPublicInstance(i.root),\r\n $emit: i => i.emit,\r\n $options: i => (__VUE_OPTIONS_API__ ? resolveMergedOptions(i) : i.type),\r\n $forceUpdate: i => i.f || (i.f = () => queueJob(i.update)),\r\n $nextTick: i => i.n || (i.n = nextTick.bind(i.proxy)),\r\n $watch: i => (__VUE_OPTIONS_API__ ? instanceWatch.bind(i) : NOOP)\r\n});\r\nconst isReservedPrefix = (key) => key === '_' || key === '$';\r\nconst PublicInstanceProxyHandlers = {\r\n get({ _: instance }, key) {\r\n const { ctx, setupState, data, props, accessCache, type, appContext } = instance;\r\n // for internal formatters to know that this is a Vue instance\r\n if ((process.env.NODE_ENV !== 'production') && key === '__isVue') {\r\n return true;\r\n }\r\n // prioritize <script setup> bindings during dev.\r\n // this allows even properties that start with _ or $ to be used - so that\r\n // it aligns with the production behavior where the render fn is inlined and\r\n // indeed has access to all declared variables.\r\n if ((process.env.NODE_ENV !== 'production') &&\r\n setupState !== EMPTY_OBJ &&\r\n setupState.__isScriptSetup &&\r\n hasOwn(setupState, key)) {\r\n return setupState[key];\r\n }\r\n // data / props / ctx\r\n // This getter gets called for every property access on the render context\r\n // during render and is a major hotspot. The most expensive part of this\r\n // is the multiple hasOwn() calls. It's much faster to do a simple property\r\n // access on a plain object, so we use an accessCache object (with null\r\n // prototype) to memoize what access type a key corresponds to.\r\n let normalizedProps;\r\n if (key[0] !== '$') {\r\n const n = accessCache[key];\r\n if (n !== undefined) {\r\n switch (n) {\r\n case 1 /* SETUP */:\r\n return setupState[key];\r\n case 2 /* DATA */:\r\n return data[key];\r\n case 4 /* CONTEXT */:\r\n return ctx[key];\r\n case 3 /* PROPS */:\r\n return props[key];\r\n // default: just fallthrough\r\n }\r\n }\r\n else if (setupState !== EMPTY_OBJ && hasOwn(setupState, key)) {\r\n accessCache[key] = 1 /* SETUP */;\r\n return setupState[key];\r\n }\r\n else if (data !== EMPTY_OBJ && hasOwn(data, key)) {\r\n accessCache[key] = 2 /* DATA */;\r\n return data[key];\r\n }\r\n else if (\r\n // only cache other properties when instance has declared (thus stable)\r\n // props\r\n (normalizedProps = instance.propsOptions[0]) &&\r\n hasOwn(normalizedProps, key)) {\r\n accessCache[key] = 3 /* PROPS */;\r\n return props[key];\r\n }\r\n else if (ctx !== EMPTY_OBJ && hasOwn(ctx, key)) {\r\n accessCache[key] = 4 /* CONTEXT */;\r\n return ctx[key];\r\n }\r\n else if (!__VUE_OPTIONS_API__ || shouldCacheAccess) {\r\n accessCache[key] = 0 /* OTHER */;\r\n }\r\n }\r\n const publicGetter = publicPropertiesMap[key];\r\n let cssModule, globalProperties;\r\n // public $xxx properties\r\n if (publicGetter) {\r\n if (key === '$attrs') {\r\n track(instance, \"get\" /* GET */, key);\r\n (process.env.NODE_ENV !== 'production') && markAttrsAccessed();\r\n }\r\n return publicGetter(instance);\r\n }\r\n else if (\r\n // css module (injected by vue-loader)\r\n (cssModule = type.__cssModules) &&\r\n (cssModule = cssModule[key])) {\r\n return cssModule;\r\n }\r\n else if (ctx !== EMPTY_OBJ && hasOwn(ctx, key)) {\r\n // user may set custom properties to `this` that start with `$`\r\n accessCache[key] = 4 /* CONTEXT */;\r\n return ctx[key];\r\n }\r\n else if (\r\n // global properties\r\n ((globalProperties = appContext.config.globalProperties),\r\n hasOwn(globalProperties, key))) {\r\n {\r\n return globalProperties[key];\r\n }\r\n }\r\n else if ((process.env.NODE_ENV !== 'production') &&\r\n currentRenderingInstance &&\r\n (!isString(key) ||\r\n // #1091 avoid internal isRef/isVNode checks on component instance leading\r\n // to infinite warning loop\r\n key.indexOf('__v') !== 0)) {\r\n if (data !== EMPTY_OBJ && isReservedPrefix(key[0]) && hasOwn(data, key)) {\r\n warn(`Property ${JSON.stringify(key)} must be accessed via $data because it starts with a reserved ` +\r\n `character (\"$\" or \"_\") and is not proxied on the render context.`);\r\n }\r\n else if (instance === currentRenderingInstance) {\r\n warn(`Property ${JSON.stringify(key)} was accessed during render ` +\r\n `but is not defined on instance.`);\r\n }\r\n }\r\n },\r\n set({ _: instance }, key, value) {\r\n const { data, setupState, ctx } = instance;\r\n if (setupState !== EMPTY_OBJ && hasOwn(setupState, key)) {\r\n setupState[key] = value;\r\n return true;\r\n }\r\n else if (data !== EMPTY_OBJ && hasOwn(data, key)) {\r\n data[key] = value;\r\n return true;\r\n }\r\n else if (hasOwn(instance.props, key)) {\r\n (process.env.NODE_ENV !== 'production') &&\r\n warn(`Attempting to mutate prop \"${key}\". Props are readonly.`, instance);\r\n return false;\r\n }\r\n if (key[0] === '$' && key.slice(1) in instance) {\r\n (process.env.NODE_ENV !== 'production') &&\r\n warn(`Attempting to mutate public property \"${key}\". ` +\r\n `Properties starting with $ are reserved and readonly.`, instance);\r\n return false;\r\n }\r\n else {\r\n if ((process.env.NODE_ENV !== 'production') && key in instance.appContext.config.globalProperties) {\r\n Object.defineProperty(ctx, key, {\r\n enumerable: true,\r\n configurable: true,\r\n value\r\n });\r\n }\r\n else {\r\n ctx[key] = value;\r\n }\r\n }\r\n return true;\r\n },\r\n has({ _: { data, setupState, accessCache, ctx, appContext, propsOptions } }, key) {\r\n let normalizedProps;\r\n return (!!accessCache[key] ||\r\n (data !== EMPTY_OBJ && hasOwn(data, key)) ||\r\n (setupState !== EMPTY_OBJ && hasOwn(setupState, key)) ||\r\n ((normalizedProps = propsOptions[0]) && hasOwn(normalizedProps, key)) ||\r\n hasOwn(ctx, key) ||\r\n hasOwn(publicPropertiesMap, key) ||\r\n hasOwn(appContext.config.globalProperties, key));\r\n },\r\n defineProperty(target, key, descriptor) {\r\n if (descriptor.get != null) {\r\n // invalidate key cache of a getter based property #5417\r\n target._.accessCache[key] = 0;\r\n }\r\n else if (hasOwn(descriptor, 'value')) {\r\n this.set(target, key, descriptor.value, null);\r\n }\r\n return Reflect.defineProperty(target, key, descriptor);\r\n }\r\n};\r\nif ((process.env.NODE_ENV !== 'production') && !false) {\r\n PublicInstanceProxyHandlers.ownKeys = (target) => {\r\n warn(`Avoid app logic that relies on enumerating keys on a component instance. ` +\r\n `The keys will be empty in production mode to avoid performance overhead.`);\r\n return Reflect.ownKeys(target);\r\n };\r\n}\r\nconst RuntimeCompiledPublicInstanceProxyHandlers = /*#__PURE__*/ extend({}, PublicInstanceProxyHandlers, {\r\n get(target, key) {\r\n // fast path for unscopables when using `with` block\r\n if (key === Symbol.unscopables) {\r\n return;\r\n }\r\n return PublicInstanceProxyHandlers.get(target, key, target);\r\n },\r\n has(_, key) {\r\n const has = key[0] !== '_' && !isGloballyWhitelisted(key);\r\n if ((process.env.NODE_ENV !== 'production') && !has && PublicInstanceProxyHandlers.has(_, key)) {\r\n warn(`Property ${JSON.stringify(key)} should not start with _ which is a reserved prefix for Vue internals.`);\r\n }\r\n return has;\r\n }\r\n});\r\n// dev only\r\n// In dev mode, the proxy target exposes the same properties as seen on `this`\r\n// for easier console inspection. In prod mode it will be an empty object so\r\n// these properties definitions can be skipped.\r\nfunction createDevRenderContext(instance) {\r\n const target = {};\r\n // expose internal instance for proxy handlers\r\n Object.defineProperty(target, `_`, {\r\n configurable: true,\r\n enumerable: false,\r\n get: () => instance\r\n });\r\n // expose public properties\r\n Object.keys(publicPropertiesMap).forEach(key => {\r\n Object.defineProperty(target, key, {\r\n configurable: true,\r\n enumerable: false,\r\n get: () => publicPropertiesMap[key](instance),\r\n // intercepted by the proxy so no need for implementation,\r\n // but needed to prevent set errors\r\n set: NOOP\r\n });\r\n });\r\n return target;\r\n}\r\n// dev only\r\nfunction exposePropsOnRenderContext(instance) {\r\n const { ctx, propsOptions: [propsOptions] } = instance;\r\n if (propsOptions) {\r\n Object.keys(propsOptions).forEach(key => {\r\n Object.defineProperty(ctx, key, {\r\n enumerable: true,\r\n configurable: true,\r\n get: () => instance.props[key],\r\n set: NOOP\r\n });\r\n });\r\n }\r\n}\r\n// dev only\r\nfunction exposeSetupStateOnRenderContext(instance) {\r\n const { ctx, setupState } = instance;\r\n Object.keys(toRaw(setupState)).forEach(key => {\r\n if (!setupState.__isScriptSetup) {\r\n if (isReservedPrefix(key[0])) {\r\n warn(`setup() return property ${JSON.stringify(key)} should not start with \"$\" or \"_\" ` +\r\n `which are reserved prefixes for Vue internals.`);\r\n return;\r\n }\r\n Object.defineProperty(ctx, key, {\r\n enumerable: true,\r\n configurable: true,\r\n get: () => setupState[key],\r\n set: NOOP\r\n });\r\n }\r\n });\r\n}\n\nfunction createDuplicateChecker() {\r\n const cache = Object.create(null);\r\n return (type, key) => {\r\n if (cache[key]) {\r\n warn(`${type} property \"${key}\" is already defined in ${cache[key]}.`);\r\n }\r\n else {\r\n cache[key] = type;\r\n }\r\n };\r\n}\r\nlet shouldCacheAccess = true;\r\nfunction applyOptions(instance) {\r\n const options = resolveMergedOptions(instance);\r\n const publicThis = instance.proxy;\r\n const ctx = instance.ctx;\r\n // do not cache property access on public proxy during state initialization\r\n shouldCacheAccess = false;\r\n // call beforeCreate first before accessing other options since\r\n // the hook may mutate resolved options (#2791)\r\n if (options.beforeCreate) {\r\n callHook(options.beforeCreate, instance, \"bc\" /* BEFORE_CREATE */);\r\n }\r\n const { \r\n // state\r\n data: dataOptions, computed: computedOptions, methods, watch: watchOptions, provide: provideOptions, inject: injectOptions, \r\n // lifecycle\r\n created, beforeMount, mounted, beforeUpdate, updated, activated, deactivated, beforeDestroy, beforeUnmount, destroyed, unmounted, render, renderTracked, renderTriggered, errorCaptured, serverPrefetch, \r\n // public API\r\n expose, inheritAttrs, \r\n // assets\r\n components, directives, filters } = options;\r\n const checkDuplicateProperties = (process.env.NODE_ENV !== 'production') ? createDuplicateChecker() : null;\r\n if ((process.env.NODE_ENV !== 'production')) {\r\n const [propsOptions] = instance.propsOptions;\r\n if (propsOptions) {\r\n for (const key in propsOptions) {\r\n checkDuplicateProperties(\"Props\" /* PROPS */, key);\r\n }\r\n }\r\n }\r\n // options initialization order (to be consistent with Vue 2):\r\n // - props (already done outside of this function)\r\n // - inject\r\n // - methods\r\n // - data (deferred since it relies on `this` access)\r\n // - computed\r\n // - watch (deferred since it relies on `this` access)\r\n if (injectOptions) {\r\n resolveInjections(injectOptions, ctx, checkDuplicateProperties, instance.appContext.config.unwrapInjectedRef);\r\n }\r\n if (methods) {\r\n for (const key in methods) {\r\n const methodHandler = methods[key];\r\n if (isFunction(methodHandler)) {\r\n // In dev mode, we use the `createRenderContext` function to define\r\n // methods to the proxy target, and those are read-only but\r\n // reconfigurable, so it needs to be redefined here\r\n if ((process.env.NODE_ENV !== 'production')) {\r\n Object.defineProperty(ctx, key, {\r\n value: methodHandler.bind(publicThis),\r\n configurable: true,\r\n enumerable: true,\r\n writable: true\r\n });\r\n }\r\n else {\r\n ctx[key] = methodHandler.bind(publicThis);\r\n }\r\n if ((process.env.NODE_ENV !== 'production')) {\r\n checkDuplicateProperties(\"Methods\" /* METHODS */, key);\r\n }\r\n }\r\n else if ((process.env.NODE_ENV !== 'production')) {\r\n warn(`Method \"${key}\" has type \"${typeof methodHandler}\" in the component definition. ` +\r\n `Did you reference the function correctly?`);\r\n }\r\n }\r\n }\r\n if (dataOptions) {\r\n if ((process.env.NODE_ENV !== 'production') && !isFunction(dataOptions)) {\r\n warn(`The data option must be a function. ` +\r\n `Plain object usage is no longer supported.`);\r\n }\r\n const data = dataOptions.call(publicThis, publicThis);\r\n if ((process.env.NODE_ENV !== 'production') && isPromise(data)) {\r\n warn(`data() returned a Promise - note data() cannot be async; If you ` +\r\n `intend to perform data fetching before component renders, use ` +\r\n `async setup() + <Suspense>.`);\r\n }\r\n if (!isObject(data)) {\r\n (process.env.NODE_ENV !== 'production') && warn(`data() should return an object.`);\r\n }\r\n else {\r\n instance.data = reactive(data);\r\n if ((process.env.NODE_ENV !== 'production')) {\r\n for (const key in data) {\r\n checkDuplicateProperties(\"Data\" /* DATA */, key);\r\n // expose data on ctx during dev\r\n if (!isReservedPrefix(key[0])) {\r\n Object.defineProperty(ctx, key, {\r\n configurable: true,\r\n enumerable: true,\r\n get: () => data[key],\r\n set: NOOP\r\n });\r\n }\r\n }\r\n }\r\n }\r\n }\r\n // state initialization complete at this point - start caching access\r\n shouldCacheAccess = true;\r\n if (computedOptions) {\r\n for (const key in computedOptions) {\r\n const opt = computedOptions[key];\r\n const get = isFunction(opt)\r\n ? opt.bind(publicThis, publicThis)\r\n : isFunction(opt.get)\r\n ? opt.get.bind(publicThis, publicThis)\r\n : NOOP;\r\n if ((process.env.NODE_ENV !== 'production') && get === NOOP) {\r\n warn(`Computed property \"${key}\" has no getter.`);\r\n }\r\n const set = !isFunction(opt) && isFunction(opt.set)\r\n ? opt.set.bind(publicThis)\r\n : (process.env.NODE_ENV !== 'production')\r\n ? () => {\r\n warn(`Write operation failed: computed property \"${key}\" is readonly.`);\r\n }\r\n : NOOP;\r\n const c = computed({\r\n get,\r\n set\r\n });\r\n Object.defineProperty(ctx, key, {\r\n enumerable: true,\r\n configurable: true,\r\n get: () => c.value,\r\n set: v => (c.value = v)\r\n });\r\n if ((process.env.NODE_ENV !== 'production')) {\r\n checkDuplicateProperties(\"Computed\" /* COMPUTED */, key);\r\n }\r\n }\r\n }\r\n if (watchOptions) {\r\n for (const key in watchOptions) {\r\n createWatcher(watchOptions[key], ctx, publicThis, key);\r\n }\r\n }\r\n if (provideOptions) {\r\n const provides = isFunction(provideOptions)\r\n ? provideOptions.call(publicThis)\r\n : provideOptions;\r\n Reflect.ownKeys(provides).forEach(key => {\r\n provide(key, provides[key]);\r\n });\r\n }\r\n if (created) {\r\n callHook(created, instance, \"c\" /* CREATED */);\r\n }\r\n function registerLifecycleHook(register, hook) {\r\n if (isArray(hook)) {\r\n hook.forEach(_hook => register(_hook.bind(publicThis)));\r\n }\r\n else if (hook) {\r\n register(hook.bind(publicThis));\r\n }\r\n }\r\n registerLifecycleHook(onBeforeMount, beforeMount);\r\n registerLifecycleHook(onMounted, mounted);\r\n registerLifecycleHook(onBeforeUpdate, beforeUpdate);\r\n registerLifecycleHook(onUpdated, updated);\r\n registerLifecycleHook(onActivated, activated);\r\n registerLifecycleHook(onDeactivated, deactivated);\r\n registerLifecycleHook(onErrorCaptured, errorCaptured);\r\n registerLifecycleHook(onRenderTracked, renderTracked);\r\n registerLifecycleHook(onRenderTriggered, renderTriggered);\r\n registerLifecycleHook(onBeforeUnmount, beforeUnmount);\r\n registerLifecycleHook(onUnmounted, unmounted);\r\n registerLifecycleHook(onServerPrefetch, serverPrefetch);\r\n if (isArray(expose)) {\r\n if (expose.length) {\r\n const exposed = instance.exposed || (instance.exposed = {});\r\n expose.forEach(key => {\r\n Object.defineProperty(exposed, key, {\r\n get: () => publicThis[key],\r\n set: val => (publicThis[key] = val)\r\n });\r\n });\r\n }\r\n else if (!instance.exposed) {\r\n instance.exposed = {};\r\n }\r\n }\r\n // options that are handled when creating the instance but also need to be\r\n // applied from mixins\r\n if (render && instance.render === NOOP) {\r\n instance.render = render;\r\n }\r\n if (inheritAttrs != null) {\r\n instance.inheritAttrs = inheritAttrs;\r\n }\r\n // asset options.\r\n if (components)\r\n instance.components = components;\r\n if (directives)\r\n instance.directives = directives;\r\n}\r\nfunction resolveInjections(injectOptions, ctx, checkDuplicateProperties = NOOP, unwrapRef = false) {\r\n if (isArray(injectOptions)) {\r\n injectOptions = normalizeInject(injectOptions);\r\n }\r\n for (const key in injectOptions) {\r\n const opt = injectOptions[key];\r\n let injected;\r\n if (isObject(opt)) {\r\n if ('default' in opt) {\r\n injected = inject(opt.from || key, opt.default, true /* treat default function as factory */);\r\n }\r\n else {\r\n injected = inject(opt.from || key);\r\n }\r\n }\r\n else {\r\n injected = inject(opt);\r\n }\r\n if (isRef(injected)) {\r\n // TODO remove the check in 3.3\r\n if (unwrapRef) {\r\n Object.defineProperty(ctx, key, {\r\n enumerable: true,\r\n configurable: true,\r\n get: () => injected.value,\r\n set: v => (injected.value = v)\r\n });\r\n }\r\n else {\r\n if ((process.env.NODE_ENV !== 'production')) {\r\n warn(`injected property \"${key}\" is a ref and will be auto-unwrapped ` +\r\n `and no longer needs \\`.value\\` in the next minor release. ` +\r\n `To opt-in to the new behavior now, ` +\r\n `set \\`app.config.unwrapInjectedRef = true\\` (this config is ` +\r\n `temporary and will not be needed in the future.)`);\r\n }\r\n ctx[key] = injected;\r\n }\r\n }\r\n else {\r\n ctx[key] = injected;\r\n }\r\n if ((process.env.NODE_ENV !== 'production')) {\r\n checkDuplicateProperties(\"Inject\" /* INJECT */, key);\r\n }\r\n }\r\n}\r\nfunction callHook(hook, instance, type) {\r\n callWithAsyncErrorHandling(isArray(hook)\r\n ? hook.map(h => h.bind(instance.proxy))\r\n : hook.bind(instance.proxy), instance, type);\r\n}\r\nfunction createWatcher(raw, ctx, publicThis, key) {\r\n const getter = key.includes('.')\r\n ? createPathGetter(publicThis, key)\r\n : () => publicThis[key];\r\n if (isString(raw)) {\r\n const handler = ctx[raw];\r\n if (isFunction(handler)) {\r\n watch(getter, handler);\r\n }\r\n else if ((process.env.NODE_ENV !== 'production')) {\r\n warn(`Invalid watch handler specified by key \"${raw}\"`, handler);\r\n }\r\n }\r\n else if (isFunction(raw)) {\r\n watch(getter, raw.bind(publicThis));\r\n }\r\n else if (isObject(raw)) {\r\n if (isArray(raw)) {\r\n raw.forEach(r => createWatcher(r, ctx, publicThis, key));\r\n }\r\n else {\r\n const handler = isFunction(raw.handler)\r\n ? raw.handler.bind(publicThis)\r\n : ctx[raw.handler];\r\n if (isFunction(handler)) {\r\n watch(getter, handler, raw);\r\n }\r\n else if ((process.env.NODE_ENV !== 'production')) {\r\n warn(`Invalid watch handler specified by key \"${raw.handler}\"`, handler);\r\n }\r\n }\r\n }\r\n else if ((process.env.NODE_ENV !== 'production')) {\r\n warn(`Invalid watch option: \"${key}\"`, raw);\r\n }\r\n}\r\n/**\r\n * Resolve merged options and cache it on the component.\r\n * This is done only once per-component since the merging does not involve\r\n * instances.\r\n */\r\nfunction resolveMergedOptions(instance) {\r\n const base = instance.type;\r\n const { mixins, extends: extendsOptions } = base;\r\n const { mixins: globalMixins, optionsCache: cache, config: { optionMergeStrategies } } = instance.appContext;\r\n const cached = cache.get(base);\r\n let resolved;\r\n if (cached) {\r\n resolved = cached;\r\n }\r\n else if (!globalMixins.length && !mixins && !extendsOptions) {\r\n {\r\n resolved = base;\r\n }\r\n }\r\n else {\r\n resolved = {};\r\n if (globalMixins.length) {\r\n globalMixins.forEach(m => mergeOptions(resolved, m, optionMergeStrategies, true));\r\n }\r\n mergeOptions(resolved, base, optionMergeStrategies);\r\n }\r\n cache.set(base, resolved);\r\n return resolved;\r\n}\r\nfunction mergeOptions(to, from, strats, asMixin = false) {\r\n const { mixins, extends: extendsOptions } = from;\r\n if (extendsOptions) {\r\n mergeOptions(to, extendsOptions, strats, true);\r\n }\r\n if (mixins) {\r\n mixins.forEach((m) => mergeOptions(to, m, strats, true));\r\n }\r\n for (const key in from) {\r\n if (asMixin && key === 'expose') {\r\n (process.env.NODE_ENV !== 'production') &&\r\n warn(`\"expose\" option is ignored when declared in mixins or extends. ` +\r\n `It should only be declared in the base component itself.`);\r\n }\r\n else {\r\n const strat = internalOptionMergeStrats[key] || (strats && strats[key]);\r\n to[key] = strat ? strat(to[key], from[key]) : from[key];\r\n }\r\n }\r\n return to;\r\n}\r\nconst internalOptionMergeStrats = {\r\n data: mergeDataFn,\r\n props: mergeObjectOptions,\r\n emits: mergeObjectOptions,\r\n // objects\r\n methods: mergeObjectOptions,\r\n computed: mergeObjectOptions,\r\n // lifecycle\r\n beforeCreate: mergeAsArray,\r\n created: mergeAsArray,\r\n beforeMount: mergeAsArray,\r\n mounted: mergeAsArray,\r\n beforeUpdate: mergeAsArray,\r\n updated: mergeAsArray,\r\n beforeDestroy: mergeAsArray,\r\n beforeUnmount: mergeAsArray,\r\n destroyed: mergeAsArray,\r\n unmounted: mergeAsArray,\r\n activated: mergeAsArray,\r\n deactivated: mergeAsArray,\r\n errorCaptured: mergeAsArray,\r\n serverPrefetch: mergeAsArray,\r\n // assets\r\n components: mergeObjectOptions,\r\n directives: mergeObjectOptions,\r\n // watch\r\n watch: mergeWatchOptions,\r\n // provide / inject\r\n provide: mergeDataFn,\r\n inject: mergeInject\r\n};\r\nfunction mergeDataFn(to, from) {\r\n if (!from) {\r\n return to;\r\n }\r\n if (!to) {\r\n return from;\r\n }\r\n return function mergedDataFn() {\r\n return (extend)(isFunction(to) ? to.call(this, this) : to, isFunction(from) ? from.call(this, this) : from);\r\n };\r\n}\r\nfunction mergeInject(to, from) {\r\n return mergeObjectOptions(normalizeInject(to), normalizeInject(from));\r\n}\r\nfunction normalizeInject(raw) {\r\n if (isArray(raw)) {\r\n const res = {};\r\n for (let i = 0; i < raw.length; i++) {\r\n res[raw[i]] = raw[i];\r\n }\r\n return res;\r\n }\r\n return raw;\r\n}\r\nfunction mergeAsArray(to, from) {\r\n return to ? [...new Set([].concat(to, from))] : from;\r\n}\r\nfunction mergeObjectOptions(to, from) {\r\n return to ? extend(extend(Object.create(null), to), from) : from;\r\n}\r\nfunction mergeWatchOptions(to, from) {\r\n if (!to)\r\n return from;\r\n if (!from)\r\n return to;\r\n const merged = extend(Object.create(null), to);\r\n for (const key in from) {\r\n merged[key] = mergeAsArray(to[key], from[key]);\r\n }\r\n return merged;\r\n}\n\nfunction initProps(instance, rawProps, isStateful, // result of bitwise flag comparison\r\nisSSR = false) {\r\n const props = {};\r\n const attrs = {};\r\n def(attrs, InternalObjectKey, 1);\r\n instance.propsDefaults = Object.create(null);\r\n setFullProps(instance, rawProps, props, attrs);\r\n // ensure all declared prop keys are present\r\n for (const key in instance.propsOptions[0]) {\r\n if (!(key in props)) {\r\n props[key] = undefined;\r\n }\r\n }\r\n // validation\r\n if ((process.env.NODE_ENV !== 'production')) {\r\n validateProps(rawProps || {}, props, instance);\r\n }\r\n if (isStateful) {\r\n // stateful\r\n instance.props = isSSR ? props : shallowReactive(props);\r\n }\r\n else {\r\n if (!instance.type.props) {\r\n // functional w/ optional props, props === attrs\r\n instance.props = attrs;\r\n }\r\n else {\r\n // functional w/ declared props\r\n instance.props = props;\r\n }\r\n }\r\n instance.attrs = attrs;\r\n}\r\nfunction updateProps(instance, rawProps, rawPrevProps, optimized) {\r\n const { props, attrs, vnode: { patchFlag } } = instance;\r\n const rawCurrentProps = toRaw(props);\r\n const [options] = instance.propsOptions;\r\n let hasAttrsChanged = false;\r\n if (\r\n // always force full diff in dev\r\n // - #1942 if hmr is enabled with sfc component\r\n // - vite#872 non-sfc component used by sfc component\r\n !((process.env.NODE_ENV !== 'production') &&\r\n (instance.type.__hmrId ||\r\n (instance.parent && instance.parent.type.__hmrId))) &&\r\n (optimized || patchFlag > 0) &&\r\n !(patchFlag & 16 /* FULL_PROPS */)) {\r\n if (patchFlag & 8 /* PROPS */) {\r\n // Compiler-generated props & no keys change, just set the updated\r\n // the props.\r\n const propsToUpdate = instance.vnode.dynamicProps;\r\n for (let i = 0; i < propsToUpdate.length; i++) {\r\n let key = propsToUpdate[i];\r\n // skip if the prop key is a declared emit event listener\r\n if (isEmitListener(instance.emitsOptions, key)) {\r\n continue;\r\n }\r\n // PROPS flag guarantees rawProps to be non-null\r\n const value = rawProps[key];\r\n if (options) {\r\n // attr / props separation was done on init and will be consistent\r\n // in this code path, so just check if attrs have it.\r\n if (hasOwn(attrs, key)) {\r\n if (value !== attrs[key]) {\r\n attrs[key] = value;\r\n hasAttrsChanged = true;\r\n }\r\n }\r\n else {\r\n const camelizedKey = camelize(key);\r\n props[camelizedKey] = resolvePropValue(options, rawCurrentProps, camelizedKey, value, instance, false /* isAbsent */);\r\n }\r\n }\r\n else {\r\n if (value !== attrs[key]) {\r\n attrs[key] = value;\r\n hasAttrsChanged = true;\r\n }\r\n }\r\n }\r\n }\r\n }\r\n else {\r\n // full props update.\r\n if (setFullProps(instance, rawProps, props, attrs)) {\r\n hasAttrsChanged = true;\r\n }\r\n // in case of dynamic props, check if we need to delete keys from\r\n // the props object\r\n let kebabKey;\r\n for (const key in rawCurrentProps) {\r\n if (!rawProps ||\r\n // for camelCase\r\n (!hasOwn(rawProps, key) &&\r\n // it's possible the original props was passed in as kebab-case\r\n // and converted to camelCase (#955)\r\n ((kebabKey = hyphenate(key)) === key || !hasOwn(rawProps, kebabKey)))) {\r\n if (options) {\r\n if (rawPrevProps &&\r\n // for camelCase\r\n (rawPrevProps[key] !== undefined ||\r\n // for kebab-case\r\n rawPrevProps[kebabKey] !== undefined)) {\r\n props[key] = resolvePropValue(options, rawCurrentProps, key, undefined, instance, true /* isAbsent */);\r\n }\r\n }\r\n else {\r\n delete props[key];\r\n }\r\n }\r\n }\r\n // in the case of functional component w/o props declaration, props and\r\n // attrs point to the same object so it should already have been updated.\r\n if (attrs !== rawCurrentProps) {\r\n for (const key in attrs) {\r\n if (!rawProps ||\r\n (!hasOwn(rawProps, key) &&\r\n (!false ))) {\r\n delete attrs[key];\r\n hasAttrsChanged = true;\r\n }\r\n }\r\n }\r\n }\r\n // trigger updates for $attrs in case it's used in component slots\r\n if (hasAttrsChanged) {\r\n trigger(instance, \"set\" /* SET */, '$attrs');\r\n }\r\n if ((process.env.NODE_ENV !== 'production')) {\r\n validateProps(rawProps || {}, props, instance);\r\n }\r\n}\r\nfunction setFullProps(instance, rawProps, props, attrs) {\r\n const [options, needCastKeys] = instance.propsOptions;\r\n let hasAttrsChanged = false;\r\n let rawCastValues;\r\n if (rawProps) {\r\n for (let key in rawProps) {\r\n // key, ref are reserved and never passed down\r\n if (isReservedProp(key)) {\r\n continue;\r\n }\r\n const value = rawProps[key];\r\n // prop option names are camelized during normalization, so to support\r\n // kebab -> camel conversion here we need to camelize the key.\r\n let camelKey;\r\n if (options && hasOwn(options, (camelKey = camelize(key)))) {\r\n if (!needCastKeys || !needCastKeys.includes(camelKey)) {\r\n props[camelKey] = value;\r\n }\r\n else {\r\n (rawCastValues || (rawCastValues = {}))[camelKey] = value;\r\n }\r\n }\r\n else if (!isEmitListener(instance.emitsOptions, key)) {\r\n if (!(key in attrs) || value !== attrs[key]) {\r\n attrs[key] = value;\r\n hasAttrsChanged = true;\r\n }\r\n }\r\n }\r\n }\r\n if (needCastKeys) {\r\n const rawCurrentProps = toRaw(props);\r\n const castValues = rawCastValues || EMPTY_OBJ;\r\n for (let i = 0; i < needCastKeys.length; i++) {\r\n const key = needCastKeys[i];\r\n props[key] = resolvePropValue(options, rawCurrentProps, key, castValues[key], instance, !hasOwn(castValues, key));\r\n }\r\n }\r\n return hasAttrsChanged;\r\n}\r\nfunction resolvePropValue(options, props, key, value, instance, isAbsent) {\r\n const opt = options[key];\r\n if (opt != null) {\r\n const hasDefault = hasOwn(opt, 'default');\r\n // default values\r\n if (hasDefault && value === undefined) {\r\n const defaultValue = opt.default;\r\n if (opt.type !== Function && isFunction(defaultValue)) {\r\n const { propsDefaults } = instance;\r\n if (key in propsDefaults) {\r\n value = propsDefaults[key];\r\n }\r\n else {\r\n setCurrentInstance(instance);\r\n value = propsDefaults[key] = defaultValue.call(null, props);\r\n unsetCurrentInstance();\r\n }\r\n }\r\n else {\r\n value = defaultValue;\r\n }\r\n }\r\n // boolean casting\r\n if (opt[0 /* shouldCast */]) {\r\n if (isAbsent && !hasDefault) {\r\n value = false;\r\n }\r\n else if (opt[1 /* shouldCastTrue */] &&\r\n (value === '' || value === hyphenate(key))) {\r\n value = true;\r\n }\r\n }\r\n }\r\n return value;\r\n}\r\nfunction normalizePropsOptions(comp, appContext, asMixin = false) {\r\n const cache = appContext.propsCache;\r\n const cached = cache.get(comp);\r\n if (cached) {\r\n return cached;\r\n }\r\n const raw = comp.props;\r\n const normalized = {};\r\n const needCastKeys = [];\r\n // apply mixin/extends props\r\n let hasExtends = false;\r\n if (__VUE_OPTIONS_API__ && !isFunction(comp)) {\r\n const extendProps = (raw) => {\r\n hasExtends = true;\r\n const [props, keys] = normalizePropsOptions(raw, appContext, true);\r\n extend(normalized, props);\r\n if (keys)\r\n needCastKeys.push(...keys);\r\n };\r\n if (!asMixin && appContext.mixins.length) {\r\n appContext.mixins.forEach(extendProps);\r\n }\r\n if (comp.extends) {\r\n extendProps(comp.extends);\r\n }\r\n if (comp.mixins) {\r\n comp.mixins.forEach(extendProps);\r\n }\r\n }\r\n if (!raw && !hasExtends) {\r\n cache.set(comp, EMPTY_ARR);\r\n return EMPTY_ARR;\r\n }\r\n if (isArray(raw)) {\r\n for (let i = 0; i < raw.length; i++) {\r\n if ((process.env.NODE_ENV !== 'production') && !isString(raw[i])) {\r\n warn(`props must be strings when using array syntax.`, raw[i]);\r\n }\r\n const normalizedKey = camelize(raw[i]);\r\n if (validatePropName(normalizedKey)) {\r\n normalized[normalizedKey] = EMPTY_OBJ;\r\n }\r\n }\r\n }\r\n else if (raw) {\r\n if ((process.env.NODE_ENV !== 'production') && !isObject(raw)) {\r\n warn(`invalid props options`, raw);\r\n }\r\n for (const key in raw) {\r\n const normalizedKey = camelize(key);\r\n if (validatePropName(normalizedKey)) {\r\n const opt = raw[key];\r\n const prop = (normalized[normalizedKey] =\r\n isArray(opt) || isFunction(opt) ? { type: opt } : opt);\r\n if (prop) {\r\n const booleanIndex = getTypeIndex(Boolean, prop.type);\r\n const stringIndex = getTypeIndex(String, prop.type);\r\n prop[0 /* shouldCast */] = booleanIndex > -1;\r\n prop[1 /* shouldCastTrue */] =\r\n stringIndex < 0 || booleanIndex < stringIndex;\r\n // if the prop needs boolean casting or default value\r\n if (booleanIndex > -1 || hasOwn(prop, 'default')) {\r\n needCastKeys.push(normalizedKey);\r\n }\r\n }\r\n }\r\n }\r\n }\r\n const res = [normalized, needCastKeys];\r\n cache.set(comp, res);\r\n return res;\r\n}\r\nfunction validatePropName(key) {\r\n if (key[0] !== '$') {\r\n return true;\r\n }\r\n else if ((process.env.NODE_ENV !== 'production')) {\r\n warn(`Invalid prop name: \"${key}\" is a reserved property.`);\r\n }\r\n return false;\r\n}\r\n// use function string name to check type constructors\r\n// so that it works across vms / iframes.\r\nfunction getType(ctor) {\r\n const match = ctor && ctor.toString().match(/^\\s*function (\\w+)/);\r\n return match ? match[1] : ctor === null ? 'null' : '';\r\n}\r\nfunction isSameType(a, b) {\r\n return getType(a) === getType(b);\r\n}\r\nfunction getTypeIndex(type, expectedTypes) {\r\n if (isArray(expectedTypes)) {\r\n return expectedTypes.findIndex(t => isSameType(t, type));\r\n }\r\n else if (isFunction(expectedTypes)) {\r\n return isSameType(expectedTypes, type) ? 0 : -1;\r\n }\r\n return -1;\r\n}\r\n/**\r\n * dev only\r\n */\r\nfunction validateProps(rawProps, props, instance) {\r\n const resolvedValues = toRaw(props);\r\n const options = instance.propsOptions[0];\r\n for (const key in options) {\r\n let opt = options[key];\r\n if (opt == null)\r\n continue;\r\n validateProp(key, resolvedValues[key], opt, !hasOwn(rawProps, key) && !hasOwn(rawProps, hyphenate(key)));\r\n }\r\n}\r\n/**\r\n * dev only\r\n */\r\nfunction validateProp(name, value, prop, isAbsent) {\r\n const { type, required, validator } = prop;\r\n // required!\r\n if (required && isAbsent) {\r\n warn('Missing required prop: \"' + name + '\"');\r\n return;\r\n }\r\n // missing but optional\r\n if (value == null && !prop.required) {\r\n return;\r\n }\r\n // type check\r\n if (type != null && type !== true) {\r\n let isValid = false;\r\n const types = isArray(type) ? type : [type];\r\n const expectedTypes = [];\r\n // value is valid as long as one of the specified types match\r\n for (let i = 0; i < types.length && !isValid; i++) {\r\n const { valid, expectedType } = assertType(value, types[i]);\r\n expectedTypes.push(expectedType || '');\r\n isValid = valid;\r\n }\r\n if (!isValid) {\r\n warn(getInvalidTypeMessage(name, value, expectedTypes));\r\n return;\r\n }\r\n }\r\n // custom validator\r\n if (validator && !validator(value)) {\r\n warn('Invalid prop: custom validator check failed for prop \"' + name + '\".');\r\n }\r\n}\r\nconst isSimpleType = /*#__PURE__*/ makeMap('String,Number,Boolean,Function,Symbol,BigInt');\r\n/**\r\n * dev only\r\n */\r\nfunction assertType(value, type) {\r\n let valid;\r\n const expectedType = getType(type);\r\n if (isSimpleType(expectedType)) {\r\n const t = typeof value;\r\n valid = t === expectedType.toLowerCase();\r\n // for primitive wrapper objects\r\n if (!valid && t === 'object') {\r\n valid = value instanceof type;\r\n }\r\n }\r\n else if (expectedType === 'Object') {\r\n valid = isObject(value);\r\n }\r\n else if (expectedType === 'Array') {\r\n valid = isArray(value);\r\n }\r\n else if (expectedType === 'null') {\r\n valid = value === null;\r\n }\r\n else {\r\n valid = value instanceof type;\r\n }\r\n return {\r\n valid,\r\n expectedType\r\n };\r\n}\r\n/**\r\n * dev only\r\n */\r\nfunction getInvalidTypeMessage(name, value, expectedTypes) {\r\n let message = `Invalid prop: type check failed for prop \"${name}\".` +\r\n ` Expected ${expectedTypes.map(capitalize).join(' | ')}`;\r\n const expectedType = expectedTypes[0];\r\n const receivedType = toRawType(value);\r\n const expectedValue = styleValue(value, expectedType);\r\n const receivedValue = styleValue(value, receivedType);\r\n // check if we need to specify expected value\r\n if (expectedTypes.length === 1 &&\r\n isExplicable(expectedType) &&\r\n !isBoolean(expectedType, receivedType)) {\r\n message += ` with value ${expectedValue}`;\r\n }\r\n message += `, got ${receivedType} `;\r\n // check if we need to specify received value\r\n if (isExplicable(receivedType)) {\r\n message += `with value ${receivedValue}.`;\r\n }\r\n return message;\r\n}\r\n/**\r\n * dev only\r\n */\r\nfunction styleValue(value, type) {\r\n if (type === 'String') {\r\n return `\"${value}\"`;\r\n }\r\n else if (type === 'Number') {\r\n return `${Number(value)}`;\r\n }\r\n else {\r\n return `${value}`;\r\n }\r\n}\r\n/**\r\n * dev only\r\n */\r\nfunction isExplicable(type) {\r\n const explicitTypes = ['string', 'number', 'boolean'];\r\n return explicitTypes.some(elem => type.toLowerCase() === elem);\r\n}\r\n/**\r\n * dev only\r\n */\r\nfunction isBoolean(...args) {\r\n return args.some(elem => elem.toLowerCase() === 'boolean');\r\n}\n\nconst isInternalKey = (key) => key[0] === '_' || key === '$stable';\r\nconst normalizeSlotValue = (value) => isArray(value)\r\n ? value.map(normalizeVNode)\r\n : [normalizeVNode(value)];\r\nconst normalizeSlot = (key, rawSlot, ctx) => {\r\n if (rawSlot._n) {\r\n // already normalized - #5353\r\n return rawSlot;\r\n }\r\n const normalized = withCtx((...args) => {\r\n if ((process.env.NODE_ENV !== 'production') && currentInstance) {\r\n warn(`Slot \"${key}\" invoked outside of the render function: ` +\r\n `this will not track dependencies used in the slot. ` +\r\n `Invoke the slot function inside the render function instead.`);\r\n }\r\n return normalizeSlotValue(rawSlot(...args));\r\n }, ctx);\r\n normalized._c = false;\r\n return normalized;\r\n};\r\nconst normalizeObjectSlots = (rawSlots, slots, instance) => {\r\n const ctx = rawSlots._ctx;\r\n for (const key in rawSlots) {\r\n if (isInternalKey(key))\r\n continue;\r\n const value = rawSlots[key];\r\n if (isFunction(value)) {\r\n slots[key] = normalizeSlot(key, value, ctx);\r\n }\r\n else if (value != null) {\r\n if ((process.env.NODE_ENV !== 'production') &&\r\n !(false )) {\r\n warn(`Non-function value encountered for slot \"${key}\". ` +\r\n `Prefer function slots for better performance.`);\r\n }\r\n const normalized = normalizeSlotValue(value);\r\n slots[key] = () => normalized;\r\n }\r\n }\r\n};\r\nconst normalizeVNodeSlots = (instance, children) => {\r\n if ((process.env.NODE_ENV !== 'production') &&\r\n !isKeepAlive(instance.vnode) &&\r\n !(false )) {\r\n warn(`Non-function value encountered for default slot. ` +\r\n `Prefer function slots for better performance.`);\r\n }\r\n const normalized = normalizeSlotValue(children);\r\n instance.slots.default = () => normalized;\r\n};\r\nconst initSlots = (instance, children) => {\r\n if (instance.vnode.shapeFlag & 32 /* SLOTS_CHILDREN */) {\r\n const type = children._;\r\n if (type) {\r\n // users can get the shallow readonly version of the slots object through `this.$slots`,\r\n // we should avoid the proxy object polluting the slots of the internal instance\r\n instance.slots = toRaw(children);\r\n // make compiler marker non-enumerable\r\n def(children, '_', type);\r\n }\r\n else {\r\n normalizeObjectSlots(children, (instance.slots = {}));\r\n }\r\n }\r\n else {\r\n instance.slots = {};\r\n if (children) {\r\n normalizeVNodeSlots(instance, children);\r\n }\r\n }\r\n def(instance.slots, InternalObjectKey, 1);\r\n};\r\nconst updateSlots = (instance, children, optimized) => {\r\n const { vnode, slots } = instance;\r\n let needDeletionCheck = true;\r\n let deletionComparisonTarget = EMPTY_OBJ;\r\n if (vnode.shapeFlag & 32 /* SLOTS_CHILDREN */) {\r\n const type = children._;\r\n if (type) {\r\n // compiled slots.\r\n if ((process.env.NODE_ENV !== 'production') && isHmrUpdating) {\r\n // Parent was HMR updated so slot content may have changed.\r\n // force update slots and mark instance for hmr as well\r\n extend(slots, children);\r\n }\r\n else if (optimized && type === 1 /* STABLE */) {\r\n // compiled AND stable.\r\n // no need to update, and skip stale slots removal.\r\n needDeletionCheck = false;\r\n }\r\n else {\r\n // compiled but dynamic (v-if/v-for on slots) - update slots, but skip\r\n // normalization.\r\n extend(slots, children);\r\n // #2893\r\n // when rendering the optimized slots by manually written render function,\r\n // we need to delete the `slots._` flag if necessary to make subsequent updates reliable,\r\n // i.e. let the `renderSlot` create the bailed Fragment\r\n if (!optimized && type === 1 /* STABLE */) {\r\n delete slots._;\r\n }\r\n }\r\n }\r\n else {\r\n needDeletionCheck = !children.$stable;\r\n normalizeObjectSlots(children, slots);\r\n }\r\n deletionComparisonTarget = children;\r\n }\r\n else if (children) {\r\n // non slot object children (direct value) passed to a component\r\n normalizeVNodeSlots(instance, children);\r\n deletionComparisonTarget = { default: 1 };\r\n }\r\n // delete stale slots\r\n if (needDeletionCheck) {\r\n for (const key in slots) {\r\n if (!isInternalKey(key) && !(key in deletionComparisonTarget)) {\r\n delete slots[key];\r\n }\r\n }\r\n }\r\n};\n\nfunction createAppContext() {\r\n return {\r\n app: null,\r\n config: {\r\n isNativeTag: NO,\r\n performance: false,\r\n globalProperties: {},\r\n optionMergeStrategies: {},\r\n errorHandler: undefined,\r\n warnHandler: undefined,\r\n compilerOptions: {}\r\n },\r\n mixins: [],\r\n components: {},\r\n directives: {},\r\n provides: Object.create(null),\r\n optionsCache: new WeakMap(),\r\n propsCache: new WeakMap(),\r\n emitsCache: new WeakMap()\r\n };\r\n}\r\nlet uid = 0;\r\nfunction createAppAPI(render, hydrate) {\r\n return function createApp(rootComponent, rootProps = null) {\r\n if (!isFunction(rootComponent)) {\r\n rootComponent = Object.assign({}, rootComponent);\r\n }\r\n if (rootProps != null && !isObject(rootProps)) {\r\n (process.env.NODE_ENV !== 'production') && warn(`root props passed to app.mount() must be an object.`);\r\n rootProps = null;\r\n }\r\n const context = createAppContext();\r\n const installedPlugins = new Set();\r\n let isMounted = false;\r\n const app = (context.app = {\r\n _uid: uid++,\r\n _component: rootComponent,\r\n _props: rootProps,\r\n _container: null,\r\n _context: context,\r\n _instance: null,\r\n version,\r\n get config() {\r\n return context.config;\r\n },\r\n set config(v) {\r\n if ((process.env.NODE_ENV !== 'production')) {\r\n warn(`app.config cannot be replaced. Modify individual options instead.`);\r\n }\r\n },\r\n use(plugin, ...options) {\r\n if (installedPlugins.has(plugin)) {\r\n (process.env.NODE_ENV !== 'production') && warn(`Plugin has already been applied to target app.`);\r\n }\r\n else if (plugin && isFunction(plugin.install)) {\r\n installedPlugins.add(plugin);\r\n plugin.install(app, ...options);\r\n }\r\n else if (isFunction(plugin)) {\r\n installedPlugins.add(plugin);\r\n plugin(app, ...options);\r\n }\r\n else if ((process.env.NODE_ENV !== 'production')) {\r\n warn(`A plugin must either be a function or an object with an \"install\" ` +\r\n `function.`);\r\n }\r\n return app;\r\n },\r\n mixin(mixin) {\r\n if (__VUE_OPTIONS_API__) {\r\n if (!context.mixins.includes(mixin)) {\r\n context.mixins.push(mixin);\r\n }\r\n else if ((process.env.NODE_ENV !== 'production')) {\r\n warn('Mixin has already been applied to target app' +\r\n (mixin.name ? `: ${mixin.name}` : ''));\r\n }\r\n }\r\n else if ((process.env.NODE_ENV !== 'production')) {\r\n warn('Mixins are only available in builds supporting Options API');\r\n }\r\n return app;\r\n },\r\n component(name, component) {\r\n if ((process.env.NODE_ENV !== 'production')) {\r\n validateComponentName(name, context.config);\r\n }\r\n if (!component) {\r\n return context.components[name];\r\n }\r\n if ((process.env.NODE_ENV !== 'production') && context.components[name]) {\r\n warn(`Component \"${name}\" has already been registered in target app.`);\r\n }\r\n context.components[name] = component;\r\n return app;\r\n },\r\n directive(name, directive) {\r\n if ((process.env.NODE_ENV !== 'production')) {\r\n validateDirectiveName(name);\r\n }\r\n if (!directive) {\r\n return context.directives[name];\r\n }\r\n if ((process.env.NODE_ENV !== 'production') && context.directives[name]) {\r\n warn(`Directive \"${name}\" has already been registered in target app.`);\r\n }\r\n context.directives[name] = directive;\r\n return app;\r\n },\r\n mount(rootContainer, isHydrate, isSVG) {\r\n if (!isMounted) {\r\n // #5571\r\n if ((process.env.NODE_ENV !== 'production') && rootContainer.__vue_app__) {\r\n warn(`There is already an app instance mounted on the host container.\\n` +\r\n ` If you want to mount another app on the same host container,` +\r\n ` you need to unmount the previous app by calling \\`app.unmount()\\` first.`);\r\n }\r\n const vnode = createVNode(rootComponent, rootProps);\r\n // store app context on the root VNode.\r\n // this will be set on the root instance on initial mount.\r\n vnode.appContext = context;\r\n // HMR root reload\r\n if ((process.env.NODE_ENV !== 'production')) {\r\n context.reload = () => {\r\n render(cloneVNode(vnode), rootContainer, isSVG);\r\n };\r\n }\r\n if (isHydrate && hydrate) {\r\n hydrate(vnode, rootContainer);\r\n }\r\n else {\r\n render(vnode, rootContainer, isSVG);\r\n }\r\n isMounted = true;\r\n app._container = rootContainer;\r\n rootContainer.__vue_app__ = app;\r\n if ((process.env.NODE_ENV !== 'production') || __VUE_PROD_DEVTOOLS__) {\r\n app._instance = vnode.component;\r\n devtoolsInitApp(app, version);\r\n }\r\n return getExposeProxy(vnode.component) || vnode.component.proxy;\r\n }\r\n else if ((process.env.NODE_ENV !== 'production')) {\r\n warn(`App has already been mounted.\\n` +\r\n `If you want to remount the same app, move your app creation logic ` +\r\n `into a factory function and create fresh app instances for each ` +\r\n `mount - e.g. \\`const createMyApp = () => createApp(App)\\``);\r\n }\r\n },\r\n unmount() {\r\n if (isMounted) {\r\n render(null, app._container);\r\n if ((process.env.NODE_ENV !== 'production') || __VUE_PROD_DEVTOOLS__) {\r\n app._instance = null;\r\n devtoolsUnmountApp(app);\r\n }\r\n delete app._container.__vue_app__;\r\n }\r\n else if ((process.env.NODE_ENV !== 'production')) {\r\n warn(`Cannot unmount an app that is not mounted.`);\r\n }\r\n },\r\n provide(key, value) {\r\n if ((process.env.NODE_ENV !== 'production') && key in context.provides) {\r\n warn(`App already provides property with key \"${String(key)}\". ` +\r\n `It will be overwritten with the new value.`);\r\n }\r\n context.provides[key] = value;\r\n return app;\r\n }\r\n });\r\n return app;\r\n };\r\n}\n\n/**\r\n * Function for handling a template ref\r\n */\r\nfunction setRef(rawRef, oldRawRef, parentSuspense, vnode, isUnmount = false) {\r\n if (isArray(rawRef)) {\r\n rawRef.forEach((r, i) => setRef(r, oldRawRef && (isArray(oldRawRef) ? oldRawRef[i] : oldRawRef), parentSuspense, vnode, isUnmount));\r\n return;\r\n }\r\n if (isAsyncWrapper(vnode) && !isUnmount) {\r\n // when mounting async components, nothing needs to be done,\r\n // because the template ref is forwarded to inner component\r\n return;\r\n }\r\n const refValue = vnode.shapeFlag & 4 /* STATEFUL_COMPONENT */\r\n ? getExposeProxy(vnode.component) || vnode.component.proxy\r\n : vnode.el;\r\n const value = isUnmount ? null : refValue;\r\n const { i: owner, r: ref } = rawRef;\r\n if ((process.env.NODE_ENV !== 'production') && !owner) {\r\n warn(`Missing ref owner context. ref cannot be used on hoisted vnodes. ` +\r\n `A vnode with ref must be created inside the render function.`);\r\n return;\r\n }\r\n const oldRef = oldRawRef && oldRawRef.r;\r\n const refs = owner.refs === EMPTY_OBJ ? (owner.refs = {}) : owner.refs;\r\n const setupState = owner.setupState;\r\n // dynamic ref changed. unset old ref\r\n if (oldRef != null && oldRef !== ref) {\r\n if (isString(oldRef)) {\r\n refs[oldRef] = null;\r\n if (hasOwn(setupState, oldRef)) {\r\n setupState[oldRef] = null;\r\n }\r\n }\r\n else if (isRef(oldRef)) {\r\n oldRef.value = null;\r\n }\r\n }\r\n if (isFunction(ref)) {\r\n callWithErrorHandling(ref, owner, 12 /* FUNCTION_REF */, [value, refs]);\r\n }\r\n else {\r\n const _isString = isString(ref);\r\n const _isRef = isRef(ref);\r\n if (_isString || _isRef) {\r\n const doSet = () => {\r\n if (rawRef.f) {\r\n const existing = _isString ? refs[ref] : ref.value;\r\n if (isUnmount) {\r\n isArray(existing) && remove(existing, refValue);\r\n }\r\n else {\r\n if (!isArray(existing)) {\r\n if (_isString) {\r\n refs[ref] = [refValue];\r\n if (hasOwn(setupState, ref)) {\r\n setupState[ref] = refs[ref];\r\n }\r\n }\r\n else {\r\n ref.value = [refValue];\r\n if (rawRef.k)\r\n refs[rawRef.k] = ref.value;\r\n }\r\n }\r\n else if (!existing.includes(refValue)) {\r\n existing.push(refValue);\r\n }\r\n }\r\n }\r\n else if (_isString) {\r\n refs[ref] = value;\r\n if (hasOwn(setupState, ref)) {\r\n setupState[ref] = value;\r\n }\r\n }\r\n else if (isRef(ref)) {\r\n ref.value = value;\r\n if (rawRef.k)\r\n refs[rawRef.k] = value;\r\n }\r\n else if ((process.env.NODE_ENV !== 'production')) {\r\n warn('Invalid template ref type:', ref, `(${typeof ref})`);\r\n }\r\n };\r\n if (value) {\r\n doSet.id = -1;\r\n queuePostRenderEffect(doSet, parentSuspense);\r\n }\r\n else {\r\n doSet();\r\n }\r\n }\r\n else if ((process.env.NODE_ENV !== 'production')) {\r\n warn('Invalid template ref type:', ref, `(${typeof ref})`);\r\n }\r\n }\r\n}\n\nlet hasMismatch = false;\r\nconst isSVGContainer = (container) => /svg/.test(container.namespaceURI) && container.tagName !== 'foreignObject';\r\nconst isComment = (node) => node.nodeType === 8 /* COMMENT */;\r\n// Note: hydration is DOM-specific\r\n// But we have to place it in core due to tight coupling with core - splitting\r\n// it out creates a ton of unnecessary complexity.\r\n// Hydration also depends on some renderer internal logic which needs to be\r\n// passed in via arguments.\r\nfunction createHydrationFunctions(rendererInternals) {\r\n const { mt: mountComponent, p: patch, o: { patchProp, createText, nextSibling, parentNode, remove, insert, createComment } } = rendererInternals;\r\n const hydrate = (vnode, container) => {\r\n if (!container.hasChildNodes()) {\r\n (process.env.NODE_ENV !== 'production') &&\r\n warn(`Attempting to hydrate existing markup but container is empty. ` +\r\n `Performing full mount instead.`);\r\n patch(null, vnode, container);\r\n flushPostFlushCbs();\r\n return;\r\n }\r\n hasMismatch = false;\r\n hydrateNode(container.firstChild, vnode, null, null, null);\r\n flushPostFlushCbs();\r\n if (hasMismatch && !false) {\r\n // this error should show up in production\r\n console.error(`Hydration completed but contains mismatches.`);\r\n }\r\n };\r\n const hydrateNode = (node, vnode, parentComponent, parentSuspense, slotScopeIds, optimized = false) => {\r\n const isFragmentStart = isComment(node) && node.data === '[';\r\n const onMismatch = () => handleMismatch(node, vnode, parentComponent, parentSuspense, slotScopeIds, isFragmentStart);\r\n const { type, ref, shapeFlag, patchFlag } = vnode;\r\n const domType = node.nodeType;\r\n vnode.el = node;\r\n if (patchFlag === -2 /* BAIL */) {\r\n optimized = false;\r\n vnode.dynamicChildren = null;\r\n }\r\n let nextNode = null;\r\n switch (type) {\r\n case Text:\r\n if (domType !== 3 /* TEXT */) {\r\n // #5728 empty text node inside a slot can cause hydration failure\r\n // because the server rendered HTML won't contain a text node\r\n if (vnode.children === '') {\r\n insert((vnode.el = createText('')), parentNode(node), node);\r\n nextNode = node;\r\n }\r\n else {\r\n nextNode = onMismatch();\r\n }\r\n }\r\n else {\r\n if (node.data !== vnode.children) {\r\n hasMismatch = true;\r\n (process.env.NODE_ENV !== 'production') &&\r\n warn(`Hydration text mismatch:` +\r\n `\\n- Client: ${JSON.stringify(node.data)}` +\r\n `\\n- Server: ${JSON.stringify(vnode.children)}`);\r\n node.data = vnode.children;\r\n }\r\n nextNode = nextSibling(node);\r\n }\r\n break;\r\n case Comment:\r\n if (domType !== 8 /* COMMENT */ || isFragmentStart) {\r\n nextNode = onMismatch();\r\n }\r\n else {\r\n nextNode = nextSibling(node);\r\n }\r\n break;\r\n case Static:\r\n if (domType !== 1 /* ELEMENT */) {\r\n nextNode = onMismatch();\r\n }\r\n else {\r\n // determine anchor, adopt content\r\n nextNode = node;\r\n // if the static vnode has its content stripped during build,\r\n // adopt it from the server-rendered HTML.\r\n const needToAdoptContent = !vnode.children.length;\r\n for (let i = 0; i < vnode.staticCount; i++) {\r\n if (needToAdoptContent)\r\n vnode.children += nextNode.outerHTML;\r\n if (i === vnode.staticCount - 1) {\r\n vnode.anchor = nextNode;\r\n }\r\n nextNode = nextSibling(nextNode);\r\n }\r\n return nextNode;\r\n }\r\n break;\r\n case Fragment:\r\n if (!isFragmentStart) {\r\n nextNode = onMismatch();\r\n }\r\n else {\r\n nextNode = hydrateFragment(node, vnode, parentComponent, parentSuspense, slotScopeIds, optimized);\r\n }\r\n break;\r\n default:\r\n if (shapeFlag & 1 /* ELEMENT */) {\r\n if (domType !== 1 /* ELEMENT */ ||\r\n vnode.type.toLowerCase() !==\r\n node.tagName.toLowerCase()) {\r\n nextNode = onMismatch();\r\n }\r\n else {\r\n nextNode = hydrateElement(node, vnode, parentComponent, parentSuspense, slotScopeIds, optimized);\r\n }\r\n }\r\n else if (shapeFlag & 6 /* COMPONENT */) {\r\n // when setting up the render effect, if the initial vnode already\r\n // has .el set, the component will perform hydration instead of mount\r\n // on its sub-tree.\r\n vnode.slotScopeIds = slotScopeIds;\r\n const container = parentNode(node);\r\n mountComponent(vnode, container, null, parentComponent, parentSuspense, isSVGContainer(container), optimized);\r\n // component may be async, so in the case of fragments we cannot rely\r\n // on component's rendered output to determine the end of the fragment\r\n // instead, we do a lookahead to find the end anchor node.\r\n nextNode = isFragmentStart\r\n ? locateClosingAsyncAnchor(node)\r\n : nextSibling(node);\r\n // #4293 teleport as component root\r\n if (nextNode &&\r\n isComment(nextNode) &&\r\n nextNode.data === 'teleport end') {\r\n nextNode = nextSibling(nextNode);\r\n }\r\n // #3787\r\n // if component is async, it may get moved / unmounted before its\r\n // inner component is loaded, so we need to give it a placeholder\r\n // vnode that matches its adopted DOM.\r\n if (isAsyncWrapper(vnode)) {\r\n let subTree;\r\n if (isFragmentStart) {\r\n subTree = createVNode(Fragment);\r\n subTree.anchor = nextNode\r\n ? nextNode.previousSibling\r\n : container.lastChild;\r\n }\r\n else {\r\n subTree =\r\n node.nodeType === 3 ? createTextVNode('') : createVNode('div');\r\n }\r\n subTree.el = node;\r\n vnode.component.subTree = subTree;\r\n }\r\n }\r\n else if (shapeFlag & 64 /* TELEPORT */) {\r\n if (domType !== 8 /* COMMENT */) {\r\n nextNode = onMismatch();\r\n }\r\n else {\r\n nextNode = vnode.type.hydrate(node, vnode, parentComponent, parentSuspense, slotScopeIds, optimized, rendererInternals, hydrateChildren);\r\n }\r\n }\r\n else if (shapeFlag & 128 /* SUSPENSE */) {\r\n nextNode = vnode.type.hydrate(node, vnode, parentComponent, parentSuspense, isSVGContainer(parentNode(node)), slotScopeIds, optimized, rendererInternals, hydrateNode);\r\n }\r\n else if ((process.env.NODE_ENV !== 'production')) {\r\n warn('Invalid HostVNode type:', type, `(${typeof type})`);\r\n }\r\n }\r\n if (ref != null) {\r\n setRef(ref, null, parentSuspense, vnode);\r\n }\r\n return nextNode;\r\n };\r\n const hydrateElement = (el, vnode, parentComponent, parentSuspense, slotScopeIds, optimized) => {\r\n optimized = optimized || !!vnode.dynamicChildren;\r\n const { type, props, patchFlag, shapeFlag, dirs } = vnode;\r\n // #4006 for form elements with non-string v-model value bindings\r\n // e.g. <option :value=\"obj\">, <input type=\"checkbox\" :true-value=\"1\">\r\n const forcePatchValue = (type === 'input' && dirs) || type === 'option';\r\n // skip props & children if this is hoisted static nodes\r\n // #5405 in dev, always hydrate children for HMR\r\n if ((process.env.NODE_ENV !== 'production') || forcePatchValue || patchFlag !== -1 /* HOISTED */) {\r\n if (dirs) {\r\n invokeDirectiveHook(vnode, null, parentComponent, 'created');\r\n }\r\n // props\r\n if (props) {\r\n if (forcePatchValue ||\r\n !optimized ||\r\n patchFlag & (16 /* FULL_PROPS */ | 32 /* HYDRATE_EVENTS */)) {\r\n for (const key in props) {\r\n if ((forcePatchValue && key.endsWith('value')) ||\r\n (isOn(key) && !isReservedProp(key))) {\r\n patchProp(el, key, null, props[key], false, undefined, parentComponent);\r\n }\r\n }\r\n }\r\n else if (props.onClick) {\r\n // Fast path for click listeners (which is most often) to avoid\r\n // iterating through props.\r\n patchProp(el, 'onClick', null, props.onClick, false, undefined, parentComponent);\r\n }\r\n }\r\n // vnode / directive hooks\r\n let vnodeHooks;\r\n if ((vnodeHooks = props && props.onVnodeBeforeMount)) {\r\n invokeVNodeHook(vnodeHooks, parentComponent, vnode);\r\n }\r\n if (dirs) {\r\n invokeDirectiveHook(vnode, null, parentComponent, 'beforeMount');\r\n }\r\n if ((vnodeHooks = props && props.onVnodeMounted) || dirs) {\r\n queueEffectWithSuspense(() => {\r\n vnodeHooks && invokeVNodeHook(vnodeHooks, parentComponent, vnode);\r\n dirs && invokeDirectiveHook(vnode, null, parentComponent, 'mounted');\r\n }, parentSuspense);\r\n }\r\n // children\r\n if (shapeFlag & 16 /* ARRAY_CHILDREN */ &&\r\n // skip if element has innerHTML / textContent\r\n !(props && (props.innerHTML || props.textContent))) {\r\n let next = hydrateChildren(el.firstChild, vnode, el, parentComponent, parentSuspense, slotScopeIds, optimized);\r\n let hasWarned = false;\r\n while (next) {\r\n hasMismatch = true;\r\n if ((process.env.NODE_ENV !== 'production') && !hasWarned) {\r\n warn(`Hydration children mismatch in <${vnode.type}>: ` +\r\n `server rendered element contains more child nodes than client vdom.`);\r\n hasWarned = true;\r\n }\r\n // The SSRed DOM contains more nodes than it should. Remove them.\r\n const cur = next;\r\n next = next.nextSibling;\r\n remove(cur);\r\n }\r\n }\r\n else if (shapeFlag & 8 /* TEXT_CHILDREN */) {\r\n if (el.textContent !== vnode.children) {\r\n hasMismatch = true;\r\n (process.env.NODE_ENV !== 'production') &&\r\n warn(`Hydration text content mismatch in <${vnode.type}>:\\n` +\r\n `- Client: ${el.textContent}\\n` +\r\n `- Server: ${vnode.children}`);\r\n el.textContent = vnode.children;\r\n }\r\n }\r\n }\r\n return el.nextSibling;\r\n };\r\n const hydrateChildren = (node, parentVNode, container, parentComponent, parentSuspense, slotScopeIds, optimized) => {\r\n optimized = optimized || !!parentVNode.dynamicChildren;\r\n const children = parentVNode.children;\r\n const l = children.length;\r\n let hasWarned = false;\r\n for (let i = 0; i < l; i++) {\r\n const vnode = optimized\r\n ? children[i]\r\n : (children[i] = normalizeVNode(children[i]));\r\n if (node) {\r\n node = hydrateNode(node, vnode, parentComponent, parentSuspense, slotScopeIds, optimized);\r\n }\r\n else if (vnode.type === Text && !vnode.children) {\r\n continue;\r\n }\r\n else {\r\n hasMismatch = true;\r\n if ((process.env.NODE_ENV !== 'production') && !hasWarned) {\r\n warn(`Hydration children mismatch in <${container.tagName.toLowerCase()}>: ` +\r\n `server rendered element contains fewer child nodes than client vdom.`);\r\n hasWarned = true;\r\n }\r\n // the SSRed DOM didn't contain enough nodes. Mount the missing ones.\r\n patch(null, vnode, container, null, parentComponent, parentSuspense, isSVGContainer(container), slotScopeIds);\r\n }\r\n }\r\n return node;\r\n };\r\n const hydrateFragment = (node, vnode, parentComponent, parentSuspense, slotScopeIds, optimized) => {\r\n const { slotScopeIds: fragmentSlotScopeIds } = vnode;\r\n if (fragmentSlotScopeIds) {\r\n slotScopeIds = slotScopeIds\r\n ? slotScopeIds.concat(fragmentSlotScopeIds)\r\n : fragmentSlotScopeIds;\r\n }\r\n const container = parentNode(node);\r\n const next = hydrateChildren(nextSibling(node), vnode, container, parentComponent, parentSuspense, slotScopeIds, optimized);\r\n if (next && isComment(next) && next.data === ']') {\r\n return nextSibling((vnode.anchor = next));\r\n }\r\n else {\r\n // fragment didn't hydrate successfully, since we didn't get a end anchor\r\n // back. This should have led to node/children mismatch warnings.\r\n hasMismatch = true;\r\n // since the anchor is missing, we need to create one and insert it\r\n insert((vnode.anchor = createComment(`]`)), container, next);\r\n return next;\r\n }\r\n };\r\n const handleMismatch = (node, vnode, parentComponent, parentSuspense, slotScopeIds, isFragment) => {\r\n hasMismatch = true;\r\n (process.env.NODE_ENV !== 'production') &&\r\n warn(`Hydration node mismatch:\\n- Client vnode:`, vnode.type, `\\n- Server rendered DOM:`, node, node.nodeType === 3 /* TEXT */\r\n ? `(text)`\r\n : isComment(node) && node.data === '['\r\n ? `(start of fragment)`\r\n : ``);\r\n vnode.el = null;\r\n if (isFragment) {\r\n // remove excessive fragment nodes\r\n const end = locateClosingAsyncAnchor(node);\r\n while (true) {\r\n const next = nextSibling(node);\r\n if (next && next !== end) {\r\n remove(next);\r\n }\r\n else {\r\n break;\r\n }\r\n }\r\n }\r\n const next = nextSibling(node);\r\n const container = parentNode(node);\r\n remove(node);\r\n patch(null, vnode, container, next, parentComponent, parentSuspense, isSVGContainer(container), slotScopeIds);\r\n return next;\r\n };\r\n const locateClosingAsyncAnchor = (node) => {\r\n let match = 0;\r\n while (node) {\r\n node = nextSibling(node);\r\n if (node && isComment(node)) {\r\n if (node.data === '[')\r\n match++;\r\n if (node.data === ']') {\r\n if (match === 0) {\r\n return nextSibling(node);\r\n }\r\n else {\r\n match--;\r\n }\r\n }\r\n }\r\n }\r\n return node;\r\n };\r\n return [hydrate, hydrateNode];\r\n}\n\n/* eslint-disable no-restricted-globals */\r\nlet supported;\r\nlet perf;\r\nfunction startMeasure(instance, type) {\r\n if (instance.appContext.config.performance && isSupported()) {\r\n perf.mark(`vue-${type}-${instance.uid}`);\r\n }\r\n if ((process.env.NODE_ENV !== 'production') || __VUE_PROD_DEVTOOLS__) {\r\n devtoolsPerfStart(instance, type, isSupported() ? perf.now() : Date.now());\r\n }\r\n}\r\nfunction endMeasure(instance, type) {\r\n if (instance.appContext.config.performance && isSupported()) {\r\n const startTag = `vue-${type}-${instance.uid}`;\r\n const endTag = startTag + `:end`;\r\n perf.mark(endTag);\r\n perf.measure(`<${formatComponentName(instance, instance.type)}> ${type}`, startTag, endTag);\r\n perf.clearMarks(startTag);\r\n perf.clearMarks(endTag);\r\n }\r\n if ((process.env.NODE_ENV !== 'production') || __VUE_PROD_DEVTOOLS__) {\r\n devtoolsPerfEnd(instance, type, isSupported() ? perf.now() : Date.now());\r\n }\r\n}\r\nfunction isSupported() {\r\n if (supported !== undefined) {\r\n return supported;\r\n }\r\n if (typeof window !== 'undefined' && window.performance) {\r\n supported = true;\r\n perf = window.performance;\r\n }\r\n else {\r\n supported = false;\r\n }\r\n return supported;\r\n}\n\n/**\r\n * This is only called in esm-bundler builds.\r\n * It is called when a renderer is created, in `baseCreateRenderer` so that\r\n * importing runtime-core is side-effects free.\r\n *\r\n * istanbul-ignore-next\r\n */\r\nfunction initFeatureFlags() {\r\n const needWarn = [];\r\n if (typeof __VUE_OPTIONS_API__ !== 'boolean') {\r\n (process.env.NODE_ENV !== 'production') && needWarn.push(`__VUE_OPTIONS_API__`);\r\n getGlobalThis().__VUE_OPTIONS_API__ = true;\r\n }\r\n if (typeof __VUE_PROD_DEVTOOLS__ !== 'boolean') {\r\n (process.env.NODE_ENV !== 'production') && needWarn.push(`__VUE_PROD_DEVTOOLS__`);\r\n getGlobalThis().__VUE_PROD_DEVTOOLS__ = false;\r\n }\r\n if ((process.env.NODE_ENV !== 'production') && needWarn.length) {\r\n const multi = needWarn.length > 1;\r\n console.warn(`Feature flag${multi ? `s` : ``} ${needWarn.join(', ')} ${multi ? `are` : `is`} not explicitly defined. You are running the esm-bundler build of Vue, ` +\r\n `which expects these compile-time feature flags to be globally injected ` +\r\n `via the bundler config in order to get better tree-shaking in the ` +\r\n `production bundle.\\n\\n` +\r\n `For more details, see https://link.vuejs.org/feature-flags.`);\r\n }\r\n}\n\nconst queuePostRenderEffect = queueEffectWithSuspense\r\n ;\r\n/**\r\n * The createRenderer function accepts two generic arguments:\r\n * HostNode and HostElement, corresponding to Node and Element types in the\r\n * host environment. For example, for runtime-dom, HostNode would be the DOM\r\n * `Node` interface and HostElement would be the DOM `Element` interface.\r\n *\r\n * Custom renderers can pass in the platform specific types like this:\r\n *\r\n * ``` js\r\n * const { render, createApp } = createRenderer<Node, Element>({\r\n * patchProp,\r\n * ...nodeOps\r\n * })\r\n * ```\r\n */\r\nfunction createRenderer(options) {\r\n return baseCreateRenderer(options);\r\n}\r\n// Separate API for creating hydration-enabled renderer.\r\n// Hydration logic is only used when calling this function, making it\r\n// tree-shakable.\r\nfunction createHydrationRenderer(options) {\r\n return baseCreateRenderer(options, createHydrationFunctions);\r\n}\r\n// implementation\r\nfunction baseCreateRenderer(options, createHydrationFns) {\r\n // compile-time feature flags check\r\n {\r\n initFeatureFlags();\r\n }\r\n const target = getGlobalThis();\r\n target.__VUE__ = true;\r\n if ((process.env.NODE_ENV !== 'production') || __VUE_PROD_DEVTOOLS__) {\r\n setDevtoolsHook(target.__VUE_DEVTOOLS_GLOBAL_HOOK__, target);\r\n }\r\n const { insert: hostInsert, remove: hostRemove, patchProp: hostPatchProp, createElement: hostCreateElement, createText: hostCreateText, createComment: hostCreateComment, setText: hostSetText, setElementText: hostSetElementText, parentNode: hostParentNode, nextSibling: hostNextSibling, setScopeId: hostSetScopeId = NOOP, cloneNode: hostCloneNode, insertStaticContent: hostInsertStaticContent } = options;\r\n // Note: functions inside this closure should use `const xxx = () => {}`\r\n // style in order to prevent being inlined by minifiers.\r\n const patch = (n1, n2, container, anchor = null, parentComponent = null, parentSuspense = null, isSVG = false, slotScopeIds = null, optimized = (process.env.NODE_ENV !== 'production') && isHmrUpdating ? false : !!n2.dynamicChildren) => {\r\n if (n1 === n2) {\r\n return;\r\n }\r\n // patching & not same type, unmount old tree\r\n if (n1 && !isSameVNodeType(n1, n2)) {\r\n anchor = getNextHostNode(n1);\r\n unmount(n1, parentComponent, parentSuspense, true);\r\n n1 = null;\r\n }\r\n if (n2.patchFlag === -2 /* BAIL */) {\r\n optimized = false;\r\n n2.dynamicChildren = null;\r\n }\r\n const { type, ref, shapeFlag } = n2;\r\n switch (type) {\r\n case Text:\r\n processText(n1, n2, container, anchor);\r\n break;\r\n case Comment:\r\n processCommentNode(n1, n2, container, anchor);\r\n break;\r\n case Static:\r\n if (n1 == null) {\r\n mountStaticNode(n2, container, anchor, isSVG);\r\n }\r\n else if ((process.env.NODE_ENV !== 'production')) {\r\n patchStaticNode(n1, n2, container, isSVG);\r\n }\r\n break;\r\n case Fragment:\r\n processFragment(n1, n2, container, anchor, parentComponent, parentSuspense, isSVG, slotScopeIds, optimized);\r\n break;\r\n default:\r\n if (shapeFlag & 1 /* ELEMENT */) {\r\n processElement(n1, n2, container, anchor, parentComponent, parentSuspense, isSVG, slotScopeIds, optimized);\r\n }\r\n else if (shapeFlag & 6 /* COMPONENT */) {\r\n processComponent(n1, n2, container, anchor, parentComponent, parentSuspense, isSVG, slotScopeIds, optimized);\r\n }\r\n else if (shapeFlag & 64 /* TELEPORT */) {\r\n type.process(n1, n2, container, anchor, parentComponent, parentSuspense, isSVG, slotScopeIds, optimized, internals);\r\n }\r\n else if (shapeFlag & 128 /* SUSPENSE */) {\r\n type.process(n1, n2, container, anchor, parentComponent, parentSuspense, isSVG, slotScopeIds, optimized, internals);\r\n }\r\n else if ((process.env.NODE_ENV !== 'production')) {\r\n warn('Invalid VNode type:', type, `(${typeof type})`);\r\n }\r\n }\r\n // set ref\r\n if (ref != null && parentComponent) {\r\n setRef(ref, n1 && n1.ref, parentSuspense, n2 || n1, !n2);\r\n }\r\n };\r\n const processText = (n1, n2, container, anchor) => {\r\n if (n1 == null) {\r\n hostInsert((n2.el = hostCreateText(n2.children)), container, anchor);\r\n }\r\n else {\r\n const el = (n2.el = n1.el);\r\n if (n2.children !== n1.children) {\r\n hostSetText(el, n2.children);\r\n }\r\n }\r\n };\r\n const processCommentNode = (n1, n2, container, anchor) => {\r\n if (n1 == null) {\r\n hostInsert((n2.el = hostCreateComment(n2.children || '')), container, anchor);\r\n }\r\n else {\r\n // there's no support for dynamic comments\r\n n2.el = n1.el;\r\n }\r\n };\r\n const mountStaticNode = (n2, container, anchor, isSVG) => {\r\n [n2.el, n2.anchor] = hostInsertStaticContent(n2.children, container, anchor, isSVG, n2.el, n2.anchor);\r\n };\r\n /**\r\n * Dev / HMR only\r\n */\r\n const patchStaticNode = (n1, n2, container, isSVG) => {\r\n // static nodes are only patched during dev for HMR\r\n if (n2.children !== n1.children) {\r\n const anchor = hostNextSibling(n1.anchor);\r\n // remove existing\r\n removeStaticNode(n1);\r\n [n2.el, n2.anchor] = hostInsertStaticContent(n2.children, container, anchor, isSVG);\r\n }\r\n else {\r\n n2.el = n1.el;\r\n n2.anchor = n1.anchor;\r\n }\r\n };\r\n const moveStaticNode = ({ el, anchor }, container, nextSibling) => {\r\n let next;\r\n while (el && el !== anchor) {\r\n next = hostNextSibling(el);\r\n hostInsert(el, container, nextSibling);\r\n el = next;\r\n }\r\n hostInsert(anchor, container, nextSibling);\r\n };\r\n const removeStaticNode = ({ el, anchor }) => {\r\n let next;\r\n while (el && el !== anchor) {\r\n next = hostNextSibling(el);\r\n hostRemove(el);\r\n el = next;\r\n }\r\n hostRemove(anchor);\r\n };\r\n const processElement = (n1, n2, container, anchor, parentComponent, parentSuspense, isSVG, slotScopeIds, optimized) => {\r\n isSVG = isSVG || n2.type === 'svg';\r\n if (n1 == null) {\r\n mountElement(n2, container, anchor, parentComponent, parentSuspense, isSVG, slotScopeIds, optimized);\r\n }\r\n else {\r\n patchElement(n1, n2, parentComponent, parentSuspense, isSVG, slotScopeIds, optimized);\r\n }\r\n };\r\n const mountElement = (vnode, container, anchor, parentComponent, parentSuspense, isSVG, slotScopeIds, optimized) => {\r\n let el;\r\n let vnodeHook;\r\n const { type, props, shapeFlag, transition, patchFlag, dirs } = vnode;\r\n if (!(process.env.NODE_ENV !== 'production') &&\r\n vnode.el &&\r\n hostCloneNode !== undefined &&\r\n patchFlag === -1 /* HOISTED */) {\r\n // If a vnode has non-null el, it means it's being reused.\r\n // Only static vnodes can be reused, so its mounted DOM nodes should be\r\n // exactly the same, and we can simply do a clone here.\r\n // only do this in production since cloned trees cannot be HMR updated.\r\n el = vnode.el = hostCloneNode(vnode.el);\r\n }\r\n else {\r\n el = vnode.el = hostCreateElement(vnode.type, isSVG, props && props.is, props);\r\n // mount children first, since some props may rely on child content\r\n // being already rendered, e.g. `<select value>`\r\n if (shapeFlag & 8 /* TEXT_CHILDREN */) {\r\n hostSetElementText(el, vnode.children);\r\n }\r\n else if (shapeFlag & 16 /* ARRAY_CHILDREN */) {\r\n mountChildren(vnode.children, el, null, parentComponent, parentSuspense, isSVG && type !== 'foreignObject', slotScopeIds, optimized);\r\n }\r\n if (dirs) {\r\n invokeDirectiveHook(vnode, null, parentComponent, 'created');\r\n }\r\n // props\r\n if (props) {\r\n for (const key in props) {\r\n if (key !== 'value' && !isReservedProp(key)) {\r\n hostPatchProp(el, key, null, props[key], isSVG, vnode.children, parentComponent, parentSuspense, unmountChildren);\r\n }\r\n }\r\n /**\r\n * Special case for setting value on DOM elements:\r\n * - it can be order-sensitive (e.g. should be set *after* min/max, #2325, #4024)\r\n * - it needs to be forced (#1471)\r\n * #2353 proposes adding another renderer option to configure this, but\r\n * the properties affects are so finite it is worth special casing it\r\n * here to reduce the complexity. (Special casing it also should not\r\n * affect non-DOM renderers)\r\n */\r\n if ('value' in props) {\r\n hostPatchProp(el, 'value', null, props.value);\r\n }\r\n if ((vnodeHook = props.onVnodeBeforeMount)) {\r\n invokeVNodeHook(vnodeHook, parentComponent, vnode);\r\n }\r\n }\r\n // scopeId\r\n setScopeId(el, vnode, vnode.scopeId, slotScopeIds, parentComponent);\r\n }\r\n if ((process.env.NODE_ENV !== 'production') || __VUE_PROD_DEVTOOLS__) {\r\n Object.defineProperty(el, '__vnode', {\r\n value: vnode,\r\n enumerable: false\r\n });\r\n Object.defineProperty(el, '__vueParentComponent', {\r\n value: parentComponent,\r\n enumerable: false\r\n });\r\n }\r\n if (dirs) {\r\n invokeDirectiveHook(vnode, null, parentComponent, 'beforeMount');\r\n }\r\n // #1583 For inside suspense + suspense not resolved case, enter hook should call when suspense resolved\r\n // #1689 For inside suspense + suspense resolved case, just call it\r\n const needCallTransitionHooks = (!parentSuspense || (parentSuspense && !parentSuspense.pendingBranch)) &&\r\n transition &&\r\n !transition.persisted;\r\n if (needCallTransitionHooks) {\r\n transition.beforeEnter(el);\r\n }\r\n hostInsert(el, container, anchor);\r\n if ((vnodeHook = props && props.onVnodeMounted) ||\r\n needCallTransitionHooks ||\r\n dirs) {\r\n queuePostRenderEffect(() => {\r\n vnodeHook && invokeVNodeHook(vnodeHook, parentComponent, vnode);\r\n needCallTransitionHooks && transition.enter(el);\r\n dirs && invokeDirectiveHook(vnode, null, parentComponent, 'mounted');\r\n }, parentSuspense);\r\n }\r\n };\r\n const setScopeId = (el, vnode, scopeId, slotScopeIds, parentComponent) => {\r\n if (scopeId) {\r\n hostSetScopeId(el, scopeId);\r\n }\r\n if (slotScopeIds) {\r\n for (let i = 0; i < slotScopeIds.length; i++) {\r\n hostSetScopeId(el, slotScopeIds[i]);\r\n }\r\n }\r\n if (parentComponent) {\r\n let subTree = parentComponent.subTree;\r\n if ((process.env.NODE_ENV !== 'production') &&\r\n subTree.patchFlag > 0 &&\r\n subTree.patchFlag & 2048 /* DEV_ROOT_FRAGMENT */) {\r\n subTree =\r\n filterSingleRoot(subTree.children) || subTree;\r\n }\r\n if (vnode === subTree) {\r\n const parentVNode = parentComponent.vnode;\r\n setScopeId(el, parentVNode, parentVNode.scopeId, parentVNode.slotScopeIds, parentComponent.parent);\r\n }\r\n }\r\n };\r\n const mountChildren = (children, container, anchor, parentComponent, parentSuspense, isSVG, slotScopeIds, optimized, start = 0) => {\r\n for (let i = start; i < children.length; i++) {\r\n const child = (children[i] = optimized\r\n ? cloneIfMounted(children[i])\r\n : normalizeVNode(children[i]));\r\n patch(null, child, container, anchor, parentComponent, parentSuspense, isSVG, slotScopeIds, optimized);\r\n }\r\n };\r\n const patchElement = (n1, n2, parentComponent, parentSuspense, isSVG, slotScopeIds, optimized) => {\r\n const el = (n2.el = n1.el);\r\n let { patchFlag, dynamicChildren, dirs } = n2;\r\n // #1426 take the old vnode's patch flag into account since user may clone a\r\n // compiler-generated vnode, which de-opts to FULL_PROPS\r\n patchFlag |= n1.patchFlag & 16 /* FULL_PROPS */;\r\n const oldProps = n1.props || EMPTY_OBJ;\r\n const newProps = n2.props || EMPTY_OBJ;\r\n let vnodeHook;\r\n // disable recurse in beforeUpdate hooks\r\n parentComponent && toggleRecurse(parentComponent, false);\r\n if ((vnodeHook = newProps.onVnodeBeforeUpdate)) {\r\n invokeVNodeHook(vnodeHook, parentComponent, n2, n1);\r\n }\r\n if (dirs) {\r\n invokeDirectiveHook(n2, n1, parentComponent, 'beforeUpdate');\r\n }\r\n parentComponent && toggleRecurse(parentComponent, true);\r\n if ((process.env.NODE_ENV !== 'production') && isHmrUpdating) {\r\n // HMR updated, force full diff\r\n patchFlag = 0;\r\n optimized = false;\r\n dynamicChildren = null;\r\n }\r\n const areChildrenSVG = isSVG && n2.type !== 'foreignObject';\r\n if (dynamicChildren) {\r\n patchBlockChildren(n1.dynamicChildren, dynamicChildren, el, parentComponent, parentSuspense, areChildrenSVG, slotScopeIds);\r\n if ((process.env.NODE_ENV !== 'production') && parentComponent && parentComponent.type.__hmrId) {\r\n traverseStaticChildren(n1, n2);\r\n }\r\n }\r\n else if (!optimized) {\r\n // full diff\r\n patchChildren(n1, n2, el, null, parentComponent, parentSuspense, areChildrenSVG, slotScopeIds, false);\r\n }\r\n if (patchFlag > 0) {\r\n // the presence of a patchFlag means this element's render code was\r\n // generated by the compiler and can take the fast path.\r\n // in this path old node and new node are guaranteed to have the same shape\r\n // (i.e. at the exact same position in the source template)\r\n if (patchFlag & 16 /* FULL_PROPS */) {\r\n // element props contain dynamic keys, full diff needed\r\n patchProps(el, n2, oldProps, newProps, parentComponent, parentSuspense, isSVG);\r\n }\r\n else {\r\n // class\r\n // this flag is matched when the element has dynamic class bindings.\r\n if (patchFlag & 2 /* CLASS */) {\r\n if (oldProps.class !== newProps.class) {\r\n hostPatchProp(el, 'class', null, newProps.class, isSVG);\r\n }\r\n }\r\n // style\r\n // this flag is matched when the element has dynamic style bindings\r\n if (patchFlag & 4 /* STYLE */) {\r\n hostPatchProp(el, 'style', oldProps.style, newProps.style, isSVG);\r\n }\r\n // props\r\n // This flag is matched when the element has dynamic prop/attr bindings\r\n // other than class and style. The keys of dynamic prop/attrs are saved for\r\n // faster iteration.\r\n // Note dynamic keys like :[foo]=\"bar\" will cause this optimization to\r\n // bail out and go through a full diff because we need to unset the old key\r\n if (patchFlag & 8 /* PROPS */) {\r\n // if the flag is present then dynamicProps must be non-null\r\n const propsToUpdate = n2.dynamicProps;\r\n for (let i = 0; i < propsToUpdate.length; i++) {\r\n const key = propsToUpdate[i];\r\n const prev = oldProps[key];\r\n const next = newProps[key];\r\n // #1471 force patch value\r\n if (next !== prev || key === 'value') {\r\n hostPatchProp(el, key, prev, next, isSVG, n1.children, parentComponent, parentSuspense, unmountChildren);\r\n }\r\n }\r\n }\r\n }\r\n // text\r\n // This flag is matched when the element has only dynamic text children.\r\n if (patchFlag & 1 /* TEXT */) {\r\n if (n1.children !== n2.children) {\r\n hostSetElementText(el, n2.children);\r\n }\r\n }\r\n }\r\n else if (!optimized && dynamicChildren == null) {\r\n // unoptimized, full diff\r\n patchProps(el, n2, oldProps, newProps, parentComponent, parentSuspense, isSVG);\r\n }\r\n if ((vnodeHook = newProps.onVnodeUpdated) || dirs) {\r\n queuePostRenderEffect(() => {\r\n vnodeHook && invokeVNodeHook(vnodeHook, parentComponent, n2, n1);\r\n dirs && invokeDirectiveHook(n2, n1, parentComponent, 'updated');\r\n }, parentSuspense);\r\n }\r\n };\r\n // The fast path for blocks.\r\n const patchBlockChildren = (oldChildren, newChildren, fallbackContainer, parentComponent, parentSuspense, isSVG, slotScopeIds) => {\r\n for (let i = 0; i < newChildren.length; i++) {\r\n const oldVNode = oldChildren[i];\r\n const newVNode = newChildren[i];\r\n // Determine the container (parent element) for the patch.\r\n const container = \r\n // oldVNode may be an errored async setup() component inside Suspense\r\n // which will not have a mounted element\r\n oldVNode.el &&\r\n // - In the case of a Fragment, we need to provide the actual parent\r\n // of the Fragment itself so it can move its children.\r\n (oldVNode.type === Fragment ||\r\n // - In the case of different nodes, there is going to be a replacement\r\n // which also requires the correct parent container\r\n !isSameVNodeType(oldVNode, newVNode) ||\r\n // - In the case of a component, it could contain anything.\r\n oldVNode.shapeFlag & (6 /* COMPONENT */ | 64 /* TELEPORT */))\r\n ? hostParentNode(oldVNode.el)\r\n : // In other cases, the parent container is not actually used so we\r\n // just pass the block element here to avoid a DOM parentNode call.\r\n fallbackContainer;\r\n patch(oldVNode, newVNode, container, null, parentComponent, parentSuspense, isSVG, slotScopeIds, true);\r\n }\r\n };\r\n const patchProps = (el, vnode, oldProps, newProps, parentComponent, parentSuspense, isSVG) => {\r\n if (oldProps !== newProps) {\r\n for (const key in newProps) {\r\n // empty string is not valid prop\r\n if (isReservedProp(key))\r\n continue;\r\n const next = newProps[key];\r\n const prev = oldProps[key];\r\n // defer patching value\r\n if (next !== prev && key !== 'value') {\r\n hostPatchProp(el, key, prev, next, isSVG, vnode.children, parentComponent, parentSuspense, unmountChildren);\r\n }\r\n }\r\n if (oldProps !== EMPTY_OBJ) {\r\n for (const key in oldProps) {\r\n if (!isReservedProp(key) && !(key in newProps)) {\r\n hostPatchProp(el, key, oldProps[key], null, isSVG, vnode.children, parentComponent, parentSuspense, unmountChildren);\r\n }\r\n }\r\n }\r\n if ('value' in newProps) {\r\n hostPatchProp(el, 'value', oldProps.value, newProps.value);\r\n }\r\n }\r\n };\r\n const processFragment = (n1, n2, container, anchor, parentComponent, parentSuspense, isSVG, slotScopeIds, optimized) => {\r\n const fragmentStartAnchor = (n2.el = n1 ? n1.el : hostCreateText(''));\r\n const fragmentEndAnchor = (n2.anchor = n1 ? n1.anchor : hostCreateText(''));\r\n let { patchFlag, dynamicChildren, slotScopeIds: fragmentSlotScopeIds } = n2;\r\n if ((process.env.NODE_ENV !== 'production') &&\r\n // #5523 dev root fragment may inherit directives\r\n (isHmrUpdating || patchFlag & 2048 /* DEV_ROOT_FRAGMENT */)) {\r\n // HMR updated / Dev root fragment (w/ comments), force full diff\r\n patchFlag = 0;\r\n optimized = false;\r\n dynamicChildren = null;\r\n }\r\n // check if this is a slot fragment with :slotted scope ids\r\n if (fragmentSlotScopeIds) {\r\n slotScopeIds = slotScopeIds\r\n ? slotScopeIds.concat(fragmentSlotScopeIds)\r\n : fragmentSlotScopeIds;\r\n }\r\n if (n1 == null) {\r\n hostInsert(fragmentStartAnchor, container, anchor);\r\n hostInsert(fragmentEndAnchor, container, anchor);\r\n // a fragment can only have array children\r\n // since they are either generated by the compiler, or implicitly created\r\n // from arrays.\r\n mountChildren(n2.children, container, fragmentEndAnchor, parentComponent, parentSuspense, isSVG, slotScopeIds, optimized);\r\n }\r\n else {\r\n if (patchFlag > 0 &&\r\n patchFlag & 64 /* STABLE_FRAGMENT */ &&\r\n dynamicChildren &&\r\n // #2715 the previous fragment could've been a BAILed one as a result\r\n // of renderSlot() with no valid children\r\n n1.dynamicChildren) {\r\n // a stable fragment (template root or <template v-for>) doesn't need to\r\n // patch children order, but it may contain dynamicChildren.\r\n patchBlockChildren(n1.dynamicChildren, dynamicChildren, container, parentComponent, parentSuspense, isSVG, slotScopeIds);\r\n if ((process.env.NODE_ENV !== 'production') && parentComponent && parentComponent.type.__hmrId) {\r\n traverseStaticChildren(n1, n2);\r\n }\r\n else if (\r\n // #2080 if the stable fragment has a key, it's a <template v-for> that may\r\n // get moved around. Make sure all root level vnodes inherit el.\r\n // #2134 or if it's a component root, it may also get moved around\r\n // as the component is being moved.\r\n n2.key != null ||\r\n (parentComponent && n2 === parentComponent.subTree)) {\r\n traverseStaticChildren(n1, n2, true /* shallow */);\r\n }\r\n }\r\n else {\r\n // keyed / unkeyed, or manual fragments.\r\n // for keyed & unkeyed, since they are compiler generated from v-for,\r\n // each child is guaranteed to be a block so the fragment will never\r\n // have dynamicChildren.\r\n patchChildren(n1, n2, container, fragmentEndAnchor, parentComponent, parentSuspense, isSVG, slotScopeIds, optimized);\r\n }\r\n }\r\n };\r\n const processComponent = (n1, n2, container, anchor, parentComponent, parentSuspense, isSVG, slotScopeIds, optimized) => {\r\n n2.slotScopeIds = slotScopeIds;\r\n if (n1 == null) {\r\n if (n2.shapeFlag & 512 /* COMPONENT_KEPT_ALIVE */) {\r\n parentComponent.ctx.activate(n2, container, anchor, isSVG, optimized);\r\n }\r\n else {\r\n mountComponent(n2, container, anchor, parentComponent, parentSuspense, isSVG, optimized);\r\n }\r\n }\r\n else {\r\n updateComponent(n1, n2, optimized);\r\n }\r\n };\r\n const mountComponent = (initialVNode, container, anchor, parentComponent, parentSuspense, isSVG, optimized) => {\r\n const instance = (initialVNode.component = createComponentInstance(initialVNode, parentComponent, parentSuspense));\r\n if ((process.env.NODE_ENV !== 'production') && instance.type.__hmrId) {\r\n registerHMR(instance);\r\n }\r\n if ((process.env.NODE_ENV !== 'production')) {\r\n pushWarningContext(initialVNode);\r\n startMeasure(instance, `mount`);\r\n }\r\n // inject renderer internals for keepAlive\r\n if (isKeepAlive(initialVNode)) {\r\n instance.ctx.renderer = internals;\r\n }\r\n // resolve props and slots for setup context\r\n {\r\n if ((process.env.NODE_ENV !== 'production')) {\r\n startMeasure(instance, `init`);\r\n }\r\n setupComponent(instance);\r\n if ((process.env.NODE_ENV !== 'production')) {\r\n endMeasure(instance, `init`);\r\n }\r\n }\r\n // setup() is async. This component relies on async logic to be resolved\r\n // before proceeding\r\n if (instance.asyncDep) {\r\n parentSuspense && parentSuspense.registerDep(instance, setupRenderEffect);\r\n // Give it a placeholder if this is not hydration\r\n // TODO handle self-defined fallback\r\n if (!initialVNode.el) {\r\n const placeholder = (instance.subTree = createVNode(Comment));\r\n processCommentNode(null, placeholder, container, anchor);\r\n }\r\n return;\r\n }\r\n setupRenderEffect(instance, initialVNode, container, anchor, parentSuspense, isSVG, optimized);\r\n if ((process.env.NODE_ENV !== 'production')) {\r\n popWarningContext();\r\n endMeasure(instance, `mount`);\r\n }\r\n };\r\n const updateComponent = (n1, n2, optimized) => {\r\n const instance = (n2.component = n1.component);\r\n if (shouldUpdateComponent(n1, n2, optimized)) {\r\n if (instance.asyncDep &&\r\n !instance.asyncResolved) {\r\n // async & still pending - just update props and slots\r\n // since the component's reactive effect for render isn't set-up yet\r\n if ((process.env.NODE_ENV !== 'production')) {\r\n pushWarningContext(n2);\r\n }\r\n updateComponentPreRender(instance, n2, optimized);\r\n if ((process.env.NODE_ENV !== 'production')) {\r\n popWarningContext();\r\n }\r\n return;\r\n }\r\n else {\r\n // normal update\r\n instance.next = n2;\r\n // in case the child component is also queued, remove it to avoid\r\n // double updating the same child component in the same flush.\r\n invalidateJob(instance.update);\r\n // instance.update is the reactive effect.\r\n instance.update();\r\n }\r\n }\r\n else {\r\n // no update needed. just copy over properties\r\n n2.el = n1.el;\r\n instance.vnode = n2;\r\n }\r\n };\r\n const setupRenderEffect = (instance, initialVNode, container, anchor, parentSuspense, isSVG, optimized) => {\r\n const componentUpdateFn = () => {\r\n if (!instance.isMounted) {\r\n let vnodeHook;\r\n const { el, props } = initialVNode;\r\n const { bm, m, parent } = instance;\r\n const isAsyncWrapperVNode = isAsyncWrapper(initialVNode);\r\n toggleRecurse(instance, false);\r\n // beforeMount hook\r\n if (bm) {\r\n invokeArrayFns(bm);\r\n }\r\n // onVnodeBeforeMount\r\n if (!isAsyncWrapperVNode &&\r\n (vnodeHook = props && props.onVnodeBeforeMount)) {\r\n invokeVNodeHook(vnodeHook, parent, initialVNode);\r\n }\r\n toggleRecurse(instance, true);\r\n if (el && hydrateNode) {\r\n // vnode has adopted host node - perform hydration instead of mount.\r\n const hydrateSubTree = () => {\r\n if ((process.env.NODE_ENV !== 'production')) {\r\n startMeasure(instance, `render`);\r\n }\r\n instance.subTree = renderComponentRoot(instance);\r\n if ((process.env.NODE_ENV !== 'production')) {\r\n endMeasure(instance, `render`);\r\n }\r\n if ((process.env.NODE_ENV !== 'production')) {\r\n startMeasure(instance, `hydrate`);\r\n }\r\n hydrateNode(el, instance.subTree, instance, parentSuspense, null);\r\n if ((process.env.NODE_ENV !== 'production')) {\r\n endMeasure(instance, `hydrate`);\r\n }\r\n };\r\n if (isAsyncWrapperVNode) {\r\n initialVNode.type.__asyncLoader().then(\r\n // note: we are moving the render call into an async callback,\r\n // which means it won't track dependencies - but it's ok because\r\n // a server-rendered async wrapper is already in resolved state\r\n // and it will never need to change.\r\n () => !instance.isUnmounted && hydrateSubTree());\r\n }\r\n else {\r\n hydrateSubTree();\r\n }\r\n }\r\n else {\r\n if ((process.env.NODE_ENV !== 'production')) {\r\n startMeasure(instance, `render`);\r\n }\r\n const subTree = (instance.subTree = renderComponentRoot(instance));\r\n if ((process.env.NODE_ENV !== 'production')) {\r\n endMeasure(instance, `render`);\r\n }\r\n if ((process.env.NODE_ENV !== 'production')) {\r\n startMeasure(instance, `patch`);\r\n }\r\n patch(null, subTree, container, anchor, instance, parentSuspense, isSVG);\r\n if ((process.env.NODE_ENV !== 'production')) {\r\n endMeasure(instance, `patch`);\r\n }\r\n initialVNode.el = subTree.el;\r\n }\r\n // mounted hook\r\n if (m) {\r\n queuePostRenderEffect(m, parentSuspense);\r\n }\r\n // onVnodeMounted\r\n if (!isAsyncWrapperVNode &&\r\n (vnodeHook = props && props.onVnodeMounted)) {\r\n const scopedInitialVNode = initialVNode;\r\n queuePostRenderEffect(() => invokeVNodeHook(vnodeHook, parent, scopedInitialVNode), parentSuspense);\r\n }\r\n // activated hook for keep-alive roots.\r\n // #1742 activated hook must be accessed after first render\r\n // since the hook may be injected by a child keep-alive\r\n if (initialVNode.shapeFlag & 256 /* COMPONENT_SHOULD_KEEP_ALIVE */ ||\r\n (parent &&\r\n isAsyncWrapper(parent.vnode) &&\r\n parent.vnode.shapeFlag & 256 /* COMPONENT_SHOULD_KEEP_ALIVE */)) {\r\n instance.a && queuePostRenderEffect(instance.a, parentSuspense);\r\n }\r\n instance.isMounted = true;\r\n if ((process.env.NODE_ENV !== 'production') || __VUE_PROD_DEVTOOLS__) {\r\n devtoolsComponentAdded(instance);\r\n }\r\n // #2458: deference mount-only object parameters to prevent memleaks\r\n initialVNode = container = anchor = null;\r\n }\r\n else {\r\n // updateComponent\r\n // This is triggered by mutation of component's own state (next: null)\r\n // OR parent calling processComponent (next: VNode)\r\n let { next, bu, u, parent, vnode } = instance;\r\n let originNext = next;\r\n let vnodeHook;\r\n if ((process.env.NODE_ENV !== 'production')) {\r\n pushWarningContext(next || instance.vnode);\r\n }\r\n // Disallow component effect recursion during pre-lifecycle hooks.\r\n toggleRecurse(instance, false);\r\n if (next) {\r\n next.el = vnode.el;\r\n updateComponentPreRender(instance, next, optimized);\r\n }\r\n else {\r\n next = vnode;\r\n }\r\n // beforeUpdate hook\r\n if (bu) {\r\n invokeArrayFns(bu);\r\n }\r\n // onVnodeBeforeUpdate\r\n if ((vnodeHook = next.props && next.props.onVnodeBeforeUpdate)) {\r\n invokeVNodeHook(vnodeHook, parent, next, vnode);\r\n }\r\n toggleRecurse(instance, true);\r\n // render\r\n if ((process.env.NODE_ENV !== 'production')) {\r\n startMeasure(instance, `render`);\r\n }\r\n const nextTree = renderComponentRoot(instance);\r\n if ((process.env.NODE_ENV !== 'production')) {\r\n endMeasure(instance, `render`);\r\n }\r\n const prevTree = instance.subTree;\r\n instance.subTree = nextTree;\r\n if ((process.env.NODE_ENV !== 'production')) {\r\n startMeasure(instance, `patch`);\r\n }\r\n patch(prevTree, nextTree, \r\n // parent may have changed if it's in a teleport\r\n hostParentNode(prevTree.el), \r\n // anchor may have changed if it's in a fragment\r\n getNextHostNode(prevTree), instance, parentSuspense, isSVG);\r\n if ((process.env.NODE_ENV !== 'production')) {\r\n endMeasure(instance, `patch`);\r\n }\r\n next.el = nextTree.el;\r\n if (originNext === null) {\r\n // self-triggered update. In case of HOC, update parent component\r\n // vnode el. HOC is indicated by parent instance's subTree pointing\r\n // to child component's vnode\r\n updateHOCHostEl(instance, nextTree.el);\r\n }\r\n // updated hook\r\n if (u) {\r\n queuePostRenderEffect(u, parentSuspense);\r\n }\r\n // onVnodeUpdated\r\n if ((vnodeHook = next.props && next.props.onVnodeUpdated)) {\r\n queuePostRenderEffect(() => invokeVNodeHook(vnodeHook, parent, next, vnode), parentSuspense);\r\n }\r\n if ((process.env.NODE_ENV !== 'production') || __VUE_PROD_DEVTOOLS__) {\r\n devtoolsComponentUpdated(instance);\r\n }\r\n if ((process.env.NODE_ENV !== 'production')) {\r\n popWarningContext();\r\n }\r\n }\r\n };\r\n // create reactive effect for rendering\r\n const effect = (instance.effect = new ReactiveEffect(componentUpdateFn, () => queueJob(update), instance.scope // track it in component's effect scope\r\n ));\r\n const update = (instance.update = () => effect.run());\r\n update.id = instance.uid;\r\n // allowRecurse\r\n // #1801, #2043 component render effects should allow recursive updates\r\n toggleRecurse(instance, true);\r\n if ((process.env.NODE_ENV !== 'production')) {\r\n effect.onTrack = instance.rtc\r\n ? e => invokeArrayFns(instance.rtc, e)\r\n : void 0;\r\n effect.onTrigger = instance.rtg\r\n ? e => invokeArrayFns(instance.rtg, e)\r\n : void 0;\r\n update.ownerInstance = instance;\r\n }\r\n update();\r\n };\r\n const updateComponentPreRender = (instance, nextVNode, optimized) => {\r\n nextVNode.component = instance;\r\n const prevProps = instance.vnode.props;\r\n instance.vnode = nextVNode;\r\n instance.next = null;\r\n updateProps(instance, nextVNode.props, prevProps, optimized);\r\n updateSlots(instance, nextVNode.children, optimized);\r\n pauseTracking();\r\n // props update may have triggered pre-flush watchers.\r\n // flush them before the render update.\r\n flushPreFlushCbs(undefined, instance.update);\r\n resetTracking();\r\n };\r\n const patchChildren = (n1, n2, container, anchor, parentComponent, parentSuspense, isSVG, slotScopeIds, optimized = false) => {\r\n const c1 = n1 && n1.children;\r\n const prevShapeFlag = n1 ? n1.shapeFlag : 0;\r\n const c2 = n2.children;\r\n const { patchFlag, shapeFlag } = n2;\r\n // fast path\r\n if (patchFlag > 0) {\r\n if (patchFlag & 128 /* KEYED_FRAGMENT */) {\r\n // this could be either fully-keyed or mixed (some keyed some not)\r\n // presence of patchFlag means children are guaranteed to be arrays\r\n patchKeyedChildren(c1, c2, container, anchor, parentComponent, parentSuspense, isSVG, slotScopeIds, optimized);\r\n return;\r\n }\r\n else if (patchFlag & 256 /* UNKEYED_FRAGMENT */) {\r\n // unkeyed\r\n patchUnkeyedChildren(c1, c2, container, anchor, parentComponent, parentSuspense, isSVG, slotScopeIds, optimized);\r\n return;\r\n }\r\n }\r\n // children has 3 possibilities: text, array or no children.\r\n if (shapeFlag & 8 /* TEXT_CHILDREN */) {\r\n // text children fast path\r\n if (prevShapeFlag & 16 /* ARRAY_CHILDREN */) {\r\n unmountChildren(c1, parentComponent, parentSuspense);\r\n }\r\n if (c2 !== c1) {\r\n hostSetElementText(container, c2);\r\n }\r\n }\r\n else {\r\n if (prevShapeFlag & 16 /* ARRAY_CHILDREN */) {\r\n // prev children was array\r\n if (shapeFlag & 16 /* ARRAY_CHILDREN */) {\r\n // two arrays, cannot assume anything, do full diff\r\n patchKeyedChildren(c1, c2, container, anchor, parentComponent, parentSuspense, isSVG, slotScopeIds, optimized);\r\n }\r\n else {\r\n // no new children, just unmount old\r\n unmountChildren(c1, parentComponent, parentSuspense, true);\r\n }\r\n }\r\n else {\r\n // prev children was text OR null\r\n // new children is array OR null\r\n if (prevShapeFlag & 8 /* TEXT_CHILDREN */) {\r\n hostSetElementText(container, '');\r\n }\r\n // mount new if array\r\n if (shapeFlag & 16 /* ARRAY_CHILDREN */) {\r\n mountChildren(c2, container, anchor, parentComponent, parentSuspense, isSVG, slotScopeIds, optimized);\r\n }\r\n }\r\n }\r\n };\r\n const patchUnkeyedChildren = (c1, c2, container, anchor, parentComponent, parentSuspense, isSVG, slotScopeIds, optimized) => {\r\n c1 = c1 || EMPTY_ARR;\r\n c2 = c2 || EMPTY_ARR;\r\n const oldLength = c1.length;\r\n const newLength = c2.length;\r\n const commonLength = Math.min(oldLength, newLength);\r\n let i;\r\n for (i = 0; i < commonLength; i++) {\r\n const nextChild = (c2[i] = optimized\r\n ? cloneIfMounted(c2[i])\r\n : normalizeVNode(c2[i]));\r\n patch(c1[i], nextChild, container, null, parentComponent, parentSuspense, isSVG, slotScopeIds, optimized);\r\n }\r\n if (oldLength > newLength) {\r\n // remove old\r\n unmountChildren(c1, parentComponent, parentSuspense, true, false, commonLength);\r\n }\r\n else {\r\n // mount new\r\n mountChildren(c2, container, anchor, parentComponent, parentSuspense, isSVG, slotScopeIds, optimized, commonLength);\r\n }\r\n };\r\n // can be all-keyed or mixed\r\n const patchKeyedChildren = (c1, c2, container, parentAnchor, parentComponent, parentSuspense, isSVG, slotScopeIds, optimized) => {\r\n let i = 0;\r\n const l2 = c2.length;\r\n let e1 = c1.length - 1; // prev ending index\r\n let e2 = l2 - 1; // next ending index\r\n // 1. sync from start\r\n // (a b) c\r\n // (a b) d e\r\n while (i <= e1 && i <= e2) {\r\n const n1 = c1[i];\r\n const n2 = (c2[i] = optimized\r\n ? cloneIfMounted(c2[i])\r\n : normalizeVNode(c2[i]));\r\n if (isSameVNodeType(n1, n2)) {\r\n patch(n1, n2, container, null, parentComponent, parentSuspense, isSVG, slotScopeIds, optimized);\r\n }\r\n else {\r\n break;\r\n }\r\n i++;\r\n }\r\n // 2. sync from end\r\n // a (b c)\r\n // d e (b c)\r\n while (i <= e1 && i <= e2) {\r\n const n1 = c1[e1];\r\n const n2 = (c2[e2] = optimized\r\n ? cloneIfMounted(c2[e2])\r\n : normalizeVNode(c2[e2]));\r\n if (isSameVNodeType(n1, n2)) {\r\n patch(n1, n2, container, null, parentComponent, parentSuspense, isSVG, slotScopeIds, optimized);\r\n }\r\n else {\r\n break;\r\n }\r\n e1--;\r\n e2--;\r\n }\r\n // 3. common sequence + mount\r\n // (a b)\r\n // (a b) c\r\n // i = 2, e1 = 1, e2 = 2\r\n // (a b)\r\n // c (a b)\r\n // i = 0, e1 = -1, e2 = 0\r\n if (i > e1) {\r\n if (i <= e2) {\r\n const nextPos = e2 + 1;\r\n const anchor = nextPos < l2 ? c2[nextPos].el : parentAnchor;\r\n while (i <= e2) {\r\n patch(null, (c2[i] = optimized\r\n ? cloneIfMounted(c2[i])\r\n : normalizeVNode(c2[i])), container, anchor, parentComponent, parentSuspense, isSVG, slotScopeIds, optimized);\r\n i++;\r\n }\r\n }\r\n }\r\n // 4. common sequence + unmount\r\n // (a b) c\r\n // (a b)\r\n // i = 2, e1 = 2, e2 = 1\r\n // a (b c)\r\n // (b c)\r\n // i = 0, e1 = 0, e2 = -1\r\n else if (i > e2) {\r\n while (i <= e1) {\r\n unmount(c1[i], parentComponent, parentSuspense, true);\r\n i++;\r\n }\r\n }\r\n // 5. unknown sequence\r\n // [i ... e1 + 1]: a b [c d e] f g\r\n // [i ... e2 + 1]: a b [e d c h] f g\r\n // i = 2, e1 = 4, e2 = 5\r\n else {\r\n const s1 = i; // prev starting index\r\n const s2 = i; // next starting index\r\n // 5.1 build key:index map for newChildren\r\n const keyToNewIndexMap = new Map();\r\n for (i = s2; i <= e2; i++) {\r\n const nextChild = (c2[i] = optimized\r\n ? cloneIfMounted(c2[i])\r\n : normalizeVNode(c2[i]));\r\n if (nextChild.key != null) {\r\n if ((process.env.NODE_ENV !== 'production') && keyToNewIndexMap.has(nextChild.key)) {\r\n warn(`Duplicate keys found during update:`, JSON.stringify(nextChild.key), `Make sure keys are unique.`);\r\n }\r\n keyToNewIndexMap.set(nextChild.key, i);\r\n }\r\n }\r\n // 5.2 loop through old children left to be patched and try to patch\r\n // matching nodes & remove nodes that are no longer present\r\n let j;\r\n let patched = 0;\r\n const toBePatched = e2 - s2 + 1;\r\n let moved = false;\r\n // used to track whether any node has moved\r\n let maxNewIndexSoFar = 0;\r\n // works as Map<newIndex, oldIndex>\r\n // Note that oldIndex is offset by +1\r\n // and oldIndex = 0 is a special value indicating the new node has\r\n // no corresponding old node.\r\n // used for determining longest stable subsequence\r\n const newIndexToOldIndexMap = new Array(toBePatched);\r\n for (i = 0; i < toBePatched; i++)\r\n newIndexToOldIndexMap[i] = 0;\r\n for (i = s1; i <= e1; i++) {\r\n const prevChild = c1[i];\r\n if (patched >= toBePatched) {\r\n // all new children have been patched so this can only be a removal\r\n unmount(prevChild, parentComponent, parentSuspense, true);\r\n continue;\r\n }\r\n let newIndex;\r\n if (prevChild.key != null) {\r\n newIndex = keyToNewIndexMap.get(prevChild.key);\r\n }\r\n else {\r\n // key-less node, try to locate a key-less node of the same type\r\n for (j = s2; j <= e2; j++) {\r\n if (newIndexToOldIndexMap[j - s2] === 0 &&\r\n isSameVNodeType(prevChild, c2[j])) {\r\n newIndex = j;\r\n break;\r\n }\r\n }\r\n }\r\n if (newIndex === undefined) {\r\n unmount(prevChild, parentComponent, parentSuspense, true);\r\n }\r\n else {\r\n newIndexToOldIndexMap[newIndex - s2] = i + 1;\r\n if (newIndex >= maxNewIndexSoFar) {\r\n maxNewIndexSoFar = newIndex;\r\n }\r\n else {\r\n moved = true;\r\n }\r\n patch(prevChild, c2[newIndex], container, null, parentComponent, parentSuspense, isSVG, slotScopeIds, optimized);\r\n patched++;\r\n }\r\n }\r\n // 5.3 move and mount\r\n // generate longest stable subsequence only when nodes have moved\r\n const increasingNewIndexSequence = moved\r\n ? getSequence(newIndexToOldIndexMap)\r\n : EMPTY_ARR;\r\n j = increasingNewIndexSequence.length - 1;\r\n // looping backwards so that we can use last patched node as anchor\r\n for (i = toBePatched - 1; i >= 0; i--) {\r\n const nextIndex = s2 + i;\r\n const nextChild = c2[nextIndex];\r\n const anchor = nextIndex + 1 < l2 ? c2[nextIndex + 1].el : parentAnchor;\r\n if (newIndexToOldIndexMap[i] === 0) {\r\n // mount new\r\n patch(null, nextChild, container, anchor, parentComponent, parentSuspense, isSVG, slotScopeIds, optimized);\r\n }\r\n else if (moved) {\r\n // move if:\r\n // There is no stable subsequence (e.g. a reverse)\r\n // OR current node is not among the stable sequence\r\n if (j < 0 || i !== increasingNewIndexSequence[j]) {\r\n move(nextChild, container, anchor, 2 /* REORDER */);\r\n }\r\n else {\r\n j--;\r\n }\r\n }\r\n }\r\n }\r\n };\r\n const move = (vnode, container, anchor, moveType, parentSuspense = null) => {\r\n const { el, type, transition, children, shapeFlag } = vnode;\r\n if (shapeFlag & 6 /* COMPONENT */) {\r\n move(vnode.component.subTree, container, anchor, moveType);\r\n return;\r\n }\r\n if (shapeFlag & 128 /* SUSPENSE */) {\r\n vnode.suspense.move(container, anchor, moveType);\r\n return;\r\n }\r\n if (shapeFlag & 64 /* TELEPORT */) {\r\n type.move(vnode, container, anchor, internals);\r\n return;\r\n }\r\n if (type === Fragment) {\r\n hostInsert(el, container, anchor);\r\n for (let i = 0; i < children.length; i++) {\r\n move(children[i], container, anchor, moveType);\r\n }\r\n hostInsert(vnode.anchor, container, anchor);\r\n return;\r\n }\r\n if (type === Static) {\r\n moveStaticNode(vnode, container, anchor);\r\n return;\r\n }\r\n // single nodes\r\n const needTransition = moveType !== 2 /* REORDER */ &&\r\n shapeFlag & 1 /* ELEMENT */ &&\r\n transition;\r\n if (needTransition) {\r\n if (moveType === 0 /* ENTER */) {\r\n transition.beforeEnter(el);\r\n hostInsert(el, container, anchor);\r\n queuePostRenderEffect(() => transition.enter(el), parentSuspense);\r\n }\r\n else {\r\n const { leave, delayLeave, afterLeave } = transition;\r\n const remove = () => hostInsert(el, container, anchor);\r\n const performLeave = () => {\r\n leave(el, () => {\r\n remove();\r\n afterLeave && afterLeave();\r\n });\r\n };\r\n if (delayLeave) {\r\n delayLeave(el, remove, performLeave);\r\n }\r\n else {\r\n performLeave();\r\n }\r\n }\r\n }\r\n else {\r\n hostInsert(el, container, anchor);\r\n }\r\n };\r\n const unmount = (vnode, parentComponent, parentSuspense, doRemove = false, optimized = false) => {\r\n const { type, props, ref, children, dynamicChildren, shapeFlag, patchFlag, dirs } = vnode;\r\n // unset ref\r\n if (ref != null) {\r\n setRef(ref, null, parentSuspense, vnode, true);\r\n }\r\n if (shapeFlag & 256 /* COMPONENT_SHOULD_KEEP_ALIVE */) {\r\n parentComponent.ctx.deactivate(vnode);\r\n return;\r\n }\r\n const shouldInvokeDirs = shapeFlag & 1 /* ELEMENT */ && dirs;\r\n const shouldInvokeVnodeHook = !isAsyncWrapper(vnode);\r\n let vnodeHook;\r\n if (shouldInvokeVnodeHook &&\r\n (vnodeHook = props && props.onVnodeBeforeUnmount)) {\r\n invokeVNodeHook(vnodeHook, parentComponent, vnode);\r\n }\r\n if (shapeFlag & 6 /* COMPONENT */) {\r\n unmountComponent(vnode.component, parentSuspense, doRemove);\r\n }\r\n else {\r\n if (shapeFlag & 128 /* SUSPENSE */) {\r\n vnode.suspense.unmount(parentSuspense, doRemove);\r\n return;\r\n }\r\n if (shouldInvokeDirs) {\r\n invokeDirectiveHook(vnode, null, parentComponent, 'beforeUnmount');\r\n }\r\n if (shapeFlag & 64 /* TELEPORT */) {\r\n vnode.type.remove(vnode, parentComponent, parentSuspense, optimized, internals, doRemove);\r\n }\r\n else if (dynamicChildren &&\r\n // #1153: fast path should not be taken for non-stable (v-for) fragments\r\n (type !== Fragment ||\r\n (patchFlag > 0 && patchFlag & 64 /* STABLE_FRAGMENT */))) {\r\n // fast path for block nodes: only need to unmount dynamic children.\r\n unmountChildren(dynamicChildren, parentComponent, parentSuspense, false, true);\r\n }\r\n else if ((type === Fragment &&\r\n patchFlag &\r\n (128 /* KEYED_FRAGMENT */ | 256 /* UNKEYED_FRAGMENT */)) ||\r\n (!optimized && shapeFlag & 16 /* ARRAY_CHILDREN */)) {\r\n unmountChildren(children, parentComponent, parentSuspense);\r\n }\r\n if (doRemove) {\r\n remove(vnode);\r\n }\r\n }\r\n if ((shouldInvokeVnodeHook &&\r\n (vnodeHook = props && props.onVnodeUnmounted)) ||\r\n shouldInvokeDirs) {\r\n queuePostRenderEffect(() => {\r\n vnodeHook && invokeVNodeHook(vnodeHook, parentComponent, vnode);\r\n shouldInvokeDirs &&\r\n invokeDirectiveHook(vnode, null, parentComponent, 'unmounted');\r\n }, parentSuspense);\r\n }\r\n };\r\n const remove = vnode => {\r\n const { type, el, anchor, transition } = vnode;\r\n if (type === Fragment) {\r\n if ((process.env.NODE_ENV !== 'production') &&\r\n vnode.patchFlag > 0 &&\r\n vnode.patchFlag & 2048 /* DEV_ROOT_FRAGMENT */ &&\r\n transition &&\r\n !transition.persisted) {\r\n vnode.children.forEach(child => {\r\n if (child.type === Comment) {\r\n hostRemove(child.el);\r\n }\r\n else {\r\n remove(child);\r\n }\r\n });\r\n }\r\n else {\r\n removeFragment(el, anchor);\r\n }\r\n return;\r\n }\r\n if (type === Static) {\r\n removeStaticNode(vnode);\r\n return;\r\n }\r\n const performRemove = () => {\r\n hostRemove(el);\r\n if (transition && !transition.persisted && transition.afterLeave) {\r\n transition.afterLeave();\r\n }\r\n };\r\n if (vnode.shapeFlag & 1 /* ELEMENT */ &&\r\n transition &&\r\n !transition.persisted) {\r\n const { leave, delayLeave } = transition;\r\n const performLeave = () => leave(el, performRemove);\r\n if (delayLeave) {\r\n delayLeave(vnode.el, performRemove, performLeave);\r\n }\r\n else {\r\n performLeave();\r\n }\r\n }\r\n else {\r\n performRemove();\r\n }\r\n };\r\n const removeFragment = (cur, end) => {\r\n // For fragments, directly remove all contained DOM nodes.\r\n // (fragment child nodes cannot have transition)\r\n let next;\r\n while (cur !== end) {\r\n next = hostNextSibling(cur);\r\n hostRemove(cur);\r\n cur = next;\r\n }\r\n hostRemove(end);\r\n };\r\n const unmountComponent = (instance, parentSuspense, doRemove) => {\r\n if ((process.env.NODE_ENV !== 'production') && instance.type.__hmrId) {\r\n unregisterHMR(instance);\r\n }\r\n const { bum, scope, update, subTree, um } = instance;\r\n // beforeUnmount hook\r\n if (bum) {\r\n invokeArrayFns(bum);\r\n }\r\n // stop effects in component scope\r\n scope.stop();\r\n // update may be null if a component is unmounted before its async\r\n // setup has resolved.\r\n if (update) {\r\n // so that scheduler will no longer invoke it\r\n update.active = false;\r\n unmount(subTree, instance, parentSuspense, doRemove);\r\n }\r\n // unmounted hook\r\n if (um) {\r\n queuePostRenderEffect(um, parentSuspense);\r\n }\r\n queuePostRenderEffect(() => {\r\n instance.isUnmounted = true;\r\n }, parentSuspense);\r\n // A component with async dep inside a pending suspense is unmounted before\r\n // its async dep resolves. This should remove the dep from the suspense, and\r\n // cause the suspense to resolve immediately if that was the last dep.\r\n if (parentSuspense &&\r\n parentSuspense.pendingBranch &&\r\n !parentSuspense.isUnmounted &&\r\n instance.asyncDep &&\r\n !instance.asyncResolved &&\r\n instance.suspenseId === parentSuspense.pendingId) {\r\n parentSuspense.deps--;\r\n if (parentSuspense.deps === 0) {\r\n parentSuspense.resolve();\r\n }\r\n }\r\n if ((process.env.NODE_ENV !== 'production') || __VUE_PROD_DEVTOOLS__) {\r\n devtoolsComponentRemoved(instance);\r\n }\r\n };\r\n const unmountChildren = (children, parentComponent, parentSuspense, doRemove = false, optimized = false, start = 0) => {\r\n for (let i = start; i < children.length; i++) {\r\n unmount(children[i], parentComponent, parentSuspense, doRemove, optimized);\r\n }\r\n };\r\n const getNextHostNode = vnode => {\r\n if (vnode.shapeFlag & 6 /* COMPONENT */) {\r\n return getNextHostNode(vnode.component.subTree);\r\n }\r\n if (vnode.shapeFlag & 128 /* SUSPENSE */) {\r\n return vnode.suspense.next();\r\n }\r\n return hostNextSibling((vnode.anchor || vnode.el));\r\n };\r\n const render = (vnode, container, isSVG) => {\r\n if (vnode == null) {\r\n if (container._vnode) {\r\n unmount(container._vnode, null, null, true);\r\n }\r\n }\r\n else {\r\n patch(container._vnode || null, vnode, container, null, null, null, isSVG);\r\n }\r\n flushPostFlushCbs();\r\n container._vnode = vnode;\r\n };\r\n const internals = {\r\n p: patch,\r\n um: unmount,\r\n m: move,\r\n r: remove,\r\n mt: mountComponent,\r\n mc: mountChildren,\r\n pc: patchChildren,\r\n pbc: patchBlockChildren,\r\n n: getNextHostNode,\r\n o: options\r\n };\r\n let hydrate;\r\n let hydrateNode;\r\n if (createHydrationFns) {\r\n [hydrate, hydrateNode] = createHydrationFns(internals);\r\n }\r\n return {\r\n render,\r\n hydrate,\r\n createApp: createAppAPI(render, hydrate)\r\n };\r\n}\r\nfunction toggleRecurse({ effect, update }, allowed) {\r\n effect.allowRecurse = update.allowRecurse = allowed;\r\n}\r\n/**\r\n * #1156\r\n * When a component is HMR-enabled, we need to make sure that all static nodes\r\n * inside a block also inherit the DOM element from the previous tree so that\r\n * HMR updates (which are full updates) can retrieve the element for patching.\r\n *\r\n * #2080\r\n * Inside keyed `template` fragment static children, if a fragment is moved,\r\n * the children will always be moved. Therefore, in order to ensure correct move\r\n * position, el should be inherited from previous nodes.\r\n */\r\nfunction traverseStaticChildren(n1, n2, shallow = false) {\r\n const ch1 = n1.children;\r\n const ch2 = n2.children;\r\n if (isArray(ch1) && isArray(ch2)) {\r\n for (let i = 0; i < ch1.length; i++) {\r\n // this is only called in the optimized path so array children are\r\n // guaranteed to be vnodes\r\n const c1 = ch1[i];\r\n let c2 = ch2[i];\r\n if (c2.shapeFlag & 1 /* ELEMENT */ && !c2.dynamicChildren) {\r\n if (c2.patchFlag <= 0 || c2.patchFlag === 32 /* HYDRATE_EVENTS */) {\r\n c2 = ch2[i] = cloneIfMounted(ch2[i]);\r\n c2.el = c1.el;\r\n }\r\n if (!shallow)\r\n traverseStaticChildren(c1, c2);\r\n }\r\n // also inherit for comment nodes, but not placeholders (e.g. v-if which\r\n // would have received .el during block patch)\r\n if ((process.env.NODE_ENV !== 'production') && c2.type === Comment && !c2.el) {\r\n c2.el = c1.el;\r\n }\r\n }\r\n }\r\n}\r\n// https://en.wikipedia.org/wiki/Longest_increasing_subsequence\r\nfunction getSequence(arr) {\r\n const p = arr.slice();\r\n const result = [0];\r\n let i, j, u, v, c;\r\n const len = arr.length;\r\n for (i = 0; i < len; i++) {\r\n const arrI = arr[i];\r\n if (arrI !== 0) {\r\n j = result[result.length - 1];\r\n if (arr[j] < arrI) {\r\n p[i] = j;\r\n result.push(i);\r\n continue;\r\n }\r\n u = 0;\r\n v = result.length - 1;\r\n while (u < v) {\r\n c = (u + v) >> 1;\r\n if (arr[result[c]] < arrI) {\r\n u = c + 1;\r\n }\r\n else {\r\n v = c;\r\n }\r\n }\r\n if (arrI < arr[result[u]]) {\r\n if (u > 0) {\r\n p[i] = result[u - 1];\r\n }\r\n result[u] = i;\r\n }\r\n }\r\n }\r\n u = result.length;\r\n v = result[u - 1];\r\n while (u-- > 0) {\r\n result[u] = v;\r\n v = p[v];\r\n }\r\n return result;\r\n}\n\nconst isTeleport = (type) => type.__isTeleport;\r\nconst isTeleportDisabled = (props) => props && (props.disabled || props.disabled === '');\r\nconst isTargetSVG = (target) => typeof SVGElement !== 'undefined' && target instanceof SVGElement;\r\nconst resolveTarget = (props, select) => {\r\n const targetSelector = props && props.to;\r\n if (isString(targetSelector)) {\r\n if (!select) {\r\n (process.env.NODE_ENV !== 'production') &&\r\n warn(`Current renderer does not support string target for Teleports. ` +\r\n `(missing querySelector renderer option)`);\r\n return null;\r\n }\r\n else {\r\n const target = select(targetSelector);\r\n if (!target) {\r\n (process.env.NODE_ENV !== 'production') &&\r\n warn(`Failed to locate Teleport target with selector \"${targetSelector}\". ` +\r\n `Note the target element must exist before the component is mounted - ` +\r\n `i.e. the target cannot be rendered by the component itself, and ` +\r\n `ideally should be outside of the entire Vue component tree.`);\r\n }\r\n return target;\r\n }\r\n }\r\n else {\r\n if ((process.env.NODE_ENV !== 'production') && !targetSelector && !isTeleportDisabled(props)) {\r\n warn(`Invalid Teleport target: ${targetSelector}`);\r\n }\r\n return targetSelector;\r\n }\r\n};\r\nconst TeleportImpl = {\r\n __isTeleport: true,\r\n process(n1, n2, container, anchor, parentComponent, parentSuspense, isSVG, slotScopeIds, optimized, internals) {\r\n const { mc: mountChildren, pc: patchChildren, pbc: patchBlockChildren, o: { insert, querySelector, createText, createComment } } = internals;\r\n const disabled = isTeleportDisabled(n2.props);\r\n let { shapeFlag, children, dynamicChildren } = n2;\r\n // #3302\r\n // HMR updated, force full diff\r\n if ((process.env.NODE_ENV !== 'production') && isHmrUpdating) {\r\n optimized = false;\r\n dynamicChildren = null;\r\n }\r\n if (n1 == null) {\r\n // insert anchors in the main view\r\n const placeholder = (n2.el = (process.env.NODE_ENV !== 'production')\r\n ? createComment('teleport start')\r\n : createText(''));\r\n const mainAnchor = (n2.anchor = (process.env.NODE_ENV !== 'production')\r\n ? createComment('teleport end')\r\n : createText(''));\r\n insert(placeholder, container, anchor);\r\n insert(mainAnchor, container, anchor);\r\n const target = (n2.target = resolveTarget(n2.props, querySelector));\r\n const targetAnchor = (n2.targetAnchor = createText(''));\r\n if (target) {\r\n insert(targetAnchor, target);\r\n // #2652 we could be teleporting from a non-SVG tree into an SVG tree\r\n isSVG = isSVG || isTargetSVG(target);\r\n }\r\n else if ((process.env.NODE_ENV !== 'production') && !disabled) {\r\n warn('Invalid Teleport target on mount:', target, `(${typeof target})`);\r\n }\r\n const mount = (container, anchor) => {\r\n // Teleport *always* has Array children. This is enforced in both the\r\n // compiler and vnode children normalization.\r\n if (shapeFlag & 16 /* ARRAY_CHILDREN */) {\r\n mountChildren(children, container, anchor, parentComponent, parentSuspense, isSVG, slotScopeIds, optimized);\r\n }\r\n };\r\n if (disabled) {\r\n mount(container, mainAnchor);\r\n }\r\n else if (target) {\r\n mount(target, targetAnchor);\r\n }\r\n }\r\n else {\r\n // update content\r\n n2.el = n1.el;\r\n const mainAnchor = (n2.anchor = n1.anchor);\r\n const target = (n2.target = n1.target);\r\n const targetAnchor = (n2.targetAnchor = n1.targetAnchor);\r\n const wasDisabled = isTeleportDisabled(n1.props);\r\n const currentContainer = wasDisabled ? container : target;\r\n const currentAnchor = wasDisabled ? mainAnchor : targetAnchor;\r\n isSVG = isSVG || isTargetSVG(target);\r\n if (dynamicChildren) {\r\n // fast path when the teleport happens to be a block root\r\n patchBlockChildren(n1.dynamicChildren, dynamicChildren, currentContainer, parentComponent, parentSuspense, isSVG, slotScopeIds);\r\n // even in block tree mode we need to make sure all root-level nodes\r\n // in the teleport inherit previous DOM references so that they can\r\n // be moved in future patches.\r\n traverseStaticChildren(n1, n2, true);\r\n }\r\n else if (!optimized) {\r\n patchChildren(n1, n2, currentContainer, currentAnchor, parentComponent, parentSuspense, isSVG, slotScopeIds, false);\r\n }\r\n if (disabled) {\r\n if (!wasDisabled) {\r\n // enabled -> disabled\r\n // move into main container\r\n moveTeleport(n2, container, mainAnchor, internals, 1 /* TOGGLE */);\r\n }\r\n }\r\n else {\r\n // target changed\r\n if ((n2.props && n2.props.to) !== (n1.props && n1.props.to)) {\r\n const nextTarget = (n2.target = resolveTarget(n2.props, querySelector));\r\n if (nextTarget) {\r\n moveTeleport(n2, nextTarget, null, internals, 0 /* TARGET_CHANGE */);\r\n }\r\n else if ((process.env.NODE_ENV !== 'production')) {\r\n warn('Invalid Teleport target on update:', target, `(${typeof target})`);\r\n }\r\n }\r\n else if (wasDisabled) {\r\n // disabled -> enabled\r\n // move into teleport target\r\n moveTeleport(n2, target, targetAnchor, internals, 1 /* TOGGLE */);\r\n }\r\n }\r\n }\r\n },\r\n remove(vnode, parentComponent, parentSuspense, optimized, { um: unmount, o: { remove: hostRemove } }, doRemove) {\r\n const { shapeFlag, children, anchor, targetAnchor, target, props } = vnode;\r\n if (target) {\r\n hostRemove(targetAnchor);\r\n }\r\n // an unmounted teleport should always remove its children if not disabled\r\n if (doRemove || !isTeleportDisabled(props)) {\r\n hostRemove(anchor);\r\n if (shapeFlag & 16 /* ARRAY_CHILDREN */) {\r\n for (let i = 0; i < children.length; i++) {\r\n const child = children[i];\r\n unmount(child, parentComponent, parentSuspense, true, !!child.dynamicChildren);\r\n }\r\n }\r\n }\r\n },\r\n move: moveTeleport,\r\n hydrate: hydrateTeleport\r\n};\r\nfunction moveTeleport(vnode, container, parentAnchor, { o: { insert }, m: move }, moveType = 2 /* REORDER */) {\r\n // move target anchor if this is a target change.\r\n if (moveType === 0 /* TARGET_CHANGE */) {\r\n insert(vnode.targetAnchor, container, parentAnchor);\r\n }\r\n const { el, anchor, shapeFlag, children, props } = vnode;\r\n const isReorder = moveType === 2 /* REORDER */;\r\n // move main view anchor if this is a re-order.\r\n if (isReorder) {\r\n insert(el, container, parentAnchor);\r\n }\r\n // if this is a re-order and teleport is enabled (content is in target)\r\n // do not move children. So the opposite is: only move children if this\r\n // is not a reorder, or the teleport is disabled\r\n if (!isReorder || isTeleportDisabled(props)) {\r\n // Teleport has either Array children or no children.\r\n if (shapeFlag & 16 /* ARRAY_CHILDREN */) {\r\n for (let i = 0; i < children.length; i++) {\r\n move(children[i], container, parentAnchor, 2 /* REORDER */);\r\n }\r\n }\r\n }\r\n // move main view anchor if this is a re-order.\r\n if (isReorder) {\r\n insert(anchor, container, parentAnchor);\r\n }\r\n}\r\nfunction hydrateTeleport(node, vnode, parentComponent, parentSuspense, slotScopeIds, optimized, { o: { nextSibling, parentNode, querySelector } }, hydrateChildren) {\r\n const target = (vnode.target = resolveTarget(vnode.props, querySelector));\r\n if (target) {\r\n // if multiple teleports rendered to the same target element, we need to\r\n // pick up from where the last teleport finished instead of the first node\r\n const targetNode = target._lpa || target.firstChild;\r\n if (vnode.shapeFlag & 16 /* ARRAY_CHILDREN */) {\r\n if (isTeleportDisabled(vnode.props)) {\r\n vnode.anchor = hydrateChildren(nextSibling(node), vnode, parentNode(node), parentComponent, parentSuspense, slotScopeIds, optimized);\r\n vnode.targetAnchor = targetNode;\r\n }\r\n else {\r\n vnode.anchor = nextSibling(node);\r\n // lookahead until we find the target anchor\r\n // we cannot rely on return value of hydrateChildren() because there\r\n // could be nested teleports\r\n let targetAnchor = targetNode;\r\n while (targetAnchor) {\r\n targetAnchor = nextSibling(targetAnchor);\r\n if (targetAnchor &&\r\n targetAnchor.nodeType === 8 &&\r\n targetAnchor.data === 'teleport anchor') {\r\n vnode.targetAnchor = targetAnchor;\r\n target._lpa =\r\n vnode.targetAnchor && nextSibling(vnode.targetAnchor);\r\n break;\r\n }\r\n }\r\n hydrateChildren(targetNode, vnode, target, parentComponent, parentSuspense, slotScopeIds, optimized);\r\n }\r\n }\r\n }\r\n return vnode.anchor && nextSibling(vnode.anchor);\r\n}\r\n// Force-casted public typing for h and TSX props inference\r\nconst Teleport = TeleportImpl;\n\nconst Fragment = Symbol((process.env.NODE_ENV !== 'production') ? 'Fragment' : undefined);\r\nconst Text = Symbol((process.env.NODE_ENV !== 'production') ? 'Text' : undefined);\r\nconst Comment = Symbol((process.env.NODE_ENV !== 'production') ? 'Comment' : undefined);\r\nconst Static = Symbol((process.env.NODE_ENV !== 'production') ? 'Static' : undefined);\r\n// Since v-if and v-for are the two possible ways node structure can dynamically\r\n// change, once we consider v-if branches and each v-for fragment a block, we\r\n// can divide a template into nested blocks, and within each block the node\r\n// structure would be stable. This allows us to skip most children diffing\r\n// and only worry about the dynamic nodes (indicated by patch flags).\r\nconst blockStack = [];\r\nlet currentBlock = null;\r\n/**\r\n * Open a block.\r\n * This must be called before `createBlock`. It cannot be part of `createBlock`\r\n * because the children of the block are evaluated before `createBlock` itself\r\n * is called. The generated code typically looks like this:\r\n *\r\n * ```js\r\n * function render() {\r\n * return (openBlock(),createBlock('div', null, [...]))\r\n * }\r\n * ```\r\n * disableTracking is true when creating a v-for fragment block, since a v-for\r\n * fragment always diffs its children.\r\n *\r\n * @private\r\n */\r\nfunction openBlock(disableTracking = false) {\r\n blockStack.push((currentBlock = disableTracking ? null : []));\r\n}\r\nfunction closeBlock() {\r\n blockStack.pop();\r\n currentBlock = blockStack[blockStack.length - 1] || null;\r\n}\r\n// Whether we should be tracking dynamic child nodes inside a block.\r\n// Only tracks when this value is > 0\r\n// We are not using a simple boolean because this value may need to be\r\n// incremented/decremented by nested usage of v-once (see below)\r\nlet isBlockTreeEnabled = 1;\r\n/**\r\n * Block tracking sometimes needs to be disabled, for example during the\r\n * creation of a tree that needs to be cached by v-once. The compiler generates\r\n * code like this:\r\n *\r\n * ``` js\r\n * _cache[1] || (\r\n * setBlockTracking(-1),\r\n * _cache[1] = createVNode(...),\r\n * setBlockTracking(1),\r\n * _cache[1]\r\n * )\r\n * ```\r\n *\r\n * @private\r\n */\r\nfunction setBlockTracking(value) {\r\n isBlockTreeEnabled += value;\r\n}\r\nfunction setupBlock(vnode) {\r\n // save current block children on the block vnode\r\n vnode.dynamicChildren =\r\n isBlockTreeEnabled > 0 ? currentBlock || EMPTY_ARR : null;\r\n // close block\r\n closeBlock();\r\n // a block is always going to be patched, so track it as a child of its\r\n // parent block\r\n if (isBlockTreeEnabled > 0 && currentBlock) {\r\n currentBlock.push(vnode);\r\n }\r\n return vnode;\r\n}\r\n/**\r\n * @private\r\n */\r\nfunction createElementBlock(type, props, children, patchFlag, dynamicProps, shapeFlag) {\r\n return setupBlock(createBaseVNode(type, props, children, patchFlag, dynamicProps, shapeFlag, true /* isBlock */));\r\n}\r\n/**\r\n * Create a block root vnode. Takes the same exact arguments as `createVNode`.\r\n * A block root keeps track of dynamic nodes within the block in the\r\n * `dynamicChildren` array.\r\n *\r\n * @private\r\n */\r\nfunction createBlock(type, props, children, patchFlag, dynamicProps) {\r\n return setupBlock(createVNode(type, props, children, patchFlag, dynamicProps, true /* isBlock: prevent a block from tracking itself */));\r\n}\r\nfunction isVNode(value) {\r\n return value ? value.__v_isVNode === true : false;\r\n}\r\nfunction isSameVNodeType(n1, n2) {\r\n if ((process.env.NODE_ENV !== 'production') &&\r\n n2.shapeFlag & 6 /* COMPONENT */ &&\r\n hmrDirtyComponents.has(n2.type)) {\r\n // HMR only: if the component has been hot-updated, force a reload.\r\n return false;\r\n }\r\n return n1.type === n2.type && n1.key === n2.key;\r\n}\r\nlet vnodeArgsTransformer;\r\n/**\r\n * Internal API for registering an arguments transform for createVNode\r\n * used for creating stubs in the test-utils\r\n * It is *internal* but needs to be exposed for test-utils to pick up proper\r\n * typings\r\n */\r\nfunction transformVNodeArgs(transformer) {\r\n vnodeArgsTransformer = transformer;\r\n}\r\nconst createVNodeWithArgsTransform = (...args) => {\r\n return _createVNode(...(vnodeArgsTransformer\r\n ? vnodeArgsTransformer(args, currentRenderingInstance)\r\n : args));\r\n};\r\nconst InternalObjectKey = `__vInternal`;\r\nconst normalizeKey = ({ key }) => key != null ? key : null;\r\nconst normalizeRef = ({ ref, ref_key, ref_for }) => {\r\n return (ref != null\r\n ? isString(ref) || isRef(ref) || isFunction(ref)\r\n ? { i: currentRenderingInstance, r: ref, k: ref_key, f: !!ref_for }\r\n : ref\r\n : null);\r\n};\r\nfunction createBaseVNode(type, props = null, children = null, patchFlag = 0, dynamicProps = null, shapeFlag = type === Fragment ? 0 : 1 /* ELEMENT */, isBlockNode = false, needFullChildrenNormalization = false) {\r\n const vnode = {\r\n __v_isVNode: true,\r\n __v_skip: true,\r\n type,\r\n props,\r\n key: props && normalizeKey(props),\r\n ref: props && normalizeRef(props),\r\n scopeId: currentScopeId,\r\n slotScopeIds: null,\r\n children,\r\n component: null,\r\n suspense: null,\r\n ssContent: null,\r\n ssFallback: null,\r\n dirs: null,\r\n transition: null,\r\n el: null,\r\n anchor: null,\r\n target: null,\r\n targetAnchor: null,\r\n staticCount: 0,\r\n shapeFlag,\r\n patchFlag,\r\n dynamicProps,\r\n dynamicChildren: null,\r\n appContext: null\r\n };\r\n if (needFullChildrenNormalization) {\r\n normalizeChildren(vnode, children);\r\n // normalize suspense children\r\n if (shapeFlag & 128 /* SUSPENSE */) {\r\n type.normalize(vnode);\r\n }\r\n }\r\n else if (children) {\r\n // compiled element vnode - if children is passed, only possible types are\r\n // string or Array.\r\n vnode.shapeFlag |= isString(children)\r\n ? 8 /* TEXT_CHILDREN */\r\n : 16 /* ARRAY_CHILDREN */;\r\n }\r\n // validate key\r\n if ((process.env.NODE_ENV !== 'production') && vnode.key !== vnode.key) {\r\n warn(`VNode created with invalid key (NaN). VNode type:`, vnode.type);\r\n }\r\n // track vnode for block tree\r\n if (isBlockTreeEnabled > 0 &&\r\n // avoid a block node from tracking itself\r\n !isBlockNode &&\r\n // has current parent block\r\n currentBlock &&\r\n // presence of a patch flag indicates this node needs patching on updates.\r\n // component nodes also should always be patched, because even if the\r\n // component doesn't need to update, it needs to persist the instance on to\r\n // the next vnode so that it can be properly unmounted later.\r\n (vnode.patchFlag > 0 || shapeFlag & 6 /* COMPONENT */) &&\r\n // the EVENTS flag is only for hydration and if it is the only flag, the\r\n // vnode should not be considered dynamic due to handler caching.\r\n vnode.patchFlag !== 32 /* HYDRATE_EVENTS */) {\r\n currentBlock.push(vnode);\r\n }\r\n return vnode;\r\n}\r\nconst createVNode = ((process.env.NODE_ENV !== 'production') ? createVNodeWithArgsTransform : _createVNode);\r\nfunction _createVNode(type, props = null, children = null, patchFlag = 0, dynamicProps = null, isBlockNode = false) {\r\n if (!type || type === NULL_DYNAMIC_COMPONENT) {\r\n if ((process.env.NODE_ENV !== 'production') && !type) {\r\n warn(`Invalid vnode type when creating vnode: ${type}.`);\r\n }\r\n type = Comment;\r\n }\r\n if (isVNode(type)) {\r\n // createVNode receiving an existing vnode. This happens in cases like\r\n // <component :is=\"vnode\"/>\r\n // #2078 make sure to merge refs during the clone instead of overwriting it\r\n const cloned = cloneVNode(type, props, true /* mergeRef: true */);\r\n if (children) {\r\n normalizeChildren(cloned, children);\r\n }\r\n if (isBlockTreeEnabled > 0 && !isBlockNode && currentBlock) {\r\n if (cloned.shapeFlag & 6 /* COMPONENT */) {\r\n currentBlock[currentBlock.indexOf(type)] = cloned;\r\n }\r\n else {\r\n currentBlock.push(cloned);\r\n }\r\n }\r\n cloned.patchFlag |= -2 /* BAIL */;\r\n return cloned;\r\n }\r\n // class component normalization.\r\n if (isClassComponent(type)) {\r\n type = type.__vccOpts;\r\n }\r\n // class & style normalization.\r\n if (props) {\r\n // for reactive or proxy objects, we need to clone it to enable mutation.\r\n props = guardReactiveProps(props);\r\n let { class: klass, style } = props;\r\n if (klass && !isString(klass)) {\r\n props.class = normalizeClass(klass);\r\n }\r\n if (isObject(style)) {\r\n // reactive state objects need to be cloned since they are likely to be\r\n // mutated\r\n if (isProxy(style) && !isArray(style)) {\r\n style = extend({}, style);\r\n }\r\n props.style = normalizeStyle(style);\r\n }\r\n }\r\n // encode the vnode type information into a bitmap\r\n const shapeFlag = isString(type)\r\n ? 1 /* ELEMENT */\r\n : isSuspense(type)\r\n ? 128 /* SUSPENSE */\r\n : isTeleport(type)\r\n ? 64 /* TELEPORT */\r\n : isObject(type)\r\n ? 4 /* STATEFUL_COMPONENT */\r\n : isFunction(type)\r\n ? 2 /* FUNCTIONAL_COMPONENT */\r\n : 0;\r\n if ((process.env.NODE_ENV !== 'production') && shapeFlag & 4 /* STATEFUL_COMPONENT */ && isProxy(type)) {\r\n type = toRaw(type);\r\n warn(`Vue received a Component which was made a reactive object. This can ` +\r\n `lead to unnecessary performance overhead, and should be avoided by ` +\r\n `marking the component with \\`markRaw\\` or using \\`shallowRef\\` ` +\r\n `instead of \\`ref\\`.`, `\\nComponent that was made reactive: `, type);\r\n }\r\n return createBaseVNode(type, props, children, patchFlag, dynamicProps, shapeFlag, isBlockNode, true);\r\n}\r\nfunction guardReactiveProps(props) {\r\n if (!props)\r\n return null;\r\n return isProxy(props) || InternalObjectKey in props\r\n ? extend({}, props)\r\n : props;\r\n}\r\nfunction cloneVNode(vnode, extraProps, mergeRef = false) {\r\n // This is intentionally NOT using spread or extend to avoid the runtime\r\n // key enumeration cost.\r\n const { props, ref, patchFlag, children } = vnode;\r\n const mergedProps = extraProps ? mergeProps(props || {}, extraProps) : props;\r\n const cloned = {\r\n __v_isVNode: true,\r\n __v_skip: true,\r\n type: vnode.type,\r\n props: mergedProps,\r\n key: mergedProps && normalizeKey(mergedProps),\r\n ref: extraProps && extraProps.ref\r\n ? // #2078 in the case of <component :is=\"vnode\" ref=\"extra\"/>\r\n // if the vnode itself already has a ref, cloneVNode will need to merge\r\n // the refs so the single vnode can be set on multiple refs\r\n mergeRef && ref\r\n ? isArray(ref)\r\n ? ref.concat(normalizeRef(extraProps))\r\n : [ref, normalizeRef(extraProps)]\r\n : normalizeRef(extraProps)\r\n : ref,\r\n scopeId: vnode.scopeId,\r\n slotScopeIds: vnode.slotScopeIds,\r\n children: (process.env.NODE_ENV !== 'production') && patchFlag === -1 /* HOISTED */ && isArray(children)\r\n ? children.map(deepCloneVNode)\r\n : children,\r\n target: vnode.target,\r\n targetAnchor: vnode.targetAnchor,\r\n staticCount: vnode.staticCount,\r\n shapeFlag: vnode.shapeFlag,\r\n // if the vnode is cloned with extra props, we can no longer assume its\r\n // existing patch flag to be reliable and need to add the FULL_PROPS flag.\r\n // note: preserve flag for fragments since they use the flag for children\r\n // fast paths only.\r\n patchFlag: extraProps && vnode.type !== Fragment\r\n ? patchFlag === -1 // hoisted node\r\n ? 16 /* FULL_PROPS */\r\n : patchFlag | 16 /* FULL_PROPS */\r\n : patchFlag,\r\n dynamicProps: vnode.dynamicProps,\r\n dynamicChildren: vnode.dynamicChildren,\r\n appContext: vnode.appContext,\r\n dirs: vnode.dirs,\r\n transition: vnode.transition,\r\n // These should technically only be non-null on mounted VNodes. However,\r\n // they *should* be copied for kept-alive vnodes. So we just always copy\r\n // them since them being non-null during a mount doesn't affect the logic as\r\n // they will simply be overwritten.\r\n component: vnode.component,\r\n suspense: vnode.suspense,\r\n ssContent: vnode.ssContent && cloneVNode(vnode.ssContent),\r\n ssFallback: vnode.ssFallback && cloneVNode(vnode.ssFallback),\r\n el: vnode.el,\r\n anchor: vnode.anchor\r\n };\r\n return cloned;\r\n}\r\n/**\r\n * Dev only, for HMR of hoisted vnodes reused in v-for\r\n * https://github.com/vitejs/vite/issues/2022\r\n */\r\nfunction deepCloneVNode(vnode) {\r\n const cloned = cloneVNode(vnode);\r\n if (isArray(vnode.children)) {\r\n cloned.children = vnode.children.map(deepCloneVNode);\r\n }\r\n return cloned;\r\n}\r\n/**\r\n * @private\r\n */\r\nfunction createTextVNode(text = ' ', flag = 0) {\r\n return createVNode(Text, null, text, flag);\r\n}\r\n/**\r\n * @private\r\n */\r\nfunction createStaticVNode(content, numberOfNodes) {\r\n // A static vnode can contain multiple stringified elements, and the number\r\n // of elements is necessary for hydration.\r\n const vnode = createVNode(Static, null, content);\r\n vnode.staticCount = numberOfNodes;\r\n return vnode;\r\n}\r\n/**\r\n * @private\r\n */\r\nfunction createCommentVNode(text = '', \r\n// when used as the v-else branch, the comment node must be created as a\r\n// block to ensure correct updates.\r\nasBlock = false) {\r\n return asBlock\r\n ? (openBlock(), createBlock(Comment, null, text))\r\n : createVNode(Comment, null, text);\r\n}\r\nfunction normalizeVNode(child) {\r\n if (child == null || typeof child === 'boolean') {\r\n // empty placeholder\r\n return createVNode(Comment);\r\n }\r\n else if (isArray(child)) {\r\n // fragment\r\n return createVNode(Fragment, null, \r\n // #3666, avoid reference pollution when reusing vnode\r\n child.slice());\r\n }\r\n else if (typeof child === 'object') {\r\n // already vnode, this should be the most common since compiled templates\r\n // always produce all-vnode children arrays\r\n return cloneIfMounted(child);\r\n }\r\n else {\r\n // strings and numbers\r\n return createVNode(Text, null, String(child));\r\n }\r\n}\r\n// optimized normalization for template-compiled render fns\r\nfunction cloneIfMounted(child) {\r\n return child.el === null || child.memo ? child : cloneVNode(child);\r\n}\r\nfunction normalizeChildren(vnode, children) {\r\n let type = 0;\r\n const { shapeFlag } = vnode;\r\n if (children == null) {\r\n children = null;\r\n }\r\n else if (isArray(children)) {\r\n type = 16 /* ARRAY_CHILDREN */;\r\n }\r\n else if (typeof children === 'object') {\r\n if (shapeFlag & (1 /* ELEMENT */ | 64 /* TELEPORT */)) {\r\n // Normalize slot to plain children for plain element and Teleport\r\n const slot = children.default;\r\n if (slot) {\r\n // _c marker is added by withCtx() indicating this is a compiled slot\r\n slot._c && (slot._d = false);\r\n normalizeChildren(vnode, slot());\r\n slot._c && (slot._d = true);\r\n }\r\n return;\r\n }\r\n else {\r\n type = 32 /* SLOTS_CHILDREN */;\r\n const slotFlag = children._;\r\n if (!slotFlag && !(InternalObjectKey in children)) {\r\n children._ctx = currentRenderingInstance;\r\n }\r\n else if (slotFlag === 3 /* FORWARDED */ && currentRenderingInstance) {\r\n // a child component receives forwarded slots from the parent.\r\n // its slot type is determined by its parent's slot type.\r\n if (currentRenderingInstance.slots._ === 1 /* STABLE */) {\r\n children._ = 1 /* STABLE */;\r\n }\r\n else {\r\n children._ = 2 /* DYNAMIC */;\r\n vnode.patchFlag |= 1024 /* DYNAMIC_SLOTS */;\r\n }\r\n }\r\n }\r\n }\r\n else if (isFunction(children)) {\r\n children = { default: children, _ctx: currentRenderingInstance };\r\n type = 32 /* SLOTS_CHILDREN */;\r\n }\r\n else {\r\n children = String(children);\r\n // force teleport children to array so it can be moved around\r\n if (shapeFlag & 64 /* TELEPORT */) {\r\n type = 16 /* ARRAY_CHILDREN */;\r\n children = [createTextVNode(children)];\r\n }\r\n else {\r\n type = 8 /* TEXT_CHILDREN */;\r\n }\r\n }\r\n vnode.children = children;\r\n vnode.shapeFlag |= type;\r\n}\r\nfunction mergeProps(...args) {\r\n const ret = {};\r\n for (let i = 0; i < args.length; i++) {\r\n const toMerge = args[i];\r\n for (const key in toMerge) {\r\n if (key === 'class') {\r\n if (ret.class !== toMerge.class) {\r\n ret.class = normalizeClass([ret.class, toMerge.class]);\r\n }\r\n }\r\n else if (key === 'style') {\r\n ret.style = normalizeStyle([ret.style, toMerge.style]);\r\n }\r\n else if (isOn(key)) {\r\n const existing = ret[key];\r\n const incoming = toMerge[key];\r\n if (incoming &&\r\n existing !== incoming &&\r\n !(isArray(existing) && existing.includes(incoming))) {\r\n ret[key] = existing\r\n ? [].concat(existing, incoming)\r\n : incoming;\r\n }\r\n }\r\n else if (key !== '') {\r\n ret[key] = toMerge[key];\r\n }\r\n }\r\n }\r\n return ret;\r\n}\r\nfunction invokeVNodeHook(hook, instance, vnode, prevVNode = null) {\r\n callWithAsyncErrorHandling(hook, instance, 7 /* VNODE_HOOK */, [\r\n vnode,\r\n prevVNode\r\n ]);\r\n}\n\nconst emptyAppContext = createAppContext();\r\nlet uid$1 = 0;\r\nfunction createComponentInstance(vnode, parent, suspense) {\r\n const type = vnode.type;\r\n // inherit parent app context - or - if root, adopt from root vnode\r\n const appContext = (parent ? parent.appContext : vnode.appContext) || emptyAppContext;\r\n const instance = {\r\n uid: uid$1++,\r\n vnode,\r\n type,\r\n parent,\r\n appContext,\r\n root: null,\r\n next: null,\r\n subTree: null,\r\n effect: null,\r\n update: null,\r\n scope: new EffectScope(true /* detached */),\r\n render: null,\r\n proxy: null,\r\n exposed: null,\r\n exposeProxy: null,\r\n withProxy: null,\r\n provides: parent ? parent.provides : Object.create(appContext.provides),\r\n accessCache: null,\r\n renderCache: [],\r\n // local resolved assets\r\n components: null,\r\n directives: null,\r\n // resolved props and emits options\r\n propsOptions: normalizePropsOptions(type, appContext),\r\n emitsOptions: normalizeEmitsOptions(type, appContext),\r\n // emit\r\n emit: null,\r\n emitted: null,\r\n // props default value\r\n propsDefaults: EMPTY_OBJ,\r\n // inheritAttrs\r\n inheritAttrs: type.inheritAttrs,\r\n // state\r\n ctx: EMPTY_OBJ,\r\n data: EMPTY_OBJ,\r\n props: EMPTY_OBJ,\r\n attrs: EMPTY_OBJ,\r\n slots: EMPTY_OBJ,\r\n refs: EMPTY_OBJ,\r\n setupState: EMPTY_OBJ,\r\n setupContext: null,\r\n // suspense related\r\n suspense,\r\n suspenseId: suspense ? suspense.pendingId : 0,\r\n asyncDep: null,\r\n asyncResolved: false,\r\n // lifecycle hooks\r\n // not using enums here because it results in computed properties\r\n isMounted: false,\r\n isUnmounted: false,\r\n isDeactivated: false,\r\n bc: null,\r\n c: null,\r\n bm: null,\r\n m: null,\r\n bu: null,\r\n u: null,\r\n um: null,\r\n bum: null,\r\n da: null,\r\n a: null,\r\n rtg: null,\r\n rtc: null,\r\n ec: null,\r\n sp: null\r\n };\r\n if ((process.env.NODE_ENV !== 'production')) {\r\n instance.ctx = createDevRenderContext(instance);\r\n }\r\n else {\r\n instance.ctx = { _: instance };\r\n }\r\n instance.root = parent ? parent.root : instance;\r\n instance.emit = emit$1.bind(null, instance);\r\n // apply custom element special handling\r\n if (vnode.ce) {\r\n vnode.ce(instance);\r\n }\r\n return instance;\r\n}\r\nlet currentInstance = null;\r\nconst getCurrentInstance = () => currentInstance || currentRenderingInstance;\r\nconst setCurrentInstance = (instance) => {\r\n currentInstance = instance;\r\n instance.scope.on();\r\n};\r\nconst unsetCurrentInstance = () => {\r\n currentInstance && currentInstance.scope.off();\r\n currentInstance = null;\r\n};\r\nconst isBuiltInTag = /*#__PURE__*/ makeMap('slot,component');\r\nfunction validateComponentName(name, config) {\r\n const appIsNativeTag = config.isNativeTag || NO;\r\n if (isBuiltInTag(name) || appIsNativeTag(name)) {\r\n warn('Do not use built-in or reserved HTML elements as component id: ' + name);\r\n }\r\n}\r\nfunction isStatefulComponent(instance) {\r\n return instance.vnode.shapeFlag & 4 /* STATEFUL_COMPONENT */;\r\n}\r\nlet isInSSRComponentSetup = false;\r\nfunction setupComponent(instance, isSSR = false) {\r\n isInSSRComponentSetup = isSSR;\r\n const { props, children } = instance.vnode;\r\n const isStateful = isStatefulComponent(instance);\r\n initProps(instance, props, isStateful, isSSR);\r\n initSlots(instance, children);\r\n const setupResult = isStateful\r\n ? setupStatefulComponent(instance, isSSR)\r\n : undefined;\r\n isInSSRComponentSetup = false;\r\n return setupResult;\r\n}\r\nfunction setupStatefulComponent(instance, isSSR) {\r\n var _a;\r\n const Component = instance.type;\r\n if ((process.env.NODE_ENV !== 'production')) {\r\n if (Component.name) {\r\n validateComponentName(Component.name, instance.appContext.config);\r\n }\r\n if (Component.components) {\r\n const names = Object.keys(Component.components);\r\n for (let i = 0; i < names.length; i++) {\r\n validateComponentName(names[i], instance.appContext.config);\r\n }\r\n }\r\n if (Component.directives) {\r\n const names = Object.keys(Component.directives);\r\n for (let i = 0; i < names.length; i++) {\r\n validateDirectiveName(names[i]);\r\n }\r\n }\r\n if (Component.compilerOptions && isRuntimeOnly()) {\r\n warn(`\"compilerOptions\" is only supported when using a build of Vue that ` +\r\n `includes the runtime compiler. Since you are using a runtime-only ` +\r\n `build, the options should be passed via your build tool config instead.`);\r\n }\r\n }\r\n // 0. create render proxy property access cache\r\n instance.accessCache = Object.create(null);\r\n // 1. create public instance / render proxy\r\n // also mark it raw so it's never observed\r\n instance.proxy = markRaw(new Proxy(instance.ctx, PublicInstanceProxyHandlers));\r\n if ((process.env.NODE_ENV !== 'production')) {\r\n exposePropsOnRenderContext(instance);\r\n }\r\n // 2. call setup()\r\n const { setup } = Component;\r\n if (setup) {\r\n const setupContext = (instance.setupContext =\r\n setup.length > 1 ? createSetupContext(instance) : null);\r\n setCurrentInstance(instance);\r\n pauseTracking();\r\n const setupResult = callWithErrorHandling(setup, instance, 0 /* SETUP_FUNCTION */, [(process.env.NODE_ENV !== 'production') ? shallowReadonly(instance.props) : instance.props, setupContext]);\r\n resetTracking();\r\n unsetCurrentInstance();\r\n if (isPromise(setupResult)) {\r\n setupResult.then(unsetCurrentInstance, unsetCurrentInstance);\r\n if (isSSR) {\r\n // return the promise so server-renderer can wait on it\r\n return setupResult\r\n .then((resolvedResult) => {\r\n handleSetupResult(instance, resolvedResult, isSSR);\r\n })\r\n .catch(e => {\r\n handleError(e, instance, 0 /* SETUP_FUNCTION */);\r\n });\r\n }\r\n else {\r\n // async setup returned Promise.\r\n // bail here and wait for re-entry.\r\n instance.asyncDep = setupResult;\r\n if ((process.env.NODE_ENV !== 'production') && !instance.suspense) {\r\n const name = (_a = Component.name) !== null && _a !== void 0 ? _a : 'Anonymous';\r\n warn(`Component <${name}>: setup function returned a promise, but no ` +\r\n `<Suspense> boundary was found in the parent component tree. ` +\r\n `A component with async setup() must be nested in a <Suspense> ` +\r\n `in order to be rendered.`);\r\n }\r\n }\r\n }\r\n else {\r\n handleSetupResult(instance, setupResult, isSSR);\r\n }\r\n }\r\n else {\r\n finishComponentSetup(instance, isSSR);\r\n }\r\n}\r\nfunction handleSetupResult(instance, setupResult, isSSR) {\r\n if (isFunction(setupResult)) {\r\n // setup returned an inline render function\r\n if (instance.type.__ssrInlineRender) {\r\n // when the function's name is `ssrRender` (compiled by SFC inline mode),\r\n // set it as ssrRender instead.\r\n instance.ssrRender = setupResult;\r\n }\r\n else {\r\n instance.render = setupResult;\r\n }\r\n }\r\n else if (isObject(setupResult)) {\r\n if ((process.env.NODE_ENV !== 'production') && isVNode(setupResult)) {\r\n warn(`setup() should not return VNodes directly - ` +\r\n `return a render function instead.`);\r\n }\r\n // setup returned bindings.\r\n // assuming a render function compiled from template is present.\r\n if ((process.env.NODE_ENV !== 'production') || __VUE_PROD_DEVTOOLS__) {\r\n instance.devtoolsRawSetupState = setupResult;\r\n }\r\n instance.setupState = proxyRefs(setupResult);\r\n if ((process.env.NODE_ENV !== 'production')) {\r\n exposeSetupStateOnRenderContext(instance);\r\n }\r\n }\r\n else if ((process.env.NODE_ENV !== 'production') && setupResult !== undefined) {\r\n warn(`setup() should return an object. Received: ${setupResult === null ? 'null' : typeof setupResult}`);\r\n }\r\n finishComponentSetup(instance, isSSR);\r\n}\r\nlet compile;\r\nlet installWithProxy;\r\n/**\r\n * For runtime-dom to register the compiler.\r\n * Note the exported method uses any to avoid d.ts relying on the compiler types.\r\n */\r\nfunction registerRuntimeCompiler(_compile) {\r\n compile = _compile;\r\n installWithProxy = i => {\r\n if (i.render._rc) {\r\n i.withProxy = new Proxy(i.ctx, RuntimeCompiledPublicInstanceProxyHandlers);\r\n }\r\n };\r\n}\r\n// dev only\r\nconst isRuntimeOnly = () => !compile;\r\nfunction finishComponentSetup(instance, isSSR, skipOptions) {\r\n const Component = instance.type;\r\n // template / render function normalization\r\n // could be already set when returned from setup()\r\n if (!instance.render) {\r\n // only do on-the-fly compile if not in SSR - SSR on-the-fly compilation\r\n // is done by server-renderer\r\n if (!isSSR && compile && !Component.render) {\r\n const template = Component.template;\r\n if (template) {\r\n if ((process.env.NODE_ENV !== 'production')) {\r\n startMeasure(instance, `compile`);\r\n }\r\n const { isCustomElement, compilerOptions } = instance.appContext.config;\r\n const { delimiters, compilerOptions: componentCompilerOptions } = Component;\r\n const finalCompilerOptions = extend(extend({\r\n isCustomElement,\r\n delimiters\r\n }, compilerOptions), componentCompilerOptions);\r\n Component.render = compile(template, finalCompilerOptions);\r\n if ((process.env.NODE_ENV !== 'production')) {\r\n endMeasure(instance, `compile`);\r\n }\r\n }\r\n }\r\n instance.render = (Component.render || NOOP);\r\n // for runtime-compiled render functions using `with` blocks, the render\r\n // proxy used needs a different `has` handler which is more performant and\r\n // also only allows a whitelist of globals to fallthrough.\r\n if (installWithProxy) {\r\n installWithProxy(instance);\r\n }\r\n }\r\n // support for 2.x options\r\n if (__VUE_OPTIONS_API__ && !(false )) {\r\n setCurrentInstance(instance);\r\n pauseTracking();\r\n applyOptions(instance);\r\n resetTracking();\r\n unsetCurrentInstance();\r\n }\r\n // warn missing template/render\r\n // the runtime compilation of template in SSR is done by server-render\r\n if ((process.env.NODE_ENV !== 'production') && !Component.render && instance.render === NOOP && !isSSR) {\r\n /* istanbul ignore if */\r\n if (!compile && Component.template) {\r\n warn(`Component provided template option but ` +\r\n `runtime compilation is not supported in this build of Vue.` +\r\n (` Configure your bundler to alias \"vue\" to \"vue/dist/vue.esm-bundler.js\".`\r\n ) /* should not happen */);\r\n }\r\n else {\r\n warn(`Component is missing template or render function.`);\r\n }\r\n }\r\n}\r\nfunction createAttrsProxy(instance) {\r\n return new Proxy(instance.attrs, (process.env.NODE_ENV !== 'production')\r\n ? {\r\n get(target, key) {\r\n markAttrsAccessed();\r\n track(instance, \"get\" /* GET */, '$attrs');\r\n return target[key];\r\n },\r\n set() {\r\n warn(`setupContext.attrs is readonly.`);\r\n return false;\r\n },\r\n deleteProperty() {\r\n warn(`setupContext.attrs is readonly.`);\r\n return false;\r\n }\r\n }\r\n : {\r\n get(target, key) {\r\n track(instance, \"get\" /* GET */, '$attrs');\r\n return target[key];\r\n }\r\n });\r\n}\r\nfunction createSetupContext(instance) {\r\n const expose = exposed => {\r\n if ((process.env.NODE_ENV !== 'production') && instance.exposed) {\r\n warn(`expose() should be called only once per setup().`);\r\n }\r\n instance.exposed = exposed || {};\r\n };\r\n let attrs;\r\n if ((process.env.NODE_ENV !== 'production')) {\r\n // We use getters in dev in case libs like test-utils overwrite instance\r\n // properties (overwrites should not be done in prod)\r\n return Object.freeze({\r\n get attrs() {\r\n return attrs || (attrs = createAttrsProxy(instance));\r\n },\r\n get slots() {\r\n return shallowReadonly(instance.slots);\r\n },\r\n get emit() {\r\n return (event, ...args) => instance.emit(event, ...args);\r\n },\r\n expose\r\n });\r\n }\r\n else {\r\n return {\r\n get attrs() {\r\n return attrs || (attrs = createAttrsProxy(instance));\r\n },\r\n slots: instance.slots,\r\n emit: instance.emit,\r\n expose\r\n };\r\n }\r\n}\r\nfunction getExposeProxy(instance) {\r\n if (instance.exposed) {\r\n return (instance.exposeProxy ||\r\n (instance.exposeProxy = new Proxy(proxyRefs(markRaw(instance.exposed)), {\r\n get(target, key) {\r\n if (key in target) {\r\n return target[key];\r\n }\r\n else if (key in publicPropertiesMap) {\r\n return publicPropertiesMap[key](instance);\r\n }\r\n }\r\n })));\r\n }\r\n}\r\nconst classifyRE = /(?:^|[-_])(\\w)/g;\r\nconst classify = (str) => str.replace(classifyRE, c => c.toUpperCase()).replace(/[-_]/g, '');\r\nfunction getComponentName(Component) {\r\n return isFunction(Component)\r\n ? Component.displayName || Component.name\r\n : Component.name;\r\n}\r\n/* istanbul ignore next */\r\nfunction formatComponentName(instance, Component, isRoot = false) {\r\n let name = getComponentName(Component);\r\n if (!name && Component.__file) {\r\n const match = Component.__file.match(/([^/\\\\]+)\\.\\w+$/);\r\n if (match) {\r\n name = match[1];\r\n }\r\n }\r\n if (!name && instance && instance.parent) {\r\n // try to infer the name based on reverse resolution\r\n const inferFromRegistry = (registry) => {\r\n for (const key in registry) {\r\n if (registry[key] === Component) {\r\n return key;\r\n }\r\n }\r\n };\r\n name =\r\n inferFromRegistry(instance.components ||\r\n instance.parent.type.components) || inferFromRegistry(instance.appContext.components);\r\n }\r\n return name ? classify(name) : isRoot ? `App` : `Anonymous`;\r\n}\r\nfunction isClassComponent(value) {\r\n return isFunction(value) && '__vccOpts' in value;\r\n}\n\nconst computed = ((getterOrOptions, debugOptions) => {\r\n // @ts-ignore\r\n return computed$1(getterOrOptions, debugOptions, isInSSRComponentSetup);\r\n});\n\n// dev only\r\nconst warnRuntimeUsage = (method) => warn(`${method}() is a compiler-hint helper that is only usable inside ` +\r\n `<script setup> of a single file component. Its arguments should be ` +\r\n `compiled away and passing it at runtime has no effect.`);\r\n// implementation\r\nfunction defineProps() {\r\n if ((process.env.NODE_ENV !== 'production')) {\r\n warnRuntimeUsage(`defineProps`);\r\n }\r\n return null;\r\n}\r\n// implementation\r\nfunction defineEmits() {\r\n if ((process.env.NODE_ENV !== 'production')) {\r\n warnRuntimeUsage(`defineEmits`);\r\n }\r\n return null;\r\n}\r\n/**\r\n * Vue `<script setup>` compiler macro for declaring a component's exposed\r\n * instance properties when it is accessed by a parent component via template\r\n * refs.\r\n *\r\n * `<script setup>` components are closed by default - i.e. variables inside\r\n * the `<script setup>` scope is not exposed to parent unless explicitly exposed\r\n * via `defineExpose`.\r\n *\r\n * This is only usable inside `<script setup>`, is compiled away in the\r\n * output and should **not** be actually called at runtime.\r\n */\r\nfunction defineExpose(exposed) {\r\n if ((process.env.NODE_ENV !== 'production')) {\r\n warnRuntimeUsage(`defineExpose`);\r\n }\r\n}\r\n/**\r\n * Vue `<script setup>` compiler macro for providing props default values when\r\n * using type-based `defineProps` declaration.\r\n *\r\n * Example usage:\r\n * ```ts\r\n * withDefaults(defineProps<{\r\n * size?: number\r\n * labels?: string[]\r\n * }>(), {\r\n * size: 3,\r\n * labels: () => ['default label']\r\n * })\r\n * ```\r\n *\r\n * This is only usable inside `<script setup>`, is compiled away in the output\r\n * and should **not** be actually called at runtime.\r\n */\r\nfunction withDefaults(props, defaults) {\r\n if ((process.env.NODE_ENV !== 'production')) {\r\n warnRuntimeUsage(`withDefaults`);\r\n }\r\n return null;\r\n}\r\nfunction useSlots() {\r\n return getContext().slots;\r\n}\r\nfunction useAttrs() {\r\n return getContext().attrs;\r\n}\r\nfunction getContext() {\r\n const i = getCurrentInstance();\r\n if ((process.env.NODE_ENV !== 'production') && !i) {\r\n warn(`useContext() called without active instance.`);\r\n }\r\n return i.setupContext || (i.setupContext = createSetupContext(i));\r\n}\r\n/**\r\n * Runtime helper for merging default declarations. Imported by compiled code\r\n * only.\r\n * @internal\r\n */\r\nfunction mergeDefaults(raw, defaults) {\r\n const props = isArray(raw)\r\n ? raw.reduce((normalized, p) => ((normalized[p] = {}), normalized), {})\r\n : raw;\r\n for (const key in defaults) {\r\n const opt = props[key];\r\n if (opt) {\r\n if (isArray(opt) || isFunction(opt)) {\r\n props[key] = { type: opt, default: defaults[key] };\r\n }\r\n else {\r\n opt.default = defaults[key];\r\n }\r\n }\r\n else if (opt === null) {\r\n props[key] = { default: defaults[key] };\r\n }\r\n else if ((process.env.NODE_ENV !== 'production')) {\r\n warn(`props default key \"${key}\" has no corresponding declaration.`);\r\n }\r\n }\r\n return props;\r\n}\r\n/**\r\n * Used to create a proxy for the rest element when destructuring props with\r\n * defineProps().\r\n * @internal\r\n */\r\nfunction createPropsRestProxy(props, excludedKeys) {\r\n const ret = {};\r\n for (const key in props) {\r\n if (!excludedKeys.includes(key)) {\r\n Object.defineProperty(ret, key, {\r\n enumerable: true,\r\n get: () => props[key]\r\n });\r\n }\r\n }\r\n return ret;\r\n}\r\n/**\r\n * `<script setup>` helper for persisting the current instance context over\r\n * async/await flows.\r\n *\r\n * `@vue/compiler-sfc` converts the following:\r\n *\r\n * ```ts\r\n * const x = await foo()\r\n * ```\r\n *\r\n * into:\r\n *\r\n * ```ts\r\n * let __temp, __restore\r\n * const x = (([__temp, __restore] = withAsyncContext(() => foo())),__temp=await __temp,__restore(),__temp)\r\n * ```\r\n * @internal\r\n */\r\nfunction withAsyncContext(getAwaitable) {\r\n const ctx = getCurrentInstance();\r\n if ((process.env.NODE_ENV !== 'production') && !ctx) {\r\n warn(`withAsyncContext called without active current instance. ` +\r\n `This is likely a bug.`);\r\n }\r\n let awaitable = getAwaitable();\r\n unsetCurrentInstance();\r\n if (isPromise(awaitable)) {\r\n awaitable = awaitable.catch(e => {\r\n setCurrentInstance(ctx);\r\n throw e;\r\n });\r\n }\r\n return [awaitable, () => setCurrentInstance(ctx)];\r\n}\n\n// Actual implementation\r\nfunction h(type, propsOrChildren, children) {\r\n const l = arguments.length;\r\n if (l === 2) {\r\n if (isObject(propsOrChildren) && !isArray(propsOrChildren)) {\r\n // single vnode without props\r\n if (isVNode(propsOrChildren)) {\r\n return createVNode(type, null, [propsOrChildren]);\r\n }\r\n // props without children\r\n return createVNode(type, propsOrChildren);\r\n }\r\n else {\r\n // omit props\r\n return createVNode(type, null, propsOrChildren);\r\n }\r\n }\r\n else {\r\n if (l > 3) {\r\n children = Array.prototype.slice.call(arguments, 2);\r\n }\r\n else if (l === 3 && isVNode(children)) {\r\n children = [children];\r\n }\r\n return createVNode(type, propsOrChildren, children);\r\n }\r\n}\n\nconst ssrContextKey = Symbol((process.env.NODE_ENV !== 'production') ? `ssrContext` : ``);\r\nconst useSSRContext = () => {\r\n {\r\n const ctx = inject(ssrContextKey);\r\n if (!ctx) {\r\n warn(`Server rendering context not provided. Make sure to only call ` +\r\n `useSSRContext() conditionally in the server build.`);\r\n }\r\n return ctx;\r\n }\r\n};\n\nfunction isShallow(value) {\r\n return !!(value && value[\"__v_isShallow\" /* IS_SHALLOW */]);\r\n}\n\nfunction initCustomFormatter() {\r\n /* eslint-disable no-restricted-globals */\r\n if (!(process.env.NODE_ENV !== 'production') || typeof window === 'undefined') {\r\n return;\r\n }\r\n const vueStyle = { style: 'color:#3ba776' };\r\n const numberStyle = { style: 'color:#0b1bc9' };\r\n const stringStyle = { style: 'color:#b62e24' };\r\n const keywordStyle = { style: 'color:#9d288c' };\r\n // custom formatter for Chrome\r\n // https://www.mattzeunert.com/2016/02/19/custom-chrome-devtools-object-formatters.html\r\n const formatter = {\r\n header(obj) {\r\n // TODO also format ComponentPublicInstance & ctx.slots/attrs in setup\r\n if (!isObject(obj)) {\r\n return null;\r\n }\r\n if (obj.__isVue) {\r\n return ['div', vueStyle, `VueInstance`];\r\n }\r\n else if (isRef(obj)) {\r\n return [\r\n 'div',\r\n {},\r\n ['span', vueStyle, genRefFlag(obj)],\r\n '<',\r\n formatValue(obj.value),\r\n `>`\r\n ];\r\n }\r\n else if (isReactive(obj)) {\r\n return [\r\n 'div',\r\n {},\r\n ['span', vueStyle, isShallow(obj) ? 'ShallowReactive' : 'Reactive'],\r\n '<',\r\n formatValue(obj),\r\n `>${isReadonly(obj) ? ` (readonly)` : ``}`\r\n ];\r\n }\r\n else if (isReadonly(obj)) {\r\n return [\r\n 'div',\r\n {},\r\n ['span', vueStyle, isShallow(obj) ? 'ShallowReadonly' : 'Readonly'],\r\n '<',\r\n formatValue(obj),\r\n '>'\r\n ];\r\n }\r\n return null;\r\n },\r\n hasBody(obj) {\r\n return obj && obj.__isVue;\r\n },\r\n body(obj) {\r\n if (obj && obj.__isVue) {\r\n return [\r\n 'div',\r\n {},\r\n ...formatInstance(obj.$)\r\n ];\r\n }\r\n }\r\n };\r\n function formatInstance(instance) {\r\n const blocks = [];\r\n if (instance.type.props && instance.props) {\r\n blocks.push(createInstanceBlock('props', toRaw(instance.props)));\r\n }\r\n if (instance.setupState !== EMPTY_OBJ) {\r\n blocks.push(createInstanceBlock('setup', instance.setupState));\r\n }\r\n if (instance.data !== EMPTY_OBJ) {\r\n blocks.push(createInstanceBlock('data', toRaw(instance.data)));\r\n }\r\n const computed = extractKeys(instance, 'computed');\r\n if (computed) {\r\n blocks.push(createInstanceBlock('computed', computed));\r\n }\r\n const injected = extractKeys(instance, 'inject');\r\n if (injected) {\r\n blocks.push(createInstanceBlock('injected', injected));\r\n }\r\n blocks.push([\r\n 'div',\r\n {},\r\n [\r\n 'span',\r\n {\r\n style: keywordStyle.style + ';opacity:0.66'\r\n },\r\n '$ (internal): '\r\n ],\r\n ['object', { object: instance }]\r\n ]);\r\n return blocks;\r\n }\r\n function createInstanceBlock(type, target) {\r\n target = extend({}, target);\r\n if (!Object.keys(target).length) {\r\n return ['span', {}];\r\n }\r\n return [\r\n 'div',\r\n { style: 'line-height:1.25em;margin-bottom:0.6em' },\r\n [\r\n 'div',\r\n {\r\n style: 'color:#476582'\r\n },\r\n type\r\n ],\r\n [\r\n 'div',\r\n {\r\n style: 'padding-left:1.25em'\r\n },\r\n ...Object.keys(target).map(key => {\r\n return [\r\n 'div',\r\n {},\r\n ['span', keywordStyle, key + ': '],\r\n formatValue(target[key], false)\r\n ];\r\n })\r\n ]\r\n ];\r\n }\r\n function formatValue(v, asRaw = true) {\r\n if (typeof v === 'number') {\r\n return ['span', numberStyle, v];\r\n }\r\n else if (typeof v === 'string') {\r\n return ['span', stringStyle, JSON.stringify(v)];\r\n }\r\n else if (typeof v === 'boolean') {\r\n return ['span', keywordStyle, v];\r\n }\r\n else if (isObject(v)) {\r\n return ['object', { object: asRaw ? toRaw(v) : v }];\r\n }\r\n else {\r\n return ['span', stringStyle, String(v)];\r\n }\r\n }\r\n function extractKeys(instance, type) {\r\n const Comp = instance.type;\r\n if (isFunction(Comp)) {\r\n return;\r\n }\r\n const extracted = {};\r\n for (const key in instance.ctx) {\r\n if (isKeyOfType(Comp, key, type)) {\r\n extracted[key] = instance.ctx[key];\r\n }\r\n }\r\n return extracted;\r\n }\r\n function isKeyOfType(Comp, key, type) {\r\n const opts = Comp[type];\r\n if ((isArray(opts) && opts.includes(key)) ||\r\n (isObject(opts) && key in opts)) {\r\n return true;\r\n }\r\n if (Comp.extends && isKeyOfType(Comp.extends, key, type)) {\r\n return true;\r\n }\r\n if (Comp.mixins && Comp.mixins.some(m => isKeyOfType(m, key, type))) {\r\n return true;\r\n }\r\n }\r\n function genRefFlag(v) {\r\n if (isShallow(v)) {\r\n return `ShallowRef`;\r\n }\r\n if (v.effect) {\r\n return `ComputedRef`;\r\n }\r\n return `Ref`;\r\n }\r\n if (window.devtoolsFormatters) {\r\n window.devtoolsFormatters.push(formatter);\r\n }\r\n else {\r\n window.devtoolsFormatters = [formatter];\r\n }\r\n}\n\nfunction withMemo(memo, render, cache, index) {\r\n const cached = cache[index];\r\n if (cached && isMemoSame(cached, memo)) {\r\n return cached;\r\n }\r\n const ret = render();\r\n // shallow clone\r\n ret.memo = memo.slice();\r\n return (cache[index] = ret);\r\n}\r\nfunction isMemoSame(cached, memo) {\r\n const prev = cached.memo;\r\n if (prev.length != memo.length) {\r\n return false;\r\n }\r\n for (let i = 0; i < prev.length; i++) {\r\n if (hasChanged(prev[i], memo[i])) {\r\n return false;\r\n }\r\n }\r\n // make sure to let parent block track it when returning cached\r\n if (isBlockTreeEnabled > 0 && currentBlock) {\r\n currentBlock.push(cached);\r\n }\r\n return true;\r\n}\n\n// Core API ------------------------------------------------------------------\r\nconst version = \"3.2.35\";\r\nconst _ssrUtils = {\r\n createComponentInstance,\r\n setupComponent,\r\n renderComponentRoot,\r\n setCurrentRenderingInstance,\r\n isVNode,\r\n normalizeVNode\r\n};\r\n/**\r\n * SSR utils for \\@vue/server-renderer. Only exposed in cjs builds.\r\n * @internal\r\n */\r\nconst ssrUtils = (_ssrUtils );\r\n/**\r\n * @internal only exposed in compat builds\r\n */\r\nconst resolveFilter = null;\r\n/**\r\n * @internal only exposed in compat builds.\r\n */\r\nconst compatUtils = (null);\n\nexport { BaseTransition, Comment, Fragment, KeepAlive, Static, Suspense, Teleport, Text, callWithAsyncErrorHandling, callWithErrorHandling, cloneVNode, compatUtils, computed, createBlock, createCommentVNode, createElementBlock, createBaseVNode as createElementVNode, createHydrationRenderer, createPropsRestProxy, createRenderer, createSlots, createStaticVNode, createTextVNode, createVNode, defineAsyncComponent, defineComponent, defineEmits, defineExpose, defineProps, devtools, getCurrentInstance, getTransitionRawChildren, guardReactiveProps, h, handleError, initCustomFormatter, inject, isMemoSame, isRuntimeOnly, isVNode, mergeDefaults, mergeProps, nextTick, onActivated, onBeforeMount, onBeforeUnmount, onBeforeUpdate, onDeactivated, onErrorCaptured, onMounted, onRenderTracked, onRenderTriggered, onServerPrefetch, onUnmounted, onUpdated, openBlock, popScopeId, provide, pushScopeId, queuePostFlushCb, registerRuntimeCompiler, renderList, renderSlot, resolveComponent, resolveDirective, resolveDynamicComponent, resolveFilter, resolveTransitionHooks, setBlockTracking, setDevtoolsHook, setTransitionHooks, ssrContextKey, ssrUtils, toHandlers, transformVNodeArgs, useAttrs, useSSRContext, useSlots, useTransitionState, version, warn, watch, watchEffect, watchPostEffect, watchSyncEffect, withAsyncContext, withCtx, withDefaults, withDirectives, withMemo, withScopeId };\n","import { camelize, warn, callWithAsyncErrorHandling, defineComponent, nextTick, createVNode, getCurrentInstance, watchPostEffect, onMounted, onUnmounted, Fragment, Static, h, BaseTransition, useTransitionState, onUpdated, toRaw, getTransitionRawChildren, setTransitionHooks, resolveTransitionHooks, createRenderer, isRuntimeOnly, createHydrationRenderer } from '@vue/runtime-core';\nexport * from '@vue/runtime-core';\nimport { isString, isArray, hyphenate, capitalize, isSpecialBooleanAttr, includeBooleanAttr, isOn, isModelListener, isFunction, toNumber, camelize as camelize$1, extend, EMPTY_OBJ, isObject, invokeArrayFns, looseIndexOf, isSet, looseEqual, isHTMLTag, isSVGTag } from '@vue/shared';\n\nconst svgNS = 'http://www.w3.org/2000/svg';\r\nconst doc = (typeof document !== 'undefined' ? document : null);\r\nconst templateContainer = doc && /*#__PURE__*/ doc.createElement('template');\r\nconst nodeOps = {\r\n insert: (child, parent, anchor) => {\r\n parent.insertBefore(child, anchor || null);\r\n },\r\n remove: child => {\r\n const parent = child.parentNode;\r\n if (parent) {\r\n parent.removeChild(child);\r\n }\r\n },\r\n createElement: (tag, isSVG, is, props) => {\r\n const el = isSVG\r\n ? doc.createElementNS(svgNS, tag)\r\n : doc.createElement(tag, is ? { is } : undefined);\r\n if (tag === 'select' && props && props.multiple != null) {\r\n el.setAttribute('multiple', props.multiple);\r\n }\r\n return el;\r\n },\r\n createText: text => doc.createTextNode(text),\r\n createComment: text => doc.createComment(text),\r\n setText: (node, text) => {\r\n node.nodeValue = text;\r\n },\r\n setElementText: (el, text) => {\r\n el.textContent = text;\r\n },\r\n parentNode: node => node.parentNode,\r\n nextSibling: node => node.nextSibling,\r\n querySelector: selector => doc.querySelector(selector),\r\n setScopeId(el, id) {\r\n el.setAttribute(id, '');\r\n },\r\n cloneNode(el) {\r\n const cloned = el.cloneNode(true);\r\n // #3072\r\n // - in `patchDOMProp`, we store the actual value in the `el._value` property.\r\n // - normally, elements using `:value` bindings will not be hoisted, but if\r\n // the bound value is a constant, e.g. `:value=\"true\"` - they do get\r\n // hoisted.\r\n // - in production, hoisted nodes are cloned when subsequent inserts, but\r\n // cloneNode() does not copy the custom property we attached.\r\n // - This may need to account for other custom DOM properties we attach to\r\n // elements in addition to `_value` in the future.\r\n if (`_value` in el) {\r\n cloned._value = el._value;\r\n }\r\n return cloned;\r\n },\r\n // __UNSAFE__\r\n // Reason: innerHTML.\r\n // Static content here can only come from compiled templates.\r\n // As long as the user only uses trusted templates, this is safe.\r\n insertStaticContent(content, parent, anchor, isSVG, start, end) {\r\n // <parent> before | first ... last | anchor </parent>\r\n const before = anchor ? anchor.previousSibling : parent.lastChild;\r\n // #5308 can only take cached path if:\r\n // - has a single root node\r\n // - nextSibling info is still available\r\n if (start && (start === end || start.nextSibling)) {\r\n // cached\r\n while (true) {\r\n parent.insertBefore(start.cloneNode(true), anchor);\r\n if (start === end || !(start = start.nextSibling))\r\n break;\r\n }\r\n }\r\n else {\r\n // fresh insert\r\n templateContainer.innerHTML = isSVG ? `<svg>${content}</svg>` : content;\r\n const template = templateContainer.content;\r\n if (isSVG) {\r\n // remove outer svg wrapper\r\n const wrapper = template.firstChild;\r\n while (wrapper.firstChild) {\r\n template.appendChild(wrapper.firstChild);\r\n }\r\n template.removeChild(wrapper);\r\n }\r\n parent.insertBefore(template, anchor);\r\n }\r\n return [\r\n // first\r\n before ? before.nextSibling : parent.firstChild,\r\n // last\r\n anchor ? anchor.previousSibling : parent.lastChild\r\n ];\r\n }\r\n};\n\n// compiler should normalize class + :class bindings on the same element\r\n// into a single binding ['staticClass', dynamic]\r\nfunction patchClass(el, value, isSVG) {\r\n // directly setting className should be faster than setAttribute in theory\r\n // if this is an element during a transition, take the temporary transition\r\n // classes into account.\r\n const transitionClasses = el._vtc;\r\n if (transitionClasses) {\r\n value = (value ? [value, ...transitionClasses] : [...transitionClasses]).join(' ');\r\n }\r\n if (value == null) {\r\n el.removeAttribute('class');\r\n }\r\n else if (isSVG) {\r\n el.setAttribute('class', value);\r\n }\r\n else {\r\n el.className = value;\r\n }\r\n}\n\nfunction patchStyle(el, prev, next) {\r\n const style = el.style;\r\n const isCssString = isString(next);\r\n if (next && !isCssString) {\r\n for (const key in next) {\r\n setStyle(style, key, next[key]);\r\n }\r\n if (prev && !isString(prev)) {\r\n for (const key in prev) {\r\n if (next[key] == null) {\r\n setStyle(style, key, '');\r\n }\r\n }\r\n }\r\n }\r\n else {\r\n const currentDisplay = style.display;\r\n if (isCssString) {\r\n if (prev !== next) {\r\n style.cssText = next;\r\n }\r\n }\r\n else if (prev) {\r\n el.removeAttribute('style');\r\n }\r\n // indicates that the `display` of the element is controlled by `v-show`,\r\n // so we always keep the current `display` value regardless of the `style`\r\n // value, thus handing over control to `v-show`.\r\n if ('_vod' in el) {\r\n style.display = currentDisplay;\r\n }\r\n }\r\n}\r\nconst importantRE = /\\s*!important$/;\r\nfunction setStyle(style, name, val) {\r\n if (isArray(val)) {\r\n val.forEach(v => setStyle(style, name, v));\r\n }\r\n else {\r\n if (val == null)\r\n val = '';\r\n if (name.startsWith('--')) {\r\n // custom property definition\r\n style.setProperty(name, val);\r\n }\r\n else {\r\n const prefixed = autoPrefix(style, name);\r\n if (importantRE.test(val)) {\r\n // !important\r\n style.setProperty(hyphenate(prefixed), val.replace(importantRE, ''), 'important');\r\n }\r\n else {\r\n style[prefixed] = val;\r\n }\r\n }\r\n }\r\n}\r\nconst prefixes = ['Webkit', 'Moz', 'ms'];\r\nconst prefixCache = {};\r\nfunction autoPrefix(style, rawName) {\r\n const cached = prefixCache[rawName];\r\n if (cached) {\r\n return cached;\r\n }\r\n let name = camelize(rawName);\r\n if (name !== 'filter' && name in style) {\r\n return (prefixCache[rawName] = name);\r\n }\r\n name = capitalize(name);\r\n for (let i = 0; i < prefixes.length; i++) {\r\n const prefixed = prefixes[i] + name;\r\n if (prefixed in style) {\r\n return (prefixCache[rawName] = prefixed);\r\n }\r\n }\r\n return rawName;\r\n}\n\nconst xlinkNS = 'http://www.w3.org/1999/xlink';\r\nfunction patchAttr(el, key, value, isSVG, instance) {\r\n if (isSVG && key.startsWith('xlink:')) {\r\n if (value == null) {\r\n el.removeAttributeNS(xlinkNS, key.slice(6, key.length));\r\n }\r\n else {\r\n el.setAttributeNS(xlinkNS, key, value);\r\n }\r\n }\r\n else {\r\n // note we are only checking boolean attributes that don't have a\r\n // corresponding dom prop of the same name here.\r\n const isBoolean = isSpecialBooleanAttr(key);\r\n if (value == null || (isBoolean && !includeBooleanAttr(value))) {\r\n el.removeAttribute(key);\r\n }\r\n else {\r\n el.setAttribute(key, isBoolean ? '' : value);\r\n }\r\n }\r\n}\n\n// __UNSAFE__\r\n// functions. The user is responsible for using them with only trusted content.\r\nfunction patchDOMProp(el, key, value, \r\n// the following args are passed only due to potential innerHTML/textContent\r\n// overriding existing VNodes, in which case the old tree must be properly\r\n// unmounted.\r\nprevChildren, parentComponent, parentSuspense, unmountChildren) {\r\n if (key === 'innerHTML' || key === 'textContent') {\r\n if (prevChildren) {\r\n unmountChildren(prevChildren, parentComponent, parentSuspense);\r\n }\r\n el[key] = value == null ? '' : value;\r\n return;\r\n }\r\n if (key === 'value' &&\r\n el.tagName !== 'PROGRESS' &&\r\n // custom elements may use _value internally\r\n !el.tagName.includes('-')) {\r\n // store value as _value as well since\r\n // non-string values will be stringified.\r\n el._value = value;\r\n const newValue = value == null ? '' : value;\r\n if (el.value !== newValue ||\r\n // #4956: always set for OPTION elements because its value falls back to\r\n // textContent if no value attribute is present. And setting .value for\r\n // OPTION has no side effect\r\n el.tagName === 'OPTION') {\r\n el.value = newValue;\r\n }\r\n if (value == null) {\r\n el.removeAttribute(key);\r\n }\r\n return;\r\n }\r\n let needRemove = false;\r\n if (value === '' || value == null) {\r\n const type = typeof el[key];\r\n if (type === 'boolean') {\r\n // e.g. <select multiple> compiles to { multiple: '' }\r\n value = includeBooleanAttr(value);\r\n }\r\n else if (value == null && type === 'string') {\r\n // e.g. <div :id=\"null\">\r\n value = '';\r\n needRemove = true;\r\n }\r\n else if (type === 'number') {\r\n // e.g. <img :width=\"null\">\r\n // the value of some IDL attr must be greater than 0, e.g. input.size = 0 -> error\r\n value = 0;\r\n needRemove = true;\r\n }\r\n }\r\n // some properties perform value validation and throw,\r\n // some properties has getter, no setter, will error in 'use strict'\r\n // eg. <select :type=\"null\"></select> <select :willValidate=\"null\"></select>\r\n try {\r\n el[key] = value;\r\n }\r\n catch (e) {\r\n if ((process.env.NODE_ENV !== 'production')) {\r\n warn(`Failed setting prop \"${key}\" on <${el.tagName.toLowerCase()}>: ` +\r\n `value ${value} is invalid.`, e);\r\n }\r\n }\r\n needRemove && el.removeAttribute(key);\r\n}\n\n// Async edge case fix requires storing an event listener's attach timestamp.\r\nconst [_getNow, skipTimestampCheck] = /*#__PURE__*/ (() => {\r\n let _getNow = Date.now;\r\n let skipTimestampCheck = false;\r\n if (typeof window !== 'undefined') {\r\n // Determine what event timestamp the browser is using. Annoyingly, the\r\n // timestamp can either be hi-res (relative to page load) or low-res\r\n // (relative to UNIX epoch), so in order to compare time we have to use the\r\n // same timestamp type when saving the flush timestamp.\r\n if (Date.now() > document.createEvent('Event').timeStamp) {\r\n // if the low-res timestamp which is bigger than the event timestamp\r\n // (which is evaluated AFTER) it means the event is using a hi-res timestamp,\r\n // and we need to use the hi-res version for event listeners as well.\r\n _getNow = () => performance.now();\r\n }\r\n // #3485: Firefox <= 53 has incorrect Event.timeStamp implementation\r\n // and does not fire microtasks in between event propagation, so safe to exclude.\r\n const ffMatch = navigator.userAgent.match(/firefox\\/(\\d+)/i);\r\n skipTimestampCheck = !!(ffMatch && Number(ffMatch[1]) <= 53);\r\n }\r\n return [_getNow, skipTimestampCheck];\r\n})();\r\n// To avoid the overhead of repeatedly calling performance.now(), we cache\r\n// and use the same timestamp for all event listeners attached in the same tick.\r\nlet cachedNow = 0;\r\nconst p = /*#__PURE__*/ Promise.resolve();\r\nconst reset = () => {\r\n cachedNow = 0;\r\n};\r\nconst getNow = () => cachedNow || (p.then(reset), (cachedNow = _getNow()));\r\nfunction addEventListener(el, event, handler, options) {\r\n el.addEventListener(event, handler, options);\r\n}\r\nfunction removeEventListener(el, event, handler, options) {\r\n el.removeEventListener(event, handler, options);\r\n}\r\nfunction patchEvent(el, rawName, prevValue, nextValue, instance = null) {\r\n // vei = vue event invokers\r\n const invokers = el._vei || (el._vei = {});\r\n const existingInvoker = invokers[rawName];\r\n if (nextValue && existingInvoker) {\r\n // patch\r\n existingInvoker.value = nextValue;\r\n }\r\n else {\r\n const [name, options] = parseName(rawName);\r\n if (nextValue) {\r\n // add\r\n const invoker = (invokers[rawName] = createInvoker(nextValue, instance));\r\n addEventListener(el, name, invoker, options);\r\n }\r\n else if (existingInvoker) {\r\n // remove\r\n removeEventListener(el, name, existingInvoker, options);\r\n invokers[rawName] = undefined;\r\n }\r\n }\r\n}\r\nconst optionsModifierRE = /(?:Once|Passive|Capture)$/;\r\nfunction parseName(name) {\r\n let options;\r\n if (optionsModifierRE.test(name)) {\r\n options = {};\r\n let m;\r\n while ((m = name.match(optionsModifierRE))) {\r\n name = name.slice(0, name.length - m[0].length);\r\n options[m[0].toLowerCase()] = true;\r\n }\r\n }\r\n return [hyphenate(name.slice(2)), options];\r\n}\r\nfunction createInvoker(initialValue, instance) {\r\n const invoker = (e) => {\r\n // async edge case #6566: inner click event triggers patch, event handler\r\n // attached to outer element during patch, and triggered again. This\r\n // happens because browsers fire microtask ticks between event propagation.\r\n // the solution is simple: we save the timestamp when a handler is attached,\r\n // and the handler would only fire if the event passed to it was fired\r\n // AFTER it was attached.\r\n const timeStamp = e.timeStamp || _getNow();\r\n if (skipTimestampCheck || timeStamp >= invoker.attached - 1) {\r\n callWithAsyncErrorHandling(patchStopImmediatePropagation(e, invoker.value), instance, 5 /* NATIVE_EVENT_HANDLER */, [e]);\r\n }\r\n };\r\n invoker.value = initialValue;\r\n invoker.attached = getNow();\r\n return invoker;\r\n}\r\nfunction patchStopImmediatePropagation(e, value) {\r\n if (isArray(value)) {\r\n const originalStop = e.stopImmediatePropagation;\r\n e.stopImmediatePropagation = () => {\r\n originalStop.call(e);\r\n e._stopped = true;\r\n };\r\n return value.map(fn => (e) => !e._stopped && fn && fn(e));\r\n }\r\n else {\r\n return value;\r\n }\r\n}\n\nconst nativeOnRE = /^on[a-z]/;\r\nconst patchProp = (el, key, prevValue, nextValue, isSVG = false, prevChildren, parentComponent, parentSuspense, unmountChildren) => {\r\n if (key === 'class') {\r\n patchClass(el, nextValue, isSVG);\r\n }\r\n else if (key === 'style') {\r\n patchStyle(el, prevValue, nextValue);\r\n }\r\n else if (isOn(key)) {\r\n // ignore v-model listeners\r\n if (!isModelListener(key)) {\r\n patchEvent(el, key, prevValue, nextValue, parentComponent);\r\n }\r\n }\r\n else if (key[0] === '.'\r\n ? ((key = key.slice(1)), true)\r\n : key[0] === '^'\r\n ? ((key = key.slice(1)), false)\r\n : shouldSetAsProp(el, key, nextValue, isSVG)) {\r\n patchDOMProp(el, key, nextValue, prevChildren, parentComponent, parentSuspense, unmountChildren);\r\n }\r\n else {\r\n // special case for <input v-model type=\"checkbox\"> with\r\n // :true-value & :false-value\r\n // store value as dom properties since non-string values will be\r\n // stringified.\r\n if (key === 'true-value') {\r\n el._trueValue = nextValue;\r\n }\r\n else if (key === 'false-value') {\r\n el._falseValue = nextValue;\r\n }\r\n patchAttr(el, key, nextValue, isSVG);\r\n }\r\n};\r\nfunction shouldSetAsProp(el, key, value, isSVG) {\r\n if (isSVG) {\r\n // most keys must be set as attribute on svg elements to work\r\n // ...except innerHTML & textContent\r\n if (key === 'innerHTML' || key === 'textContent') {\r\n return true;\r\n }\r\n // or native onclick with function values\r\n if (key in el && nativeOnRE.test(key) && isFunction(value)) {\r\n return true;\r\n }\r\n return false;\r\n }\r\n // these are enumerated attrs, however their corresponding DOM properties\r\n // are actually booleans - this leads to setting it with a string \"false\"\r\n // value leading it to be coerced to `true`, so we need to always treat\r\n // them as attributes.\r\n // Note that `contentEditable` doesn't have this problem: its DOM\r\n // property is also enumerated string values.\r\n if (key === 'spellcheck' || key === 'draggable' || key === 'translate') {\r\n return false;\r\n }\r\n // #1787, #2840 form property on form elements is readonly and must be set as\r\n // attribute.\r\n if (key === 'form') {\r\n return false;\r\n }\r\n // #1526 <input list> must be set as attribute\r\n if (key === 'list' && el.tagName === 'INPUT') {\r\n return false;\r\n }\r\n // #2766 <textarea type> must be set as attribute\r\n if (key === 'type' && el.tagName === 'TEXTAREA') {\r\n return false;\r\n }\r\n // native onclick with string value, must be set as attribute\r\n if (nativeOnRE.test(key) && isString(value)) {\r\n return false;\r\n }\r\n return key in el;\r\n}\n\nfunction defineCustomElement(options, hydrate) {\r\n const Comp = defineComponent(options);\r\n class VueCustomElement extends VueElement {\r\n constructor(initialProps) {\r\n super(Comp, initialProps, hydrate);\r\n }\r\n }\r\n VueCustomElement.def = Comp;\r\n return VueCustomElement;\r\n}\r\nconst defineSSRCustomElement = ((options) => {\r\n // @ts-ignore\r\n return defineCustomElement(options, hydrate);\r\n});\r\nconst BaseClass = (typeof HTMLElement !== 'undefined' ? HTMLElement : class {\r\n});\r\nclass VueElement extends BaseClass {\r\n constructor(_def, _props = {}, hydrate) {\r\n super();\r\n this._def = _def;\r\n this._props = _props;\r\n /**\r\n * @internal\r\n */\r\n this._instance = null;\r\n this._connected = false;\r\n this._resolved = false;\r\n this._numberProps = null;\r\n if (this.shadowRoot && hydrate) {\r\n hydrate(this._createVNode(), this.shadowRoot);\r\n }\r\n else {\r\n if ((process.env.NODE_ENV !== 'production') && this.shadowRoot) {\r\n warn(`Custom element has pre-rendered declarative shadow root but is not ` +\r\n `defined as hydratable. Use \\`defineSSRCustomElement\\`.`);\r\n }\r\n this.attachShadow({ mode: 'open' });\r\n }\r\n }\r\n connectedCallback() {\r\n this._connected = true;\r\n if (!this._instance) {\r\n this._resolveDef();\r\n }\r\n }\r\n disconnectedCallback() {\r\n this._connected = false;\r\n nextTick(() => {\r\n if (!this._connected) {\r\n render(null, this.shadowRoot);\r\n this._instance = null;\r\n }\r\n });\r\n }\r\n /**\r\n * resolve inner component definition (handle possible async component)\r\n */\r\n _resolveDef() {\r\n if (this._resolved) {\r\n return;\r\n }\r\n this._resolved = true;\r\n // set initial attrs\r\n for (let i = 0; i < this.attributes.length; i++) {\r\n this._setAttr(this.attributes[i].name);\r\n }\r\n // watch future attr changes\r\n new MutationObserver(mutations => {\r\n for (const m of mutations) {\r\n this._setAttr(m.attributeName);\r\n }\r\n }).observe(this, { attributes: true });\r\n const resolve = (def) => {\r\n const { props, styles } = def;\r\n const hasOptions = !isArray(props);\r\n const rawKeys = props ? (hasOptions ? Object.keys(props) : props) : [];\r\n // cast Number-type props set before resolve\r\n let numberProps;\r\n if (hasOptions) {\r\n for (const key in this._props) {\r\n const opt = props[key];\r\n if (opt === Number || (opt && opt.type === Number)) {\r\n this._props[key] = toNumber(this._props[key]);\r\n (numberProps || (numberProps = Object.create(null)))[key] = true;\r\n }\r\n }\r\n }\r\n this._numberProps = numberProps;\r\n // check if there are props set pre-upgrade or connect\r\n for (const key of Object.keys(this)) {\r\n if (key[0] !== '_') {\r\n this._setProp(key, this[key], true, false);\r\n }\r\n }\r\n // defining getter/setters on prototype\r\n for (const key of rawKeys.map(camelize$1)) {\r\n Object.defineProperty(this, key, {\r\n get() {\r\n return this._getProp(key);\r\n },\r\n set(val) {\r\n this._setProp(key, val);\r\n }\r\n });\r\n }\r\n // apply CSS\r\n this._applyStyles(styles);\r\n // initial render\r\n this._update();\r\n };\r\n const asyncDef = this._def.__asyncLoader;\r\n if (asyncDef) {\r\n asyncDef().then(resolve);\r\n }\r\n else {\r\n resolve(this._def);\r\n }\r\n }\r\n _setAttr(key) {\r\n let value = this.getAttribute(key);\r\n if (this._numberProps && this._numberProps[key]) {\r\n value = toNumber(value);\r\n }\r\n this._setProp(camelize$1(key), value, false);\r\n }\r\n /**\r\n * @internal\r\n */\r\n _getProp(key) {\r\n return this._props[key];\r\n }\r\n /**\r\n * @internal\r\n */\r\n _setProp(key, val, shouldReflect = true, shouldUpdate = true) {\r\n if (val !== this._props[key]) {\r\n this._props[key] = val;\r\n if (shouldUpdate && this._instance) {\r\n this._update();\r\n }\r\n // reflect\r\n if (shouldReflect) {\r\n if (val === true) {\r\n this.setAttribute(hyphenate(key), '');\r\n }\r\n else if (typeof val === 'string' || typeof val === 'number') {\r\n this.setAttribute(hyphenate(key), val + '');\r\n }\r\n else if (!val) {\r\n this.removeAttribute(hyphenate(key));\r\n }\r\n }\r\n }\r\n }\r\n _update() {\r\n render(this._createVNode(), this.shadowRoot);\r\n }\r\n _createVNode() {\r\n const vnode = createVNode(this._def, extend({}, this._props));\r\n if (!this._instance) {\r\n vnode.ce = instance => {\r\n this._instance = instance;\r\n instance.isCE = true;\r\n // HMR\r\n if ((process.env.NODE_ENV !== 'production')) {\r\n instance.ceReload = newStyles => {\r\n // always reset styles\r\n if (this._styles) {\r\n this._styles.forEach(s => this.shadowRoot.removeChild(s));\r\n this._styles.length = 0;\r\n }\r\n this._applyStyles(newStyles);\r\n // if this is an async component, ceReload is called from the inner\r\n // component so no need to reload the async wrapper\r\n if (!this._def.__asyncLoader) {\r\n // reload\r\n this._instance = null;\r\n this._update();\r\n }\r\n };\r\n }\r\n // intercept emit\r\n instance.emit = (event, ...args) => {\r\n this.dispatchEvent(new CustomEvent(event, {\r\n detail: args\r\n }));\r\n };\r\n // locate nearest Vue custom element parent for provide/inject\r\n let parent = this;\r\n while ((parent =\r\n parent && (parent.parentNode || parent.host))) {\r\n if (parent instanceof VueElement) {\r\n instance.parent = parent._instance;\r\n break;\r\n }\r\n }\r\n };\r\n }\r\n return vnode;\r\n }\r\n _applyStyles(styles) {\r\n if (styles) {\r\n styles.forEach(css => {\r\n const s = document.createElement('style');\r\n s.textContent = css;\r\n this.shadowRoot.appendChild(s);\r\n // record for HMR\r\n if ((process.env.NODE_ENV !== 'production')) {\r\n (this._styles || (this._styles = [])).push(s);\r\n }\r\n });\r\n }\r\n }\r\n}\n\nfunction useCssModule(name = '$style') {\r\n /* istanbul ignore else */\r\n {\r\n const instance = getCurrentInstance();\r\n if (!instance) {\r\n (process.env.NODE_ENV !== 'production') && warn(`useCssModule must be called inside setup()`);\r\n return EMPTY_OBJ;\r\n }\r\n const modules = instance.type.__cssModules;\r\n if (!modules) {\r\n (process.env.NODE_ENV !== 'production') && warn(`Current instance does not have CSS modules injected.`);\r\n return EMPTY_OBJ;\r\n }\r\n const mod = modules[name];\r\n if (!mod) {\r\n (process.env.NODE_ENV !== 'production') &&\r\n warn(`Current instance does not have CSS module named \"${name}\".`);\r\n return EMPTY_OBJ;\r\n }\r\n return mod;\r\n }\r\n}\n\n/**\r\n * Runtime helper for SFC's CSS variable injection feature.\r\n * @private\r\n */\r\nfunction useCssVars(getter) {\r\n const instance = getCurrentInstance();\r\n /* istanbul ignore next */\r\n if (!instance) {\r\n (process.env.NODE_ENV !== 'production') &&\r\n warn(`useCssVars is called without current active component instance.`);\r\n return;\r\n }\r\n const setVars = () => setVarsOnVNode(instance.subTree, getter(instance.proxy));\r\n watchPostEffect(setVars);\r\n onMounted(() => {\r\n const ob = new MutationObserver(setVars);\r\n ob.observe(instance.subTree.el.parentNode, { childList: true });\r\n onUnmounted(() => ob.disconnect());\r\n });\r\n}\r\nfunction setVarsOnVNode(vnode, vars) {\r\n if (vnode.shapeFlag & 128 /* SUSPENSE */) {\r\n const suspense = vnode.suspense;\r\n vnode = suspense.activeBranch;\r\n if (suspense.pendingBranch && !suspense.isHydrating) {\r\n suspense.effects.push(() => {\r\n setVarsOnVNode(suspense.activeBranch, vars);\r\n });\r\n }\r\n }\r\n // drill down HOCs until it's a non-component vnode\r\n while (vnode.component) {\r\n vnode = vnode.component.subTree;\r\n }\r\n if (vnode.shapeFlag & 1 /* ELEMENT */ && vnode.el) {\r\n setVarsOnNode(vnode.el, vars);\r\n }\r\n else if (vnode.type === Fragment) {\r\n vnode.children.forEach(c => setVarsOnVNode(c, vars));\r\n }\r\n else if (vnode.type === Static) {\r\n let { el, anchor } = vnode;\r\n while (el) {\r\n setVarsOnNode(el, vars);\r\n if (el === anchor)\r\n break;\r\n el = el.nextSibling;\r\n }\r\n }\r\n}\r\nfunction setVarsOnNode(el, vars) {\r\n if (el.nodeType === 1) {\r\n const style = el.style;\r\n for (const key in vars) {\r\n style.setProperty(`--${key}`, vars[key]);\r\n }\r\n }\r\n}\n\nconst TRANSITION = 'transition';\r\nconst ANIMATION = 'animation';\r\n// DOM Transition is a higher-order-component based on the platform-agnostic\r\n// base Transition component, with DOM-specific logic.\r\nconst Transition = (props, { slots }) => h(BaseTransition, resolveTransitionProps(props), slots);\r\nTransition.displayName = 'Transition';\r\nconst DOMTransitionPropsValidators = {\r\n name: String,\r\n type: String,\r\n css: {\r\n type: Boolean,\r\n default: true\r\n },\r\n duration: [String, Number, Object],\r\n enterFromClass: String,\r\n enterActiveClass: String,\r\n enterToClass: String,\r\n appearFromClass: String,\r\n appearActiveClass: String,\r\n appearToClass: String,\r\n leaveFromClass: String,\r\n leaveActiveClass: String,\r\n leaveToClass: String\r\n};\r\nconst TransitionPropsValidators = (Transition.props =\r\n /*#__PURE__*/ extend({}, BaseTransition.props, DOMTransitionPropsValidators));\r\n/**\r\n * #3227 Incoming hooks may be merged into arrays when wrapping Transition\r\n * with custom HOCs.\r\n */\r\nconst callHook = (hook, args = []) => {\r\n if (isArray(hook)) {\r\n hook.forEach(h => h(...args));\r\n }\r\n else if (hook) {\r\n hook(...args);\r\n }\r\n};\r\n/**\r\n * Check if a hook expects a callback (2nd arg), which means the user\r\n * intends to explicitly control the end of the transition.\r\n */\r\nconst hasExplicitCallback = (hook) => {\r\n return hook\r\n ? isArray(hook)\r\n ? hook.some(h => h.length > 1)\r\n : hook.length > 1\r\n : false;\r\n};\r\nfunction resolveTransitionProps(rawProps) {\r\n const baseProps = {};\r\n for (const key in rawProps) {\r\n if (!(key in DOMTransitionPropsValidators)) {\r\n baseProps[key] = rawProps[key];\r\n }\r\n }\r\n if (rawProps.css === false) {\r\n return baseProps;\r\n }\r\n const { name = 'v', type, duration, enterFromClass = `${name}-enter-from`, enterActiveClass = `${name}-enter-active`, enterToClass = `${name}-enter-to`, appearFromClass = enterFromClass, appearActiveClass = enterActiveClass, appearToClass = enterToClass, leaveFromClass = `${name}-leave-from`, leaveActiveClass = `${name}-leave-active`, leaveToClass = `${name}-leave-to` } = rawProps;\r\n const durations = normalizeDuration(duration);\r\n const enterDuration = durations && durations[0];\r\n const leaveDuration = durations && durations[1];\r\n const { onBeforeEnter, onEnter, onEnterCancelled, onLeave, onLeaveCancelled, onBeforeAppear = onBeforeEnter, onAppear = onEnter, onAppearCancelled = onEnterCancelled } = baseProps;\r\n const finishEnter = (el, isAppear, done) => {\r\n removeTransitionClass(el, isAppear ? appearToClass : enterToClass);\r\n removeTransitionClass(el, isAppear ? appearActiveClass : enterActiveClass);\r\n done && done();\r\n };\r\n let isLeaving = false;\r\n const finishLeave = (el, done) => {\r\n isLeaving = false;\r\n removeTransitionClass(el, leaveFromClass);\r\n removeTransitionClass(el, leaveToClass);\r\n removeTransitionClass(el, leaveActiveClass);\r\n done && done();\r\n };\r\n const makeEnterHook = (isAppear) => {\r\n return (el, done) => {\r\n const hook = isAppear ? onAppear : onEnter;\r\n const resolve = () => finishEnter(el, isAppear, done);\r\n callHook(hook, [el, resolve]);\r\n nextFrame(() => {\r\n removeTransitionClass(el, isAppear ? appearFromClass : enterFromClass);\r\n addTransitionClass(el, isAppear ? appearToClass : enterToClass);\r\n if (!hasExplicitCallback(hook)) {\r\n whenTransitionEnds(el, type, enterDuration, resolve);\r\n }\r\n });\r\n };\r\n };\r\n return extend(baseProps, {\r\n onBeforeEnter(el) {\r\n callHook(onBeforeEnter, [el]);\r\n addTransitionClass(el, enterFromClass);\r\n addTransitionClass(el, enterActiveClass);\r\n },\r\n onBeforeAppear(el) {\r\n callHook(onBeforeAppear, [el]);\r\n addTransitionClass(el, appearFromClass);\r\n addTransitionClass(el, appearActiveClass);\r\n },\r\n onEnter: makeEnterHook(false),\r\n onAppear: makeEnterHook(true),\r\n onLeave(el, done) {\r\n isLeaving = true;\r\n const resolve = () => finishLeave(el, done);\r\n addTransitionClass(el, leaveFromClass);\r\n // force reflow so *-leave-from classes immediately take effect (#2593)\r\n forceReflow();\r\n addTransitionClass(el, leaveActiveClass);\r\n nextFrame(() => {\r\n if (!isLeaving) {\r\n // cancelled\r\n return;\r\n }\r\n removeTransitionClass(el, leaveFromClass);\r\n addTransitionClass(el, leaveToClass);\r\n if (!hasExplicitCallback(onLeave)) {\r\n whenTransitionEnds(el, type, leaveDuration, resolve);\r\n }\r\n });\r\n callHook(onLeave, [el, resolve]);\r\n },\r\n onEnterCancelled(el) {\r\n finishEnter(el, false);\r\n callHook(onEnterCancelled, [el]);\r\n },\r\n onAppearCancelled(el) {\r\n finishEnter(el, true);\r\n callHook(onAppearCancelled, [el]);\r\n },\r\n onLeaveCancelled(el) {\r\n finishLeave(el);\r\n callHook(onLeaveCancelled, [el]);\r\n }\r\n });\r\n}\r\nfunction normalizeDuration(duration) {\r\n if (duration == null) {\r\n return null;\r\n }\r\n else if (isObject(duration)) {\r\n return [NumberOf(duration.enter), NumberOf(duration.leave)];\r\n }\r\n else {\r\n const n = NumberOf(duration);\r\n return [n, n];\r\n }\r\n}\r\nfunction NumberOf(val) {\r\n const res = toNumber(val);\r\n if ((process.env.NODE_ENV !== 'production'))\r\n validateDuration(res);\r\n return res;\r\n}\r\nfunction validateDuration(val) {\r\n if (typeof val !== 'number') {\r\n warn(`<transition> explicit duration is not a valid number - ` +\r\n `got ${JSON.stringify(val)}.`);\r\n }\r\n else if (isNaN(val)) {\r\n warn(`<transition> explicit duration is NaN - ` +\r\n 'the duration expression might be incorrect.');\r\n }\r\n}\r\nfunction addTransitionClass(el, cls) {\r\n cls.split(/\\s+/).forEach(c => c && el.classList.add(c));\r\n (el._vtc ||\r\n (el._vtc = new Set())).add(cls);\r\n}\r\nfunction removeTransitionClass(el, cls) {\r\n cls.split(/\\s+/).forEach(c => c && el.classList.remove(c));\r\n const { _vtc } = el;\r\n if (_vtc) {\r\n _vtc.delete(cls);\r\n if (!_vtc.size) {\r\n el._vtc = undefined;\r\n }\r\n }\r\n}\r\nfunction nextFrame(cb) {\r\n requestAnimationFrame(() => {\r\n requestAnimationFrame(cb);\r\n });\r\n}\r\nlet endId = 0;\r\nfunction whenTransitionEnds(el, expectedType, explicitTimeout, resolve) {\r\n const id = (el._endId = ++endId);\r\n const resolveIfNotStale = () => {\r\n if (id === el._endId) {\r\n resolve();\r\n }\r\n };\r\n if (explicitTimeout) {\r\n return setTimeout(resolveIfNotStale, explicitTimeout);\r\n }\r\n const { type, timeout, propCount } = getTransitionInfo(el, expectedType);\r\n if (!type) {\r\n return resolve();\r\n }\r\n const endEvent = type + 'end';\r\n let ended = 0;\r\n const end = () => {\r\n el.removeEventListener(endEvent, onEnd);\r\n resolveIfNotStale();\r\n };\r\n const onEnd = (e) => {\r\n if (e.target === el && ++ended >= propCount) {\r\n end();\r\n }\r\n };\r\n setTimeout(() => {\r\n if (ended < propCount) {\r\n end();\r\n }\r\n }, timeout + 1);\r\n el.addEventListener(endEvent, onEnd);\r\n}\r\nfunction getTransitionInfo(el, expectedType) {\r\n const styles = window.getComputedStyle(el);\r\n // JSDOM may return undefined for transition properties\r\n const getStyleProperties = (key) => (styles[key] || '').split(', ');\r\n const transitionDelays = getStyleProperties(TRANSITION + 'Delay');\r\n const transitionDurations = getStyleProperties(TRANSITION + 'Duration');\r\n const transitionTimeout = getTimeout(transitionDelays, transitionDurations);\r\n const animationDelays = getStyleProperties(ANIMATION + 'Delay');\r\n const animationDurations = getStyleProperties(ANIMATION + 'Duration');\r\n const animationTimeout = getTimeout(animationDelays, animationDurations);\r\n let type = null;\r\n let timeout = 0;\r\n let propCount = 0;\r\n /* istanbul ignore if */\r\n if (expectedType === TRANSITION) {\r\n if (transitionTimeout > 0) {\r\n type = TRANSITION;\r\n timeout = transitionTimeout;\r\n propCount = transitionDurations.length;\r\n }\r\n }\r\n else if (expectedType === ANIMATION) {\r\n if (animationTimeout > 0) {\r\n type = ANIMATION;\r\n timeout = animationTimeout;\r\n propCount = animationDurations.length;\r\n }\r\n }\r\n else {\r\n timeout = Math.max(transitionTimeout, animationTimeout);\r\n type =\r\n timeout > 0\r\n ? transitionTimeout > animationTimeout\r\n ? TRANSITION\r\n : ANIMATION\r\n : null;\r\n propCount = type\r\n ? type === TRANSITION\r\n ? transitionDurations.length\r\n : animationDurations.length\r\n : 0;\r\n }\r\n const hasTransform = type === TRANSITION &&\r\n /\\b(transform|all)(,|$)/.test(styles[TRANSITION + 'Property']);\r\n return {\r\n type,\r\n timeout,\r\n propCount,\r\n hasTransform\r\n };\r\n}\r\nfunction getTimeout(delays, durations) {\r\n while (delays.length < durations.length) {\r\n delays = delays.concat(delays);\r\n }\r\n return Math.max(...durations.map((d, i) => toMs(d) + toMs(delays[i])));\r\n}\r\n// Old versions of Chromium (below 61.0.3163.100) formats floating pointer\r\n// numbers in a locale-dependent way, using a comma instead of a dot.\r\n// If comma is not replaced with a dot, the input will be rounded down\r\n// (i.e. acting as a floor function) causing unexpected behaviors\r\nfunction toMs(s) {\r\n return Number(s.slice(0, -1).replace(',', '.')) * 1000;\r\n}\r\n// synchronously force layout to put elements into a certain state\r\nfunction forceReflow() {\r\n return document.body.offsetHeight;\r\n}\n\nconst positionMap = new WeakMap();\r\nconst newPositionMap = new WeakMap();\r\nconst TransitionGroupImpl = {\r\n name: 'TransitionGroup',\r\n props: /*#__PURE__*/ extend({}, TransitionPropsValidators, {\r\n tag: String,\r\n moveClass: String\r\n }),\r\n setup(props, { slots }) {\r\n const instance = getCurrentInstance();\r\n const state = useTransitionState();\r\n let prevChildren;\r\n let children;\r\n onUpdated(() => {\r\n // children is guaranteed to exist after initial render\r\n if (!prevChildren.length) {\r\n return;\r\n }\r\n const moveClass = props.moveClass || `${props.name || 'v'}-move`;\r\n if (!hasCSSTransform(prevChildren[0].el, instance.vnode.el, moveClass)) {\r\n return;\r\n }\r\n // we divide the work into three loops to avoid mixing DOM reads and writes\r\n // in each iteration - which helps prevent layout thrashing.\r\n prevChildren.forEach(callPendingCbs);\r\n prevChildren.forEach(recordPosition);\r\n const movedChildren = prevChildren.filter(applyTranslation);\r\n // force reflow to put everything in position\r\n forceReflow();\r\n movedChildren.forEach(c => {\r\n const el = c.el;\r\n const style = el.style;\r\n addTransitionClass(el, moveClass);\r\n style.transform = style.webkitTransform = style.transitionDuration = '';\r\n const cb = (el._moveCb = (e) => {\r\n if (e && e.target !== el) {\r\n return;\r\n }\r\n if (!e || /transform$/.test(e.propertyName)) {\r\n el.removeEventListener('transitionend', cb);\r\n el._moveCb = null;\r\n removeTransitionClass(el, moveClass);\r\n }\r\n });\r\n el.addEventListener('transitionend', cb);\r\n });\r\n });\r\n return () => {\r\n const rawProps = toRaw(props);\r\n const cssTransitionProps = resolveTransitionProps(rawProps);\r\n let tag = rawProps.tag || Fragment;\r\n prevChildren = children;\r\n children = slots.default ? getTransitionRawChildren(slots.default()) : [];\r\n for (let i = 0; i < children.length; i++) {\r\n const child = children[i];\r\n if (child.key != null) {\r\n setTransitionHooks(child, resolveTransitionHooks(child, cssTransitionProps, state, instance));\r\n }\r\n else if ((process.env.NODE_ENV !== 'production')) {\r\n warn(`<TransitionGroup> children must be keyed.`);\r\n }\r\n }\r\n if (prevChildren) {\r\n for (let i = 0; i < prevChildren.length; i++) {\r\n const child = prevChildren[i];\r\n setTransitionHooks(child, resolveTransitionHooks(child, cssTransitionProps, state, instance));\r\n positionMap.set(child, child.el.getBoundingClientRect());\r\n }\r\n }\r\n return createVNode(tag, null, children);\r\n };\r\n }\r\n};\r\nconst TransitionGroup = TransitionGroupImpl;\r\nfunction callPendingCbs(c) {\r\n const el = c.el;\r\n if (el._moveCb) {\r\n el._moveCb();\r\n }\r\n if (el._enterCb) {\r\n el._enterCb();\r\n }\r\n}\r\nfunction recordPosition(c) {\r\n newPositionMap.set(c, c.el.getBoundingClientRect());\r\n}\r\nfunction applyTranslation(c) {\r\n const oldPos = positionMap.get(c);\r\n const newPos = newPositionMap.get(c);\r\n const dx = oldPos.left - newPos.left;\r\n const dy = oldPos.top - newPos.top;\r\n if (dx || dy) {\r\n const s = c.el.style;\r\n s.transform = s.webkitTransform = `translate(${dx}px,${dy}px)`;\r\n s.transitionDuration = '0s';\r\n return c;\r\n }\r\n}\r\nfunction hasCSSTransform(el, root, moveClass) {\r\n // Detect whether an element with the move class applied has\r\n // CSS transitions. Since the element may be inside an entering\r\n // transition at this very moment, we make a clone of it and remove\r\n // all other transition classes applied to ensure only the move class\r\n // is applied.\r\n const clone = el.cloneNode();\r\n if (el._vtc) {\r\n el._vtc.forEach(cls => {\r\n cls.split(/\\s+/).forEach(c => c && clone.classList.remove(c));\r\n });\r\n }\r\n moveClass.split(/\\s+/).forEach(c => c && clone.classList.add(c));\r\n clone.style.display = 'none';\r\n const container = (root.nodeType === 1 ? root : root.parentNode);\r\n container.appendChild(clone);\r\n const { hasTransform } = getTransitionInfo(clone);\r\n container.removeChild(clone);\r\n return hasTransform;\r\n}\n\nconst getModelAssigner = (vnode) => {\r\n const fn = vnode.props['onUpdate:modelValue'] ||\r\n (false );\r\n return isArray(fn) ? value => invokeArrayFns(fn, value) : fn;\r\n};\r\nfunction onCompositionStart(e) {\r\n e.target.composing = true;\r\n}\r\nfunction onCompositionEnd(e) {\r\n const target = e.target;\r\n if (target.composing) {\r\n target.composing = false;\r\n target.dispatchEvent(new Event('input'));\r\n }\r\n}\r\n// We are exporting the v-model runtime directly as vnode hooks so that it can\r\n// be tree-shaken in case v-model is never used.\r\nconst vModelText = {\r\n created(el, { modifiers: { lazy, trim, number } }, vnode) {\r\n el._assign = getModelAssigner(vnode);\r\n const castToNumber = number || (vnode.props && vnode.props.type === 'number');\r\n addEventListener(el, lazy ? 'change' : 'input', e => {\r\n if (e.target.composing)\r\n return;\r\n let domValue = el.value;\r\n if (trim) {\r\n domValue = domValue.trim();\r\n }\r\n if (castToNumber) {\r\n domValue = toNumber(domValue);\r\n }\r\n el._assign(domValue);\r\n });\r\n if (trim) {\r\n addEventListener(el, 'change', () => {\r\n el.value = el.value.trim();\r\n });\r\n }\r\n if (!lazy) {\r\n addEventListener(el, 'compositionstart', onCompositionStart);\r\n addEventListener(el, 'compositionend', onCompositionEnd);\r\n // Safari < 10.2 & UIWebView doesn't fire compositionend when\r\n // switching focus before confirming composition choice\r\n // this also fixes the issue where some browsers e.g. iOS Chrome\r\n // fires \"change\" instead of \"input\" on autocomplete.\r\n addEventListener(el, 'change', onCompositionEnd);\r\n }\r\n },\r\n // set value on mounted so it's after min/max for type=\"range\"\r\n mounted(el, { value }) {\r\n el.value = value == null ? '' : value;\r\n },\r\n beforeUpdate(el, { value, modifiers: { lazy, trim, number } }, vnode) {\r\n el._assign = getModelAssigner(vnode);\r\n // avoid clearing unresolved text. #2302\r\n if (el.composing)\r\n return;\r\n if (document.activeElement === el && el.type !== 'range') {\r\n if (lazy) {\r\n return;\r\n }\r\n if (trim && el.value.trim() === value) {\r\n return;\r\n }\r\n if ((number || el.type === 'number') && toNumber(el.value) === value) {\r\n return;\r\n }\r\n }\r\n const newValue = value == null ? '' : value;\r\n if (el.value !== newValue) {\r\n el.value = newValue;\r\n }\r\n }\r\n};\r\nconst vModelCheckbox = {\r\n // #4096 array checkboxes need to be deep traversed\r\n deep: true,\r\n created(el, _, vnode) {\r\n el._assign = getModelAssigner(vnode);\r\n addEventListener(el, 'change', () => {\r\n const modelValue = el._modelValue;\r\n const elementValue = getValue(el);\r\n const checked = el.checked;\r\n const assign = el._assign;\r\n if (isArray(modelValue)) {\r\n const index = looseIndexOf(modelValue, elementValue);\r\n const found = index !== -1;\r\n if (checked && !found) {\r\n assign(modelValue.concat(elementValue));\r\n }\r\n else if (!checked && found) {\r\n const filtered = [...modelValue];\r\n filtered.splice(index, 1);\r\n assign(filtered);\r\n }\r\n }\r\n else if (isSet(modelValue)) {\r\n const cloned = new Set(modelValue);\r\n if (checked) {\r\n cloned.add(elementValue);\r\n }\r\n else {\r\n cloned.delete(elementValue);\r\n }\r\n assign(cloned);\r\n }\r\n else {\r\n assign(getCheckboxValue(el, checked));\r\n }\r\n });\r\n },\r\n // set initial checked on mount to wait for true-value/false-value\r\n mounted: setChecked,\r\n beforeUpdate(el, binding, vnode) {\r\n el._assign = getModelAssigner(vnode);\r\n setChecked(el, binding, vnode);\r\n }\r\n};\r\nfunction setChecked(el, { value, oldValue }, vnode) {\r\n el._modelValue = value;\r\n if (isArray(value)) {\r\n el.checked = looseIndexOf(value, vnode.props.value) > -1;\r\n }\r\n else if (isSet(value)) {\r\n el.checked = value.has(vnode.props.value);\r\n }\r\n else if (value !== oldValue) {\r\n el.checked = looseEqual(value, getCheckboxValue(el, true));\r\n }\r\n}\r\nconst vModelRadio = {\r\n created(el, { value }, vnode) {\r\n el.checked = looseEqual(value, vnode.props.value);\r\n el._assign = getModelAssigner(vnode);\r\n addEventListener(el, 'change', () => {\r\n el._assign(getValue(el));\r\n });\r\n },\r\n beforeUpdate(el, { value, oldValue }, vnode) {\r\n el._assign = getModelAssigner(vnode);\r\n if (value !== oldValue) {\r\n el.checked = looseEqual(value, vnode.props.value);\r\n }\r\n }\r\n};\r\nconst vModelSelect = {\r\n // <select multiple> value need to be deep traversed\r\n deep: true,\r\n created(el, { value, modifiers: { number } }, vnode) {\r\n const isSetModel = isSet(value);\r\n addEventListener(el, 'change', () => {\r\n const selectedVal = Array.prototype.filter\r\n .call(el.options, (o) => o.selected)\r\n .map((o) => number ? toNumber(getValue(o)) : getValue(o));\r\n el._assign(el.multiple\r\n ? isSetModel\r\n ? new Set(selectedVal)\r\n : selectedVal\r\n : selectedVal[0]);\r\n });\r\n el._assign = getModelAssigner(vnode);\r\n },\r\n // set value in mounted & updated because <select> relies on its children\r\n // <option>s.\r\n mounted(el, { value }) {\r\n setSelected(el, value);\r\n },\r\n beforeUpdate(el, _binding, vnode) {\r\n el._assign = getModelAssigner(vnode);\r\n },\r\n updated(el, { value }) {\r\n setSelected(el, value);\r\n }\r\n};\r\nfunction setSelected(el, value) {\r\n const isMultiple = el.multiple;\r\n if (isMultiple && !isArray(value) && !isSet(value)) {\r\n (process.env.NODE_ENV !== 'production') &&\r\n warn(`<select multiple v-model> expects an Array or Set value for its binding, ` +\r\n `but got ${Object.prototype.toString.call(value).slice(8, -1)}.`);\r\n return;\r\n }\r\n for (let i = 0, l = el.options.length; i < l; i++) {\r\n const option = el.options[i];\r\n const optionValue = getValue(option);\r\n if (isMultiple) {\r\n if (isArray(value)) {\r\n option.selected = looseIndexOf(value, optionValue) > -1;\r\n }\r\n else {\r\n option.selected = value.has(optionValue);\r\n }\r\n }\r\n else {\r\n if (looseEqual(getValue(option), value)) {\r\n if (el.selectedIndex !== i)\r\n el.selectedIndex = i;\r\n return;\r\n }\r\n }\r\n }\r\n if (!isMultiple && el.selectedIndex !== -1) {\r\n el.selectedIndex = -1;\r\n }\r\n}\r\n// retrieve raw value set via :value bindings\r\nfunction getValue(el) {\r\n return '_value' in el ? el._value : el.value;\r\n}\r\n// retrieve raw value for true-value and false-value set via :true-value or :false-value bindings\r\nfunction getCheckboxValue(el, checked) {\r\n const key = checked ? '_trueValue' : '_falseValue';\r\n return key in el ? el[key] : checked;\r\n}\r\nconst vModelDynamic = {\r\n created(el, binding, vnode) {\r\n callModelHook(el, binding, vnode, null, 'created');\r\n },\r\n mounted(el, binding, vnode) {\r\n callModelHook(el, binding, vnode, null, 'mounted');\r\n },\r\n beforeUpdate(el, binding, vnode, prevVNode) {\r\n callModelHook(el, binding, vnode, prevVNode, 'beforeUpdate');\r\n },\r\n updated(el, binding, vnode, prevVNode) {\r\n callModelHook(el, binding, vnode, prevVNode, 'updated');\r\n }\r\n};\r\nfunction resolveDynamicModel(tagName, type) {\r\n switch (tagName) {\r\n case 'SELECT':\r\n return vModelSelect;\r\n case 'TEXTAREA':\r\n return vModelText;\r\n default:\r\n switch (type) {\r\n case 'checkbox':\r\n return vModelCheckbox;\r\n case 'radio':\r\n return vModelRadio;\r\n default:\r\n return vModelText;\r\n }\r\n }\r\n}\r\nfunction callModelHook(el, binding, vnode, prevVNode, hook) {\r\n const modelToUse = resolveDynamicModel(el.tagName, vnode.props && vnode.props.type);\r\n const fn = modelToUse[hook];\r\n fn && fn(el, binding, vnode, prevVNode);\r\n}\r\n// SSR vnode transforms, only used when user includes client-oriented render\r\n// function in SSR\r\nfunction initVModelForSSR() {\r\n vModelText.getSSRProps = ({ value }) => ({ value });\r\n vModelRadio.getSSRProps = ({ value }, vnode) => {\r\n if (vnode.props && looseEqual(vnode.props.value, value)) {\r\n return { checked: true };\r\n }\r\n };\r\n vModelCheckbox.getSSRProps = ({ value }, vnode) => {\r\n if (isArray(value)) {\r\n if (vnode.props && looseIndexOf(value, vnode.props.value) > -1) {\r\n return { checked: true };\r\n }\r\n }\r\n else if (isSet(value)) {\r\n if (vnode.props && value.has(vnode.props.value)) {\r\n return { checked: true };\r\n }\r\n }\r\n else if (value) {\r\n return { checked: true };\r\n }\r\n };\r\n vModelDynamic.getSSRProps = (binding, vnode) => {\r\n if (typeof vnode.type !== 'string') {\r\n return;\r\n }\r\n const modelToUse = resolveDynamicModel(\r\n // resolveDynamicModel expects an uppercase tag name, but vnode.type is lowercase\r\n vnode.type.toUpperCase(), vnode.props && vnode.props.type);\r\n if (modelToUse.getSSRProps) {\r\n return modelToUse.getSSRProps(binding, vnode);\r\n }\r\n };\r\n}\n\nconst systemModifiers = ['ctrl', 'shift', 'alt', 'meta'];\r\nconst modifierGuards = {\r\n stop: e => e.stopPropagation(),\r\n prevent: e => e.preventDefault(),\r\n self: e => e.target !== e.currentTarget,\r\n ctrl: e => !e.ctrlKey,\r\n shift: e => !e.shiftKey,\r\n alt: e => !e.altKey,\r\n meta: e => !e.metaKey,\r\n left: e => 'button' in e && e.button !== 0,\r\n middle: e => 'button' in e && e.button !== 1,\r\n right: e => 'button' in e && e.button !== 2,\r\n exact: (e, modifiers) => systemModifiers.some(m => e[`${m}Key`] && !modifiers.includes(m))\r\n};\r\n/**\r\n * @private\r\n */\r\nconst withModifiers = (fn, modifiers) => {\r\n return (event, ...args) => {\r\n for (let i = 0; i < modifiers.length; i++) {\r\n const guard = modifierGuards[modifiers[i]];\r\n if (guard && guard(event, modifiers))\r\n return;\r\n }\r\n return fn(event, ...args);\r\n };\r\n};\r\n// Kept for 2.x compat.\r\n// Note: IE11 compat for `spacebar` and `del` is removed for now.\r\nconst keyNames = {\r\n esc: 'escape',\r\n space: ' ',\r\n up: 'arrow-up',\r\n left: 'arrow-left',\r\n right: 'arrow-right',\r\n down: 'arrow-down',\r\n delete: 'backspace'\r\n};\r\n/**\r\n * @private\r\n */\r\nconst withKeys = (fn, modifiers) => {\r\n return (event) => {\r\n if (!('key' in event)) {\r\n return;\r\n }\r\n const eventKey = hyphenate(event.key);\r\n if (modifiers.some(k => k === eventKey || keyNames[k] === eventKey)) {\r\n return fn(event);\r\n }\r\n };\r\n};\n\nconst vShow = {\r\n beforeMount(el, { value }, { transition }) {\r\n el._vod = el.style.display === 'none' ? '' : el.style.display;\r\n if (transition && value) {\r\n transition.beforeEnter(el);\r\n }\r\n else {\r\n setDisplay(el, value);\r\n }\r\n },\r\n mounted(el, { value }, { transition }) {\r\n if (transition && value) {\r\n transition.enter(el);\r\n }\r\n },\r\n updated(el, { value, oldValue }, { transition }) {\r\n if (!value === !oldValue)\r\n return;\r\n if (transition) {\r\n if (value) {\r\n transition.beforeEnter(el);\r\n setDisplay(el, true);\r\n transition.enter(el);\r\n }\r\n else {\r\n transition.leave(el, () => {\r\n setDisplay(el, false);\r\n });\r\n }\r\n }\r\n else {\r\n setDisplay(el, value);\r\n }\r\n },\r\n beforeUnmount(el, { value }) {\r\n setDisplay(el, value);\r\n }\r\n};\r\nfunction setDisplay(el, value) {\r\n el.style.display = value ? el._vod : 'none';\r\n}\r\n// SSR vnode transforms, only used when user includes client-oriented render\r\n// function in SSR\r\nfunction initVShowForSSR() {\r\n vShow.getSSRProps = ({ value }) => {\r\n if (!value) {\r\n return { style: { display: 'none' } };\r\n }\r\n };\r\n}\n\nconst rendererOptions = /*#__PURE__*/ extend({ patchProp }, nodeOps);\r\n// lazy create the renderer - this makes core renderer logic tree-shakable\r\n// in case the user only imports reactivity utilities from Vue.\r\nlet renderer;\r\nlet enabledHydration = false;\r\nfunction ensureRenderer() {\r\n return (renderer ||\r\n (renderer = createRenderer(rendererOptions)));\r\n}\r\nfunction ensureHydrationRenderer() {\r\n renderer = enabledHydration\r\n ? renderer\r\n : createHydrationRenderer(rendererOptions);\r\n enabledHydration = true;\r\n return renderer;\r\n}\r\n// use explicit type casts here to avoid import() calls in rolled-up d.ts\r\nconst render = ((...args) => {\r\n ensureRenderer().render(...args);\r\n});\r\nconst hydrate = ((...args) => {\r\n ensureHydrationRenderer().hydrate(...args);\r\n});\r\nconst createApp = ((...args) => {\r\n const app = ensureRenderer().createApp(...args);\r\n if ((process.env.NODE_ENV !== 'production')) {\r\n injectNativeTagCheck(app);\r\n injectCompilerOptionsCheck(app);\r\n }\r\n const { mount } = app;\r\n app.mount = (containerOrSelector) => {\r\n const container = normalizeContainer(containerOrSelector);\r\n if (!container)\r\n return;\r\n const component = app._component;\r\n if (!isFunction(component) && !component.render && !component.template) {\r\n // __UNSAFE__\r\n // Reason: potential execution of JS expressions in in-DOM template.\r\n // The user must make sure the in-DOM template is trusted. If it's\r\n // rendered by the server, the template should not contain any user data.\r\n component.template = container.innerHTML;\r\n }\r\n // clear content before mounting\r\n container.innerHTML = '';\r\n const proxy = mount(container, false, container instanceof SVGElement);\r\n if (container instanceof Element) {\r\n container.removeAttribute('v-cloak');\r\n container.setAttribute('data-v-app', '');\r\n }\r\n return proxy;\r\n };\r\n return app;\r\n});\r\nconst createSSRApp = ((...args) => {\r\n const app = ensureHydrationRenderer().createApp(...args);\r\n if ((process.env.NODE_ENV !== 'production')) {\r\n injectNativeTagCheck(app);\r\n injectCompilerOptionsCheck(app);\r\n }\r\n const { mount } = app;\r\n app.mount = (containerOrSelector) => {\r\n const container = normalizeContainer(containerOrSelector);\r\n if (container) {\r\n return mount(container, true, container instanceof SVGElement);\r\n }\r\n };\r\n return app;\r\n});\r\nfunction injectNativeTagCheck(app) {\r\n // Inject `isNativeTag`\r\n // this is used for component name validation (dev only)\r\n Object.defineProperty(app.config, 'isNativeTag', {\r\n value: (tag) => isHTMLTag(tag) || isSVGTag(tag),\r\n writable: false\r\n });\r\n}\r\n// dev only\r\nfunction injectCompilerOptionsCheck(app) {\r\n if (isRuntimeOnly()) {\r\n const isCustomElement = app.config.isCustomElement;\r\n Object.defineProperty(app.config, 'isCustomElement', {\r\n get() {\r\n return isCustomElement;\r\n },\r\n set() {\r\n warn(`The \\`isCustomElement\\` config option is deprecated. Use ` +\r\n `\\`compilerOptions.isCustomElement\\` instead.`);\r\n }\r\n });\r\n const compilerOptions = app.config.compilerOptions;\r\n const msg = `The \\`compilerOptions\\` config option is only respected when using ` +\r\n `a build of Vue.js that includes the runtime compiler (aka \"full build\"). ` +\r\n `Since you are using the runtime-only build, \\`compilerOptions\\` ` +\r\n `must be passed to \\`@vue/compiler-dom\\` in the build setup instead.\\n` +\r\n `- For vue-loader: pass it via vue-loader's \\`compilerOptions\\` loader option.\\n` +\r\n `- For vue-cli: see https://cli.vuejs.org/guide/webpack.html#modifying-options-of-a-loader\\n` +\r\n `- For vite: pass it via @vitejs/plugin-vue options. See https://github.com/vitejs/vite/tree/main/packages/plugin-vue#example-for-passing-options-to-vuecompiler-dom`;\r\n Object.defineProperty(app.config, 'compilerOptions', {\r\n get() {\r\n warn(msg);\r\n return compilerOptions;\r\n },\r\n set() {\r\n warn(msg);\r\n }\r\n });\r\n }\r\n}\r\nfunction normalizeContainer(container) {\r\n if (isString(container)) {\r\n const res = document.querySelector(container);\r\n if ((process.env.NODE_ENV !== 'production') && !res) {\r\n warn(`Failed to mount app: mount target selector \"${container}\" returned null.`);\r\n }\r\n return res;\r\n }\r\n if ((process.env.NODE_ENV !== 'production') &&\r\n window.ShadowRoot &&\r\n container instanceof window.ShadowRoot &&\r\n container.mode === 'closed') {\r\n warn(`mounting on a ShadowRoot with \\`{mode: \"closed\"}\\` may lead to unpredictable bugs`);\r\n }\r\n return container;\r\n}\r\nlet ssrDirectiveInitialized = false;\r\n/**\r\n * @internal\r\n */\r\nconst initDirectivesForSSR = () => {\r\n if (!ssrDirectiveInitialized) {\r\n ssrDirectiveInitialized = true;\r\n initVModelForSSR();\r\n initVShowForSSR();\r\n }\r\n }\r\n ;\n\nexport { Transition, TransitionGroup, VueElement, createApp, createSSRApp, defineCustomElement, defineSSRCustomElement, hydrate, initDirectivesForSSR, render, useCssModule, useCssVars, vModelCheckbox, vModelDynamic, vModelRadio, vModelSelect, vModelText, vShow, withKeys, withModifiers };\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\nvar _a;\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};\nconst isIOS = isClient && ((_a = window == null ? void 0 : window.navigator) == null ? void 0 : _a.userAgent) && /iP(ad|hone|od)/.test(window.navigator.userAgent);\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 isLeading = true;\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 && (leading || !isLeading)) {\n lastExec = Date.now();\n invoke();\n } else if (trailing) {\n timer = setTimeout(() => {\n lastExec = Date.now();\n isLeading = true;\n clear();\n invoke();\n }, duration);\n }\n if (!leading && !timer)\n timer = setTimeout(() => isLeading = true, duration);\n isLeading = false;\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 const newObject = __spreadProps$4(__spreadValues$6({}, objectRef.value), { [key]: v });\n Object.setPrototypeOf(newObject, objectRef.value);\n objectRef.value = newObject;\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 maxWait = void 0\n } = _a, watchOptions = __objRest$3(_a, [\n \"debounce\",\n \"maxWait\"\n ]);\n return watchWithFilter(source, cb, __spreadProps$3(__spreadValues$3({}, watchOptions), {\n eventFilter: debounceFilter(debounce, { maxWait })\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, isIOS, 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, isDef, throttleFilter, useDebounceFn, useThrottleFn, isObject, isNumber, useIntervalFn, syncRef, objectPick, tryOnUnmounted, isIOS, 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 const isSupported = Boolean(window && \"matchMedia\" in window);\n let mediaQuery;\n const matches = ref(false);\n const update = () => {\n if (!isSupported)\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\", \"fetch\");\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 __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 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 isDef(activeElement.value) && isDef(targetElement.value) && 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\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}\nfunction useScrollLock(element, initialState = false) {\n const isLocked = ref(initialState);\n let stopTouchMoveListener = 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 stopTouchMoveListener = useEventListener(ele, \"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 && (stopTouchMoveListener == null ? void 0 : stopTouchMoveListener());\n ele.style.overflow = initialOverflow;\n isLocked.value = false;\n };\n tryOnScopeDispose(unlock);\n return computed({\n get() {\n return isLocked.value;\n },\n set(v) {\n if (v)\n lock();\n else\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({});\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 const initial = read();\n if (initial.keys().next().value)\n updateState(initial);\n else\n Object.assign(state, initialValue);\n return state;\n}\n\nfunction useUserMedia(options = {}) {\n var _a, _b, _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 const getValue = () => isDef(props[key]) ? props[key] : defaultValue;\n if (passive) {\n const proxy = ref(getValue());\n watch(() => props[key], (v) => proxy.value = v);\n watch(proxy, (v) => {\n if (v !== props[key] || deep)\n _emit(event, v);\n }, {\n deep\n });\n return proxy;\n } else {\n return computed({\n get() {\n return getValue();\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","import { useStorage } from '@vueuse/core';\nimport type { RemovableRef } from '@vueuse/core';\n\nexport interface UserMeta {\n nick: string;\n mail: string;\n link: string;\n}\n\nexport const useUserMeta = (): RemovableRef<UserMeta> =>\n useStorage<UserMeta>('WALINE_USER_META', {\n nick: '',\n mail: '',\n link: '',\n });\n\nexport const useEditor = (): RemovableRef<string> =>\n useStorage<string>('WALINE_COMMENT_BOX_EDITOR', '');\n","export const decodePath = (path: string): string => {\n try {\n path = decodeURI(path);\n } catch (err) {\n // ignore error\n }\n\n return path;\n};\n\nexport const removeEndingSplash = (content = ''): string =>\n content.replace(/\\/$/u, '');\n\nexport const isLinkHttp = (link: string): boolean =>\n /^(https?:)?\\/\\//.test(link);\n","import {\n defaultLang,\n defaultUploadImage,\n defaultHighlighter,\n defaultTexRenderer,\n getMeta,\n defaultLocales,\n} from '../config';\n\nimport { decodePath, isLinkHttp, removeEndingSplash } from './path';\n\nimport type {\n WalineEmojiInfo,\n WalineEmojiMaps,\n WalineLocale,\n WalineProps,\n} from '../typings';\n\nexport interface WalineEmojiConfig {\n tabs: Pick<WalineEmojiInfo, 'name' | 'icon' | 'items'>[];\n map: WalineEmojiMaps;\n}\n\nexport interface WalineConfig extends Required<Omit<WalineProps, 'wordLimit'>> {\n locale: WalineLocale;\n wordLimit: [number, number] | false;\n // emoji: Promise<EmojiConfig>;\n}\n\nconst getServerURL = (serverURL: string): string => {\n const result = removeEndingSplash(serverURL);\n\n return isLinkHttp(result) ? result : `https://${result}`;\n};\n\nconst getWordLimit = (\n wordLimit: WalineProps['wordLimit']\n): [number, number] | false =>\n Array.isArray(wordLimit) ? wordLimit : wordLimit ? [0, wordLimit] : false;\n\nconst fallback = <T = unknown>(\n value: T | false | undefined,\n fallback: T\n): T | false =>\n typeof value === 'function' ? value : value === false ? false : fallback;\n\nexport const getConfig = ({\n serverURL,\n\n path = location.pathname,\n lang = defaultLang,\n locale,\n emoji = ['//unpkg.com/@waline/emojis@1.0.1/weibo'],\n meta = ['nick', 'mail', 'link'],\n requiredMeta = [],\n dark = false,\n pageSize = 10,\n wordLimit,\n imageUploader,\n highlighter,\n texRenderer,\n copyright = true,\n login = 'enable',\n ...more\n}: WalineProps): WalineConfig => ({\n serverURL: getServerURL(serverURL),\n path: decodePath(path),\n locale: {\n ...(defaultLocales[lang] || defaultLocales[defaultLang]),\n ...(typeof locale === 'object' ? locale : {}),\n } as WalineLocale,\n wordLimit: getWordLimit(wordLimit),\n meta: getMeta(meta),\n requiredMeta: getMeta(requiredMeta),\n imageUploader: fallback(imageUploader, defaultUploadImage),\n highlighter: fallback(highlighter, defaultHighlighter),\n texRenderer: fallback(texRenderer, defaultTexRenderer),\n lang,\n dark,\n emoji,\n pageSize,\n login,\n copyright,\n ...more,\n});\n","const style = `{--waline-white:#000;--waline-light-grey:#666;--waline-dark-grey:#999;--waline-color:#888;--waline-bgcolor:#1e1e1e;--waline-bgcolor-light:#272727;--waline-bgcolor-hover: #444;--waline-border-color:#333;--waline-disable-bgcolor:#444;--waline-disable-color:#272727;--waline-bq-color:#272727;--waline-info-bgcolor:#272727;--waline-info-color:#666}`;\n\nexport const getDarkStyle = (selector?: string | boolean): string => {\n if (typeof selector === 'string') {\n return selector === 'auto'\n ? `@media(prefers-color-scheme:dark){body${style}}`\n : `${selector}${style}`;\n }\n\n return selector === true ? `:root${style}` : '';\n};\n","import { WalineDateLocale } from '../typings';\n\nconst padWithZeros = (vNumber: number, width: number): string => {\n let numAsString = vNumber.toString();\n\n while (numAsString.length < width) {\n numAsString = '0' + numAsString;\n }\n\n return numAsString;\n};\n\nexport const dateFormat = (date: Date): string => {\n const vDay = padWithZeros(date.getDate(), 2);\n const vMonth = padWithZeros(date.getMonth() + 1, 2);\n const vYear = padWithZeros(date.getFullYear(), 2);\n\n return `${vYear}-${vMonth}-${vDay}`;\n};\n\nexport const getTimeAgo = (\n date: Date | string,\n now: Date,\n locale: WalineDateLocale\n): string => {\n if (!date) return '';\n\n const time =\n typeof date === 'string'\n ? new Date(date.indexOf(' ') !== -1 ? date.replace(/-/g, '/') : date)\n : date;\n\n const timepassed = now.getTime() - time.getTime();\n\n const days = Math.floor(timepassed / (24 * 3600 * 1000));\n\n if (days === 0) {\n // 计算相差小时数\n\n // 计算天数后剩余的毫秒数\n const leave1 = timepassed % (24 * 3600 * 1000);\n const hours = Math.floor(leave1 / (3600 * 1000));\n\n if (hours === 0) {\n //计算相差分钟数\n\n // 计算小时数后剩余的毫秒数\n const leave2 = leave1 % (3600 * 1000);\n const minutes = Math.floor(leave2 / (60 * 1000));\n\n // 计算相差秒数\n if (minutes === 0) {\n // 计算分钟数后剩余的毫秒数\n const leave3 = leave2 % (60 * 1000);\n const seconds = Math.round(leave3 / 1000);\n\n return `${seconds} ${locale.seconds}`;\n }\n\n return `${minutes} ${locale.minutes}`;\n }\n\n return `${hours} ${locale.hours}`;\n }\n\n if (days < 0) return locale.now;\n\n if (days < 8) return `${days} ${locale.days}`;\n\n return dateFormat(time);\n};\n","import { useStorage } from '@vueuse/core';\nimport { removeEndingSplash } from './path';\n\nimport type { WalineEmojiConfig } from './config';\nimport type { WalineEmojiInfo } from '../typings';\n\nconst hasVersion = (url: string): boolean =>\n Boolean(/@[0-9]+\\.[0-9]+\\.[0-9]+/.test(url));\n\nconst fetchEmoji = (link: string): Promise<WalineEmojiInfo> => {\n const emojiStore = useStorage<Record<string, WalineEmojiInfo>>(\n 'WALINE_EMOJI',\n {}\n );\n\n const result = hasVersion(link);\n\n if (result) {\n const info = emojiStore.value[link];\n\n if (info) return Promise.resolve(info);\n }\n\n return fetch(`${link}/info.json`)\n .then((resp) => resp.json() as Promise<Omit<WalineEmojiInfo, 'folder'>>)\n .then((emojiInfo) => {\n const info = {\n folder: link,\n ...emojiInfo,\n };\n\n if (result) emojiStore.value[link] = info;\n\n return info;\n });\n};\n\nconst getLink = (name: string, folder = '', prefix = '', type = ''): string =>\n `${folder ? `${folder}/` : ''}${prefix}${name}${type ? `.${type}` : ''}`;\n\nexport const getEmojis = (\n emojis: (string | WalineEmojiInfo)[]\n): Promise<WalineEmojiConfig> =>\n Promise.all(\n emojis.map((emoji) =>\n typeof emoji === 'string'\n ? fetchEmoji(removeEndingSplash(emoji))\n : Promise.resolve(emoji)\n )\n ).then((emojiInfos) => {\n const emojiConfig: WalineEmojiConfig = {\n tabs: [],\n map: {},\n };\n\n emojiInfos.forEach((emojiInfo) => {\n const { name, folder, icon, prefix, type, items } = emojiInfo;\n\n emojiConfig.tabs.push({\n name,\n icon: getLink(icon, folder, prefix, type),\n items: items.map((item) => {\n const key = `${prefix || ''}${item}`;\n\n emojiConfig.map[key] = getLink(item, folder, prefix, type);\n\n return key;\n }),\n });\n });\n\n return emojiConfig;\n });\n","export const errorHandler = (err: Error): void => {\n if (err.name !== 'AbortError') console.error(err.message);\n};\n","import type { WalineComment, WalineCommentData } from '../typings';\n\nexport interface FetchErrorData {\n errno: number;\n errmsg: string;\n}\n\nconst JSON_HEADERS: Record<string, string> = {\n // eslint-disable-next-line @typescript-eslint/naming-convention\n 'Content-Type': 'application/json',\n};\n\nconst errorCheck = <T = unknown>(data: T | FetchErrorData, name = ''): T => {\n if (typeof data === 'object' && (data as FetchErrorData).errno)\n throw new TypeError(\n `Fetch ${name} failed with ${(data as FetchErrorData).errno}: ${\n (data as FetchErrorData).errmsg\n }`\n );\n\n return data as T;\n};\n\nexport interface FetchCountOptions {\n serverURL: string;\n lang: string;\n paths: string[];\n signal: AbortSignal;\n token?: string;\n}\n\nexport const fetchCommentCount = ({\n serverURL,\n lang,\n paths,\n signal,\n token,\n}: FetchCountOptions): Promise<number[]> => {\n const headers: Record<string, string> = {};\n if (token) headers.Authorization = `Bearer ${token}`;\n\n return (\n fetch(\n `${serverURL}/comment?type=count&url=${encodeURIComponent(\n paths.join(',')\n )}&lang=${lang}`,\n { signal, headers }\n )\n .then((resp) => resp.json() as Promise<number | number[]>)\n .then((data) => errorCheck(data, 'comment count'))\n // TODO: Improve this API\n .then((counts) => (Array.isArray(counts) ? counts : [counts]))\n );\n};\nexport interface FetchRecentOptions {\n serverURL: string;\n lang: string;\n count: number;\n signal: AbortSignal;\n token?: string;\n}\n\nexport const fetchRecentComment = ({\n serverURL,\n lang,\n count,\n signal,\n token,\n}: FetchRecentOptions): Promise<WalineComment[]> => {\n const headers: Record<string, string> = {};\n if (token) headers.Authorization = `Bearer ${token}`;\n\n return fetch(`${serverURL}/comment?type=recent&count=${count}&lang=${lang}`, {\n signal,\n headers,\n })\n .then((resp) => resp.json() as Promise<WalineComment[]>)\n .then((data) => errorCheck(data, 'recent comment'));\n};\n\nexport interface FetchListOptions {\n serverURL: string;\n path: string;\n page: number;\n pageSize: number;\n signal: AbortSignal;\n token?: string;\n lang: string;\n}\n\nexport interface FetchListResult {\n count: number;\n data: WalineComment[];\n totalPages: number;\n}\n\nexport const fetchCommentList = ({\n serverURL,\n lang,\n path,\n page,\n pageSize,\n signal,\n token,\n}: FetchListOptions): Promise<FetchListResult> => {\n const headers: Record<string, string> = {};\n if (token) headers.Authorization = `Bearer ${token}`;\n\n return fetch(\n `${serverURL}/comment?path=${encodeURIComponent(\n path\n )}&pageSize=${pageSize}&page=${page}&lang=${lang}`,\n { signal, headers }\n )\n .then((resp) => resp.json() as Promise<FetchListResult>)\n .then((data) => errorCheck(data, 'comment list'));\n};\n\nexport interface PostCommentOptions {\n serverURL: string;\n lang: string;\n token?: string;\n comment: WalineCommentData;\n}\n\nexport interface PostCommentResponse {\n data?: WalineComment;\n errmsg?: string;\n}\n\nexport const postComment = ({\n serverURL,\n lang,\n token,\n comment,\n}: PostCommentOptions): Promise<PostCommentResponse> => {\n const headers: Record<string, string> = {\n // eslint-disable-next-line @typescript-eslint/naming-convention\n 'Content-Type': 'application/json',\n };\n\n if (token) headers.Authorization = `Bearer ${token}`;\n\n return fetch(`${serverURL}/comment?lang=${lang}`, {\n method: 'POST',\n headers,\n body: JSON.stringify(comment),\n }).then((resp) => resp.json() as Promise<PostCommentResponse>);\n};\n\nexport interface DeleteCommentOptions {\n serverURL: string;\n lang: string;\n token: string;\n objectId: string | number;\n}\n\nexport const deleteComment = ({\n serverURL,\n lang,\n token,\n objectId,\n}: DeleteCommentOptions): Promise<void> => {\n const headers: Record<string, string> = {\n Authorization: `Bearer ${token}`,\n };\n\n return fetch(`${serverURL}/comment/${objectId}?lang=${lang}`, {\n method: 'DELETE',\n headers,\n }).then((resp) => resp.json() as Promise<void>);\n};\n\nexport interface LikeCommentOptions {\n serverURL: string;\n lang: string;\n objectId: number | string;\n like: boolean;\n}\n\nexport const likeComment = ({\n serverURL,\n lang,\n objectId,\n like,\n}: LikeCommentOptions): Promise<void> =>\n fetch(`${serverURL}/comment/${objectId}?lang=${lang}`, {\n method: 'PUT',\n headers: JSON_HEADERS,\n body: JSON.stringify({ like }),\n }).then((resp) => resp.json() as Promise<void>);\n\nexport interface UpdateCommentOptions {\n serverURL: string;\n lang: string;\n token: string;\n objectId: number | string;\n status?: 'approved' | 'waiting' | 'spam';\n sticky?: number;\n}\n\nexport const updateComment = ({\n serverURL,\n lang,\n token,\n objectId,\n ...data\n}: UpdateCommentOptions): Promise<void> => {\n const headers: Record<string, string> = {\n // eslint-disable-next-line @typescript-eslint/naming-convention\n 'Content-Type': 'application/json',\n Authorization: `Bearer ${token}`,\n };\n\n return fetch(`${serverURL}/comment/${objectId}?lang=${lang}`, {\n method: 'PUT',\n headers,\n body: JSON.stringify(data),\n }).then((resp) => resp.json() as Promise<void>);\n};\n\nexport interface FetchPageviewsOptions {\n serverURL: string;\n lang: string;\n paths: string[];\n signal: AbortSignal;\n}\n\nexport const fetchPageviews = ({\n serverURL,\n lang,\n paths,\n signal,\n}: FetchPageviewsOptions): Promise<number[]> =>\n fetch(\n `${serverURL}/article?path=${encodeURIComponent(\n paths.join(',')\n )}&lang=${lang}`,\n { signal }\n )\n .then((resp) => resp.json() as Promise<number[] | number>)\n .then((data) => errorCheck(data, 'visit count'))\n // TODO: Improve this API\n .then((counts) => (Array.isArray(counts) ? counts : [counts]));\n\nexport interface UpdatePageviewsOptions {\n serverURL: string;\n lang: string;\n path: string;\n}\n\nexport const updatePageviews = ({\n serverURL,\n lang,\n path,\n}: UpdatePageviewsOptions): Promise<number> =>\n fetch(`${serverURL}/article?lang=${lang}`, {\n method: 'POST',\n headers: JSON_HEADERS,\n body: JSON.stringify({ path }),\n })\n .then((resp) => resp.json() as Promise<number>)\n .then((data) => errorCheck(data, 'visit count'));\n","export const getRoot = (\n el: string | HTMLElement | undefined\n): HTMLElement | null =>\n el instanceof HTMLElement\n ? el\n : typeof el === 'string'\n ? document.querySelector(el)\n : null;\n","const isImage = (item: DataTransferItem): boolean =>\n item.type.includes('image');\n\nexport const getImagefromDataTransfer = (\n items: DataTransferItemList\n): File | null => {\n const image = Array.from(items).find(isImage);\n\n return image ? (image.getAsFile() as File) : null;\n};\n","/**\n * marked - a markdown parser\n * Copyright (c) 2011-2022, Christopher Jeffrey. (MIT Licensed)\n * https://github.com/markedjs/marked\n */\n\n/**\n * DO NOT EDIT THIS FILE\n * The code in this file is generated from files in ./src/\n */\n\nfunction getDefaults() {\n return {\n baseUrl: null,\n breaks: false,\n extensions: null,\n gfm: true,\n headerIds: true,\n headerPrefix: '',\n highlight: null,\n langPrefix: 'language-',\n mangle: true,\n pedantic: false,\n renderer: null,\n sanitize: false,\n sanitizer: null,\n silent: false,\n smartLists: false,\n smartypants: false,\n tokenizer: null,\n walkTokens: null,\n xhtml: false\n };\n}\n\nlet defaults = getDefaults();\n\nfunction changeDefaults(newDefaults) {\n defaults = newDefaults;\n}\n\n/**\n * Helpers\n */\nconst escapeTest = /[&<>\"']/;\nconst escapeReplace = /[&<>\"']/g;\nconst escapeTestNoEncode = /[<>\"']|&(?!#?\\w+;)/;\nconst escapeReplaceNoEncode = /[<>\"']|&(?!#?\\w+;)/g;\nconst escapeReplacements = {\n '&': '&',\n '<': '<',\n '>': '>',\n '\"': '"',\n \"'\": '''\n};\nconst getEscapeReplacement = (ch) => escapeReplacements[ch];\nfunction escape(html, encode) {\n if (encode) {\n if (escapeTest.test(html)) {\n return html.replace(escapeReplace, getEscapeReplacement);\n }\n } else {\n if (escapeTestNoEncode.test(html)) {\n return html.replace(escapeReplaceNoEncode, getEscapeReplacement);\n }\n }\n\n return html;\n}\n\nconst unescapeTest = /&(#(?:\\d+)|(?:#x[0-9A-Fa-f]+)|(?:\\w+));?/ig;\n\n/**\n * @param {string} html\n */\nfunction unescape(html) {\n // explicitly match decimal, hex, and named HTML entities\n return html.replace(unescapeTest, (_, n) => {\n n = n.toLowerCase();\n if (n === 'colon') return ':';\n if (n.charAt(0) === '#') {\n return n.charAt(1) === 'x'\n ? String.fromCharCode(parseInt(n.substring(2), 16))\n : String.fromCharCode(+n.substring(1));\n }\n return '';\n });\n}\n\nconst caret = /(^|[^\\[])\\^/g;\n\n/**\n * @param {string | RegExp} regex\n * @param {string} opt\n */\nfunction edit(regex, opt) {\n regex = typeof regex === 'string' ? regex : regex.source;\n opt = opt || '';\n const obj = {\n replace: (name, val) => {\n val = val.source || val;\n val = val.replace(caret, '$1');\n regex = regex.replace(name, val);\n return obj;\n },\n getRegex: () => {\n return new RegExp(regex, opt);\n }\n };\n return obj;\n}\n\nconst nonWordAndColonTest = /[^\\w:]/g;\nconst originIndependentUrl = /^$|^[a-z][a-z0-9+.-]*:|^[?#]/i;\n\n/**\n * @param {boolean} sanitize\n * @param {string} base\n * @param {string} href\n */\nfunction cleanUrl(sanitize, base, href) {\n if (sanitize) {\n let prot;\n try {\n prot = decodeURIComponent(unescape(href))\n .replace(nonWordAndColonTest, '')\n .toLowerCase();\n } catch (e) {\n return null;\n }\n if (prot.indexOf('javascript:') === 0 || prot.indexOf('vbscript:') === 0 || prot.indexOf('data:') === 0) {\n return null;\n }\n }\n if (base && !originIndependentUrl.test(href)) {\n href = resolveUrl(base, href);\n }\n try {\n href = encodeURI(href).replace(/%25/g, '%');\n } catch (e) {\n return null;\n }\n return href;\n}\n\nconst baseUrls = {};\nconst justDomain = /^[^:]+:\\/*[^/]*$/;\nconst protocol = /^([^:]+:)[\\s\\S]*$/;\nconst domain = /^([^:]+:\\/*[^/]*)[\\s\\S]*$/;\n\n/**\n * @param {string} base\n * @param {string} href\n */\nfunction resolveUrl(base, href) {\n if (!baseUrls[' ' + base]) {\n // we can ignore everything in base after the last slash of its path component,\n // but we might need to add _that_\n // https://tools.ietf.org/html/rfc3986#section-3\n if (justDomain.test(base)) {\n baseUrls[' ' + base] = base + '/';\n } else {\n baseUrls[' ' + base] = rtrim(base, '/', true);\n }\n }\n base = baseUrls[' ' + base];\n const relativeBase = base.indexOf(':') === -1;\n\n if (href.substring(0, 2) === '//') {\n if (relativeBase) {\n return href;\n }\n return base.replace(protocol, '$1') + href;\n } else if (href.charAt(0) === '/') {\n if (relativeBase) {\n return href;\n }\n return base.replace(domain, '$1') + href;\n } else {\n return base + href;\n }\n}\n\nconst noopTest = { exec: function noopTest() {} };\n\nfunction merge(obj) {\n let i = 1,\n target,\n key;\n\n for (; i < arguments.length; i++) {\n target = arguments[i];\n for (key in target) {\n if (Object.prototype.hasOwnProperty.call(target, key)) {\n obj[key] = target[key];\n }\n }\n }\n\n return obj;\n}\n\nfunction splitCells(tableRow, count) {\n // ensure that every cell-delimiting pipe has a space\n // before it to distinguish it from an escaped pipe\n const row = tableRow.replace(/\\|/g, (match, offset, str) => {\n let escaped = false,\n curr = offset;\n while (--curr >= 0 && str[curr] === '\\\\') escaped = !escaped;\n if (escaped) {\n // odd number of slashes means | is escaped\n // so we leave it alone\n return '|';\n } else {\n // add space before unescaped |\n return ' |';\n }\n }),\n cells = row.split(/ \\|/);\n let i = 0;\n\n // First/last cell in a row cannot be empty if it has no leading/trailing pipe\n if (!cells[0].trim()) { cells.shift(); }\n if (cells.length > 0 && !cells[cells.length - 1].trim()) { cells.pop(); }\n\n if (cells.length > count) {\n cells.splice(count);\n } else {\n while (cells.length < count) cells.push('');\n }\n\n for (; i < cells.length; i++) {\n // leading or trailing whitespace is ignored per the gfm spec\n cells[i] = cells[i].trim().replace(/\\\\\\|/g, '|');\n }\n return cells;\n}\n\n/**\n * Remove trailing 'c's. Equivalent to str.replace(/c*$/, '').\n * /c*$/ is vulnerable to REDOS.\n *\n * @param {string} str\n * @param {string} c\n * @param {boolean} invert Remove suffix of non-c chars instead. Default falsey.\n */\nfunction rtrim(str, c, invert) {\n const l = str.length;\n if (l === 0) {\n return '';\n }\n\n // Length of suffix matching the invert condition.\n let suffLen = 0;\n\n // Step left until we fail to match the invert condition.\n while (suffLen < l) {\n const currChar = str.charAt(l - suffLen - 1);\n if (currChar === c && !invert) {\n suffLen++;\n } else if (currChar !== c && invert) {\n suffLen++;\n } else {\n break;\n }\n }\n\n return str.slice(0, l - suffLen);\n}\n\nfunction findClosingBracket(str, b) {\n if (str.indexOf(b[1]) === -1) {\n return -1;\n }\n const l = str.length;\n let level = 0,\n i = 0;\n for (; i < l; i++) {\n if (str[i] === '\\\\') {\n i++;\n } else if (str[i] === b[0]) {\n level++;\n } else if (str[i] === b[1]) {\n level--;\n if (level < 0) {\n return i;\n }\n }\n }\n return -1;\n}\n\nfunction checkSanitizeDeprecation(opt) {\n if (opt && opt.sanitize && !opt.silent) {\n console.warn('marked(): sanitize and sanitizer parameters are deprecated since version 0.7.0, should not be used and will be removed in the future. Read more here: https://marked.js.org/#/USING_ADVANCED.md#options');\n }\n}\n\n// copied from https://stackoverflow.com/a/5450113/806777\n/**\n * @param {string} pattern\n * @param {number} count\n */\nfunction repeatString(pattern, count) {\n if (count < 1) {\n return '';\n }\n let result = '';\n while (count > 1) {\n if (count & 1) {\n result += pattern;\n }\n count >>= 1;\n pattern += pattern;\n }\n return result + pattern;\n}\n\nfunction outputLink(cap, link, raw, lexer) {\n const href = link.href;\n const title = link.title ? escape(link.title) : null;\n const text = cap[1].replace(/\\\\([\\[\\]])/g, '$1');\n\n if (cap[0].charAt(0) !== '!') {\n lexer.state.inLink = true;\n const token = {\n type: 'link',\n raw,\n href,\n title,\n text,\n tokens: lexer.inlineTokens(text, [])\n };\n lexer.state.inLink = false;\n return token;\n }\n return {\n type: 'image',\n raw,\n href,\n title,\n text: escape(text)\n };\n}\n\nfunction indentCodeCompensation(raw, text) {\n const matchIndentToCode = raw.match(/^(\\s+)(?:```)/);\n\n if (matchIndentToCode === null) {\n return text;\n }\n\n const indentToCode = matchIndentToCode[1];\n\n return text\n .split('\\n')\n .map(node => {\n const matchIndentInNode = node.match(/^\\s+/);\n if (matchIndentInNode === null) {\n return node;\n }\n\n const [indentInNode] = matchIndentInNode;\n\n if (indentInNode.length >= indentToCode.length) {\n return node.slice(indentToCode.length);\n }\n\n return node;\n })\n .join('\\n');\n}\n\n/**\n * Tokenizer\n */\nclass Tokenizer {\n constructor(options) {\n this.options = options || defaults;\n }\n\n space(src) {\n const cap = this.rules.block.newline.exec(src);\n if (cap && cap[0].length > 0) {\n return {\n type: 'space',\n raw: cap[0]\n };\n }\n }\n\n code(src) {\n const cap = this.rules.block.code.exec(src);\n if (cap) {\n const text = cap[0].replace(/^ {1,4}/gm, '');\n return {\n type: 'code',\n raw: cap[0],\n codeBlockStyle: 'indented',\n text: !this.options.pedantic\n ? rtrim(text, '\\n')\n : text\n };\n }\n }\n\n fences(src) {\n const cap = this.rules.block.fences.exec(src);\n if (cap) {\n const raw = cap[0];\n const text = indentCodeCompensation(raw, cap[3] || '');\n\n return {\n type: 'code',\n raw,\n lang: cap[2] ? cap[2].trim() : cap[2],\n text\n };\n }\n }\n\n heading(src) {\n const cap = this.rules.block.heading.exec(src);\n if (cap) {\n let text = cap[2].trim();\n\n // remove trailing #s\n if (/#$/.test(text)) {\n const trimmed = rtrim(text, '#');\n if (this.options.pedantic) {\n text = trimmed.trim();\n } else if (!trimmed || / $/.test(trimmed)) {\n // CommonMark requires space before trailing #s\n text = trimmed.trim();\n }\n }\n\n const token = {\n type: 'heading',\n raw: cap[0],\n depth: cap[1].length,\n text,\n tokens: []\n };\n this.lexer.inline(token.text, token.tokens);\n return token;\n }\n }\n\n hr(src) {\n const cap = this.rules.block.hr.exec(src);\n if (cap) {\n return {\n type: 'hr',\n raw: cap[0]\n };\n }\n }\n\n blockquote(src) {\n const cap = this.rules.block.blockquote.exec(src);\n if (cap) {\n const text = cap[0].replace(/^ *>[ \\t]?/gm, '');\n\n return {\n type: 'blockquote',\n raw: cap[0],\n tokens: this.lexer.blockTokens(text, []),\n text\n };\n }\n }\n\n list(src) {\n let cap = this.rules.block.list.exec(src);\n if (cap) {\n let raw, istask, ischecked, indent, i, blankLine, endsWithBlankLine,\n line, nextLine, rawLine, itemContents, endEarly;\n\n let bull = cap[1].trim();\n const isordered = bull.length > 1;\n\n const list = {\n type: 'list',\n raw: '',\n ordered: isordered,\n start: isordered ? +bull.slice(0, -1) : '',\n loose: false,\n items: []\n };\n\n bull = isordered ? `\\\\d{1,9}\\\\${bull.slice(-1)}` : `\\\\${bull}`;\n\n if (this.options.pedantic) {\n bull = isordered ? bull : '[*+-]';\n }\n\n // Get next list item\n const itemRegex = new RegExp(`^( {0,3}${bull})((?:[\\t ][^\\\\n]*)?(?:\\\\n|$))`);\n\n // Check if current bullet point can start a new List Item\n while (src) {\n endEarly = false;\n if (!(cap = itemRegex.exec(src))) {\n break;\n }\n\n if (this.rules.block.hr.test(src)) { // End list if bullet was actually HR (possibly move into itemRegex?)\n break;\n }\n\n raw = cap[0];\n src = src.substring(raw.length);\n\n line = cap[2].split('\\n', 1)[0];\n nextLine = src.split('\\n', 1)[0];\n\n if (this.options.pedantic) {\n indent = 2;\n itemContents = line.trimLeft();\n } else {\n indent = cap[2].search(/[^ ]/); // Find first non-space char\n indent = indent > 4 ? 1 : indent; // Treat indented code blocks (> 4 spaces) as having only 1 indent\n itemContents = line.slice(indent);\n indent += cap[1].length;\n }\n\n blankLine = false;\n\n if (!line && /^ *$/.test(nextLine)) { // Items begin with at most one blank line\n raw += nextLine + '\\n';\n src = src.substring(nextLine.length + 1);\n endEarly = true;\n }\n\n if (!endEarly) {\n const nextBulletRegex = new RegExp(`^ {0,${Math.min(3, indent - 1)}}(?:[*+-]|\\\\d{1,9}[.)])((?: [^\\\\n]*)?(?:\\\\n|$))`);\n const hrRegex = new RegExp(`^ {0,${Math.min(3, indent - 1)}}((?:- *){3,}|(?:_ *){3,}|(?:\\\\* *){3,})(?:\\\\n+|$)`);\n\n // Check if following lines should be included in List Item\n while (src) {\n rawLine = src.split('\\n', 1)[0];\n line = rawLine;\n\n // Re-align to follow commonmark nesting rules\n if (this.options.pedantic) {\n line = line.replace(/^ {1,4}(?=( {4})*[^ ])/g, ' ');\n }\n\n // End list item if found start of new bullet\n if (nextBulletRegex.test(line)) {\n break;\n }\n\n // Horizontal rule found\n if (hrRegex.test(src)) {\n break;\n }\n\n if (line.search(/[^ ]/) >= indent || !line.trim()) { // Dedent if possible\n itemContents += '\\n' + line.slice(indent);\n } else if (!blankLine) { // Until blank line, item doesn't need indentation\n itemContents += '\\n' + line;\n } else { // Otherwise, improper indentation ends this item\n break;\n }\n\n if (!blankLine && !line.trim()) { // Check if current line is blank\n blankLine = true;\n }\n\n raw += rawLine + '\\n';\n src = src.substring(rawLine.length + 1);\n }\n }\n\n if (!list.loose) {\n // If the previous item ended with a blank line, the list is loose\n if (endsWithBlankLine) {\n list.loose = true;\n } else if (/\\n *\\n *$/.test(raw)) {\n endsWithBlankLine = true;\n }\n }\n\n // Check for task list items\n if (this.options.gfm) {\n istask = /^\\[[ xX]\\] /.exec(itemContents);\n if (istask) {\n ischecked = istask[0] !== '[ ] ';\n itemContents = itemContents.replace(/^\\[[ xX]\\] +/, '');\n }\n }\n\n list.items.push({\n type: 'list_item',\n raw,\n task: !!istask,\n checked: ischecked,\n loose: false,\n text: itemContents\n });\n\n list.raw += raw;\n }\n\n // Do not consume newlines at end of final item. Alternatively, make itemRegex *start* with any newlines to simplify/speed up endsWithBlankLine logic\n list.items[list.items.length - 1].raw = raw.trimRight();\n list.items[list.items.length - 1].text = itemContents.trimRight();\n list.raw = list.raw.trimRight();\n\n const l = list.items.length;\n\n // Item child tokens handled here at end because we needed to have the final item to trim it first\n for (i = 0; i < l; i++) {\n this.lexer.state.top = false;\n list.items[i].tokens = this.lexer.blockTokens(list.items[i].text, []);\n const spacers = list.items[i].tokens.filter(t => t.type === 'space');\n const hasMultipleLineBreaks = spacers.every(t => {\n const chars = t.raw.split('');\n let lineBreaks = 0;\n for (const char of chars) {\n if (char === '\\n') {\n lineBreaks += 1;\n }\n if (lineBreaks > 1) {\n return true;\n }\n }\n\n return false;\n });\n\n if (!list.loose && spacers.length && hasMultipleLineBreaks) {\n // Having a single line break doesn't mean a list is loose. A single line break is terminating the last list item\n list.loose = true;\n list.items[i].loose = true;\n }\n }\n\n return list;\n }\n }\n\n html(src) {\n const cap = this.rules.block.html.exec(src);\n if (cap) {\n const token = {\n type: 'html',\n raw: cap[0],\n pre: !this.options.sanitizer\n && (cap[1] === 'pre' || cap[1] === 'script' || cap[1] === 'style'),\n text: cap[0]\n };\n if (this.options.sanitize) {\n token.type = 'paragraph';\n token.text = this.options.sanitizer ? this.options.sanitizer(cap[0]) : escape(cap[0]);\n token.tokens = [];\n this.lexer.inline(token.text, token.tokens);\n }\n return token;\n }\n }\n\n def(src) {\n const cap = this.rules.block.def.exec(src);\n if (cap) {\n if (cap[3]) cap[3] = cap[3].substring(1, cap[3].length - 1);\n const tag = cap[1].toLowerCase().replace(/\\s+/g, ' ');\n return {\n type: 'def',\n tag,\n raw: cap[0],\n href: cap[2],\n title: cap[3]\n };\n }\n }\n\n table(src) {\n const cap = this.rules.block.table.exec(src);\n if (cap) {\n const item = {\n type: 'table',\n header: splitCells(cap[1]).map(c => { return { text: c }; }),\n align: cap[2].replace(/^ *|\\| *$/g, '').split(/ *\\| */),\n rows: cap[3] && cap[3].trim() ? cap[3].replace(/\\n[ \\t]*$/, '').split('\\n') : []\n };\n\n if (item.header.length === item.align.length) {\n item.raw = cap[0];\n\n let l = item.align.length;\n let i, j, k, row;\n for (i = 0; i < l; i++) {\n if (/^ *-+: *$/.test(item.align[i])) {\n item.align[i] = 'right';\n } else if (/^ *:-+: *$/.test(item.align[i])) {\n item.align[i] = 'center';\n } else if (/^ *:-+ *$/.test(item.align[i])) {\n item.align[i] = 'left';\n } else {\n item.align[i] = null;\n }\n }\n\n l = item.rows.length;\n for (i = 0; i < l; i++) {\n item.rows[i] = splitCells(item.rows[i], item.header.length).map(c => { return { text: c }; });\n }\n\n // parse child tokens inside headers and cells\n\n // header child tokens\n l = item.header.length;\n for (j = 0; j < l; j++) {\n item.header[j].tokens = [];\n this.lexer.inline(item.header[j].text, item.header[j].tokens);\n }\n\n // cell child tokens\n l = item.rows.length;\n for (j = 0; j < l; j++) {\n row = item.rows[j];\n for (k = 0; k < row.length; k++) {\n row[k].tokens = [];\n this.lexer.inline(row[k].text, row[k].tokens);\n }\n }\n\n return item;\n }\n }\n }\n\n lheading(src) {\n const cap = this.rules.block.lheading.exec(src);\n if (cap) {\n const token = {\n type: 'heading',\n raw: cap[0],\n depth: cap[2].charAt(0) === '=' ? 1 : 2,\n text: cap[1],\n tokens: []\n };\n this.lexer.inline(token.text, token.tokens);\n return token;\n }\n }\n\n paragraph(src) {\n const cap = this.rules.block.paragraph.exec(src);\n if (cap) {\n const token = {\n type: 'paragraph',\n raw: cap[0],\n text: cap[1].charAt(cap[1].length - 1) === '\\n'\n ? cap[1].slice(0, -1)\n : cap[1],\n tokens: []\n };\n this.lexer.inline(token.text, token.tokens);\n return token;\n }\n }\n\n text(src) {\n const cap = this.rules.block.text.exec(src);\n if (cap) {\n const token = {\n type: 'text',\n raw: cap[0],\n text: cap[0],\n tokens: []\n };\n this.lexer.inline(token.text, token.tokens);\n return token;\n }\n }\n\n escape(src) {\n const cap = this.rules.inline.escape.exec(src);\n if (cap) {\n return {\n type: 'escape',\n raw: cap[0],\n text: escape(cap[1])\n };\n }\n }\n\n tag(src) {\n const cap = this.rules.inline.tag.exec(src);\n if (cap) {\n if (!this.lexer.state.inLink && /^<a /i.test(cap[0])) {\n this.lexer.state.inLink = true;\n } else if (this.lexer.state.inLink && /^<\\/a>/i.test(cap[0])) {\n this.lexer.state.inLink = false;\n }\n if (!this.lexer.state.inRawBlock && /^<(pre|code|kbd|script)(\\s|>)/i.test(cap[0])) {\n this.lexer.state.inRawBlock = true;\n } else if (this.lexer.state.inRawBlock && /^<\\/(pre|code|kbd|script)(\\s|>)/i.test(cap[0])) {\n this.lexer.state.inRawBlock = false;\n }\n\n return {\n type: this.options.sanitize\n ? 'text'\n : 'html',\n raw: cap[0],\n inLink: this.lexer.state.inLink,\n inRawBlock: this.lexer.state.inRawBlock,\n text: this.options.sanitize\n ? (this.options.sanitizer\n ? this.options.sanitizer(cap[0])\n : escape(cap[0]))\n : cap[0]\n };\n }\n }\n\n link(src) {\n const cap = this.rules.inline.link.exec(src);\n if (cap) {\n const trimmedUrl = cap[2].trim();\n if (!this.options.pedantic && /^</.test(trimmedUrl)) {\n // commonmark requires matching angle brackets\n if (!(/>$/.test(trimmedUrl))) {\n return;\n }\n\n // ending angle bracket cannot be escaped\n const rtrimSlash = rtrim(trimmedUrl.slice(0, -1), '\\\\');\n if ((trimmedUrl.length - rtrimSlash.length) % 2 === 0) {\n return;\n }\n } else {\n // find closing parenthesis\n const lastParenIndex = findClosingBracket(cap[2], '()');\n if (lastParenIndex > -1) {\n const start = cap[0].indexOf('!') === 0 ? 5 : 4;\n const linkLen = start + cap[1].length + lastParenIndex;\n cap[2] = cap[2].substring(0, lastParenIndex);\n cap[0] = cap[0].substring(0, linkLen).trim();\n cap[3] = '';\n }\n }\n let href = cap[2];\n let title = '';\n if (this.options.pedantic) {\n // split pedantic href and title\n const link = /^([^'\"]*[^\\s])\\s+(['\"])(.*)\\2/.exec(href);\n\n if (link) {\n href = link[1];\n title = link[3];\n }\n } else {\n title = cap[3] ? cap[3].slice(1, -1) : '';\n }\n\n href = href.trim();\n if (/^</.test(href)) {\n if (this.options.pedantic && !(/>$/.test(trimmedUrl))) {\n // pedantic allows starting angle bracket without ending angle bracket\n href = href.slice(1);\n } else {\n href = href.slice(1, -1);\n }\n }\n return outputLink(cap, {\n href: href ? href.replace(this.rules.inline._escapes, '$1') : href,\n title: title ? title.replace(this.rules.inline._escapes, '$1') : title\n }, cap[0], this.lexer);\n }\n }\n\n reflink(src, links) {\n let cap;\n if ((cap = this.rules.inline.reflink.exec(src))\n || (cap = this.rules.inline.nolink.exec(src))) {\n let link = (cap[2] || cap[1]).replace(/\\s+/g, ' ');\n link = links[link.toLowerCase()];\n if (!link || !link.href) {\n const text = cap[0].charAt(0);\n return {\n type: 'text',\n raw: text,\n text\n };\n }\n return outputLink(cap, link, cap[0], this.lexer);\n }\n }\n\n emStrong(src, maskedSrc, prevChar = '') {\n let match = this.rules.inline.emStrong.lDelim.exec(src);\n if (!match) return;\n\n // _ can't be between two alphanumerics. \\p{L}\\p{N} includes non-english alphabet/numbers as well\n if (match[3] && prevChar.match(/[\\p{L}\\p{N}]/u)) return;\n\n const nextChar = match[1] || match[2] || '';\n\n if (!nextChar || (nextChar && (prevChar === '' || this.rules.inline.punctuation.exec(prevChar)))) {\n const lLength = match[0].length - 1;\n let rDelim, rLength, delimTotal = lLength, midDelimTotal = 0;\n\n const endReg = match[0][0] === '*' ? this.rules.inline.emStrong.rDelimAst : this.rules.inline.emStrong.rDelimUnd;\n endReg.lastIndex = 0;\n\n // Clip maskedSrc to same section of string as src (move to lexer?)\n maskedSrc = maskedSrc.slice(-1 * src.length + lLength);\n\n while ((match = endReg.exec(maskedSrc)) != null) {\n rDelim = match[1] || match[2] || match[3] || match[4] || match[5] || match[6];\n\n if (!rDelim) continue; // skip single * in __abc*abc__\n\n rLength = rDelim.length;\n\n if (match[3] || match[4]) { // found another Left Delim\n delimTotal += rLength;\n continue;\n } else if (match[5] || match[6]) { // either Left or Right Delim\n if (lLength % 3 && !((lLength + rLength) % 3)) {\n midDelimTotal += rLength;\n continue; // CommonMark Emphasis Rules 9-10\n }\n }\n\n delimTotal -= rLength;\n\n if (delimTotal > 0) continue; // Haven't found enough closing delimiters\n\n // Remove extra characters. *a*** -> *a*\n rLength = Math.min(rLength, rLength + delimTotal + midDelimTotal);\n\n // Create `em` if smallest delimiter has odd char count. *a***\n if (Math.min(lLength, rLength) % 2) {\n const text = src.slice(1, lLength + match.index + rLength);\n return {\n type: 'em',\n raw: src.slice(0, lLength + match.index + rLength + 1),\n text,\n tokens: this.lexer.inlineTokens(text, [])\n };\n }\n\n // Create 'strong' if smallest delimiter has even char count. **a***\n const text = src.slice(2, lLength + match.index + rLength - 1);\n return {\n type: 'strong',\n raw: src.slice(0, lLength + match.index + rLength + 1),\n text,\n tokens: this.lexer.inlineTokens(text, [])\n };\n }\n }\n }\n\n codespan(src) {\n const cap = this.rules.inline.code.exec(src);\n if (cap) {\n let text = cap[2].replace(/\\n/g, ' ');\n const hasNonSpaceChars = /[^ ]/.test(text);\n const hasSpaceCharsOnBothEnds = /^ /.test(text) && / $/.test(text);\n if (hasNonSpaceChars && hasSpaceCharsOnBothEnds) {\n text = text.substring(1, text.length - 1);\n }\n text = escape(text, true);\n return {\n type: 'codespan',\n raw: cap[0],\n text\n };\n }\n }\n\n br(src) {\n const cap = this.rules.inline.br.exec(src);\n if (cap) {\n return {\n type: 'br',\n raw: cap[0]\n };\n }\n }\n\n del(src) {\n const cap = this.rules.inline.del.exec(src);\n if (cap) {\n return {\n type: 'del',\n raw: cap[0],\n text: cap[2],\n tokens: this.lexer.inlineTokens(cap[2], [])\n };\n }\n }\n\n autolink(src, mangle) {\n const cap = this.rules.inline.autolink.exec(src);\n if (cap) {\n let text, href;\n if (cap[2] === '@') {\n text = escape(this.options.mangle ? mangle(cap[1]) : cap[1]);\n href = 'mailto:' + text;\n } else {\n text = escape(cap[1]);\n href = text;\n }\n\n return {\n type: 'link',\n raw: cap[0],\n text,\n href,\n tokens: [\n {\n type: 'text',\n raw: text,\n text\n }\n ]\n };\n }\n }\n\n url(src, mangle) {\n let cap;\n if (cap = this.rules.inline.url.exec(src)) {\n let text, href;\n if (cap[2] === '@') {\n text = escape(this.options.mangle ? mangle(cap[0]) : cap[0]);\n href = 'mailto:' + text;\n } else {\n // do extended autolink path validation\n let prevCapZero;\n do {\n prevCapZero = cap[0];\n cap[0] = this.rules.inline._backpedal.exec(cap[0])[0];\n } while (prevCapZero !== cap[0]);\n text = escape(cap[0]);\n if (cap[1] === 'www.') {\n href = 'http://' + text;\n } else {\n href = text;\n }\n }\n return {\n type: 'link',\n raw: cap[0],\n text,\n href,\n tokens: [\n {\n type: 'text',\n raw: text,\n text\n }\n ]\n };\n }\n }\n\n inlineText(src, smartypants) {\n const cap = this.rules.inline.text.exec(src);\n if (cap) {\n let text;\n if (this.lexer.state.inRawBlock) {\n text = this.options.sanitize ? (this.options.sanitizer ? this.options.sanitizer(cap[0]) : escape(cap[0])) : cap[0];\n } else {\n text = escape(this.options.smartypants ? smartypants(cap[0]) : cap[0]);\n }\n return {\n type: 'text',\n raw: cap[0],\n text\n };\n }\n }\n}\n\n/**\n * Block-Level Grammar\n */\nconst block = {\n newline: /^(?: *(?:\\n|$))+/,\n code: /^( {4}[^\\n]+(?:\\n(?: *(?:\\n|$))*)?)+/,\n fences: /^ {0,3}(`{3,}(?=[^`\\n]*\\n)|~{3,})([^\\n]*)\\n(?:|([\\s\\S]*?)\\n)(?: {0,3}\\1[~`]* *(?=\\n|$)|$)/,\n hr: /^ {0,3}((?:-[\\t ]*){3,}|(?:_[ \\t]*){3,}|(?:\\*[ \\t]*){3,})(?:\\n+|$)/,\n heading: /^ {0,3}(#{1,6})(?=\\s|$)(.*)(?:\\n+|$)/,\n blockquote: /^( {0,3}> ?(paragraph|[^\\n]*)(?:\\n|$))+/,\n list: /^( {0,3}bull)([ \\t][^\\n]+?)?(?:\\n|$)/,\n html: '^ {0,3}(?:' // optional indentation\n + '<(script|pre|style|textarea)[\\\\s>][\\\\s\\\\S]*?(?:</\\\\1>[^\\\\n]*\\\\n+|$)' // (1)\n + '|comment[^\\\\n]*(\\\\n+|$)' // (2)\n + '|<\\\\?[\\\\s\\\\S]*?(?:\\\\?>\\\\n*|$)' // (3)\n + '|<![A-Z][\\\\s\\\\S]*?(?:>\\\\n*|$)' // (4)\n + '|<!\\\\[CDATA\\\\[[\\\\s\\\\S]*?(?:\\\\]\\\\]>\\\\n*|$)' // (5)\n + '|</?(tag)(?: +|\\\\n|/?>)[\\\\s\\\\S]*?(?:(?:\\\\n *)+\\\\n|$)' // (6)\n + '|<(?!script|pre|style|textarea)([a-z][\\\\w-]*)(?:attribute)*? */?>(?=[ \\\\t]*(?:\\\\n|$))[\\\\s\\\\S]*?(?:(?:\\\\n *)+\\\\n|$)' // (7) open tag\n + '|</(?!script|pre|style|textarea)[a-z][\\\\w-]*\\\\s*>(?=[ \\\\t]*(?:\\\\n|$))[\\\\s\\\\S]*?(?:(?:\\\\n *)+\\\\n|$)' // (7) closing tag\n + ')',\n def: /^ {0,3}\\[(label)\\]: *(?:\\n *)?<?([^\\s>]+)>?(?:(?: +(?:\\n *)?| *\\n *)(title))? *(?:\\n+|$)/,\n table: noopTest,\n lheading: /^([^\\n]+)\\n {0,3}(=+|-+) *(?:\\n+|$)/,\n // regex template, placeholders will be replaced according to different paragraph\n // interruption rules of commonmark and the original markdown spec:\n _paragraph: /^([^\\n]+(?:\\n(?!hr|heading|lheading|blockquote|fences|list|html|table| +\\n)[^\\n]+)*)/,\n text: /^[^\\n]+/\n};\n\nblock._label = /(?!\\s*\\])(?:\\\\.|[^\\[\\]\\\\])+/;\nblock._title = /(?:\"(?:\\\\\"?|[^\"\\\\])*\"|'[^'\\n]*(?:\\n[^'\\n]+)*\\n?'|\\([^()]*\\))/;\nblock.def = edit(block.def)\n .replace('label', block._label)\n .replace('title', block._title)\n .getRegex();\n\nblock.bullet = /(?:[*+-]|\\d{1,9}[.)])/;\nblock.listItemStart = edit(/^( *)(bull) */)\n .replace('bull', block.bullet)\n .getRegex();\n\nblock.list = edit(block.list)\n .replace(/bull/g, block.bullet)\n .replace('hr', '\\\\n+(?=\\\\1?(?:(?:- *){3,}|(?:_ *){3,}|(?:\\\\* *){3,})(?:\\\\n+|$))')\n .replace('def', '\\\\n+(?=' + block.def.source + ')')\n .getRegex();\n\nblock._tag = 'address|article|aside|base|basefont|blockquote|body|caption'\n + '|center|col|colgroup|dd|details|dialog|dir|div|dl|dt|fieldset|figcaption'\n + '|figure|footer|form|frame|frameset|h[1-6]|head|header|hr|html|iframe'\n + '|legend|li|link|main|menu|menuitem|meta|nav|noframes|ol|optgroup|option'\n + '|p|param|section|source|summary|table|tbody|td|tfoot|th|thead|title|tr'\n + '|track|ul';\nblock._comment = /<!--(?!-?>)[\\s\\S]*?(?:-->|$)/;\nblock.html = edit(block.html, 'i')\n .replace('comment', block._comment)\n .replace('tag', block._tag)\n .replace('attribute', / +[a-zA-Z:_][\\w.:-]*(?: *= *\"[^\"\\n]*\"| *= *'[^'\\n]*'| *= *[^\\s\"'=<>`]+)?/)\n .getRegex();\n\nblock.paragraph = edit(block._paragraph)\n .replace('hr', block.hr)\n .replace('heading', ' {0,3}#{1,6} ')\n .replace('|lheading', '') // setex headings don't interrupt commonmark paragraphs\n .replace('|table', '')\n .replace('blockquote', ' {0,3}>')\n .replace('fences', ' {0,3}(?:`{3,}(?=[^`\\\\n]*\\\\n)|~{3,})[^\\\\n]*\\\\n')\n .replace('list', ' {0,3}(?:[*+-]|1[.)]) ') // only lists starting from 1 can interrupt\n .replace('html', '</?(?:tag)(?: +|\\\\n|/?>)|<(?:script|pre|style|textarea|!--)')\n .replace('tag', block._tag) // pars can be interrupted by type (6) html blocks\n .getRegex();\n\nblock.blockquote = edit(block.blockquote)\n .replace('paragraph', block.paragraph)\n .getRegex();\n\n/**\n * Normal Block Grammar\n */\n\nblock.normal = merge({}, block);\n\n/**\n * GFM Block Grammar\n */\n\nblock.gfm = merge({}, block.normal, {\n table: '^ *([^\\\\n ].*\\\\|.*)\\\\n' // Header\n + ' {0,3}(?:\\\\| *)?(:?-+:? *(?:\\\\| *:?-+:? *)*)(?:\\\\| *)?' // Align\n + '(?:\\\\n((?:(?! *\\\\n|hr|heading|blockquote|code|fences|list|html).*(?:\\\\n|$))*)\\\\n*|$)' // Cells\n});\n\nblock.gfm.table = edit(block.gfm.table)\n .replace('hr', block.hr)\n .replace('heading', ' {0,3}#{1,6} ')\n .replace('blockquote', ' {0,3}>')\n .replace('code', ' {4}[^\\\\n]')\n .replace('fences', ' {0,3}(?:`{3,}(?=[^`\\\\n]*\\\\n)|~{3,})[^\\\\n]*\\\\n')\n .replace('list', ' {0,3}(?:[*+-]|1[.)]) ') // only lists starting from 1 can interrupt\n .replace('html', '</?(?:tag)(?: +|\\\\n|/?>)|<(?:script|pre|style|textarea|!--)')\n .replace('tag', block._tag) // tables can be interrupted by type (6) html blocks\n .getRegex();\n\nblock.gfm.paragraph = edit(block._paragraph)\n .replace('hr', block.hr)\n .replace('heading', ' {0,3}#{1,6} ')\n .replace('|lheading', '') // setex headings don't interrupt commonmark paragraphs\n .replace('table', block.gfm.table) // interrupt paragraphs with table\n .replace('blockquote', ' {0,3}>')\n .replace('fences', ' {0,3}(?:`{3,}(?=[^`\\\\n]*\\\\n)|~{3,})[^\\\\n]*\\\\n')\n .replace('list', ' {0,3}(?:[*+-]|1[.)]) ') // only lists starting from 1 can interrupt\n .replace('html', '</?(?:tag)(?: +|\\\\n|/?>)|<(?:script|pre|style|textarea|!--)')\n .replace('tag', block._tag) // pars can be interrupted by type (6) html blocks\n .getRegex();\n/**\n * Pedantic grammar (original John Gruber's loose markdown specification)\n */\n\nblock.pedantic = merge({}, block.normal, {\n html: edit(\n '^ *(?:comment *(?:\\\\n|\\\\s*$)'\n + '|<(tag)[\\\\s\\\\S]+?</\\\\1> *(?:\\\\n{2,}|\\\\s*$)' // closed tag\n + '|<tag(?:\"[^\"]*\"|\\'[^\\']*\\'|\\\\s[^\\'\"/>\\\\s]*)*?/?> *(?:\\\\n{2,}|\\\\s*$))')\n .replace('comment', block._comment)\n .replace(/tag/g, '(?!(?:'\n + 'a|em|strong|small|s|cite|q|dfn|abbr|data|time|code|var|samp|kbd|sub'\n + '|sup|i|b|u|mark|ruby|rt|rp|bdi|bdo|span|br|wbr|ins|del|img)'\n + '\\\\b)\\\\w+(?!:|[^\\\\w\\\\s@]*@)\\\\b')\n .getRegex(),\n def: /^ *\\[([^\\]]+)\\]: *<?([^\\s>]+)>?(?: +([\"(][^\\n]+[\")]))? *(?:\\n+|$)/,\n heading: /^(#{1,6})(.*)(?:\\n+|$)/,\n fences: noopTest, // fences not supported\n paragraph: edit(block.normal._paragraph)\n .replace('hr', block.hr)\n .replace('heading', ' *#{1,6} *[^\\n]')\n .replace('lheading', block.lheading)\n .replace('blockquote', ' {0,3}>')\n .replace('|fences', '')\n .replace('|list', '')\n .replace('|html', '')\n .getRegex()\n});\n\n/**\n * Inline-Level Grammar\n */\nconst inline = {\n escape: /^\\\\([!\"#$%&'()*+,\\-./:;<=>?@\\[\\]\\\\^_`{|}~])/,\n autolink: /^<(scheme:[^\\s\\x00-\\x1f<>]*|email)>/,\n url: noopTest,\n tag: '^comment'\n + '|^</[a-zA-Z][\\\\w:-]*\\\\s*>' // self-closing tag\n + '|^<[a-zA-Z][\\\\w-]*(?:attribute)*?\\\\s*/?>' // open tag\n + '|^<\\\\?[\\\\s\\\\S]*?\\\\?>' // processing instruction, e.g. <?php ?>\n + '|^<![a-zA-Z]+\\\\s[\\\\s\\\\S]*?>' // declaration, e.g. <!DOCTYPE html>\n + '|^<!\\\\[CDATA\\\\[[\\\\s\\\\S]*?\\\\]\\\\]>', // CDATA section\n link: /^!?\\[(label)\\]\\(\\s*(href)(?:\\s+(title))?\\s*\\)/,\n reflink: /^!?\\[(label)\\]\\[(ref)\\]/,\n nolink: /^!?\\[(ref)\\](?:\\[\\])?/,\n reflinkSearch: 'reflink|nolink(?!\\\\()',\n emStrong: {\n lDelim: /^(?:\\*+(?:([punct_])|[^\\s*]))|^_+(?:([punct*])|([^\\s_]))/,\n // (1) and (2) can only be a Right Delimiter. (3) and (4) can only be Left. (5) and (6) can be either Left or Right.\n // () Skip orphan inside strong () Consume to delim (1) #*** (2) a***#, a*** (3) #***a, ***a (4) ***# (5) #***# (6) a***a\n rDelimAst: /^[^_*]*?\\_\\_[^_*]*?\\*[^_*]*?(?=\\_\\_)|[^*]+(?=[^*])|[punct_](\\*+)(?=[\\s]|$)|[^punct*_\\s](\\*+)(?=[punct_\\s]|$)|[punct_\\s](\\*+)(?=[^punct*_\\s])|[\\s](\\*+)(?=[punct_])|[punct_](\\*+)(?=[punct_])|[^punct*_\\s](\\*+)(?=[^punct*_\\s])/,\n rDelimUnd: /^[^_*]*?\\*\\*[^_*]*?\\_[^_*]*?(?=\\*\\*)|[^_]+(?=[^_])|[punct*](\\_+)(?=[\\s]|$)|[^punct*_\\s](\\_+)(?=[punct*\\s]|$)|[punct*\\s](\\_+)(?=[^punct*_\\s])|[\\s](\\_+)(?=[punct*])|[punct*](\\_+)(?=[punct*])/ // ^- Not allowed for _\n },\n code: /^(`+)([^`]|[^`][\\s\\S]*?[^`])\\1(?!`)/,\n br: /^( {2,}|\\\\)\\n(?!\\s*$)/,\n del: noopTest,\n text: /^(`+|[^`])(?:(?= {2,}\\n)|[\\s\\S]*?(?:(?=[\\\\<!\\[`*_]|\\b_|$)|[^ ](?= {2,}\\n)))/,\n punctuation: /^([\\spunctuation])/\n};\n\n// list of punctuation marks from CommonMark spec\n// without * and _ to handle the different emphasis markers * and _\ninline._punctuation = '!\"#$%&\\'()+\\\\-.,/:;<=>?@\\\\[\\\\]`^{|}~';\ninline.punctuation = edit(inline.punctuation).replace(/punctuation/g, inline._punctuation).getRegex();\n\n// sequences em should skip over [title](link), `code`, <html>\ninline.blockSkip = /\\[[^\\]]*?\\]\\([^\\)]*?\\)|`[^`]*?`|<[^>]*?>/g;\ninline.escapedEmSt = /\\\\\\*|\\\\_/g;\n\ninline._comment = edit(block._comment).replace('(?:-->|$)', '-->').getRegex();\n\ninline.emStrong.lDelim = edit(inline.emStrong.lDelim)\n .replace(/punct/g, inline._punctuation)\n .getRegex();\n\ninline.emStrong.rDelimAst = edit(inline.emStrong.rDelimAst, 'g')\n .replace(/punct/g, inline._punctuation)\n .getRegex();\n\ninline.emStrong.rDelimUnd = edit(inline.emStrong.rDelimUnd, 'g')\n .replace(/punct/g, inline._punctuation)\n .getRegex();\n\ninline._escapes = /\\\\([!\"#$%&'()*+,\\-./:;<=>?@\\[\\]\\\\^_`{|}~])/g;\n\ninline._scheme = /[a-zA-Z][a-zA-Z0-9+.-]{1,31}/;\ninline._email = /[a-zA-Z0-9.!#$%&'*+/=?^_`{|}~-]+(@)[a-zA-Z0-9](?:[a-zA-Z0-9-]{0,61}[a-zA-Z0-9])?(?:\\.[a-zA-Z0-9](?:[a-zA-Z0-9-]{0,61}[a-zA-Z0-9])?)+(?![-_])/;\ninline.autolink = edit(inline.autolink)\n .replace('scheme', inline._scheme)\n .replace('email', inline._email)\n .getRegex();\n\ninline._attribute = /\\s+[a-zA-Z:_][\\w.:-]*(?:\\s*=\\s*\"[^\"]*\"|\\s*=\\s*'[^']*'|\\s*=\\s*[^\\s\"'=<>`]+)?/;\n\ninline.tag = edit(inline.tag)\n .replace('comment', inline._comment)\n .replace('attribute', inline._attribute)\n .getRegex();\n\ninline._label = /(?:\\[(?:\\\\.|[^\\[\\]\\\\])*\\]|\\\\.|`[^`]*`|[^\\[\\]\\\\`])*?/;\ninline._href = /<(?:\\\\.|[^\\n<>\\\\])+>|[^\\s\\x00-\\x1f]*/;\ninline._title = /\"(?:\\\\\"?|[^\"\\\\])*\"|'(?:\\\\'?|[^'\\\\])*'|\\((?:\\\\\\)?|[^)\\\\])*\\)/;\n\ninline.link = edit(inline.link)\n .replace('label', inline._label)\n .replace('href', inline._href)\n .replace('title', inline._title)\n .getRegex();\n\ninline.reflink = edit(inline.reflink)\n .replace('label', inline._label)\n .replace('ref', block._label)\n .getRegex();\n\ninline.nolink = edit(inline.nolink)\n .replace('ref', block._label)\n .getRegex();\n\ninline.reflinkSearch = edit(inline.reflinkSearch, 'g')\n .replace('reflink', inline.reflink)\n .replace('nolink', inline.nolink)\n .getRegex();\n\n/**\n * Normal Inline Grammar\n */\n\ninline.normal = merge({}, inline);\n\n/**\n * Pedantic Inline Grammar\n */\n\ninline.pedantic = merge({}, inline.normal, {\n strong: {\n start: /^__|\\*\\*/,\n middle: /^__(?=\\S)([\\s\\S]*?\\S)__(?!_)|^\\*\\*(?=\\S)([\\s\\S]*?\\S)\\*\\*(?!\\*)/,\n endAst: /\\*\\*(?!\\*)/g,\n endUnd: /__(?!_)/g\n },\n em: {\n start: /^_|\\*/,\n middle: /^()\\*(?=\\S)([\\s\\S]*?\\S)\\*(?!\\*)|^_(?=\\S)([\\s\\S]*?\\S)_(?!_)/,\n endAst: /\\*(?!\\*)/g,\n endUnd: /_(?!_)/g\n },\n link: edit(/^!?\\[(label)\\]\\((.*?)\\)/)\n .replace('label', inline._label)\n .getRegex(),\n reflink: edit(/^!?\\[(label)\\]\\s*\\[([^\\]]*)\\]/)\n .replace('label', inline._label)\n .getRegex()\n});\n\n/**\n * GFM Inline Grammar\n */\n\ninline.gfm = merge({}, inline.normal, {\n escape: edit(inline.escape).replace('])', '~|])').getRegex(),\n _extended_email: /[A-Za-z0-9._+-]+(@)[a-zA-Z0-9-_]+(?:\\.[a-zA-Z0-9-_]*[a-zA-Z0-9])+(?![-_])/,\n url: /^((?:ftp|https?):\\/\\/|www\\.)(?:[a-zA-Z0-9\\-]+\\.?)+[^\\s<]*|^email/,\n _backpedal: /(?:[^?!.,:;*_~()&]+|\\([^)]*\\)|&(?![a-zA-Z0-9]+;$)|[?!.,:;*_~)]+(?!$))+/,\n del: /^(~~?)(?=[^\\s~])([\\s\\S]*?[^\\s~])\\1(?=[^~]|$)/,\n text: /^([`~]+|[^`~])(?:(?= {2,}\\n)|(?=[a-zA-Z0-9.!#$%&'*+\\/=?_`{\\|}~-]+@)|[\\s\\S]*?(?:(?=[\\\\<!\\[`*~_]|\\b_|https?:\\/\\/|ftp:\\/\\/|www\\.|$)|[^ ](?= {2,}\\n)|[^a-zA-Z0-9.!#$%&'*+\\/=?_`{\\|}~-](?=[a-zA-Z0-9.!#$%&'*+\\/=?_`{\\|}~-]+@)))/\n});\n\ninline.gfm.url = edit(inline.gfm.url, 'i')\n .replace('email', inline.gfm._extended_email)\n .getRegex();\n/**\n * GFM + Line Breaks Inline Grammar\n */\n\ninline.breaks = merge({}, inline.gfm, {\n br: edit(inline.br).replace('{2,}', '*').getRegex(),\n text: edit(inline.gfm.text)\n .replace('\\\\b_', '\\\\b_| {2,}\\\\n')\n .replace(/\\{2,\\}/g, '*')\n .getRegex()\n});\n\n/**\n * smartypants text replacement\n * @param {string} text\n */\nfunction smartypants(text) {\n return text\n // em-dashes\n .replace(/---/g, '\\u2014')\n // en-dashes\n .replace(/--/g, '\\u2013')\n // opening singles\n .replace(/(^|[-\\u2014/(\\[{\"\\s])'/g, '$1\\u2018')\n // closing singles & apostrophes\n .replace(/'/g, '\\u2019')\n // opening doubles\n .replace(/(^|[-\\u2014/(\\[{\\u2018\\s])\"/g, '$1\\u201c')\n // closing doubles\n .replace(/\"/g, '\\u201d')\n // ellipses\n .replace(/\\.{3}/g, '\\u2026');\n}\n\n/**\n * mangle email addresses\n * @param {string} text\n */\nfunction mangle(text) {\n let out = '',\n i,\n ch;\n\n const l = text.length;\n for (i = 0; i < l; i++) {\n ch = text.charCodeAt(i);\n if (Math.random() > 0.5) {\n ch = 'x' + ch.toString(16);\n }\n out += '&#' + ch + ';';\n }\n\n return out;\n}\n\n/**\n * Block Lexer\n */\nclass Lexer {\n constructor(options) {\n this.tokens = [];\n this.tokens.links = Object.create(null);\n this.options = options || defaults;\n this.options.tokenizer = this.options.tokenizer || new Tokenizer();\n this.tokenizer = this.options.tokenizer;\n this.tokenizer.options = this.options;\n this.tokenizer.lexer = this;\n this.inlineQueue = [];\n this.state = {\n inLink: false,\n inRawBlock: false,\n top: true\n };\n\n const rules = {\n block: block.normal,\n inline: inline.normal\n };\n\n if (this.options.pedantic) {\n rules.block = block.pedantic;\n rules.inline = inline.pedantic;\n } else if (this.options.gfm) {\n rules.block = block.gfm;\n if (this.options.breaks) {\n rules.inline = inline.breaks;\n } else {\n rules.inline = inline.gfm;\n }\n }\n this.tokenizer.rules = rules;\n }\n\n /**\n * Expose Rules\n */\n static get rules() {\n return {\n block,\n inline\n };\n }\n\n /**\n * Static Lex Method\n */\n static lex(src, options) {\n const lexer = new Lexer(options);\n return lexer.lex(src);\n }\n\n /**\n * Static Lex Inline Method\n */\n static lexInline(src, options) {\n const lexer = new Lexer(options);\n return lexer.inlineTokens(src);\n }\n\n /**\n * Preprocessing\n */\n lex(src) {\n src = src\n .replace(/\\r\\n|\\r/g, '\\n');\n\n this.blockTokens(src, this.tokens);\n\n let next;\n while (next = this.inlineQueue.shift()) {\n this.inlineTokens(next.src, next.tokens);\n }\n\n return this.tokens;\n }\n\n /**\n * Lexing\n */\n blockTokens(src, tokens = []) {\n if (this.options.pedantic) {\n src = src.replace(/\\t/g, ' ').replace(/^ +$/gm, '');\n } else {\n src = src.replace(/^( *)(\\t+)/gm, (_, leading, tabs) => {\n return leading + ' '.repeat(tabs.length);\n });\n }\n\n let token, lastToken, cutSrc, lastParagraphClipped;\n\n while (src) {\n if (this.options.extensions\n && this.options.extensions.block\n && this.options.extensions.block.some((extTokenizer) => {\n if (token = extTokenizer.call({ lexer: this }, src, tokens)) {\n src = src.substring(token.raw.length);\n tokens.push(token);\n return true;\n }\n return false;\n })) {\n continue;\n }\n\n // newline\n if (token = this.tokenizer.space(src)) {\n src = src.substring(token.raw.length);\n if (token.raw.length === 1 && tokens.length > 0) {\n // if there's a single \\n as a spacer, it's terminating the last line,\n // so move it there so that we don't get unecessary paragraph tags\n tokens[tokens.length - 1].raw += '\\n';\n } else {\n tokens.push(token);\n }\n continue;\n }\n\n // code\n if (token = this.tokenizer.code(src)) {\n src = src.substring(token.raw.length);\n lastToken = tokens[tokens.length - 1];\n // An indented code block cannot interrupt a paragraph.\n if (lastToken && (lastToken.type === 'paragraph' || lastToken.type === 'text')) {\n lastToken.raw += '\\n' + token.raw;\n lastToken.text += '\\n' + token.text;\n this.inlineQueue[this.inlineQueue.length - 1].src = lastToken.text;\n } else {\n tokens.push(token);\n }\n continue;\n }\n\n // fences\n if (token = this.tokenizer.fences(src)) {\n src = src.substring(token.raw.length);\n tokens.push(token);\n continue;\n }\n\n // heading\n if (token = this.tokenizer.heading(src)) {\n src = src.substring(token.raw.length);\n tokens.push(token);\n continue;\n }\n\n // hr\n if (token = this.tokenizer.hr(src)) {\n src = src.substring(token.raw.length);\n tokens.push(token);\n continue;\n }\n\n // blockquote\n if (token = this.tokenizer.blockquote(src)) {\n src = src.substring(token.raw.length);\n tokens.push(token);\n continue;\n }\n\n // list\n if (token = this.tokenizer.list(src)) {\n src = src.substring(token.raw.length);\n tokens.push(token);\n continue;\n }\n\n // html\n if (token = this.tokenizer.html(src)) {\n src = src.substring(token.raw.length);\n tokens.push(token);\n continue;\n }\n\n // def\n if (token = this.tokenizer.def(src)) {\n src = src.substring(token.raw.length);\n lastToken = tokens[tokens.length - 1];\n if (lastToken && (lastToken.type === 'paragraph' || lastToken.type === 'text')) {\n lastToken.raw += '\\n' + token.raw;\n lastToken.text += '\\n' + token.raw;\n this.inlineQueue[this.inlineQueue.length - 1].src = lastToken.text;\n } else if (!this.tokens.links[token.tag]) {\n this.tokens.links[token.tag] = {\n href: token.href,\n title: token.title\n };\n }\n continue;\n }\n\n // table (gfm)\n if (token = this.tokenizer.table(src)) {\n src = src.substring(token.raw.length);\n tokens.push(token);\n continue;\n }\n\n // lheading\n if (token = this.tokenizer.lheading(src)) {\n src = src.substring(token.raw.length);\n tokens.push(token);\n continue;\n }\n\n // top-level paragraph\n // prevent paragraph consuming extensions by clipping 'src' to extension start\n cutSrc = src;\n if (this.options.extensions && this.options.extensions.startBlock) {\n let startIndex = Infinity;\n const tempSrc = src.slice(1);\n let tempStart;\n this.options.extensions.startBlock.forEach(function(getStartIndex) {\n tempStart = getStartIndex.call({ lexer: this }, tempSrc);\n if (typeof tempStart === 'number' && tempStart >= 0) { startIndex = Math.min(startIndex, tempStart); }\n });\n if (startIndex < Infinity && startIndex >= 0) {\n cutSrc = src.substring(0, startIndex + 1);\n }\n }\n if (this.state.top && (token = this.tokenizer.paragraph(cutSrc))) {\n lastToken = tokens[tokens.length - 1];\n if (lastParagraphClipped && lastToken.type === 'paragraph') {\n lastToken.raw += '\\n' + token.raw;\n lastToken.text += '\\n' + token.text;\n this.inlineQueue.pop();\n this.inlineQueue[this.inlineQueue.length - 1].src = lastToken.text;\n } else {\n tokens.push(token);\n }\n lastParagraphClipped = (cutSrc.length !== src.length);\n src = src.substring(token.raw.length);\n continue;\n }\n\n // text\n if (token = this.tokenizer.text(src)) {\n src = src.substring(token.raw.length);\n lastToken = tokens[tokens.length - 1];\n if (lastToken && lastToken.type === 'text') {\n lastToken.raw += '\\n' + token.raw;\n lastToken.text += '\\n' + token.text;\n this.inlineQueue.pop();\n this.inlineQueue[this.inlineQueue.length - 1].src = lastToken.text;\n } else {\n tokens.push(token);\n }\n continue;\n }\n\n if (src) {\n const errMsg = 'Infinite loop on byte: ' + src.charCodeAt(0);\n if (this.options.silent) {\n console.error(errMsg);\n break;\n } else {\n throw new Error(errMsg);\n }\n }\n }\n\n this.state.top = true;\n return tokens;\n }\n\n inline(src, tokens) {\n this.inlineQueue.push({ src, tokens });\n }\n\n /**\n * Lexing/Compiling\n */\n inlineTokens(src, tokens = []) {\n let token, lastToken, cutSrc;\n\n // String with links masked to avoid interference with em and strong\n let maskedSrc = src;\n let match;\n let keepPrevChar, prevChar;\n\n // Mask out reflinks\n if (this.tokens.links) {\n const links = Object.keys(this.tokens.links);\n if (links.length > 0) {\n while ((match = this.tokenizer.rules.inline.reflinkSearch.exec(maskedSrc)) != null) {\n if (links.includes(match[0].slice(match[0].lastIndexOf('[') + 1, -1))) {\n maskedSrc = maskedSrc.slice(0, match.index) + '[' + repeatString('a', match[0].length - 2) + ']' + maskedSrc.slice(this.tokenizer.rules.inline.reflinkSearch.lastIndex);\n }\n }\n }\n }\n // Mask out other blocks\n while ((match = this.tokenizer.rules.inline.blockSkip.exec(maskedSrc)) != null) {\n maskedSrc = maskedSrc.slice(0, match.index) + '[' + repeatString('a', match[0].length - 2) + ']' + maskedSrc.slice(this.tokenizer.rules.inline.blockSkip.lastIndex);\n }\n\n // Mask out escaped em & strong delimiters\n while ((match = this.tokenizer.rules.inline.escapedEmSt.exec(maskedSrc)) != null) {\n maskedSrc = maskedSrc.slice(0, match.index) + '++' + maskedSrc.slice(this.tokenizer.rules.inline.escapedEmSt.lastIndex);\n }\n\n while (src) {\n if (!keepPrevChar) {\n prevChar = '';\n }\n keepPrevChar = false;\n\n // extensions\n if (this.options.extensions\n && this.options.extensions.inline\n && this.options.extensions.inline.some((extTokenizer) => {\n if (token = extTokenizer.call({ lexer: this }, src, tokens)) {\n src = src.substring(token.raw.length);\n tokens.push(token);\n return true;\n }\n return false;\n })) {\n continue;\n }\n\n // escape\n if (token = this.tokenizer.escape(src)) {\n src = src.substring(token.raw.length);\n tokens.push(token);\n continue;\n }\n\n // tag\n if (token = this.tokenizer.tag(src)) {\n src = src.substring(token.raw.length);\n lastToken = tokens[tokens.length - 1];\n if (lastToken && token.type === 'text' && lastToken.type === 'text') {\n lastToken.raw += token.raw;\n lastToken.text += token.text;\n } else {\n tokens.push(token);\n }\n continue;\n }\n\n // link\n if (token = this.tokenizer.link(src)) {\n src = src.substring(token.raw.length);\n tokens.push(token);\n continue;\n }\n\n // reflink, nolink\n if (token = this.tokenizer.reflink(src, this.tokens.links)) {\n src = src.substring(token.raw.length);\n lastToken = tokens[tokens.length - 1];\n if (lastToken && token.type === 'text' && lastToken.type === 'text') {\n lastToken.raw += token.raw;\n lastToken.text += token.text;\n } else {\n tokens.push(token);\n }\n continue;\n }\n\n // em & strong\n if (token = this.tokenizer.emStrong(src, maskedSrc, prevChar)) {\n src = src.substring(token.raw.length);\n tokens.push(token);\n continue;\n }\n\n // code\n if (token = this.tokenizer.codespan(src)) {\n src = src.substring(token.raw.length);\n tokens.push(token);\n continue;\n }\n\n // br\n if (token = this.tokenizer.br(src)) {\n src = src.substring(token.raw.length);\n tokens.push(token);\n continue;\n }\n\n // del (gfm)\n if (token = this.tokenizer.del(src)) {\n src = src.substring(token.raw.length);\n tokens.push(token);\n continue;\n }\n\n // autolink\n if (token = this.tokenizer.autolink(src, mangle)) {\n src = src.substring(token.raw.length);\n tokens.push(token);\n continue;\n }\n\n // url (gfm)\n if (!this.state.inLink && (token = this.tokenizer.url(src, mangle))) {\n src = src.substring(token.raw.length);\n tokens.push(token);\n continue;\n }\n\n // text\n // prevent inlineText consuming extensions by clipping 'src' to extension start\n cutSrc = src;\n if (this.options.extensions && this.options.extensions.startInline) {\n let startIndex = Infinity;\n const tempSrc = src.slice(1);\n let tempStart;\n this.options.extensions.startInline.forEach(function(getStartIndex) {\n tempStart = getStartIndex.call({ lexer: this }, tempSrc);\n if (typeof tempStart === 'number' && tempStart >= 0) { startIndex = Math.min(startIndex, tempStart); }\n });\n if (startIndex < Infinity && startIndex >= 0) {\n cutSrc = src.substring(0, startIndex + 1);\n }\n }\n if (token = this.tokenizer.inlineText(cutSrc, smartypants)) {\n src = src.substring(token.raw.length);\n if (token.raw.slice(-1) !== '_') { // Track prevChar before string of ____ started\n prevChar = token.raw.slice(-1);\n }\n keepPrevChar = true;\n lastToken = tokens[tokens.length - 1];\n if (lastToken && lastToken.type === 'text') {\n lastToken.raw += token.raw;\n lastToken.text += token.text;\n } else {\n tokens.push(token);\n }\n continue;\n }\n\n if (src) {\n const errMsg = 'Infinite loop on byte: ' + src.charCodeAt(0);\n if (this.options.silent) {\n console.error(errMsg);\n break;\n } else {\n throw new Error(errMsg);\n }\n }\n }\n\n return tokens;\n }\n}\n\n/**\n * Renderer\n */\nclass Renderer {\n constructor(options) {\n this.options = options || defaults;\n }\n\n code(code, infostring, escaped) {\n const lang = (infostring || '').match(/\\S*/)[0];\n if (this.options.highlight) {\n const out = this.options.highlight(code, lang);\n if (out != null && out !== code) {\n escaped = true;\n code = out;\n }\n }\n\n code = code.replace(/\\n$/, '') + '\\n';\n\n if (!lang) {\n return '<pre><code>'\n + (escaped ? code : escape(code, true))\n + '</code></pre>\\n';\n }\n\n return '<pre><code class=\"'\n + this.options.langPrefix\n + escape(lang, true)\n + '\">'\n + (escaped ? code : escape(code, true))\n + '</code></pre>\\n';\n }\n\n /**\n * @param {string} quote\n */\n blockquote(quote) {\n return `<blockquote>\\n${quote}</blockquote>\\n`;\n }\n\n html(html) {\n return html;\n }\n\n /**\n * @param {string} text\n * @param {string} level\n * @param {string} raw\n * @param {any} slugger\n */\n heading(text, level, raw, slugger) {\n if (this.options.headerIds) {\n const id = this.options.headerPrefix + slugger.slug(raw);\n return `<h${level} id=\"${id}\">${text}</h${level}>\\n`;\n }\n\n // ignore IDs\n return `<h${level}>${text}</h${level}>\\n`;\n }\n\n hr() {\n return this.options.xhtml ? '<hr/>\\n' : '<hr>\\n';\n }\n\n list(body, ordered, start) {\n const type = ordered ? 'ol' : 'ul',\n startatt = (ordered && start !== 1) ? (' start=\"' + start + '\"') : '';\n return '<' + type + startatt + '>\\n' + body + '</' + type + '>\\n';\n }\n\n /**\n * @param {string} text\n */\n listitem(text) {\n return `<li>${text}</li>\\n`;\n }\n\n checkbox(checked) {\n return '<input '\n + (checked ? 'checked=\"\" ' : '')\n + 'disabled=\"\" type=\"checkbox\"'\n + (this.options.xhtml ? ' /' : '')\n + '> ';\n }\n\n /**\n * @param {string} text\n */\n paragraph(text) {\n return `<p>${text}</p>\\n`;\n }\n\n /**\n * @param {string} header\n * @param {string} body\n */\n table(header, body) {\n if (body) body = `<tbody>${body}</tbody>`;\n\n return '<table>\\n'\n + '<thead>\\n'\n + header\n + '</thead>\\n'\n + body\n + '</table>\\n';\n }\n\n /**\n * @param {string} content\n */\n tablerow(content) {\n return `<tr>\\n${content}</tr>\\n`;\n }\n\n tablecell(content, flags) {\n const type = flags.header ? 'th' : 'td';\n const tag = flags.align\n ? `<${type} align=\"${flags.align}\">`\n : `<${type}>`;\n return tag + content + `</${type}>\\n`;\n }\n\n /**\n * span level renderer\n * @param {string} text\n */\n strong(text) {\n return `<strong>${text}</strong>`;\n }\n\n /**\n * @param {string} text\n */\n em(text) {\n return `<em>${text}</em>`;\n }\n\n /**\n * @param {string} text\n */\n codespan(text) {\n return `<code>${text}</code>`;\n }\n\n br() {\n return this.options.xhtml ? '<br/>' : '<br>';\n }\n\n /**\n * @param {string} text\n */\n del(text) {\n return `<del>${text}</del>`;\n }\n\n /**\n * @param {string} href\n * @param {string} title\n * @param {string} text\n */\n link(href, title, text) {\n href = cleanUrl(this.options.sanitize, this.options.baseUrl, href);\n if (href === null) {\n return text;\n }\n let out = '<a href=\"' + escape(href) + '\"';\n if (title) {\n out += ' title=\"' + title + '\"';\n }\n out += '>' + text + '</a>';\n return out;\n }\n\n /**\n * @param {string} href\n * @param {string} title\n * @param {string} text\n */\n image(href, title, text) {\n href = cleanUrl(this.options.sanitize, this.options.baseUrl, href);\n if (href === null) {\n return text;\n }\n\n let out = `<img src=\"${href}\" alt=\"${text}\"`;\n if (title) {\n out += ` title=\"${title}\"`;\n }\n out += this.options.xhtml ? '/>' : '>';\n return out;\n }\n\n text(text) {\n return text;\n }\n}\n\n/**\n * TextRenderer\n * returns only the textual part of the token\n */\nclass TextRenderer {\n // no need for block level renderers\n strong(text) {\n return text;\n }\n\n em(text) {\n return text;\n }\n\n codespan(text) {\n return text;\n }\n\n del(text) {\n return text;\n }\n\n html(text) {\n return text;\n }\n\n text(text) {\n return text;\n }\n\n link(href, title, text) {\n return '' + text;\n }\n\n image(href, title, text) {\n return '' + text;\n }\n\n br() {\n return '';\n }\n}\n\n/**\n * Slugger generates header id\n */\nclass Slugger {\n constructor() {\n this.seen = {};\n }\n\n /**\n * @param {string} value\n */\n serialize(value) {\n return value\n .toLowerCase()\n .trim()\n // remove html tags\n .replace(/<[!\\/a-z].*?>/ig, '')\n // remove unwanted chars\n .replace(/[\\u2000-\\u206F\\u2E00-\\u2E7F\\\\'!\"#$%&()*+,./:;<=>?@[\\]^`{|}~]/g, '')\n .replace(/\\s/g, '-');\n }\n\n /**\n * Finds the next safe (unique) slug to use\n * @param {string} originalSlug\n * @param {boolean} isDryRun\n */\n getNextSafeSlug(originalSlug, isDryRun) {\n let slug = originalSlug;\n let occurenceAccumulator = 0;\n if (this.seen.hasOwnProperty(slug)) {\n occurenceAccumulator = this.seen[originalSlug];\n do {\n occurenceAccumulator++;\n slug = originalSlug + '-' + occurenceAccumulator;\n } while (this.seen.hasOwnProperty(slug));\n }\n if (!isDryRun) {\n this.seen[originalSlug] = occurenceAccumulator;\n this.seen[slug] = 0;\n }\n return slug;\n }\n\n /**\n * Convert string to unique id\n * @param {object} [options]\n * @param {boolean} [options.dryrun] Generates the next unique slug without\n * updating the internal accumulator.\n */\n slug(value, options = {}) {\n const slug = this.serialize(value);\n return this.getNextSafeSlug(slug, options.dryrun);\n }\n}\n\n/**\n * Parsing & Compiling\n */\nclass Parser {\n constructor(options) {\n this.options = options || defaults;\n this.options.renderer = this.options.renderer || new Renderer();\n this.renderer = this.options.renderer;\n this.renderer.options = this.options;\n this.textRenderer = new TextRenderer();\n this.slugger = new Slugger();\n }\n\n /**\n * Static Parse Method\n */\n static parse(tokens, options) {\n const parser = new Parser(options);\n return parser.parse(tokens);\n }\n\n /**\n * Static Parse Inline Method\n */\n static parseInline(tokens, options) {\n const parser = new Parser(options);\n return parser.parseInline(tokens);\n }\n\n /**\n * Parse Loop\n */\n parse(tokens, top = true) {\n let out = '',\n i,\n j,\n k,\n l2,\n l3,\n row,\n cell,\n header,\n body,\n token,\n ordered,\n start,\n loose,\n itemBody,\n item,\n checked,\n task,\n checkbox,\n ret;\n\n const l = tokens.length;\n for (i = 0; i < l; i++) {\n token = tokens[i];\n\n // Run any renderer extensions\n if (this.options.extensions && this.options.extensions.renderers && this.options.extensions.renderers[token.type]) {\n ret = this.options.extensions.renderers[token.type].call({ parser: this }, token);\n if (ret !== false || !['space', 'hr', 'heading', 'code', 'table', 'blockquote', 'list', 'html', 'paragraph', 'text'].includes(token.type)) {\n out += ret || '';\n continue;\n }\n }\n\n switch (token.type) {\n case 'space': {\n continue;\n }\n case 'hr': {\n out += this.renderer.hr();\n continue;\n }\n case 'heading': {\n out += this.renderer.heading(\n this.parseInline(token.tokens),\n token.depth,\n unescape(this.parseInline(token.tokens, this.textRenderer)),\n this.slugger);\n continue;\n }\n case 'code': {\n out += this.renderer.code(token.text,\n token.lang,\n token.escaped);\n continue;\n }\n case 'table': {\n header = '';\n\n // header\n cell = '';\n l2 = token.header.length;\n for (j = 0; j < l2; j++) {\n cell += this.renderer.tablecell(\n this.parseInline(token.header[j].tokens),\n { header: true, align: token.align[j] }\n );\n }\n header += this.renderer.tablerow(cell);\n\n body = '';\n l2 = token.rows.length;\n for (j = 0; j < l2; j++) {\n row = token.rows[j];\n\n cell = '';\n l3 = row.length;\n for (k = 0; k < l3; k++) {\n cell += this.renderer.tablecell(\n this.parseInline(row[k].tokens),\n { header: false, align: token.align[k] }\n );\n }\n\n body += this.renderer.tablerow(cell);\n }\n out += this.renderer.table(header, body);\n continue;\n }\n case 'blockquote': {\n body = this.parse(token.tokens);\n out += this.renderer.blockquote(body);\n continue;\n }\n case 'list': {\n ordered = token.ordered;\n start = token.start;\n loose = token.loose;\n l2 = token.items.length;\n\n body = '';\n for (j = 0; j < l2; j++) {\n item = token.items[j];\n checked = item.checked;\n task = item.task;\n\n itemBody = '';\n if (item.task) {\n checkbox = this.renderer.checkbox(checked);\n if (loose) {\n if (item.tokens.length > 0 && item.tokens[0].type === 'paragraph') {\n item.tokens[0].text = checkbox + ' ' + item.tokens[0].text;\n if (item.tokens[0].tokens && item.tokens[0].tokens.length > 0 && item.tokens[0].tokens[0].type === 'text') {\n item.tokens[0].tokens[0].text = checkbox + ' ' + item.tokens[0].tokens[0].text;\n }\n } else {\n item.tokens.unshift({\n type: 'text',\n text: checkbox\n });\n }\n } else {\n itemBody += checkbox;\n }\n }\n\n itemBody += this.parse(item.tokens, loose);\n body += this.renderer.listitem(itemBody, task, checked);\n }\n\n out += this.renderer.list(body, ordered, start);\n continue;\n }\n case 'html': {\n // TODO parse inline content if parameter markdown=1\n out += this.renderer.html(token.text);\n continue;\n }\n case 'paragraph': {\n out += this.renderer.paragraph(this.parseInline(token.tokens));\n continue;\n }\n case 'text': {\n body = token.tokens ? this.parseInline(token.tokens) : token.text;\n while (i + 1 < l && tokens[i + 1].type === 'text') {\n token = tokens[++i];\n body += '\\n' + (token.tokens ? this.parseInline(token.tokens) : token.text);\n }\n out += top ? this.renderer.paragraph(body) : body;\n continue;\n }\n\n default: {\n const errMsg = 'Token with \"' + token.type + '\" type was not found.';\n if (this.options.silent) {\n console.error(errMsg);\n return;\n } else {\n throw new Error(errMsg);\n }\n }\n }\n }\n\n return out;\n }\n\n /**\n * Parse Inline Tokens\n */\n parseInline(tokens, renderer) {\n renderer = renderer || this.renderer;\n let out = '',\n i,\n token,\n ret;\n\n const l = tokens.length;\n for (i = 0; i < l; i++) {\n token = tokens[i];\n\n // Run any renderer extensions\n if (this.options.extensions && this.options.extensions.renderers && this.options.extensions.renderers[token.type]) {\n ret = this.options.extensions.renderers[token.type].call({ parser: this }, token);\n if (ret !== false || !['escape', 'html', 'link', 'image', 'strong', 'em', 'codespan', 'br', 'del', 'text'].includes(token.type)) {\n out += ret || '';\n continue;\n }\n }\n\n switch (token.type) {\n case 'escape': {\n out += renderer.text(token.text);\n break;\n }\n case 'html': {\n out += renderer.html(token.text);\n break;\n }\n case 'link': {\n out += renderer.link(token.href, token.title, this.parseInline(token.tokens, renderer));\n break;\n }\n case 'image': {\n out += renderer.image(token.href, token.title, token.text);\n break;\n }\n case 'strong': {\n out += renderer.strong(this.parseInline(token.tokens, renderer));\n break;\n }\n case 'em': {\n out += renderer.em(this.parseInline(token.tokens, renderer));\n break;\n }\n case 'codespan': {\n out += renderer.codespan(token.text);\n break;\n }\n case 'br': {\n out += renderer.br();\n break;\n }\n case 'del': {\n out += renderer.del(this.parseInline(token.tokens, renderer));\n break;\n }\n case 'text': {\n out += renderer.text(token.text);\n break;\n }\n default: {\n const errMsg = 'Token with \"' + token.type + '\" type was not found.';\n if (this.options.silent) {\n console.error(errMsg);\n return;\n } else {\n throw new Error(errMsg);\n }\n }\n }\n }\n return out;\n }\n}\n\n/**\n * Marked\n */\nfunction marked(src, opt, callback) {\n // throw error in case of non string input\n if (typeof src === 'undefined' || src === null) {\n throw new Error('marked(): input parameter is undefined or null');\n }\n if (typeof src !== 'string') {\n throw new Error('marked(): input parameter is of type '\n + Object.prototype.toString.call(src) + ', string expected');\n }\n\n if (typeof opt === 'function') {\n callback = opt;\n opt = null;\n }\n\n opt = merge({}, marked.defaults, opt || {});\n checkSanitizeDeprecation(opt);\n\n if (callback) {\n const highlight = opt.highlight;\n let tokens;\n\n try {\n tokens = Lexer.lex(src, opt);\n } catch (e) {\n return callback(e);\n }\n\n const done = function(err) {\n let out;\n\n if (!err) {\n try {\n if (opt.walkTokens) {\n marked.walkTokens(tokens, opt.walkTokens);\n }\n out = Parser.parse(tokens, opt);\n } catch (e) {\n err = e;\n }\n }\n\n opt.highlight = highlight;\n\n return err\n ? callback(err)\n : callback(null, out);\n };\n\n if (!highlight || highlight.length < 3) {\n return done();\n }\n\n delete opt.highlight;\n\n if (!tokens.length) return done();\n\n let pending = 0;\n marked.walkTokens(tokens, function(token) {\n if (token.type === 'code') {\n pending++;\n setTimeout(() => {\n highlight(token.text, token.lang, function(err, code) {\n if (err) {\n return done(err);\n }\n if (code != null && code !== token.text) {\n token.text = code;\n token.escaped = true;\n }\n\n pending--;\n if (pending === 0) {\n done();\n }\n });\n }, 0);\n }\n });\n\n if (pending === 0) {\n done();\n }\n\n return;\n }\n\n try {\n const tokens = Lexer.lex(src, opt);\n if (opt.walkTokens) {\n marked.walkTokens(tokens, opt.walkTokens);\n }\n return Parser.parse(tokens, opt);\n } catch (e) {\n e.message += '\\nPlease report this to https://github.com/markedjs/marked.';\n if (opt.silent) {\n return '<p>An error occurred:</p><pre>'\n + escape(e.message + '', true)\n + '</pre>';\n }\n throw e;\n }\n}\n\n/**\n * Options\n */\n\nmarked.options =\nmarked.setOptions = function(opt) {\n merge(marked.defaults, opt);\n changeDefaults(marked.defaults);\n return marked;\n};\n\nmarked.getDefaults = getDefaults;\n\nmarked.defaults = defaults;\n\n/**\n * Use Extension\n */\n\nmarked.use = function(...args) {\n const opts = merge({}, ...args);\n const extensions = marked.defaults.extensions || { renderers: {}, childTokens: {} };\n let hasExtensions;\n\n args.forEach((pack) => {\n // ==-- Parse \"addon\" extensions --== //\n if (pack.extensions) {\n hasExtensions = true;\n pack.extensions.forEach((ext) => {\n if (!ext.name) {\n throw new Error('extension name required');\n }\n if (ext.renderer) { // Renderer extensions\n const prevRenderer = extensions.renderers ? extensions.renderers[ext.name] : null;\n if (prevRenderer) {\n // Replace extension with func to run new extension but fall back if false\n extensions.renderers[ext.name] = function(...args) {\n let ret = ext.renderer.apply(this, args);\n if (ret === false) {\n ret = prevRenderer.apply(this, args);\n }\n return ret;\n };\n } else {\n extensions.renderers[ext.name] = ext.renderer;\n }\n }\n if (ext.tokenizer) { // Tokenizer Extensions\n if (!ext.level || (ext.level !== 'block' && ext.level !== 'inline')) {\n throw new Error(\"extension level must be 'block' or 'inline'\");\n }\n if (extensions[ext.level]) {\n extensions[ext.level].unshift(ext.tokenizer);\n } else {\n extensions[ext.level] = [ext.tokenizer];\n }\n if (ext.start) { // Function to check for start of token\n if (ext.level === 'block') {\n if (extensions.startBlock) {\n extensions.startBlock.push(ext.start);\n } else {\n extensions.startBlock = [ext.start];\n }\n } else if (ext.level === 'inline') {\n if (extensions.startInline) {\n extensions.startInline.push(ext.start);\n } else {\n extensions.startInline = [ext.start];\n }\n }\n }\n }\n if (ext.childTokens) { // Child tokens to be visited by walkTokens\n extensions.childTokens[ext.name] = ext.childTokens;\n }\n });\n }\n\n // ==-- Parse \"overwrite\" extensions --== //\n if (pack.renderer) {\n const renderer = marked.defaults.renderer || new Renderer();\n for (const prop in pack.renderer) {\n const prevRenderer = renderer[prop];\n // Replace renderer with func to run extension, but fall back if false\n renderer[prop] = (...args) => {\n let ret = pack.renderer[prop].apply(renderer, args);\n if (ret === false) {\n ret = prevRenderer.apply(renderer, args);\n }\n return ret;\n };\n }\n opts.renderer = renderer;\n }\n if (pack.tokenizer) {\n const tokenizer = marked.defaults.tokenizer || new Tokenizer();\n for (const prop in pack.tokenizer) {\n const prevTokenizer = tokenizer[prop];\n // Replace tokenizer with func to run extension, but fall back if false\n tokenizer[prop] = (...args) => {\n let ret = pack.tokenizer[prop].apply(tokenizer, args);\n if (ret === false) {\n ret = prevTokenizer.apply(tokenizer, args);\n }\n return ret;\n };\n }\n opts.tokenizer = tokenizer;\n }\n\n // ==-- Parse WalkTokens extensions --== //\n if (pack.walkTokens) {\n const walkTokens = marked.defaults.walkTokens;\n opts.walkTokens = function(token) {\n pack.walkTokens.call(this, token);\n if (walkTokens) {\n walkTokens.call(this, token);\n }\n };\n }\n\n if (hasExtensions) {\n opts.extensions = extensions;\n }\n\n marked.setOptions(opts);\n });\n};\n\n/**\n * Run callback for every token\n */\n\nmarked.walkTokens = function(tokens, callback) {\n for (const token of tokens) {\n callback.call(marked, token);\n switch (token.type) {\n case 'table': {\n for (const cell of token.header) {\n marked.walkTokens(cell.tokens, callback);\n }\n for (const row of token.rows) {\n for (const cell of row) {\n marked.walkTokens(cell.tokens, callback);\n }\n }\n break;\n }\n case 'list': {\n marked.walkTokens(token.items, callback);\n break;\n }\n default: {\n if (marked.defaults.extensions && marked.defaults.extensions.childTokens && marked.defaults.extensions.childTokens[token.type]) { // Walk any extensions\n marked.defaults.extensions.childTokens[token.type].forEach(function(childTokens) {\n marked.walkTokens(token[childTokens], callback);\n });\n } else if (token.tokens) {\n marked.walkTokens(token.tokens, callback);\n }\n }\n }\n }\n};\n\n/**\n * Parse Inline\n * @param {string} src\n */\nmarked.parseInline = function(src, opt) {\n // throw error in case of non string input\n if (typeof src === 'undefined' || src === null) {\n throw new Error('marked.parseInline(): input parameter is undefined or null');\n }\n if (typeof src !== 'string') {\n throw new Error('marked.parseInline(): input parameter is of type '\n + Object.prototype.toString.call(src) + ', string expected');\n }\n\n opt = merge({}, marked.defaults, opt || {});\n checkSanitizeDeprecation(opt);\n\n try {\n const tokens = Lexer.lexInline(src, opt);\n if (opt.walkTokens) {\n marked.walkTokens(tokens, opt.walkTokens);\n }\n return Parser.parseInline(tokens, opt);\n } catch (e) {\n e.message += '\\nPlease report this to https://github.com/markedjs/marked.';\n if (opt.silent) {\n return '<p>An error occurred:</p><pre>'\n + escape(e.message + '', true)\n + '</pre>';\n }\n throw e;\n }\n};\n\n/**\n * Expose\n */\nmarked.Parser = Parser;\nmarked.parser = Parser.parse;\nmarked.Renderer = Renderer;\nmarked.TextRenderer = TextRenderer;\nmarked.Lexer = Lexer;\nmarked.lexer = Lexer.lex;\nmarked.Tokenizer = Tokenizer;\nmarked.Slugger = Slugger;\nmarked.parse = marked;\n\nconst options = marked.options;\nconst setOptions = marked.setOptions;\nconst use = marked.use;\nconst walkTokens = marked.walkTokens;\nconst parseInline = marked.parseInline;\nconst parse = marked;\nconst parser = Parser.parse;\nconst lexer = Lexer.lex;\n\nexport { Lexer, Parser, Renderer, Slugger, TextRenderer, Tokenizer, defaults, getDefaults, lexer, marked, options, parse, parseInline, parser, setOptions, use, walkTokens };\n","import type { marked } from 'marked';\nimport type { WalineTexRenderer } from '../typings';\n\nconst inlineMathStart = /\\$.*?\\$/;\nconst inlineMathReg = /^\\$(.*?)\\$/;\nconst blockMathReg = /^(?:\\s{0,3})\\$\\$((?:[^\\n]|\\n[^\\n])+?)\\n{0,1}\\$\\$/;\n\nexport const markedTexExtensions = (\n texRenderer: WalineTexRenderer\n): marked.TokenizerExtension[] => {\n const blockMathExtension: marked.TokenizerExtension = {\n name: 'blockMath',\n level: 'block',\n tokenizer(src: string) {\n const cap = blockMathReg.exec(src);\n\n if (cap !== null) {\n return {\n type: 'html',\n raw: cap[0],\n text: texRenderer(true, cap[1]),\n };\n }\n\n return undefined;\n },\n };\n\n const inlineMathExtension: marked.TokenizerExtension = {\n name: 'inlineMath',\n level: 'inline',\n start(src: string) {\n const idx = src.search(inlineMathStart);\n return idx !== -1 ? idx : src.length;\n },\n tokenizer(src: string) {\n const cap = inlineMathReg.exec(src);\n\n if (cap !== null) {\n return {\n type: 'html',\n raw: cap[0],\n text: texRenderer(false, cap[1]),\n };\n }\n\n return undefined;\n },\n };\n\n return [blockMathExtension, inlineMathExtension];\n};\n","import { marked } from 'marked';\nimport { markedTexExtensions } from './markedMathExtension';\n\nimport type {\n WalineEmojiMaps,\n WalineHighlighter,\n WalineTexRenderer,\n} from '../typings';\n\nexport const parseEmoji = (text = '', emojiMap: WalineEmojiMaps = {}): string =>\n text.replace(/:(.+?):/g, (placeholder, key: string) =>\n emojiMap[key]\n ? `<img class=\"wl-emoji\" src=\"${emojiMap[key]}\" alt=\"${key}\">`\n : placeholder\n );\n\nexport interface ParseMarkdownOptions {\n emojiMap: WalineEmojiMaps;\n highlighter: WalineHighlighter | false;\n texRenderer: WalineTexRenderer | false;\n}\n\nexport const parseMarkdown = (\n content: string,\n { emojiMap, highlighter, texRenderer }: ParseMarkdownOptions\n): string => {\n marked.setOptions({\n highlight: highlighter || undefined,\n breaks: true,\n smartLists: true,\n smartypants: true,\n });\n\n if (texRenderer) {\n const extensions = markedTexExtensions(texRenderer);\n\n marked.use({ extensions });\n }\n\n return marked.parse(parseEmoji(content, emojiMap));\n};\n","export const getQuery = (element: HTMLElement): string | null =>\n element.dataset.path || element.getAttribute('id');\n","export type GifFormat =\n | 'gif'\n | 'mediumgif'\n | 'tinygif'\n | 'nanogif'\n | 'mp4'\n | 'loopedmp4'\n | 'tinymp4'\n | 'nanomp4'\n | 'webm'\n | 'tinywebm'\n | 'nanowebm';\nexport interface MediaObject {\n preview: string;\n url: string;\n dims: number[];\n size: number;\n}\n\nexport interface FetchGifRequest {\n key?: string;\n keyword: string;\n pos?: string;\n limit?: number;\n}\n\nexport interface GifObject {\n created: number;\n hasaudio: boolean;\n id: string;\n media: Record<GifFormat, MediaObject>[];\n tags: string[];\n title: string;\n itemurl: string;\n hascaption: boolean;\n url: string;\n}\n\nexport interface FetchGifResponse {\n next: string;\n results: GifObject[];\n}\n\nexport const fetchGif = ({\n key,\n keyword,\n pos,\n limit,\n}: FetchGifRequest): Promise<FetchGifResponse> => {\n const baseUrl = `https://g.tenor.com/v1/search`;\n const query = new URLSearchParams('media_filter=minimal');\n query.set('key', key || 'PAY5JLFIH6V6');\n query.set('limit', (limit || 20).toString());\n query.set('pos', pos || '');\n query.set('q', keyword);\n\n return fetch(`${baseUrl}?${query.toString()}`, {\n headers: {\n // eslint-disable-next-line @typescript-eslint/naming-convention\n 'Content-Type': 'application/json',\n },\n }).then((resp) => resp.json() as Promise<FetchGifResponse>);\n};\n","import { useStorage } from '@vueuse/core';\n\nimport type { Ref } from 'vue';\n\nexport interface UserInfo {\n // eslint-disable-next-line @typescript-eslint/naming-convention\n display_name: string;\n email: string;\n url: string;\n token: string;\n avatar: string;\n mailMd5: string;\n objectId: string | number;\n type: 'administrator' | 'guest';\n}\n\nexport const USER_KEY = 'WALINE_USER';\n\nexport type UserInfoRef = Ref<UserInfo | Record<string, never>>;\n\nlet userInfoStorage: UserInfoRef | null = null;\n\nexport const useUserInfo = (): UserInfoRef =>\n userInfoStorage ||\n (userInfoStorage = useStorage<UserInfo | Record<string, never>>(\n 'USER_KEY',\n {}\n ));\n","import { useStorage } from '@vueuse/core';\n\nimport type { Ref } from 'vue';\n\nconst LIKE_KEY = 'WALINE_LIKE';\n\nexport type LikeID = number | string;\n\nexport type LikeRef = Ref<LikeID[]>;\n\nlet likeStorage: LikeRef | null = null;\n\nexport const useLikeStorage = (): LikeRef =>\n likeStorage || (likeStorage = useStorage<LikeID[]>(LIKE_KEY, []));\n","import { useUserInfo } from './composables';\nimport { decodePath, errorHandler, fetchCommentCount } from './utils';\nimport type { WalineAbort } from './typings';\n\nexport interface WalineCommentCountOptions {\n /**\n * Waline 服务端地址\n *\n * Waline server url\n */\n serverURL: string;\n\n /**\n * 评论数 CSS 选择器\n *\n * Commment count CSS selector\n *\n * @default '.waline-comment-count'\n */\n selector?: string;\n\n /**\n * 需要获取的默认路径\n *\n * Path to be fetched by default\n *\n * @default window.location.pathname\n */\n path?: string;\n\n /**\n * 错误提示消息所使用的语言\n *\n * Language of error message\n *\n * @default 'zh-CN'\n */\n lang?: string;\n}\n\nexport const commentCount = ({\n serverURL,\n path = window.location.pathname,\n selector = '.waline-comment-count',\n lang = 'zh-CN',\n}: // eslint-disable-next-line @typescript-eslint/no-explicit-any\nWalineCommentCountOptions): WalineAbort => {\n const controller = new AbortController();\n\n // comment count\n const elements = document.querySelectorAll<HTMLElement>(selector);\n\n const userInfo = useUserInfo();\n\n if (elements.length)\n void fetchCommentCount({\n serverURL,\n paths: Array.from(elements).map((element) =>\n decodePath(element.dataset.path || element.getAttribute('id') || path)\n ),\n lang,\n signal: controller.signal,\n token: userInfo.value?.token,\n })\n .then((counts) => {\n elements.forEach((element, index) => {\n element.innerText = counts[index].toString();\n });\n })\n .catch(errorHandler);\n\n return controller.abort.bind(controller);\n};\n","var e,t,n=\"function\"==typeof Map?new Map:(e=[],t=[],{has:function(t){return e.indexOf(t)>-1},get:function(n){return t[e.indexOf(n)]},set:function(n,o){-1===e.indexOf(n)&&(e.push(n),t.push(o))},delete:function(n){var o=e.indexOf(n);o>-1&&(e.splice(o,1),t.splice(o,1))}}),o=function(e){return new Event(e,{bubbles:!0})};try{new Event(\"test\")}catch(e){o=function(e){var t=document.createEvent(\"Event\");return t.initEvent(e,!0,!1),t}}function r(e){var t=n.get(e);t&&t.destroy()}function i(e){var t=n.get(e);t&&t.update()}var l=null;\"undefined\"==typeof window||\"function\"!=typeof window.getComputedStyle?((l=function(e){return e}).destroy=function(e){return e},l.update=function(e){return e}):((l=function(e,t){return e&&Array.prototype.forEach.call(e.length?e:[e],function(e){return function(e){if(e&&e.nodeName&&\"TEXTAREA\"===e.nodeName&&!n.has(e)){var t,r=null,i=null,l=null,d=function(){e.clientWidth!==i&&c()},a=function(t){window.removeEventListener(\"resize\",d,!1),e.removeEventListener(\"input\",c,!1),e.removeEventListener(\"keyup\",c,!1),e.removeEventListener(\"autosize:destroy\",a,!1),e.removeEventListener(\"autosize:update\",c,!1),Object.keys(t).forEach(function(n){e.style[n]=t[n]}),n.delete(e)}.bind(e,{height:e.style.height,resize:e.style.resize,overflowY:e.style.overflowY,overflowX:e.style.overflowX,wordWrap:e.style.wordWrap});e.addEventListener(\"autosize:destroy\",a,!1),\"onpropertychange\"in e&&\"oninput\"in e&&e.addEventListener(\"keyup\",c,!1),window.addEventListener(\"resize\",d,!1),e.addEventListener(\"input\",c,!1),e.addEventListener(\"autosize:update\",c,!1),e.style.overflowX=\"hidden\",e.style.wordWrap=\"break-word\",n.set(e,{destroy:a,update:c}),\"vertical\"===(t=window.getComputedStyle(e,null)).resize?e.style.resize=\"none\":\"both\"===t.resize&&(e.style.resize=\"horizontal\"),r=\"content-box\"===t.boxSizing?-(parseFloat(t.paddingTop)+parseFloat(t.paddingBottom)):parseFloat(t.borderTopWidth)+parseFloat(t.borderBottomWidth),isNaN(r)&&(r=0),c()}function u(t){var n=e.style.width;e.style.width=\"0px\",e.style.width=n,e.style.overflowY=t}function s(){if(0!==e.scrollHeight){var t=function(e){for(var t=[];e&&e.parentNode&&e.parentNode instanceof Element;)e.parentNode.scrollTop&&t.push({node:e.parentNode,scrollTop:e.parentNode.scrollTop}),e=e.parentNode;return t}(e),n=document.documentElement&&document.documentElement.scrollTop;e.style.height=\"\",e.style.height=e.scrollHeight+r+\"px\",i=e.clientWidth,t.forEach(function(e){e.node.scrollTop=e.scrollTop}),n&&(document.documentElement.scrollTop=n)}}function c(){s();var t=Math.round(parseFloat(e.style.height)),n=window.getComputedStyle(e,null),r=\"content-box\"===n.boxSizing?Math.round(parseFloat(n.height)):e.offsetHeight;if(r<t?\"hidden\"===n.overflowY&&(u(\"scroll\"),s(),r=\"content-box\"===n.boxSizing?Math.round(parseFloat(window.getComputedStyle(e,null).height)):e.offsetHeight):\"hidden\"!==n.overflowY&&(u(\"hidden\"),s(),r=\"content-box\"===n.boxSizing?Math.round(parseFloat(window.getComputedStyle(e,null).height)):e.offsetHeight),l!==r){l=r;var i=o(\"autosize:resized\");try{e.dispatchEvent(i)}catch(e){}}}}(e)}),e}).destroy=function(e){return e&&Array.prototype.forEach.call(e.length?e:[e],r),e},l.update=function(e){return e&&Array.prototype.forEach.call(e.length?e:[e],i),e});var d=l;export default d;\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","<!-- forked from https://github.com/DerYeger/vue-masonry-wall/blob/master/src/masonry-wall.vue -->\n\n<!-- MIT License\n\nCopyright (c) 2021 Fuxing Loh, Jan Müller\n\nPermission is hereby granted, free of charge, to any person obtaining a copy\nof this software and associated documentation files (the \"Software\"), to deal\nin the Software without restriction, including without limitation the rights\nto use, copy, modify, merge, publish, distribute, sublicense, and/or sell\ncopies of the Software, and to permit persons to whom the Software is\nfurnished to do so, subject to the following conditions:\n\nThe above copyright notice and this permission notice shall be included in all\ncopies or substantial portions of the Software.\n\nTHE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\nIMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\nFITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\nAUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\nLIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\nOUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE\nSOFTWARE. -->\n\n<template>\n <div ref=\"wall\" class=\"wl-gallery\" :style=\"{ gap: `${gap}px` }\">\n <div\n v-for=\"(column, columnIndex) in columns\"\n :key=\"columnIndex\"\n class=\"wl-gallery-column\"\n :data-index=\"columnIndex\"\n :style=\"{ gap: `${gap}px` }\"\n >\n <img\n v-for=\"itemIndex in column\"\n :key=\"itemIndex\"\n class=\"wl-gallery-item\"\n :src=\"items[itemIndex].media[0].tinygif.url\"\n :title=\"items[itemIndex].title\"\n loading=\"lazy\"\n @click=\"\n $emit('insert', ``)\n \"\n />\n </div>\n </div>\n</template>\n\n<script lang=\"ts\">\nimport {\n defineComponent,\n nextTick,\n onBeforeUnmount,\n onMounted,\n ref,\n watch,\n} from 'vue';\n\nimport type { PropType } from 'vue';\n\ntype Column = number[];\n\nexport default defineComponent({\n props: {\n columnWidth: { type: Number, default: 300 },\n items: { type: Array as PropType<unknown[]>, default: () => [] },\n gap: { type: Number, default: 0 },\n rtl: { type: Boolean, default: false },\n },\n\n emit: ['insert'],\n\n setup(props) {\n let resizeObserver: ResizeObserver | null = null;\n const wall = ref<HTMLDivElement | null>(null);\n\n const columns = ref<Column[]>([]);\n\n const getColumnCount = (): number => {\n const count = Math.floor(\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n (wall.value!.getBoundingClientRect().width + props.gap) /\n (props.columnWidth + props.gap)\n );\n\n return count > 0 ? count : 1;\n };\n\n const createColumns = (count: number): Column[] =>\n new Array(count).fill(null).map(() => []);\n\n const fillColumns = async (itemIndex: number): Promise<void> => {\n if (itemIndex >= props.items.length) return;\n\n await nextTick();\n\n const columnDivs = Array.from(\n wall.value?.children || []\n ) as HTMLDivElement[];\n\n if (props.rtl) columnDivs.reverse();\n\n const target = columnDivs.reduce((prev, curr) =>\n curr.getBoundingClientRect().height <\n prev.getBoundingClientRect().height\n ? curr\n : prev\n );\n\n columns.value[Number(target.dataset.index)].push(itemIndex);\n\n await fillColumns(itemIndex + 1);\n };\n\n const redraw = async (force = false): Promise<void> => {\n if (columns.value.length === getColumnCount() && !force) return;\n\n columns.value = createColumns(getColumnCount());\n\n const scrollY = window.scrollY;\n\n await fillColumns(0);\n\n window.scrollTo({ top: scrollY });\n };\n\n watch(\n () => [props.items, props.rtl],\n () => redraw(true)\n );\n watch(\n () => [props.columnWidth, props.gap],\n () => redraw()\n );\n\n onMounted(() => {\n redraw(true);\n resizeObserver = new ResizeObserver(() => redraw());\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n resizeObserver.observe(wall.value!);\n });\n\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n onBeforeUnmount(() => resizeObserver!.unobserve(wall.value!));\n\n return {\n columns,\n wall,\n };\n },\n});\n</script>\n","import { h } from 'vue';\nimport type { FunctionalComponent } from 'vue';\n\nexport const CloseIcon: FunctionalComponent<{ size: number }> = ({ size }) =>\n h(\n 'svg',\n {\n class: 'wl-close-icon',\n viewBox: '0 0 1024 1024',\n width: size,\n height: size,\n },\n [\n h('path', {\n d: 'M697.173 85.333h-369.92c-144.64 0-241.92 101.547-241.92 252.587v348.587c0 150.613 97.28 252.16 241.92 252.16h369.92c144.64 0 241.494-101.547 241.494-252.16V337.92c0-151.04-96.854-252.587-241.494-252.587z',\n fill: 'currentColor',\n }),\n h('path', {\n d: 'm640.683 587.52-75.947-75.861 75.904-75.862a37.29 37.29 0 0 0 0-52.778 37.205 37.205 0 0 0-52.779 0l-75.946 75.818-75.862-75.946a37.419 37.419 0 0 0-52.821 0 37.419 37.419 0 0 0 0 52.821l75.947 75.947-75.776 75.733a37.29 37.29 0 1 0 52.778 52.821l75.776-75.776 75.947 75.947a37.376 37.376 0 0 0 52.779-52.821z',\n fill: '#888',\n }),\n ]\n );\n\nexport const DeleteIcon: FunctionalComponent = () =>\n h(\n 'svg',\n { viewBox: '0 0 1024 1024', width: '24', height: '24' },\n h('path', {\n d: 'm341.013 394.667 27.755 393.45h271.83l27.733-393.45h64.106l-28.01 397.952a64 64 0 0 1-63.83 59.498H368.768a64 64 0 0 1-63.83-59.52l-28.053-397.93h64.128zm139.307 19.818v298.667h-64V414.485h64zm117.013 0v298.667h-64V414.485h64zM181.333 288h640v64h-640v-64zm453.483-106.667v64h-256v-64h256z',\n fill: 'red',\n })\n );\n\nexport const EmojiIcon: FunctionalComponent = () =>\n h(\n 'svg',\n { viewBox: '0 0 1024 1024', width: '24', height: '24' },\n h('path', {\n d: 'M563.2 463.3 677 540c1.7 1.2 3.7 1.8 5.8 1.8.7 0 1.4-.1 2-.2 2.7-.5 5.1-2.1 6.6-4.4l25.3-37.8c1.5-2.3 2.1-5.1 1.6-7.8s-2.1-5.1-4.4-6.6l-73.6-49.1 73.6-49.1c2.3-1.5 3.9-3.9 4.4-6.6.5-2.7 0-5.5-1.6-7.8l-25.3-37.8a10.1 10.1 0 0 0-6.6-4.4c-.7-.1-1.3-.2-2-.2-2.1 0-4.1.6-5.8 1.8l-113.8 76.6c-9.2 6.2-14.7 16.4-14.7 27.5.1 11 5.5 21.3 14.7 27.4zM387 348.8h-45.5c-5.7 0-10.4 4.7-10.4 10.4v153.3c0 5.7 4.7 10.4 10.4 10.4H387c5.7 0 10.4-4.7 10.4-10.4V359.2c0-5.7-4.7-10.4-10.4-10.4zm333.8 241.3-41-20a10.3 10.3 0 0 0-8.1-.5c-2.6.9-4.8 2.9-5.9 5.4-30.1 64.9-93.1 109.1-164.4 115.2-5.7.5-9.9 5.5-9.5 11.2l3.9 45.5c.5 5.3 5 9.5 10.3 9.5h.9c94.8-8 178.5-66.5 218.6-152.7 2.4-5 .3-11.2-4.8-13.6zm186-186.1c-11.9-42-30.5-81.4-55.2-117.1-24.1-34.9-53.5-65.6-87.5-91.2-33.9-25.6-71.5-45.5-111.6-59.2-41.2-14-84.1-21.1-127.8-21.1h-1.2c-75.4 0-148.8 21.4-212.5 61.7-63.7 40.3-114.3 97.6-146.5 165.8-32.2 68.1-44.3 143.6-35.1 218.4 9.3 74.8 39.4 145 87.3 203.3.1.2.3.3.4.5l36.2 38.4c1.1 1.2 2.5 2.1 3.9 2.6 73.3 66.7 168.2 103.5 267.5 103.5 73.3 0 145.2-20.3 207.7-58.7 37.3-22.9 70.3-51.5 98.1-85 27.1-32.7 48.7-69.5 64.2-109.1 15.5-39.7 24.4-81.3 26.6-123.8 2.4-43.6-2.5-87-14.5-129zm-60.5 181.1c-8.3 37-22.8 72-43 104-19.7 31.1-44.3 58.6-73.1 81.7-28.8 23.1-61 41-95.7 53.4-35.6 12.7-72.9 19.1-110.9 19.1-82.6 0-161.7-30.6-222.8-86.2l-34.1-35.8c-23.9-29.3-42.4-62.2-55.1-97.7-12.4-34.7-18.8-71-19.2-107.9-.4-36.9 5.4-73.3 17.1-108.2 12-35.8 30-69.2 53.4-99.1 31.7-40.4 71.1-72 117.2-94.1 44.5-21.3 94-32.6 143.4-32.6 49.3 0 97 10.8 141.8 32 34.3 16.3 65.3 38.1 92 64.8 26.1 26 47.5 56 63.6 89.2 16.2 33.2 26.6 68.5 31 105.1 4.6 37.5 2.7 75.3-5.6 112.3z',\n fill: 'currentColor',\n })\n );\n\nexport const ImageIcon: FunctionalComponent = () =>\n h('svg', { viewBox: '0 0 1024 1024', width: '24', height: '24' }, [\n h('path', {\n d: 'M784 112H240c-88 0-160 72-160 160v480c0 88 72 160 160 160h544c88 0 160-72 160-160V272c0-88-72-160-160-160zm96 640c0 52.8-43.2 96-96 96H240c-52.8 0-96-43.2-96-96V272c0-52.8 43.2-96 96-96h544c52.8 0 96 43.2 96 96v480z',\n fill: 'currentColor',\n }),\n h('path', {\n d: 'M352 480c52.8 0 96-43.2 96-96s-43.2-96-96-96-96 43.2-96 96 43.2 96 96 96zm0-128c17.6 0 32 14.4 32 32s-14.4 32-32 32-32-14.4-32-32 14.4-32 32-32zm462.4 379.2-3.2-3.2-177.6-177.6c-25.6-25.6-65.6-25.6-91.2 0l-80 80-36.8-36.8c-25.6-25.6-65.6-25.6-91.2 0L200 728c-4.8 6.4-8 14.4-8 24 0 17.6 14.4 32 32 32 9.6 0 16-3.2 22.4-9.6L380.8 640l134.4 134.4c6.4 6.4 14.4 9.6 24 9.6 17.6 0 32-14.4 32-32 0-9.6-4.8-17.6-9.6-24l-52.8-52.8 80-80L769.6 776c6.4 4.8 12.8 8 20.8 8 17.6 0 32-14.4 32-32 0-8-3.2-16-8-20.8z',\n fill: 'currentColor',\n }),\n ]);\n\nexport const LikeIcon: FunctionalComponent<{ active: boolean }> = ({\n active = false,\n}: {\n active?: boolean;\n}) =>\n h('svg', { viewBox: '0 0 1024 1024', width: '24', height: '24' }, [\n h('path', {\n d: `M850.654 323.804c-11.042-25.625-26.862-48.532-46.885-68.225-20.022-19.61-43.258-34.936-69.213-45.73-26.78-11.124-55.124-16.727-84.375-16.727-40.622 0-80.256 11.123-114.698 32.135A214.79 214.79 0 0 0 512 241.819a214.79 214.79 0 0 0-23.483-16.562c-34.442-21.012-74.076-32.135-114.698-32.135-29.25 0-57.595 5.603-84.375 16.727-25.872 10.711-49.19 26.12-69.213 45.73-20.105 19.693-35.843 42.6-46.885 68.225-11.453 26.615-17.303 54.877-17.303 83.963 0 27.439 5.603 56.03 16.727 85.117 9.31 24.307 22.659 49.52 39.715 74.981 27.027 40.293 64.188 82.316 110.33 124.915 76.465 70.615 152.189 119.394 155.402 121.371l19.528 12.525c8.652 5.52 19.776 5.52 28.427 0l19.529-12.525c3.213-2.06 78.854-50.756 155.401-121.371 46.143-42.6 83.304-84.622 110.33-124.915 17.057-25.46 30.487-50.674 39.716-74.981 11.124-29.087 16.727-57.678 16.727-85.117.082-29.086-5.768-57.348-17.221-83.963z${\n active\n ? ''\n : 'M512 761.5S218.665 573.55 218.665 407.767c0-83.963 69.461-152.023 155.154-152.023 60.233 0 112.473 33.618 138.181 82.727 25.708-49.109 77.948-82.727 138.18-82.727 85.694 0 155.155 68.06 155.155 152.023C805.335 573.551 512 761.5 512 761.5z'\n }`,\n fill: active ? 'red' : 'currentColor',\n }),\n ]);\n\nexport const PreviewIcon: FunctionalComponent = () =>\n h('svg', { viewBox: '0 0 1024 1024', width: '24', height: '24' }, [\n h('path', {\n d: 'M710.816 654.301c70.323-96.639 61.084-230.578-23.705-314.843-46.098-46.098-107.183-71.109-172.28-71.109-65.008 0-126.092 25.444-172.28 71.109-45.227 46.098-70.756 107.183-70.756 172.106 0 64.923 25.444 126.007 71.194 172.106 46.099 46.098 107.184 71.109 172.28 71.109 51.414 0 100.648-16.212 142.824-47.404l126.53 126.006c7.058 7.06 16.297 10.979 26.406 10.979 10.105 0 19.343-3.919 26.402-10.979 14.467-14.467 14.467-38.172 0-52.723L710.816 654.301zm-315.107-23.265c-65.88-65.88-65.88-172.54 0-238.42 32.069-32.07 74.245-49.149 119.471-49.149 45.227 0 87.407 17.603 119.472 49.149 65.88 65.879 65.88 172.539 0 238.42-63.612 63.178-175.242 63.178-238.943 0zm0 0',\n fill: 'currentColor',\n }),\n h('path', {\n d: 'M703.319 121.603H321.03c-109.8 0-199.469 89.146-199.469 199.38v382.034c0 109.796 89.236 199.38 199.469 199.38h207.397c20.653 0 37.384-16.645 37.384-37.299 0-20.649-16.731-37.296-37.384-37.296H321.03c-68.582 0-124.352-55.77-124.352-124.267V321.421c0-68.496 55.77-124.267 124.352-124.267h382.289c68.582 0 124.352 55.771 124.352 124.267V524.72c0 20.654 16.736 37.299 37.385 37.299 20.654 0 37.384-16.645 37.384-37.299V320.549c-.085-109.8-89.321-198.946-199.121-198.946zm0 0',\n fill: 'currentColor',\n }),\n ]);\n\nexport const MarkdownIcon: FunctionalComponent = () =>\n h(\n 'svg',\n { width: '16', height: '16', ariaHidden: 'true' },\n h('path', {\n d: 'M14.85 3H1.15C.52 3 0 3.52 0 4.15v7.69C0 12.48.52 13 1.15 13h13.69c.64 0 1.15-.52 1.15-1.15v-7.7C16 3.52 15.48 3 14.85 3zM9 11H7V8L5.5 9.92 4 8v3H2V5h2l1.5 2L7 5h2v6zm2.99.5L9.5 8H11V5h2v3h1.5l-2.51 3.5z',\n fill: 'currentColor',\n })\n );\n\nexport const ReplyIcon: FunctionalComponent = () =>\n h(\n 'svg',\n { viewBox: '0 0 1024 1024', width: '24', height: '24' },\n h('path', {\n d: 'M810.667 213.333a64 64 0 0 1 64 64V704a64 64 0 0 1-64 64H478.336l-146.645 96.107a21.333 21.333 0 0 1-33.024-17.856V768h-85.334a64 64 0 0 1-64-64V277.333a64 64 0 0 1 64-64h597.334zm0 64H213.333V704h149.334v63.296L459.243 704h351.424V277.333zm-271.36 213.334v64h-176.64v-64h176.64zm122.026-128v64H362.667v-64h298.666z',\n fill: 'currentColor',\n })\n );\n\nexport const VerifiedIcon: FunctionalComponent = () =>\n h(\n 'svg',\n {\n class: 'verified-icon',\n viewBox: '0 0 1024 1024',\n width: '14',\n height: '14',\n },\n h('path', {\n d: 'm894.4 461.56-54.4-63.2c-10.4-12-18.8-34.4-18.8-50.4v-68c0-42.4-34.8-77.2-77.2-77.2h-68c-15.6 0-38.4-8.4-50.4-18.8l-63.2-54.4c-27.6-23.6-72.8-23.6-100.8 0l-62.8 54.8c-12 10-34.8 18.4-50.4 18.4h-69.2c-42.4 0-77.2 34.8-77.2 77.2v68.4c0 15.6-8.4 38-18.4 50l-54 63.6c-23.2 27.6-23.2 72.4 0 100l54 63.6c10 12 18.4 34.4 18.4 50v68.4c0 42.4 34.8 77.2 77.2 77.2h69.2c15.6 0 38.4 8.4 50.4 18.8l63.2 54.4c27.6 23.6 72.8 23.6 100.8 0l63.2-54.4c12-10.4 34.4-18.8 50.4-18.8h68c42.4 0 77.2-34.8 77.2-77.2v-68c0-15.6 8.4-38.4 18.8-50.4l54.4-63.2c23.2-27.6 23.2-73.2-.4-100.8zm-216-25.2-193.2 193.2a30 30 0 0 1-42.4 0l-96.8-96.8a30.16 30.16 0 0 1 0-42.4c11.6-11.6 30.8-11.6 42.4 0l75.6 75.6 172-172c11.6-11.6 30.8-11.6 42.4 0 11.6 11.6 11.6 30.8 0 42.4z',\n fill: '#27ae60',\n })\n );\n\nexport const LoadingIcon: FunctionalComponent<{ size: number }> = ({ size }) =>\n h(\n 'svg',\n {\n width: size,\n height: size,\n viewBox: '0 0 100 100',\n preserveAspectRatio: 'xMidYMid',\n },\n h(\n 'circle',\n {\n cx: 50,\n cy: 50,\n fill: 'none',\n stroke: 'currentColor',\n strokeWidth: '4',\n r: '40',\n // eslint-disable-next-line @typescript-eslint/naming-convention\n 'stroke-dasharray': '85 30',\n },\n h('animateTransform', {\n attributeName: 'transform',\n type: 'rotate',\n repeatCount: 'indefinite',\n dur: '1s',\n values: '0 50 50;360 50 50',\n keyTimes: '0;1',\n })\n )\n );\n\nexport const GifIcon: FunctionalComponent = () =>\n h(\n 'svg',\n {\n width: 24,\n height: 24,\n fill: 'currentcolor',\n viewBox: '0 0 24 24',\n },\n [\n h('path', {\n style: 'transform: translateY(0.5px)',\n d: 'M18.968 10.5H15.968V11.484H17.984V12.984H15.968V15H14.468V9H18.968V10.5V10.5ZM8.984 9C9.26533 9 9.49967 9.09367 9.687 9.281C9.87433 9.46833 9.968 9.70267 9.968 9.984V10.5H6.499V13.5H8.468V12H9.968V14.016C9.968 14.2973 9.87433 14.5317 9.687 14.719C9.49967 14.9063 9.26533 15 8.984 15H5.984C5.70267 15 5.46833 14.9063 5.281 14.719C5.09367 14.5317 5 14.2973 5 14.016V9.985C5 9.70367 5.09367 9.46933 5.281 9.282C5.46833 9.09467 5.70267 9.001 5.984 9.001H8.984V9ZM11.468 9H12.968V15H11.468V9V9Z',\n }),\n h('path', {\n d: 'M18.5 3H5.75C3.6875 3 2 4.6875 2 6.75V18C2 20.0625 3.6875 21.75 5.75 21.75H18.5C20.5625 21.75 22.25 20.0625 22.25 18V6.75C22.25 4.6875 20.5625 3 18.5 3ZM20.75 18C20.75 19.2375 19.7375 20.25 18.5 20.25H5.75C4.5125 20.25 3.5 19.2375 3.5 18V6.75C3.5 5.5125 4.5125 4.5 5.75 4.5H18.5C19.7375 4.5 20.75 5.5125 20.75 6.75V18Z',\n }),\n ]\n );\n","<template>\n <div class=\"wl-comment\">\n <div v-if=\"config.login !== 'disable' && isLogin\" class=\"wl-login-info\">\n <div class=\"wl-avatar\">\n <button class=\"wl-logout-btn\" :title=\"locale.logout\" @click=\"onLogout\">\n <CloseIcon :size=\"14\" />\n </button>\n\n <img :src=\"userInfo.avatar\" alt=\"avatar\" />\n </div>\n <a\n href=\"#\"\n class=\"wl-login-nick\"\n aria-label=\"Profile\"\n @click=\"onProfile\"\n v-text=\"userInfo.display_name\"\n />\n </div>\n\n <div class=\"wl-panel\">\n <div\n v-if=\"config.login !== 'force' && config.meta.length && !isLogin\"\n :class=\"['wl-header', `item${config.meta.length}`]\"\n >\n <div v-for=\"kind in config.meta\" class=\"wl-header-item\" :key=\"kind\">\n <label\n :for=\"kind\"\n v-text=\"\n locale[kind] +\n (config.requiredMeta.includes(kind) || !config.requiredMeta.length\n ? ''\n : `(${locale.optional})`)\n \"\n />\n <input\n :ref=\"\n (element) => {\n if (element) inputRefs[kind] = element as HTMLInputElement;\n }\n \"\n :id=\"`wl-${kind}`\"\n :class=\"['wl-input', `wl-${kind}`]\"\n :name=\"kind\"\n :type=\"kind === 'mail' ? 'email' : 'text'\"\n v-model=\"userMeta[kind]\"\n />\n </div>\n </div>\n\n <textarea\n class=\"wl-editor\"\n ref=\"editorRef\"\n id=\"wl-edit\"\n :placeholder=\"replyUser ? `@${replyUser}` : locale.placeholder\"\n v-model=\"editor\"\n @keydown=\"onKeyDown\"\n @drop=\"onDrop\"\n @paste=\"onPaste\"\n />\n\n <div class=\"wl-preview\" v-show=\"showPreview\">\n <hr />\n <h4>{{ locale.preview }}:</h4>\n <div class=\"wl-content\" v-html=\"previewText\" />\n </div>\n\n <div class=\"wl-footer\">\n <div class=\"wl-actions\">\n <a\n href=\"https://guides.github.com/features/mastering-markdown/\"\n title=\"Markdown Guide\"\n aria-label=\"Markdown is supported\"\n class=\"wl-action\"\n target=\"_blank\"\n rel=\"noreferrer\"\n >\n <MarkdownIcon />\n </a>\n\n <button\n v-show=\"emoji.tabs.length\"\n ref=\"emojiButtonRef\"\n class=\"wl-action\"\n :class=\"{ actived: showEmoji }\"\n :title=\"locale.emoji\"\n @click=\"showEmoji = !showEmoji\"\n >\n <EmojiIcon />\n </button>\n\n <button\n ref=\"gifButtonRef\"\n class=\"wl-action\"\n :class=\"{ actived: showGif }\"\n :title=\"locale.gif\"\n @click=\"showGif = !showGif\"\n >\n <GifIcon />\n </button>\n\n <input\n ref=\"imageUploadRef\"\n class=\"upload\"\n id=\"wl-image-upload\"\n type=\"file\"\n accept=\".png,.jpg,.jpeg,.webp,.bmp,.gif\"\n @change=\"onChange\"\n />\n\n <label\n v-if=\"canUploadImage\"\n for=\"wl-image-upload\"\n class=\"wl-action\"\n :title=\"locale.uploadImage\"\n >\n <ImageIcon />\n </label>\n\n <button\n class=\"wl-action\"\n :class=\"{ actived: showPreview }\"\n :title=\"locale.preview\"\n @click=\"showPreview = !showPreview\"\n >\n <PreviewIcon />\n </button>\n </div>\n\n <div class=\"wl-info\">\n <div class=\"wl-text-number\">\n {{ wordNumber }}\n\n <span v-if=\"config.wordLimit\">\n / \n <span\n :class=\"{ illegal: !isWordNumberLegal }\"\n v-text=\"wordLimit\"\n />\n </span>\n\n {{ locale.word }}\n </div>\n\n <button\n v-if=\"config.login !== 'disable' && !isLogin\"\n class=\"wl-btn\"\n @click=\"onLogin\"\n v-text=\"locale.login\"\n />\n\n <button\n v-if=\"config.login !== 'force' || isLogin\"\n class=\"wl-btn primary\"\n title=\"Cmd|Ctrl + Enter\"\n :disabled=\"isSubmitting\"\n @click=\"submitComment\"\n >\n <LoadingIcon v-if=\"isSubmitting\" :size=\"16\" />\n <template v-else>\n {{ locale.submit }}\n </template>\n </button>\n </div>\n\n <div\n ref=\"gifPopupRef\"\n class=\"wl-gif-popup\"\n :class=\"{ display: showGif }\"\n >\n <input\n type=\"text\"\n :placeholder=\"locale.gifSearchPlaceholder\"\n ref=\"gifSearchInputRef\"\n @input=\"onGifSearch\"\n />\n\n <ImageWall\n :items=\"gifData.list\"\n :column-width=\"200\"\n :gap=\"6\"\n @insert=\"insert($event)\"\n @scroll=\"onImageWallScroll\"\n >\n </ImageWall>\n\n <div v-if=\"gifData.loading\" class=\"wl-loading\">\n <LoadingIcon :size=\"30\" />\n </div>\n </div>\n <div\n ref=\"emojiPopupRef\"\n class=\"wl-emoji-popup\"\n :class=\"{ display: showEmoji }\"\n >\n <template v-for=\"(config, index) in emoji.tabs\" :key=\"config.name\">\n <div v-if=\"index === emojiTabIndex\" class=\"wl-tab-wrapper\">\n <button\n v-for=\"key in config.items\"\n :key=\"key\"\n :title=\"key\"\n @click=\"insert(`:${key}:`)\"\n >\n <img\n v-if=\"showEmoji\"\n class=\"wl-emoji\"\n :src=\"emoji.map[key]\"\n :alt=\"key\"\n loading=\"lazy\"\n referrerPolicy=\"no-referrer\"\n />\n </button>\n </div>\n </template>\n <div v-if=\"emoji.tabs.length > 1\" class=\"wl-tabs\">\n <button\n v-for=\"(config, index) in emoji.tabs\"\n :key=\"config.name\"\n class=\"wl-tab\"\n :class=\"{ active: emojiTabIndex === index }\"\n @click=\"emojiTabIndex = index\"\n >\n <img\n class=\"wl-emoji\"\n :src=\"config.icon\"\n :alt=\"config.name\"\n :title=\"config.name\"\n loading=\"lazy\"\n referrerPolicy=\"no-referrer\"\n />\n </button>\n </div>\n </div>\n </div>\n </div>\n\n <button\n v-if=\"replyId\"\n class=\"wl-close\"\n :title=\"locale.cancelReply\"\n @click=\"$emit('cancel-reply')\"\n >\n <CloseIcon :size=\"24\" />\n </button>\n </div>\n</template>\n\n<script lang=\"ts\">\nimport autosize from 'autosize';\nimport {\n computed,\n defineComponent,\n inject,\n onMounted,\n onUnmounted,\n ref,\n watch,\n} from 'vue';\n\nimport ImageWall from './ImageWall.vue';\nimport {\n CloseIcon,\n EmojiIcon,\n ImageIcon,\n MarkdownIcon,\n PreviewIcon,\n LoadingIcon,\n GifIcon,\n} from './Icons';\nimport { useEditor, useUserMeta, useUserInfo } from '../composables';\nimport {\n fetchGif,\n getEmojis,\n getImagefromDataTransfer,\n getWordNumber,\n parseEmoji,\n parseMarkdown,\n postComment,\n throttle,\n} from '../utils';\n\nimport type { ComputedRef, DeepReadonly } from 'vue';\nimport type { WalineCommentData, WalineImageUploader } from '../typings';\nimport type {\n FetchGifResponse,\n WalineConfig,\n WalineEmojiConfig,\n} from '../utils';\n\nexport default defineComponent({\n name: 'CommentBox',\n\n components: {\n CloseIcon,\n EmojiIcon,\n ImageIcon,\n ImageWall,\n MarkdownIcon,\n PreviewIcon,\n LoadingIcon,\n GifIcon,\n },\n\n props: {\n rootId: {\n type: String,\n default: '',\n },\n replyId: {\n type: String,\n default: '',\n },\n replyUser: {\n type: String,\n default: '',\n },\n },\n\n emits: ['submit', 'cancel-reply'],\n\n setup(props, { emit }) {\n const config = inject<ComputedRef<WalineConfig>>(\n 'config'\n ) as ComputedRef<WalineConfig>;\n\n const editor = useEditor();\n const userMeta = useUserMeta();\n const userInfo = useUserInfo();\n\n const inputRefs = ref<Record<string, HTMLInputElement>>({});\n const editorRef = ref<HTMLTextAreaElement | null>(null);\n const imageUploadRef = ref<HTMLInputElement | null>(null);\n const emojiButtonRef = ref<HTMLDivElement | null>(null);\n const emojiPopupRef = ref<HTMLDivElement | null>(null);\n const gifButtonRef = ref<HTMLDivElement | null>(null);\n const gifPopupRef = ref<HTMLDivElement | null>(null);\n const gifSearchInputRef = ref<HTMLInputElement | null>(null);\n\n const emoji = ref<DeepReadonly<WalineEmojiConfig>>({ tabs: [], map: {} });\n const emojiTabIndex = ref(0);\n const showEmoji = ref(false);\n const showGif = ref(false);\n const showPreview = ref(false);\n const previewText = ref('');\n const wordNumber = ref(0);\n const gifData = ref<{\n cursor: string;\n loading: boolean;\n list: FetchGifResponse['results'];\n }>({ cursor: '', loading: true, list: [] });\n\n const wordLimit = ref(0);\n const isWordNumberLegal = ref(false);\n\n const content = ref('');\n\n const isSubmitting = ref(false);\n\n const locale = computed(() => config.value.locale);\n\n const isLogin = computed(() => Boolean(userInfo.value?.token));\n\n const canUploadImage = computed(() => config.value.imageUploader !== false);\n\n const insert = (content: string): void => {\n const textArea = editorRef.value as HTMLTextAreaElement;\n const startPosition = textArea.selectionStart;\n const endPosition = textArea.selectionEnd || 0;\n const scrollTop = textArea.scrollTop;\n\n editor.value =\n textArea.value.substring(0, startPosition) +\n content +\n textArea.value.substring(endPosition, textArea.value.length);\n textArea.focus();\n textArea.selectionStart = startPosition + content.length;\n textArea.selectionEnd = startPosition + content.length;\n textArea.scrollTop = scrollTop;\n };\n\n const onKeyDown = (event: KeyboardEvent): void => {\n const key = event.key;\n\n // Shortcut key\n if ((event.ctrlKey || event.metaKey) && key === 'Enter') submitComment();\n };\n\n const uploadImage = (file: File): Promise<void> => {\n const uploadText = `![${config.value.locale.uploading} ${file.name}]()`;\n\n insert(uploadText);\n\n return Promise.resolve()\n .then(() => (config.value.imageUploader as WalineImageUploader)(file))\n .then((url) => {\n editor.value = editor.value.replace(\n uploadText,\n `\\r\\n`\n );\n });\n };\n\n const onDrop = (event: DragEvent): void => {\n if (event.dataTransfer?.items) {\n const file = getImagefromDataTransfer(event.dataTransfer.items);\n\n if (file && canUploadImage.value) {\n uploadImage(file);\n event.preventDefault();\n }\n }\n };\n\n const onPaste = (event: ClipboardEvent): void => {\n if (event.clipboardData) {\n const file = getImagefromDataTransfer(event.clipboardData.items);\n\n if (file && canUploadImage.value) uploadImage(file);\n }\n };\n\n const onChange = (): void => {\n const inputElement = imageUploadRef.value as HTMLInputElement;\n\n if (inputElement.files && canUploadImage.value)\n uploadImage(inputElement.files[0]).then(() => {\n // clear input so a same image can be uploaded later\n inputElement.value = '';\n });\n };\n\n const submitComment = (): void => {\n const { serverURL, lang, login, wordLimit, requiredMeta } = config.value;\n\n const comment: WalineCommentData = {\n comment: content.value,\n nick: userMeta.value.nick,\n mail: userMeta.value.mail,\n link: userMeta.value.link,\n ua: navigator.userAgent,\n url: config.value.path,\n };\n\n if (userInfo.value?.token) {\n // login user\n\n comment.nick = userInfo.value.display_name;\n comment.mail = userInfo.value.email;\n comment.link = userInfo.value.url;\n } else {\n if (login === 'force') return;\n\n // check nick\n if (requiredMeta.indexOf('nick') > -1 && !comment.nick) {\n inputRefs.value.nick?.focus();\n return alert(locale.value.nickError);\n }\n\n // check mail\n if (\n (requiredMeta.indexOf('mail') > -1 && !comment.mail) ||\n (comment.mail &&\n !/^\\w(?:[\\w._-]*\\w)?@(?:\\w(?:[\\w-]*\\w)?\\.)*\\w+$/.exec(comment.mail))\n ) {\n inputRefs.value.mail?.focus();\n return alert(locale.value.mailError);\n }\n\n // check comment\n if (!comment.comment) {\n editorRef.value?.focus();\n return;\n }\n\n if (!comment.nick) comment.nick = locale.value.anonymous;\n }\n\n if (!isWordNumberLegal.value)\n return alert(\n locale.value.wordHint\n .replace('$0', (wordLimit as [number, number])[0].toString())\n .replace('$1', (wordLimit as [number, number])[1].toString())\n .replace('$2', wordNumber.value.toString())\n );\n\n comment.comment = parseEmoji(comment.comment, emoji.value.map);\n\n if (props.replyId && props.rootId) {\n comment.pid = props.replyId;\n comment.rid = props.rootId;\n comment.at = props.replyUser;\n }\n\n isSubmitting.value = true;\n\n postComment({\n serverURL,\n lang,\n token: userInfo.value?.token,\n comment,\n })\n .then((resp) => {\n isSubmitting.value = false;\n\n if (resp.errmsg) return alert(resp.errmsg);\n\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n emit('submit', resp.data!);\n\n editor.value = '';\n\n previewText.value = '';\n\n if (props.replyId) emit('cancel-reply');\n })\n .catch((err: TypeError) => {\n isSubmitting.value = false;\n\n alert(err.message);\n });\n };\n\n const onLogin = (event: Event): void => {\n event.preventDefault();\n const { lang, serverURL } = config.value;\n\n const width = 450;\n const height = 450;\n const left = (window.innerWidth - width) / 2;\n const top = (window.innerHeight - height) / 2;\n\n const handler = window.open(\n `${serverURL}/ui/login?lng=${encodeURIComponent(lang)}`,\n '_blank',\n `width=${width},height=${height},left=${left},top=${top},scrollbars=no,resizable=no,status=no,location=no,toolbar=no,menubar=no`\n );\n\n handler?.postMessage({ type: 'TOKEN', data: null }, '*');\n\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const receiver = ({ data }: any): void => {\n if (!data || data.type !== 'userInfo') return;\n\n if (data.data.token) {\n handler?.close();\n userInfo.value = data.data;\n (data.data.remember ? localStorage : sessionStorage).setItem(\n 'WALINE_USER',\n JSON.stringify(data.data)\n );\n\n window.removeEventListener('message', receiver);\n }\n };\n\n window.addEventListener('message', receiver);\n };\n\n const onLogout = (): void => {\n userInfo.value = {};\n localStorage.setItem('WALINE_USER', 'null');\n sessionStorage.setItem('WALINE_USER', 'null');\n };\n\n const onProfile = (event: Event): void => {\n event.preventDefault();\n\n const { lang, serverURL } = config.value;\n\n const width = 800;\n const height = 800;\n const left = (window.innerWidth - width) / 2;\n const top = (window.innerHeight - height) / 2;\n const handler = window.open(\n `${serverURL}/ui/profile?lng=${encodeURIComponent(lang)}`,\n '_blank',\n `width=${width},height=${height},left=${left},top=${top},scrollbars=no,resizable=no,status=no,location=no,toolbar=no,menubar=no`\n );\n\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n handler?.postMessage({ type: 'TOKEN', data: userInfo.value!.token }, '*');\n\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const receiver = ({ data }: any): void => {\n if (!data || data.type !== 'profile') return;\n\n userInfo.value = { ...userInfo.value, ...data };\n\n [localStorage, sessionStorage]\n .filter((store) => store.getItem('WALINE_USER'))\n .forEach((store) =>\n store.setItem('WALINE_USER', JSON.stringify(userInfo))\n );\n window.removeEventListener('message', receiver);\n };\n\n window.addEventListener('message', receiver);\n };\n\n const popupHandler = (event: MouseEvent): void => {\n if (\n !(emojiButtonRef.value as HTMLElement).contains(event.target as Node) &&\n !(emojiPopupRef.value as HTMLElement).contains(event.target as Node)\n )\n showEmoji.value = false;\n\n if (\n !(gifButtonRef.value as HTMLElement).contains(event.target as Node) &&\n !(gifPopupRef.value as HTMLElement).contains(event.target as Node)\n )\n showGif.value = false;\n };\n\n const onImageWallScroll = async (event: Event): Promise<void> => {\n const { scrollTop, clientHeight, scrollHeight } =\n event.target as HTMLDivElement;\n const percent = (clientHeight + scrollTop) / scrollHeight;\n\n if (percent < 0.9 || gifData.value.loading) return;\n\n gifData.value.loading = true;\n\n const data = await fetchGif({\n keyword: gifSearchInputRef.value?.value || '',\n pos: gifData.value.cursor,\n }).finally(() => {\n gifData.value.loading = false;\n });\n\n gifData.value.cursor = data.next;\n gifData.value.list = gifData.value.list.concat(data.results);\n\n setTimeout(() => {\n (event.target as HTMLDivElement).scrollTop = scrollTop;\n }, 50);\n };\n\n const onGifSearch = throttle(async (event: Event) => {\n gifData.value.cursor = '';\n gifData.value.list = [];\n onImageWallScroll(event);\n });\n\n // update wordNumber\n watch(\n [config, wordNumber],\n ([config, wordNumber]) => {\n const { wordLimit: limit } = config;\n\n if (limit) {\n if (wordNumber < limit[0] && limit[0] !== 0) {\n wordLimit.value = limit[0];\n isWordNumberLegal.value = false;\n } else if (wordNumber > limit[1]) {\n wordLimit.value = limit[1];\n isWordNumberLegal.value = false;\n } else {\n wordLimit.value = limit[1];\n isWordNumberLegal.value = true;\n }\n } else {\n wordLimit.value = 0;\n isWordNumberLegal.value = true;\n }\n },\n { immediate: true }\n );\n\n watch(showGif, async (showGif) => {\n if (!showGif) return;\n\n gifData.value.loading = true;\n const data = await fetchGif({ keyword: '' }).finally(() => {\n gifData.value.loading = false;\n });\n\n gifData.value.cursor = data.next;\n gifData.value.list = gifData.value.list.concat(data.results);\n });\n\n onMounted(() => {\n document.body.addEventListener('click', popupHandler);\n\n // watch editor\n watch(\n () => editor.value,\n (value) => {\n const { highlighter, texRenderer } = config.value;\n\n content.value = value;\n previewText.value = parseMarkdown(value, {\n emojiMap: emoji.value.map,\n highlighter,\n texRenderer,\n });\n wordNumber.value = getWordNumber(value);\n\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n if (value) autosize(editorRef.value!);\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n else autosize.destroy(editorRef.value!);\n },\n { immediate: true }\n );\n\n // watch emoji value change\n watch(\n () => config.value.emoji,\n (emojiConfig) =>\n getEmojis(Array.isArray(emojiConfig) ? emojiConfig : []).then(\n (config) => {\n emoji.value = config;\n }\n ),\n { immediate: true }\n );\n });\n\n onUnmounted(() => {\n document.body.removeEventListener('click', popupHandler);\n });\n\n return {\n // config\n config,\n locale,\n\n // events\n insert,\n onChange,\n onDrop,\n onKeyDown,\n onPaste,\n onLogin,\n onLogout,\n onProfile,\n submitComment,\n onImageWallScroll,\n onGifSearch,\n\n isLogin,\n userInfo,\n isSubmitting,\n\n // word\n wordNumber,\n wordLimit,\n isWordNumberLegal,\n\n // inputs\n editor,\n userMeta,\n\n // emoji\n emoji,\n emojiTabIndex,\n showEmoji,\n\n // gif\n gifData,\n showGif,\n\n // image\n canUploadImage,\n\n // preview\n previewText,\n showPreview,\n\n // ref\n inputRefs,\n editorRef,\n emojiButtonRef,\n emojiPopupRef,\n gifButtonRef,\n gifPopupRef,\n imageUploadRef,\n gifSearchInputRef,\n };\n },\n});\n</script>\n","export const throttle = (\n func: (...args: any[]) => void,\n timeout = 300\n): ((...args: []) => void) => {\n let timer: number | null;\n\n return (...args: []): void => {\n if (timer) clearTimeout(timer);\n\n timer = window.setTimeout(() => {\n func(...args);\n timer = null;\n }, timeout);\n };\n};\n","/**\n * The wordCount module should be lightweight as it's packed into client.\n *\n * So We just make a simple implement here\n *\n * Forked from https://github.com/vuepress-theme-hope/vuepress-theme-hope/blob/main/packages/reading-time2/src/node/reading-time.ts\n */\n\nexport const getWords = (content: string): string[] =>\n content.match(/[\\w\\d\\s\\u00C0-\\u024F]+/giu) || [];\n\nexport const getChinese = (content: string): string[] =>\n content.match(/[\\u4E00-\\u9FA5]/gu) || [];\n\nexport const getWordNumber = (content: string): number =>\n getWords(content).reduce(\n (accumulator, word) =>\n accumulator + (word.trim() === '' ? 0 : word.trim().split(/\\s+/u).length),\n 0\n ) + getChinese(content).length;\n","<template>\n <div class=\"wl-item\" :id=\"comment.objectId\">\n <div class=\"wl-user\" aria-hidden=\"true\">\n <img v-if=\"comment.avatar\" :src=\"comment.avatar\" />\n <VerifiedIcon v-if=\"comment.type\" />\n </div>\n\n <div class=\"wl-card\">\n <div class=\"wl-head\">\n <a\n v-if=\"link\"\n class=\"wl-nick\"\n :href=\"link\"\n target=\"_blank\"\n rel=\"nofollow noreferrer\"\n >{{ comment.nick }}</a\n >\n <span v-else class=\"wl-nick\">{{ comment.nick }}</span>\n\n <span\n v-if=\"comment.type === 'administrator'\"\n class=\"wl-badge\"\n v-text=\"locale.admin\"\n />\n <span v-if=\"comment.label\" class=\"wl-badge\" v-text=\"comment.label\" />\n <span v-if=\"comment.sticky\" class=\"wl-badge\" v-text=\"locale.sticky\" />\n <span\n v-if=\"comment.level !== undefined && comment.level >= 0\"\n :class=\"`wl-badge level${comment.level}`\"\n v-text=\"locale[`level${comment.level}`] || `Level ${comment.level}`\"\n />\n <span class=\"wl-time\" v-text=\"time\" />\n\n <div class=\"wl-comment-actions\">\n <button\n class=\"wl-delete\"\n v-if=\"isAdmin || isOwner\"\n @click=\"$emit('delete', comment)\"\n >\n <DeleteIcon />\n </button>\n\n <button\n class=\"wl-like\"\n @click=\"$emit('like', comment)\"\n :title=\"like ? locale.cancelLike : locale.like\"\n >\n <LikeIcon :active=\"like\" />\n <span v-if=\"'like' in comment\" v-text=\"comment.like\" />\n </button>\n\n <button\n class=\"wl-reply\"\n :class=\"{ active: isReplyingCurrent }\"\n :title=\"isReplyingCurrent ? locale.cancelReply : locale.reply\"\n @click=\"$emit('reply', isReplyingCurrent ? null : comment)\"\n >\n <ReplyIcon />\n </button>\n </div>\n </div>\n <div class=\"wl-meta\" aria-hidden=\"true\">\n <span v-if=\"comment.addr\" v-text=\"comment.addr\" />\n <span v-if=\"comment.browser\" v-text=\"comment.browser\" />\n <span v-if=\"comment.os\" v-text=\"comment.os\" />\n </div>\n <div class=\"wl-content\" v-html=\"comment.comment\" />\n\n <div v-if=\"isAdmin\" class=\"wl-admin-actions\">\n <span class=\"wl-comment-status\">\n <button\n v-for=\"status in commentStatus\"\n :key=\"status\"\n :class=\"`wl-btn wl-${status}`\"\n :disabled=\"comment.status === status\"\n @click=\"$emit('status', { status, comment })\"\n v-text=\"status\"\n />\n </span>\n\n <button\n class=\"wl-btn wl-sticky\"\n v-if=\"isAdmin && !comment.rid\"\n @click=\"$emit('sticky', comment)\"\n >\n {{ comment.sticky ? 'unsticky' : 'sticky' }}\n </button>\n </div>\n\n <div v-if=\"isReplyingCurrent\" class=\"wl-reply-wrapper\">\n <CommentBox\n :replyId=\"comment.objectId\"\n :replyUser=\"comment.nick\"\n :rootId=\"rootId\"\n @submit=\"$emit('submit', $event)\"\n @cancel-reply=\"$emit('reply', null)\"\n />\n </div>\n <div v-if=\"comment.children\" class=\"wl-quote\">\n <CommentCard\n v-for=\"child in comment.children\"\n :key=\"child.objectId\"\n :comment=\"child\"\n :reply=\"reply\"\n :rootId=\"rootId\"\n @reply=\"$emit('reply', $event)\"\n @submit=\"$emit('submit', $event)\"\n @like=\"$emit('like', $event)\"\n @delete=\"$emit('delete', $event)\"\n @status=\"$emit('status', $event)\"\n @sticky=\"$emit('sticky', $event)\"\n />\n </div>\n </div>\n </div>\n</template>\n\n<script lang=\"ts\">\nimport { computed, defineComponent, inject } from 'vue';\nimport CommentBox from './CommentBox.vue';\nimport { DeleteIcon, LikeIcon, ReplyIcon, VerifiedIcon } from './Icons';\nimport { isLinkHttp } from '../utils';\nimport { useTimeAgo, useLikeStorage, useUserInfo } from '../composables';\n\nimport type { ComputedRef, PropType } from 'vue';\nimport type { WalineConfig } from '../utils';\nimport type { WalineComment, WalineCommentStatus } from '../typings';\n\nconst commentStatus: WalineCommentStatus[] = ['approved', 'waiting', 'spam'];\n\nexport default defineComponent({\n props: {\n comment: {\n type: Object as PropType<WalineComment>,\n required: true,\n },\n rootId: {\n type: String,\n required: true,\n },\n reply: {\n type: Object as PropType<WalineComment | null>,\n },\n },\n\n components: {\n CommentBox,\n DeleteIcon,\n LikeIcon,\n ReplyIcon,\n VerifiedIcon,\n },\n\n emits: ['submit', 'reply', 'like', 'delete', 'status', 'sticky'],\n\n setup(props) {\n const config = inject<ComputedRef<WalineConfig>>(\n 'config'\n ) as ComputedRef<WalineConfig>;\n const likes = useLikeStorage();\n const userInfo = useUserInfo();\n\n const locale = computed(() => config.value.locale);\n\n const link = computed(() => {\n let { link } = props.comment;\n\n return link ? (isLinkHttp(link) ? link : `https://${link}`) : '';\n });\n\n const like = computed(() => likes.value.includes(props.comment.objectId));\n\n const time = useTimeAgo(props.comment.insertedAt, locale.value);\n\n const isAdmin = computed(() => userInfo.value.type === 'administrator');\n\n const isOwner = computed(\n () =>\n props.comment.user_id &&\n userInfo.value.objectId === props.comment.user_id\n );\n\n const isReplyingCurrent = computed(\n () => props.comment.objectId === props.reply?.objectId\n );\n\n return {\n config,\n locale,\n\n isReplyingCurrent,\n link,\n like,\n time,\n\n isAdmin,\n isOwner,\n\n commentStatus,\n };\n },\n});\n</script>\n","import { useNow } from '@vueuse/core';\nimport { computed } from 'vue';\nimport { getTimeAgo } from '../utils';\n\nimport type { ComputedRef } from 'vue';\nimport type { WalineLocale } from '../typings';\n\nexport const useTimeAgo = (\n date: Date | string,\n locale: WalineLocale\n): ComputedRef<string> => {\n const now = useNow();\n\n return computed(() => getTimeAgo(date, now.value, locale));\n};\n","<template>\n <div data-waline>\n <CommentBox v-if=\"!reply\" @submit=\"onSubmit\" />\n <div class=\"wl-count\">\n <span v-if=\"count\" class=\"wl-num\" v-text=\"count\" />\n {{ i18n.comment }}\n </div>\n\n <div class=\"wl-cards\">\n <CommentCard\n v-for=\"comment in data\"\n :key=\"comment.objectId\"\n :root-id=\"comment.objectId\"\n :comment=\"comment\"\n :reply=\"reply\"\n @reply=\"onReply\"\n @submit=\"onSubmit\"\n @status=\"onStatusChange\"\n @delete=\"onDelete\"\n @sticky=\"onSticky\"\n @like=\"onLike\"\n />\n </div>\n\n <div v-if=\"status === 'error'\" class=\"wl-operation\">\n <button\n type=\"button\"\n class=\"wl-btn\"\n @click=\"refresh\"\n v-text=\"i18n.refresh\"\n />\n </div>\n\n <template v-else>\n <div v-if=\"status === 'loading'\" class=\"wl-loading\">\n <LoadingIcon :size=\"30\" />\n </div>\n\n <div v-else-if=\"!data.length\" class=\"wl-empty\" v-text=\"i18n.sofa\" />\n\n <!-- Load more button -->\n <div v-else-if=\"page < totalPages\" class=\"wl-operation\">\n <button\n type=\"button\"\n class=\"wl-btn\"\n @click=\"loadMore\"\n v-text=\"i18n.more\"\n />\n </div>\n </template>\n\n <!-- Copyright Information -->\n <div v-if=\"config.copyright\" class=\"wl-power\">\n Powered by\n <a\n href=\"https://github.com/walinejs/waline\"\n target=\"_blank\"\n rel=\"noreferrer\"\n >\n Waline\n </a>\n v{{ version }}\n </div>\n </div>\n</template>\n\n<script lang=\"ts\">\nimport { useStyleTag } from '@vueuse/core';\nimport { computed, defineComponent, onMounted, provide, ref, watch } from 'vue';\nimport CommentBox from './CommentBox.vue';\nimport CommentCard from './CommentCard.vue';\nimport { LoadingIcon } from './Icons';\nimport { useUserInfo, useLikeStorage } from '../composables';\nimport { defaultLocales } from '../config';\nimport {\n deleteComment,\n fetchCommentList,\n likeComment,\n getConfig,\n getDarkStyle,\n updateComment,\n} from '../utils';\n\nimport type { PropType } from 'vue';\nimport type {\n WalineComment,\n WalineCommentStatus,\n WalineEmojiInfo,\n WalineHighlighter,\n WalineTexRenderer,\n WalineImageUploader,\n WalineLocale,\n WalineProps,\n WalineMeta,\n} from '../typings';\n\ndeclare const SHOULD_VALIDATE: boolean;\ndeclare const VERSION: string;\n\nconst props = [\n 'serverURL',\n 'path',\n 'meta',\n 'requiredMeta',\n 'dark',\n 'lang',\n 'locale',\n 'pageSize',\n 'wordLimit',\n 'emoji',\n 'login',\n 'highlighter',\n 'texRenderer',\n 'imageUploader',\n 'copyright',\n];\n\nconst propsWithValidate = {\n serverURL: {\n type: String,\n required: true,\n },\n\n path: {\n type: String,\n required: true,\n },\n\n meta: {\n type: Array as PropType<WalineMeta[]>,\n default: (): WalineMeta[] => ['nick', 'mail', 'link'],\n validator: (value: unknown): boolean =>\n Array.isArray(value) &&\n value.every((item) => ['nick', 'mail', 'link'].includes(item)),\n },\n\n requiredMeta: {\n type: Array,\n default: (): WalineMeta[] => [],\n validator: (value: unknown): boolean =>\n Array.isArray(value) &&\n value.every((item) => ['nick', 'mail', 'link'].includes(item)),\n },\n\n dark: [String, Boolean],\n\n lang: {\n type: String,\n default: 'zh-CN',\n validator: (value: unknown): boolean =>\n Object.keys(defaultLocales).includes(value as string),\n },\n\n locale: Object as PropType<Partial<WalineLocale>>,\n\n pageSize: { type: Number, default: 10 },\n\n wordLimit: {\n type: [Number, Array] as PropType<number | [number, number]>,\n validator: (value: unknown): boolean =>\n typeof value === 'number' ||\n (Array.isArray(value) &&\n value.length === 2 &&\n value.every((item) => typeof item === 'number')),\n },\n\n emoji: {\n type: [Array, Boolean] as PropType<(string | WalineEmojiInfo)[] | false>,\n validator: (value: unknown): boolean =>\n value === false ||\n (Array.isArray(value) &&\n value.every(\n (item) =>\n typeof item === 'string' ||\n (typeof item === 'object' &&\n typeof item.name === 'string' &&\n typeof item.folder === 'string' &&\n typeof item.icon === 'string' &&\n Array.isArray(item.items) &&\n (item.items as unknown[]).every(\n (icon) => typeof icon === 'string'\n ))\n )),\n },\n\n login: String as PropType<'enable' | 'disable' | 'force'>,\n\n highlighter: Function as PropType<WalineHighlighter>,\n\n imageUploader: {\n type: [Function, Boolean] as PropType<WalineImageUploader | false>,\n default: undefined,\n },\n\n texRenderer: {\n type: [Function, Boolean] as PropType<WalineTexRenderer | false>,\n default: undefined,\n },\n\n copyright: { type: Boolean, default: true },\n};\n\nexport default defineComponent({\n name: 'WalineRoot',\n\n components: {\n CommentBox,\n CommentCard,\n LoadingIcon,\n },\n\n props: SHOULD_VALIDATE ? propsWithValidate : props,\n\n setup(props) {\n const config = computed(() => getConfig(props as unknown as WalineProps));\n\n const userInfo = useUserInfo();\n const likeStorage = useLikeStorage();\n\n const status = ref<'loading' | 'success' | 'error'>('loading');\n\n const count = ref(0);\n const page = ref(1);\n const totalPages = ref(0);\n\n const data = ref<WalineComment[]>([]);\n const reply = ref<WalineComment | null>(null);\n\n const darkmodeStyle = computed(() => getDarkStyle(config.value.dark));\n\n useStyleTag(darkmodeStyle);\n\n // eslint-disable-next-line vue/no-setup-props-destructure\n let abort: () => void;\n\n const fetchComment = (pageNumber: number): void => {\n const { serverURL, path, pageSize } = config.value;\n const controller = new AbortController();\n\n status.value = 'loading';\n\n abort?.();\n\n fetchCommentList({\n serverURL,\n lang: config.value.lang,\n path,\n pageSize,\n page: pageNumber,\n signal: controller.signal,\n token: userInfo.value?.token,\n })\n .then((resp) => {\n status.value = 'success';\n count.value = resp.count;\n data.value.push(...resp.data);\n page.value = pageNumber;\n totalPages.value = resp.totalPages;\n })\n .catch((err) => {\n if (err.name !== 'AbortError') {\n console.error(err.message);\n status.value = 'error';\n }\n });\n\n abort = controller.abort.bind(controller);\n };\n\n const loadMore = (): void => fetchComment(page.value + 1);\n\n const refresh = (): void => {\n count.value = 0;\n data.value = [];\n fetchComment(1);\n };\n\n const onReply = (comment: WalineComment | null): void => {\n reply.value = comment;\n };\n\n const onSubmit = (comment: WalineComment): void => {\n if (comment.rid) {\n const repliedComment = data.value.find(\n ({ objectId }) => objectId === comment.rid\n );\n\n if (!repliedComment) return;\n\n if (!Array.isArray(repliedComment.children))\n repliedComment.children = [];\n\n repliedComment.children.push(comment);\n } else data.value.unshift(comment);\n };\n\n const onStatusChange = async ({\n comment,\n status,\n }: {\n comment: WalineComment;\n status: WalineCommentStatus;\n }): Promise<void> => {\n if (comment.status === status) return;\n\n const { serverURL, lang } = config.value;\n\n await updateComment({\n serverURL,\n lang,\n token: userInfo.value?.token,\n objectId: comment.objectId,\n status,\n });\n\n comment.status = status;\n };\n\n const onSticky = async (comment: WalineComment): Promise<void> => {\n if (comment.rid) return;\n\n const { serverURL, lang } = config.value;\n\n await updateComment({\n serverURL,\n lang,\n token: userInfo.value?.token,\n objectId: comment.objectId,\n sticky: comment.sticky ? 0 : 1,\n });\n\n comment.sticky = !comment.sticky;\n };\n\n const onDelete = async ({ objectId }: WalineComment): Promise<void> => {\n if (!confirm('Are you sure you want to delete this comment?')) return;\n\n const { serverURL, lang } = config.value;\n\n await deleteComment({\n serverURL,\n lang,\n token: userInfo.value?.token,\n objectId: objectId,\n });\n\n // delete comment from data\n data.value.some((item, index) => {\n if (item.objectId === objectId) {\n data.value = data.value.filter((_item, i) => i !== index);\n\n return true;\n }\n\n return item.children.some((child, childIndex) => {\n if (child.objectId === objectId) {\n data.value[index].children = item.children.filter(\n (_item, i) => i !== childIndex\n );\n\n return true;\n }\n\n return false;\n });\n });\n };\n\n const onLike = async (comment: WalineComment): Promise<void> => {\n const { serverURL, lang } = config.value;\n const { objectId } = comment;\n const hasLiked = likeStorage.value.includes(objectId);\n\n await likeComment({\n serverURL,\n lang,\n objectId,\n like: !hasLiked,\n });\n\n if (hasLiked)\n likeStorage.value = likeStorage.value.filter((id) => id !== objectId);\n else {\n likeStorage.value = [...likeStorage.value, objectId];\n\n if (likeStorage.value.length > 50)\n likeStorage.value = likeStorage.value.slice(-50);\n }\n\n comment.like = (comment.like || 0) + (hasLiked ? -1 : 1);\n };\n\n provide('config', config);\n\n watch(() => (props as unknown as WalineProps).path, refresh);\n\n onMounted(() => refresh());\n\n return {\n config,\n darkmodeStyle,\n i18n: computed(() => config.value.locale),\n\n status,\n count,\n page,\n totalPages,\n data,\n reply,\n\n loadMore,\n refresh,\n onReply,\n onSubmit,\n onStatusChange,\n onDelete,\n onSticky,\n onLike,\n\n version: VERSION,\n };\n },\n});\n</script>\n","import {\n errorHandler,\n fetchPageviews,\n getQuery,\n updatePageviews,\n} from './utils';\n\nimport type { WalineAbort } from './typings';\n\nexport interface WalinePageviewCountOptions {\n /**\n * Waline 服务端地址\n *\n * Waline server url\n */\n serverURL: string;\n\n /**\n * 浏览量 CSS 选择器\n *\n * Pageview CSS selector\n *\n * @default '.waline-pageview-count'\n */\n selector?: string;\n\n /**\n * 需要更新和获取的路径\n *\n * Path to be fetched and updated\n *\n * @default window.location.pathname\n */\n path?: string;\n\n /**\n * 是否在查询时更新 path 的浏览量\n *\n * Whether update pageviews when fetching path result\n *\n * @default true\n */\n update?: boolean;\n\n /**\n * 错误提示消息所使用的语言\n *\n * Language of error message\n *\n * @default 'zh-CN'\n */\n lang?: string;\n}\n\nconst renderVisitorCount = (\n counts: number[],\n countElements: HTMLElement[]\n): void => {\n countElements.forEach((element, index) => {\n element.innerText = counts[index].toString();\n });\n};\n\nexport const pageviewCount = ({\n serverURL,\n path = window.location.pathname,\n selector = '.waline-pageview-count',\n update = true,\n lang = 'zh-CN',\n}: WalinePageviewCountOptions): WalineAbort => {\n const controller = new AbortController();\n\n const elements = Array.from(\n // pageview selectors\n document.querySelectorAll<HTMLElement>(selector)\n );\n\n const filter = (element: HTMLElement): boolean => {\n const query = getQuery(element);\n\n return query !== null && path !== query;\n };\n\n const fetch = (elements: HTMLElement[]): Promise<void> =>\n fetchPageviews({\n serverURL,\n paths: elements.map((element) => getQuery(element) || path),\n lang,\n signal: controller.signal,\n })\n .then((counts) => renderVisitorCount(counts, elements))\n .catch(errorHandler);\n\n // we should update pageviews\n if (update) {\n const normalElements = elements.filter((element) => !filter(element));\n const elementsNeedstoBeFetched = elements.filter(filter);\n\n void updatePageviews({ serverURL, path, lang }).then((count) =>\n renderVisitorCount(\n new Array<number>(normalElements.length).fill(count),\n normalElements\n )\n );\n\n // if we should fetch count of other pages\n if (elementsNeedstoBeFetched.length) {\n void fetch(elementsNeedstoBeFetched);\n }\n }\n // we should not update pageviews\n else {\n void fetch(elements);\n }\n\n return controller.abort.bind(controller);\n};\n","import { createApp, h, reactive, watchEffect } from 'vue';\n\nimport Waline from './components/Waline.vue';\nimport { commentCount } from './comment';\nimport { pageviewCount } from './pageview';\nimport { getRoot } from './utils';\n\nimport type { WalineInitOptions } from './typings';\n\nexport interface WalineInstance {\n /**\n * Waline 被挂载到的元素\n *\n * @description 当通过 `el: null` 初始化,值为 `null`\n *\n * Element where Waline is mounted\n *\n * @description when initialized with `el: null`, it will be `null`\n */\n el: HTMLElement | null;\n\n /**\n * 更新 Waline 实例\n *\n * @description 只要不设置`path` 选项,更新时它就会被重置为 `windows.location.pathname`\n *\n * Update Waline instance\n *\n * @description when not setting `path` option, it will be reset to `window.location.pathname`\n */\n update: (newOptions?: Partial<Omit<WalineInitOptions, 'el'>>) => void;\n\n /**\n * 取消挂载并摧毁 Waline 实例\n *\n * Unmount and destroy Waline instance\n */\n destroy: () => void;\n}\n\nexport const init = ({\n el = '#waline',\n path = window.location.pathname,\n comment = false,\n pageview = false,\n ...initProps\n}: WalineInitOptions): WalineInstance | null => {\n // check el element\n const root = el ? getRoot(el) : null;\n\n // check root\n if (el && !root) throw new Error(`Option 'el' do not match any domElement!`);\n\n // check serverURL\n if (!initProps.serverURL) throw new Error(\"Option 'serverURL' is missing!\");\n\n const props = reactive({ ...initProps });\n const state = reactive({ comment, pageview, path });\n\n const updateCommentCount = (): void => {\n if (state.comment)\n commentCount({\n serverURL: props.serverURL,\n path: state.path,\n selector: typeof state.comment === 'string' ? state.comment : undefined,\n });\n };\n\n const updatePageviewCount = (): void => {\n if (state.pageview)\n pageviewCount({\n serverURL: props.serverURL,\n path: state.path,\n selector:\n typeof state.pageview === 'string' ? state.pageview : undefined,\n });\n };\n\n const app = root\n ? createApp(() => h(Waline, { path: state.path, ...props }))\n : null;\n\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n if (app) app.mount(root!);\n\n updateCommentCount();\n updatePageviewCount();\n\n const stopComment = watchEffect(updateCommentCount);\n const stopPageview = watchEffect(updatePageviewCount);\n\n return {\n el: root,\n update: ({\n comment,\n pageview,\n path = window.location.pathname,\n ...newProps\n }: Partial<Omit<WalineInitOptions, 'el'>> = {}): void => {\n Object.entries(newProps).forEach(([key, value]) => {\n // eslint-disable-next-line @typescript-eslint/ban-ts-comment\n // @ts-ignore\n // eslint-disable-next-line\n props[key] = value;\n });\n\n state.path = path;\n if (comment !== undefined) state.comment = comment;\n if (pageview !== undefined) state.pageview = pageview;\n },\n destroy: (): void => {\n app?.unmount();\n stopComment();\n stopPageview();\n },\n };\n};\n","declare const VERSION: string;\n\nexport const version = VERSION;\n","import { useUserInfo } from '../composables';\nimport { fetchRecentComment, getRoot } from '../utils';\n\nimport type { WalineComment } from '../typings';\n\nexport interface WalineRecentCommentsOptions {\n /**\n * Waline 服务端地址\n *\n * Waline serverURL\n */\n serverURL: string;\n\n /**\n * 获取最新评论的数量\n *\n * fetch number of latest comments\n */\n count: number;\n\n /**\n * 需要挂载的元素\n *\n * Element to be mounted\n */\n el?: string | HTMLElement;\n\n /**\n * 错误提示消息所使用的语言\n *\n * Language of error message\n *\n * @default 'zh-CN'\n */\n lang?: string;\n}\n\nexport interface WalineRecentCommentsResult {\n /**\n * 评论数据\n *\n * Comment Data\n */\n comments: WalineComment[];\n\n /**\n * 取消挂载挂件\n *\n * Umount widget\n */\n destroy: () => void;\n}\n\nexport const RecentComments = ({\n el,\n serverURL,\n count,\n lang = 'zh-CN',\n}: WalineRecentCommentsOptions): Promise<WalineRecentCommentsResult> => {\n const userInfo = useUserInfo();\n const root = getRoot(el);\n const controller = new AbortController();\n\n return fetchRecentComment({\n serverURL,\n count,\n lang,\n signal: controller.signal,\n token: userInfo.value?.token,\n }).then((comments) => {\n if (root && comments.length) {\n root.innerHTML = `<ul class=\"wl-recent-list\">${comments\n .map(\n (comment) =>\n `<li class=\"wl-recent-item\"><a href=\"${comment.url}\">${comment.nick}</a>:${comment.comment}</li>`\n )\n .join('')}</ul>`;\n\n return {\n comments,\n destroy: (): void => {\n controller.abort();\n root.innerHTML = '';\n },\n };\n }\n\n return {\n comments,\n destroy: (): void => controller.abort(),\n };\n });\n};\n"],"names":["availableMeta","getMeta","meta","filter","item","includes","defaultUploadImage","file","Promise","resolve","reject","reader","FileReader","readAsDataURL","onload","result","toString","onerror","defaultTexRenderer","blockMode","REGEXP","RegExp","source","COLORS","cache","defaultHighlighter","input","index","replace","_match","word","comment","color","out","length","localeKeys","generateLocale","locale","Object","fromEntries","map","en","jp","zhCN","zhTW","ptBR","ru","defaultLocales","zh","makeMap","str","expectsLowerCase","create","list","split","i","val","toLowerCase","isSpecialBooleanAttr","includeBooleanAttr","value","normalizeStyle","isArray","res","normalized","isString","parseStringStyle","key","isObject","listDelimiterRE","propertyDelimiterRE","cssText","ret","forEach","tmp","trim","normalizeClass","name","looseEqual","a","b","aValidType","isDate","bValidType","getTime","isSymbol","equal","looseCompareArrays","keys","aHasKey","hasOwnProperty","bHasKey","String","looseIndexOf","arr","findIndex","toDisplayString","objectToString","isFunction","JSON","stringify","replacer","_key","__v_isRef","isMap","size","entries","reduce","isSet","values","isPlainObject","EMPTY_OBJ","EMPTY_ARR","NOOP","NO","onRE","isOn","test","isModelListener","startsWith","extend","assign","remove","el","indexOf","splice","prototype","hasOwn","call","Array","toTypeString","isPromise","then","catch","isIntegerKey","parseInt","isReservedProp","cacheStringFunction","fn","camelizeRE","camelize","_","c","toUpperCase","hyphenateRE","hyphenate","capitalize","charAt","slice","toHandlerKey","hasChanged","oldValue","is","invokeArrayFns","fns","arg","def","obj","defineProperty","configurable","enumerable","toNumber","n","parseFloat","isNaN","_globalThis","activeEffectScope","EffectScope","constructor","detached","this","active","effects","cleanups","parent","scopes","push","run","currentEffectScope","on","off","stop","fromParent","l","last","pop","createDep","dep","Set","w","wasTracked","trackOpBit","newTracked","targetMap","WeakMap","effectTrackDepth","activeEffect","ITERATE_KEY","Symbol","MAP_KEY_ITERATE_KEY","ReactiveEffect","scheduler","scope","deps","undefined","effect","recordEffectScope","lastShouldTrack","shouldTrack","initDepMarkers","cleanupEffect","ptr","delete","finalizeDepMarkers","deferStop","onStop","trackStack","pauseTracking","resetTracking","track","target","type","depsMap","get","set","Map","trackEffects","debuggerEventExtraInfo","has","add","trigger","newValue","oldTarget","triggerEffects","computed","triggerEffect","allowRecurse","isNonTrackableKeys","builtInSymbols","getOwnPropertyNames","createGetter","shallowGet","readonlyGet","arrayInstrumentations","createArrayInstrumentations","instrumentations","args","toRaw","apply","isReadonly","shallow","receiver","shallowReadonlyMap","readonlyMap","shallowReactiveMap","reactiveMap","targetIsArray","Reflect","isRef","readonly","reactive","createSetter","isShallow","hadKey","Number","mutableHandlers","deleteProperty","ownKeys","readonlyHandlers","shallowReactiveHandlers","toShallow","getProto","v","getPrototypeOf","get$1","rawTarget","rawKey","wrap","toReadonly","toReactive","has$1","set$1","deleteEntry","clear","hadItems","createForEach","callback","thisArg","observed","createIterableMethod","method","targetIsMap","isPair","iterator","isKeyOnly","innerIterator","next","done","createReadonlyMethod","createInstrumentations","mutableInstrumentations","shallowInstrumentations","readonlyInstrumentations","shallowReadonlyInstrumentations","createInstrumentationGetter","mutableCollectionHandlers","shallowCollectionHandlers","readonlyCollectionHandlers","getTargetType","isExtensible","rawType","targetTypeMap","toRawType","createReactiveObject","baseHandlers","collectionHandlers","proxyMap","existingProxy","targetType","proxy","Proxy","isReactive","isProxy","raw","markRaw","trackRefValue","ref","triggerRefValue","newVal","r","createRef","shallowRef","rawValue","RefImpl","__v_isShallow","_rawValue","_value","unref","shallowUnwrapHandlers","proxyRefs","objectWithRefs","ComputedRefImpl","getter","_setter","isSSR","_dirty","_cacheable","self","callWithErrorHandling","instance","err","handleError","callWithAsyncErrorHandling","throwInDev","vnode","cur","exposedInstance","errorInfo","errorCapturedHooks","ec","appErrorHandler","appContext","config","errorHandler","contextVNode","console","error","logError","isFlushing","isFlushPending","queue","flushIndex","pendingPreFlushCbs","activePreFlushCbs","preFlushIndex","pendingPostFlushCbs","activePostFlushCbs","postFlushIndex","resolvedPromise","currentFlushPromise","currentPreFlushParentJob","nextTick","p","bind","queueJob","job","id","start","end","middle","getId","findInsertionIndex","queueFlush","flushJobs","queueCb","cb","activeQueue","pendingQueue","flushPreFlushCbs","seen","parentJob","flushPostFlushCbs","deduped","sort","Infinity","emit$1","event","rawArgs","isUnmounted","props","modelArg","modifiersKey","number","handlerName","handler","onceHandler","emitted","normalizeEmitsOptions","comp","asMixin","emitsCache","cached","emits","isEmitListener","options","currentRenderingInstance","currentScopeId","setCurrentRenderingInstance","prev","__scopeId","renderComponentRoot","Component","withProxy","propsOptions","slots","attrs","emit","render","renderCache","data","setupState","ctx","inheritAttrs","fallthroughAttrs","shapeFlag","proxyToUse","normalizeVNode","getFunctionalFallthrough","blockStack","createVNode","Comment","root","some","filterModelListeners","cloneVNode","dirs","concat","transition","hasPropsChanged","prevProps","nextProps","emitsOptions","nextKeys","inject","defaultValue","treatDefaultAsFactory","currentInstance","provides","arguments","watchEffect","doWatch","INITIAL_WATCHER_VALUE","watch","immediate","deep","flush","onTrack","onTrigger","cleanup","forceTrigger","isMultiSource","isShallow$1","s","traverse","onCleanup","baseGetter","isInSSRComponentSetup","queuePostRenderEffect","suspense","queuePreFlushCb","defineComponent","setup","isAsyncWrapper","__asyncLoader","createHook","lifecycle","hook","prepend","hooks","wrappedHook","__weh","setCurrentInstance","unsetCurrentInstance","unshift","injectHook","onMounted","onBeforeUnmount","onUnmounted","withDirectives","directives","internalInstance","getExposeProxy","bindings","dir","modifiers","mounted","updated","invokeDirectiveHook","prevVNode","oldBindings","binding","resolveComponent","maybeSelfReference","warnMissing","selfName","displayName","getComponentName","resolveAsset","NULL_DYNAMIC_COMPONENT","registry","renderList","renderItem","from","getPublicInstance","isStatefulComponent","publicPropertiesMap","$","$el","$data","$props","$attrs","$slots","$refs","$parent","$root","$emit","$options","$forceUpdate","f","update","$nextTick","$watch","PublicInstanceProxyHandlers","accessCache","normalizedProps","publicGetter","cssModule","globalProperties","__cssModules","descriptor","initProps","rawProps","isStateful","InternalObjectKey","propsDefaults","setFullProps","needCastKeys","rawCastValues","hasAttrsChanged","camelKey","rawCurrentProps","castValues","resolvePropValue","isAbsent","opt","hasDefault","default","Function","normalizePropsOptions","propsCache","normalizedKey","validatePropName","prop","booleanIndex","getTypeIndex","Boolean","stringIndex","getType","ctor","match","isSameType","expectedTypes","t","isInternalKey","normalizeSlotValue","normalizeSlot","rawSlot","_n","isNonScopedSlot","renderFnWithContext","_d","setBlockTracking","prevInstance","_c","withCtx","normalizeObjectSlots","rawSlots","_ctx","normalizeVNodeSlots","children","createAppContext","app","isNativeTag","performance","optionMergeStrategies","warnHandler","compilerOptions","mixins","components","optionsCache","uid","createAppAPI","hydrate","rootComponent","rootProps","context","installedPlugins","isMounted","_uid","_component","_props","_container","_context","_instance","version","use","plugin","install","mixin","component","directive","mount","rootContainer","isHydrate","isSVG","__vue_app__","unmount","provide","setRef","rawRef","oldRawRef","parentSuspense","isUnmount","refValue","owner","oldRef","refs","_isString","_isRef","doSet","existing","k","pendingBranch","createRenderer","createHydrationFns","globalThis","window","global","__VUE__","insert","hostInsert","hostRemove","patchProp","hostPatchProp","createElement","hostCreateElement","createText","hostCreateText","createComment","hostCreateComment","setText","hostSetText","setElementText","hostSetElementText","parentNode","hostParentNode","nextSibling","hostNextSibling","setScopeId","hostSetScopeId","cloneNode","hostCloneNode","insertStaticContent","hostInsertStaticContent","patch","n1","n2","container","anchor","parentComponent","slotScopeIds","optimized","dynamicChildren","isSameVNodeType","getNextHostNode","patchFlag","Text","processText","processCommentNode","Static","mountStaticNode","Fragment","processFragment","processElement","processComponent","process","internals","moveStaticNode","removeStaticNode","mountElement","patchElement","vnodeHook","mountChildren","unmountChildren","onVnodeBeforeMount","invokeVNodeHook","scopeId","needCallTransitionHooks","persisted","beforeEnter","onVnodeMounted","enter","subTree","parentVNode","child","cloneIfMounted","oldProps","newProps","toggleRecurse","onVnodeBeforeUpdate","areChildrenSVG","patchBlockChildren","patchChildren","patchProps","class","style","propsToUpdate","dynamicProps","onVnodeUpdated","oldChildren","newChildren","fallbackContainer","oldVNode","newVNode","fragmentStartAnchor","fragmentEndAnchor","fragmentSlotScopeIds","traverseStaticChildren","activate","mountComponent","updateComponent","initialVNode","emptyAppContext","uid$1","exposed","exposeProxy","setupContext","suspenseId","pendingId","asyncDep","asyncResolved","isDeactivated","bc","bm","m","bu","u","um","bum","da","rtg","rtc","sp","ce","createComponentInstance","__isKeepAlive","renderer","initSlots","setupResult","expose","createAttrsProxy","createSetupContext","resolvedResult","handleSetupResult","e","finishComponentSetup","setupStatefulComponent","setupComponent","registerDep","setupRenderEffect","placeholder","nextVNode","prevChildren","nextChildren","$stable","shouldUpdateComponent","updateComponentPreRender","invalidateJob","componentUpdateFn","originNext","nextTree","prevTree","updateHOCHostEl","isAsyncWrapperVNode","hydrateNode","hydrateSubTree","scopedInitialVNode","rawPrevProps","kebabKey","camelizedKey","updateProps","needDeletionCheck","deletionComparisonTarget","updateSlots","c1","prevShapeFlag","c2","patchKeyedChildren","patchUnkeyedChildren","oldLength","newLength","commonLength","Math","min","nextChild","parentAnchor","l2","e1","e2","nextPos","s1","s2","keyToNewIndexMap","j","patched","toBePatched","moved","maxNewIndexSoFar","newIndexToOldIndexMap","prevChild","newIndex","increasingNewIndexSequence","len","arrI","getSequence","nextIndex","move","moveType","leave","delayLeave","afterLeave","performLeave","doRemove","deactivate","shouldInvokeDirs","shouldInvokeVnodeHook","onVnodeBeforeUnmount","unmountComponent","onVnodeUnmounted","removeFragment","performRemove","_vnode","mt","mc","pc","pbc","o","createApp","baseCreateRenderer","allowed","ch1","ch2","currentBlock","openBlock","disableTracking","isBlockTreeEnabled","setupBlock","createElementBlock","createBaseVNode","createBlock","isVNode","__v_isVNode","normalizeKey","normalizeRef","ref_key","ref_for","isBlockNode","needFullChildrenNormalization","__v_skip","ssContent","ssFallback","targetAnchor","staticCount","normalizeChildren","normalize","cloned","__vccOpts","guardReactiveProps","klass","__isSuspense","isSuspense","__isTeleport","isTeleport","extraProps","mergeRef","mergedProps","toMerge","incoming","mergeProps","createTextVNode","text","flag","createCommentVNode","asBlock","memo","slot","slotFlag","__ssrInlineRender","ssrRender","skipOptions","getterOrOptions","debugOptions","setter","onlyGetter","computed$1","h","propsOrChildren","doc","document","templateContainer","nodeOps","insertBefore","removeChild","tag","createElementNS","multiple","setAttribute","createTextNode","node","nodeValue","textContent","querySelector","selector","content","before","previousSibling","lastChild","innerHTML","template","wrapper","firstChild","appendChild","importantRE","setStyle","setProperty","prefixed","rawName","prefixCache","prefixes","autoPrefix","xlinkNS","_getNow","skipTimestampCheck","Date","now","createEvent","timeStamp","ffMatch","navigator","userAgent","cachedNow","reset","addEventListener","patchEvent","prevValue","nextValue","invokers","_vei","existingInvoker","optionsModifierRE","parseName","invoker","initialValue","attached","originalStop","stopImmediatePropagation","_stopped","patchStopImmediatePropagation","getNow","createInvoker","removeEventListener","nativeOnRE","getModelAssigner","onCompositionStart","composing","onCompositionEnd","dispatchEvent","Event","vModelText","created","lazy","_assign","castToNumber","domValue","beforeUpdate","activeElement","vModelCheckbox","modelValue","_modelValue","elementValue","getValue","checked","found","filtered","getCheckboxValue","setChecked","vModelRadio","vModelSelect","isSetModel","selectedVal","selected","setSelected","_binding","isMultiple","option","optionValue","selectedIndex","vModelDynamic","callModelHook","tagName","resolveDynamicModel","vShow","beforeMount","_vod","display","setDisplay","beforeUnmount","rendererOptions","transitionClasses","_vtc","join","removeAttribute","className","patchClass","isCssString","currentDisplay","patchStyle","shouldSetAsProp","needRemove","patchDOMProp","_trueValue","_falseValue","removeAttributeNS","setAttributeNS","isBoolean","patchAttr","containerOrSelector","normalizeContainer","SVGElement","Element","tryOnScopeDispose","onScopeDispose","_a","isClient","noop","bypassFilter","invoke","__getOwnPropSymbols$5","getOwnPropertySymbols","__hasOwnProp$5","__propIsEnum$5","propertyIsEnumerable","watchWithFilter","eventFilter","watchOptions","exclude","__objRest$5","__defProp$1","__defProps$1","defineProperties","__getOwnPropDescs$1","getOwnPropertyDescriptors","__getOwnPropSymbols$1","__hasOwnProp$1","__propIsEnum$1","__defNormalProp$1","writable","watchPausable","__objRest$1","pause","resume","isActive","extendFilter","pausableFilter","__spreadValues$1","defaultWindow","defaultDocument","useEventListener","listener","stopWatch","elRef","plain","unrefElement","location","_global","globalKey","handlers","StorageSerializers","boolean","read","write","object","parse","any","string","date","toISOString","useStorage","storage","listenToStorageChanges","writeDefaults","onError","fallback","getSSRHandler","_a2","localStorage","rawInit","guessSerializerType","serializer","pauseWatch","resumeWatch","pausableWatch","removeItem","setItem","getItem","__defProp$5","__defNormalProp$5","useNow","controls","exposeControls","interval","rafId","loop","requestAnimationFrame","cancelAnimationFrame","useRafFn","immediateCallback","timer","clean","clearInterval","setInterval","useIntervalFn","__spreadValues$5","_id","decodePath","path","decodeURI","removeEndingSplash","isLinkHttp","link","getServerURL","serverURL","getWordLimit","wordLimit","padWithZeros","vNumber","width","numAsString","getTimeAgo","time","timepassed","days","floor","leave1","hours","leave2","minutes","leave3","round","seconds","vDay","getDate","vMonth","getMonth","getFullYear","dateFormat","fetchEmoji","emojiStore","info","fetch","resp","json","emojiInfo","folder","getLink","prefix","message","JSON_HEADERS","errorCheck","errno","TypeError","errmsg","updateComment","lang","token","objectId","headers","Authorization","body","fetchPageviews","paths","signal","encodeURIComponent","counts","updatePageviews","getRoot","HTMLElement","isImage","getImagefromDataTransfer","items","image","find","getAsFile","getDefaults","baseUrl","breaks","extensions","gfm","headerIds","headerPrefix","highlight","langPrefix","mangle","pedantic","sanitize","sanitizer","silent","smartLists","smartypants","tokenizer","walkTokens","xhtml","defaults","escapeTest","escapeReplace","escapeTestNoEncode","escapeReplaceNoEncode","escapeReplacements","getEscapeReplacement","ch","escape","html","encode","unescapeTest","unescape","fromCharCode","substring","caret","edit","regex","getRegex","nonWordAndColonTest","originIndependentUrl","cleanUrl","base","href","prot","decodeURIComponent","baseUrls","justDomain","rtrim","relativeBase","protocol","domain","resolveUrl","encodeURI","noopTest","exec","merge","splitCells","tableRow","count","cells","offset","escaped","curr","shift","invert","suffLen","currChar","checkSanitizeDeprecation","warn","repeatString","pattern","outputLink","cap","lexer","title","state","inLink","tokens","inlineTokens","Tokenizer","space","src","rules","block","newline","code","codeBlockStyle","fences","matchIndentToCode","indentToCode","matchIndentInNode","indentInNode","indentCodeCompensation","heading","trimmed","depth","inline","hr","blockquote","blockTokens","istask","ischecked","indent","blankLine","endsWithBlankLine","line","nextLine","rawLine","itemContents","endEarly","bull","isordered","ordered","loose","itemRegex","trimLeft","search","nextBulletRegex","hrRegex","task","trimRight","top","spacers","hasMultipleLineBreaks","every","chars","lineBreaks","char","pre","table","header","align","rows","row","lheading","paragraph","inRawBlock","trimmedUrl","rtrimSlash","lastParenIndex","level","findClosingBracket","linkLen","_escapes","reflink","links","nolink","emStrong","maskedSrc","prevChar","lDelim","nextChar","punctuation","lLength","rDelim","rLength","delimTotal","midDelimTotal","endReg","rDelimAst","rDelimUnd","lastIndex","codespan","hasNonSpaceChars","hasSpaceCharsOnBothEnds","br","del","autolink","url","prevCapZero","_backpedal","inlineText","_paragraph","_label","_title","bullet","listItemStart","_tag","_comment","normal","reflinkSearch","charCodeAt","random","_punctuation","blockSkip","escapedEmSt","_scheme","_email","_attribute","_href","strong","endAst","endUnd","em","_extended_email","Lexer","inlineQueue","static","lex","lastToken","cutSrc","lastParagraphClipped","leading","tabs","repeat","extTokenizer","startBlock","startIndex","tempSrc","tempStart","getStartIndex","errMsg","Error","keepPrevChar","lastIndexOf","startInline","Renderer","infostring","quote","slugger","slug","listitem","checkbox","tablerow","tablecell","flags","TextRenderer","Slugger","serialize","getNextSafeSlug","originalSlug","isDryRun","occurenceAccumulator","dryrun","Parser","textRenderer","parseInline","l3","cell","itemBody","renderers","parser","marked","pending","setTimeout","setOptions","newDefaults","opts","childTokens","hasExtensions","pack","ext","prevRenderer","prevTokenizer","lexInline","inlineMathStart","inlineMathReg","blockMathReg","parseEmoji","emojiMap","parseMarkdown","highlighter","texRenderer","idx","markedTexExtensions","getQuery","element","dataset","getAttribute","fetchGif","keyword","pos","limit","query","URLSearchParams","userInfoStorage","useUserInfo","likeStorage","useLikeStorage","commentCount","pathname","controller","AbortController","elements","querySelectorAll","userInfo","fetchCommentCount","innerText","abort","bubbles","initEvent","destroy","getComputedStyle","nodeName","d","clientWidth","height","resize","overflowY","overflowX","wordWrap","boxSizing","paddingTop","paddingBottom","borderTopWidth","borderBottomWidth","scrollHeight","scrollTop","documentElement","offsetHeight","_export_sfc","sfc","_sfc_main","columnWidth","gap","rtl","resizeObserver","wall","columns","getColumnCount","getBoundingClientRect","fillColumns","async","itemIndex","columnDivs","reverse","redraw","force","fill","scrollY","scrollTo","ResizeObserver","observe","unobserve","LoadingIcon","viewBox","preserveAspectRatio","cx","cy","stroke","strokeWidth","attributeName","repeatCount","dur","keyTimes","CloseIcon","EmojiIcon","ImageIcon","ImageWall","_createElementBlock","_normalizeStyle","_openBlock","_Fragment","_renderList","column","columnIndex","media","tinygif","loading","onClick","_hoisted_2","MarkdownIcon","ariaHidden","PreviewIcon","GifIcon","rootId","replyId","replyUser","editor","userMeta","nick","mail","inputRefs","editorRef","imageUploadRef","emojiButtonRef","emojiPopupRef","gifButtonRef","gifPopupRef","gifSearchInputRef","emoji","emojiTabIndex","showEmoji","showGif","showPreview","previewText","wordNumber","gifData","cursor","isWordNumberLegal","isSubmitting","isLogin","canUploadImage","imageUploader","content2","textArea","startPosition","selectionStart","endPosition","selectionEnd","focus","uploadImage","uploadText","uploading","submitComment","login","wordLimit2","requiredMeta","ua","display_name","email","alert","nickError","mailError","anonymous","wordHint","pid","rid","at","postComment","popupHandler","contains","onImageWallScroll","clientHeight","finally","results","onGifSearch","func","timeout","clearTimeout","throttle","config2","wordNumber2","showGif2","getWords","accumulator","getChinese","getWordNumber","autosize","emojiConfig","getEmojis","emojis","all","emojiInfos","icon","onChange","inputElement","files","onDrop","dataTransfer","preventDefault","onKeyDown","ctrlKey","metaKey","onPaste","clipboardData","onLogin","left","innerWidth","innerHeight","open","postMessage","close","remember","sessionStorage","onLogout","onProfile","store","_hoisted_1","_hoisted_3","_hoisted_7","_hoisted_11","_createElementVNode","_hoisted_14","_hoisted_15","rel","_hoisted_21","_hoisted_22","logout","_cache","_createVNode","_component_CloseIcon","_hoisted_4","avatar","alt","_hoisted_5","_toDisplayString","_hoisted_6","_normalizeClass","kind","for","optional","$event","_hoisted_9","_vModelDynamic","onKeydown","_hoisted_10","_withDirectives","_hoisted_12","preview","_hoisted_13","_hoisted_16","_component_MarkdownIcon","actived","_component_EmojiIcon","_hoisted_17","_vShow","gif","_component_GifIcon","_hoisted_18","accept","_component_ImageIcon","_hoisted_19","_createCommentVNode","_component_PreviewIcon","_hoisted_20","_createTextVNode","_hoisted_23","_hoisted_24","_hoisted_25","_hoisted_26","disabled","_createBlock","_component_LoadingIcon","submit","gifSearchPlaceholder","onInput","_hoisted_28","_component_ImageWall","onInsert","onScroll","_hoisted_29","_hoisted_30","referrerPolicy","_hoisted_32","_hoisted_33","_hoisted_35","cancelReply","_hoisted_36","commentStatus","required","reply","CommentBox","DeleteIcon","LikeIcon","ReplyIcon","VerifiedIcon","likes","link2","like","useTimeAgo","insertedAt","isAdmin","isOwner","user_id","isReplyingCurrent","CommentCard","_component_VerifiedIcon","admin","_hoisted_8","label","sticky","_component_DeleteIcon","cancelLike","_component_LikeIcon","_component_ReplyIcon","addr","browser","os","status","_component_CommentBox","onSubmit","onCancelReply","_component_CommentCard","onReply","onLike","onDelete","onStatus","onSticky","props2","dark","pageSize","copyright","more","getConfig","page","totalPages","darkmodeStyle","getDarkStyle","css","isLoaded","manual","cssRef","load","getElementById","head","unload","useStyleTag","fetchComment","pageNumber","fetchCommentList","refresh","parentProvides","i18n","loadMore","repliedComment","onStatusChange","status2","confirm","deleteComment","_item","childIndex","hasLiked","likeComment","sofa","renderVisitorCount","countElements","pageviewCount","normalElements","elementsNeedstoBeFetched","init","pageview","updateCommentCount","updatePageviewCount","Waline","stopComment","stopPageview","RecentComments","fetchRecentComment","comments"],"mappings":"AAEA,MAAMA,EAA8B,CAAC,OAAQ,OAAQ,QAExCC,EAAWC,GACtBA,EAAKC,QAAQC,GAASJ,EAAcK,SAASD,KAIlCE,EAAsBC,GACjC,IAAIC,SAAQ,CAACC,EAASC,KACpB,MAAMC,EAAS,IAAIC,WACnBD,EAAOE,cAAcN,GACrBI,EAAOG,OAAS,IAAYL,EAAQE,EAAOI,QAAQC,YAAc,IACjEL,EAAOM,QAAUP,KAGRQ,EAAsBC,IACnB,IAAdA,EACI,wDACA,8DCUAC,EAAS,IAAIC,OACjB,IALA,wFAKgBC,UAJQ,IAIoBA,eAHlB,uBAGqDA,cAFpD,uBAEuFA,WAClH,OAGIC,EAAS,CACb,SACA,SACA,SACA,SACA,SACA,SACA,SACA,SACA,SACA,SACA,SACA,SACA,UAEIC,EAAgC,GAEzBC,EAAsBC,IACjC,IAAIC,EAAQ,EAEZ,OAAOD,EAAME,QAAQR,GAAQ,CAACS,EAAQC,EAAcC,KAClD,GAAIA,EAAS,MAAO,kCAAkCA,WACtD,GAAa,MAATD,EAAc,MAAO,OAEzB,IAAIE,EAEAR,EAAMM,GAAOE,EAAQR,EAAMM,IAE7BE,EAAQT,EAAOI,GACfH,EAAMM,GAAQE,GAGhB,MAAMC,EAAM,wBAAwBD,MAAUF,WAI9C,OAFAH,IAAUA,EAAQJ,EAAOW,OAElBD,MCrELE,EAAa,CACjB,OACA,YACA,OACA,YACA,OACA,WACA,cACA,OACA,SACA,OACA,aACA,QACA,cACA,UACA,UACA,OACA,UACA,QACA,cACA,UACA,UACA,QACA,OACA,MACA,YACA,QACA,SACA,QACA,SACA,OACA,WACA,YACA,SACA,SACA,SACA,SACA,SACA,SACA,MACA,wBAGWC,EAAkBC,GAC7BC,OAAOC,YACLF,EAAOG,KAAI,CAACpC,EAAMuB,IAAU,CAACQ,EAAWR,GAAQvB,MC7CpD,IAAAqC,EAAeL,EAAe,CAC5B,WACA,wCACA,SACA,qCACA,UACA,WACA,kBACA,kBACA,SACA,OACA,cACA,QACA,eACA,WACA,UACA,eACA,UACA,QACA,eACA,cACA,cACA,YACA,WACA,WACA,YACA,QACA,SACA,QACA,SACA,QACA,2EACA,YACA,UACA,UACA,OACA,UACA,QACA,QACA,MACA,eCxCFM,EAAeN,EAAe,CAC5B,SACA,yBACA,UACA,mBACA,MACA,QACA,UACA,aACA,OACA,OACA,cACA,OACA,QACA,OACA,KACA,UACA,QACA,MACA,YACA,KACA,KACA,MACA,KACA,OACA,SACA,SACA,QACA,MACA,SACA,MACA,gDACA,KACA,OACA,OACA,OACA,SACA,KACA,MACA,MACA,WCxCFO,EAAeP,EAAe,CAC5B,KACA,aACA,KACA,aACA,KACA,KACA,OACA,SACA,KACA,KACA,OACA,KACA,OACA,KACA,KACA,UACA,KACA,KACA,OACA,KACA,MACA,MACA,KACA,KACA,OACA,KACA,KACA,KACA,KACA,IACA,+BACA,KACA,KACA,KACA,KACA,KACA,KACA,KACA,MACA,UCxCFQ,EAAeR,EAAe,CAC5B,KACA,KACA,KACA,KACA,aACA,aACA,OACA,SACA,KACA,KACA,OACA,KACA,OACA,KACA,KACA,UACA,KACA,KACA,OACA,KACA,MACA,MACA,KACA,KACA,OACA,KACA,KACA,KACA,KACA,IACA,+BACA,KACA,KACA,KACA,KACA,KACA,KACA,KACA,MACA,UCxCFS,EAAeT,EAAe,CAC5B,UACA,0CACA,SACA,8CACA,UACA,WACA,kBACA,4BACA,SACA,OACA,cACA,YACA,oBACA,cACA,YACA,mBACA,aACA,QACA,gBACA,iBACA,gBACA,cACA,aACA,cACA,WACA,SACA,OACA,QACA,SACA,WACA,gFACA,UACA,UACA,UACA,OACA,UACA,QACA,QACA,MACA,kBCxCFU,EAAeV,EAAe,CAC5B,YACA,uCACA,YACA,yDACA,WACA,iBACA,uBACA,yBACA,YACA,OACA,cACA,WACA,iBACA,cACA,WACA,oBACA,SACA,SACA,wBACA,eACA,wBACA,wBACA,aACA,eACA,WACA,iBACA,mBACA,QACA,SACA,QACA,8EACA,YACA,UACA,UACA,OACA,UACA,QACA,QACA,MACA,cC9BW,MAAAW,EAA0B,CACrCC,GAAI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"}
|
|
1
|
+
{"version":3,"file":"waline.esm.js","sources":["../src/config/default.ts","../src/config/highlighter.ts","../src/config/i18n/generate.ts","../src/config/i18n/en.ts","../src/config/i18n/jp.ts","../src/config/i18n/zh-CN.ts","../src/config/i18n/zh-TW.ts","../src/config/i18n/pt-BR.ts","../src/config/i18n/ru.ts","../src/config/i18n/index.ts","../src/composables/inputs.ts","../src/utils/path.ts","../src/utils/config.ts","../src/utils/darkmode.ts","../src/utils/date.ts","../src/utils/emoji.ts","../src/utils/error.ts","../src/utils/fetch.ts","../src/utils/getRoot.ts","../src/utils/image.ts","../src/utils/markedMathExtension.ts","../src/utils/markdown.ts","../src/utils/query.ts","../src/composables/userInfo.ts","../src/composables/like.ts","../src/comment.ts","../src/components/Icons.ts","../src/components/ImageWall.vue","../src/components/CommentBox.vue","../src/utils/wordCount.ts","../src/components/CommentCard.vue","../src/composables/timeAgo.ts","../src/components/Waline.vue","../src/pageview.ts","../src/init.ts","../src/version.ts","../src/widgets/recentComments.ts"],"sourcesContent":["import type { WalineMeta, WalineSearchOptions } from '../typings';\n\nconst availableMeta: WalineMeta[] = ['nick', 'mail', 'link'];\n\nexport const getMeta = (meta: WalineMeta[]): WalineMeta[] =>\n meta.filter((item) => availableMeta.includes(item));\n\nexport const defaultLang = 'zh-CN';\n\nexport const defaultUploadImage = (file: File): Promise<string> =>\n new Promise((resolve, reject) => {\n const reader = new FileReader();\n\n reader.readAsDataURL(file);\n reader.onload = (): void => resolve(reader.result?.toString() || '');\n reader.onerror = reject;\n });\n\nexport const defaultTexRenderer = (blockMode: boolean): string =>\n blockMode === true\n ? '<p class=\"wl-tex\">Tex is not available in preview</p>'\n : '<span class=\"wl-tex\">Tex is not available in preview</span>';\n\nexport const getDefaultSearchOptions = (): WalineSearchOptions => {\n interface FetchGifRequest {\n keyword: string;\n pos?: string;\n }\n\n type GifFormat =\n | 'gif'\n | 'mediumgif'\n | 'tinygif'\n | 'nanogif'\n | 'mp4'\n | 'loopedmp4'\n | 'tinymp4'\n | 'nanomp4'\n | 'webm'\n | 'tinywebm'\n | 'nanowebm';\n\n interface MediaObject {\n preview: string;\n url: string;\n dims: number[];\n size: number;\n }\n\n interface GifObject {\n created: number;\n hasaudio: boolean;\n id: string;\n media: Record<GifFormat, MediaObject>[];\n tags: string[];\n title: string;\n itemurl: string;\n hascaption: boolean;\n url: string;\n }\n\n interface FetchGifResponse {\n next: string;\n results: GifObject[];\n }\n\n const state = {\n next: '',\n };\n\n const fetchGif = ({\n keyword,\n pos,\n }: FetchGifRequest): Promise<FetchGifResponse> => {\n const baseUrl = `https://g.tenor.com/v1/search`;\n const query = new URLSearchParams('media_filter=minimal');\n\n query.set('key', 'PAY5JLFIH6V6');\n query.set('limit', '20');\n query.set('pos', pos || '');\n query.set('q', keyword);\n\n return fetch(`${baseUrl}?${query.toString()}`, {\n headers: {\n // eslint-disable-next-line @typescript-eslint/naming-convention\n 'Content-Type': 'application/json',\n },\n })\n .then((resp) => resp.json() as Promise<FetchGifResponse>)\n .catch(() => ({ next: pos || '', results: [] }));\n };\n\n return {\n search: (word = '') =>\n fetchGif({ keyword: word }).then((resp) => {\n state.next = resp.next;\n\n return resp.results.map((item) => ({\n title: item.title,\n src: item.media[0].tinygif.url,\n }));\n }),\n more: (word) =>\n fetchGif({ keyword: word, pos: state.next }).then((resp) => {\n state.next = resp.next;\n\n return resp.results.map((item) => ({\n title: item.title,\n src: item.media[0].tinygif.url,\n }));\n }),\n };\n};\n","/**\n * The MIT License (MIT)\n *\n * Copyright (c) egoist <0x142857@gmail.com> (https://egoistian.com)\n *\n * Permission is hereby granted, free of charge, to any person obtaining a copy\n * of this software and associated documentation files (the \"Software\"), to deal\n * in the Software without restriction, including without limitation the rights\n * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n * copies of the Software, and to permit persons to whom the Software is\n * furnished to do so, subject to the following conditions:\n *\n * The above copyright notice and this permission notice shall be included in\n * all copies or substantial portions of the Software.\n *\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n * THE SOFTWARE.\n *\n */\n\nconst WORD_REGEXP =\n /[\\u4E00-\\u9FFF\\u3400-\\u4dbf\\uf900-\\ufaff\\u3040-\\u309f\\uac00-\\ud7af\\u0400-\\u04FF]+|\\w+/;\nconst LEFT_ANGLE_REGEXP = /</;\nconst LINE_COMMENT_REGEXP = /(?:^|\\s)\\/\\/(.+?)$/gm;\nconst BLOCK_COMMENT_REGEXP = /\\/\\*([\\S\\s]*?)\\*\\//gm;\nconst REGEXP = new RegExp(\n `(${WORD_REGEXP.source}|${LEFT_ANGLE_REGEXP.source})|((?:${LINE_COMMENT_REGEXP.source})|(?:${BLOCK_COMMENT_REGEXP.source}))`,\n 'gmi'\n);\n\nconst COLORS = [\n '23AC69',\n '91C132',\n 'F19726',\n 'E8552D',\n '1AAB8E',\n 'E1147F',\n '2980C1',\n '1BA1E6',\n '9FA0A0',\n 'F19726',\n 'E30B20',\n 'E30B20',\n 'A3338B',\n];\nconst cache: Record<string, string> = {};\n\nexport const defaultHighlighter = (input: string): string => {\n let index = 0;\n\n return input.replace(REGEXP, (_match, word: string, comment: string) => {\n if (comment) return `<span style=\"color: slategray\">${comment}</span>`;\n if (word === '<') return '<';\n\n let color: string;\n\n if (cache[word]) color = cache[word];\n else {\n color = COLORS[index];\n cache[word] = color;\n }\n\n const out = `<span style=\"color: #${color}\">${word}</span>`;\n\n index = ++index % COLORS.length;\n\n return out;\n });\n};\n","import type { WalineLocale } from '../../typings';\n\nconst localeKeys = [\n 'nick',\n 'nickError',\n 'mail',\n 'mailError',\n 'link',\n 'optional',\n 'placeholder',\n 'sofa',\n 'submit',\n 'like',\n 'cancelLike',\n 'reply',\n 'cancelReply',\n 'comment',\n 'refresh',\n 'more',\n 'preview',\n 'emoji',\n 'uploadImage',\n 'seconds',\n 'minutes',\n 'hours',\n 'days',\n 'now',\n 'uploading',\n 'login',\n 'logout',\n 'admin',\n 'sticky',\n 'word',\n 'wordHint',\n 'anonymous',\n 'level0',\n 'level1',\n 'level2',\n 'level3',\n 'level4',\n 'level5',\n 'gif',\n 'gifSearchPlaceholder',\n 'profile',\n];\n\nexport const generateLocale = (locale: string[]): WalineLocale =>\n Object.fromEntries(\n locale.map((item, index) => [localeKeys[index], item])\n ) as unknown as WalineLocale;\n","import { generateLocale } from './generate';\n\nexport default generateLocale([\n 'NickName',\n 'NickName cannot be less than 3 bytes.',\n 'E-Mail',\n 'Please confirm your email address.',\n 'Website',\n 'Optional',\n 'Comment here...',\n 'No comment yet.',\n 'Submit',\n 'Like',\n 'Cancel like',\n 'Reply',\n 'Cancel reply',\n 'Comments',\n 'Refresh',\n 'Load More...',\n 'Preview',\n 'Emoji',\n 'Upload Image',\n 'seconds ago',\n 'minutes ago',\n 'hours ago',\n 'days ago',\n 'just now',\n 'Uploading',\n 'Login',\n 'logout',\n 'Admin',\n 'Sticky',\n 'Words',\n 'Please input comments between $0 and $1 words!\\n Current word number: $2',\n 'Anonymous',\n 'Dwarves',\n 'Hobbits',\n 'Ents',\n 'Wizards',\n 'Elves',\n 'Maiar',\n 'GIF',\n 'Search GIF',\n 'Profile',\n]);\n","import { generateLocale } from './generate';\n\nexport default generateLocale([\n 'ニックネーム',\n '3バイト以上のニックネームをご入力ください.',\n 'メールアドレス',\n 'メールアドレスをご確認ください.',\n 'サイト',\n 'オプション',\n 'ここにコメント',\n 'コメントしましょう~',\n '提出する',\n 'Like',\n 'Cancel like',\n '返信する',\n 'キャンセル',\n 'コメント',\n '更新',\n 'さらに読み込む',\n 'プレビュー',\n '絵文字',\n '画像をアップロード',\n '秒前',\n '分前',\n '時間前',\n '日前',\n 'たっだ今',\n 'アップロード',\n 'ログインする',\n 'ログアウト',\n '管理者',\n 'トップに置く',\n 'ワード',\n 'コメントは $0 から $1 ワードの間でなければなりません!\\n 現在の単語番号: $2',\n '匿名',\n 'うえにん',\n 'なかにん',\n 'しもおし',\n '特にしもおし',\n 'かげ',\n 'なぬし',\n 'GIF',\n '探す GIF',\n '個人情報',\n]);\n","import { generateLocale } from './generate';\n\nexport default generateLocale([\n '昵称',\n '昵称不能少于3个字符',\n '邮箱',\n '请填写正确的邮件地址',\n '网址',\n '可选',\n '欢迎评论',\n '来发评论吧~',\n '提交',\n '喜欢',\n '取消喜欢',\n '回复',\n '取消回复',\n '评论',\n '刷新',\n '加载更多...',\n '预览',\n '表情',\n '上传图片',\n '秒前',\n '分钟前',\n '小时前',\n '天前',\n '刚刚',\n '正在上传',\n '登录',\n '退出',\n '博主',\n '置顶',\n '字',\n '评论字数应在 $0 到 $1 字之间!\\n当前字数:$2',\n '匿名',\n '潜水',\n '冒泡',\n '吐槽',\n '活跃',\n '话痨',\n '传说',\n '表情包',\n '搜索表情包',\n '个人资料',\n]);\n","import { generateLocale } from './generate';\n\nexport default generateLocale([\n '暱稱',\n '暱稱不能少於3個字元',\n '郵箱',\n '請填寫正確的郵件地址',\n '網址',\n '可選',\n '歡迎評論',\n '來發評論吧~',\n '提交',\n '喜歡',\n '取消喜歡',\n '回覆',\n '取消回覆',\n '評論',\n '刷新',\n '載入更多...',\n '預覽',\n '表情',\n '上傳圖片',\n '秒前',\n '分鐘前',\n '小時前',\n '天前',\n '剛剛',\n '正在上傳',\n '登錄',\n '退出',\n '博主',\n '置頂',\n '字',\n '評論字數應在 $0 到 $1 字之間!\\n當前字數:$2',\n '匿名',\n '潛水',\n '冒泡',\n '吐槽',\n '活躍',\n '話癆',\n '傳說',\n '表情包',\n '搜索表情包',\n '個人資料',\n]);\n","import { generateLocale } from './generate';\n\nexport default generateLocale([\n 'Apelido',\n 'Apelido não pode ser menor que 3 bytes.',\n 'E-Mail',\n 'Por favor, confirme seu endereço de e-mail.',\n 'Website',\n 'Opcional',\n 'Comente aqui...',\n 'Nenhum comentário, ainda.',\n 'Enviar',\n 'Like',\n 'Cancel like',\n 'Responder',\n 'Cancelar resposta',\n 'Comentários',\n 'Refrescar',\n 'Carregar Mais...',\n 'Visualizar',\n 'Emoji',\n 'Enviar Imagem',\n 'segundos atrás',\n 'minutos atrás',\n 'horas atrás',\n 'dias atrás',\n 'agora mesmo',\n 'Enviando',\n 'Entrar',\n 'Sair',\n 'Admin',\n 'Sticky',\n 'Palavras',\n 'Favor enviar comentário com $0 a $1 palavras!\\n Número de palavras atuais: $2',\n 'Anônimo',\n 'Dwarves',\n 'Hobbits',\n 'Ents',\n 'Wizards',\n 'Elves',\n 'Maiar',\n 'GIF',\n 'Pesquisar GIF',\n 'informação pessoal',\n]);\n","import { generateLocale } from './generate';\n\nexport default generateLocale([\n 'Псевдоним',\n 'Никнейм не может быть меньше 3 байт.',\n 'Эл. адрес',\n 'Пожалуйста, подтвердите адрес вашей электронной почты.',\n 'Веб-сайт',\n 'Необязательный',\n 'Комментарий здесь...',\n 'Пока нет комментариев.',\n 'Отправить',\n 'Like',\n 'Cancel like',\n 'Отвечать',\n 'Отменить ответ',\n 'Комментарии',\n 'Обновить',\n 'Загрузи больше...',\n 'Превью',\n 'эмодзи',\n 'Загрузить изображение',\n 'секунд назад',\n 'несколько минут назад',\n 'несколько часов назад',\n 'дней назад',\n 'прямо сейчас',\n 'Загрузка',\n 'Авторизоваться',\n 'Выход из системы',\n 'Админ',\n 'Липкий',\n 'Слова',\n 'Пожалуйста, введите комментарии от $0 до $1 слов!\\nНомер текущего слова: $2',\n 'Анонимный',\n 'Dwarves',\n 'Hobbits',\n 'Ents',\n 'Wizards',\n 'Elves',\n 'Maiar',\n 'GIF',\n 'Поиск GIF',\n 'Персональные данные',\n]);\n","/* eslint-disable @typescript-eslint/naming-convention */\nimport en from './en';\nimport jp from './jp';\nimport zhCN from './zh-CN';\nimport zhTW from './zh-TW';\nimport ptBR from './pt-BR';\nimport ru from './ru';\n\nimport type { WalineLocale } from '../../typings';\n\nexport type Locales = Record<string, WalineLocale>;\n\nexport const defaultLocales: Locales = {\n zh: zhCN,\n 'zh-cn': zhCN,\n 'zh-CN': zhCN,\n 'zh-tw': zhTW,\n 'zh-TW': zhTW,\n en: en,\n 'en-US': en,\n 'en-us': en,\n jp: jp,\n 'jp-jp': jp,\n 'jp-JP': jp,\n 'pt-br': ptBR,\n 'pt-BR': ptBR,\n ru: ru,\n 'ru-ru': ru,\n 'ru-RU': ru,\n};\n","import { useStorage } from '@vueuse/core';\nimport type { RemovableRef } from '@vueuse/core';\n\nexport interface UserMeta {\n nick: string;\n mail: string;\n link: string;\n}\n\nexport const useUserMeta = (): RemovableRef<UserMeta> =>\n useStorage<UserMeta>('WALINE_USER_META', {\n nick: '',\n mail: '',\n link: '',\n });\n\nexport const useEditor = (): RemovableRef<string> =>\n useStorage<string>('WALINE_COMMENT_BOX_EDITOR', '');\n","export const decodePath = (path: string): string => {\n try {\n path = decodeURI(path);\n } catch (err) {\n // ignore error\n }\n\n return path;\n};\n\nexport const removeEndingSplash = (content = ''): string =>\n content.replace(/\\/$/u, '');\n\nexport const isLinkHttp = (link: string): boolean =>\n /^(https?:)?\\/\\//.test(link);\n","import {\n defaultLang,\n defaultLocales,\n defaultUploadImage,\n defaultHighlighter,\n defaultTexRenderer,\n getDefaultSearchOptions,\n getMeta,\n} from '../config';\n\nimport { decodePath, isLinkHttp, removeEndingSplash } from './path';\n\nimport type {\n WalineEmojiInfo,\n WalineEmojiMaps,\n WalineLocale,\n WalineProps,\n} from '../typings';\n\nexport interface WalineEmojiConfig {\n tabs: Pick<WalineEmojiInfo, 'name' | 'icon' | 'items'>[];\n map: WalineEmojiMaps;\n}\n\nexport interface WalineConfig extends Required<Omit<WalineProps, 'wordLimit'>> {\n locale: WalineLocale;\n wordLimit: [number, number] | false;\n // emoji: Promise<EmojiConfig>;\n}\n\nexport const getServerURL = (serverURL: string): string => {\n const result = removeEndingSplash(serverURL);\n\n return isLinkHttp(result) ? result : `https://${result}`;\n};\n\nconst getWordLimit = (\n wordLimit: WalineProps['wordLimit']\n): [number, number] | false =>\n Array.isArray(wordLimit) ? wordLimit : wordLimit ? [0, wordLimit] : false;\n\nconst fallback = <T = unknown>(\n value: T | false | undefined,\n fallback: T\n): T | false =>\n typeof value === 'function' ? value : value === false ? false : fallback;\n\nexport const getConfig = ({\n serverURL,\n\n path = location.pathname,\n lang = defaultLang,\n locale,\n emoji = ['//unpkg.com/@waline/emojis@1.0.1/weibo'],\n meta = ['nick', 'mail', 'link'],\n requiredMeta = [],\n dark = false,\n pageSize = 10,\n wordLimit,\n imageUploader,\n highlighter,\n texRenderer,\n copyright = true,\n login = 'enable',\n search = getDefaultSearchOptions(),\n ...more\n}: WalineProps): WalineConfig => ({\n serverURL: getServerURL(serverURL),\n path: decodePath(path),\n locale: {\n ...(defaultLocales[lang] || defaultLocales[defaultLang]),\n ...(typeof locale === 'object' ? locale : {}),\n } as WalineLocale,\n wordLimit: getWordLimit(wordLimit),\n meta: getMeta(meta),\n requiredMeta: getMeta(requiredMeta),\n imageUploader: fallback(imageUploader, defaultUploadImage),\n highlighter: fallback(highlighter, defaultHighlighter),\n texRenderer: fallback(texRenderer, defaultTexRenderer),\n lang,\n dark,\n emoji,\n pageSize,\n login,\n copyright,\n search,\n ...more,\n});\n","const style = `{--waline-white:#000;--waline-light-grey:#666;--waline-dark-grey:#999;--waline-color:#888;--waline-bgcolor:#1e1e1e;--waline-bgcolor-light:#272727;--waline-bgcolor-hover: #444;--waline-border-color:#333;--waline-disable-bgcolor:#444;--waline-disable-color:#272727;--waline-bq-color:#272727;--waline-info-bgcolor:#272727;--waline-info-color:#666}`;\n\nexport const getDarkStyle = (selector?: string | boolean): string => {\n if (typeof selector === 'string') {\n return selector === 'auto'\n ? `@media(prefers-color-scheme:dark){body${style}}`\n : `${selector}${style}`;\n }\n\n return selector === true ? `:root${style}` : '';\n};\n","import { WalineDateLocale } from '../typings';\n\nconst padWithZeros = (vNumber: number, width: number): string => {\n let numAsString = vNumber.toString();\n\n while (numAsString.length < width) {\n numAsString = '0' + numAsString;\n }\n\n return numAsString;\n};\n\nexport const dateFormat = (date: Date): string => {\n const vDay = padWithZeros(date.getDate(), 2);\n const vMonth = padWithZeros(date.getMonth() + 1, 2);\n const vYear = padWithZeros(date.getFullYear(), 2);\n\n return `${vYear}-${vMonth}-${vDay}`;\n};\n\nexport const getTimeAgo = (\n date: Date | string,\n now: Date,\n locale: WalineDateLocale\n): string => {\n if (!date) return '';\n\n const time =\n typeof date === 'string'\n ? new Date(date.indexOf(' ') !== -1 ? date.replace(/-/g, '/') : date)\n : date;\n\n const timepassed = now.getTime() - time.getTime();\n\n const days = Math.floor(timepassed / (24 * 3600 * 1000));\n\n if (days === 0) {\n // 计算相差小时数\n\n // 计算天数后剩余的毫秒数\n const leave1 = timepassed % (24 * 3600 * 1000);\n const hours = Math.floor(leave1 / (3600 * 1000));\n\n if (hours === 0) {\n //计算相差分钟数\n\n // 计算小时数后剩余的毫秒数\n const leave2 = leave1 % (3600 * 1000);\n const minutes = Math.floor(leave2 / (60 * 1000));\n\n // 计算相差秒数\n if (minutes === 0) {\n // 计算分钟数后剩余的毫秒数\n const leave3 = leave2 % (60 * 1000);\n const seconds = Math.round(leave3 / 1000);\n\n return `${seconds} ${locale.seconds}`;\n }\n\n return `${minutes} ${locale.minutes}`;\n }\n\n return `${hours} ${locale.hours}`;\n }\n\n if (days < 0) return locale.now;\n\n if (days < 8) return `${days} ${locale.days}`;\n\n return dateFormat(time);\n};\n","import { useStorage } from '@vueuse/core';\nimport { removeEndingSplash } from './path';\n\nimport type { WalineEmojiConfig } from './config';\nimport type { WalineEmojiInfo } from '../typings';\n\nconst hasVersion = (url: string): boolean =>\n Boolean(/@[0-9]+\\.[0-9]+\\.[0-9]+/.test(url));\n\nconst fetchEmoji = (link: string): Promise<WalineEmojiInfo> => {\n const emojiStore = useStorage<Record<string, WalineEmojiInfo>>(\n 'WALINE_EMOJI',\n {}\n );\n\n const result = hasVersion(link);\n\n if (result) {\n const info = emojiStore.value[link];\n\n if (info) return Promise.resolve(info);\n }\n\n return fetch(`${link}/info.json`)\n .then((resp) => resp.json() as Promise<Omit<WalineEmojiInfo, 'folder'>>)\n .then((emojiInfo) => {\n const info = {\n folder: link,\n ...emojiInfo,\n };\n\n if (result) emojiStore.value[link] = info;\n\n return info;\n });\n};\n\nconst getLink = (name: string, folder = '', prefix = '', type = ''): string =>\n `${folder ? `${folder}/` : ''}${prefix}${name}${type ? `.${type}` : ''}`;\n\nexport const getEmojis = (\n emojis: (string | WalineEmojiInfo)[]\n): Promise<WalineEmojiConfig> =>\n Promise.all(\n emojis.map((emoji) =>\n typeof emoji === 'string'\n ? fetchEmoji(removeEndingSplash(emoji))\n : Promise.resolve(emoji)\n )\n ).then((emojiInfos) => {\n const emojiConfig: WalineEmojiConfig = {\n tabs: [],\n map: {},\n };\n\n emojiInfos.forEach((emojiInfo) => {\n const { name, folder, icon, prefix, type, items } = emojiInfo;\n\n emojiConfig.tabs.push({\n name,\n icon: getLink(icon, folder, prefix, type),\n items: items.map((item) => {\n const key = `${prefix || ''}${item}`;\n\n emojiConfig.map[key] = getLink(item, folder, prefix, type);\n\n return key;\n }),\n });\n });\n\n return emojiConfig;\n });\n","export const errorHandler = (err: Error): void => {\n if (err.name !== 'AbortError') console.error(err.message);\n};\n","import type { WalineComment, WalineCommentData } from '../typings';\n\nexport interface FetchErrorData {\n errno: number;\n errmsg: string;\n}\n\nconst JSON_HEADERS: Record<string, string> = {\n // eslint-disable-next-line @typescript-eslint/naming-convention\n 'Content-Type': 'application/json',\n};\n\nconst errorCheck = <T = unknown>(data: T | FetchErrorData, name = ''): T => {\n if (typeof data === 'object' && (data as FetchErrorData).errno)\n throw new TypeError(\n `Fetch ${name} failed with ${(data as FetchErrorData).errno}: ${\n (data as FetchErrorData).errmsg\n }`\n );\n\n return data as T;\n};\n\nexport interface FetchCountOptions {\n serverURL: string;\n lang: string;\n paths: string[];\n signal: AbortSignal;\n token?: string;\n}\n\nexport const fetchCommentCount = ({\n serverURL,\n lang,\n paths,\n signal,\n token,\n}: FetchCountOptions): Promise<number[]> => {\n const headers: Record<string, string> = {};\n\n if (token) headers.Authorization = `Bearer ${token}`;\n\n return (\n fetch(\n `${serverURL}/comment?type=count&url=${encodeURIComponent(\n paths.join(',')\n )}&lang=${lang}`,\n { signal, headers }\n )\n .then((resp) => resp.json() as Promise<number | number[]>)\n .then((data) => errorCheck(data, 'comment count'))\n // TODO: Improve this API\n .then((counts) => (Array.isArray(counts) ? counts : [counts]))\n );\n};\nexport interface FetchRecentOptions {\n serverURL: string;\n lang: string;\n count: number;\n signal: AbortSignal;\n token?: string;\n}\n\nexport const fetchRecentComment = ({\n serverURL,\n lang,\n count,\n signal,\n token,\n}: FetchRecentOptions): Promise<WalineComment[]> => {\n const headers: Record<string, string> = {};\n\n if (token) headers.Authorization = `Bearer ${token}`;\n\n return fetch(`${serverURL}/comment?type=recent&count=${count}&lang=${lang}`, {\n signal,\n headers,\n })\n .then((resp) => resp.json() as Promise<WalineComment[]>)\n .then((data) => errorCheck(data, 'recent comment'));\n};\n\nexport interface FetchListOptions {\n serverURL: string;\n path: string;\n page: number;\n pageSize: number;\n signal: AbortSignal;\n token?: string;\n lang: string;\n}\n\nexport interface FetchListResult {\n count: number;\n data: WalineComment[];\n totalPages: number;\n}\n\nexport const fetchCommentList = ({\n serverURL,\n lang,\n path,\n page,\n pageSize,\n signal,\n token,\n}: FetchListOptions): Promise<FetchListResult> => {\n const headers: Record<string, string> = {};\n\n if (token) headers.Authorization = `Bearer ${token}`;\n\n return fetch(\n `${serverURL}/comment?path=${encodeURIComponent(\n path\n )}&pageSize=${pageSize}&page=${page}&lang=${lang}`,\n { signal, headers }\n )\n .then((resp) => resp.json() as Promise<FetchListResult>)\n .then((data) => errorCheck(data, 'comment list'));\n};\n\nexport interface PostCommentOptions {\n serverURL: string;\n lang: string;\n token?: string;\n comment: WalineCommentData;\n}\n\nexport interface PostCommentResponse {\n data?: WalineComment;\n errmsg?: string;\n}\n\nexport const postComment = ({\n serverURL,\n lang,\n token,\n comment,\n}: PostCommentOptions): Promise<PostCommentResponse> => {\n const headers: Record<string, string> = {\n // eslint-disable-next-line @typescript-eslint/naming-convention\n 'Content-Type': 'application/json',\n };\n\n if (token) headers.Authorization = `Bearer ${token}`;\n\n return fetch(`${serverURL}/comment?lang=${lang}`, {\n method: 'POST',\n headers,\n body: JSON.stringify(comment),\n }).then((resp) => resp.json() as Promise<PostCommentResponse>);\n};\n\nexport interface DeleteCommentOptions {\n serverURL: string;\n lang: string;\n token: string;\n objectId: string | number;\n}\n\nexport const deleteComment = ({\n serverURL,\n lang,\n token,\n objectId,\n}: DeleteCommentOptions): Promise<void> => {\n const headers: Record<string, string> = {\n Authorization: `Bearer ${token}`,\n };\n\n return fetch(`${serverURL}/comment/${objectId}?lang=${lang}`, {\n method: 'DELETE',\n headers,\n }).then((resp) => resp.json() as Promise<void>);\n};\n\nexport interface LikeCommentOptions {\n serverURL: string;\n lang: string;\n objectId: number | string;\n like: boolean;\n}\n\nexport const likeComment = ({\n serverURL,\n lang,\n objectId,\n like,\n}: LikeCommentOptions): Promise<void> =>\n fetch(`${serverURL}/comment/${objectId}?lang=${lang}`, {\n method: 'PUT',\n headers: JSON_HEADERS,\n body: JSON.stringify({ like }),\n }).then((resp) => resp.json() as Promise<void>);\n\nexport interface UpdateCommentOptions {\n serverURL: string;\n lang: string;\n token: string;\n objectId: number | string;\n status?: 'approved' | 'waiting' | 'spam';\n sticky?: number;\n}\n\nexport const updateComment = ({\n serverURL,\n lang,\n token,\n objectId,\n ...data\n}: UpdateCommentOptions): Promise<void> => {\n const headers: Record<string, string> = {\n // eslint-disable-next-line @typescript-eslint/naming-convention\n 'Content-Type': 'application/json',\n Authorization: `Bearer ${token}`,\n };\n\n return fetch(`${serverURL}/comment/${objectId}?lang=${lang}`, {\n method: 'PUT',\n headers,\n body: JSON.stringify(data),\n }).then((resp) => resp.json() as Promise<void>);\n};\n\nexport interface FetchPageviewsOptions {\n serverURL: string;\n lang: string;\n paths: string[];\n signal: AbortSignal;\n}\n\nexport const fetchPageviews = ({\n serverURL,\n lang,\n paths,\n signal,\n}: FetchPageviewsOptions): Promise<number[]> =>\n fetch(\n `${serverURL}/article?path=${encodeURIComponent(\n paths.join(',')\n )}&lang=${lang}`,\n { signal }\n )\n .then((resp) => resp.json() as Promise<number[] | number>)\n .then((data) => errorCheck(data, 'visit count'))\n // TODO: Improve this API\n .then((counts) => (Array.isArray(counts) ? counts : [counts]));\n\nexport interface UpdatePageviewsOptions {\n serverURL: string;\n lang: string;\n path: string;\n}\n\nexport const updatePageviews = ({\n serverURL,\n lang,\n path,\n}: UpdatePageviewsOptions): Promise<number> =>\n fetch(`${serverURL}/article?lang=${lang}`, {\n method: 'POST',\n headers: JSON_HEADERS,\n body: JSON.stringify({ path }),\n })\n .then((resp) => resp.json() as Promise<number>)\n .then((data) => errorCheck(data, 'visit count'));\n","export const getRoot = (\n el: string | HTMLElement | undefined\n): HTMLElement | null =>\n el instanceof HTMLElement\n ? el\n : typeof el === 'string'\n ? document.querySelector(el)\n : null;\n","const isImage = (item: DataTransferItem): boolean =>\n item.type.includes('image');\n\nexport const getImagefromDataTransfer = (\n items: DataTransferItemList\n): File | null => {\n const image = Array.from(items).find(isImage);\n\n return image ? (image.getAsFile() as File) : null;\n};\n","import type { marked } from 'marked';\nimport type { WalineTexRenderer } from '../typings';\n\nconst inlineMathStart = /\\$.*?\\$/;\nconst inlineMathReg = /^\\$(.*?)\\$/;\nconst blockMathReg = /^(?:\\s{0,3})\\$\\$((?:[^\\n]|\\n[^\\n])+?)\\n{0,1}\\$\\$/;\n\nexport const markedTexExtensions = (\n texRenderer: WalineTexRenderer\n): marked.TokenizerExtension[] => {\n const blockMathExtension: marked.TokenizerExtension = {\n name: 'blockMath',\n level: 'block',\n tokenizer(src: string) {\n const cap = blockMathReg.exec(src);\n\n if (cap !== null) {\n return {\n type: 'html',\n raw: cap[0],\n text: texRenderer(true, cap[1]),\n };\n }\n\n return undefined;\n },\n };\n\n const inlineMathExtension: marked.TokenizerExtension = {\n name: 'inlineMath',\n level: 'inline',\n start(src: string) {\n const idx = src.search(inlineMathStart);\n\n return idx !== -1 ? idx : src.length;\n },\n tokenizer(src: string) {\n const cap = inlineMathReg.exec(src);\n\n if (cap !== null) {\n return {\n type: 'html',\n raw: cap[0],\n text: texRenderer(false, cap[1]),\n };\n }\n\n return undefined;\n },\n };\n\n return [blockMathExtension, inlineMathExtension];\n};\n","import { marked } from 'marked';\nimport { markedTexExtensions } from './markedMathExtension';\n\nimport type {\n WalineEmojiMaps,\n WalineHighlighter,\n WalineTexRenderer,\n} from '../typings';\n\nexport const parseEmoji = (text = '', emojiMap: WalineEmojiMaps = {}): string =>\n text.replace(/:(.+?):/g, (placeholder, key: string) =>\n emojiMap[key]\n ? `<img class=\"wl-emoji\" src=\"${emojiMap[key]}\" alt=\"${key}\">`\n : placeholder\n );\n\nexport interface ParseMarkdownOptions {\n emojiMap: WalineEmojiMaps;\n highlighter: WalineHighlighter | false;\n texRenderer: WalineTexRenderer | false;\n}\n\nexport const parseMarkdown = (\n content: string,\n { emojiMap, highlighter, texRenderer }: ParseMarkdownOptions\n): string => {\n marked.setOptions({\n highlight: highlighter || undefined,\n breaks: true,\n smartLists: true,\n smartypants: true,\n });\n\n if (texRenderer) {\n const extensions = markedTexExtensions(texRenderer);\n\n marked.use({ extensions });\n }\n\n return marked.parse(parseEmoji(content, emojiMap));\n};\n","export const getQuery = (element: HTMLElement): string | null =>\n element.dataset.path || element.getAttribute('id');\n","import { useStorage } from '@vueuse/core';\n\nimport type { Ref } from 'vue';\n\nexport interface UserInfo {\n // eslint-disable-next-line @typescript-eslint/naming-convention\n display_name: string;\n email: string;\n url: string;\n token: string;\n avatar: string;\n mailMd5: string;\n objectId: string | number;\n type: 'administrator' | 'guest';\n}\n\nexport const USER_KEY = 'WALINE_USER';\n\nexport type UserInfoRef = Ref<UserInfo | Record<string, never>>;\n\nlet userInfoStorage: UserInfoRef | null = null;\n\nexport const useUserInfo = (): UserInfoRef =>\n userInfoStorage ||\n (userInfoStorage = useStorage<UserInfo | Record<string, never>>(\n USER_KEY,\n {}\n ));\n","import { useStorage } from '@vueuse/core';\n\nimport type { Ref } from 'vue';\n\nconst LIKE_KEY = 'WALINE_LIKE';\n\nexport type LikeID = number | string;\n\nexport type LikeRef = Ref<LikeID[]>;\n\nlet likeStorage: LikeRef | null = null;\n\nexport const useLikeStorage = (): LikeRef =>\n likeStorage || (likeStorage = useStorage<LikeID[]>(LIKE_KEY, []));\n","import { useUserInfo } from './composables';\nimport {\n decodePath,\n errorHandler,\n fetchCommentCount,\n getServerURL,\n} from './utils';\nimport type { WalineAbort } from './typings';\n\nexport interface WalineCommentCountOptions {\n /**\n * Waline 服务端地址\n *\n * Waline server url\n */\n serverURL: string;\n\n /**\n * 评论数 CSS 选择器\n *\n * Commment count CSS selector\n *\n * @default '.waline-comment-count'\n */\n selector?: string;\n\n /**\n * 需要获取的默认路径\n *\n * Path to be fetched by default\n *\n * @default window.location.pathname\n */\n path?: string;\n\n /**\n * 错误提示消息所使用的语言\n *\n * Language of error message\n *\n * @default 'zh-CN'\n */\n lang?: string;\n}\n\nexport const commentCount = ({\n serverURL,\n path = window.location.pathname,\n selector = '.waline-comment-count',\n lang = 'zh-CN',\n}: // eslint-disable-next-line @typescript-eslint/no-explicit-any\nWalineCommentCountOptions): WalineAbort => {\n const controller = new AbortController();\n\n // comment count\n const elements = document.querySelectorAll<HTMLElement>(selector);\n\n const userInfo = useUserInfo();\n\n if (elements.length)\n void fetchCommentCount({\n serverURL: getServerURL(serverURL),\n paths: Array.from(elements).map((element) =>\n decodePath(element.dataset.path || element.getAttribute('id') || path)\n ),\n lang,\n signal: controller.signal,\n token: userInfo.value?.token,\n })\n .then((counts) => {\n elements.forEach((element, index) => {\n element.innerText = counts[index].toString();\n });\n })\n .catch(errorHandler);\n\n return controller.abort.bind(controller);\n};\n","import { h } from 'vue';\nimport type { FunctionalComponent } from 'vue';\n\nexport const CloseIcon: FunctionalComponent<{ size: number }> = ({ size }) =>\n h(\n 'svg',\n {\n class: 'wl-close-icon',\n viewBox: '0 0 1024 1024',\n width: size,\n height: size,\n },\n [\n h('path', {\n d: 'M697.173 85.333h-369.92c-144.64 0-241.92 101.547-241.92 252.587v348.587c0 150.613 97.28 252.16 241.92 252.16h369.92c144.64 0 241.494-101.547 241.494-252.16V337.92c0-151.04-96.854-252.587-241.494-252.587z',\n fill: 'currentColor',\n }),\n h('path', {\n d: 'm640.683 587.52-75.947-75.861 75.904-75.862a37.29 37.29 0 0 0 0-52.778 37.205 37.205 0 0 0-52.779 0l-75.946 75.818-75.862-75.946a37.419 37.419 0 0 0-52.821 0 37.419 37.419 0 0 0 0 52.821l75.947 75.947-75.776 75.733a37.29 37.29 0 1 0 52.778 52.821l75.776-75.776 75.947 75.947a37.376 37.376 0 0 0 52.779-52.821z',\n fill: '#888',\n }),\n ]\n );\n\nexport const DeleteIcon: FunctionalComponent = () =>\n h(\n 'svg',\n { viewBox: '0 0 1024 1024', width: '24', height: '24' },\n h('path', {\n d: 'm341.013 394.667 27.755 393.45h271.83l27.733-393.45h64.106l-28.01 397.952a64 64 0 0 1-63.83 59.498H368.768a64 64 0 0 1-63.83-59.52l-28.053-397.93h64.128zm139.307 19.818v298.667h-64V414.485h64zm117.013 0v298.667h-64V414.485h64zM181.333 288h640v64h-640v-64zm453.483-106.667v64h-256v-64h256z',\n fill: 'red',\n })\n );\n\nexport const EmojiIcon: FunctionalComponent = () =>\n h(\n 'svg',\n { viewBox: '0 0 1024 1024', width: '24', height: '24' },\n h('path', {\n d: 'M563.2 463.3 677 540c1.7 1.2 3.7 1.8 5.8 1.8.7 0 1.4-.1 2-.2 2.7-.5 5.1-2.1 6.6-4.4l25.3-37.8c1.5-2.3 2.1-5.1 1.6-7.8s-2.1-5.1-4.4-6.6l-73.6-49.1 73.6-49.1c2.3-1.5 3.9-3.9 4.4-6.6.5-2.7 0-5.5-1.6-7.8l-25.3-37.8a10.1 10.1 0 0 0-6.6-4.4c-.7-.1-1.3-.2-2-.2-2.1 0-4.1.6-5.8 1.8l-113.8 76.6c-9.2 6.2-14.7 16.4-14.7 27.5.1 11 5.5 21.3 14.7 27.4zM387 348.8h-45.5c-5.7 0-10.4 4.7-10.4 10.4v153.3c0 5.7 4.7 10.4 10.4 10.4H387c5.7 0 10.4-4.7 10.4-10.4V359.2c0-5.7-4.7-10.4-10.4-10.4zm333.8 241.3-41-20a10.3 10.3 0 0 0-8.1-.5c-2.6.9-4.8 2.9-5.9 5.4-30.1 64.9-93.1 109.1-164.4 115.2-5.7.5-9.9 5.5-9.5 11.2l3.9 45.5c.5 5.3 5 9.5 10.3 9.5h.9c94.8-8 178.5-66.5 218.6-152.7 2.4-5 .3-11.2-4.8-13.6zm186-186.1c-11.9-42-30.5-81.4-55.2-117.1-24.1-34.9-53.5-65.6-87.5-91.2-33.9-25.6-71.5-45.5-111.6-59.2-41.2-14-84.1-21.1-127.8-21.1h-1.2c-75.4 0-148.8 21.4-212.5 61.7-63.7 40.3-114.3 97.6-146.5 165.8-32.2 68.1-44.3 143.6-35.1 218.4 9.3 74.8 39.4 145 87.3 203.3.1.2.3.3.4.5l36.2 38.4c1.1 1.2 2.5 2.1 3.9 2.6 73.3 66.7 168.2 103.5 267.5 103.5 73.3 0 145.2-20.3 207.7-58.7 37.3-22.9 70.3-51.5 98.1-85 27.1-32.7 48.7-69.5 64.2-109.1 15.5-39.7 24.4-81.3 26.6-123.8 2.4-43.6-2.5-87-14.5-129zm-60.5 181.1c-8.3 37-22.8 72-43 104-19.7 31.1-44.3 58.6-73.1 81.7-28.8 23.1-61 41-95.7 53.4-35.6 12.7-72.9 19.1-110.9 19.1-82.6 0-161.7-30.6-222.8-86.2l-34.1-35.8c-23.9-29.3-42.4-62.2-55.1-97.7-12.4-34.7-18.8-71-19.2-107.9-.4-36.9 5.4-73.3 17.1-108.2 12-35.8 30-69.2 53.4-99.1 31.7-40.4 71.1-72 117.2-94.1 44.5-21.3 94-32.6 143.4-32.6 49.3 0 97 10.8 141.8 32 34.3 16.3 65.3 38.1 92 64.8 26.1 26 47.5 56 63.6 89.2 16.2 33.2 26.6 68.5 31 105.1 4.6 37.5 2.7 75.3-5.6 112.3z',\n fill: 'currentColor',\n })\n );\n\nexport const ImageIcon: FunctionalComponent = () =>\n h('svg', { viewBox: '0 0 1024 1024', width: '24', height: '24' }, [\n h('path', {\n d: 'M784 112H240c-88 0-160 72-160 160v480c0 88 72 160 160 160h544c88 0 160-72 160-160V272c0-88-72-160-160-160zm96 640c0 52.8-43.2 96-96 96H240c-52.8 0-96-43.2-96-96V272c0-52.8 43.2-96 96-96h544c52.8 0 96 43.2 96 96v480z',\n fill: 'currentColor',\n }),\n h('path', {\n d: 'M352 480c52.8 0 96-43.2 96-96s-43.2-96-96-96-96 43.2-96 96 43.2 96 96 96zm0-128c17.6 0 32 14.4 32 32s-14.4 32-32 32-32-14.4-32-32 14.4-32 32-32zm462.4 379.2-3.2-3.2-177.6-177.6c-25.6-25.6-65.6-25.6-91.2 0l-80 80-36.8-36.8c-25.6-25.6-65.6-25.6-91.2 0L200 728c-4.8 6.4-8 14.4-8 24 0 17.6 14.4 32 32 32 9.6 0 16-3.2 22.4-9.6L380.8 640l134.4 134.4c6.4 6.4 14.4 9.6 24 9.6 17.6 0 32-14.4 32-32 0-9.6-4.8-17.6-9.6-24l-52.8-52.8 80-80L769.6 776c6.4 4.8 12.8 8 20.8 8 17.6 0 32-14.4 32-32 0-8-3.2-16-8-20.8z',\n fill: 'currentColor',\n }),\n ]);\n\nexport const LikeIcon: FunctionalComponent<{ active: boolean }> = ({\n active = false,\n}: {\n active?: boolean;\n}) =>\n h('svg', { viewBox: '0 0 1024 1024', width: '24', height: '24' }, [\n h('path', {\n d: `M850.654 323.804c-11.042-25.625-26.862-48.532-46.885-68.225-20.022-19.61-43.258-34.936-69.213-45.73-26.78-11.124-55.124-16.727-84.375-16.727-40.622 0-80.256 11.123-114.698 32.135A214.79 214.79 0 0 0 512 241.819a214.79 214.79 0 0 0-23.483-16.562c-34.442-21.012-74.076-32.135-114.698-32.135-29.25 0-57.595 5.603-84.375 16.727-25.872 10.711-49.19 26.12-69.213 45.73-20.105 19.693-35.843 42.6-46.885 68.225-11.453 26.615-17.303 54.877-17.303 83.963 0 27.439 5.603 56.03 16.727 85.117 9.31 24.307 22.659 49.52 39.715 74.981 27.027 40.293 64.188 82.316 110.33 124.915 76.465 70.615 152.189 119.394 155.402 121.371l19.528 12.525c8.652 5.52 19.776 5.52 28.427 0l19.529-12.525c3.213-2.06 78.854-50.756 155.401-121.371 46.143-42.6 83.304-84.622 110.33-124.915 17.057-25.46 30.487-50.674 39.716-74.981 11.124-29.087 16.727-57.678 16.727-85.117.082-29.086-5.768-57.348-17.221-83.963z${\n active\n ? ''\n : 'M512 761.5S218.665 573.55 218.665 407.767c0-83.963 69.461-152.023 155.154-152.023 60.233 0 112.473 33.618 138.181 82.727 25.708-49.109 77.948-82.727 138.18-82.727 85.694 0 155.155 68.06 155.155 152.023C805.335 573.551 512 761.5 512 761.5z'\n }`,\n fill: active ? 'red' : 'currentColor',\n }),\n ]);\n\nexport const PreviewIcon: FunctionalComponent = () =>\n h('svg', { viewBox: '0 0 1024 1024', width: '24', height: '24' }, [\n h('path', {\n d: 'M710.816 654.301c70.323-96.639 61.084-230.578-23.705-314.843-46.098-46.098-107.183-71.109-172.28-71.109-65.008 0-126.092 25.444-172.28 71.109-45.227 46.098-70.756 107.183-70.756 172.106 0 64.923 25.444 126.007 71.194 172.106 46.099 46.098 107.184 71.109 172.28 71.109 51.414 0 100.648-16.212 142.824-47.404l126.53 126.006c7.058 7.06 16.297 10.979 26.406 10.979 10.105 0 19.343-3.919 26.402-10.979 14.467-14.467 14.467-38.172 0-52.723L710.816 654.301zm-315.107-23.265c-65.88-65.88-65.88-172.54 0-238.42 32.069-32.07 74.245-49.149 119.471-49.149 45.227 0 87.407 17.603 119.472 49.149 65.88 65.879 65.88 172.539 0 238.42-63.612 63.178-175.242 63.178-238.943 0zm0 0',\n fill: 'currentColor',\n }),\n h('path', {\n d: 'M703.319 121.603H321.03c-109.8 0-199.469 89.146-199.469 199.38v382.034c0 109.796 89.236 199.38 199.469 199.38h207.397c20.653 0 37.384-16.645 37.384-37.299 0-20.649-16.731-37.296-37.384-37.296H321.03c-68.582 0-124.352-55.77-124.352-124.267V321.421c0-68.496 55.77-124.267 124.352-124.267h382.289c68.582 0 124.352 55.771 124.352 124.267V524.72c0 20.654 16.736 37.299 37.385 37.299 20.654 0 37.384-16.645 37.384-37.299V320.549c-.085-109.8-89.321-198.946-199.121-198.946zm0 0',\n fill: 'currentColor',\n }),\n ]);\n\nexport const MarkdownIcon: FunctionalComponent = () =>\n h(\n 'svg',\n { width: '16', height: '16', ariaHidden: 'true' },\n h('path', {\n d: 'M14.85 3H1.15C.52 3 0 3.52 0 4.15v7.69C0 12.48.52 13 1.15 13h13.69c.64 0 1.15-.52 1.15-1.15v-7.7C16 3.52 15.48 3 14.85 3zM9 11H7V8L5.5 9.92 4 8v3H2V5h2l1.5 2L7 5h2v6zm2.99.5L9.5 8H11V5h2v3h1.5l-2.51 3.5z',\n fill: 'currentColor',\n })\n );\n\nexport const ReplyIcon: FunctionalComponent = () =>\n h(\n 'svg',\n { viewBox: '0 0 1024 1024', width: '24', height: '24' },\n h('path', {\n d: 'M810.667 213.333a64 64 0 0 1 64 64V704a64 64 0 0 1-64 64H478.336l-146.645 96.107a21.333 21.333 0 0 1-33.024-17.856V768h-85.334a64 64 0 0 1-64-64V277.333a64 64 0 0 1 64-64h597.334zm0 64H213.333V704h149.334v63.296L459.243 704h351.424V277.333zm-271.36 213.334v64h-176.64v-64h176.64zm122.026-128v64H362.667v-64h298.666z',\n fill: 'currentColor',\n })\n );\n\nexport const VerifiedIcon: FunctionalComponent = () =>\n h(\n 'svg',\n {\n class: 'verified-icon',\n viewBox: '0 0 1024 1024',\n width: '14',\n height: '14',\n },\n h('path', {\n d: 'm894.4 461.56-54.4-63.2c-10.4-12-18.8-34.4-18.8-50.4v-68c0-42.4-34.8-77.2-77.2-77.2h-68c-15.6 0-38.4-8.4-50.4-18.8l-63.2-54.4c-27.6-23.6-72.8-23.6-100.8 0l-62.8 54.8c-12 10-34.8 18.4-50.4 18.4h-69.2c-42.4 0-77.2 34.8-77.2 77.2v68.4c0 15.6-8.4 38-18.4 50l-54 63.6c-23.2 27.6-23.2 72.4 0 100l54 63.6c10 12 18.4 34.4 18.4 50v68.4c0 42.4 34.8 77.2 77.2 77.2h69.2c15.6 0 38.4 8.4 50.4 18.8l63.2 54.4c27.6 23.6 72.8 23.6 100.8 0l63.2-54.4c12-10.4 34.4-18.8 50.4-18.8h68c42.4 0 77.2-34.8 77.2-77.2v-68c0-15.6 8.4-38.4 18.8-50.4l54.4-63.2c23.2-27.6 23.2-73.2-.4-100.8zm-216-25.2-193.2 193.2a30 30 0 0 1-42.4 0l-96.8-96.8a30.16 30.16 0 0 1 0-42.4c11.6-11.6 30.8-11.6 42.4 0l75.6 75.6 172-172c11.6-11.6 30.8-11.6 42.4 0 11.6 11.6 11.6 30.8 0 42.4z',\n fill: '#27ae60',\n })\n );\n\nexport const LoadingIcon: FunctionalComponent<{ size: number }> = ({ size }) =>\n h(\n 'svg',\n {\n width: size,\n height: size,\n viewBox: '0 0 100 100',\n preserveAspectRatio: 'xMidYMid',\n },\n h(\n 'circle',\n {\n cx: 50,\n cy: 50,\n fill: 'none',\n stroke: 'currentColor',\n strokeWidth: '4',\n r: '40',\n // eslint-disable-next-line @typescript-eslint/naming-convention\n 'stroke-dasharray': '85 30',\n },\n h('animateTransform', {\n attributeName: 'transform',\n type: 'rotate',\n repeatCount: 'indefinite',\n dur: '1s',\n values: '0 50 50;360 50 50',\n keyTimes: '0;1',\n })\n )\n );\n\nexport const GifIcon: FunctionalComponent = () =>\n h(\n 'svg',\n {\n width: 24,\n height: 24,\n fill: 'currentcolor',\n viewBox: '0 0 24 24',\n },\n [\n h('path', {\n style: 'transform: translateY(0.5px)',\n d: 'M18.968 10.5H15.968V11.484H17.984V12.984H15.968V15H14.468V9H18.968V10.5V10.5ZM8.984 9C9.26533 9 9.49967 9.09367 9.687 9.281C9.87433 9.46833 9.968 9.70267 9.968 9.984V10.5H6.499V13.5H8.468V12H9.968V14.016C9.968 14.2973 9.87433 14.5317 9.687 14.719C9.49967 14.9063 9.26533 15 8.984 15H5.984C5.70267 15 5.46833 14.9063 5.281 14.719C5.09367 14.5317 5 14.2973 5 14.016V9.985C5 9.70367 5.09367 9.46933 5.281 9.282C5.46833 9.09467 5.70267 9.001 5.984 9.001H8.984V9ZM11.468 9H12.968V15H11.468V9V9Z',\n }),\n h('path', {\n d: 'M18.5 3H5.75C3.6875 3 2 4.6875 2 6.75V18C2 20.0625 3.6875 21.75 5.75 21.75H18.5C20.5625 21.75 22.25 20.0625 22.25 18V6.75C22.25 4.6875 20.5625 3 18.5 3ZM20.75 18C20.75 19.2375 19.7375 20.25 18.5 20.25H5.75C4.5125 20.25 3.5 19.2375 3.5 18V6.75C3.5 5.5125 4.5125 4.5 5.75 4.5H18.5C19.7375 4.5 20.75 5.5125 20.75 6.75V18Z',\n }),\n ]\n );\n","<!-- forked from https://github.com/DerYeger/vue-masonry-wall/blob/master/src/masonry-wall.vue -->\n\n<!-- MIT License\n\nCopyright (c) 2021 Fuxing Loh, Jan Müller\n\nPermission is hereby granted, free of charge, to any person obtaining a copy\nof this software and associated documentation files (the \"Software\"), to deal\nin the Software without restriction, including without limitation the rights\nto use, copy, modify, merge, publish, distribute, sublicense, and/or sell\ncopies of the Software, and to permit persons to whom the Software is\nfurnished to do so, subject to the following conditions:\n\nThe above copyright notice and this permission notice shall be included in all\ncopies or substantial portions of the Software.\n\nTHE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\nIMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\nFITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\nAUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\nLIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\nOUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE\nSOFTWARE. -->\n\n<template>\n <div ref=\"wall\" class=\"wl-gallery\" :style=\"{ gap: `${gap}px` }\">\n <div\n v-for=\"(column, columnIndex) in columns\"\n :key=\"columnIndex\"\n class=\"wl-gallery-column\"\n :data-index=\"columnIndex\"\n :style=\"{ gap: `${gap}px` }\"\n >\n <template v-for=\"itemIndex in column\" :key=\"itemIndex\">\n <LoadingIcon\n v-if=\"!state[items[itemIndex].src]\"\n :size=\"36\"\n style=\"margin: 20px auto\"\n />\n <img\n class=\"wl-gallery-item\"\n :src=\"items[itemIndex].src\"\n :title=\"items[itemIndex].title\"\n loading=\"lazy\"\n @load=\"state[items[itemIndex].src] = true\"\n @click=\"$emit('insert', ``)\"\n />\n </template>\n </div>\n </div>\n</template>\n\n<script lang=\"ts\">\nimport {\n defineComponent,\n nextTick,\n onBeforeUnmount,\n onMounted,\n ref,\n watch,\n} from 'vue';\n\nimport { LoadingIcon } from './Icons';\n\nimport type { PropType } from 'vue';\nimport type { WalineSearchResult } from '../typings';\n\ntype Column = number[];\n\nexport default defineComponent({\n name: 'ImageWall',\n\n components: {\n LoadingIcon,\n },\n\n props: {\n items: { type: Array as PropType<WalineSearchResult[]>, default: () => [] },\n columnWidth: { type: Number, default: 300 },\n gap: { type: Number, default: 0 },\n },\n\n emits: ['insert'],\n\n setup(props) {\n let resizeObserver: ResizeObserver | null = null;\n const wall = ref<HTMLDivElement | null>(null);\n const state = ref<Record<string, boolean>>({});\n const columns = ref<Column[]>([]);\n\n const getColumnCount = (): number => {\n const count = Math.floor(\n (wall.value!.getBoundingClientRect().width + props.gap) /\n (props.columnWidth + props.gap)\n );\n\n return count > 0 ? count : 1;\n };\n\n const createColumns = (count: number): Column[] =>\n new Array(count).fill(null).map(() => []);\n\n const fillColumns = async (itemIndex: number): Promise<void> => {\n if (itemIndex >= props.items.length) return;\n\n await nextTick();\n\n const columnDivs = Array.from(\n wall.value?.children || []\n ) as HTMLDivElement[];\n\n const target = columnDivs.reduce((prev, curr) =>\n curr.getBoundingClientRect().height <\n prev.getBoundingClientRect().height\n ? curr\n : prev\n );\n\n columns.value[Number(target.dataset.index)].push(itemIndex);\n\n await fillColumns(itemIndex + 1);\n };\n\n const redraw = async (force = false): Promise<void> => {\n if (columns.value.length === getColumnCount() && !force) return;\n\n columns.value = createColumns(getColumnCount());\n\n const scrollY = window.scrollY;\n\n await fillColumns(0);\n\n window.scrollTo({ top: scrollY });\n };\n\n watch(\n () => [props.items],\n () => {\n state.value = {};\n redraw(true);\n }\n );\n watch(\n () => [props.columnWidth, props.gap],\n () => redraw()\n );\n\n onMounted(() => {\n redraw(true);\n resizeObserver = new ResizeObserver(() => redraw());\n\n resizeObserver.observe(wall.value!);\n });\n\n onBeforeUnmount(() => resizeObserver!.unobserve(wall.value!));\n\n return {\n columns,\n state,\n wall,\n };\n },\n});\n</script>\n","<template>\n <div class=\"wl-comment\">\n <div v-if=\"config.login !== 'disable' && isLogin\" class=\"wl-login-info\">\n <div class=\"wl-avatar\">\n <button class=\"wl-logout-btn\" :title=\"locale.logout\" @click=\"onLogout\">\n <CloseIcon :size=\"14\" />\n </button>\n\n <a\n href=\"#\"\n class=\"wl-login-nick\"\n aria-label=\"Profile\"\n :title=\"locale.profile\"\n @click=\"onProfile\"\n >\n <img :src=\"userInfo.avatar\" alt=\"avatar\" />\n </a>\n </div>\n <a\n href=\"#\"\n class=\"wl-login-nick\"\n aria-label=\"Profile\"\n :title=\"locale.profile\"\n @click=\"onProfile\"\n v-text=\"userInfo.display_name\"\n />\n </div>\n\n <div class=\"wl-panel\">\n <div\n v-if=\"config.login !== 'force' && config.meta.length && !isLogin\"\n :class=\"['wl-header', `item${config.meta.length}`]\"\n >\n <div v-for=\"kind in config.meta\" :key=\"kind\" class=\"wl-header-item\">\n <label\n :for=\"kind\"\n v-text=\"\n locale[kind] +\n (config.requiredMeta.includes(kind) || !config.requiredMeta.length\n ? ''\n : `(${locale.optional})`)\n \"\n />\n <input\n :id=\"`wl-${kind}`\"\n :ref=\"\n (element) => {\n if (element) inputRefs[kind] = element as HTMLInputElement;\n }\n \"\n v-model=\"userMeta[kind]\"\n :class=\"['wl-input', `wl-${kind}`]\"\n :name=\"kind\"\n :type=\"kind === 'mail' ? 'email' : 'text'\"\n />\n </div>\n </div>\n\n <textarea\n id=\"wl-edit\"\n ref=\"editorRef\"\n v-model=\"editor\"\n class=\"wl-editor\"\n :placeholder=\"replyUser ? `@${replyUser}` : locale.placeholder\"\n @keydown=\"onKeyDown\"\n @drop=\"onDrop\"\n @paste=\"onPaste\"\n />\n\n <div v-show=\"showPreview\" class=\"wl-preview\">\n <hr />\n <h4>{{ locale.preview }}:</h4>\n <!-- eslint-disable-next-line vue/no-v-html -->\n <div class=\"wl-content\" v-html=\"previewText\" />\n </div>\n\n <div class=\"wl-footer\">\n <div class=\"wl-actions\">\n <a\n href=\"https://guides.github.com/features/mastering-markdown/\"\n title=\"Markdown Guide\"\n aria-label=\"Markdown is supported\"\n class=\"wl-action\"\n target=\"_blank\"\n rel=\"noreferrer\"\n >\n <MarkdownIcon />\n </a>\n\n <button\n v-show=\"emoji.tabs.length\"\n ref=\"emojiButtonRef\"\n class=\"wl-action\"\n :class=\"{ actived: showEmoji }\"\n :title=\"locale.emoji\"\n @click=\"showEmoji = !showEmoji\"\n >\n <EmojiIcon />\n </button>\n\n <button\n v-if=\"config.search\"\n ref=\"gifButtonRef\"\n class=\"wl-action\"\n :class=\"{ actived: showGif }\"\n :title=\"locale.gif\"\n @click=\"showGif = !showGif\"\n >\n <GifIcon />\n </button>\n\n <input\n id=\"wl-image-upload\"\n ref=\"imageUploadRef\"\n class=\"upload\"\n type=\"file\"\n accept=\".png,.jpg,.jpeg,.webp,.bmp,.gif\"\n @change=\"onChange\"\n />\n\n <label\n v-if=\"canUploadImage\"\n for=\"wl-image-upload\"\n class=\"wl-action\"\n :title=\"locale.uploadImage\"\n >\n <ImageIcon />\n </label>\n\n <button\n class=\"wl-action\"\n :class=\"{ actived: showPreview }\"\n :title=\"locale.preview\"\n @click=\"showPreview = !showPreview\"\n >\n <PreviewIcon />\n </button>\n </div>\n\n <div class=\"wl-info\">\n <div class=\"wl-text-number\">\n {{ wordNumber }}\n\n <span v-if=\"config.wordLimit\">\n / \n <span\n :class=\"{ illegal: !isWordNumberLegal }\"\n v-text=\"wordLimit\"\n />\n </span>\n\n {{ locale.word }}\n </div>\n\n <button\n v-if=\"config.login !== 'disable' && !isLogin\"\n class=\"wl-btn\"\n @click=\"onLogin\"\n v-text=\"locale.login\"\n />\n\n <button\n v-if=\"config.login !== 'force' || isLogin\"\n class=\"wl-btn primary\"\n title=\"Cmd|Ctrl + Enter\"\n :disabled=\"isSubmitting\"\n @click=\"submitComment\"\n >\n <LoadingIcon v-if=\"isSubmitting\" :size=\"16\" />\n <template v-else>\n {{ locale.submit }}\n </template>\n </button>\n </div>\n\n <div\n ref=\"gifPopupRef\"\n class=\"wl-gif-popup\"\n :class=\"{ display: showGif }\"\n >\n <input\n ref=\"gifSearchInputRef\"\n type=\"text\"\n :placeholder=\"locale.gifSearchPlaceholder\"\n @input=\"onGifSearch\"\n />\n\n <ImageWall\n :items=\"gifData.list\"\n :column-width=\"200\"\n :gap=\"6\"\n @insert=\"insert($event)\"\n @scroll=\"onImageWallScroll\"\n >\n </ImageWall>\n\n <div v-if=\"gifData.loading\" class=\"wl-loading\">\n <LoadingIcon :size=\"30\" />\n </div>\n </div>\n <div\n ref=\"emojiPopupRef\"\n class=\"wl-emoji-popup\"\n :class=\"{ display: showEmoji }\"\n >\n <template\n v-for=\"(emojiItem, index) in emoji.tabs\"\n :key=\"emojiItem.name\"\n >\n <div v-if=\"index === emojiTabIndex\" class=\"wl-tab-wrapper\">\n <button\n v-for=\"key in emojiItem.items\"\n :key=\"key\"\n :title=\"key\"\n @click=\"insert(`:${key}:`)\"\n >\n <img\n v-if=\"showEmoji\"\n class=\"wl-emoji\"\n :src=\"emoji.map[key]\"\n :alt=\"key\"\n loading=\"lazy\"\n referrerPolicy=\"no-referrer\"\n />\n </button>\n </div>\n </template>\n <div v-if=\"emoji.tabs.length > 1\" class=\"wl-tabs\">\n <button\n v-for=\"(emojiItem, index) in emoji.tabs\"\n :key=\"emojiItem.name\"\n class=\"wl-tab\"\n :class=\"{ active: emojiTabIndex === index }\"\n @click=\"emojiTabIndex = index\"\n >\n <img\n class=\"wl-emoji\"\n :src=\"emojiItem.icon\"\n :alt=\"emojiItem.name\"\n :title=\"emojiItem.name\"\n loading=\"lazy\"\n referrerPolicy=\"no-referrer\"\n />\n </button>\n </div>\n </div>\n </div>\n </div>\n\n <button\n v-if=\"replyId\"\n class=\"wl-close\"\n :title=\"locale.cancelReply\"\n @click=\"$emit('cancel-reply')\"\n >\n <CloseIcon :size=\"24\" />\n </button>\n </div>\n</template>\n\n<script lang=\"ts\">\nimport { useDebounceFn } from '@vueuse/core';\nimport autosize from 'autosize';\nimport {\n computed,\n defineComponent,\n inject,\n onMounted,\n onUnmounted,\n reactive,\n ref,\n watch,\n} from 'vue';\n\nimport {\n CloseIcon,\n EmojiIcon,\n ImageIcon,\n MarkdownIcon,\n PreviewIcon,\n LoadingIcon,\n GifIcon,\n} from './Icons';\nimport ImageWall from './ImageWall.vue';\nimport { useEditor, useUserMeta, useUserInfo } from '../composables';\nimport {\n getEmojis,\n getImagefromDataTransfer,\n getWordNumber,\n parseEmoji,\n parseMarkdown,\n postComment,\n} from '../utils';\n\nimport type { ComputedRef, DeepReadonly } from 'vue';\nimport type {\n WalineCommentData,\n WalineImageUploader,\n WalineSearchOptions,\n WalineSearchResult,\n} from '../typings';\nimport type { WalineConfig, WalineEmojiConfig } from '../utils';\n\nexport default defineComponent({\n name: 'CommentBox',\n\n components: {\n CloseIcon,\n EmojiIcon,\n ImageIcon,\n ImageWall,\n MarkdownIcon,\n PreviewIcon,\n LoadingIcon,\n GifIcon,\n },\n\n props: {\n rootId: {\n type: String,\n default: '',\n },\n replyId: {\n type: String,\n default: '',\n },\n replyUser: {\n type: String,\n default: '',\n },\n },\n\n emits: ['submit', 'cancel-reply'],\n\n setup(props, { emit }) {\n const config = inject<ComputedRef<WalineConfig>>(\n 'config'\n ) as ComputedRef<WalineConfig>;\n\n const editor = useEditor();\n const userMeta = useUserMeta();\n const userInfo = useUserInfo();\n\n const inputRefs = ref<Record<string, HTMLInputElement>>({});\n const editorRef = ref<HTMLTextAreaElement | null>(null);\n const imageUploadRef = ref<HTMLInputElement | null>(null);\n const emojiButtonRef = ref<HTMLDivElement | null>(null);\n const emojiPopupRef = ref<HTMLDivElement | null>(null);\n const gifButtonRef = ref<HTMLDivElement | null>(null);\n const gifPopupRef = ref<HTMLDivElement | null>(null);\n const gifSearchInputRef = ref<HTMLInputElement | null>(null);\n\n const emoji = ref<DeepReadonly<WalineEmojiConfig>>({ tabs: [], map: {} });\n const emojiTabIndex = ref(0);\n const showEmoji = ref(false);\n const showGif = ref(false);\n const showPreview = ref(false);\n const previewText = ref('');\n const wordNumber = ref(0);\n\n const searchResults = reactive({\n loading: true,\n list: [] as WalineSearchResult[],\n });\n\n const wordLimit = ref(0);\n const isWordNumberLegal = ref(false);\n\n const content = ref('');\n\n const isSubmitting = ref(false);\n\n const locale = computed(() => config.value.locale);\n\n const isLogin = computed(() => Boolean(userInfo.value?.token));\n\n const canUploadImage = computed(() => config.value.imageUploader !== false);\n\n const insert = (content: string): void => {\n const textArea = editorRef.value as HTMLTextAreaElement;\n const startPosition = textArea.selectionStart;\n const endPosition = textArea.selectionEnd || 0;\n const scrollTop = textArea.scrollTop;\n\n editor.value =\n textArea.value.substring(0, startPosition) +\n content +\n textArea.value.substring(endPosition, textArea.value.length);\n textArea.focus();\n textArea.selectionStart = startPosition + content.length;\n textArea.selectionEnd = startPosition + content.length;\n textArea.scrollTop = scrollTop;\n };\n\n const onKeyDown = (event: KeyboardEvent): void => {\n const key = event.key;\n\n // Shortcut key\n if ((event.ctrlKey || event.metaKey) && key === 'Enter') submitComment();\n };\n\n const uploadImage = (file: File): Promise<void> => {\n const uploadText = `![${config.value.locale.uploading} ${file.name}]()`;\n\n insert(uploadText);\n\n return Promise.resolve()\n .then(() => (config.value.imageUploader as WalineImageUploader)(file))\n .then((url) => {\n editor.value = editor.value.replace(\n uploadText,\n `\\r\\n`\n );\n });\n };\n\n const onDrop = (event: DragEvent): void => {\n if (event.dataTransfer?.items) {\n const file = getImagefromDataTransfer(event.dataTransfer.items);\n\n if (file && canUploadImage.value) {\n uploadImage(file);\n event.preventDefault();\n }\n }\n };\n\n const onPaste = (event: ClipboardEvent): void => {\n if (event.clipboardData) {\n const file = getImagefromDataTransfer(event.clipboardData.items);\n\n if (file && canUploadImage.value) uploadImage(file);\n }\n };\n\n const onChange = (): void => {\n const inputElement = imageUploadRef.value as HTMLInputElement;\n\n if (inputElement.files && canUploadImage.value)\n uploadImage(inputElement.files[0]).then(() => {\n // clear input so a same image can be uploaded later\n inputElement.value = '';\n });\n };\n\n const submitComment = (): void => {\n const { serverURL, lang, login, wordLimit, requiredMeta } = config.value;\n\n const comment: WalineCommentData = {\n comment: content.value,\n nick: userMeta.value.nick,\n mail: userMeta.value.mail,\n link: userMeta.value.link,\n ua: navigator.userAgent,\n url: config.value.path,\n };\n\n if (userInfo.value?.token) {\n // login user\n\n comment.nick = userInfo.value.display_name;\n comment.mail = userInfo.value.email;\n comment.link = userInfo.value.url;\n } else {\n if (login === 'force') return;\n\n // check nick\n if (requiredMeta.indexOf('nick') > -1 && !comment.nick) {\n inputRefs.value.nick?.focus();\n\n return alert(locale.value.nickError);\n }\n\n // check mail\n if (\n (requiredMeta.indexOf('mail') > -1 && !comment.mail) ||\n (comment.mail &&\n !/^\\w(?:[\\w._-]*\\w)?@(?:\\w(?:[\\w-]*\\w)?\\.)*\\w+$/.exec(comment.mail))\n ) {\n inputRefs.value.mail?.focus();\n\n return alert(locale.value.mailError);\n }\n\n // check comment\n if (!comment.comment) {\n editorRef.value?.focus();\n\n return;\n }\n\n if (!comment.nick) comment.nick = locale.value.anonymous;\n }\n\n if (!isWordNumberLegal.value)\n return alert(\n locale.value.wordHint\n .replace('$0', (wordLimit as [number, number])[0].toString())\n .replace('$1', (wordLimit as [number, number])[1].toString())\n .replace('$2', wordNumber.value.toString())\n );\n\n comment.comment = parseEmoji(comment.comment, emoji.value.map);\n\n if (props.replyId && props.rootId) {\n comment.pid = props.replyId;\n comment.rid = props.rootId;\n comment.at = props.replyUser;\n }\n\n isSubmitting.value = true;\n\n postComment({\n serverURL,\n lang,\n token: userInfo.value?.token,\n comment,\n })\n .then((resp) => {\n isSubmitting.value = false;\n\n if (resp.errmsg) return alert(resp.errmsg);\n\n emit('submit', resp.data!);\n\n editor.value = '';\n\n previewText.value = '';\n\n if (props.replyId) emit('cancel-reply');\n })\n .catch((err: TypeError) => {\n isSubmitting.value = false;\n\n alert(err.message);\n });\n };\n\n const onLogin = (event: Event): void => {\n event.preventDefault();\n const { lang, serverURL } = config.value;\n\n const width = 450;\n const height = 450;\n const left = (window.innerWidth - width) / 2;\n const top = (window.innerHeight - height) / 2;\n\n const handler = window.open(\n `${serverURL}/ui/login?lng=${encodeURIComponent(lang)}`,\n '_blank',\n `width=${width},height=${height},left=${left},top=${top},scrollbars=no,resizable=no,status=no,location=no,toolbar=no,menubar=no`\n );\n\n handler?.postMessage({ type: 'TOKEN', data: null }, '*');\n\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const receiver = ({ data }: any): void => {\n if (!data || data.type !== 'userInfo') return;\n\n if (data.data.token) {\n handler?.close();\n userInfo.value = data.data;\n (data.data.remember ? localStorage : sessionStorage).setItem(\n 'WALINE_USER',\n JSON.stringify(data.data)\n );\n\n window.removeEventListener('message', receiver);\n }\n };\n\n window.addEventListener('message', receiver);\n };\n\n const onLogout = (): void => {\n userInfo.value = {};\n localStorage.setItem('WALINE_USER', 'null');\n sessionStorage.setItem('WALINE_USER', 'null');\n };\n\n const onProfile = (event: Event): void => {\n event.preventDefault();\n\n const { lang, serverURL } = config.value;\n\n const width = 800;\n const height = 800;\n const left = (window.innerWidth - width) / 2;\n const top = (window.innerHeight - height) / 2;\n const handler = window.open(\n `${serverURL}/ui/profile?lng=${encodeURIComponent(lang)}`,\n '_blank',\n `width=${width},height=${height},left=${left},top=${top},scrollbars=no,resizable=no,status=no,location=no,toolbar=no,menubar=no`\n );\n\n handler?.postMessage({ type: 'TOKEN', data: userInfo.value!.token }, '*');\n };\n\n const popupHandler = (event: MouseEvent): void => {\n if (\n !(emojiButtonRef.value as HTMLElement).contains(event.target as Node) &&\n !(emojiPopupRef.value as HTMLElement).contains(event.target as Node)\n )\n showEmoji.value = false;\n\n if (\n !(gifButtonRef.value as HTMLElement).contains(event.target as Node) &&\n !(gifPopupRef.value as HTMLElement).contains(event.target as Node)\n )\n showGif.value = false;\n };\n\n const onImageWallScroll = async (event: Event): Promise<void> => {\n const { scrollTop, clientHeight, scrollHeight } =\n event.target as HTMLDivElement;\n const percent = (clientHeight + scrollTop) / scrollHeight;\n const searchOptions = config.value.search as WalineSearchOptions;\n const keyword = gifSearchInputRef.value?.value || '';\n\n if (percent < 0.9 || searchResults.loading) return;\n\n searchResults.loading = true;\n\n searchResults.list.push(\n ...(searchOptions.more\n ? await searchOptions.more(keyword, searchResults.list.length)\n : await searchOptions.search(keyword))\n );\n\n searchResults.loading = false;\n\n setTimeout(() => {\n (event.target as HTMLDivElement).scrollTop = scrollTop;\n }, 50);\n };\n\n const onGifSearch = useDebounceFn((event: Event) => {\n searchResults.list = [];\n onImageWallScroll(event);\n }, 300);\n\n // update wordNumber\n watch(\n [config, wordNumber],\n ([config, wordNumber]) => {\n const { wordLimit: limit } = config;\n\n if (limit) {\n if (wordNumber < limit[0] && limit[0] !== 0) {\n wordLimit.value = limit[0];\n isWordNumberLegal.value = false;\n } else if (wordNumber > limit[1]) {\n wordLimit.value = limit[1];\n isWordNumberLegal.value = false;\n } else {\n wordLimit.value = limit[1];\n isWordNumberLegal.value = true;\n }\n } else {\n wordLimit.value = 0;\n isWordNumberLegal.value = true;\n }\n },\n { immediate: true }\n );\n\n watch(showGif, async (showGif) => {\n if (!showGif) return;\n\n const searchOptions = config.value.search as WalineSearchOptions;\n\n // clear input\n if (gifSearchInputRef.value) gifSearchInputRef.value.value = '';\n\n searchResults.loading = true;\n\n searchResults.list = searchOptions.default\n ? await searchOptions.default()\n : await searchOptions.search('');\n\n searchResults.loading = false;\n });\n\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const onMessageRecive = ({ data }: any): void => {\n if (!data || data.type !== 'profile') return;\n\n userInfo.value = { ...userInfo.value, ...data.data };\n\n [localStorage, sessionStorage]\n .filter((store) => store.getItem('WALINE_USER'))\n .forEach((store) =>\n store.setItem('WALINE_USER', JSON.stringify(userInfo))\n );\n };\n\n onMounted(() => {\n document.body.addEventListener('click', popupHandler);\n window.addEventListener('message', onMessageRecive);\n\n // watch editor\n watch(\n () => editor.value,\n (value) => {\n const { highlighter, texRenderer } = config.value;\n\n content.value = value;\n previewText.value = parseMarkdown(value, {\n emojiMap: emoji.value.map,\n highlighter,\n texRenderer,\n });\n wordNumber.value = getWordNumber(value);\n\n if (value) autosize(editorRef.value!);\n else autosize.destroy(editorRef.value!);\n },\n { immediate: true }\n );\n\n // watch emoji value change\n watch(\n () => config.value.emoji,\n (emojiConfig) =>\n getEmojis(Array.isArray(emojiConfig) ? emojiConfig : []).then(\n (config) => {\n emoji.value = config;\n }\n ),\n { immediate: true }\n );\n });\n\n onUnmounted(() => {\n document.body.removeEventListener('click', popupHandler);\n window.removeEventListener('message', onMessageRecive);\n });\n\n return {\n // config\n config,\n locale,\n\n // events\n insert,\n onChange,\n onDrop,\n onKeyDown,\n onPaste,\n onLogin,\n onLogout,\n onProfile,\n submitComment,\n onImageWallScroll,\n onGifSearch,\n\n isLogin,\n userInfo,\n isSubmitting,\n\n // word\n wordNumber,\n wordLimit,\n isWordNumberLegal,\n\n // inputs\n editor,\n userMeta,\n\n // emoji\n emoji,\n emojiTabIndex,\n showEmoji,\n\n // gif\n gifData: searchResults,\n showGif,\n\n // image\n canUploadImage,\n\n // preview\n previewText,\n showPreview,\n\n // ref\n inputRefs,\n editorRef,\n emojiButtonRef,\n emojiPopupRef,\n gifButtonRef,\n gifPopupRef,\n imageUploadRef,\n gifSearchInputRef,\n };\n },\n});\n</script>\n","/**\n * The wordCount module should be lightweight as it's packed into client.\n *\n * So We just make a simple implement here\n *\n * Forked from https://github.com/vuepress-theme-hope/vuepress-theme-hope/blob/main/packages/reading-time2/src/node/reading-time.ts\n */\n\nexport const getWords = (content: string): string[] =>\n content.match(/[\\w\\d\\s\\u00C0-\\u024F]+/giu) || [];\n\nexport const getChinese = (content: string): string[] =>\n content.match(/[\\u4E00-\\u9FA5]/gu) || [];\n\nexport const getWordNumber = (content: string): number =>\n getWords(content).reduce(\n (accumulator, word) =>\n accumulator + (word.trim() === '' ? 0 : word.trim().split(/\\s+/u).length),\n 0\n ) + getChinese(content).length;\n","<template>\n <div :id=\"comment.objectId\" class=\"wl-item\">\n <div class=\"wl-user\" aria-hidden=\"true\">\n <img v-if=\"comment.avatar\" :src=\"comment.avatar\" />\n <VerifiedIcon v-if=\"comment.type\" />\n </div>\n\n <div class=\"wl-card\">\n <div class=\"wl-head\">\n <a\n v-if=\"link\"\n class=\"wl-nick\"\n :href=\"link\"\n target=\"_blank\"\n rel=\"nofollow noreferrer\"\n >{{ comment.nick }}</a\n >\n <span v-else class=\"wl-nick\">{{ comment.nick }}</span>\n\n <span\n v-if=\"comment.type === 'administrator'\"\n class=\"wl-badge\"\n v-text=\"locale.admin\"\n />\n <span v-if=\"comment.label\" class=\"wl-badge\" v-text=\"comment.label\" />\n <span v-if=\"comment.sticky\" class=\"wl-badge\" v-text=\"locale.sticky\" />\n <span\n v-if=\"comment.level !== undefined && comment.level >= 0\"\n :class=\"`wl-badge level${comment.level}`\"\n v-text=\"locale[`level${comment.level}`] || `Level ${comment.level}`\"\n />\n <span class=\"wl-time\" v-text=\"time\" />\n\n <div class=\"wl-comment-actions\">\n <button\n v-if=\"isAdmin || isOwner\"\n class=\"wl-delete\"\n @click=\"$emit('delete', comment)\"\n >\n <DeleteIcon />\n </button>\n\n <button\n class=\"wl-like\"\n :title=\"like ? locale.cancelLike : locale.like\"\n @click=\"$emit('like', comment)\"\n >\n <LikeIcon :active=\"like\" />\n <span v-if=\"'like' in comment\" v-text=\"comment.like\" />\n </button>\n\n <button\n class=\"wl-reply\"\n :class=\"{ active: isReplyingCurrent }\"\n :title=\"isReplyingCurrent ? locale.cancelReply : locale.reply\"\n @click=\"$emit('reply', isReplyingCurrent ? null : comment)\"\n >\n <ReplyIcon />\n </button>\n </div>\n </div>\n <div class=\"wl-meta\" aria-hidden=\"true\">\n <span v-if=\"comment.addr\" v-text=\"comment.addr\" />\n <span v-if=\"comment.browser\" v-text=\"comment.browser\" />\n <span v-if=\"comment.os\" v-text=\"comment.os\" />\n </div>\n <!-- eslint-disable-next-line vue/no-v-html -->\n <div class=\"wl-content\" v-html=\"comment.comment\" />\n\n <div v-if=\"isAdmin\" class=\"wl-admin-actions\">\n <span class=\"wl-comment-status\">\n <button\n v-for=\"status in commentStatus\"\n :key=\"status\"\n :class=\"`wl-btn wl-${status}`\"\n :disabled=\"comment.status === status\"\n @click=\"$emit('status', { status, comment })\"\n v-text=\"status\"\n />\n </span>\n\n <button\n v-if=\"isAdmin && !comment.rid\"\n class=\"wl-btn wl-sticky\"\n @click=\"$emit('sticky', comment)\"\n >\n {{ comment.sticky ? 'unsticky' : 'sticky' }}\n </button>\n </div>\n\n <div v-if=\"isReplyingCurrent\" class=\"wl-reply-wrapper\">\n <CommentBox\n :reply-id=\"comment.objectId\"\n :reply-user=\"comment.nick\"\n :root-id=\"rootId\"\n @submit=\"$emit('submit', $event)\"\n @cancel-reply=\"$emit('reply', null)\"\n />\n </div>\n <div v-if=\"comment.children\" class=\"wl-quote\">\n <CommentCard\n v-for=\"child in comment.children\"\n :key=\"child.objectId\"\n :comment=\"child\"\n :reply=\"reply\"\n :root-id=\"rootId\"\n @reply=\"$emit('reply', $event)\"\n @submit=\"$emit('submit', $event)\"\n @like=\"$emit('like', $event)\"\n @delete=\"$emit('delete', $event)\"\n @status=\"$emit('status', $event)\"\n @sticky=\"$emit('sticky', $event)\"\n />\n </div>\n </div>\n </div>\n</template>\n\n<script lang=\"ts\">\nimport { computed, defineComponent, inject } from 'vue';\nimport CommentBox from './CommentBox.vue';\nimport { DeleteIcon, LikeIcon, ReplyIcon, VerifiedIcon } from './Icons';\nimport { isLinkHttp } from '../utils';\nimport { useTimeAgo, useLikeStorage, useUserInfo } from '../composables';\n\nimport type { ComputedRef, PropType } from 'vue';\nimport type { WalineConfig } from '../utils';\nimport type { WalineComment, WalineCommentStatus } from '../typings';\n\nconst commentStatus: WalineCommentStatus[] = ['approved', 'waiting', 'spam'];\n\nexport default defineComponent({\n components: {\n CommentBox,\n DeleteIcon,\n LikeIcon,\n ReplyIcon,\n VerifiedIcon,\n },\n\n props: {\n comment: {\n type: Object as PropType<WalineComment>,\n required: true,\n },\n rootId: {\n type: String,\n required: true,\n },\n reply: {\n type: Object as PropType<WalineComment | null>,\n default: null,\n },\n },\n\n emits: ['submit', 'reply', 'like', 'delete', 'status', 'sticky'],\n\n setup(props) {\n const config = inject<ComputedRef<WalineConfig>>(\n 'config'\n ) as ComputedRef<WalineConfig>;\n const likes = useLikeStorage();\n const userInfo = useUserInfo();\n\n const locale = computed(() => config.value.locale);\n\n const link = computed(() => {\n const { link } = props.comment;\n\n return link ? (isLinkHttp(link) ? link : `https://${link}`) : '';\n });\n\n const like = computed(() => likes.value.includes(props.comment.objectId));\n\n const time = useTimeAgo(props.comment.insertedAt, locale.value);\n\n const isAdmin = computed(() => userInfo.value.type === 'administrator');\n\n const isOwner = computed(\n () =>\n props.comment.user_id &&\n userInfo.value.objectId === props.comment.user_id\n );\n\n const isReplyingCurrent = computed(\n () => props.comment.objectId === props.reply?.objectId\n );\n\n return {\n config,\n locale,\n\n isReplyingCurrent,\n link,\n like,\n time,\n\n isAdmin,\n isOwner,\n\n commentStatus,\n };\n },\n});\n</script>\n","import { useNow } from '@vueuse/core';\nimport { computed } from 'vue';\nimport { getTimeAgo } from '../utils';\n\nimport type { ComputedRef } from 'vue';\nimport type { WalineLocale } from '../typings';\n\nexport const useTimeAgo = (\n date: Date | string,\n locale: WalineLocale\n): ComputedRef<string> => {\n const now = useNow();\n\n return computed(() => getTimeAgo(date, now.value, locale));\n};\n","<template>\n <div data-waline>\n <CommentBox v-if=\"!reply\" @submit=\"onSubmit\" />\n <div class=\"wl-count\">\n <span v-if=\"count\" class=\"wl-num\" v-text=\"count\" />\n {{ i18n.comment }}\n </div>\n\n <div class=\"wl-cards\">\n <CommentCard\n v-for=\"comment in data\"\n :key=\"comment.objectId\"\n :root-id=\"comment.objectId\"\n :comment=\"comment\"\n :reply=\"reply\"\n @reply=\"onReply\"\n @submit=\"onSubmit\"\n @status=\"onStatusChange\"\n @delete=\"onDelete\"\n @sticky=\"onSticky\"\n @like=\"onLike\"\n />\n </div>\n\n <div v-if=\"status === 'error'\" class=\"wl-operation\">\n <button\n type=\"button\"\n class=\"wl-btn\"\n @click=\"refresh\"\n v-text=\"i18n.refresh\"\n />\n </div>\n\n <template v-else>\n <div v-if=\"status === 'loading'\" class=\"wl-loading\">\n <LoadingIcon :size=\"30\" />\n </div>\n\n <div v-else-if=\"!data.length\" class=\"wl-empty\" v-text=\"i18n.sofa\" />\n\n <!-- Load more button -->\n <div v-else-if=\"page < totalPages\" class=\"wl-operation\">\n <button\n type=\"button\"\n class=\"wl-btn\"\n @click=\"loadMore\"\n v-text=\"i18n.more\"\n />\n </div>\n </template>\n\n <!-- Copyright Information -->\n <div v-if=\"config.copyright\" class=\"wl-power\">\n Powered by\n <a\n href=\"https://github.com/walinejs/waline\"\n target=\"_blank\"\n rel=\"noreferrer\"\n >\n Waline\n </a>\n v{{ version }}\n </div>\n </div>\n</template>\n\n<script lang=\"ts\">\nimport { useStyleTag } from '@vueuse/core';\nimport { computed, defineComponent, onMounted, provide, ref, watch } from 'vue';\nimport CommentBox from './CommentBox.vue';\nimport CommentCard from './CommentCard.vue';\nimport { LoadingIcon } from './Icons';\nimport { useUserInfo, useLikeStorage } from '../composables';\nimport { defaultLocales } from '../config';\nimport {\n deleteComment,\n fetchCommentList,\n likeComment,\n getConfig,\n getDarkStyle,\n updateComment,\n} from '../utils';\n\nimport type { PropType } from 'vue';\nimport type {\n WalineComment,\n WalineCommentStatus,\n WalineEmojiInfo,\n WalineHighlighter,\n WalineTexRenderer,\n WalineImageUploader,\n WalineLocale,\n WalineProps,\n WalineMeta,\n} from '../typings';\n\ndeclare const SHOULD_VALIDATE: boolean;\ndeclare const VERSION: string;\n\nconst props = [\n 'serverURL',\n 'path',\n 'meta',\n 'requiredMeta',\n 'dark',\n 'lang',\n 'locale',\n 'pageSize',\n 'wordLimit',\n 'emoji',\n 'login',\n 'highlighter',\n 'texRenderer',\n 'imageUploader',\n 'copyright',\n];\n\nconst propsWithValidate = {\n serverURL: {\n type: String,\n required: true,\n },\n\n path: {\n type: String,\n required: true,\n },\n\n meta: {\n type: Array as PropType<WalineMeta[]>,\n default: (): WalineMeta[] => ['nick', 'mail', 'link'],\n validator: (value: unknown): boolean =>\n Array.isArray(value) &&\n value.every((item) => ['nick', 'mail', 'link'].includes(item)),\n },\n\n requiredMeta: {\n type: Array,\n default: (): WalineMeta[] => [],\n validator: (value: unknown): boolean =>\n Array.isArray(value) &&\n value.every((item) => ['nick', 'mail', 'link'].includes(item)),\n },\n\n dark: [String, Boolean],\n\n lang: {\n type: String,\n default: 'zh-CN',\n validator: (value: unknown): boolean =>\n Object.keys(defaultLocales).includes(value as string),\n },\n\n locale: Object as PropType<Partial<WalineLocale>>,\n\n pageSize: { type: Number, default: 10 },\n\n wordLimit: {\n type: [Number, Array] as PropType<number | [number, number]>,\n validator: (value: unknown): boolean =>\n typeof value === 'number' ||\n (Array.isArray(value) &&\n value.length === 2 &&\n value.every((item) => typeof item === 'number')),\n },\n\n emoji: {\n type: [Array, Boolean] as PropType<(string | WalineEmojiInfo)[] | false>,\n validator: (value: unknown): boolean =>\n value === false ||\n (Array.isArray(value) &&\n value.every(\n (item) =>\n typeof item === 'string' ||\n (typeof item === 'object' &&\n typeof item.name === 'string' &&\n typeof item.folder === 'string' &&\n typeof item.icon === 'string' &&\n Array.isArray(item.items) &&\n (item.items as unknown[]).every(\n (icon) => typeof icon === 'string'\n ))\n )),\n },\n\n login: String as PropType<'enable' | 'disable' | 'force'>,\n\n highlighter: Function as PropType<WalineHighlighter>,\n\n imageUploader: {\n type: [Function, Boolean] as PropType<WalineImageUploader | false>,\n default: undefined,\n },\n\n texRenderer: {\n type: [Function, Boolean] as PropType<WalineTexRenderer | false>,\n default: undefined,\n },\n\n copyright: { type: Boolean, default: true },\n};\n\nexport default defineComponent({\n name: 'WalineRoot',\n\n components: {\n CommentBox,\n CommentCard,\n LoadingIcon,\n },\n\n props: SHOULD_VALIDATE ? propsWithValidate : props,\n\n setup(props) {\n const config = computed(() => getConfig(props as unknown as WalineProps));\n\n const userInfo = useUserInfo();\n const likeStorage = useLikeStorage();\n\n const status = ref<'loading' | 'success' | 'error'>('loading');\n\n const count = ref(0);\n const page = ref(1);\n const totalPages = ref(0);\n\n const data = ref<WalineComment[]>([]);\n const reply = ref<WalineComment | null>(null);\n\n const darkmodeStyle = computed(() => getDarkStyle(config.value.dark));\n\n useStyleTag(darkmodeStyle);\n\n // eslint-disable-next-line vue/no-setup-props-destructure\n let abort: () => void;\n\n const fetchComment = (pageNumber: number): void => {\n const { serverURL, path, pageSize } = config.value;\n const controller = new AbortController();\n\n status.value = 'loading';\n\n abort?.();\n\n fetchCommentList({\n serverURL,\n lang: config.value.lang,\n path,\n pageSize,\n page: pageNumber,\n signal: controller.signal,\n token: userInfo.value?.token,\n })\n .then((resp) => {\n status.value = 'success';\n count.value = resp.count;\n data.value.push(...resp.data);\n page.value = pageNumber;\n totalPages.value = resp.totalPages;\n })\n .catch((err) => {\n if (err.name !== 'AbortError') {\n console.error(err.message);\n status.value = 'error';\n }\n });\n\n abort = controller.abort.bind(controller);\n };\n\n const loadMore = (): void => fetchComment(page.value + 1);\n\n const refresh = (): void => {\n count.value = 0;\n data.value = [];\n fetchComment(1);\n };\n\n const onReply = (comment: WalineComment | null): void => {\n reply.value = comment;\n };\n\n const onSubmit = (comment: WalineComment): void => {\n if (comment.rid) {\n const repliedComment = data.value.find(\n ({ objectId }) => objectId === comment.rid\n );\n\n if (!repliedComment) return;\n\n if (!Array.isArray(repliedComment.children))\n repliedComment.children = [];\n\n repliedComment.children.push(comment);\n } else data.value.unshift(comment);\n };\n\n const onStatusChange = async ({\n comment,\n status,\n }: {\n comment: WalineComment;\n status: WalineCommentStatus;\n }): Promise<void> => {\n if (comment.status === status) return;\n\n const { serverURL, lang } = config.value;\n\n await updateComment({\n serverURL,\n lang,\n token: userInfo.value?.token,\n objectId: comment.objectId,\n status,\n });\n\n comment.status = status;\n };\n\n const onSticky = async (comment: WalineComment): Promise<void> => {\n if (comment.rid) return;\n\n const { serverURL, lang } = config.value;\n\n await updateComment({\n serverURL,\n lang,\n token: userInfo.value?.token,\n objectId: comment.objectId,\n sticky: comment.sticky ? 0 : 1,\n });\n\n comment.sticky = !comment.sticky;\n };\n\n const onDelete = async ({ objectId }: WalineComment): Promise<void> => {\n if (!confirm('Are you sure you want to delete this comment?')) return;\n\n const { serverURL, lang } = config.value;\n\n await deleteComment({\n serverURL,\n lang,\n token: userInfo.value?.token,\n objectId: objectId,\n });\n\n // delete comment from data\n data.value.some((item, index) => {\n if (item.objectId === objectId) {\n data.value = data.value.filter((_item, i) => i !== index);\n\n return true;\n }\n\n return item.children.some((child, childIndex) => {\n if (child.objectId === objectId) {\n data.value[index].children = item.children.filter(\n (_item, i) => i !== childIndex\n );\n\n return true;\n }\n\n return false;\n });\n });\n };\n\n const onLike = async (comment: WalineComment): Promise<void> => {\n const { serverURL, lang } = config.value;\n const { objectId } = comment;\n const hasLiked = likeStorage.value.includes(objectId);\n\n await likeComment({\n serverURL,\n lang,\n objectId,\n like: !hasLiked,\n });\n\n if (hasLiked)\n likeStorage.value = likeStorage.value.filter((id) => id !== objectId);\n else {\n likeStorage.value = [...likeStorage.value, objectId];\n\n if (likeStorage.value.length > 50)\n likeStorage.value = likeStorage.value.slice(-50);\n }\n\n comment.like = (comment.like || 0) + (hasLiked ? -1 : 1);\n };\n\n provide('config', config);\n\n watch(() => (props as unknown as WalineProps).path, refresh);\n\n onMounted(() => refresh());\n\n return {\n config,\n darkmodeStyle,\n i18n: computed(() => config.value.locale),\n\n status,\n count,\n page,\n totalPages,\n data,\n reply,\n\n loadMore,\n refresh,\n onReply,\n onSubmit,\n onStatusChange,\n onDelete,\n onSticky,\n onLike,\n\n version: VERSION,\n };\n },\n});\n</script>\n","import {\n errorHandler,\n fetchPageviews,\n getQuery,\n getServerURL,\n updatePageviews,\n} from './utils';\n\nimport type { WalineAbort } from './typings';\n\nexport interface WalinePageviewCountOptions {\n /**\n * Waline 服务端地址\n *\n * Waline server url\n */\n serverURL: string;\n\n /**\n * 浏览量 CSS 选择器\n *\n * Pageview CSS selector\n *\n * @default '.waline-pageview-count'\n */\n selector?: string;\n\n /**\n * 需要更新和获取的路径\n *\n * Path to be fetched and updated\n *\n * @default window.location.pathname\n */\n path?: string;\n\n /**\n * 是否在查询时更新 path 的浏览量\n *\n * Whether update pageviews when fetching path result\n *\n * @default true\n */\n update?: boolean;\n\n /**\n * 错误提示消息所使用的语言\n *\n * Language of error message\n *\n * @default 'zh-CN'\n */\n lang?: string;\n}\n\nconst renderVisitorCount = (\n counts: number[],\n countElements: HTMLElement[]\n): void => {\n countElements.forEach((element, index) => {\n element.innerText = counts[index].toString();\n });\n};\n\nexport const pageviewCount = ({\n serverURL,\n path = window.location.pathname,\n selector = '.waline-pageview-count',\n update = true,\n lang = 'zh-CN',\n}: WalinePageviewCountOptions): WalineAbort => {\n const controller = new AbortController();\n\n const elements = Array.from(\n // pageview selectors\n document.querySelectorAll<HTMLElement>(selector)\n );\n\n const filter = (element: HTMLElement): boolean => {\n const query = getQuery(element);\n\n return query !== null && path !== query;\n };\n\n const fetch = (elements: HTMLElement[]): Promise<void> =>\n fetchPageviews({\n serverURL: getServerURL(serverURL),\n paths: elements.map((element) => getQuery(element) || path),\n lang,\n signal: controller.signal,\n })\n .then((counts) => renderVisitorCount(counts, elements))\n .catch(errorHandler);\n\n // we should update pageviews\n if (update) {\n const normalElements = elements.filter((element) => !filter(element));\n const elementsNeedstoBeFetched = elements.filter(filter);\n\n void updatePageviews({\n serverURL: getServerURL(serverURL),\n path,\n lang,\n }).then((count) =>\n renderVisitorCount(\n new Array<number>(normalElements.length).fill(count),\n normalElements\n )\n );\n\n // if we should fetch count of other pages\n if (elementsNeedstoBeFetched.length) {\n void fetch(elementsNeedstoBeFetched);\n }\n }\n // we should not update pageviews\n else {\n void fetch(elements);\n }\n\n return controller.abort.bind(controller);\n};\n","import { createApp, h, reactive, watchEffect } from 'vue';\n\nimport Waline from './components/Waline.vue';\nimport { commentCount } from './comment';\nimport { pageviewCount } from './pageview';\nimport { getRoot } from './utils';\n\nimport type { WalineInitOptions } from './typings';\n\nexport interface WalineInstance {\n /**\n * Waline 被挂载到的元素\n *\n * @description 当通过 `el: null` 初始化,值为 `null`\n *\n * Element where Waline is mounted\n *\n * @description when initialized with `el: null`, it will be `null`\n */\n el: HTMLElement | null;\n\n /**\n * 更新 Waline 实例\n *\n * @description 只要不设置`path` 选项,更新时它就会被重置为 `windows.location.pathname`\n *\n * Update Waline instance\n *\n * @description when not setting `path` option, it will be reset to `window.location.pathname`\n */\n update: (newOptions?: Partial<Omit<WalineInitOptions, 'el'>>) => void;\n\n /**\n * 取消挂载并摧毁 Waline 实例\n *\n * Unmount and destroy Waline instance\n */\n destroy: () => void;\n}\n\nexport const init = ({\n el = '#waline',\n path = window.location.pathname,\n comment = false,\n pageview = false,\n ...initProps\n}: WalineInitOptions): WalineInstance | null => {\n // check el element\n const root = el ? getRoot(el) : null;\n\n // check root\n if (el && !root) throw new Error(`Option 'el' do not match any domElement!`);\n\n // check serverURL\n if (!initProps.serverURL) throw new Error(\"Option 'serverURL' is missing!\");\n\n const props = reactive({ ...initProps });\n const state = reactive({ comment, pageview, path });\n\n const updateCommentCount = (): void => {\n if (state.comment)\n commentCount({\n serverURL: props.serverURL,\n path: state.path,\n selector: typeof state.comment === 'string' ? state.comment : undefined,\n });\n };\n\n const updatePageviewCount = (): void => {\n if (state.pageview)\n pageviewCount({\n serverURL: props.serverURL,\n path: state.path,\n selector:\n typeof state.pageview === 'string' ? state.pageview : undefined,\n });\n };\n\n const app = root\n ? createApp(() => h(Waline, { path: state.path, ...props }))\n : null;\n\n if (app) app.mount(root!);\n\n const stopComment = watchEffect(updateCommentCount);\n const stopPageview = watchEffect(updatePageviewCount);\n\n return {\n el: root,\n update: ({\n comment,\n pageview,\n path = window.location.pathname,\n ...newProps\n }: Partial<Omit<WalineInitOptions, 'el'>> = {}): void => {\n Object.entries(newProps).forEach(([key, value]) => {\n // eslint-disable-next-line @typescript-eslint/ban-ts-comment\n // @ts-ignore\n // eslint-disable-next-line\n props[key] = value;\n });\n\n state.path = path;\n if (comment !== undefined) state.comment = comment;\n if (pageview !== undefined) state.pageview = pageview;\n },\n destroy: (): void => {\n app?.unmount();\n stopComment();\n stopPageview();\n },\n };\n};\n","declare const VERSION: string;\n\nexport const version = VERSION;\n","import { useUserInfo } from '../composables';\nimport { fetchRecentComment, getRoot } from '../utils';\n\nimport type { WalineComment } from '../typings';\n\nexport interface WalineRecentCommentsOptions {\n /**\n * Waline 服务端地址\n *\n * Waline serverURL\n */\n serverURL: string;\n\n /**\n * 获取最新评论的数量\n *\n * fetch number of latest comments\n */\n count: number;\n\n /**\n * 需要挂载的元素\n *\n * Element to be mounted\n */\n el?: string | HTMLElement;\n\n /**\n * 错误提示消息所使用的语言\n *\n * Language of error message\n *\n * @default 'zh-CN'\n */\n lang?: string;\n}\n\nexport interface WalineRecentCommentsResult {\n /**\n * 评论数据\n *\n * Comment Data\n */\n comments: WalineComment[];\n\n /**\n * 取消挂载挂件\n *\n * Umount widget\n */\n destroy: () => void;\n}\n\nexport const RecentComments = ({\n el,\n serverURL,\n count,\n lang = 'zh-CN',\n}: WalineRecentCommentsOptions): Promise<WalineRecentCommentsResult> => {\n const userInfo = useUserInfo();\n const root = getRoot(el);\n const controller = new AbortController();\n\n return fetchRecentComment({\n serverURL,\n count,\n lang,\n signal: controller.signal,\n token: userInfo.value?.token,\n }).then((comments) => {\n if (root && comments.length) {\n root.innerHTML = `<ul class=\"wl-recent-list\">${comments\n .map(\n (comment) =>\n `<li class=\"wl-recent-item\"><a href=\"${comment.url}\">${comment.nick}</a>:${comment.comment}</li>`\n )\n .join('')}</ul>`;\n\n return {\n comments,\n destroy: (): void => {\n controller.abort();\n root.innerHTML = '';\n },\n };\n }\n\n return {\n comments,\n destroy: (): void => controller.abort(),\n };\n });\n};\n"],"names":["availableMeta","getMeta","meta","filter","item","includes","defaultUploadImage","file","Promise","resolve","reject","reader","FileReader","readAsDataURL","onload","result","toString","onerror","defaultTexRenderer","blockMode","getDefaultSearchOptions","state","next","fetchGif","keyword","pos","query","URLSearchParams","set","fetch","headers","then","resp","json","catch","results","search","word","map","title","src","media","tinygif","url","more","REGEXP","RegExp","source","COLORS","cache","defaultHighlighter","input","index","replace","_match","comment","color","out","length","localeKeys","generateLocale","locale","Object","fromEntries","en","jp","zhCN","zhTW","ptBR","ru","defaultLocales","zh","decodePath","path","decodeURI","err","removeEndingSplash","content","isLinkHttp","link","test","getServerURL","serverURL","getWordLimit","wordLimit","Array","isArray","fallback","value","style","padWithZeros","vNumber","width","numAsString","getTimeAgo","date","now","time","Date","indexOf","timepassed","getTime","days","Math","floor","leave1","hours","leave2","minutes","leave3","round","seconds","vDay","getDate","vMonth","getMonth","getFullYear","dateFormat","fetchEmoji","emojiStore","useStorage","Boolean","info","emojiInfo","folder","getLink","name","prefix","type","errorHandler","console","error","message","JSON_HEADERS","errorCheck","data","errno","TypeError","errmsg","updateComment","lang","token","objectId","method","Authorization","body","JSON","stringify","fetchPageviews","paths","signal","encodeURIComponent","join","counts","updatePageviews","getRoot","el","HTMLElement","document","querySelector","isImage","getImagefromDataTransfer","items","image","from","find","getAsFile","inlineMathStart","inlineMathReg","blockMathReg","parseEmoji","text","emojiMap","placeholder","key","parseMarkdown","highlighter","texRenderer","marked","setOptions","highlight","undefined","breaks","smartLists","smartypants","extensions","level","tokenizer","cap","exec","raw","start","idx","markedTexExtensions","use","parse","getQuery","element","dataset","getAttribute","userInfoStorage","useUserInfo","likeStorage","useLikeStorage","commentCount","window","location","pathname","selector","controller","AbortController","elements","querySelectorAll","userInfo","fetchCommentCount","forEach","innerText","abort","bind","LoadingIcon","size","h","height","viewBox","preserveAspectRatio","cx","cy","fill","stroke","strokeWidth","r","attributeName","repeatCount","dur","values","keyTimes","_sfc_main$3","defineComponent","components","props","default","columnWidth","Number","gap","emits","setup","resizeObserver","wall","ref","columns","getColumnCount","count","getBoundingClientRect","fillColumns","async","itemIndex","nextTick","target","children","reduce","prev","curr","push","redraw","force","scrollY","scrollTo","top","watch","onMounted","ResizeObserver","observe","onBeforeUnmount","unobserve","_sfc_main$2","CloseIcon","class","d","EmojiIcon","ImageIcon","ImageWall","MarkdownIcon","ariaHidden","PreviewIcon","GifIcon","rootId","String","replyId","replyUser","emit","config","inject","editor","userMeta","nick","mail","inputRefs","editorRef","imageUploadRef","emojiButtonRef","emojiPopupRef","gifButtonRef","gifPopupRef","gifSearchInputRef","emoji","tabs","emojiTabIndex","showEmoji","showGif","showPreview","previewText","wordNumber","searchResults","reactive","loading","list","isWordNumberLegal","isSubmitting","computed","isLogin","canUploadImage","imageUploader","insert","textArea","startPosition","selectionStart","endPosition","selectionEnd","scrollTop","substring","focus","uploadImage","uploadText","uploading","submitComment","login","requiredMeta","ua","navigator","userAgent","display_name","email","alert","nickError","mailError","anonymous","wordHint","pid","rid","at","postComment","popupHandler","event","contains","onImageWallScroll","clientHeight","scrollHeight","percent","searchOptions","setTimeout","onGifSearch","useDebounceFn","limit","immediate","onMessageRecive","localStorage","sessionStorage","store","getItem","setItem","addEventListener","match","getWords","accumulator","trim","split","getChinese","getWordNumber","autosize","destroy","emojiConfig","getEmojis","emojis","all","emojiInfos","icon","onUnmounted","removeEventListener","onChange","inputElement","files","onDrop","dataTransfer","preventDefault","onKeyDown","ctrlKey","metaKey","onPaste","clipboardData","onLogin","left","innerWidth","innerHeight","handler","open","postMessage","receiver","close","remember","onLogout","onProfile","gifData","commentStatus","_sfc_main$1","CommentBox","DeleteIcon","LikeIcon","active","ReplyIcon","VerifiedIcon","required","reply","likes","like","useNow","useTimeAgo","insertedAt","isAdmin","isOwner","user_id","isReplyingCurrent","_sfc_main","CommentCard","dark","pageSize","copyright","getConfig","status","page","totalPages","darkmodeStyle","getDarkStyle","useStyleTag","fetchComment","pageNumber","fetchCommentList","refresh","provide","i18n","loadMore","onReply","onSubmit","repliedComment","unshift","onStatusChange","onDelete","confirm","deleteComment","some","_item","i","child","childIndex","onSticky","sticky","onLike","hasLiked","likeComment","id","slice","version","renderVisitorCount","countElements","pageviewCount","update","normalElements","elementsNeedstoBeFetched","init","pageview","initProps","root","Error","app","createApp","Waline","mount","stopComment","watchEffect","stopPageview","newProps","entries","unmount","RecentComments","fetchRecentComment","comments","innerHTML"],"mappings":"AAEA,MAAMA,EAA8B,CAAC,OAAQ,OAAQ,QAExCC,EAAWC,GACtBA,EAAKC,QAAQC,GAASJ,EAAcK,SAASD,KAIlCE,EAAsBC,GACjC,IAAIC,SAAQ,CAACC,EAASC,KACpB,MAAMC,EAAS,IAAIC,WAEnBD,EAAOE,cAAcN,GACrBI,EAAOG,OAAS,IAAYL,EAAQE,EAAOI,QAAQC,YAAc,IACjEL,EAAOM,QAAUP,CAAM,IAGdQ,EAAsBC,IACnB,IAAdA,EACI,wDACA,8DAEOC,EAA0B,KA2CrC,MAAMC,EAAQ,CACZC,KAAM,IAGFC,EAAW,EACfC,UACAC,UAEA,MACMC,EAAQ,IAAIC,gBAAgB,wBAOlC,OALAD,EAAME,IAAI,MAAO,gBACjBF,EAAME,IAAI,QAAS,MACnBF,EAAME,IAAI,MAAOH,GAAO,IACxBC,EAAME,IAAI,IAAKJ,GAERK,MAAM,iCAAcH,EAAMV,aAAc,CAC7Cc,QAAS,CAEP,eAAgB,sBAGjBC,MAAMC,GAASA,EAAKC,SACpBC,OAAM,KAAA,CAASZ,KAAMG,GAAO,GAAIU,QAAS,MAAM,EAGpD,MAAO,CACLC,OAAQ,CAACC,EAAO,KACdd,EAAS,CAAEC,QAASa,IAAQN,MAAMC,IAChCX,EAAMC,KAAOU,EAAKV,KAEXU,EAAKG,QAAQG,KAAKlC,IAAU,CACjCmC,MAAOnC,EAAKmC,MACZC,IAAKpC,EAAKqC,MAAM,GAAGC,QAAQC,WAGjCC,KAAOP,GACLd,EAAS,CAAEC,QAASa,EAAMZ,IAAKJ,EAAMC,OAAQS,MAAMC,IACjDX,EAAMC,KAAOU,EAAKV,KAEXU,EAAKG,QAAQG,KAAKlC,IAAU,CACjCmC,MAAOnC,EAAKmC,MACZC,IAAKpC,EAAKqC,MAAM,GAAGC,QAAQC,WAGlC,ECjFGE,EAAS,IAAIC,OACjB,IALA,wFAKgBC,UAJQ,IAIoBA,eAHlB,uBAGqDA,cAFpD,uBAEuFA,WAClH,OAGIC,EAAS,CACb,SACA,SACA,SACA,SACA,SACA,SACA,SACA,SACA,SACA,SACA,SACA,SACA,UAEIC,EAAgC,CAAA,EAEzBC,EAAsBC,IACjC,IAAIC,EAAQ,EAEZ,OAAOD,EAAME,QAAQR,GAAQ,CAACS,EAAQjB,EAAckB,KAClD,GAAIA,EAAS,MAAO,kCAAkCA,WACtD,GAAa,MAATlB,EAAc,MAAO,OAEzB,IAAImB,EAEAP,EAAMZ,GAAOmB,EAAQP,EAAMZ,IAE7BmB,EAAQR,EAAOI,GACfH,EAAMZ,GAAQmB,GAGhB,MAAMC,EAAM,wBAAwBD,MAAUnB,WAI9C,OAFAe,IAAUA,EAAQJ,EAAOU,OAElBD,CAAG,GACV,ECtEEE,EAAa,CACjB,OACA,YACA,OACA,YACA,OACA,WACA,cACA,OACA,SACA,OACA,aACA,QACA,cACA,UACA,UACA,OACA,UACA,QACA,cACA,UACA,UACA,QACA,OACA,MACA,YACA,QACA,SACA,QACA,SACA,OACA,WACA,YACA,SACA,SACA,SACA,SACA,SACA,SACA,MACA,uBACA,WAGWC,EAAkBC,GAC7BC,OAAOC,YACLF,EAAOvB,KAAI,CAAClC,EAAMgD,IAAU,CAACO,EAAWP,GAAQhD,MC9CpD,IAAA4D,EAAeJ,EAAe,CAC5B,WACA,wCACA,SACA,qCACA,UACA,WACA,kBACA,kBACA,SACA,OACA,cACA,QACA,eACA,WACA,UACA,eACA,UACA,QACA,eACA,cACA,cACA,YACA,WACA,WACA,YACA,QACA,SACA,QACA,SACA,QACA,2EACA,YACA,UACA,UACA,OACA,UACA,QACA,QACA,MACA,aACA,YCzCFK,EAAeL,EAAe,CAC5B,SACA,yBACA,UACA,mBACA,MACA,QACA,UACA,aACA,OACA,OACA,cACA,OACA,QACA,OACA,KACA,UACA,QACA,MACA,YACA,KACA,KACA,MACA,KACA,OACA,SACA,SACA,QACA,MACA,SACA,MACA,gDACA,KACA,OACA,OACA,OACA,SACA,KACA,MACA,MACA,SACA,SCzCFM,EAAeN,EAAe,CAC5B,KACA,aACA,KACA,aACA,KACA,KACA,OACA,SACA,KACA,KACA,OACA,KACA,OACA,KACA,KACA,UACA,KACA,KACA,OACA,KACA,MACA,MACA,KACA,KACA,OACA,KACA,KACA,KACA,KACA,IACA,+BACA,KACA,KACA,KACA,KACA,KACA,KACA,KACA,MACA,QACA,SCzCFO,EAAeP,EAAe,CAC5B,KACA,aACA,KACA,aACA,KACA,KACA,OACA,SACA,KACA,KACA,OACA,KACA,OACA,KACA,KACA,UACA,KACA,KACA,OACA,KACA,MACA,MACA,KACA,KACA,OACA,KACA,KACA,KACA,KACA,IACA,+BACA,KACA,KACA,KACA,KACA,KACA,KACA,KACA,MACA,QACA,SCzCFQ,EAAeR,EAAe,CAC5B,UACA,0CACA,SACA,8CACA,UACA,WACA,kBACA,4BACA,SACA,OACA,cACA,YACA,oBACA,cACA,YACA,mBACA,aACA,QACA,gBACA,iBACA,gBACA,cACA,aACA,cACA,WACA,SACA,OACA,QACA,SACA,WACA,gFACA,UACA,UACA,UACA,OACA,UACA,QACA,QACA,MACA,gBACA,uBCzCFS,EAAeT,EAAe,CAC5B,YACA,uCACA,YACA,yDACA,WACA,iBACA,uBACA,yBACA,YACA,OACA,cACA,WACA,iBACA,cACA,WACA,oBACA,SACA,SACA,wBACA,eACA,wBACA,wBACA,aACA,eACA,WACA,iBACA,mBACA,QACA,SACA,QACA,8EACA,YACA,UACA,UACA,OACA,UACA,QACA,QACA,MACA,YACA,wBC/BW,MAAAU,EAA0B,CACrCC,GAAIL,EACJ,QAASA,EACT,QAASA,EACT,QAASC,EACT,QAASA,EACTH,GAAIA,EACJ,QAASA,EACT,QAASA,EACTC,GAAIA,EACJ,QAASA,EACT,QAASA,EACT,QAASG,EACT,QAASA,EACTC,GAAIA,EACJ,QAASA,EACT,QAASA,ywpDCnBJ,MCTMG,GAAcC,IACzB,IACEA,EAAOC,UAAUD,EAGlB,CAFC,MAAOE,GAER,CAED,OAAOF,CAAI,EAGAG,GAAqB,CAACC,EAAU,KAC3CA,EAAQxB,QAAQ,OAAQ,IAEbyB,GAAcC,GACzB,kBAAkBC,KAAKD,GCgBZE,GAAgBC,IAC3B,MAAMnE,EAAS6D,GAAmBM,GAElC,OAAOJ,GAAW/D,GAAUA,EAAS,WAAWA,GAAQ,EAGpDoE,GACJC,GAEAC,MAAMC,QAAQF,GAAaA,IAAYA,GAAY,CAAC,EAAGA,GAEnDG,GAAW,CACfC,EACAD,IAEiB,mBAAVC,EAAuBA,GAAkB,IAAVA,GAA0BD,EC7C5DE,GAAQ,2VCERC,GAAe,CAACC,EAAiBC,KACrC,IAAIC,EAAcF,EAAQ3E,WAE1B,KAAO6E,EAAYnC,OAASkC,GAC1BC,EAAc,IAAMA,EAGtB,OAAOA,CAAW,EAWPC,GAAa,CACxBC,EACAC,EACAnC,KAEA,IAAKkC,EAAM,MAAO,GAElB,MAAME,EACY,iBAATF,EACH,IAAIG,MAA4B,IAAvBH,EAAKI,QAAQ,KAAcJ,EAAK1C,QAAQ,KAAM,KAAO0C,GAC9DA,EAEAK,EAAaJ,EAAIK,UAAYJ,EAAKI,UAElCC,EAAOC,KAAKC,MAAMJ,EAAc,OAEtC,GAAa,IAATE,EAAY,CAId,MAAMG,EAASL,EAAU,MACnBM,EAAQH,KAAKC,MAAMC,EAAM,MAE/B,GAAc,IAAVC,EAAa,CAIf,MAAMC,EAASF,OACTG,EAAUL,KAAKC,MAAMG,EAAM,KAGjC,GAAgB,IAAZC,EAAe,CAEjB,MAAMC,EAASF,MAGf,MAAO,GAFSJ,KAAKO,MAAMD,EAAS,QAEfhD,EAAOkD,SAC7B,CAED,MAAO,GAAGH,KAAW/C,EAAO+C,SAC7B,CAED,MAAO,GAAGF,KAAS7C,EAAO6C,OAC3B,CAED,OAAIJ,EAAO,EAAUzC,EAAOmC,IAExBM,EAAO,EAAU,GAAGA,KAAQzC,EAAOyC,OAvDf,CAACP,IACzB,MAAMiB,EAAOtB,GAAaK,EAAKkB,UAAW,GACpCC,EAASxB,GAAaK,EAAKoB,WAAa,EAAG,GAGjD,MAAO,GAFOzB,GAAaK,EAAKqB,cAAe,MAE5BF,KAAUF,GAAM,EAoD5BK,CAAWpB,EAAK,EC5DnBqB,GAAcvC,IAClB,MAAMwC,EAAaC,GACjB,eACA,CAAE,GAGEzG,EARN0G,QAAQ,0BAA0BzC,KAQRD,IAE1B,GAAIhE,EAAQ,CACV,MAAM2G,EAAOH,EAAW/B,MAAMT,GAE9B,GAAI2C,EAAM,OAAOlH,QAAQC,QAAQiH,EAClC,CAED,OAAO7F,MAAM,GAAGkD,eACbhD,MAAMC,GAASA,EAAKC,SACpBF,MAAM4F,IACL,MAAMD,EAAO,CACXE,OAAQ7C,KACL4C,GAKL,OAFI5G,IAAQwG,EAAW/B,MAAMT,GAAQ2C,GAE9BA,CAAI,GACX,EAGAG,GAAU,CAACC,EAAcF,EAAS,GAAIG,EAAS,GAAIC,EAAO,KAC9D,GAAGJ,EAAS,GAAGA,KAAY,KAAKG,IAASD,IAAOE,EAAO,IAAIA,IAAS,KCtCzDC,GAAgBtD,IACV,eAAbA,EAAImD,MAAuBI,QAAQC,MAAMxD,EAAIyD,QAAQ,ECMrDC,GAAuC,CAE3C,eAAgB,oBAGZC,GAAa,CAAcC,EAA0BT,EAAO,MAChE,GAAoB,iBAATS,GAAsBA,EAAwBC,MACvD,MAAM,IAAIC,UACR,SAASX,iBAAqBS,EAAwBC,UACnDD,EAAwBG,UAI/B,OAAOH,CAAS,EAwLLI,GAAgB,EAC3BzD,YACA0D,OACAC,QACAC,cACGP,KAQI1G,MAAM,GAAGqD,aAAqB4D,UAAiBF,IAAQ,CAC5DG,OAAQ,MACRjH,QARsC,CAEtC,eAAgB,mBAChBkH,cAAe,UAAUH,KAMzBI,KAAMC,KAAKC,UAAUZ,KACpBxG,MAAMC,GAASA,EAAKC,SAUZmH,GAAiB,EAC5BlE,YACA0D,OACAS,QACAC,YAEAzH,MACE,GAAGqD,kBAA0BqE,mBAC3BF,EAAMG,KAAK,cACHZ,IACV,CAAEU,WAEDvH,MAAMC,GAASA,EAAKC,SACpBF,MAAMwG,GAASD,GAAWC,EAAM,iBAEhCxG,MAAM0H,GAAYpE,MAAMC,QAAQmE,GAAUA,EAAS,CAACA,KAQ5CC,GAAkB,EAC7BxE,YACA0D,OACAnE,UAEA5C,MAAM,GAAGqD,kBAA0B0D,IAAQ,CACzCG,OAAQ,OACRjH,QAASuG,GACTY,KAAMC,KAAKC,UAAU,CAAE1E,WAEtB1C,MAAMC,GAASA,EAAKC,SACpBF,MAAMwG,GAASD,GAAWC,EAAM,iBCzQxBoB,GACXC,GAEAA,aAAcC,YACVD,EACc,iBAAPA,EACPE,SAASC,cAAcH,GACvB,KCPAI,GAAW5J,GACfA,EAAK4H,KAAK3H,SAAS,SAER4J,GACXC,IAEA,MAAMC,EAAQ9E,MAAM+E,KAAKF,GAAOG,KAAKL,IAErC,OAAOG,EAASA,EAAMG,YAAuB,IAAI,oqnCCLnD,MAAMC,GAAkB,UAClBC,GAAgB,aAChBC,GAAe,mDCIRC,GAAa,CAACC,EAAO,GAAIC,EAA4B,CAAA,IAChED,EAAKtH,QAAQ,YAAY,CAACwH,EAAaC,IACrCF,EAASE,GACL,8BAA8BF,EAASE,YAAcA,MACrDD,IASKE,GAAgB,CAC3BlG,GACE+F,WAAUI,cAAaC,kBASzB,GAPAC,GAAOC,WAAW,CAChBC,UAAWJ,QAAeK,EAC1BC,QAAQ,EACRC,YAAY,EACZC,aAAa,IAGXP,EAAa,CACf,MAAMQ,ED3ByB,CACjCR,GA2CO,CAzC+C,CACpDnD,KAAM,YACN4D,MAAO,QACPC,UAAUnJ,GACR,MAAMoJ,EAAMnB,GAAaoB,KAAKrJ,GAE9B,GAAY,OAARoJ,EACF,MAAO,CACL5D,KAAM,OACN8D,IAAKF,EAAI,GACTjB,KAAMM,GAAY,EAAMW,EAAI,IAKjC,GAGoD,CACrD9D,KAAM,aACN4D,MAAO,SACPK,MAAMvJ,GACJ,MAAMwJ,EAAMxJ,EAAIJ,OAAOmI,IAEvB,OAAgB,IAATyB,EAAaA,EAAMxJ,EAAIkB,MAC/B,EACDiI,UAAUnJ,GACR,MAAMoJ,EAAMpB,GAAcqB,KAAKrJ,GAE/B,GAAY,OAARoJ,EACF,MAAO,CACL5D,KAAM,OACN8D,IAAKF,EAAI,GACTjB,KAAMM,GAAY,EAAOW,EAAI,IAKlC,ICdkBK,CAAoBhB,GAEvCC,GAAOgB,IAAI,CAAET,cACd,CAED,OAAOP,GAAOiB,MAAMzB,GAAW7F,EAAS+F,GAAU,ECvCvCwB,GAAYC,GACvBA,EAAQC,QAAQ7H,MAAQ4H,EAAQE,aAAa,MCmB/C,IAAIC,GAAsC,KAEnC,MAAMC,GAAc,IACzBD,KACCA,GAAkBhF,GARG,cAUpB,CAAA,IChBJ,IAAIkF,GAA8B,KAE3B,MAAMC,GAAiB,IAC5BD,KAAgBA,GAAclF,GATf,cAS8C,KCgClDoF,GAAe,EAC1B1H,YACAT,OAAOoI,OAAOC,SAASC,SACvBC,WAAW,wBACXpE,OAAO,YAGP,MAAMqE,EAAa,IAAIC,gBAGjBC,EAAWrD,SAASsD,iBAA8BJ,GAElDK,EAAWZ,KAmBjB,OAjBIU,EAASzJ,QR5BkB,GAC/BwB,YACA0D,OACAS,QACAC,SACAT,YAEA,MAAM/G,EAAkC,CAAA,EAIxC,OAFI+G,IAAO/G,EAAQkH,cAAgB,UAAUH,KAG3ChH,MACE,GAAGqD,4BAAoCqE,mBACrCF,EAAMG,KAAK,cACHZ,IACV,CAAEU,SAAQxH,YAETC,MAAMC,GAASA,EAAKC,SACpBF,MAAMwG,GAASD,GAAWC,EAAM,mBAEhCxG,MAAM0H,GAAYpE,MAAMC,QAAQmE,GAAUA,EAAS,CAACA,IACvD,EQOK6D,CAAkB,CACrBpI,UAAWD,GAAaC,GACxBmE,MAAOhE,MAAM+E,KAAK+C,GAAU7K,KAAK+J,GAC/B7H,GAAW6H,EAAQC,QAAQ7H,MAAQ4H,EAAQE,aAAa,OAAS9H,KAEnEmE,OACAU,OAAQ2D,EAAW3D,OACnBT,MAAOwE,EAAS7H,OAAOqD,QAEtB9G,MAAM0H,IACL0D,EAASI,SAAQ,CAAClB,EAASjJ,KACzBiJ,EAAQmB,UAAY/D,EAAOrG,GAAOpC,UAAU,GAC5C,IAEHkB,MAAM+F,IAEJgF,EAAWQ,MAAMC,KAAKT,EAAW,wsGCzEnC,MAoHMU,GAAqD,EAAGC,UACnEC,GACE,MACA,CACEjI,MAAOgI,EACPE,OAAQF,EACRG,QAAS,cACTC,oBAAqB,YAEvBH,GACE,SACA,CACEI,GAAI,GACJC,GAAI,GACJC,KAAM,OACNC,OAAQ,eACRC,YAAa,IACbC,EAAG,KAEH,mBAAoB,SAEtBT,GAAE,mBAAoB,CACpBU,cAAe,YACfvG,KAAM,SACNwG,YAAa,aACbC,IAAK,KACLC,OAAQ,oBACRC,SAAU,UC7ElB,IAAAC,GAAeC,GAAgB,CAC7B/G,KAAM,YAENgH,WAAY,CACVnB,gBAGFoB,MAAO,CACL7E,MAAO,CAAElC,KAAM3C,MAAyC2J,QAAS,IAAM,IACvEC,YAAa,CAAEjH,KAAMkH,OAAQF,QAAS,KACtCG,IAAK,CAAEnH,KAAMkH,OAAQF,QAAS,IAGhCI,MAAO,CAAC,UAERC,MAAMN,GACJ,IAAIO,EAAwC,KAC5C,MAAMC,EAAOC,GAA2B,MAClCnO,EAAQmO,GAA6B,CAAA,GACrCC,EAAUD,GAAc,IAExBE,EAAiB,KACrB,MAAMC,EAAQpJ,KAAKC,OAChB+I,EAAK/J,MAAOoK,wBAAwBhK,MAAQmJ,EAAMI,MAChDJ,EAAME,YAAcF,EAAMI,MAG/B,OAAOQ,EAAQ,EAAIA,EAAQ,CAAC,EAMxBE,EAAcC,MAAOC,IACzB,GAAIA,GAAahB,EAAM7E,MAAMxG,OAAQ,aAE/BsM,KAEN,MAIMC,EAJa5K,MAAM+E,KACvBmF,EAAK/J,OAAO0K,UAAY,IAGAC,QAAO,CAACC,EAAMC,IACtCA,EAAKT,wBAAwB9B,OAC7BsC,EAAKR,wBAAwB9B,OACzBuC,EACAD,IAGNX,EAAQjK,MAAM0J,OAAOe,EAAO3D,QAAQlJ,QAAQkN,KAAKP,SAE3CF,EAAYE,EAAY,EAAE,EAG5BQ,EAAST,MAAOU,GAAQ,KAC5B,GAAIf,EAAQjK,MAAM9B,SAAWgM,MAAqBc,EAAO,OAzBrC,IAACb,EA2BrBF,EAAQjK,OA3BamK,EA2BSD,IA1B9B,IAAIrK,MAAMsK,GAAOxB,KAAK,MAAM7L,KAAI,IAAM,MA4BtC,MAAMmO,EAAU5D,OAAO4D,cAEjBZ,EAAY,GAElBhD,OAAO6D,SAAS,CAAEC,IAAKF,GAAU,EAwBnC,OArBAG,IACE,IAAM,CAAC7B,EAAM7E,SACb,KACE7I,EAAMmE,MAAQ,GACd+K,GAAO,EAAK,IAGhBK,IACE,IAAM,CAAC7B,EAAME,YAAaF,EAAMI,OAChC,IAAMoB,MAGRM,IAAU,KACRN,GAAO,GACPjB,EAAiB,IAAIwB,gBAAe,IAAMP,MAE1CjB,EAAeyB,QAAQxB,EAAK/J,MAAO,IAGrCwL,IAAgB,IAAM1B,EAAgB2B,UAAU1B,EAAK/J,SAE9C,CACLiK,UACApO,QACAkO,OAEH,4IC8IH2B,GAAerC,GAAgB,CAC7B/G,KAAM,aAENgH,WAAY,CACVqC,UFhT4D,EAAGvD,UACjEC,GACE,MACA,CACEuD,MAAO,gBACPrD,QAAS,gBACTnI,MAAOgI,EACPE,OAAQF,GAEV,CACEC,GAAE,OAAQ,CACRwD,EAAG,8MACHlD,KAAM,iBAERN,GAAE,OAAQ,CACRwD,EAAG,wTACHlD,KAAM,WEiSVmD,UFlR0C,IAC5CzD,GACE,MACA,CAAEE,QAAS,gBAAiBnI,MAAO,KAAMkI,OAAQ,MACjDD,GAAE,OAAQ,CACRwD,EAAG,smDACHlD,KAAM,kBE6QRoD,UFzQ0C,IAC5C1D,GAAE,MAAO,CAAEE,QAAS,gBAAiBnI,MAAO,KAAMkI,OAAQ,MAAQ,CAChED,GAAE,OAAQ,CACRwD,EAAG,0NACHlD,KAAM,iBAERN,GAAE,OAAQ,CACRwD,EAAG,sfACHlD,KAAM,mBEkQRqD,srBACAC,aFnO6C,IAC/C5D,GACE,MACA,CAAEjI,MAAO,KAAMkI,OAAQ,KAAM4D,WAAY,QACzC7D,GAAE,OAAQ,CACRwD,EAAG,8MACHlD,KAAM,kBE8NRwD,YFhP4C,IAC9C9D,GAAE,MAAO,CAAEE,QAAS,gBAAiBnI,MAAO,KAAMkI,OAAQ,MAAQ,CAChED,GAAE,OAAQ,CACRwD,EAAG,wpBACHlD,KAAM,iBAERN,GAAE,OAAQ,CACRwD,EAAG,ydACHlD,KAAM,mBEyORR,eACAiE,QFnKwC,IAC1C/D,GACE,MACA,CACEjI,MAAO,GACPkI,OAAQ,GACRK,KAAM,eACNJ,QAAS,aAEX,CACEF,GAAE,OAAQ,CACRpI,MAAO,+BACP4L,EAAG,8eAELxD,GAAE,OAAQ,CACRwD,EAAG,sUEuJTtC,MAAO,CACL8C,OAAQ,CACN7J,KAAM8J,OACN9C,QAAS,IAEX+C,QAAS,CACP/J,KAAM8J,OACN9C,QAAS,IAEXgD,UAAW,CACThK,KAAM8J,OACN9C,QAAS,KAIbI,MAAO,CAAC,SAAU,gBAElBC,MAAMN,GAAOkD,KAAEA,IACb,MAAMC,EAASC,GACb,UAGIC,ElBlUR5K,GAAmB,4BAA6B,IkBmUxC6K,ElB1UR7K,GAAqB,mBAAoB,CACvC8K,KAAM,GACNC,KAAM,GACNxN,KAAM,KkBwUAsI,EAAWZ,KAEX+F,EAAYhD,GAAsC,CAAA,GAClDiD,EAAYjD,GAAgC,MAC5CkD,EAAiBlD,GAA6B,MAC9CmD,EAAiBnD,GAA2B,MAC5CoD,EAAgBpD,GAA2B,MAC3CqD,EAAerD,GAA2B,MAC1CsD,EAActD,GAA2B,MACzCuD,EAAoBvD,GAA6B,MAEjDwD,EAAQxD,GAAqC,CAAEyD,KAAM,GAAI3Q,IAAK,CAAC,IAC/D4Q,EAAgB1D,GAAI,GACpB2D,EAAY3D,IAAI,GAChB4D,EAAU5D,IAAI,GACd6D,EAAc7D,IAAI,GAClB8D,EAAc9D,GAAI,IAClB+D,EAAa/D,GAAI,GAEjBgE,EAAgBC,GAAS,CAC7BC,SAAS,EACTC,KAAM,KAGFvO,EAAYoK,GAAI,GAChBoE,EAAoBpE,IAAI,GAExB3K,EAAU2K,GAAI,IAEdqE,EAAerE,IAAI,GAEnB3L,EAASiQ,IAAS,IAAM5B,EAAO1M,MAAM3B,SAErCkQ,EAAUD,IAAS,IAAMrM,QAAQ4F,EAAS7H,OAAOqD,SAEjDmL,EAAiBF,IAAS,KAAqC,IAA/B5B,EAAO1M,MAAMyO,gBAE7CC,EAAUrP,IACd,MAAMsP,EAAW1B,EAAUjN,MACrB4O,EAAgBD,EAASE,eACzBC,EAAcH,EAASI,cAAgB,EACvCC,EAAYL,EAASK,UAE3BpC,EAAO5M,MACL2O,EAAS3O,MAAMiP,UAAU,EAAGL,GAC5BvP,EACAsP,EAAS3O,MAAMiP,UAAUH,EAAaH,EAAS3O,MAAM9B,QACvDyQ,EAASO,QACTP,EAASE,eAAiBD,EAAgBvP,EAAQnB,OAClDyQ,EAASI,aAAeH,EAAgBvP,EAAQnB,OAChDyQ,EAASK,UAAYA,CAAS,EAU1BG,EAAepU,IACnB,MAAMqU,EAAa,KAAK1C,EAAO1M,MAAM3B,OAAOgR,aAAatU,EAAKuH,UAI9D,OAFAoM,EAAOU,GAEApU,QAAQC,UACZsB,MAAK,IAAOmQ,EAAO1M,MAAMyO,cAAsC1T,KAC/DwB,MAAMY,IACLyP,EAAO5M,MAAQ4M,EAAO5M,MAAMnC,QAC1BuR,EACA,SAASrU,EAAKuH,SAASnF,KACxB,GACD,EAgCAmS,EAAgB,KACpB,MAAM5P,UAAEA,EAAS0D,KAAEA,EAAImM,MAAEA,EAAK3P,UAAEA,EAAS4P,aAAEA,GAAiB9C,EAAO1M,MAE7DjC,EAA6B,CACjCA,QAASsB,EAAQW,MACjB8M,KAAMD,EAAS7M,MAAM8M,KACrBC,KAAMF,EAAS7M,MAAM+M,KACrBxN,KAAMsN,EAAS7M,MAAMT,KACrBkQ,GAAIC,UAAUC,UACdxS,IAAKuP,EAAO1M,MAAMf,MAGpB,GAAI4I,EAAS7H,OAAOqD,MAGlBtF,EAAQ+O,KAAOjF,EAAS7H,MAAM4P,aAC9B7R,EAAQgP,KAAOlF,EAAS7H,MAAM6P,MAC9B9R,EAAQwB,KAAOsI,EAAS7H,MAAM7C,QACzB,CACL,GAAc,UAAVoS,EAAmB,OAGvB,GAAIC,EAAa7O,QAAQ,SAAW,IAAM5C,EAAQ+O,KAGhD,OAFAE,EAAUhN,MAAM8M,MAAMoC,QAEfY,MAAMzR,EAAO2B,MAAM+P,WAI5B,GACGP,EAAa7O,QAAQ,SAAW,IAAM5C,EAAQgP,MAC9ChP,EAAQgP,OACN,gDAAgD1G,KAAKtI,EAAQgP,MAIhE,OAFAC,EAAUhN,MAAM+M,MAAMmC,QAEfY,MAAMzR,EAAO2B,MAAMgQ,WAI5B,IAAKjS,EAAQA,QAGX,YAFAkP,EAAUjN,OAAOkP,QAKdnR,EAAQ+O,OAAM/O,EAAQ+O,KAAOzO,EAAO2B,MAAMiQ,UACjD,CAEA,IAAK7B,EAAkBpO,MACrB,OAAO8P,MACLzR,EAAO2B,MAAMkQ,SACVrS,QAAQ,KAAO+B,EAA+B,GAAGpE,YACjDqC,QAAQ,KAAO+B,EAA+B,GAAGpE,YACjDqC,QAAQ,KAAMkQ,EAAW/N,MAAMxE,aAGtCuC,EAAQA,QAAUmH,GAAWnH,EAAQA,QAASyP,EAAMxN,MAAMlD,KAEtDyM,EAAMgD,SAAWhD,EAAM8C,SACzBtO,EAAQoS,IAAM5G,EAAMgD,QACpBxO,EAAQqS,IAAM7G,EAAM8C,OACpBtO,EAAQsS,GAAK9G,EAAMiD,WAGrB6B,EAAarO,OAAQ,EXzXA,GACzBN,YACA0D,OACAC,QACAtF,cAEA,MAAMzB,EAAkC,CAEtC,eAAgB,oBAKlB,OAFI+G,IAAO/G,EAAQkH,cAAgB,UAAUH,KAEtChH,MAAM,GAAGqD,kBAA0B0D,IAAQ,CAChDG,OAAQ,OACRjH,UACAmH,KAAMC,KAAKC,UAAU5F,KACpBxB,MAAMC,GAASA,EAAKC,QAAuC,EW0W1D6T,CAAY,CACV5Q,YACA0D,OACAC,MAAOwE,EAAS7H,OAAOqD,MACvBtF,YAECxB,MAAMC,IAGL,GAFA6R,EAAarO,OAAQ,EAEjBxD,EAAK0G,OAAQ,OAAO4M,MAAMtT,EAAK0G,QAEnCuJ,EAAK,SAAUjQ,EAAKuG,MAEpB6J,EAAO5M,MAAQ,GAEf8N,EAAY9N,MAAQ,GAEhBuJ,EAAMgD,SAASE,EAAK,eAAe,IAExC/P,OAAOyC,IACNkP,EAAarO,OAAQ,EAErB8P,MAAM3Q,EAAIyD,QAAQ,GAClB,EA+DA2N,EAAgBC,IAEhBrD,EAAenN,MAAsByQ,SAASD,EAAM/F,SACpD2C,EAAcpN,MAAsByQ,SAASD,EAAM/F,UAErDkD,EAAU3N,OAAQ,GAGhBqN,EAAarN,MAAsByQ,SAASD,EAAM/F,SAClD6C,EAAYtN,MAAsByQ,SAASD,EAAM/F,UAEnDmD,EAAQ5N,OAAQ,EAAK,EAGnB0Q,EAAoBpG,MAAOkG,IAC/B,MAAMxB,UAAEA,EAAS2B,aAAEA,EAAYC,aAAEA,GAC/BJ,EAAM/F,OACFoG,GAAWF,EAAe3B,GAAa4B,EACvCE,EAAgBpE,EAAO1M,MAAMpD,OAC7BZ,EAAUuR,EAAkBvN,OAAOA,OAAS,GAE9C6Q,EAAU,IAAO7C,EAAcE,UAEnCF,EAAcE,SAAU,EAExBF,EAAcG,KAAKrD,QACbgG,EAAc1T,WACR0T,EAAc1T,KAAKpB,EAASgS,EAAcG,KAAKjQ,cAC/C4S,EAAclU,OAAOZ,IAGjCgS,EAAcE,SAAU,EAExB6C,YAAW,KACRP,EAAM/F,OAA0BuE,UAAYA,CAAS,GACrD,IAAG,EAGFgC,EAAcC,IAAeT,IACjCxC,EAAcG,KAAO,GACrBuC,EAAkBF,EAAM,GACvB,KAGHpF,GACE,CAACsB,EAAQqB,IACT,EAAErB,EAAQqB,MACR,MAAQnO,UAAWsR,GAAUxE,EAEzBwE,EACEnD,EAAamD,EAAM,IAAmB,IAAbA,EAAM,IACjCtR,EAAUI,MAAQkR,EAAM,GACxB9C,EAAkBpO,OAAQ,GACjB+N,EAAamD,EAAM,IAC5BtR,EAAUI,MAAQkR,EAAM,GACxB9C,EAAkBpO,OAAQ,IAE1BJ,EAAUI,MAAQkR,EAAM,GACxB9C,EAAkBpO,OAAQ,IAG5BJ,EAAUI,MAAQ,EAClBoO,EAAkBpO,OAAQ,EAC5B,GAEF,CAAEmR,WAAW,IAGf/F,GAAMwC,GAAStD,MAAOsD,IACpB,IAAKA,EAAS,OAEd,MAAMkD,EAAgBpE,EAAO1M,MAAMpD,OAG/B2Q,EAAkBvN,QAAOuN,EAAkBvN,MAAMA,MAAQ,IAE7DgO,EAAcE,SAAU,EAExBF,EAAcG,KAAO2C,EAActH,cACzBsH,EAActH,gBACdsH,EAAclU,OAAO,IAE/BoR,EAAcE,SAAU,CAAK,IAI/B,MAAMkD,EAAkB,EAAGrO,WACpBA,GAAsB,YAAdA,EAAKP,OAElBqF,EAAS7H,MAAQ,IAAK6H,EAAS7H,SAAU+C,EAAKA,MAE9C,CAACsO,aAAcC,gBACZ3W,QAAQ4W,GAAUA,EAAMC,QAAQ,iBAChCzJ,SAASwJ,GACRA,EAAME,QAAQ,cAAe/N,KAAKC,UAAUkE,MAC7C,EA6CL,OA1CAwD,IAAU,KACR/G,SAASb,KAAKiO,iBAAiB,QAASnB,GACxClJ,OAAOqK,iBAAiB,UAAWN,GAGnChG,IACE,IAAMwB,EAAO5M,QACZA,IACC,MAAMwF,YAAEA,EAAWC,YAAEA,GAAgBiH,EAAO1M,MAE5CX,EAAQW,MAAQA,EAChB8N,EAAY9N,MAAQuF,GAAcvF,EAAO,CACvCoF,SAAUoI,EAAMxN,MAAMlD,IACtB0I,cACAC,gBAEFsI,EAAW/N,MC1rBQ,CAACX,GANN,CAACA,GACvBA,EAAQsS,MAAM,8BAAgC,GAM9CC,CAASvS,GAASsL,QAChB,CAACkH,EAAahV,IACZgV,GAA+B,KAAhBhV,EAAKiV,OAAgB,EAAIjV,EAAKiV,OAAOC,MAAM,QAAQ7T,SACpE,GAPsB,CAACmB,GACzBA,EAAQsS,MAAM,sBAAwB,GAOlCK,CAAW3S,GAASnB,ODqrBG+T,CAAcjS,GAE7BA,EAAOkS,GAASjF,EAAUjN,OACzBkS,GAASC,QAAQlF,EAAUjN,MAAO,GAEzC,CAAEmR,WAAW,IAIf/F,IACE,IAAMsB,EAAO1M,MAAMwN,QAClB4E,IACCC,Ob3qBRC,Ea2qBkBzS,MAAMC,QAAQsS,GAAeA,EAAc,GbzqB7DpX,QAAQuX,IACND,EAAOxV,KAAK0Q,GACO,iBAAVA,EACH1L,GAAW1C,GAAmBoO,IAC9BxS,QAAQC,QAAQuS,MAEtBjR,MAAMiW,IACN,MAAMJ,EAAiC,CACrC3E,KAAM,GACN3Q,IAAK,CAAE,GAmBT,OAhBA0V,EAAWzK,SAAS5F,IAClB,MAAMG,KAAEA,EAAIF,OAAEA,EAAMqQ,KAAEA,EAAIlQ,OAAEA,EAAMC,KAAEA,EAAIkC,MAAEA,GAAUvC,EAEpDiQ,EAAY3E,KAAK3C,KAAK,CACpBxI,OACAmQ,KAAMpQ,GAAQoQ,EAAMrQ,EAAQG,EAAQC,GACpCkC,MAAOA,EAAM5H,KAAKlC,IAChB,MAAM0K,EAAM,GAAG/C,GAAU,KAAK3H,IAI9B,OAFAwX,EAAYtV,IAAIwI,GAAOjD,GAAQzH,EAAMwH,EAAQG,EAAQC,GAE9C8C,CAAG,KAEZ,IAGG8M,CAAW,Ka6oB6C7V,MACtDmQ,IACCc,EAAMxN,MAAQ0M,CAAM,Ib9qBT,IACvB4F,Ca+qBS,GACH,CAAEnB,WAAW,GACd,IAGHuB,IAAY,KACVpO,SAASb,KAAKkP,oBAAoB,QAASpC,GAC3ClJ,OAAOsL,oBAAoB,UAAWvB,EAAgB,IAGjD,CAEL1E,SACArO,SAGAqQ,SACAkE,SAtTe,KACf,MAAMC,EAAe3F,EAAelN,MAEhC6S,EAAaC,OAAStE,EAAexO,OACvCmP,EAAY0D,EAAaC,MAAM,IAAIvW,MAAK,KAEtCsW,EAAa7S,MAAQ,EAAE,GACvB,EAgTJ+S,OA1UcvC,IACd,GAAIA,EAAMwC,cAActO,MAAO,CAC7B,MAAM3J,EAAO0J,GAAyB+L,EAAMwC,aAAatO,OAErD3J,GAAQyT,EAAexO,QACzBmP,EAAYpU,GACZyV,EAAMyC,iBAEV,GAmUAC,UAjWiB1C,IACjB,MAAMlL,EAAMkL,EAAMlL,KAGbkL,EAAM2C,SAAW3C,EAAM4C,UAAoB,UAAR9N,GAAiBgK,GAAe,EA8VxE+D,QAjUe7C,IACf,GAAIA,EAAM8C,cAAe,CACvB,MAAMvY,EAAO0J,GAAyB+L,EAAM8C,cAAc5O,OAEtD3J,GAAQyT,EAAexO,OAAOmP,EAAYpU,EAChD,GA6TAwY,QAnNe/C,IACfA,EAAMyC,iBACN,MAAM7P,KAAEA,EAAI1D,UAAEA,GAAcgN,EAAO1M,MAI7BwT,GAAQnM,OAAOoM,WAFP,KAE6B,EACrCtI,GAAO9D,OAAOqM,YAFL,KAE6B,EAEtCC,EAAUtM,OAAOuM,KACrB,GAAGlU,kBAA0BqE,mBAAmBX,KAChD,SACA,6BAAwCoQ,SAAYrI,4EAGtDwI,GAASE,YAAY,CAAErR,KAAM,QAASO,KAAM,MAAQ,KAGpD,MAAM+Q,EAAW,EAAG/Q,WACbA,GAAsB,aAAdA,EAAKP,MAEdO,EAAKA,KAAKM,QACZsQ,GAASI,QACTlM,EAAS7H,MAAQ+C,EAAKA,MACrBA,EAAKA,KAAKiR,SAAW3C,aAAeC,gBAAgBG,QACnD,cACA/N,KAAKC,UAAUZ,EAAKA,OAGtBsE,OAAOsL,oBAAoB,UAAWmB,GACxC,EAGFzM,OAAOqK,iBAAiB,UAAWoC,EAAS,EAmL5CG,SAhLe,KACfpM,EAAS7H,MAAQ,GACjBqR,aAAaI,QAAQ,cAAe,QACpCH,eAAeG,QAAQ,cAAe,OAAO,EA8K7CyC,UA3KiB1D,IACjBA,EAAMyC,iBAEN,MAAM7P,KAAEA,EAAI1D,UAAEA,GAAcgN,EAAO1M,MAI7BwT,GAAQnM,OAAOoM,WAFP,KAE6B,EACrCtI,GAAO9D,OAAOqM,YAFL,KAE6B,EAC5BrM,OAAOuM,KACrB,GAAGlU,oBAA4BqE,mBAAmBX,KAClD,SACA,6BAAwCoQ,SAAYrI,6EAG7C0I,YAAY,CAAErR,KAAM,QAASO,KAAM8E,EAAS7H,MAAOqD,OAAS,IAAI,EA6JzEiM,gBACAoB,oBACAM,cAEAzC,UACA1G,WACAwG,eAGAN,aACAnO,YACAwO,oBAGAxB,SACAC,WAGAW,QACAE,gBACAC,YAGAwG,QAASnG,EACTJ,UAGAY,iBAGAV,cACAD,cAGAb,YACAC,YACAE,iBACAC,gBACAC,eACAC,cACAJ,iBACAK,oBAEH,sjME1pBH,MAAM6G,GAAuC,CAAC,WAAY,UAAW,QAErE,IAAAC,GAAehL,GAAgB,CAC7BC,WAAY,CACVgL,cACAC,WJ9G2C,IAC7ClM,GACE,MACA,CAAEE,QAAS,gBAAiBnI,MAAO,KAAMkI,OAAQ,MACjDD,GAAE,OAAQ,CACRwD,EAAG,mSACHlD,KAAM,SIyGR6L,SJ/E8D,EAChEC,UAAS,KAITpM,GAAE,MAAO,CAAEE,QAAS,gBAAiBnI,MAAO,KAAMkI,OAAQ,MAAQ,CAChED,GAAE,OAAQ,CACRwD,EAAG,22BACD4I,EACI,GACA,kPAEN9L,KAAM8L,EAAS,MAAQ,mBIoEzBC,UJ1C0C,IAC5CrM,GACE,MACA,CAAEE,QAAS,gBAAiBnI,MAAO,KAAMkI,OAAQ,MACjDD,GAAE,OAAQ,CACRwD,EAAG,8TACHlD,KAAM,kBIqCRgM,aJjC6C,IAC/CtM,GACE,MACA,CACEuD,MAAO,gBACPrD,QAAS,gBACTnI,MAAO,KACPkI,OAAQ,MAEVD,GAAE,OAAQ,CACRwD,EAAG,ouBACHlD,KAAM,cIyBVY,MAAO,CACLxL,QAAS,CACPyE,KAAMlE,OACNsW,UAAU,GAEZvI,OAAQ,CACN7J,KAAM8J,OACNsI,UAAU,GAEZC,MAAO,CACLrS,KAAMlE,OACNkL,QAAS,OAIbI,MAAO,CAAC,SAAU,QAAS,OAAQ,SAAU,SAAU,UAEvDC,MAAMN,GACJ,MAAMmD,EAASC,GACb,UAEImI,EAAQ3N,KACRU,EAAWZ,KAEX5I,EAASiQ,IAAS,IAAM5B,EAAO1M,MAAM3B,SAErCkB,EAAO+O,IAAS,KACpB,MAAM/O,KAAEA,GAASgK,EAAMxL,QAEvB,OAAOwB,EAAQD,GAAWC,GAAQA,EAAO,WAAWA,IAAU,EAAE,IAG5DwV,EAAOzG,IAAS,IAAMwG,EAAM9U,MAAMnF,SAAS0O,EAAMxL,QAAQuF,YAEzD7C,ECvKgB,EACxBF,EACAlC,KAEA,MAAMmC,EAAMwU,KAEZ,OAAO1G,IAAS,IAAMhO,GAAWC,EAAMC,EAAIR,MAAO3B,IAAQ,EDiK3C4W,CAAW1L,EAAMxL,QAAQmX,WAAY7W,EAAO2B,OAEnDmV,EAAU7G,IAAS,IAA8B,kBAAxBzG,EAAS7H,MAAMwC,OAExC4S,EAAU9G,IACd,IACE/E,EAAMxL,QAAQsX,SACdxN,EAAS7H,MAAMsD,WAAaiG,EAAMxL,QAAQsX,UAGxCC,EAAoBhH,IACxB,IAAM/E,EAAMxL,QAAQuF,WAAaiG,EAAMsL,OAAOvR,WAGhD,MAAO,CACLoJ,SACArO,SAEAiX,oBACA/V,OACAwV,OACAtU,OAEA0U,UACAC,UAEAhB,iBAEH,qmBEAH,IAAAmB,GAAelM,GAAgB,CAC7B/G,KAAM,aAENgH,WAAY,CACVgL,cACAkB,2+GACArN,gBAGFoB,MAhHY,CACZ,YACA,OACA,OACA,eACA,OACA,OACA,SACA,WACA,YACA,QACA,QACA,cACA,cACA,gBACA,aAmGAM,MAAMN,GACJ,MAAMmD,EAAS4B,IAAS,IpBvKH,GACvB5O,YAEAT,OAAOqI,SAASC,SAChBnE,OZ5CyB,QY6CzB/E,SACAmP,QAAQ,CAAC,0CACT9S,OAAO,CAAC,OAAQ,OAAQ,QACxB8U,eAAe,GACfiG,QAAO,EACPC,WAAW,GACX9V,YACA6O,gBACAjJ,cACAC,cACAkQ,aAAY,EACZpG,QAAQ,SACR3S,SAAShB,OACNwB,MAC6B,CAChCsC,UAAWD,GAAaC,GACxBT,KAAMD,GAAWC,GACjBZ,OAAQ,IACFS,EAAesE,IAAStE,EZ/DL,YYgED,iBAAXT,EAAsBA,EAAS,CAAA,GAE5CuB,UAAWD,GAAaC,GACxBlF,KAAMD,EAAQC,GACd8U,aAAc/U,EAAQ+U,GACtBf,cAAe1O,GAAS0O,EAAe3T,GACvC0K,YAAazF,GAASyF,EAAa9H,GACnC+H,YAAa1F,GAAS0F,EAAa/J,GACnC0H,OACAqS,OACAjI,QACAkI,WACAnG,QACAoG,YACA/Y,YACGQ,IoBgI6BwY,CAAUrM,KAElC1B,EAAWZ,KACXC,EAAcC,KAEd0O,EAAS7L,GAAqC,WAE9CG,EAAQH,GAAI,GACZ8L,EAAO9L,GAAI,GACX+L,EAAa/L,GAAI,GAEjBjH,EAAOiH,GAAqB,IAC5B6K,EAAQ7K,GAA0B,MAElCgM,EAAgB1H,IAAS,KAAM2H,MnBjOf,iBADGzO,EmBkOyBkF,EAAO1M,MAAMyV,MnBhO3C,SAAbjO,EACH,yCAAyCvH,MACzC,GAAGuH,IAAWvH,MAGA,IAAbuH,EAAoB,QAAQvH,KAAU,GAPnB,IAACuH,CmBkO2C,IAKpE,IAAIS,ycAHJiO,CAAYF,GAKZ,MAAMG,EAAgBC,IACpB,MAAM1W,UAAEA,EAAST,KAAEA,EAAIyW,SAAEA,GAAahJ,EAAO1M,MACvCyH,EAAa,IAAIC,gBAEvBmO,EAAO7V,MAAQ,UAEfiI,Mf/I0B,GAC9BvI,YACA0D,OACAnE,OACA6W,OACAJ,WACA5R,SACAT,YAEA,MAAM/G,EAAkC,CAAA,EAIxC,OAFI+G,IAAO/G,EAAQkH,cAAgB,UAAUH,KAEtChH,MACL,GAAGqD,kBAA0BqE,mBAC3B9E,eACYyW,UAAiBI,UAAa1S,IAC5C,CAAEU,SAAQxH,YAETC,MAAMC,GAASA,EAAKC,SACpBF,MAAMwG,GAASD,GAAWC,EAAM,iBAAgB,Ee6H/CsT,CAAiB,CACf3W,YACA0D,KAAMsJ,EAAO1M,MAAMoD,KACnBnE,OACAyW,WACAI,KAAMM,EACNtS,OAAQ2D,EAAW3D,OACnBT,MAAOwE,EAAS7H,OAAOqD,QAEtB9G,MAAMC,IACLqZ,EAAO7V,MAAQ,UACfmK,EAAMnK,MAAQxD,EAAK2N,MACnBpH,EAAK/C,MAAM8K,QAAQtO,EAAKuG,MACxB+S,EAAK9V,MAAQoW,EACbL,EAAW/V,MAAQxD,EAAKuZ,UAAU,IAEnCrZ,OAAOyC,IACW,eAAbA,EAAImD,OACNI,QAAQC,MAAMxD,EAAIyD,SAClBiT,EAAO7V,MAAQ,QACjB,IAGJiI,EAAQR,EAAWQ,MAAMC,KAAKT,EAAW,EAKrC6O,EAAU,KACdnM,EAAMnK,MAAQ,EACd+C,EAAK/C,MAAQ,GACbmW,EAAa,EAAE,EA4HjB,oIANAI,CAAQ,SAAU7J,GAElBtB,IAAM,IAAO7B,EAAiCtK,MAAMqX,GAEpDjL,IAAU,IAAMiL,MAET,CACL5J,SACAsJ,gBACAQ,KAAMlI,IAAS,IAAM5B,EAAO1M,MAAM3B,SAElCwX,SACA1L,QACA2L,OACAC,aACAhT,OACA8R,QAEA4B,SA7Ie,IAAYN,EAAaL,EAAK9V,MAAQ,GA8IrDsW,UACAI,QAvIe3Y,IACf8W,EAAM7U,MAAQjC,CAAO,EAuIrB4Y,SApIgB5Y,IAChB,GAAIA,EAAQqS,IAAK,CACf,MAAMwG,EAAiB7T,EAAK/C,MAAM6E,MAChC,EAAGvB,cAAeA,IAAavF,EAAQqS,MAGzC,IAAKwG,EAAgB,OAEhB/W,MAAMC,QAAQ8W,EAAelM,YAChCkM,EAAelM,SAAW,IAE5BkM,EAAelM,SAASI,KAAK/M,EAC/B,MAAOgF,EAAK/C,MAAM6W,QAAQ9Y,EAAQ,EAyHlC+Y,eAtHqBxM,OACrBvM,UACA8X,aAKA,GAAI9X,EAAQ8X,SAAWA,EAAQ,OAE/B,MAAMnW,UAAEA,EAAS0D,KAAEA,GAASsJ,EAAO1M,YAE7BmD,GAAc,CAClBzD,YACA0D,OACAC,MAAOwE,EAAS7H,OAAOqD,MACvBC,SAAUvF,EAAQuF,SAClBuS,WAGF9X,EAAQ8X,OAASA,CAAM,EAoGvBkB,SAjFezM,OAAShH,eACxB,IAAK0T,QAAQ,iDAAkD,OAE/D,MAAMtX,UAAEA,EAAS0D,KAAEA,GAASsJ,EAAO1M,WfjLZ,GAC3BN,YACA0D,OACAC,QACAC,cAMOjH,MAAM,GAAGqD,aAAqB4D,UAAiBF,IAAQ,CAC5DG,OAAQ,SACRjH,QANsC,CACtCkH,cAAe,UAAUH,OAMxB9G,MAAMC,GAASA,EAAKC,SesKbwa,CAAc,CAClBvX,YACA0D,OACAC,MAAOwE,EAAS7H,OAAOqD,MACvBC,SAAUA,IAIZP,EAAK/C,MAAMkX,MAAK,CAACtc,EAAMgD,IACjBhD,EAAK0I,WAAaA,GACpBP,EAAK/C,MAAQ+C,EAAK/C,MAAMrF,QAAO,CAACwc,EAAOC,IAAMA,IAAMxZ,KAE5C,GAGFhD,EAAK8P,SAASwM,MAAK,CAACG,EAAOC,IAC5BD,EAAM/T,WAAaA,IACrBP,EAAK/C,MAAMpC,GAAO8M,SAAW9P,EAAK8P,SAAS/P,QACzC,CAACwc,EAAOC,IAAMA,IAAME,KAGf,MAKX,EAmDFC,SAlGejN,MAAOvM,IACtB,GAAIA,EAAQqS,IAAK,OAEjB,MAAM1Q,UAAEA,EAAS0D,KAAEA,GAASsJ,EAAO1M,YAE7BmD,GAAc,CAClBzD,YACA0D,OACAC,MAAOwE,EAAS7H,OAAOqD,MACvBC,SAAUvF,EAAQuF,SAClBkU,OAAQzZ,EAAQyZ,OAAS,EAAI,IAG/BzZ,EAAQyZ,QAAUzZ,EAAQyZ,MAAM,EAsFhCC,OAjDanN,MAAOvM,IACpB,MAAM2B,UAAEA,EAAS0D,KAAEA,GAASsJ,EAAO1M,OAC7BsD,SAAEA,GAAavF,EACf2Z,EAAWxQ,EAAYlH,MAAMnF,SAASyI,Qf5LvB,GACzB5D,YACA0D,OACAE,WACAyR,UAEA1Y,MAAM,GAAGqD,aAAqB4D,UAAiBF,IAAQ,CACrDG,OAAQ,MACRjH,QAASuG,GACTY,KAAMC,KAAKC,UAAU,CAAEoR,WACtBxY,MAAMC,GAASA,EAAKC,SeoLbkb,CAAY,CAChBjY,YACA0D,OACAE,WACAyR,MAAO2C,IAGLA,EACFxQ,EAAYlH,MAAQkH,EAAYlH,MAAMrF,QAAQid,GAAOA,IAAOtU,KAE5D4D,EAAYlH,MAAQ,IAAIkH,EAAYlH,MAAOsD,GAEvC4D,EAAYlH,MAAM9B,OAAS,KAC7BgJ,EAAYlH,MAAQkH,EAAYlH,MAAM6X,OAAO,MAGjD9Z,EAAQgX,MAAQhX,EAAQgX,MAAQ,IAAM2C,GAAY,EAAI,EAAE,EA8BxDI,QAAS,QAEZ,wzDC9WH,MAAMC,GAAqB,CACzB9T,EACA+T,KAEAA,EAAcjQ,SAAQ,CAAClB,EAASjJ,KAC9BiJ,EAAQmB,UAAY/D,EAAOrG,GAAOpC,UAAU,GAC5C,EAGSyc,GAAgB,EAC3BvY,YACAT,OAAOoI,OAAOC,SAASC,SACvBC,WAAW,yBACX0Q,UAAS,EACT9U,OAAO,YAEP,MAAMqE,EAAa,IAAIC,gBAEjBC,EAAW9H,MAAM+E,KAErBN,SAASsD,iBAA8BJ,IAGnC7M,EAAUkM,IACd,MAAM3K,EAAQ0K,GAASC,GAEvB,OAAiB,OAAV3K,GAAkB+C,IAAS/C,CAAK,EAGnCG,EAASsL,GACb/D,GAAe,CACblE,UAAWD,GAAaC,GACxBmE,MAAO8D,EAAS7K,KAAK+J,GAAYD,GAASC,IAAY5H,IACtDmE,OACAU,OAAQ2D,EAAW3D,SAElBvH,MAAM0H,GAAW8T,GAAmB9T,EAAQ0D,KAC5CjL,MAAM+F,IAGX,GAAIyV,EAAQ,CACV,MAAMC,EAAiBxQ,EAAShN,QAAQkM,IAAalM,EAAOkM,KACtDuR,EAA2BzQ,EAAShN,OAAOA,GAE5CuJ,GAAgB,CACnBxE,UAAWD,GAAaC,GACxBT,OACAmE,SACC7G,MAAM4N,GACP4N,GACE,IAAIlY,MAAcsY,EAAeja,QAAQyK,KAAKwB,GAC9CgO,KAKAC,EAAyBla,QACtB7B,EAAM+b,EAEd,MAGM/b,EAAMsL,GAGb,OAAOF,EAAWQ,MAAMC,KAAKT,EAAW,EChF7B4Q,GAAO,EAClBjU,KAAK,UACLnF,OAAOoI,OAAOC,SAASC,SACvBxJ,WAAU,EACVua,YAAW,KACRC,MAGH,MAAMC,EAAOpU,EAAKD,GAAQC,GAAM,KAGhC,GAAIA,IAAOoU,EAAM,MAAM,IAAIC,MAAM,4CAGjC,IAAKF,EAAU7Y,UAAW,MAAM,IAAI+Y,MAAM,kCAE1C,MAAMlP,EAAQ0E,GAAS,IAAKsK,IACtB1c,EAAQoS,GAAS,CAAElQ,UAASua,WAAUrZ,SAqBtCyZ,EAAMF,EACRG,IAAU,IAAMtQ,GAAEuQ,GAAQ,CAAE3Z,KAAMpD,EAAMoD,QAASsK,MACjD,KAEAmP,GAAKA,EAAIG,MAAML,GAEnB,MAAMM,EAAcC,IAzBO,KACrBld,EAAMkC,SACRqJ,GAAa,CACX1H,UAAW6J,EAAM7J,UACjBT,KAAMpD,EAAMoD,KACZuI,SAAmC,iBAAlB3L,EAAMkC,QAAuBlC,EAAMkC,aAAU8H,GAC9D,IAoBAmT,EAAeD,IAjBO,KACtBld,EAAMyc,UACRL,GAAc,CACZvY,UAAW6J,EAAM7J,UACjBT,KAAMpD,EAAMoD,KACZuI,SAC4B,iBAAnB3L,EAAMyc,SAAwBzc,EAAMyc,cAAWzS,GACxD,IAYN,MAAO,CACLzB,GAAIoU,EACJN,OAAQ,EACNna,UACAua,WACArZ,OAAOoI,OAAOC,SAASC,YACpB0R,GACuC,CAAA,KAC1C3a,OAAO4a,QAAQD,GAAUlR,SAAQ,EAAEzC,EAAKtF,MAItCuJ,EAAMjE,GAAOtF,CAAK,IAGpBnE,EAAMoD,KAAOA,OACG4G,IAAZ9H,IAAuBlC,EAAMkC,QAAUA,QAC1B8H,IAAbyS,IAAwBzc,EAAMyc,SAAWA,EAAQ,EAEvDnG,QAAS,KACPuG,GAAKS,UACLL,IACAE,GAAc,EAEjB,EC7GUlB,GAAU,QCmDVsB,GAAiB,EAC5BhV,KACA1E,YACAyK,QACA/G,OAAO,YAEP,MAAMyE,EAAWZ,KACXuR,EAAOrU,GAAQC,GACfqD,EAAa,IAAIC,gBAEvB,MnBAgC,GAChChI,YACA0D,OACA+G,QACArG,SACAT,YAEA,MAAM/G,EAAkC,CAAA,EAIxC,OAFI+G,IAAO/G,EAAQkH,cAAgB,UAAUH,KAEtChH,MAAM,GAAGqD,+BAAuCyK,UAAc/G,IAAQ,CAC3EU,SACAxH,YAECC,MAAMC,GAASA,EAAKC,SACpBF,MAAMwG,GAASD,GAAWC,EAAM,mBAAkB,EmBhB9CsW,CAAmB,CACxB3Z,YACAyK,QACA/G,OACAU,OAAQ2D,EAAW3D,OACnBT,MAAOwE,EAAS7H,OAAOqD,QACtB9G,MAAM+c,GACHd,GAAQc,EAASpb,QACnBsa,EAAKe,UAAY,8BAA8BD,EAC5Cxc,KACEiB,GACC,uCAAuCA,EAAQZ,QAAQY,EAAQ+O,YAAY/O,EAAQA,iBAEtFiG,KAAK,WAED,CACLsV,WACAnH,QAAS,KACP1K,EAAWQ,QACXuQ,EAAKe,UAAY,EAAE,IAKlB,CACLD,WACAnH,QAAS,IAAY1K,EAAWQ,UAElC"}
|