@waline/client 2.6.0 → 2.6.1
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.js +1 -1
- package/dist/legacy.js +1 -1
- package/dist/legacy.js.map +1 -1
- package/dist/pageview.cjs.js +1 -1
- package/dist/pageview.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.esm.js +1 -1
- package/dist/shim.esm.js.map +1 -1
- package/dist/shim.js +1 -1
- package/dist/shim.js.map +1 -1
- package/dist/waline.cjs.js +1 -1
- package/dist/waline.cjs.js.map +1 -1
- package/dist/waline.esm.js +1 -1
- package/dist/waline.esm.js.map +1 -1
- package/dist/waline.js +1 -1
- package/dist/waline.js.map +1 -1
- package/package.json +5 -5
- package/src/pageview.ts +5 -1
package/dist/pageview.esm.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"pageview.esm.js","sources":["../src/version.ts","../src/utils/config.ts","../src/utils/path.ts","../src/utils/error.ts","../src/utils/fetch.ts","../src/utils/query.ts","../src/pageview.ts"],"sourcesContent":["declare const VERSION: string;\n\nexport const version = VERSION;\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","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","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 getQuery = (element: HTMLElement): string | null =>\n element.dataset.path || element.getAttribute('id');\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({ 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"],"names":["version","getServerURL","serverURL","result","content","replace","removeEndingSplash","test","errorHandler","err","name","console","error","message","JSON_HEADERS","errorCheck","data","errno","TypeError","errmsg","fetchPageviews","lang","paths","signal","fetch","encodeURIComponent","join","then","resp","json","counts","Array","isArray","updatePageviews","path","method","headers","body","JSON","stringify","getQuery","element","dataset","getAttribute","renderVisitorCount","countElements","forEach","index","innerText","toString","pageviewCount","window","location","pathname","selector","update","controller","AbortController","elements","from","document","querySelectorAll","filter","query","map","catch","normalElements","elementsNeedstoBeFetched","count","length","fill","abort","bind"],"mappings":"AAEO,MAAMA,EAAU,QC4BVC,EAAgBC,IAC3B,MAAMC,ECrB0B,EAACC,EAAU,KAC3CA,EAAQC,QAAQ,OAAQ,IDoBTC,CAAmBJ,GAElC,MCnBA,kBAAkBK,KDmBAJ,GAAUA,EAAS,WAAWA,KEjCrCK,EAAgBC,IACV,eAAbA,EAAIC,MAAuBC,QAAQC,MAAMH,EAAII,UCM7CC,EAAuC,CAE3C,eAAgB,oBAGZC,EAAa,CAAcC,EAA0BN,EAAO,MAChE,GAAoB,iBAATM,GAAsBA,EAAwBC,MACvD,MAAM,IAAIC,UACR,SAASR,iBAAqBM,EAAwBC,UACnDD,EAAwBG,UAI/B,OAAOH,GAgNII,EAAiB,EAC5BlB,YACAmB,OACAC,QACAC,YAEAC,MACE,GAAGtB,kBAA0BuB,mBAC3BH,EAAMI,KAAK,cACHL,IACV,CAAEE,WAEDI,MAAMC,GAASA,EAAKC,SACpBF,MAAMX,GAASD,EAAWC,EAAM,iBAEhCW,MAAMG,GAAYC,MAAMC,QAAQF,GAAUA,EAAS,CAACA,KAQ5CG,EAAkB,EAC7B/B,YACAmB,OACAa,UAEAV,MAAM,GAAGtB,kBAA0BmB,IAAQ,CACzCc,OAAQ,OACRC,QAAStB,EACTuB,KAAMC,KAAKC,UAAU,CAAEL,WAEtBP,MAAMC,GAASA,EAAKC,SACpBF,MAAMX,GAASD,EAAWC,EAAM,iBCtQxBwB,EAAYC,GACvBA,EAAQC,QAAQR,MAAQO,EAAQE,aAAa,MCsDzCC,EAAqB,CACzBd,EACAe,KAEAA,EAAcC,SAAQ,CAACL,EAASM,KAC9BN,EAAQO,UAAYlB,EAAOiB,GAAOE,eAIzBC,EAAgB,EAC3BhD,YACAgC,OAAOiB,OAAOC,SAASC,SACvBC,WAAW,yBACXC,UAAS,EACTlC,OAAO,YAEP,MAAMmC,EAAa,IAAIC,gBAEjBC,EAAW3B,MAAM4B,KAErBC,SAASC,iBAA8BP,IAGnCQ,EAAUrB,IACd,MAAMsB,EAAQvB,EAASC,GAEvB,OAAiB,OAAVsB,GAAkB7B,IAAS6B,GAG9BvC,EAASkC,GACbtC,EAAe,CACblB,UAAWD,EAAaC,GACxBoB,MAAOoC,EAASM,KAAKvB,GAAYD,EAASC,IAAYP,IACtDb,OACAE,OAAQiC,EAAWjC,SAElBI,MAAMG,GAAWc,EAAmBd,EAAQ4B,KAC5CO,MAAMzD,GAGX,GAAI+C,EAAQ,CACV,MAAMW,EAAiBR,EAASI,QAAQrB,IAAaqB,EAAOrB,KACtD0B,EAA2BT,EAASI,OAAOA,GAE5C7B,EAAgB,CAAE/B,YAAWgC,OAAMb,SAAQM,MAAMyC,GACpDxB,EACE,IAAIb,MAAcmC,EAAeG,QAAQC,KAAKF,GAC9CF,KAKAC,EAAyBE,QACtB7C,EAAM2C,QAKR3C,EAAMkC,GAGb,OAAOF,EAAWe,MAAMC,KAAKhB"}
|
|
1
|
+
{"version":3,"file":"pageview.esm.js","sources":["../src/version.ts","../src/utils/config.ts","../src/utils/path.ts","../src/utils/error.ts","../src/utils/fetch.ts","../src/utils/query.ts","../src/pageview.ts"],"sourcesContent":["declare const VERSION: string;\n\nexport const version = VERSION;\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","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","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 getQuery = (element: HTMLElement): string | null =>\n element.dataset.path || element.getAttribute('id');\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"],"names":["version","getServerURL","serverURL","result","content","replace","removeEndingSplash","test","errorHandler","err","name","console","error","message","JSON_HEADERS","errorCheck","data","errno","TypeError","errmsg","fetchPageviews","lang","paths","signal","fetch","encodeURIComponent","join","then","resp","json","counts","Array","isArray","updatePageviews","path","method","headers","body","JSON","stringify","getQuery","element","dataset","getAttribute","renderVisitorCount","countElements","forEach","index","innerText","toString","pageviewCount","window","location","pathname","selector","update","controller","AbortController","elements","from","document","querySelectorAll","filter","query","map","catch","normalElements","elementsNeedstoBeFetched","count","length","fill","abort","bind"],"mappings":"AAEO,MAAMA,EAAU,QC4BVC,EAAgBC,IAC3B,MAAMC,ECrB0B,EAACC,EAAU,KAC3CA,EAAQC,QAAQ,OAAQ,IDoBTC,CAAmBJ,GAElC,MCnBA,kBAAkBK,KDmBAJ,GAAUA,EAAS,WAAWA,KEjCrCK,EAAgBC,IACV,eAAbA,EAAIC,MAAuBC,QAAQC,MAAMH,EAAII,UCM7CC,EAAuC,CAE3C,eAAgB,oBAGZC,EAAa,CAAcC,EAA0BN,EAAO,MAChE,GAAoB,iBAATM,GAAsBA,EAAwBC,MACvD,MAAM,IAAIC,UACR,SAASR,iBAAqBM,EAAwBC,UACnDD,EAAwBG,UAI/B,OAAOH,GAgNII,EAAiB,EAC5BlB,YACAmB,OACAC,QACAC,YAEAC,MACE,GAAGtB,kBAA0BuB,mBAC3BH,EAAMI,KAAK,cACHL,IACV,CAAEE,WAEDI,MAAMC,GAASA,EAAKC,SACpBF,MAAMX,GAASD,EAAWC,EAAM,iBAEhCW,MAAMG,GAAYC,MAAMC,QAAQF,GAAUA,EAAS,CAACA,KAQ5CG,EAAkB,EAC7B/B,YACAmB,OACAa,UAEAV,MAAM,GAAGtB,kBAA0BmB,IAAQ,CACzCc,OAAQ,OACRC,QAAStB,EACTuB,KAAMC,KAAKC,UAAU,CAAEL,WAEtBP,MAAMC,GAASA,EAAKC,SACpBF,MAAMX,GAASD,EAAWC,EAAM,iBCtQxBwB,EAAYC,GACvBA,EAAQC,QAAQR,MAAQO,EAAQE,aAAa,MCsDzCC,EAAqB,CACzBd,EACAe,KAEAA,EAAcC,SAAQ,CAACL,EAASM,KAC9BN,EAAQO,UAAYlB,EAAOiB,GAAOE,eAIzBC,EAAgB,EAC3BhD,YACAgC,OAAOiB,OAAOC,SAASC,SACvBC,WAAW,yBACXC,UAAS,EACTlC,OAAO,YAEP,MAAMmC,EAAa,IAAIC,gBAEjBC,EAAW3B,MAAM4B,KAErBC,SAASC,iBAA8BP,IAGnCQ,EAAUrB,IACd,MAAMsB,EAAQvB,EAASC,GAEvB,OAAiB,OAAVsB,GAAkB7B,IAAS6B,GAG9BvC,EAASkC,GACbtC,EAAe,CACblB,UAAWD,EAAaC,GACxBoB,MAAOoC,EAASM,KAAKvB,GAAYD,EAASC,IAAYP,IACtDb,OACAE,OAAQiC,EAAWjC,SAElBI,MAAMG,GAAWc,EAAmBd,EAAQ4B,KAC5CO,MAAMzD,GAGX,GAAI+C,EAAQ,CACV,MAAMW,EAAiBR,EAASI,QAAQrB,IAAaqB,EAAOrB,KACtD0B,EAA2BT,EAASI,OAAOA,GAE5C7B,EAAgB,CACnB/B,UAAWD,EAAaC,GACxBgC,OACAb,SACCM,MAAMyC,GACPxB,EACE,IAAIb,MAAcmC,EAAeG,QAAQC,KAAKF,GAC9CF,KAKAC,EAAyBE,QACtB7C,EAAM2C,QAKR3C,EAAMkC,GAGb,OAAOF,EAAWe,MAAMC,KAAKhB"}
|
package/dist/pageview.js
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
!function(e,t){if("function"==typeof define&&define.amd)define("Waline",["exports"],t);else if("undefined"!=typeof exports)t(exports);else{var n={exports:{}};t(n.exports),e.Waline=n.exports}}("undefined"!=typeof globalThis?globalThis:"undefined"!=typeof self?self:this,(function(e){Object.defineProperty(e,"__esModule",{value:!0}),e.version=e.pageviewCount=void 0;e.version="2.6.
|
|
1
|
+
!function(e,t){if("function"==typeof define&&define.amd)define("Waline",["exports"],t);else if("undefined"!=typeof exports)t(exports);else{var n={exports:{}};t(n.exports),e.Waline=n.exports}}("undefined"!=typeof globalThis?globalThis:"undefined"!=typeof self?self:this,(function(e){Object.defineProperty(e,"__esModule",{value:!0}),e.version=e.pageviewCount=void 0;e.version="2.6.1";const t=e=>{const t=function(){return(arguments.length>0&&void 0!==arguments[0]?arguments[0]:"").replace(/\/$/u,"")}(e);return/^(https?:)?\/\//.test(t)?t:"https://".concat(t)},n=e=>{"AbortError"!==e.name&&console.error(e.message)},r={"Content-Type":"application/json"},o=function(e){let t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:"";if("object"==typeof e&&e.errno)throw new TypeError("Fetch ".concat(t," failed with ").concat(e.errno,": ").concat(e.errmsg));return e},a=e=>{let{serverURL:t,lang:n,paths:r,signal:a}=e;return fetch("".concat(t,"/article?path=").concat(encodeURIComponent(r.join(",")),"&lang=").concat(n),{signal:a}).then((e=>e.json())).then((e=>o(e,"visit count"))).then((e=>Array.isArray(e)?e:[e]))},i=e=>{let{serverURL:t,lang:n,path:a}=e;return fetch("".concat(t,"/article?lang=").concat(n),{method:"POST",headers:r,body:JSON.stringify({path:a})}).then((e=>e.json())).then((e=>o(e,"visit count")))},l=e=>e.dataset.path||e.getAttribute("id"),s=(e,t)=>{t.forEach(((t,n)=>{t.innerText=e[n].toString()}))};e.pageviewCount=e=>{let{serverURL:r,path:o=window.location.pathname,selector:c=".waline-pageview-count",update:h=!0,lang:p="zh-CN"}=e;const f=new AbortController,u=Array.from(document.querySelectorAll(c)),d=e=>{const t=l(e);return null!==t&&o!==t},g=e=>a({serverURL:t(r),paths:e.map((e=>l(e)||o)),lang:p,signal:f.signal}).then((t=>s(t,e))).catch(n);if(h){const e=u.filter((e=>!d(e))),n=u.filter(d);i({serverURL:t(r),path:o,lang:p}).then((t=>s(new Array(e.length).fill(t),e))),n.length&&g(n)}else g(u);return f.abort.bind(f)}}));
|
|
2
2
|
//# sourceMappingURL=pageview.js.map
|
package/dist/pageview.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"pageview.js","sources":["../src/version.ts","../src/utils/path.ts","../src/utils/config.ts","../src/utils/error.ts","../src/utils/fetch.ts","../src/utils/query.ts","../src/pageview.ts"],"sourcesContent":["declare const VERSION: string;\n\nexport const version = VERSION;\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","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 getQuery = (element: HTMLElement): string | null =>\n element.dataset.path || element.getAttribute('id');\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({ 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"],"names":["getServerURL","serverURL","result","replace","removeEndingSplash","test","concat","errorHandler","err","name","console","error","message","JSON_HEADERS","errorCheck","data","errno","TypeError","errmsg","fetchPageviews","_ref","lang","paths","signal","fetch","encodeURIComponent","join","then","resp","json","counts","Array","isArray","updatePageviews","_ref2","path","method","headers","body","JSON","stringify","getQuery","element","dataset","getAttribute","renderVisitorCount","countElements","forEach","index","innerText","toString","_ref3","window","location","pathname","selector","update","controller","AbortController","elements","from","document","querySelectorAll","filter","query","map","catch","normalElements","elementsNeedstoBeFetched","count","length","fill","abort","bind"],"mappings":"sXAEuB,QCQhB,MCoBMA,EAAgBC,IAC3B,MAAMC,EDrB0B,WAAA,8DAAW,IACnCC,QAAQ,OAAQ,ICoBTC,CAAmBH,GAElC,MDnBA,kBAAkBI,KCmBAH,GAAUA,EAArB,WAAAI,OAAyCJ,ICjCrCK,EAAgBC,IACV,eAAbA,EAAIC,MAAuBC,QAAQC,MAAMH,EAAII,UCM7CC,EAAuC,CAE3C,eAAgB,oBAGZC,EAAa,SAAcC,GAA0C,IAAhBN,yDAAO,GAChE,GAAoB,iBAATM,GAAsBA,EAAwBC,MACvD,MAAM,IAAIC,UACCR,SAAAA,OAAAA,0BAAqBM,EAAwBC,MACnDD,MAAAA,OAAAA,EAAwBG,SAI/B,OAAOH,GAgNII,EAAiBC,IAAA,IAACnB,UAC7BA,EAD6BoB,KAE7BA,EAF6BC,MAG7BA,EAH6BC,OAI7BA,GAJ4BH,EAAA,OAM5BI,MAAK,GAAAlB,OACAL,EADA,kBAAAK,OAC0BmB,mBAC3BH,EAAMI,KAAK,MAFV,UAAApB,OAGOe,GACV,CAAEE,WAEDI,MAAMC,GAASA,EAAKC,SACpBF,MAAMZ,GAASD,EAAWC,EAAM,iBAEhCY,MAAMG,GAAYC,MAAMC,QAAQF,GAAUA,EAAS,CAACA,MAQ5CG,EAAkBC,IAAA,IAACjC,UAC9BA,EAD8BoB,KAE9BA,EAF8Bc,KAG9BA,GAH6BD,EAAA,OAK7BV,MAAK,GAAAlB,OAAIL,EAAJ,kBAAAK,OAA8Be,GAAQ,CACzCe,OAAQ,OACRC,QAASxB,EACTyB,KAAMC,KAAKC,UAAU,CAAEL,WAEtBR,MAAMC,GAASA,EAAKC,SACpBF,MAAMZ,GAASD,EAAWC,EAAM,kBCtQxB0B,EAAYC,GACvBA,EAAQC,QAAQR,MAAQO,EAAQE,aAAa,MCsDzCC,EAAqB,CACzBf,EACAgB,KAEAA,EAAcC,SAAQ,CAACL,EAASM,KAC9BN,EAAQO,UAAYnB,EAAOkB,GAAOE,+BAITC,IAMiB,IANhBlD,UAC5BA,EAD4BkC,KAE5BA,EAAOiB,OAAOC,SAASC,SAFKC,SAG5BA,EAAW,yBAHiBC,OAI5BA,GAAS,EAJmBnC,KAK5BA,EAAO,SACqC8B,EAC5C,MAAMM,EAAa,IAAIC,gBAEjBC,EAAW5B,MAAM6B,KAErBC,SAASC,iBAA8BP,IAGnCQ,EAAUrB,IACd,MAAMsB,EAAQvB,EAASC,GAEvB,OAAiB,OAAVsB,GAAkB7B,IAAS6B,GAG9BxC,EAASmC,GACbxC,EAAe,CACblB,UAAWD,EAAaC,GACxBqB,MAAOqC,EAASM,KAAKvB,GAAYD,EAASC,IAAYP,IACtDd,OACAE,OAAQkC,EAAWlC,SAElBI,MAAMG,GAAWe,EAAmBf,EAAQ6B,KAC5CO,MAAM3D,GAGX,GAAIiD,EAAQ,CACV,MAAMW,EAAiBR,EAASI,QAAQrB,IAAaqB,EAAOrB,KACtD0B,EAA2BT,EAASI,OAAOA,GAE5C9B,EAAgB,CAAEhC,YAAWkC,OAAMd,SAAQM,MAAM0C,GACpDxB,EACE,IAAId,MAAcoC,EAAeG,QAAQC,KAAKF,GAC9CF,KAKAC,EAAyBE,QACtB9C,EAAM4C,QAKR5C,EAAMmC,GAGb,OAAOF,EAAWe,MAAMC,KAAKhB"}
|
|
1
|
+
{"version":3,"file":"pageview.js","sources":["../src/version.ts","../src/utils/path.ts","../src/utils/config.ts","../src/utils/error.ts","../src/utils/fetch.ts","../src/utils/query.ts","../src/pageview.ts"],"sourcesContent":["declare const VERSION: string;\n\nexport const version = VERSION;\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","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 getQuery = (element: HTMLElement): string | null =>\n element.dataset.path || element.getAttribute('id');\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"],"names":["getServerURL","serverURL","result","replace","removeEndingSplash","test","concat","errorHandler","err","name","console","error","message","JSON_HEADERS","errorCheck","data","errno","TypeError","errmsg","fetchPageviews","_ref","lang","paths","signal","fetch","encodeURIComponent","join","then","resp","json","counts","Array","isArray","updatePageviews","_ref2","path","method","headers","body","JSON","stringify","getQuery","element","dataset","getAttribute","renderVisitorCount","countElements","forEach","index","innerText","toString","_ref3","window","location","pathname","selector","update","controller","AbortController","elements","from","document","querySelectorAll","filter","query","map","catch","normalElements","elementsNeedstoBeFetched","count","length","fill","abort","bind"],"mappings":"sXAEuB,QCQhB,MCoBMA,EAAgBC,IAC3B,MAAMC,EDrB0B,WAAA,8DAAW,IACnCC,QAAQ,OAAQ,ICoBTC,CAAmBH,GAElC,MDnBA,kBAAkBI,KCmBAH,GAAUA,EAArB,WAAAI,OAAyCJ,ICjCrCK,EAAgBC,IACV,eAAbA,EAAIC,MAAuBC,QAAQC,MAAMH,EAAII,UCM7CC,EAAuC,CAE3C,eAAgB,oBAGZC,EAAa,SAAcC,GAA0C,IAAhBN,yDAAO,GAChE,GAAoB,iBAATM,GAAsBA,EAAwBC,MACvD,MAAM,IAAIC,UACCR,SAAAA,OAAAA,0BAAqBM,EAAwBC,MACnDD,MAAAA,OAAAA,EAAwBG,SAI/B,OAAOH,GAgNII,EAAiBC,IAAA,IAACnB,UAC7BA,EAD6BoB,KAE7BA,EAF6BC,MAG7BA,EAH6BC,OAI7BA,GAJ4BH,EAAA,OAM5BI,MAAK,GAAAlB,OACAL,EADA,kBAAAK,OAC0BmB,mBAC3BH,EAAMI,KAAK,MAFV,UAAApB,OAGOe,GACV,CAAEE,WAEDI,MAAMC,GAASA,EAAKC,SACpBF,MAAMZ,GAASD,EAAWC,EAAM,iBAEhCY,MAAMG,GAAYC,MAAMC,QAAQF,GAAUA,EAAS,CAACA,MAQ5CG,EAAkBC,IAAA,IAACjC,UAC9BA,EAD8BoB,KAE9BA,EAF8Bc,KAG9BA,GAH6BD,EAAA,OAK7BV,MAAK,GAAAlB,OAAIL,EAAJ,kBAAAK,OAA8Be,GAAQ,CACzCe,OAAQ,OACRC,QAASxB,EACTyB,KAAMC,KAAKC,UAAU,CAAEL,WAEtBR,MAAMC,GAASA,EAAKC,SACpBF,MAAMZ,GAASD,EAAWC,EAAM,kBCtQxB0B,EAAYC,GACvBA,EAAQC,QAAQR,MAAQO,EAAQE,aAAa,MCsDzCC,EAAqB,CACzBf,EACAgB,KAEAA,EAAcC,SAAQ,CAACL,EAASM,KAC9BN,EAAQO,UAAYnB,EAAOkB,GAAOE,+BAITC,IAMiB,IANhBlD,UAC5BA,EAD4BkC,KAE5BA,EAAOiB,OAAOC,SAASC,SAFKC,SAG5BA,EAAW,yBAHiBC,OAI5BA,GAAS,EAJmBnC,KAK5BA,EAAO,SACqC8B,EAC5C,MAAMM,EAAa,IAAIC,gBAEjBC,EAAW5B,MAAM6B,KAErBC,SAASC,iBAA8BP,IAGnCQ,EAAUrB,IACd,MAAMsB,EAAQvB,EAASC,GAEvB,OAAiB,OAAVsB,GAAkB7B,IAAS6B,GAG9BxC,EAASmC,GACbxC,EAAe,CACblB,UAAWD,EAAaC,GACxBqB,MAAOqC,EAASM,KAAKvB,GAAYD,EAASC,IAAYP,IACtDd,OACAE,OAAQkC,EAAWlC,SAElBI,MAAMG,GAAWe,EAAmBf,EAAQ6B,KAC5CO,MAAM3D,GAGX,GAAIiD,EAAQ,CACV,MAAMW,EAAiBR,EAASI,QAAQrB,IAAaqB,EAAOrB,KACtD0B,EAA2BT,EAASI,OAAOA,GAE5C9B,EAAgB,CACnBhC,UAAWD,EAAaC,GACxBkC,OACAd,SACCM,MAAM0C,GACPxB,EACE,IAAId,MAAcoC,EAAeG,QAAQC,KAAKF,GAC9CF,KAKAC,EAAyBE,QACtB9C,EAAM4C,QAKR5C,EAAMmC,GAGb,OAAOF,EAAWe,MAAMC,KAAKhB"}
|
package/dist/shim.esm.js
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import{getCurrentScope as e,onScopeDispose as t,watch as n,ref as l,unref as o,isRef as a,readonly as r,shallowRef as i,computed as s,h as c,defineComponent as u,onMounted as m,onBeforeUnmount as d,resolveComponent as p,openBlock as v,createElementBlock as g,normalizeStyle as h,Fragment as f,renderList as w,createBlock as y,createCommentVNode as b,createElementVNode as k,nextTick as C,inject as $,reactive as I,onUnmounted as L,createVNode as S,toDisplayString as j,normalizeClass as x,withDirectives as R,vModelDynamic as E,vModelText as A,vShow as U,createTextVNode as z,provide as M,createApp as O,watchEffect as T}from"vue";import P from"autosize";import{marked as N}from"marked";const H=["nick","mail","link"],V=e=>e.filter((e=>H.includes(e))),_=e=>new Promise(((t,n)=>{const l=new FileReader;l.readAsDataURL(e),l.onload=()=>t(l.result?.toString()||""),l.onerror=n})),F=e=>!0===e?'<p class="wl-tex">Tex is not available in preview</p>':'<span class="wl-tex">Tex is not available in preview</span>',B=()=>{const e={next:""},t=({keyword:e,pos:t})=>{const n=new URLSearchParams("media_filter=minimal");return n.set("key","PAY5JLFIH6V6"),n.set("limit","20"),n.set("pos",t||""),n.set("q",e),fetch(`https://g.tenor.com/v1/search?${n.toString()}`,{headers:{"Content-Type":"application/json"}}).then((e=>e.json())).catch((()=>({next:t||"",results:[]})))};return{search:(n="")=>t({keyword:n}).then((t=>(e.next=t.next,t.results.map((e=>({title:e.title,src:e.media[0].tinygif.url})))))),more:n=>t({keyword:n,pos:e.next}).then((t=>(e.next=t.next,t.results.map((e=>({title:e.title,src:e.media[0].tinygif.url}))))))}},D=new RegExp(`(${/[\u4E00-\u9FFF\u3400-\u4dbf\uf900-\ufaff\u3040-\u309f\uac00-\ud7af\u0400-\u04FF]+|\w+/.source}|${/</.source})|((?:${/(?:^|\s)\/\/(.+?)$/gm.source})|(?:${/\/\*([\S\s]*?)\*\//gm.source}))`,"gmi"),W=["23AC69","91C132","F19726","E8552D","1AAB8E","E1147F","2980C1","1BA1E6","9FA0A0","F19726","E30B20","E30B20","A3338B"],G={},q=e=>{let t=0;return e.replace(D,((e,n,l)=>{if(l)return`<span style="color: slategray">${l}</span>`;if("<"===n)return"<";let o;G[n]?o=G[n]:(o=W[t],G[n]=o);const a=`<span style="color: #${o}">${n}</span>`;return t=++t%W.length,a}))},J=["nick","nickError","mail","mailError","link","optional","placeholder","sofa","submit","like","cancelLike","reply","cancelReply","comment","refresh","more","preview","emoji","uploadImage","seconds","minutes","hours","days","now","uploading","login","logout","admin","sticky","word","wordHint","anonymous","level0","level1","level2","level3","level4","level5","gif","gifSearchPlaceholder"],K=e=>Object.fromEntries(e.map(((e,t)=>[J[t],e])));var Y=K(["NickName","NickName cannot be less than 3 bytes.","E-Mail","Please confirm your email address.","Website","Optional","Comment here...","No comment yet.","Submit","Like","Cancel like","Reply","Cancel reply","Comments","Refresh","Load More...","Preview","Emoji","Upload Image","seconds ago","minutes ago","hours ago","days ago","just now","Uploading","Login","logout","Admin","Sticky","Words","Please input comments between $0 and $1 words!\n Current word number: $2","Anonymous","Dwarves","Hobbits","Ents","Wizards","Elves","Maiar","GIF","Search GIF"]),Z=K(["ニックネーム","3バイト以上のニックネームをご入力ください.","メールアドレス","メールアドレスをご確認ください.","サイト","オプション","ここにコメント","コメントしましょう~","提出する","Like","Cancel like","返信する","キャンセル","コメント","更新","さらに読み込む","プレビュー","絵文字","画像をアップロード","秒前","分前","時間前","日前","たっだ今","アップロード","ログインする","ログアウト","管理者","トップに置く","ワード","コメントは $0 から $1 ワードの間でなければなりません!\n 現在の単語番号: $2","匿名","うえにん","なかにん","しもおし","特にしもおし","かげ","なぬし","GIF","探す GIF"]),X=K(["昵称","昵称不能少于3个字符","邮箱","请填写正确的邮件地址","网址","可选","欢迎评论","来发评论吧~","提交","喜欢","取消喜欢","回复","取消回复","评论","刷新","加载更多...","预览","表情","上传图片","秒前","分钟前","小时前","天前","刚刚","正在上传","登录","退出","博主","置顶","字","评论字数应在 $0 到 $1 字之间!\n当前字数:$2","匿名","潜水","冒泡","吐槽","活跃","话痨","传说","表情包","搜索表情包"]),Q=K(["暱稱","郵箱","網址","可選","暱稱不能少於3個字元","請填寫正確的郵件地址","歡迎評論","來發評論吧~","提交","喜歡","取消喜歡","回覆","取消回覆","評論","刷新","載入更多...","預覽","表情","上傳圖片","秒前","分鐘前","小時前","天前","剛剛","正在上傳","登錄","退出","博主","置頂","字","評論字數應在 $0 到 $1 字之間!\n當前字數:$2","匿名","潛水","冒泡","吐槽","活躍","話癆","傳說","表情包","搜索表情包"]),ee=K(["Apelido","Apelido não pode ser menor que 3 bytes.","E-Mail","Por favor, confirme seu endereço de e-mail.","Website","Opcional","Comente aqui...","Nenhum comentário, ainda.","Enviar","Like","Cancel like","Responder","Cancelar resposta","Comentários","Refrescar","Carregar Mais...","Visualizar","Emoji","Enviar Imagem","segundos atrás","minutos atrás","horas atrás","dias atrás","agora mesmo","Enviando","Entrar","Sair","Admin","Sticky","Palavras","Favor enviar comentário com $0 a $1 palavras!\n Número de palavras atuais: $2","Anônimo","Dwarves","Hobbits","Ents","Wizards","Elves","Maiar","GIF","Pesquisar GIF"]),te=K(["Псевдоним","Никнейм не может быть меньше 3 байт.","Эл. адрес","Пожалуйста, подтвердите адрес вашей электронной почты.","Веб-сайт","Необязательный","Комментарий здесь...","Пока нет комментариев.","Отправить","Like","Cancel like","Отвечать","Отменить ответ","Комментарии","Обновить","Загрузи больше...","Превью","эмодзи","Загрузить изображение","секунд назад","несколько минут назад","несколько часов назад","дней назад","прямо сейчас","Загрузка","Авторизоваться","Выход из системы","Админ","Липкий","Слова","Пожалуйста, введите комментарии от $0 до $1 слов!\nНомер текущего слова: $2","Анонимный","Dwarves","Hobbits","Ents","Wizards","Elves","Maiar","GIF","Поиск GIF"]);const ne={zh:X,"zh-cn":X,"zh-CN":X,"zh-tw":Q,"zh-TW":Q,en:Y,"en-US":Y,"en-us":Y,jp:Z,"jp-jp":Z,"jp-JP":Z,"pt-br":ee,"pt-BR":ee,ru:te,"ru-ru":te,"ru-RU":te};function le(n){return!!e()&&(t(n),!0)}var oe;const ae="undefined"!=typeof window,re=()=>{};function ie(e,t){return function(...n){e((()=>t.apply(this,n)),{fn:t,thisArg:this,args:n})}}ae&&(null==(oe=null==window?void 0:window.navigator)?void 0:oe.userAgent)&&/iP(ad|hone|od)/.test(window.navigator.userAgent);const se=e=>e();function ce(e,t=200,n={}){return ie(function(e,t={}){let n,l;return a=>{const r=o(e),i=o(t.maxWait);if(n&&clearTimeout(n),r<=0||void 0!==i&&i<=0)return l&&(clearTimeout(l),l=null),a();i&&!l&&(l=setTimeout((()=>{n&&clearTimeout(n),l=null,a()}),i)),n=setTimeout((()=>{l&&clearTimeout(l),l=null,a()}),r)}}(t,n),e)}var ue=Object.getOwnPropertySymbols,me=Object.prototype.hasOwnProperty,de=Object.prototype.propertyIsEnumerable;function pe(e,t,l={}){const o=l,{eventFilter:a=se}=o,r=((e,t)=>{var n={};for(var l in e)me.call(e,l)&&t.indexOf(l)<0&&(n[l]=e[l]);if(null!=e&&ue)for(var l of ue(e))t.indexOf(l)<0&&de.call(e,l)&&(n[l]=e[l]);return n})(o,["eventFilter"]);return n(e,ie(a,t),r)}var ve=Object.defineProperty,ge=Object.defineProperties,he=Object.getOwnPropertyDescriptors,fe=Object.getOwnPropertySymbols,we=Object.prototype.hasOwnProperty,ye=Object.prototype.propertyIsEnumerable,be=(e,t,n)=>t in e?ve(e,t,{enumerable:!0,configurable:!0,writable:!0,value:n}):e[t]=n;function ke(e,t,n={}){const o=n,{eventFilter:a}=o,r=((e,t)=>{var n={};for(var l in e)we.call(e,l)&&t.indexOf(l)<0&&(n[l]=e[l]);if(null!=e&&fe)for(var l of fe(e))t.indexOf(l)<0&&ye.call(e,l)&&(n[l]=e[l]);return n})(o,["eventFilter"]),{eventFilter:i,pause:s,resume:c,isActive:u}=function(e=se){const t=l(!0);return{isActive:t,pause:function(){t.value=!1},resume:function(){t.value=!0},eventFilter:(...n)=>{t.value&&e(...n)}}}(a),m=pe(e,t,(d=((e,t)=>{for(var n in t||(t={}))we.call(t,n)&&be(e,n,t[n]);if(fe)for(var n of fe(t))ye.call(t,n)&&be(e,n,t[n]);return e})({},r),ge(d,he({eventFilter:i}))));var d;return{stop:m,pause:s,resume:c,isActive:u}}const Ce=ae?window:void 0,$e=ae?window.document:void 0;function Ie(...e){let t,l,a,r;if("string"==typeof e[0]?([l,a,r]=e,t=Ce):[t,l,a,r]=e,!t)return re;let i=re;const s=n((()=>function(e){var t;const n=o(e);return null!=(t=null==n?void 0:n.$el)?t:n}(t)),(e=>{i(),e&&(e.addEventListener(l,a,r),i=()=>{e.removeEventListener(l,a,r),i=re})}),{immediate:!0,flush:"post"}),c=()=>{s(),i()};return le(c),c}ae&&window.navigator,ae&&window.location;const Le="undefined"!=typeof globalThis?globalThis:"undefined"!=typeof window?window:"undefined"!=typeof global?global:"undefined"!=typeof self?self:{},Se="__vueuse_ssr_handlers__";Le[Se]=Le[Se]||{};const je=Le[Se];const xe={boolean:{read:e=>"true"===e,write:e=>String(e)},object:{read:e=>JSON.parse(e),write:e=>JSON.stringify(e)},number:{read:e=>Number.parseFloat(e),write:e=>String(e)},any:{read:e=>e,write:e=>String(e)},string:{read:e=>e,write:e=>String(e)},map:{read:e=>new Map(JSON.parse(e)),write:e=>JSON.stringify(Array.from(e.entries()))},set:{read:e=>new Set(JSON.parse(e)),write:e=>JSON.stringify(Array.from(e))},date:{read:e=>new Date(e),write:e=>e.toISOString()}};function Re(e,t,n,a={}){var r;const{flush:s="pre",deep:c=!0,listenToStorageChanges:u=!0,writeDefaults:m=!0,shallow:d,window:p=Ce,eventFilter:v,onError:g=(e=>{console.error(e)})}=a,h=(d?i:l)(t);if(!n)try{n=function(e,t){return je[e]||t}("getDefaultStorage",(()=>{var e;return null==(e=Ce)?void 0:e.localStorage}))()}catch(e){g(e)}if(!n)return h;const f=o(t),w=function(e){return null==e?"any":e instanceof Set?"set":e instanceof Map?"map":e instanceof Date?"date":"boolean"==typeof e?"boolean":"string"==typeof e?"string":"object"==typeof e||Array.isArray(e)?"object":Number.isNaN(e)?"any":"number"}(f),y=null!=(r=a.serializer)?r:xe[w],{pause:b,resume:k}=ke(h,(()=>function(t){try{null==t?n.removeItem(e):n.setItem(e,y.write(t))}catch(e){g(e)}}(h.value)),{flush:s,deep:c,eventFilter:v});return p&&u&&Ie(p,"storage",C),C(),h;function C(t){t&&t.key!==e||(h.value=function(t){if(!t||t.key===e){b();try{const l=t?t.newValue:n.getItem(e);return null==l?(m&&null!==f&&n.setItem(e,y.write(f)),f):"string"!=typeof l?l:y.read(l)}catch(e){g(e)}finally{k()}}}(t))}}var Ee,Ae,Ue=Object.defineProperty,ze=Object.getOwnPropertySymbols,Me=Object.prototype.hasOwnProperty,Oe=Object.prototype.propertyIsEnumerable,Te=(e,t,n)=>t in e?Ue(e,t,{enumerable:!0,configurable:!0,writable:!0,value:n}):e[t]=n;function Pe(e={}){const{controls:t=!1,interval:r="requestAnimationFrame"}=e,i=l(new Date),s=()=>i.value=new Date,c="requestAnimationFrame"===r?function(e,t={}){const{immediate:n=!0,window:o=Ce}=t,a=l(!1);let r=null;function i(){a.value&&o&&(e(),r=o.requestAnimationFrame(i))}function s(){!a.value&&o&&(a.value=!0,i())}function c(){a.value=!1,null!=r&&o&&(o.cancelAnimationFrame(r),r=null)}return n&&s(),le(c),{isActive:a,pause:c,resume:s}}(s,{immediate:!0}):function(e,t=1e3,r={}){const{immediate:i=!0,immediateCallback:s=!1}=r;let c=null;const u=l(!1);function m(){c&&(clearInterval(c),c=null)}function d(){u.value=!1,m()}function p(){o(t)<=0||(u.value=!0,s&&e(),m(),c=setInterval(e,o(t)))}i&&ae&&p(),a(t)&&le(n(t,(()=>{i&&ae&&p()})));return le(d),{isActive:u,pause:d,resume:p}}(s,r,{immediate:!0});return t?((e,t)=>{for(var n in t||(t={}))Me.call(t,n)&&Te(e,n,t[n]);if(ze)for(var n of ze(t))Oe.call(t,n)&&Te(e,n,t[n]);return e})({now:i},c):i}(Ae=Ee||(Ee={})).UP="UP",Ae.RIGHT="RIGHT",Ae.DOWN="DOWN",Ae.LEFT="LEFT",Ae.NONE="NONE";let Ne=0;const He=e=>{try{e=decodeURI(e)}catch(e){}return e},Ve=(e="")=>e.replace(/\/$/u,""),_e=e=>/^(https?:)?\/\//.test(e),Fe=e=>{const t=Ve(e);return _e(t)?t:`https://${t}`},Be=e=>Array.isArray(e)?e:!!e&&[0,e],De=(e,t)=>"function"==typeof e?e:!1!==e&&t,We="{--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}",Ge=(e,t)=>{let n=e.toString();for(;n.length<t;)n="0"+n;return n},qe=(e,t,n)=>{if(!e)return"";const l="string"==typeof e?new Date(-1!==e.indexOf(" ")?e.replace(/-/g,"/"):e):e,o=t.getTime()-l.getTime(),a=Math.floor(o/864e5);if(0===a){const e=o%864e5,t=Math.floor(e/36e5);if(0===t){const t=e%36e5,l=Math.floor(t/6e4);if(0===l){const e=t%6e4;return`${Math.round(e/1e3)} ${n.seconds}`}return`${l} ${n.minutes}`}return`${t} ${n.hours}`}return a<0?n.now:a<8?`${a} ${n.days}`:(e=>{const t=Ge(e.getDate(),2),n=Ge(e.getMonth()+1,2);return`${Ge(e.getFullYear(),2)}-${n}-${t}`})(l)},Je=e=>{const t=Re("WALINE_EMOJI",{}),n=Boolean(/@[0-9]+\.[0-9]+\.[0-9]+/.test(e));if(n){const n=t.value[e];if(n)return Promise.resolve(n)}return fetch(`${e}/info.json`).then((e=>e.json())).then((l=>{const o={folder:e,...l};return n&&(t.value[e]=o),o}))},Ke=(e,t="",n="",l="")=>`${t?`${t}/`:""}${n}${e}${l?`.${l}`:""}`,Ye=e=>{"AbortError"!==e.name&&console.error(e.message)},Ze={"Content-Type":"application/json"},Xe=(e,t="")=>{if("object"==typeof e&&e.errno)throw new TypeError(`Fetch ${t} failed with ${e.errno}: ${e.errmsg}`);return e},Qe=({serverURL:e,lang:t,token:n,objectId:l,...o})=>fetch(`${e}/comment/${l}?lang=${t}`,{method:"PUT",headers:{"Content-Type":"application/json",Authorization:`Bearer ${n}`},body:JSON.stringify(o)}).then((e=>e.json())),et=({serverURL:e,lang:t,paths:n,signal:l})=>fetch(`${e}/article?path=${encodeURIComponent(n.join(","))}&lang=${t}`,{signal:l}).then((e=>e.json())).then((e=>Xe(e,"visit count"))).then((e=>Array.isArray(e)?e:[e])),tt=({serverURL:e,lang:t,path:n})=>fetch(`${e}/article?lang=${t}`,{method:"POST",headers:Ze,body:JSON.stringify({path:n})}).then((e=>e.json())).then((e=>Xe(e,"visit count"))),nt=e=>e instanceof HTMLElement?e:"string"==typeof e?document.querySelector(e):null,lt=e=>e.type.includes("image"),ot=e=>{const t=Array.from(e).find(lt);return t?t.getAsFile():null},at=/\$.*?\$/,rt=/^\$(.*?)\$/,it=/^(?:\s{0,3})\$\$((?:[^\n]|\n[^\n])+?)\n{0,1}\$\$/,st=(e="",t={})=>e.replace(/:(.+?):/g,((e,n)=>t[n]?`<img class="wl-emoji" src="${t[n]}" alt="${n}">`:e)),ct=(e,{emojiMap:t,highlighter:n,texRenderer:l})=>{if(N.setOptions({highlight:n||void 0,breaks:!0,smartLists:!0,smartypants:!0}),l){const e=(e=>[{name:"blockMath",level:"block",tokenizer(t){const n=it.exec(t);if(null!==n)return{type:"html",raw:n[0],text:e(!0,n[1])}}},{name:"inlineMath",level:"inline",start(e){const t=e.search(at);return-1!==t?t:e.length},tokenizer(t){const n=rt.exec(t);if(null!==n)return{type:"html",raw:n[0],text:e(!1,n[1])}}}])(l);N.use({extensions:e})}return N.parse(st(e,t))},ut=e=>e.dataset.path||e.getAttribute("id");let mt=null;const dt=()=>mt||(mt=Re("USER_KEY",{}));let pt=null;const vt=()=>pt||(pt=Re("WALINE_LIKE",[])),gt=({serverURL:e,path:t=window.location.pathname,selector:n=".waline-comment-count",lang:l="zh-CN"})=>{const o=new AbortController,a=document.querySelectorAll(n),r=dt();return a.length&&(({serverURL:e,lang:t,paths:n,signal:l,token:o})=>{const a={};return o&&(a.Authorization=`Bearer ${o}`),fetch(`${e}/comment?type=count&url=${encodeURIComponent(n.join(","))}&lang=${t}`,{signal:l,headers:a}).then((e=>e.json())).then((e=>Xe(e,"comment count"))).then((e=>Array.isArray(e)?e:[e]))})({serverURL:Fe(e),paths:Array.from(a).map((e=>He(e.dataset.path||e.getAttribute("id")||t))),lang:l,signal:o.signal,token:r.value?.token}).then((e=>{a.forEach(((t,n)=>{t.innerText=e[n].toString()}))})).catch(Ye),o.abort.bind(o)},ht=({size:e})=>c("svg",{width:e,height:e,viewBox:"0 0 100 100",preserveAspectRatio:"xMidYMid"},c("circle",{cx:50,cy:50,fill:"none",stroke:"currentColor",strokeWidth:"4",r:"40","stroke-dasharray":"85 30"},c("animateTransform",{attributeName:"transform",type:"rotate",repeatCount:"indefinite",dur:"1s",values:"0 50 50;360 50 50",keyTimes:"0;1"})));var ft=(e,t)=>{const n=e.__vccOpts||e;for(const[e,l]of t)n[e]=l;return n};const wt=u({name:"ImageWall",components:{LoadingIcon:ht},props:{items:{type:Array,default:()=>[]},columnWidth:{type:Number,default:300},gap:{type:Number,default:0}},emit:["insert"],setup(e){let t=null;const o=l(null),a=l({}),r=l([]),i=()=>{const t=Math.floor((o.value.getBoundingClientRect().width+e.gap)/(e.columnWidth+e.gap));return t>0?t:1},s=async t=>{if(t>=e.items.length)return;await C();const n=Array.from(o.value?.children||[]).reduce(((e,t)=>t.getBoundingClientRect().height<e.getBoundingClientRect().height?t:e));r.value[Number(n.dataset.index)].push(t),await s(t+1)},c=async(e=!1)=>{if(r.value.length===i()&&!e)return;var t;r.value=(t=i(),new Array(t).fill(null).map((()=>[])));const n=window.scrollY;await s(0),window.scrollTo({top:n})};return n((()=>[e.items]),(()=>{a.value={},c(!0)})),n((()=>[e.columnWidth,e.gap]),(()=>c())),m((()=>{c(!0),t=new ResizeObserver((()=>c())),t.observe(o.value)})),d((()=>t.unobserve(o.value))),{columns:r,state:a,wall:o}}}),yt=["data-index"],bt=["src","title","onLoad","onClick"];const kt=u({name:"CommentBox",components:{CloseIcon:({size:e})=>c("svg",{class:"wl-close-icon",viewBox:"0 0 1024 1024",width:e,height:e},[c("path",{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",fill:"currentColor"}),c("path",{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",fill:"#888"})]),EmojiIcon:()=>c("svg",{viewBox:"0 0 1024 1024",width:"24",height:"24"},c("path",{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",fill:"currentColor"})),ImageIcon:()=>c("svg",{viewBox:"0 0 1024 1024",width:"24",height:"24"},[c("path",{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",fill:"currentColor"}),c("path",{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",fill:"currentColor"})]),ImageWall:ft(wt,[["render",function(e,t,n,l,o,a){const r=p("LoadingIcon");return v(),g("div",{ref:"wall",class:"wl-gallery",style:h({gap:`${e.gap}px`})},[(v(!0),g(f,null,w(e.columns,((t,n)=>(v(),g("div",{key:n,class:"wl-gallery-column","data-index":n,style:h({gap:`${e.gap}px`})},[(v(!0),g(f,null,w(t,(t=>(v(),g(f,{key:t},[e.state[e.items[t].src]?b("v-if",!0):(v(),y(r,{key:0,size:36,style:{margin:"20px auto"}})),k("img",{class:"wl-gallery-item",src:e.items[t].src,title:e.items[t].title,loading:"lazy",onLoad:n=>e.state[e.items[t].src]=!0,onClick:n=>e.$emit("insert",``)},null,40,bt)],64)))),128))],12,yt)))),128))],4)}],["__file","ImageWall.vue"]]),MarkdownIcon:()=>c("svg",{width:"16",height:"16",ariaHidden:"true"},c("path",{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",fill:"currentColor"})),PreviewIcon:()=>c("svg",{viewBox:"0 0 1024 1024",width:"24",height:"24"},[c("path",{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",fill:"currentColor"}),c("path",{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",fill:"currentColor"})]),LoadingIcon:ht,GifIcon:()=>c("svg",{width:24,height:24,fill:"currentcolor",viewBox:"0 0 24 24"},[c("path",{style:"transform: translateY(0.5px)",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"}),c("path",{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"})])},props:{rootId:{type:String,default:""},replyId:{type:String,default:""},replyUser:{type:String,default:""}},emits:["submit","cancel-reply"],setup(e,{emit:t}){const o=$("config"),a=Re("WALINE_COMMENT_BOX_EDITOR",""),r=Re("WALINE_USER_META",{nick:"",mail:"",link:""}),i=dt(),c=l({}),u=l(null),d=l(null),p=l(null),v=l(null),g=l(null),h=l(null),f=l(null),w=l({tabs:[],map:{}}),y=l(0),b=l(!1),k=l(!1),C=l(!1),S=l(""),j=l(0),x=I({loading:!0,list:[]}),R=l(0),E=l(!1),A=l(""),U=l(!1),z=s((()=>o.value.locale)),M=s((()=>Boolean(i.value?.token))),O=s((()=>!1!==o.value.imageUploader)),T=e=>{const t=u.value,n=t.selectionStart,l=t.selectionEnd||0,o=t.scrollTop;a.value=t.value.substring(0,n)+e+t.value.substring(l,t.value.length),t.focus(),t.selectionStart=n+e.length,t.selectionEnd=n+e.length,t.scrollTop=o},N=e=>{const t=`![${o.value.locale.uploading} ${e.name}]()`;return T(t),Promise.resolve().then((()=>o.value.imageUploader(e))).then((n=>{a.value=a.value.replace(t,`\r\n`)}))},H=()=>{const{serverURL:n,lang:l,login:s,wordLimit:m,requiredMeta:d}=o.value,p={comment:A.value,nick:r.value.nick,mail:r.value.mail,link:r.value.link,ua:navigator.userAgent,url:o.value.path};if(i.value?.token)p.nick=i.value.display_name,p.mail=i.value.email,p.link=i.value.url;else{if("force"===s)return;if(d.indexOf("nick")>-1&&!p.nick)return c.value.nick?.focus(),alert(z.value.nickError);if(d.indexOf("mail")>-1&&!p.mail||p.mail&&!/^\w(?:[\w._-]*\w)?@(?:\w(?:[\w-]*\w)?\.)*\w+$/.exec(p.mail))return c.value.mail?.focus(),alert(z.value.mailError);if(!p.comment)return void u.value?.focus();p.nick||(p.nick=z.value.anonymous)}if(!E.value)return alert(z.value.wordHint.replace("$0",m[0].toString()).replace("$1",m[1].toString()).replace("$2",j.value.toString()));p.comment=st(p.comment,w.value.map),e.replyId&&e.rootId&&(p.pid=e.replyId,p.rid=e.rootId,p.at=e.replyUser),U.value=!0,(({serverURL:e,lang:t,token:n,comment:l})=>{const o={"Content-Type":"application/json"};return n&&(o.Authorization=`Bearer ${n}`),fetch(`${e}/comment?lang=${t}`,{method:"POST",headers:o,body:JSON.stringify(l)}).then((e=>e.json()))})({serverURL:n,lang:l,token:i.value?.token,comment:p}).then((n=>{if(U.value=!1,n.errmsg)return alert(n.errmsg);t("submit",n.data),a.value="",S.value="",e.replyId&&t("cancel-reply")})).catch((e=>{U.value=!1,alert(e.message)}))},V=e=>{p.value.contains(e.target)||v.value.contains(e.target)||(b.value=!1),g.value.contains(e.target)||h.value.contains(e.target)||(k.value=!1)},_=async e=>{const{scrollTop:t,clientHeight:n,scrollHeight:l}=e.target,a=(n+t)/l,r=o.value.search,i=f.value?.value||"";a<.9||x.loading||(x.loading=!0,x.list.push(...r.more?await r.more(i,x.list.length):await r.search(i)),x.loading=!1,setTimeout((()=>{e.target.scrollTop=t}),50))},F=ce((e=>{x.list=[],_(e)}),300);return n([o,j],(([e,t])=>{const{wordLimit:n}=e;n?t<n[0]&&0!==n[0]?(R.value=n[0],E.value=!1):t>n[1]?(R.value=n[1],E.value=!1):(R.value=n[1],E.value=!0):(R.value=0,E.value=!0)}),{immediate:!0}),n(k,(async e=>{if(!e)return;const t=o.value.search;f.value&&(f.value.value=""),x.loading=!0,x.list=t.default?await t.default():await t.search(""),x.loading=!1})),m((()=>{document.body.addEventListener("click",V),n((()=>a.value),(e=>{const{highlighter:t,texRenderer:n}=o.value;A.value=e,S.value=ct(e,{emojiMap:w.value.map,highlighter:t,texRenderer:n}),j.value=(e=>(e=>e.match(/[\w\d\s\u00C0-\u024F]+/giu)||[])(e).reduce(((e,t)=>e+(""===t.trim()?0:t.trim().split(/\s+/u).length)),0)+(e=>e.match(/[\u4E00-\u9FA5]/gu)||[])(e).length)(e),e?P(u.value):P.destroy(u.value)}),{immediate:!0}),n((()=>o.value.emoji),(e=>{return(t=Array.isArray(e)?e:[],Promise.all(t.map((e=>"string"==typeof e?Je(Ve(e)):Promise.resolve(e)))).then((e=>{const t={tabs:[],map:{}};return e.forEach((e=>{const{name:n,folder:l,icon:o,prefix:a,type:r,items:i}=e;t.tabs.push({name:n,icon:Ke(o,l,a,r),items:i.map((e=>{const n=`${a||""}${e}`;return t.map[n]=Ke(e,l,a,r),n}))})})),t}))).then((e=>{w.value=e}));var t}),{immediate:!0})})),L((()=>{document.body.removeEventListener("click",V)})),{config:o,locale:z,insert:T,onChange:()=>{const e=d.value;e.files&&O.value&&N(e.files[0]).then((()=>{e.value=""}))},onDrop:e=>{if(e.dataTransfer?.items){const t=ot(e.dataTransfer.items);t&&O.value&&(N(t),e.preventDefault())}},onKeyDown:e=>{const t=e.key;(e.ctrlKey||e.metaKey)&&"Enter"===t&&H()},onPaste:e=>{if(e.clipboardData){const t=ot(e.clipboardData.items);t&&O.value&&N(t)}},onLogin:e=>{e.preventDefault();const{lang:t,serverURL:n}=o.value,l=(window.innerWidth-450)/2,a=(window.innerHeight-450)/2,r=window.open(`${n}/ui/login?lng=${encodeURIComponent(t)}`,"_blank",`width=450,height=450,left=${l},top=${a},scrollbars=no,resizable=no,status=no,location=no,toolbar=no,menubar=no`);r?.postMessage({type:"TOKEN",data:null},"*");const s=({data:e})=>{e&&"userInfo"===e.type&&e.data.token&&(r?.close(),i.value=e.data,(e.data.remember?localStorage:sessionStorage).setItem("WALINE_USER",JSON.stringify(e.data)),window.removeEventListener("message",s))};window.addEventListener("message",s)},onLogout:()=>{i.value={},localStorage.setItem("WALINE_USER","null"),sessionStorage.setItem("WALINE_USER","null")},onProfile:e=>{e.preventDefault();const{lang:t,serverURL:n}=o.value,l=(window.innerWidth-800)/2,a=(window.innerHeight-800)/2;window.open(`${n}/ui/profile?lng=${encodeURIComponent(t)}`,"_blank",`width=800,height=800,left=${l},top=${a},scrollbars=no,resizable=no,status=no,location=no,toolbar=no,menubar=no`)?.postMessage({type:"TOKEN",data:i.value.token},"*");const r=({data:e})=>{e&&"profile"===e.type&&(i.value={...i.value,...e},[localStorage,sessionStorage].filter((e=>e.getItem("WALINE_USER"))).forEach((e=>e.setItem("WALINE_USER",JSON.stringify(i)))),window.removeEventListener("message",r))};window.addEventListener("message",r)},submitComment:H,onImageWallScroll:_,onGifSearch:F,isLogin:M,userInfo:i,isSubmitting:U,wordNumber:j,wordLimit:R,isWordNumberLegal:E,editor:a,userMeta:r,emoji:w,emojiTabIndex:y,showEmoji:b,gifData:x,showGif:k,canUploadImage:O,previewText:S,showPreview:C,inputRefs:c,editorRef:u,emojiButtonRef:p,emojiPopupRef:v,gifButtonRef:g,gifPopupRef:h,imageUploadRef:d,gifSearchInputRef:f}}}),Ct={class:"wl-comment"},$t={key:0,class:"wl-login-info"},It={class:"wl-avatar"},Lt=["title"],St=["src"],jt=["textContent"],xt={class:"wl-panel"},Rt=["for","textContent"],Et=["id","name","type","onUpdate:modelValue"],At=["placeholder"],Ut={class:"wl-preview"},zt=k("hr",null,null,-1),Mt=["innerHTML"],Ot={class:"wl-footer"},Tt={class:"wl-actions"},Pt={href:"https://guides.github.com/features/mastering-markdown/",title:"Markdown Guide","aria-label":"Markdown is supported",class:"wl-action",target:"_blank",rel:"noreferrer"},Nt=["title"],Ht=["title"],Vt=["title"],_t=["title"],Ft={class:"wl-info"},Bt={class:"wl-text-number"},Dt={key:0},Wt=z(" / "),Gt=["textContent"],qt=["textContent"],Jt=["disabled"],Kt=["placeholder"],Yt={key:0,class:"wl-loading"},Zt={key:0,class:"wl-tab-wrapper"},Xt=["title","onClick"],Qt=["src","alt"],en={key:0,class:"wl-tabs"},tn=["onClick"],nn=["src","alt","title"],ln=["title"];var on=ft(kt,[["render",function(e,t,n,l,o,a){const r=p("CloseIcon"),i=p("MarkdownIcon"),s=p("EmojiIcon"),c=p("GifIcon"),u=p("ImageIcon"),m=p("PreviewIcon"),d=p("LoadingIcon"),h=p("ImageWall");return v(),g("div",Ct,["disable"!==e.config.login&&e.isLogin?(v(),g("div",$t,[k("div",It,[k("button",{class:"wl-logout-btn",title:e.locale.logout,onClick:t[0]||(t[0]=(...t)=>e.onLogout&&e.onLogout(...t))},[S(r,{size:14})],8,Lt),k("img",{src:e.userInfo.avatar,alt:"avatar"},null,8,St)]),k("a",{href:"#",class:"wl-login-nick","aria-label":"Profile",onClick:t[1]||(t[1]=(...t)=>e.onProfile&&e.onProfile(...t)),textContent:j(e.userInfo.display_name)},null,8,jt)])):b("v-if",!0),k("div",xt,["force"!==e.config.login&&e.config.meta.length&&!e.isLogin?(v(),g("div",{key:0,class:x(["wl-header",`item${e.config.meta.length}`])},[(v(!0),g(f,null,w(e.config.meta,(t=>(v(),g("div",{class:"wl-header-item",key:t},[k("label",{for:t,textContent:j(e.locale[t]+(e.config.requiredMeta.includes(t)||!e.config.requiredMeta.length?"":`(${e.locale.optional})`))},null,8,Rt),R(k("input",{ref_for:!0,ref:n=>{n&&(e.inputRefs[t]=n)},id:`wl-${t}`,class:x(["wl-input",`wl-${t}`]),name:t,type:"mail"===t?"email":"text","onUpdate:modelValue":n=>e.userMeta[t]=n},null,10,Et),[[E,e.userMeta[t]]])])))),128))],2)):b("v-if",!0),R(k("textarea",{class:"wl-editor",ref:"editorRef",id:"wl-edit",placeholder:e.replyUser?`@${e.replyUser}`:e.locale.placeholder,"onUpdate:modelValue":t[2]||(t[2]=t=>e.editor=t),onKeydown:t[3]||(t[3]=(...t)=>e.onKeyDown&&e.onKeyDown(...t)),onDrop:t[4]||(t[4]=(...t)=>e.onDrop&&e.onDrop(...t)),onPaste:t[5]||(t[5]=(...t)=>e.onPaste&&e.onPaste(...t))},null,40,At),[[A,e.editor]]),R(k("div",Ut,[zt,k("h4",null,j(e.locale.preview)+":",1),k("div",{class:"wl-content",innerHTML:e.previewText},null,8,Mt)],512),[[U,e.showPreview]]),k("div",Ot,[k("div",Tt,[k("a",Pt,[S(i)]),R(k("button",{ref:"emojiButtonRef",class:x(["wl-action",{actived:e.showEmoji}]),title:e.locale.emoji,onClick:t[6]||(t[6]=t=>e.showEmoji=!e.showEmoji)},[S(s)],10,Nt),[[U,e.emoji.tabs.length]]),e.config.search?(v(),g("button",{key:0,ref:"gifButtonRef",class:x(["wl-action",{actived:e.showGif}]),title:e.locale.gif,onClick:t[7]||(t[7]=t=>e.showGif=!e.showGif)},[S(c)],10,Ht)):b("v-if",!0),k("input",{ref:"imageUploadRef",class:"upload",id:"wl-image-upload",type:"file",accept:".png,.jpg,.jpeg,.webp,.bmp,.gif",onChange:t[8]||(t[8]=(...t)=>e.onChange&&e.onChange(...t))},null,544),e.canUploadImage?(v(),g("label",{key:1,for:"wl-image-upload",class:"wl-action",title:e.locale.uploadImage},[S(u)],8,Vt)):b("v-if",!0),k("button",{class:x(["wl-action",{actived:e.showPreview}]),title:e.locale.preview,onClick:t[9]||(t[9]=t=>e.showPreview=!e.showPreview)},[S(m)],10,_t)]),k("div",Ft,[k("div",Bt,[z(j(e.wordNumber)+" ",1),e.config.wordLimit?(v(),g("span",Dt,[Wt,k("span",{class:x({illegal:!e.isWordNumberLegal}),textContent:j(e.wordLimit)},null,10,Gt)])):b("v-if",!0),z(" "+j(e.locale.word),1)]),"disable"===e.config.login||e.isLogin?b("v-if",!0):(v(),g("button",{key:0,class:"wl-btn",onClick:t[10]||(t[10]=(...t)=>e.onLogin&&e.onLogin(...t)),textContent:j(e.locale.login)},null,8,qt)),"force"!==e.config.login||e.isLogin?(v(),g("button",{key:1,class:"wl-btn primary",title:"Cmd|Ctrl + Enter",disabled:e.isSubmitting,onClick:t[11]||(t[11]=(...t)=>e.submitComment&&e.submitComment(...t))},[e.isSubmitting?(v(),y(d,{key:0,size:16})):(v(),g(f,{key:1},[z(j(e.locale.submit),1)],64))],8,Jt)):b("v-if",!0)]),k("div",{ref:"gifPopupRef",class:x(["wl-gif-popup",{display:e.showGif}])},[k("input",{type:"text",placeholder:e.locale.gifSearchPlaceholder,ref:"gifSearchInputRef",onInput:t[12]||(t[12]=(...t)=>e.onGifSearch&&e.onGifSearch(...t))},null,40,Kt),S(h,{items:e.gifData.list,"column-width":200,gap:6,onInsert:t[13]||(t[13]=t=>e.insert(t)),onScroll:e.onImageWallScroll},null,8,["items","onScroll"]),e.gifData.loading?(v(),g("div",Yt,[S(d,{size:30})])):b("v-if",!0)],2),k("div",{ref:"emojiPopupRef",class:x(["wl-emoji-popup",{display:e.showEmoji}])},[(v(!0),g(f,null,w(e.emoji.tabs,((t,n)=>(v(),g(f,{key:t.name},[n===e.emojiTabIndex?(v(),g("div",Zt,[(v(!0),g(f,null,w(t.items,(t=>(v(),g("button",{key:t,title:t,onClick:n=>e.insert(`:${t}:`)},[e.showEmoji?(v(),g("img",{key:0,class:"wl-emoji",src:e.emoji.map[t],alt:t,loading:"lazy",referrerPolicy:"no-referrer"},null,8,Qt)):b("v-if",!0)],8,Xt)))),128))])):b("v-if",!0)],64)))),128)),e.emoji.tabs.length>1?(v(),g("div",en,[(v(!0),g(f,null,w(e.emoji.tabs,((t,n)=>(v(),g("button",{key:t.name,class:x(["wl-tab",{active:e.emojiTabIndex===n}]),onClick:t=>e.emojiTabIndex=n},[k("img",{class:"wl-emoji",src:t.icon,alt:t.name,title:t.name,loading:"lazy",referrerPolicy:"no-referrer"},null,8,nn)],10,tn)))),128))])):b("v-if",!0)],2)])]),e.replyId?(v(),g("button",{key:1,class:"wl-close",title:e.locale.cancelReply,onClick:t[14]||(t[14]=t=>e.$emit("cancel-reply"))},[S(r,{size:24})],8,ln)):b("v-if",!0)])}],["__file","CommentBox.vue"]]);const an=["approved","waiting","spam"],rn=u({props:{comment:{type:Object,required:!0},rootId:{type:String,required:!0},reply:{type:Object}},components:{CommentBox:on,DeleteIcon:()=>c("svg",{viewBox:"0 0 1024 1024",width:"24",height:"24"},c("path",{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",fill:"red"})),LikeIcon:({active:e=!1})=>c("svg",{viewBox:"0 0 1024 1024",width:"24",height:"24"},[c("path",{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"+(e?"":"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"),fill:e?"red":"currentColor"})]),ReplyIcon:()=>c("svg",{viewBox:"0 0 1024 1024",width:"24",height:"24"},c("path",{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",fill:"currentColor"})),VerifiedIcon:()=>c("svg",{class:"verified-icon",viewBox:"0 0 1024 1024",width:"14",height:"14"},c("path",{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",fill:"#27ae60"}))},emits:["submit","reply","like","delete","status","sticky"],setup(e){const t=$("config"),n=vt(),l=dt(),o=s((()=>t.value.locale)),a=s((()=>{let{link:t}=e.comment;return t?_e(t)?t:`https://${t}`:""})),r=s((()=>n.value.includes(e.comment.objectId))),i=((e,t)=>{const n=Pe();return s((()=>qe(e,n.value,t)))})(e.comment.insertedAt,o.value),c=s((()=>"administrator"===l.value.type)),u=s((()=>e.comment.user_id&&l.value.objectId===e.comment.user_id)),m=s((()=>e.comment.objectId===e.reply?.objectId));return{config:t,locale:o,isReplyingCurrent:m,link:a,like:r,time:i,isAdmin:c,isOwner:u,commentStatus:an}}}),sn=["id"],cn={class:"wl-user","aria-hidden":"true"},un=["src"],mn={class:"wl-card"},dn={class:"wl-head"},pn=["href"],vn={key:1,class:"wl-nick"},gn=["textContent"],hn=["textContent"],fn=["textContent"],wn=["textContent"],yn=["textContent"],bn={class:"wl-comment-actions"},kn=["title"],Cn=["textContent"],$n=["title"],In={class:"wl-meta","aria-hidden":"true"},Ln=["textContent"],Sn=["textContent"],jn=["textContent"],xn=["innerHTML"],Rn={key:0,class:"wl-admin-actions"},En={class:"wl-comment-status"},An=["disabled","onClick","textContent"],Un={key:1,class:"wl-reply-wrapper"},zn={key:2,class:"wl-quote"};const Mn=u({name:"WalineRoot",components:{CommentBox:on,CommentCard:ft(rn,[["render",function(e,t,n,l,o,a){const r=p("VerifiedIcon"),i=p("DeleteIcon"),s=p("LikeIcon"),c=p("ReplyIcon"),u=p("CommentBox"),m=p("CommentCard",!0);return v(),g("div",{class:"wl-item",id:e.comment.objectId},[k("div",cn,[e.comment.avatar?(v(),g("img",{key:0,src:e.comment.avatar},null,8,un)):b("v-if",!0),e.comment.type?(v(),y(r,{key:1})):b("v-if",!0)]),k("div",mn,[k("div",dn,[e.link?(v(),g("a",{key:0,class:"wl-nick",href:e.link,target:"_blank",rel:"nofollow noreferrer"},j(e.comment.nick),9,pn)):(v(),g("span",vn,j(e.comment.nick),1)),"administrator"===e.comment.type?(v(),g("span",{key:2,class:"wl-badge",textContent:j(e.locale.admin)},null,8,gn)):b("v-if",!0),e.comment.label?(v(),g("span",{key:3,class:"wl-badge",textContent:j(e.comment.label)},null,8,hn)):b("v-if",!0),e.comment.sticky?(v(),g("span",{key:4,class:"wl-badge",textContent:j(e.locale.sticky)},null,8,fn)):b("v-if",!0),void 0!==e.comment.level&&e.comment.level>=0?(v(),g("span",{key:5,class:x(`wl-badge level${e.comment.level}`),textContent:j(e.locale[`level${e.comment.level}`]||`Level ${e.comment.level}`)},null,10,wn)):b("v-if",!0),k("span",{class:"wl-time",textContent:j(e.time)},null,8,yn),k("div",bn,[e.isAdmin||e.isOwner?(v(),g("button",{key:0,class:"wl-delete",onClick:t[0]||(t[0]=t=>e.$emit("delete",e.comment))},[S(i)])):b("v-if",!0),k("button",{class:"wl-like",onClick:t[1]||(t[1]=t=>e.$emit("like",e.comment)),title:e.like?e.locale.cancelLike:e.locale.like},[S(s,{active:e.like},null,8,["active"]),"like"in e.comment?(v(),g("span",{key:0,textContent:j(e.comment.like)},null,8,Cn)):b("v-if",!0)],8,kn),k("button",{class:x(["wl-reply",{active:e.isReplyingCurrent}]),title:e.isReplyingCurrent?e.locale.cancelReply:e.locale.reply,onClick:t[2]||(t[2]=t=>e.$emit("reply",e.isReplyingCurrent?null:e.comment))},[S(c)],10,$n)])]),k("div",In,[e.comment.addr?(v(),g("span",{key:0,textContent:j(e.comment.addr)},null,8,Ln)):b("v-if",!0),e.comment.browser?(v(),g("span",{key:1,textContent:j(e.comment.browser)},null,8,Sn)):b("v-if",!0),e.comment.os?(v(),g("span",{key:2,textContent:j(e.comment.os)},null,8,jn)):b("v-if",!0)]),k("div",{class:"wl-content",innerHTML:e.comment.comment},null,8,xn),e.isAdmin?(v(),g("div",Rn,[k("span",En,[(v(!0),g(f,null,w(e.commentStatus,(t=>(v(),g("button",{key:t,class:x(`wl-btn wl-${t}`),disabled:e.comment.status===t,onClick:n=>e.$emit("status",{status:t,comment:e.comment}),textContent:j(t)},null,10,An)))),128))]),e.isAdmin&&!e.comment.rid?(v(),g("button",{key:0,class:"wl-btn wl-sticky",onClick:t[3]||(t[3]=t=>e.$emit("sticky",e.comment))},j(e.comment.sticky?"unsticky":"sticky"),1)):b("v-if",!0)])):b("v-if",!0),e.isReplyingCurrent?(v(),g("div",Un,[S(u,{replyId:e.comment.objectId,replyUser:e.comment.nick,rootId:e.rootId,onSubmit:t[4]||(t[4]=t=>e.$emit("submit",t)),onCancelReply:t[5]||(t[5]=t=>e.$emit("reply",null))},null,8,["replyId","replyUser","rootId"])])):b("v-if",!0),e.comment.children?(v(),g("div",zn,[(v(!0),g(f,null,w(e.comment.children,(n=>(v(),y(m,{key:n.objectId,comment:n,reply:e.reply,rootId:e.rootId,onReply:t[6]||(t[6]=t=>e.$emit("reply",t)),onSubmit:t[7]||(t[7]=t=>e.$emit("submit",t)),onLike:t[8]||(t[8]=t=>e.$emit("like",t)),onDelete:t[9]||(t[9]=t=>e.$emit("delete",t)),onStatus:t[10]||(t[10]=t=>e.$emit("status",t)),onSticky:t[11]||(t[11]=t=>e.$emit("sticky",t))},null,8,["comment","reply","rootId"])))),128))])):b("v-if",!0)])],8,sn)}],["__file","CommentCard.vue"]]),LoadingIcon:ht},props:["serverURL","path","meta","requiredMeta","dark","lang","locale","pageSize","wordLimit","emoji","login","highlighter","texRenderer","imageUploader","copyright"],setup(e){const t=s((()=>(({serverURL:e,path:t=location.pathname,lang:n="zh-CN",locale:l,emoji:o=["//unpkg.com/@waline/emojis@1.0.1/weibo"],meta:a=["nick","mail","link"],requiredMeta:r=[],dark:i=!1,pageSize:s=10,wordLimit:c,imageUploader:u,highlighter:m,texRenderer:d,copyright:p=!0,login:v="enable",search:g=B(),...h})=>({serverURL:Fe(e),path:He(t),locale:{...ne[n]||ne["zh-CN"],..."object"==typeof l?l:{}},wordLimit:Be(c),meta:V(a),requiredMeta:V(r),imageUploader:De(u,_),highlighter:De(m,q),texRenderer:De(d,F),lang:n,dark:i,emoji:o,pageSize:s,login:v,copyright:p,search:g,...h}))(e))),o=dt(),a=vt(),i=l("loading"),c=l(0),u=l(1),d=l(0),p=l([]),v=l(null),g=s((()=>{return"string"==typeof(e=t.value.dark)?"auto"===e?`@media(prefers-color-scheme:dark){body${We}}`:`${e}${We}`:!0===e?`:root${We}`:"";var e}));let h;!function(e,t={}){const o=l(!1),{document:a=$e,immediate:i=!0,manual:s=!1,id:c="vueuse_styletag_"+ ++Ne}=t,u=l(e);let m=()=>{};const d=()=>{if(!a)return;const e=a.getElementById(c)||a.createElement("style");e.type="text/css",e.id=c,t.media&&(e.media=t.media),a.head.appendChild(e),o.value||(m=n(u,(t=>{e.innerText=t}),{immediate:!0}),o.value=!0)},p=()=>{a&&o.value&&(m(),a.head.removeChild(a.getElementById(c)),o.value=!1)};i&&!s&&d(),s||le(p),r(o)}(g);const f=e=>{const{serverURL:n,path:l,pageSize:a}=t.value,r=new AbortController;i.value="loading",h?.(),(({serverURL:e,lang:t,path:n,page:l,pageSize:o,signal:a,token:r})=>{const i={};return r&&(i.Authorization=`Bearer ${r}`),fetch(`${e}/comment?path=${encodeURIComponent(n)}&pageSize=${o}&page=${l}&lang=${t}`,{signal:a,headers:i}).then((e=>e.json())).then((e=>Xe(e,"comment list")))})({serverURL:n,lang:t.value.lang,path:l,pageSize:a,page:e,signal:r.signal,token:o.value?.token}).then((t=>{i.value="success",c.value=t.count,p.value.push(...t.data),u.value=e,d.value=t.totalPages})).catch((e=>{"AbortError"!==e.name&&(console.error(e.message),i.value="error")})),h=r.abort.bind(r)},w=()=>{c.value=0,p.value=[],f(1)};return M("config",t),n((()=>e.path),w),m((()=>w())),{config:t,darkmodeStyle:g,i18n:s((()=>t.value.locale)),status:i,count:c,page:u,totalPages:d,data:p,reply:v,loadMore:()=>f(u.value+1),refresh:w,onReply:e=>{v.value=e},onSubmit:e=>{if(e.rid){const t=p.value.find((({objectId:t})=>t===e.rid));if(!t)return;Array.isArray(t.children)||(t.children=[]),t.children.push(e)}else p.value.unshift(e)},onStatusChange:async({comment:e,status:n})=>{if(e.status===n)return;const{serverURL:l,lang:a}=t.value;await Qe({serverURL:l,lang:a,token:o.value?.token,objectId:e.objectId,status:n}),e.status=n},onDelete:async({objectId:e})=>{if(!confirm("Are you sure you want to delete this comment?"))return;const{serverURL:n,lang:l}=t.value;await(({serverURL:e,lang:t,token:n,objectId:l})=>fetch(`${e}/comment/${l}?lang=${t}`,{method:"DELETE",headers:{Authorization:`Bearer ${n}`}}).then((e=>e.json())))({serverURL:n,lang:l,token:o.value?.token,objectId:e}),p.value.some(((t,n)=>t.objectId===e?(p.value=p.value.filter(((e,t)=>t!==n)),!0):t.children.some(((l,o)=>l.objectId===e&&(p.value[n].children=t.children.filter(((e,t)=>t!==o)),!0)))))},onSticky:async e=>{if(e.rid)return;const{serverURL:n,lang:l}=t.value;await Qe({serverURL:n,lang:l,token:o.value?.token,objectId:e.objectId,sticky:e.sticky?0:1}),e.sticky=!e.sticky},onLike:async e=>{const{serverURL:n,lang:l}=t.value,{objectId:o}=e,r=a.value.includes(o);await(({serverURL:e,lang:t,objectId:n,like:l})=>fetch(`${e}/comment/${n}?lang=${t}`,{method:"PUT",headers:Ze,body:JSON.stringify({like:l})}).then((e=>e.json())))({serverURL:n,lang:l,objectId:o,like:!r}),r?a.value=a.value.filter((e=>e!==o)):(a.value=[...a.value,o],a.value.length>50&&(a.value=a.value.slice(-50))),e.like=(e.like||0)+(r?-1:1)},version:"2.6.0"}}}),On={"data-waline":""},Tn={class:"wl-count"},Pn=["textContent"],Nn={class:"wl-cards"},Hn={key:1,class:"wl-operation"},Vn=["textContent"],_n={key:0,class:"wl-loading"},Fn=["textContent"],Bn={class:"wl-operation"},Dn=["textContent"],Wn={key:3,class:"wl-power"},Gn=z(" Powered by "),qn=k("a",{href:"https://github.com/walinejs/waline",target:"_blank",rel:"noreferrer"}," Waline ",-1);var Jn=ft(Mn,[["render",function(e,t,n,l,o,a){const r=p("CommentBox"),i=p("CommentCard"),s=p("LoadingIcon");return v(),g("div",On,[e.reply?b("v-if",!0):(v(),y(r,{key:0,onSubmit:e.onSubmit},null,8,["onSubmit"])),k("div",Tn,[e.count?(v(),g("span",{key:0,class:"wl-num",textContent:j(e.count)},null,8,Pn)):b("v-if",!0),z(" "+j(e.i18n.comment),1)]),k("div",Nn,[(v(!0),g(f,null,w(e.data,(t=>(v(),y(i,{key:t.objectId,"root-id":t.objectId,comment:t,reply:e.reply,onReply:e.onReply,onSubmit:e.onSubmit,onStatus:e.onStatusChange,onDelete:e.onDelete,onSticky:e.onSticky,onLike:e.onLike},null,8,["root-id","comment","reply","onReply","onSubmit","onStatus","onDelete","onSticky","onLike"])))),128))]),"error"===e.status?(v(),g("div",Hn,[k("button",{type:"button",class:"wl-btn",onClick:t[0]||(t[0]=(...t)=>e.refresh&&e.refresh(...t)),textContent:j(e.i18n.refresh)},null,8,Vn)])):(v(),g(f,{key:2},["loading"===e.status?(v(),g("div",_n,[S(s,{size:30})])):e.data.length?e.page<e.totalPages?(v(),g(f,{key:2},[b(" Load more button "),k("div",Bn,[k("button",{type:"button",class:"wl-btn",onClick:t[1]||(t[1]=(...t)=>e.loadMore&&e.loadMore(...t)),textContent:j(e.i18n.more)},null,8,Dn)])],2112)):b("v-if",!0):(v(),g("div",{key:1,class:"wl-empty",textContent:j(e.i18n.sofa)},null,8,Fn))],64)),b(" Copyright Information "),e.config.copyright?(v(),g("div",Wn,[Gn,qn,z(" v"+j(e.version),1)])):b("v-if",!0)])}],["__file","Waline.vue"]]);const Kn=(e,t)=>{t.forEach(((t,n)=>{t.innerText=e[n].toString()}))},Yn=({serverURL:e,path:t=window.location.pathname,selector:n=".waline-pageview-count",update:l=!0,lang:o="zh-CN"})=>{const a=new AbortController,r=Array.from(document.querySelectorAll(n)),i=e=>{const n=ut(e);return null!==n&&t!==n},s=n=>et({serverURL:Fe(e),paths:n.map((e=>ut(e)||t)),lang:o,signal:a.signal}).then((e=>Kn(e,n))).catch(Ye);if(l){const n=r.filter((e=>!i(e))),l=r.filter(i);tt({serverURL:e,path:t,lang:o}).then((e=>Kn(new Array(n.length).fill(e),n))),l.length&&s(l)}else s(r);return a.abort.bind(a)},Zn=({el:e="#waline",path:t=window.location.pathname,comment:n=!1,pageview:l=!1,...o})=>{const a=e?nt(e):null;if(e&&!a)throw new Error("Option 'el' do not match any domElement!");if(!o.serverURL)throw new Error("Option 'serverURL' is missing!");const r=I({...o}),i=I({comment:n,pageview:l,path:t}),s=a?O((()=>c(Jn,{path:i.path,...r}))):null;s&&s.mount(a);const u=T((()=>{i.comment&>({serverURL:r.serverURL,path:i.path,selector:"string"==typeof i.comment?i.comment:void 0})})),m=T((()=>{i.pageview&&Yn({serverURL:r.serverURL,path:i.path,selector:"string"==typeof i.pageview?i.pageview:void 0})}));return{el:a,update:({comment:e,pageview:t,path:n=window.location.pathname,...l}={})=>{Object.entries(l).forEach((([e,t])=>{r[e]=t})),i.path=n,void 0!==e&&(i.comment=e),void 0!==t&&(i.pageview=t)},destroy:()=>{s?.unmount(),u(),m()}}},Xn="2.6.0",Qn=({el:e,serverURL:t,count:n,lang:l="zh-CN"})=>{const o=dt(),a=nt(e),r=new AbortController;return(({serverURL:e,lang:t,count:n,signal:l,token:o})=>{const a={};return o&&(a.Authorization=`Bearer ${o}`),fetch(`${e}/comment?type=recent&count=${n}&lang=${t}`,{signal:l,headers:a}).then((e=>e.json())).then((e=>Xe(e,"recent comment")))})({serverURL:t,count:n,lang:l,signal:r.signal,token:o.value?.token}).then((e=>a&&e.length?(a.innerHTML=`<ul class="wl-recent-list">${e.map((e=>`<li class="wl-recent-item"><a href="${e.url}">${e.nick}</a>:${e.comment}</li>`)).join("")}</ul>`,{comments:e,destroy:()=>{r.abort(),a.innerHTML=""}}):{comments:e,destroy:()=>r.abort()}))};export{Qn as RecentComments,gt as commentCount,ne as defaultLocales,Zn as init,Yn as pageviewCount,Xn as version};
|
|
1
|
+
import{getCurrentScope as e,onScopeDispose as t,watch as n,ref as l,unref as o,isRef as a,readonly as r,shallowRef as i,computed as s,h as c,defineComponent as u,onMounted as m,onBeforeUnmount as d,resolveComponent as p,openBlock as v,createElementBlock as g,normalizeStyle as h,Fragment as f,renderList as w,createBlock as y,createCommentVNode as b,createElementVNode as k,nextTick as C,inject as $,reactive as I,onUnmounted as L,createVNode as S,toDisplayString as j,normalizeClass as x,withDirectives as R,vModelDynamic as E,vModelText as A,vShow as U,createTextVNode as z,provide as M,createApp as O,watchEffect as T}from"vue";import P from"autosize";import{marked as N}from"marked";const H=["nick","mail","link"],V=e=>e.filter((e=>H.includes(e))),_=e=>new Promise(((t,n)=>{const l=new FileReader;l.readAsDataURL(e),l.onload=()=>t(l.result?.toString()||""),l.onerror=n})),F=e=>!0===e?'<p class="wl-tex">Tex is not available in preview</p>':'<span class="wl-tex">Tex is not available in preview</span>',B=()=>{const e={next:""},t=({keyword:e,pos:t})=>{const n=new URLSearchParams("media_filter=minimal");return n.set("key","PAY5JLFIH6V6"),n.set("limit","20"),n.set("pos",t||""),n.set("q",e),fetch(`https://g.tenor.com/v1/search?${n.toString()}`,{headers:{"Content-Type":"application/json"}}).then((e=>e.json())).catch((()=>({next:t||"",results:[]})))};return{search:(n="")=>t({keyword:n}).then((t=>(e.next=t.next,t.results.map((e=>({title:e.title,src:e.media[0].tinygif.url})))))),more:n=>t({keyword:n,pos:e.next}).then((t=>(e.next=t.next,t.results.map((e=>({title:e.title,src:e.media[0].tinygif.url}))))))}},D=new RegExp(`(${/[\u4E00-\u9FFF\u3400-\u4dbf\uf900-\ufaff\u3040-\u309f\uac00-\ud7af\u0400-\u04FF]+|\w+/.source}|${/</.source})|((?:${/(?:^|\s)\/\/(.+?)$/gm.source})|(?:${/\/\*([\S\s]*?)\*\//gm.source}))`,"gmi"),W=["23AC69","91C132","F19726","E8552D","1AAB8E","E1147F","2980C1","1BA1E6","9FA0A0","F19726","E30B20","E30B20","A3338B"],G={},q=e=>{let t=0;return e.replace(D,((e,n,l)=>{if(l)return`<span style="color: slategray">${l}</span>`;if("<"===n)return"<";let o;G[n]?o=G[n]:(o=W[t],G[n]=o);const a=`<span style="color: #${o}">${n}</span>`;return t=++t%W.length,a}))},J=["nick","nickError","mail","mailError","link","optional","placeholder","sofa","submit","like","cancelLike","reply","cancelReply","comment","refresh","more","preview","emoji","uploadImage","seconds","minutes","hours","days","now","uploading","login","logout","admin","sticky","word","wordHint","anonymous","level0","level1","level2","level3","level4","level5","gif","gifSearchPlaceholder"],K=e=>Object.fromEntries(e.map(((e,t)=>[J[t],e])));var Y=K(["NickName","NickName cannot be less than 3 bytes.","E-Mail","Please confirm your email address.","Website","Optional","Comment here...","No comment yet.","Submit","Like","Cancel like","Reply","Cancel reply","Comments","Refresh","Load More...","Preview","Emoji","Upload Image","seconds ago","minutes ago","hours ago","days ago","just now","Uploading","Login","logout","Admin","Sticky","Words","Please input comments between $0 and $1 words!\n Current word number: $2","Anonymous","Dwarves","Hobbits","Ents","Wizards","Elves","Maiar","GIF","Search GIF"]),Z=K(["ニックネーム","3バイト以上のニックネームをご入力ください.","メールアドレス","メールアドレスをご確認ください.","サイト","オプション","ここにコメント","コメントしましょう~","提出する","Like","Cancel like","返信する","キャンセル","コメント","更新","さらに読み込む","プレビュー","絵文字","画像をアップロード","秒前","分前","時間前","日前","たっだ今","アップロード","ログインする","ログアウト","管理者","トップに置く","ワード","コメントは $0 から $1 ワードの間でなければなりません!\n 現在の単語番号: $2","匿名","うえにん","なかにん","しもおし","特にしもおし","かげ","なぬし","GIF","探す GIF"]),X=K(["昵称","昵称不能少于3个字符","邮箱","请填写正确的邮件地址","网址","可选","欢迎评论","来发评论吧~","提交","喜欢","取消喜欢","回复","取消回复","评论","刷新","加载更多...","预览","表情","上传图片","秒前","分钟前","小时前","天前","刚刚","正在上传","登录","退出","博主","置顶","字","评论字数应在 $0 到 $1 字之间!\n当前字数:$2","匿名","潜水","冒泡","吐槽","活跃","话痨","传说","表情包","搜索表情包"]),Q=K(["暱稱","郵箱","網址","可選","暱稱不能少於3個字元","請填寫正確的郵件地址","歡迎評論","來發評論吧~","提交","喜歡","取消喜歡","回覆","取消回覆","評論","刷新","載入更多...","預覽","表情","上傳圖片","秒前","分鐘前","小時前","天前","剛剛","正在上傳","登錄","退出","博主","置頂","字","評論字數應在 $0 到 $1 字之間!\n當前字數:$2","匿名","潛水","冒泡","吐槽","活躍","話癆","傳說","表情包","搜索表情包"]),ee=K(["Apelido","Apelido não pode ser menor que 3 bytes.","E-Mail","Por favor, confirme seu endereço de e-mail.","Website","Opcional","Comente aqui...","Nenhum comentário, ainda.","Enviar","Like","Cancel like","Responder","Cancelar resposta","Comentários","Refrescar","Carregar Mais...","Visualizar","Emoji","Enviar Imagem","segundos atrás","minutos atrás","horas atrás","dias atrás","agora mesmo","Enviando","Entrar","Sair","Admin","Sticky","Palavras","Favor enviar comentário com $0 a $1 palavras!\n Número de palavras atuais: $2","Anônimo","Dwarves","Hobbits","Ents","Wizards","Elves","Maiar","GIF","Pesquisar GIF"]),te=K(["Псевдоним","Никнейм не может быть меньше 3 байт.","Эл. адрес","Пожалуйста, подтвердите адрес вашей электронной почты.","Веб-сайт","Необязательный","Комментарий здесь...","Пока нет комментариев.","Отправить","Like","Cancel like","Отвечать","Отменить ответ","Комментарии","Обновить","Загрузи больше...","Превью","эмодзи","Загрузить изображение","секунд назад","несколько минут назад","несколько часов назад","дней назад","прямо сейчас","Загрузка","Авторизоваться","Выход из системы","Админ","Липкий","Слова","Пожалуйста, введите комментарии от $0 до $1 слов!\nНомер текущего слова: $2","Анонимный","Dwarves","Hobbits","Ents","Wizards","Elves","Maiar","GIF","Поиск GIF"]);const ne={zh:X,"zh-cn":X,"zh-CN":X,"zh-tw":Q,"zh-TW":Q,en:Y,"en-US":Y,"en-us":Y,jp:Z,"jp-jp":Z,"jp-JP":Z,"pt-br":ee,"pt-BR":ee,ru:te,"ru-ru":te,"ru-RU":te};function le(n){return!!e()&&(t(n),!0)}var oe;const ae="undefined"!=typeof window,re=()=>{};function ie(e,t){return function(...n){e((()=>t.apply(this,n)),{fn:t,thisArg:this,args:n})}}ae&&(null==(oe=null==window?void 0:window.navigator)?void 0:oe.userAgent)&&/iP(ad|hone|od)/.test(window.navigator.userAgent);const se=e=>e();function ce(e,t=200,n={}){return ie(function(e,t={}){let n,l;return a=>{const r=o(e),i=o(t.maxWait);if(n&&clearTimeout(n),r<=0||void 0!==i&&i<=0)return l&&(clearTimeout(l),l=null),a();i&&!l&&(l=setTimeout((()=>{n&&clearTimeout(n),l=null,a()}),i)),n=setTimeout((()=>{l&&clearTimeout(l),l=null,a()}),r)}}(t,n),e)}var ue=Object.getOwnPropertySymbols,me=Object.prototype.hasOwnProperty,de=Object.prototype.propertyIsEnumerable;function pe(e,t,l={}){const o=l,{eventFilter:a=se}=o,r=((e,t)=>{var n={};for(var l in e)me.call(e,l)&&t.indexOf(l)<0&&(n[l]=e[l]);if(null!=e&&ue)for(var l of ue(e))t.indexOf(l)<0&&de.call(e,l)&&(n[l]=e[l]);return n})(o,["eventFilter"]);return n(e,ie(a,t),r)}var ve=Object.defineProperty,ge=Object.defineProperties,he=Object.getOwnPropertyDescriptors,fe=Object.getOwnPropertySymbols,we=Object.prototype.hasOwnProperty,ye=Object.prototype.propertyIsEnumerable,be=(e,t,n)=>t in e?ve(e,t,{enumerable:!0,configurable:!0,writable:!0,value:n}):e[t]=n;function ke(e,t,n={}){const o=n,{eventFilter:a}=o,r=((e,t)=>{var n={};for(var l in e)we.call(e,l)&&t.indexOf(l)<0&&(n[l]=e[l]);if(null!=e&&fe)for(var l of fe(e))t.indexOf(l)<0&&ye.call(e,l)&&(n[l]=e[l]);return n})(o,["eventFilter"]),{eventFilter:i,pause:s,resume:c,isActive:u}=function(e=se){const t=l(!0);return{isActive:t,pause:function(){t.value=!1},resume:function(){t.value=!0},eventFilter:(...n)=>{t.value&&e(...n)}}}(a),m=pe(e,t,(d=((e,t)=>{for(var n in t||(t={}))we.call(t,n)&&be(e,n,t[n]);if(fe)for(var n of fe(t))ye.call(t,n)&&be(e,n,t[n]);return e})({},r),ge(d,he({eventFilter:i}))));var d;return{stop:m,pause:s,resume:c,isActive:u}}const Ce=ae?window:void 0,$e=ae?window.document:void 0;function Ie(...e){let t,l,a,r;if("string"==typeof e[0]?([l,a,r]=e,t=Ce):[t,l,a,r]=e,!t)return re;let i=re;const s=n((()=>function(e){var t;const n=o(e);return null!=(t=null==n?void 0:n.$el)?t:n}(t)),(e=>{i(),e&&(e.addEventListener(l,a,r),i=()=>{e.removeEventListener(l,a,r),i=re})}),{immediate:!0,flush:"post"}),c=()=>{s(),i()};return le(c),c}ae&&window.navigator,ae&&window.location;const Le="undefined"!=typeof globalThis?globalThis:"undefined"!=typeof window?window:"undefined"!=typeof global?global:"undefined"!=typeof self?self:{},Se="__vueuse_ssr_handlers__";Le[Se]=Le[Se]||{};const je=Le[Se];const xe={boolean:{read:e=>"true"===e,write:e=>String(e)},object:{read:e=>JSON.parse(e),write:e=>JSON.stringify(e)},number:{read:e=>Number.parseFloat(e),write:e=>String(e)},any:{read:e=>e,write:e=>String(e)},string:{read:e=>e,write:e=>String(e)},map:{read:e=>new Map(JSON.parse(e)),write:e=>JSON.stringify(Array.from(e.entries()))},set:{read:e=>new Set(JSON.parse(e)),write:e=>JSON.stringify(Array.from(e))},date:{read:e=>new Date(e),write:e=>e.toISOString()}};function Re(e,t,n,a={}){var r;const{flush:s="pre",deep:c=!0,listenToStorageChanges:u=!0,writeDefaults:m=!0,shallow:d,window:p=Ce,eventFilter:v,onError:g=(e=>{console.error(e)})}=a,h=(d?i:l)(t);if(!n)try{n=function(e,t){return je[e]||t}("getDefaultStorage",(()=>{var e;return null==(e=Ce)?void 0:e.localStorage}))()}catch(e){g(e)}if(!n)return h;const f=o(t),w=function(e){return null==e?"any":e instanceof Set?"set":e instanceof Map?"map":e instanceof Date?"date":"boolean"==typeof e?"boolean":"string"==typeof e?"string":"object"==typeof e||Array.isArray(e)?"object":Number.isNaN(e)?"any":"number"}(f),y=null!=(r=a.serializer)?r:xe[w],{pause:b,resume:k}=ke(h,(()=>function(t){try{null==t?n.removeItem(e):n.setItem(e,y.write(t))}catch(e){g(e)}}(h.value)),{flush:s,deep:c,eventFilter:v});return p&&u&&Ie(p,"storage",C),C(),h;function C(t){t&&t.key!==e||(h.value=function(t){if(!t||t.key===e){b();try{const l=t?t.newValue:n.getItem(e);return null==l?(m&&null!==f&&n.setItem(e,y.write(f)),f):"string"!=typeof l?l:y.read(l)}catch(e){g(e)}finally{k()}}}(t))}}var Ee,Ae,Ue=Object.defineProperty,ze=Object.getOwnPropertySymbols,Me=Object.prototype.hasOwnProperty,Oe=Object.prototype.propertyIsEnumerable,Te=(e,t,n)=>t in e?Ue(e,t,{enumerable:!0,configurable:!0,writable:!0,value:n}):e[t]=n;function Pe(e={}){const{controls:t=!1,interval:r="requestAnimationFrame"}=e,i=l(new Date),s=()=>i.value=new Date,c="requestAnimationFrame"===r?function(e,t={}){const{immediate:n=!0,window:o=Ce}=t,a=l(!1);let r=null;function i(){a.value&&o&&(e(),r=o.requestAnimationFrame(i))}function s(){!a.value&&o&&(a.value=!0,i())}function c(){a.value=!1,null!=r&&o&&(o.cancelAnimationFrame(r),r=null)}return n&&s(),le(c),{isActive:a,pause:c,resume:s}}(s,{immediate:!0}):function(e,t=1e3,r={}){const{immediate:i=!0,immediateCallback:s=!1}=r;let c=null;const u=l(!1);function m(){c&&(clearInterval(c),c=null)}function d(){u.value=!1,m()}function p(){o(t)<=0||(u.value=!0,s&&e(),m(),c=setInterval(e,o(t)))}i&&ae&&p(),a(t)&&le(n(t,(()=>{i&&ae&&p()})));return le(d),{isActive:u,pause:d,resume:p}}(s,r,{immediate:!0});return t?((e,t)=>{for(var n in t||(t={}))Me.call(t,n)&&Te(e,n,t[n]);if(ze)for(var n of ze(t))Oe.call(t,n)&&Te(e,n,t[n]);return e})({now:i},c):i}(Ae=Ee||(Ee={})).UP="UP",Ae.RIGHT="RIGHT",Ae.DOWN="DOWN",Ae.LEFT="LEFT",Ae.NONE="NONE";let Ne=0;const He=e=>{try{e=decodeURI(e)}catch(e){}return e},Ve=(e="")=>e.replace(/\/$/u,""),_e=e=>/^(https?:)?\/\//.test(e),Fe=e=>{const t=Ve(e);return _e(t)?t:`https://${t}`},Be=e=>Array.isArray(e)?e:!!e&&[0,e],De=(e,t)=>"function"==typeof e?e:!1!==e&&t,We="{--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}",Ge=(e,t)=>{let n=e.toString();for(;n.length<t;)n="0"+n;return n},qe=(e,t,n)=>{if(!e)return"";const l="string"==typeof e?new Date(-1!==e.indexOf(" ")?e.replace(/-/g,"/"):e):e,o=t.getTime()-l.getTime(),a=Math.floor(o/864e5);if(0===a){const e=o%864e5,t=Math.floor(e/36e5);if(0===t){const t=e%36e5,l=Math.floor(t/6e4);if(0===l){const e=t%6e4;return`${Math.round(e/1e3)} ${n.seconds}`}return`${l} ${n.minutes}`}return`${t} ${n.hours}`}return a<0?n.now:a<8?`${a} ${n.days}`:(e=>{const t=Ge(e.getDate(),2),n=Ge(e.getMonth()+1,2);return`${Ge(e.getFullYear(),2)}-${n}-${t}`})(l)},Je=e=>{const t=Re("WALINE_EMOJI",{}),n=Boolean(/@[0-9]+\.[0-9]+\.[0-9]+/.test(e));if(n){const n=t.value[e];if(n)return Promise.resolve(n)}return fetch(`${e}/info.json`).then((e=>e.json())).then((l=>{const o={folder:e,...l};return n&&(t.value[e]=o),o}))},Ke=(e,t="",n="",l="")=>`${t?`${t}/`:""}${n}${e}${l?`.${l}`:""}`,Ye=e=>{"AbortError"!==e.name&&console.error(e.message)},Ze={"Content-Type":"application/json"},Xe=(e,t="")=>{if("object"==typeof e&&e.errno)throw new TypeError(`Fetch ${t} failed with ${e.errno}: ${e.errmsg}`);return e},Qe=({serverURL:e,lang:t,token:n,objectId:l,...o})=>fetch(`${e}/comment/${l}?lang=${t}`,{method:"PUT",headers:{"Content-Type":"application/json",Authorization:`Bearer ${n}`},body:JSON.stringify(o)}).then((e=>e.json())),et=({serverURL:e,lang:t,paths:n,signal:l})=>fetch(`${e}/article?path=${encodeURIComponent(n.join(","))}&lang=${t}`,{signal:l}).then((e=>e.json())).then((e=>Xe(e,"visit count"))).then((e=>Array.isArray(e)?e:[e])),tt=({serverURL:e,lang:t,path:n})=>fetch(`${e}/article?lang=${t}`,{method:"POST",headers:Ze,body:JSON.stringify({path:n})}).then((e=>e.json())).then((e=>Xe(e,"visit count"))),nt=e=>e instanceof HTMLElement?e:"string"==typeof e?document.querySelector(e):null,lt=e=>e.type.includes("image"),ot=e=>{const t=Array.from(e).find(lt);return t?t.getAsFile():null},at=/\$.*?\$/,rt=/^\$(.*?)\$/,it=/^(?:\s{0,3})\$\$((?:[^\n]|\n[^\n])+?)\n{0,1}\$\$/,st=(e="",t={})=>e.replace(/:(.+?):/g,((e,n)=>t[n]?`<img class="wl-emoji" src="${t[n]}" alt="${n}">`:e)),ct=(e,{emojiMap:t,highlighter:n,texRenderer:l})=>{if(N.setOptions({highlight:n||void 0,breaks:!0,smartLists:!0,smartypants:!0}),l){const e=(e=>[{name:"blockMath",level:"block",tokenizer(t){const n=it.exec(t);if(null!==n)return{type:"html",raw:n[0],text:e(!0,n[1])}}},{name:"inlineMath",level:"inline",start(e){const t=e.search(at);return-1!==t?t:e.length},tokenizer(t){const n=rt.exec(t);if(null!==n)return{type:"html",raw:n[0],text:e(!1,n[1])}}}])(l);N.use({extensions:e})}return N.parse(st(e,t))},ut=e=>e.dataset.path||e.getAttribute("id");let mt=null;const dt=()=>mt||(mt=Re("USER_KEY",{}));let pt=null;const vt=()=>pt||(pt=Re("WALINE_LIKE",[])),gt=({serverURL:e,path:t=window.location.pathname,selector:n=".waline-comment-count",lang:l="zh-CN"})=>{const o=new AbortController,a=document.querySelectorAll(n),r=dt();return a.length&&(({serverURL:e,lang:t,paths:n,signal:l,token:o})=>{const a={};return o&&(a.Authorization=`Bearer ${o}`),fetch(`${e}/comment?type=count&url=${encodeURIComponent(n.join(","))}&lang=${t}`,{signal:l,headers:a}).then((e=>e.json())).then((e=>Xe(e,"comment count"))).then((e=>Array.isArray(e)?e:[e]))})({serverURL:Fe(e),paths:Array.from(a).map((e=>He(e.dataset.path||e.getAttribute("id")||t))),lang:l,signal:o.signal,token:r.value?.token}).then((e=>{a.forEach(((t,n)=>{t.innerText=e[n].toString()}))})).catch(Ye),o.abort.bind(o)},ht=({size:e})=>c("svg",{width:e,height:e,viewBox:"0 0 100 100",preserveAspectRatio:"xMidYMid"},c("circle",{cx:50,cy:50,fill:"none",stroke:"currentColor",strokeWidth:"4",r:"40","stroke-dasharray":"85 30"},c("animateTransform",{attributeName:"transform",type:"rotate",repeatCount:"indefinite",dur:"1s",values:"0 50 50;360 50 50",keyTimes:"0;1"})));var ft=(e,t)=>{const n=e.__vccOpts||e;for(const[e,l]of t)n[e]=l;return n};const wt=u({name:"ImageWall",components:{LoadingIcon:ht},props:{items:{type:Array,default:()=>[]},columnWidth:{type:Number,default:300},gap:{type:Number,default:0}},emit:["insert"],setup(e){let t=null;const o=l(null),a=l({}),r=l([]),i=()=>{const t=Math.floor((o.value.getBoundingClientRect().width+e.gap)/(e.columnWidth+e.gap));return t>0?t:1},s=async t=>{if(t>=e.items.length)return;await C();const n=Array.from(o.value?.children||[]).reduce(((e,t)=>t.getBoundingClientRect().height<e.getBoundingClientRect().height?t:e));r.value[Number(n.dataset.index)].push(t),await s(t+1)},c=async(e=!1)=>{if(r.value.length===i()&&!e)return;var t;r.value=(t=i(),new Array(t).fill(null).map((()=>[])));const n=window.scrollY;await s(0),window.scrollTo({top:n})};return n((()=>[e.items]),(()=>{a.value={},c(!0)})),n((()=>[e.columnWidth,e.gap]),(()=>c())),m((()=>{c(!0),t=new ResizeObserver((()=>c())),t.observe(o.value)})),d((()=>t.unobserve(o.value))),{columns:r,state:a,wall:o}}}),yt=["data-index"],bt=["src","title","onLoad","onClick"];const kt=u({name:"CommentBox",components:{CloseIcon:({size:e})=>c("svg",{class:"wl-close-icon",viewBox:"0 0 1024 1024",width:e,height:e},[c("path",{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",fill:"currentColor"}),c("path",{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",fill:"#888"})]),EmojiIcon:()=>c("svg",{viewBox:"0 0 1024 1024",width:"24",height:"24"},c("path",{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",fill:"currentColor"})),ImageIcon:()=>c("svg",{viewBox:"0 0 1024 1024",width:"24",height:"24"},[c("path",{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",fill:"currentColor"}),c("path",{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",fill:"currentColor"})]),ImageWall:ft(wt,[["render",function(e,t,n,l,o,a){const r=p("LoadingIcon");return v(),g("div",{ref:"wall",class:"wl-gallery",style:h({gap:`${e.gap}px`})},[(v(!0),g(f,null,w(e.columns,((t,n)=>(v(),g("div",{key:n,class:"wl-gallery-column","data-index":n,style:h({gap:`${e.gap}px`})},[(v(!0),g(f,null,w(t,(t=>(v(),g(f,{key:t},[e.state[e.items[t].src]?b("v-if",!0):(v(),y(r,{key:0,size:36,style:{margin:"20px auto"}})),k("img",{class:"wl-gallery-item",src:e.items[t].src,title:e.items[t].title,loading:"lazy",onLoad:n=>e.state[e.items[t].src]=!0,onClick:n=>e.$emit("insert",``)},null,40,bt)],64)))),128))],12,yt)))),128))],4)}],["__file","ImageWall.vue"]]),MarkdownIcon:()=>c("svg",{width:"16",height:"16",ariaHidden:"true"},c("path",{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",fill:"currentColor"})),PreviewIcon:()=>c("svg",{viewBox:"0 0 1024 1024",width:"24",height:"24"},[c("path",{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",fill:"currentColor"}),c("path",{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",fill:"currentColor"})]),LoadingIcon:ht,GifIcon:()=>c("svg",{width:24,height:24,fill:"currentcolor",viewBox:"0 0 24 24"},[c("path",{style:"transform: translateY(0.5px)",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"}),c("path",{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"})])},props:{rootId:{type:String,default:""},replyId:{type:String,default:""},replyUser:{type:String,default:""}},emits:["submit","cancel-reply"],setup(e,{emit:t}){const o=$("config"),a=Re("WALINE_COMMENT_BOX_EDITOR",""),r=Re("WALINE_USER_META",{nick:"",mail:"",link:""}),i=dt(),c=l({}),u=l(null),d=l(null),p=l(null),v=l(null),g=l(null),h=l(null),f=l(null),w=l({tabs:[],map:{}}),y=l(0),b=l(!1),k=l(!1),C=l(!1),S=l(""),j=l(0),x=I({loading:!0,list:[]}),R=l(0),E=l(!1),A=l(""),U=l(!1),z=s((()=>o.value.locale)),M=s((()=>Boolean(i.value?.token))),O=s((()=>!1!==o.value.imageUploader)),T=e=>{const t=u.value,n=t.selectionStart,l=t.selectionEnd||0,o=t.scrollTop;a.value=t.value.substring(0,n)+e+t.value.substring(l,t.value.length),t.focus(),t.selectionStart=n+e.length,t.selectionEnd=n+e.length,t.scrollTop=o},N=e=>{const t=`![${o.value.locale.uploading} ${e.name}]()`;return T(t),Promise.resolve().then((()=>o.value.imageUploader(e))).then((n=>{a.value=a.value.replace(t,`\r\n`)}))},H=()=>{const{serverURL:n,lang:l,login:s,wordLimit:m,requiredMeta:d}=o.value,p={comment:A.value,nick:r.value.nick,mail:r.value.mail,link:r.value.link,ua:navigator.userAgent,url:o.value.path};if(i.value?.token)p.nick=i.value.display_name,p.mail=i.value.email,p.link=i.value.url;else{if("force"===s)return;if(d.indexOf("nick")>-1&&!p.nick)return c.value.nick?.focus(),alert(z.value.nickError);if(d.indexOf("mail")>-1&&!p.mail||p.mail&&!/^\w(?:[\w._-]*\w)?@(?:\w(?:[\w-]*\w)?\.)*\w+$/.exec(p.mail))return c.value.mail?.focus(),alert(z.value.mailError);if(!p.comment)return void u.value?.focus();p.nick||(p.nick=z.value.anonymous)}if(!E.value)return alert(z.value.wordHint.replace("$0",m[0].toString()).replace("$1",m[1].toString()).replace("$2",j.value.toString()));p.comment=st(p.comment,w.value.map),e.replyId&&e.rootId&&(p.pid=e.replyId,p.rid=e.rootId,p.at=e.replyUser),U.value=!0,(({serverURL:e,lang:t,token:n,comment:l})=>{const o={"Content-Type":"application/json"};return n&&(o.Authorization=`Bearer ${n}`),fetch(`${e}/comment?lang=${t}`,{method:"POST",headers:o,body:JSON.stringify(l)}).then((e=>e.json()))})({serverURL:n,lang:l,token:i.value?.token,comment:p}).then((n=>{if(U.value=!1,n.errmsg)return alert(n.errmsg);t("submit",n.data),a.value="",S.value="",e.replyId&&t("cancel-reply")})).catch((e=>{U.value=!1,alert(e.message)}))},V=e=>{p.value.contains(e.target)||v.value.contains(e.target)||(b.value=!1),g.value.contains(e.target)||h.value.contains(e.target)||(k.value=!1)},_=async e=>{const{scrollTop:t,clientHeight:n,scrollHeight:l}=e.target,a=(n+t)/l,r=o.value.search,i=f.value?.value||"";a<.9||x.loading||(x.loading=!0,x.list.push(...r.more?await r.more(i,x.list.length):await r.search(i)),x.loading=!1,setTimeout((()=>{e.target.scrollTop=t}),50))},F=ce((e=>{x.list=[],_(e)}),300);return n([o,j],(([e,t])=>{const{wordLimit:n}=e;n?t<n[0]&&0!==n[0]?(R.value=n[0],E.value=!1):t>n[1]?(R.value=n[1],E.value=!1):(R.value=n[1],E.value=!0):(R.value=0,E.value=!0)}),{immediate:!0}),n(k,(async e=>{if(!e)return;const t=o.value.search;f.value&&(f.value.value=""),x.loading=!0,x.list=t.default?await t.default():await t.search(""),x.loading=!1})),m((()=>{document.body.addEventListener("click",V),n((()=>a.value),(e=>{const{highlighter:t,texRenderer:n}=o.value;A.value=e,S.value=ct(e,{emojiMap:w.value.map,highlighter:t,texRenderer:n}),j.value=(e=>(e=>e.match(/[\w\d\s\u00C0-\u024F]+/giu)||[])(e).reduce(((e,t)=>e+(""===t.trim()?0:t.trim().split(/\s+/u).length)),0)+(e=>e.match(/[\u4E00-\u9FA5]/gu)||[])(e).length)(e),e?P(u.value):P.destroy(u.value)}),{immediate:!0}),n((()=>o.value.emoji),(e=>{return(t=Array.isArray(e)?e:[],Promise.all(t.map((e=>"string"==typeof e?Je(Ve(e)):Promise.resolve(e)))).then((e=>{const t={tabs:[],map:{}};return e.forEach((e=>{const{name:n,folder:l,icon:o,prefix:a,type:r,items:i}=e;t.tabs.push({name:n,icon:Ke(o,l,a,r),items:i.map((e=>{const n=`${a||""}${e}`;return t.map[n]=Ke(e,l,a,r),n}))})})),t}))).then((e=>{w.value=e}));var t}),{immediate:!0})})),L((()=>{document.body.removeEventListener("click",V)})),{config:o,locale:z,insert:T,onChange:()=>{const e=d.value;e.files&&O.value&&N(e.files[0]).then((()=>{e.value=""}))},onDrop:e=>{if(e.dataTransfer?.items){const t=ot(e.dataTransfer.items);t&&O.value&&(N(t),e.preventDefault())}},onKeyDown:e=>{const t=e.key;(e.ctrlKey||e.metaKey)&&"Enter"===t&&H()},onPaste:e=>{if(e.clipboardData){const t=ot(e.clipboardData.items);t&&O.value&&N(t)}},onLogin:e=>{e.preventDefault();const{lang:t,serverURL:n}=o.value,l=(window.innerWidth-450)/2,a=(window.innerHeight-450)/2,r=window.open(`${n}/ui/login?lng=${encodeURIComponent(t)}`,"_blank",`width=450,height=450,left=${l},top=${a},scrollbars=no,resizable=no,status=no,location=no,toolbar=no,menubar=no`);r?.postMessage({type:"TOKEN",data:null},"*");const s=({data:e})=>{e&&"userInfo"===e.type&&e.data.token&&(r?.close(),i.value=e.data,(e.data.remember?localStorage:sessionStorage).setItem("WALINE_USER",JSON.stringify(e.data)),window.removeEventListener("message",s))};window.addEventListener("message",s)},onLogout:()=>{i.value={},localStorage.setItem("WALINE_USER","null"),sessionStorage.setItem("WALINE_USER","null")},onProfile:e=>{e.preventDefault();const{lang:t,serverURL:n}=o.value,l=(window.innerWidth-800)/2,a=(window.innerHeight-800)/2;window.open(`${n}/ui/profile?lng=${encodeURIComponent(t)}`,"_blank",`width=800,height=800,left=${l},top=${a},scrollbars=no,resizable=no,status=no,location=no,toolbar=no,menubar=no`)?.postMessage({type:"TOKEN",data:i.value.token},"*");const r=({data:e})=>{e&&"profile"===e.type&&(i.value={...i.value,...e},[localStorage,sessionStorage].filter((e=>e.getItem("WALINE_USER"))).forEach((e=>e.setItem("WALINE_USER",JSON.stringify(i)))),window.removeEventListener("message",r))};window.addEventListener("message",r)},submitComment:H,onImageWallScroll:_,onGifSearch:F,isLogin:M,userInfo:i,isSubmitting:U,wordNumber:j,wordLimit:R,isWordNumberLegal:E,editor:a,userMeta:r,emoji:w,emojiTabIndex:y,showEmoji:b,gifData:x,showGif:k,canUploadImage:O,previewText:S,showPreview:C,inputRefs:c,editorRef:u,emojiButtonRef:p,emojiPopupRef:v,gifButtonRef:g,gifPopupRef:h,imageUploadRef:d,gifSearchInputRef:f}}}),Ct={class:"wl-comment"},$t={key:0,class:"wl-login-info"},It={class:"wl-avatar"},Lt=["title"],St=["src"],jt=["textContent"],xt={class:"wl-panel"},Rt=["for","textContent"],Et=["id","name","type","onUpdate:modelValue"],At=["placeholder"],Ut={class:"wl-preview"},zt=k("hr",null,null,-1),Mt=["innerHTML"],Ot={class:"wl-footer"},Tt={class:"wl-actions"},Pt={href:"https://guides.github.com/features/mastering-markdown/",title:"Markdown Guide","aria-label":"Markdown is supported",class:"wl-action",target:"_blank",rel:"noreferrer"},Nt=["title"],Ht=["title"],Vt=["title"],_t=["title"],Ft={class:"wl-info"},Bt={class:"wl-text-number"},Dt={key:0},Wt=z(" / "),Gt=["textContent"],qt=["textContent"],Jt=["disabled"],Kt=["placeholder"],Yt={key:0,class:"wl-loading"},Zt={key:0,class:"wl-tab-wrapper"},Xt=["title","onClick"],Qt=["src","alt"],en={key:0,class:"wl-tabs"},tn=["onClick"],nn=["src","alt","title"],ln=["title"];var on=ft(kt,[["render",function(e,t,n,l,o,a){const r=p("CloseIcon"),i=p("MarkdownIcon"),s=p("EmojiIcon"),c=p("GifIcon"),u=p("ImageIcon"),m=p("PreviewIcon"),d=p("LoadingIcon"),h=p("ImageWall");return v(),g("div",Ct,["disable"!==e.config.login&&e.isLogin?(v(),g("div",$t,[k("div",It,[k("button",{class:"wl-logout-btn",title:e.locale.logout,onClick:t[0]||(t[0]=(...t)=>e.onLogout&&e.onLogout(...t))},[S(r,{size:14})],8,Lt),k("img",{src:e.userInfo.avatar,alt:"avatar"},null,8,St)]),k("a",{href:"#",class:"wl-login-nick","aria-label":"Profile",onClick:t[1]||(t[1]=(...t)=>e.onProfile&&e.onProfile(...t)),textContent:j(e.userInfo.display_name)},null,8,jt)])):b("v-if",!0),k("div",xt,["force"!==e.config.login&&e.config.meta.length&&!e.isLogin?(v(),g("div",{key:0,class:x(["wl-header",`item${e.config.meta.length}`])},[(v(!0),g(f,null,w(e.config.meta,(t=>(v(),g("div",{class:"wl-header-item",key:t},[k("label",{for:t,textContent:j(e.locale[t]+(e.config.requiredMeta.includes(t)||!e.config.requiredMeta.length?"":`(${e.locale.optional})`))},null,8,Rt),R(k("input",{ref_for:!0,ref:n=>{n&&(e.inputRefs[t]=n)},id:`wl-${t}`,class:x(["wl-input",`wl-${t}`]),name:t,type:"mail"===t?"email":"text","onUpdate:modelValue":n=>e.userMeta[t]=n},null,10,Et),[[E,e.userMeta[t]]])])))),128))],2)):b("v-if",!0),R(k("textarea",{class:"wl-editor",ref:"editorRef",id:"wl-edit",placeholder:e.replyUser?`@${e.replyUser}`:e.locale.placeholder,"onUpdate:modelValue":t[2]||(t[2]=t=>e.editor=t),onKeydown:t[3]||(t[3]=(...t)=>e.onKeyDown&&e.onKeyDown(...t)),onDrop:t[4]||(t[4]=(...t)=>e.onDrop&&e.onDrop(...t)),onPaste:t[5]||(t[5]=(...t)=>e.onPaste&&e.onPaste(...t))},null,40,At),[[A,e.editor]]),R(k("div",Ut,[zt,k("h4",null,j(e.locale.preview)+":",1),k("div",{class:"wl-content",innerHTML:e.previewText},null,8,Mt)],512),[[U,e.showPreview]]),k("div",Ot,[k("div",Tt,[k("a",Pt,[S(i)]),R(k("button",{ref:"emojiButtonRef",class:x(["wl-action",{actived:e.showEmoji}]),title:e.locale.emoji,onClick:t[6]||(t[6]=t=>e.showEmoji=!e.showEmoji)},[S(s)],10,Nt),[[U,e.emoji.tabs.length]]),e.config.search?(v(),g("button",{key:0,ref:"gifButtonRef",class:x(["wl-action",{actived:e.showGif}]),title:e.locale.gif,onClick:t[7]||(t[7]=t=>e.showGif=!e.showGif)},[S(c)],10,Ht)):b("v-if",!0),k("input",{ref:"imageUploadRef",class:"upload",id:"wl-image-upload",type:"file",accept:".png,.jpg,.jpeg,.webp,.bmp,.gif",onChange:t[8]||(t[8]=(...t)=>e.onChange&&e.onChange(...t))},null,544),e.canUploadImage?(v(),g("label",{key:1,for:"wl-image-upload",class:"wl-action",title:e.locale.uploadImage},[S(u)],8,Vt)):b("v-if",!0),k("button",{class:x(["wl-action",{actived:e.showPreview}]),title:e.locale.preview,onClick:t[9]||(t[9]=t=>e.showPreview=!e.showPreview)},[S(m)],10,_t)]),k("div",Ft,[k("div",Bt,[z(j(e.wordNumber)+" ",1),e.config.wordLimit?(v(),g("span",Dt,[Wt,k("span",{class:x({illegal:!e.isWordNumberLegal}),textContent:j(e.wordLimit)},null,10,Gt)])):b("v-if",!0),z(" "+j(e.locale.word),1)]),"disable"===e.config.login||e.isLogin?b("v-if",!0):(v(),g("button",{key:0,class:"wl-btn",onClick:t[10]||(t[10]=(...t)=>e.onLogin&&e.onLogin(...t)),textContent:j(e.locale.login)},null,8,qt)),"force"!==e.config.login||e.isLogin?(v(),g("button",{key:1,class:"wl-btn primary",title:"Cmd|Ctrl + Enter",disabled:e.isSubmitting,onClick:t[11]||(t[11]=(...t)=>e.submitComment&&e.submitComment(...t))},[e.isSubmitting?(v(),y(d,{key:0,size:16})):(v(),g(f,{key:1},[z(j(e.locale.submit),1)],64))],8,Jt)):b("v-if",!0)]),k("div",{ref:"gifPopupRef",class:x(["wl-gif-popup",{display:e.showGif}])},[k("input",{type:"text",placeholder:e.locale.gifSearchPlaceholder,ref:"gifSearchInputRef",onInput:t[12]||(t[12]=(...t)=>e.onGifSearch&&e.onGifSearch(...t))},null,40,Kt),S(h,{items:e.gifData.list,"column-width":200,gap:6,onInsert:t[13]||(t[13]=t=>e.insert(t)),onScroll:e.onImageWallScroll},null,8,["items","onScroll"]),e.gifData.loading?(v(),g("div",Yt,[S(d,{size:30})])):b("v-if",!0)],2),k("div",{ref:"emojiPopupRef",class:x(["wl-emoji-popup",{display:e.showEmoji}])},[(v(!0),g(f,null,w(e.emoji.tabs,((t,n)=>(v(),g(f,{key:t.name},[n===e.emojiTabIndex?(v(),g("div",Zt,[(v(!0),g(f,null,w(t.items,(t=>(v(),g("button",{key:t,title:t,onClick:n=>e.insert(`:${t}:`)},[e.showEmoji?(v(),g("img",{key:0,class:"wl-emoji",src:e.emoji.map[t],alt:t,loading:"lazy",referrerPolicy:"no-referrer"},null,8,Qt)):b("v-if",!0)],8,Xt)))),128))])):b("v-if",!0)],64)))),128)),e.emoji.tabs.length>1?(v(),g("div",en,[(v(!0),g(f,null,w(e.emoji.tabs,((t,n)=>(v(),g("button",{key:t.name,class:x(["wl-tab",{active:e.emojiTabIndex===n}]),onClick:t=>e.emojiTabIndex=n},[k("img",{class:"wl-emoji",src:t.icon,alt:t.name,title:t.name,loading:"lazy",referrerPolicy:"no-referrer"},null,8,nn)],10,tn)))),128))])):b("v-if",!0)],2)])]),e.replyId?(v(),g("button",{key:1,class:"wl-close",title:e.locale.cancelReply,onClick:t[14]||(t[14]=t=>e.$emit("cancel-reply"))},[S(r,{size:24})],8,ln)):b("v-if",!0)])}],["__file","CommentBox.vue"]]);const an=["approved","waiting","spam"],rn=u({props:{comment:{type:Object,required:!0},rootId:{type:String,required:!0},reply:{type:Object}},components:{CommentBox:on,DeleteIcon:()=>c("svg",{viewBox:"0 0 1024 1024",width:"24",height:"24"},c("path",{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",fill:"red"})),LikeIcon:({active:e=!1})=>c("svg",{viewBox:"0 0 1024 1024",width:"24",height:"24"},[c("path",{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"+(e?"":"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"),fill:e?"red":"currentColor"})]),ReplyIcon:()=>c("svg",{viewBox:"0 0 1024 1024",width:"24",height:"24"},c("path",{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",fill:"currentColor"})),VerifiedIcon:()=>c("svg",{class:"verified-icon",viewBox:"0 0 1024 1024",width:"14",height:"14"},c("path",{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",fill:"#27ae60"}))},emits:["submit","reply","like","delete","status","sticky"],setup(e){const t=$("config"),n=vt(),l=dt(),o=s((()=>t.value.locale)),a=s((()=>{let{link:t}=e.comment;return t?_e(t)?t:`https://${t}`:""})),r=s((()=>n.value.includes(e.comment.objectId))),i=((e,t)=>{const n=Pe();return s((()=>qe(e,n.value,t)))})(e.comment.insertedAt,o.value),c=s((()=>"administrator"===l.value.type)),u=s((()=>e.comment.user_id&&l.value.objectId===e.comment.user_id)),m=s((()=>e.comment.objectId===e.reply?.objectId));return{config:t,locale:o,isReplyingCurrent:m,link:a,like:r,time:i,isAdmin:c,isOwner:u,commentStatus:an}}}),sn=["id"],cn={class:"wl-user","aria-hidden":"true"},un=["src"],mn={class:"wl-card"},dn={class:"wl-head"},pn=["href"],vn={key:1,class:"wl-nick"},gn=["textContent"],hn=["textContent"],fn=["textContent"],wn=["textContent"],yn=["textContent"],bn={class:"wl-comment-actions"},kn=["title"],Cn=["textContent"],$n=["title"],In={class:"wl-meta","aria-hidden":"true"},Ln=["textContent"],Sn=["textContent"],jn=["textContent"],xn=["innerHTML"],Rn={key:0,class:"wl-admin-actions"},En={class:"wl-comment-status"},An=["disabled","onClick","textContent"],Un={key:1,class:"wl-reply-wrapper"},zn={key:2,class:"wl-quote"};const Mn=u({name:"WalineRoot",components:{CommentBox:on,CommentCard:ft(rn,[["render",function(e,t,n,l,o,a){const r=p("VerifiedIcon"),i=p("DeleteIcon"),s=p("LikeIcon"),c=p("ReplyIcon"),u=p("CommentBox"),m=p("CommentCard",!0);return v(),g("div",{class:"wl-item",id:e.comment.objectId},[k("div",cn,[e.comment.avatar?(v(),g("img",{key:0,src:e.comment.avatar},null,8,un)):b("v-if",!0),e.comment.type?(v(),y(r,{key:1})):b("v-if",!0)]),k("div",mn,[k("div",dn,[e.link?(v(),g("a",{key:0,class:"wl-nick",href:e.link,target:"_blank",rel:"nofollow noreferrer"},j(e.comment.nick),9,pn)):(v(),g("span",vn,j(e.comment.nick),1)),"administrator"===e.comment.type?(v(),g("span",{key:2,class:"wl-badge",textContent:j(e.locale.admin)},null,8,gn)):b("v-if",!0),e.comment.label?(v(),g("span",{key:3,class:"wl-badge",textContent:j(e.comment.label)},null,8,hn)):b("v-if",!0),e.comment.sticky?(v(),g("span",{key:4,class:"wl-badge",textContent:j(e.locale.sticky)},null,8,fn)):b("v-if",!0),void 0!==e.comment.level&&e.comment.level>=0?(v(),g("span",{key:5,class:x(`wl-badge level${e.comment.level}`),textContent:j(e.locale[`level${e.comment.level}`]||`Level ${e.comment.level}`)},null,10,wn)):b("v-if",!0),k("span",{class:"wl-time",textContent:j(e.time)},null,8,yn),k("div",bn,[e.isAdmin||e.isOwner?(v(),g("button",{key:0,class:"wl-delete",onClick:t[0]||(t[0]=t=>e.$emit("delete",e.comment))},[S(i)])):b("v-if",!0),k("button",{class:"wl-like",onClick:t[1]||(t[1]=t=>e.$emit("like",e.comment)),title:e.like?e.locale.cancelLike:e.locale.like},[S(s,{active:e.like},null,8,["active"]),"like"in e.comment?(v(),g("span",{key:0,textContent:j(e.comment.like)},null,8,Cn)):b("v-if",!0)],8,kn),k("button",{class:x(["wl-reply",{active:e.isReplyingCurrent}]),title:e.isReplyingCurrent?e.locale.cancelReply:e.locale.reply,onClick:t[2]||(t[2]=t=>e.$emit("reply",e.isReplyingCurrent?null:e.comment))},[S(c)],10,$n)])]),k("div",In,[e.comment.addr?(v(),g("span",{key:0,textContent:j(e.comment.addr)},null,8,Ln)):b("v-if",!0),e.comment.browser?(v(),g("span",{key:1,textContent:j(e.comment.browser)},null,8,Sn)):b("v-if",!0),e.comment.os?(v(),g("span",{key:2,textContent:j(e.comment.os)},null,8,jn)):b("v-if",!0)]),k("div",{class:"wl-content",innerHTML:e.comment.comment},null,8,xn),e.isAdmin?(v(),g("div",Rn,[k("span",En,[(v(!0),g(f,null,w(e.commentStatus,(t=>(v(),g("button",{key:t,class:x(`wl-btn wl-${t}`),disabled:e.comment.status===t,onClick:n=>e.$emit("status",{status:t,comment:e.comment}),textContent:j(t)},null,10,An)))),128))]),e.isAdmin&&!e.comment.rid?(v(),g("button",{key:0,class:"wl-btn wl-sticky",onClick:t[3]||(t[3]=t=>e.$emit("sticky",e.comment))},j(e.comment.sticky?"unsticky":"sticky"),1)):b("v-if",!0)])):b("v-if",!0),e.isReplyingCurrent?(v(),g("div",Un,[S(u,{replyId:e.comment.objectId,replyUser:e.comment.nick,rootId:e.rootId,onSubmit:t[4]||(t[4]=t=>e.$emit("submit",t)),onCancelReply:t[5]||(t[5]=t=>e.$emit("reply",null))},null,8,["replyId","replyUser","rootId"])])):b("v-if",!0),e.comment.children?(v(),g("div",zn,[(v(!0),g(f,null,w(e.comment.children,(n=>(v(),y(m,{key:n.objectId,comment:n,reply:e.reply,rootId:e.rootId,onReply:t[6]||(t[6]=t=>e.$emit("reply",t)),onSubmit:t[7]||(t[7]=t=>e.$emit("submit",t)),onLike:t[8]||(t[8]=t=>e.$emit("like",t)),onDelete:t[9]||(t[9]=t=>e.$emit("delete",t)),onStatus:t[10]||(t[10]=t=>e.$emit("status",t)),onSticky:t[11]||(t[11]=t=>e.$emit("sticky",t))},null,8,["comment","reply","rootId"])))),128))])):b("v-if",!0)])],8,sn)}],["__file","CommentCard.vue"]]),LoadingIcon:ht},props:["serverURL","path","meta","requiredMeta","dark","lang","locale","pageSize","wordLimit","emoji","login","highlighter","texRenderer","imageUploader","copyright"],setup(e){const t=s((()=>(({serverURL:e,path:t=location.pathname,lang:n="zh-CN",locale:l,emoji:o=["//unpkg.com/@waline/emojis@1.0.1/weibo"],meta:a=["nick","mail","link"],requiredMeta:r=[],dark:i=!1,pageSize:s=10,wordLimit:c,imageUploader:u,highlighter:m,texRenderer:d,copyright:p=!0,login:v="enable",search:g=B(),...h})=>({serverURL:Fe(e),path:He(t),locale:{...ne[n]||ne["zh-CN"],..."object"==typeof l?l:{}},wordLimit:Be(c),meta:V(a),requiredMeta:V(r),imageUploader:De(u,_),highlighter:De(m,q),texRenderer:De(d,F),lang:n,dark:i,emoji:o,pageSize:s,login:v,copyright:p,search:g,...h}))(e))),o=dt(),a=vt(),i=l("loading"),c=l(0),u=l(1),d=l(0),p=l([]),v=l(null),g=s((()=>{return"string"==typeof(e=t.value.dark)?"auto"===e?`@media(prefers-color-scheme:dark){body${We}}`:`${e}${We}`:!0===e?`:root${We}`:"";var e}));let h;!function(e,t={}){const o=l(!1),{document:a=$e,immediate:i=!0,manual:s=!1,id:c="vueuse_styletag_"+ ++Ne}=t,u=l(e);let m=()=>{};const d=()=>{if(!a)return;const e=a.getElementById(c)||a.createElement("style");e.type="text/css",e.id=c,t.media&&(e.media=t.media),a.head.appendChild(e),o.value||(m=n(u,(t=>{e.innerText=t}),{immediate:!0}),o.value=!0)},p=()=>{a&&o.value&&(m(),a.head.removeChild(a.getElementById(c)),o.value=!1)};i&&!s&&d(),s||le(p),r(o)}(g);const f=e=>{const{serverURL:n,path:l,pageSize:a}=t.value,r=new AbortController;i.value="loading",h?.(),(({serverURL:e,lang:t,path:n,page:l,pageSize:o,signal:a,token:r})=>{const i={};return r&&(i.Authorization=`Bearer ${r}`),fetch(`${e}/comment?path=${encodeURIComponent(n)}&pageSize=${o}&page=${l}&lang=${t}`,{signal:a,headers:i}).then((e=>e.json())).then((e=>Xe(e,"comment list")))})({serverURL:n,lang:t.value.lang,path:l,pageSize:a,page:e,signal:r.signal,token:o.value?.token}).then((t=>{i.value="success",c.value=t.count,p.value.push(...t.data),u.value=e,d.value=t.totalPages})).catch((e=>{"AbortError"!==e.name&&(console.error(e.message),i.value="error")})),h=r.abort.bind(r)},w=()=>{c.value=0,p.value=[],f(1)};return M("config",t),n((()=>e.path),w),m((()=>w())),{config:t,darkmodeStyle:g,i18n:s((()=>t.value.locale)),status:i,count:c,page:u,totalPages:d,data:p,reply:v,loadMore:()=>f(u.value+1),refresh:w,onReply:e=>{v.value=e},onSubmit:e=>{if(e.rid){const t=p.value.find((({objectId:t})=>t===e.rid));if(!t)return;Array.isArray(t.children)||(t.children=[]),t.children.push(e)}else p.value.unshift(e)},onStatusChange:async({comment:e,status:n})=>{if(e.status===n)return;const{serverURL:l,lang:a}=t.value;await Qe({serverURL:l,lang:a,token:o.value?.token,objectId:e.objectId,status:n}),e.status=n},onDelete:async({objectId:e})=>{if(!confirm("Are you sure you want to delete this comment?"))return;const{serverURL:n,lang:l}=t.value;await(({serverURL:e,lang:t,token:n,objectId:l})=>fetch(`${e}/comment/${l}?lang=${t}`,{method:"DELETE",headers:{Authorization:`Bearer ${n}`}}).then((e=>e.json())))({serverURL:n,lang:l,token:o.value?.token,objectId:e}),p.value.some(((t,n)=>t.objectId===e?(p.value=p.value.filter(((e,t)=>t!==n)),!0):t.children.some(((l,o)=>l.objectId===e&&(p.value[n].children=t.children.filter(((e,t)=>t!==o)),!0)))))},onSticky:async e=>{if(e.rid)return;const{serverURL:n,lang:l}=t.value;await Qe({serverURL:n,lang:l,token:o.value?.token,objectId:e.objectId,sticky:e.sticky?0:1}),e.sticky=!e.sticky},onLike:async e=>{const{serverURL:n,lang:l}=t.value,{objectId:o}=e,r=a.value.includes(o);await(({serverURL:e,lang:t,objectId:n,like:l})=>fetch(`${e}/comment/${n}?lang=${t}`,{method:"PUT",headers:Ze,body:JSON.stringify({like:l})}).then((e=>e.json())))({serverURL:n,lang:l,objectId:o,like:!r}),r?a.value=a.value.filter((e=>e!==o)):(a.value=[...a.value,o],a.value.length>50&&(a.value=a.value.slice(-50))),e.like=(e.like||0)+(r?-1:1)},version:"2.6.1"}}}),On={"data-waline":""},Tn={class:"wl-count"},Pn=["textContent"],Nn={class:"wl-cards"},Hn={key:1,class:"wl-operation"},Vn=["textContent"],_n={key:0,class:"wl-loading"},Fn=["textContent"],Bn={class:"wl-operation"},Dn=["textContent"],Wn={key:3,class:"wl-power"},Gn=z(" Powered by "),qn=k("a",{href:"https://github.com/walinejs/waline",target:"_blank",rel:"noreferrer"}," Waline ",-1);var Jn=ft(Mn,[["render",function(e,t,n,l,o,a){const r=p("CommentBox"),i=p("CommentCard"),s=p("LoadingIcon");return v(),g("div",On,[e.reply?b("v-if",!0):(v(),y(r,{key:0,onSubmit:e.onSubmit},null,8,["onSubmit"])),k("div",Tn,[e.count?(v(),g("span",{key:0,class:"wl-num",textContent:j(e.count)},null,8,Pn)):b("v-if",!0),z(" "+j(e.i18n.comment),1)]),k("div",Nn,[(v(!0),g(f,null,w(e.data,(t=>(v(),y(i,{key:t.objectId,"root-id":t.objectId,comment:t,reply:e.reply,onReply:e.onReply,onSubmit:e.onSubmit,onStatus:e.onStatusChange,onDelete:e.onDelete,onSticky:e.onSticky,onLike:e.onLike},null,8,["root-id","comment","reply","onReply","onSubmit","onStatus","onDelete","onSticky","onLike"])))),128))]),"error"===e.status?(v(),g("div",Hn,[k("button",{type:"button",class:"wl-btn",onClick:t[0]||(t[0]=(...t)=>e.refresh&&e.refresh(...t)),textContent:j(e.i18n.refresh)},null,8,Vn)])):(v(),g(f,{key:2},["loading"===e.status?(v(),g("div",_n,[S(s,{size:30})])):e.data.length?e.page<e.totalPages?(v(),g(f,{key:2},[b(" Load more button "),k("div",Bn,[k("button",{type:"button",class:"wl-btn",onClick:t[1]||(t[1]=(...t)=>e.loadMore&&e.loadMore(...t)),textContent:j(e.i18n.more)},null,8,Dn)])],2112)):b("v-if",!0):(v(),g("div",{key:1,class:"wl-empty",textContent:j(e.i18n.sofa)},null,8,Fn))],64)),b(" Copyright Information "),e.config.copyright?(v(),g("div",Wn,[Gn,qn,z(" v"+j(e.version),1)])):b("v-if",!0)])}],["__file","Waline.vue"]]);const Kn=(e,t)=>{t.forEach(((t,n)=>{t.innerText=e[n].toString()}))},Yn=({serverURL:e,path:t=window.location.pathname,selector:n=".waline-pageview-count",update:l=!0,lang:o="zh-CN"})=>{const a=new AbortController,r=Array.from(document.querySelectorAll(n)),i=e=>{const n=ut(e);return null!==n&&t!==n},s=n=>et({serverURL:Fe(e),paths:n.map((e=>ut(e)||t)),lang:o,signal:a.signal}).then((e=>Kn(e,n))).catch(Ye);if(l){const n=r.filter((e=>!i(e))),l=r.filter(i);tt({serverURL:Fe(e),path:t,lang:o}).then((e=>Kn(new Array(n.length).fill(e),n))),l.length&&s(l)}else s(r);return a.abort.bind(a)},Zn=({el:e="#waline",path:t=window.location.pathname,comment:n=!1,pageview:l=!1,...o})=>{const a=e?nt(e):null;if(e&&!a)throw new Error("Option 'el' do not match any domElement!");if(!o.serverURL)throw new Error("Option 'serverURL' is missing!");const r=I({...o}),i=I({comment:n,pageview:l,path:t}),s=a?O((()=>c(Jn,{path:i.path,...r}))):null;s&&s.mount(a);const u=T((()=>{i.comment&>({serverURL:r.serverURL,path:i.path,selector:"string"==typeof i.comment?i.comment:void 0})})),m=T((()=>{i.pageview&&Yn({serverURL:r.serverURL,path:i.path,selector:"string"==typeof i.pageview?i.pageview:void 0})}));return{el:a,update:({comment:e,pageview:t,path:n=window.location.pathname,...l}={})=>{Object.entries(l).forEach((([e,t])=>{r[e]=t})),i.path=n,void 0!==e&&(i.comment=e),void 0!==t&&(i.pageview=t)},destroy:()=>{s?.unmount(),u(),m()}}},Xn="2.6.1",Qn=({el:e,serverURL:t,count:n,lang:l="zh-CN"})=>{const o=dt(),a=nt(e),r=new AbortController;return(({serverURL:e,lang:t,count:n,signal:l,token:o})=>{const a={};return o&&(a.Authorization=`Bearer ${o}`),fetch(`${e}/comment?type=recent&count=${n}&lang=${t}`,{signal:l,headers:a}).then((e=>e.json())).then((e=>Xe(e,"recent comment")))})({serverURL:t,count:n,lang:l,signal:r.signal,token:o.value?.token}).then((e=>a&&e.length?(a.innerHTML=`<ul class="wl-recent-list">${e.map((e=>`<li class="wl-recent-item"><a href="${e.url}">${e.nick}</a>:${e.comment}</li>`)).join("")}</ul>`,{comments:e,destroy:()=>{r.abort(),a.innerHTML=""}}):{comments:e,destroy:()=>r.abort()}))};export{Qn as RecentComments,gt as commentCount,ne as defaultLocales,Zn as init,Yn as pageviewCount,Xn as version};
|
|
2
2
|
//# sourceMappingURL=shim.esm.js.map
|