@waline/client 2.5.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/LICENSE +339 -0
- package/dist/component.esm.js +1 -1
- package/dist/component.esm.js.map +1 -1
- package/dist/component.js +1 -1
- package/dist/component.js.map +1 -1
- package/dist/legacy.d.ts +40 -0
- package/dist/legacy.js +1 -1
- package/dist/legacy.js.map +1 -1
- package/dist/pageview.cjs.js +1 -1
- package/dist/pageview.cjs.js.map +1 -1
- package/dist/pageview.esm.js +1 -1
- package/dist/pageview.esm.js.map +1 -1
- package/dist/pageview.js +1 -1
- package/dist/pageview.js.map +1 -1
- package/dist/shim.d.ts +41 -1
- package/dist/shim.esm.d.ts +41 -1
- package/dist/shim.esm.js +1 -1
- package/dist/shim.esm.js.map +1 -1
- package/dist/shim.js +1 -1
- package/dist/shim.js.map +1 -1
- package/dist/waline.cjs.d.ts +41 -1
- package/dist/waline.cjs.js +1 -1
- package/dist/waline.cjs.js.map +1 -1
- package/dist/waline.css +1 -1
- package/dist/waline.css.map +1 -1
- package/dist/waline.d.ts +41 -1
- package/dist/waline.esm.d.ts +41 -1
- package/dist/waline.esm.js +1 -1
- package/dist/waline.esm.js.map +1 -1
- package/dist/waline.js +1 -1
- package/dist/waline.js.map +1 -1
- package/package.json +31 -33
- package/src/comment.ts +7 -2
- package/src/components/CommentBox.vue +57 -63
- package/src/components/CommentCard.vue +1 -1
- package/src/components/ImageWall.vue +166 -0
- package/src/composables/like.ts +1 -1
- package/src/config/default.ts +91 -1
- package/src/init.ts +2 -10
- package/src/pageview.ts +7 -2
- package/src/styles/emoji.scss +112 -94
- package/src/styles/gif.scss +58 -139
- package/src/styles/index.scss +3 -0
- package/src/styles/panel.scss +0 -6
- package/src/typings/base.ts +40 -0
- package/src/typings/waline.ts +8 -0
- package/src/utils/config.ts +5 -2
- package/src/utils/index.ts +0 -2
- package/src/utils/fetchGif.ts +0 -62
- package/src/utils/throttle.ts +0 -16
package/dist/shim.esm.js
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import{getCurrentScope as e,onScopeDispose as t,watch as n,ref as o,unref as l,isRef as a,readonly as i,shallowRef as r,computed as s,defineComponent as c,toRefs as u,onMounted as m,onBeforeUnmount as d,openBlock as v,createElementBlock as p,normalizeStyle as g,Fragment as f,renderList as h,renderSlot as w,createTextVNode as y,toDisplayString as b,nextTick as k,h as C,inject as $,onUnmounted as I,resolveComponent as L,createElementVNode as x,createVNode as S,createCommentVNode as j,normalizeClass as R,withDirectives as E,vModelDynamic as A,vModelText as U,vShow as z,createBlock as M,withCtx as O,provide as P,reactive as T,createApp as H,watchEffect as N}from"vue";import V from"autosize";import{marked as _}from"marked";const B=["nick","mail","link"],F=e=>e.filter((e=>B.includes(e))),D=e=>new Promise(((t,n)=>{const o=new FileReader;o.readAsDataURL(e),o.onload=()=>t(o.result?.toString()||""),o.onerror=n})),W=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>',G=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"),q=["23AC69","91C132","F19726","E8552D","1AAB8E","E1147F","2980C1","1BA1E6","9FA0A0","F19726","E30B20","E30B20","A3338B"],J={},K=e=>{let t=0;return e.replace(G,((e,n,o)=>{if(o)return`<span style="color: slategray">${o}</span>`;if("<"===n)return"<";let l;J[n]?l=J[n]:(l=q[t],J[n]=l);const a=`<span style="color: #${l}">${n}</span>`;return t=++t%q.length,a}))},Y=["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"],Z=e=>Object.fromEntries(e.map(((e,t)=>[Y[t],e])));var X=Z(["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"]),Q=Z(["ニックネーム","3バイト以上のニックネームをご入力ください.","メールアドレス","メールアドレスをご確認ください.","サイト","オプション","ここにコメント","コメントしましょう~","提出する","Like","Cancel like","返信する","キャンセル","コメント","更新","さらに読み込む","プレビュー","絵文字","画像をアップロード","秒前","分前","時間前","日前","たっだ今","アップロード","ログインする","ログアウト","管理者","トップに置く","ワード","コメントは $0 から $1 ワードの間でなければなりません!\n 現在の単語番号: $2","匿名","うえにん","なかにん","しもおし","特にしもおし","かげ","なぬし","GIF","探す GIF"]),ee=Z(["昵称","昵称不能少于3个字符","邮箱","请填写正确的邮件地址","网址","可选","欢迎评论","来发评论吧~","提交","喜欢","取消喜欢","回复","取消回复","评论","刷新","加载更多...","预览","表情","上传图片","秒前","分钟前","小时前","天前","刚刚","正在上传","登录","退出","博主","置顶","字","评论字数应在 $0 到 $1 字之间!\n当前字数:$2","匿名","潜水","冒泡","吐槽","活跃","话痨","传说","表情包","搜索表情包"]),te=Z(["暱稱","郵箱","網址","可選","暱稱不能少於3個字元","請填寫正確的郵件地址","歡迎評論","來發評論吧~","提交","喜歡","取消喜歡","回覆","取消回覆","評論","刷新","載入更多...","預覽","表情","上傳圖片","秒前","分鐘前","小時前","天前","剛剛","正在上傳","登錄","退出","博主","置頂","字","評論字數應在 $0 到 $1 字之間!\n當前字數:$2","匿名","潛水","冒泡","吐槽","活躍","話癆","傳說","表情包","搜索表情包"]),ne=Z(["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"]),oe=Z(["Псевдоним","Никнейм не может быть меньше 3 байт.","Эл. адрес","Пожалуйста, подтвердите адрес вашей электронной почты.","Веб-сайт","Необязательный","Комментарий здесь...","Пока нет комментариев.","Отправить","Like","Cancel like","Отвечать","Отменить ответ","Комментарии","Обновить","Загрузи больше...","Превью","эмодзи","Загрузить изображение","секунд назад","несколько минут назад","несколько часов назад","дней назад","прямо сейчас","Загрузка","Авторизоваться","Выход из системы","Админ","Липкий","Слова","Пожалуйста, введите комментарии от $0 до $1 слов!\nНомер текущего слова: $2","Анонимный","Dwarves","Hobbits","Ents","Wizards","Elves","Maiar","GIF","Поиск GIF"]);const le={zh:ee,"zh-cn":ee,"zh-CN":ee,"zh-tw":te,"zh-TW":te,en:X,"en-US":X,"en-us":X,jp:Q,"jp-jp":Q,"jp-JP":Q,"pt-br":ne,"pt-BR":ne,ru:oe,"ru-ru":oe,"ru-RU":oe};function ae(n){return!!e()&&(t(n),!0)}const ie="undefined"!=typeof window,re=()=>{};const se=e=>e();var ce=Object.getOwnPropertySymbols,ue=Object.prototype.hasOwnProperty,me=Object.prototype.propertyIsEnumerable;function de(e,t,o={}){const l=o,{eventFilter:a=se}=l,i=((e,t)=>{var n={};for(var o in e)ue.call(e,o)&&t.indexOf(o)<0&&(n[o]=e[o]);if(null!=e&&ce)for(var o of ce(e))t.indexOf(o)<0&&me.call(e,o)&&(n[o]=e[o]);return n})(l,["eventFilter"]);return n(e,(r=a,s=t,function(...e){r((()=>s.apply(this,e)),{fn:s,thisArg:this,args:e})}),i);var r,s}var ve=Object.defineProperty,pe=Object.defineProperties,ge=Object.getOwnPropertyDescriptors,fe=Object.getOwnPropertySymbols,he=Object.prototype.hasOwnProperty,we=Object.prototype.propertyIsEnumerable,ye=(e,t,n)=>t in e?ve(e,t,{enumerable:!0,configurable:!0,writable:!0,value:n}):e[t]=n;function be(e,t,n={}){const l=n,{eventFilter:a}=l,i=((e,t)=>{var n={};for(var o in e)he.call(e,o)&&t.indexOf(o)<0&&(n[o]=e[o]);if(null!=e&&fe)for(var o of fe(e))t.indexOf(o)<0&&we.call(e,o)&&(n[o]=e[o]);return n})(l,["eventFilter"]),{eventFilter:r,pause:s,resume:c,isActive:u}=function(e=se){const t=o(!0);return{isActive:t,pause:function(){t.value=!1},resume:function(){t.value=!0},eventFilter:(...n)=>{t.value&&e(...n)}}}(a),m=de(e,t,(d=((e,t)=>{for(var n in t||(t={}))he.call(t,n)&&ye(e,n,t[n]);if(fe)for(var n of fe(t))we.call(t,n)&&ye(e,n,t[n]);return e})({},i),pe(d,ge({eventFilter:r}))));var d;return{stop:m,pause:s,resume:c,isActive:u}}const ke=ie?window:void 0,Ce=ie?window.document:void 0;function $e(...e){let t,o,a,i;if("string"==typeof e[0]?([o,a,i]=e,t=ke):[t,o,a,i]=e,!t)return re;let r=re;const s=n((()=>function(e){var t;const n=l(e);return null!=(t=null==n?void 0:n.$el)?t:n}(t)),(e=>{r(),e&&(e.addEventListener(o,a,i),r=()=>{e.removeEventListener(o,a,i),r=re})}),{immediate:!0,flush:"post"}),c=()=>{s(),r()};return ae(c),c}ie&&window.navigator,ie&&window.location;const Ie="undefined"!=typeof globalThis?globalThis:"undefined"!=typeof window?window:"undefined"!=typeof global?global:"undefined"!=typeof self?self:{},Le="__vueuse_ssr_handlers__";Ie[Le]=Ie[Le]||{};const xe=Ie[Le];const Se={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 je(e,t,n,a={}){var i;const{flush:s="pre",deep:c=!0,listenToStorageChanges:u=!0,writeDefaults:m=!0,shallow:d,window:v=ke,eventFilter:p,onError:g=(e=>{console.error(e)})}=a,f=(d?r:o)(t);if(!n)try{n=function(e,t){return xe[e]||t}("getDefaultStorage",(()=>{var e;return null==(e=ke)?void 0:e.localStorage}))()}catch(e){g(e)}if(!n)return f;const h=l(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"}(h),y=null!=(i=a.serializer)?i:Se[w],{pause:b,resume:k}=be(f,(()=>function(t){try{null==t?n.removeItem(e):n.setItem(e,y.write(t))}catch(e){g(e)}}(f.value)),{flush:s,deep:c,eventFilter:p});return v&&u&&$e(v,"storage",C),C(),f;function C(t){t&&t.key!==e||(f.value=function(t){if(!t||t.key===e){b();try{const o=t?t.newValue:n.getItem(e);return null==o?(m&&null!==h&&n.setItem(e,y.write(h)),h):"string"!=typeof o?o:y.read(o)}catch(e){g(e)}finally{k()}}}(t))}}var Re,Ee,Ae=Object.defineProperty,Ue=Object.getOwnPropertySymbols,ze=Object.prototype.hasOwnProperty,Me=Object.prototype.propertyIsEnumerable,Oe=(e,t,n)=>t in e?Ae(e,t,{enumerable:!0,configurable:!0,writable:!0,value:n}):e[t]=n;function Pe(e={}){const{controls:t=!1,interval:i="requestAnimationFrame"}=e,r=o(new Date),s=()=>r.value=new Date,c="requestAnimationFrame"===i?function(e,t={}){const{immediate:n=!0,window:l=ke}=t,a=o(!1);let i=null;function r(){a.value&&l&&(e(),i=l.requestAnimationFrame(r))}function s(){!a.value&&l&&(a.value=!0,r())}function c(){a.value=!1,null!=i&&l&&(l.cancelAnimationFrame(i),i=null)}return n&&s(),ae(c),{isActive:a,pause:c,resume:s}}(s,{immediate:!0}):function(e,t=1e3,i={}){const{immediate:r=!0,immediateCallback:s=!1}=i;let c=null;const u=o(!1);function m(){c&&(clearInterval(c),c=null)}function d(){u.value=!1,m()}function v(){t<=0||(u.value=!0,s&&e(),m(),c=setInterval(e,l(t)))}r&&ie&&v(),a(t)&&ae(n(t,(()=>{r&&ie&&v()})));return ae(d),{isActive:u,pause:d,resume:v}}(s,i,{immediate:!0});return t?((e,t)=>{for(var n in t||(t={}))ze.call(t,n)&&Oe(e,n,t[n]);if(Ue)for(var n of Ue(t))Me.call(t,n)&&Oe(e,n,t[n]);return e})({now:r},c):r}ie&&(null==window?void 0:window.navigator)&&(null==(Re=null==window?void 0:window.navigator)?void 0:Re.platform)&&/iP(ad|hone|od)/.test(null==(Ee=null==window?void 0:window.navigator)?void 0:Ee.platform);let Te=0;const He=e=>{try{e=decodeURI(e)}catch(e){}return e},Ne=(e="")=>e.replace(/\/$/u,""),Ve=e=>/^(https?:)?\/\//.test(e),_e=e=>{const t=Ne(e);return Ve(t)?t:`https://${t}`},Be=e=>Array.isArray(e)?e:!!e&&[0,e],Fe=(e,t)=>"function"==typeof e?e:!1!==e&&t,De="{--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}",We=(e,t)=>{let n=e.toString();for(;n.length<t;)n="0"+n;return n},Ge=(e,t,n)=>{if(!e)return"";const o="string"==typeof e?new Date(-1!==e.indexOf(" ")?e.replace(/-/g,"/"):e):e,l=t.getTime()-o.getTime(),a=Math.floor(l/864e5);if(0===a){const e=l%864e5,t=Math.floor(e/36e5);if(0===t){const t=e%36e5,o=Math.floor(t/6e4);if(0===o){const e=t%6e4;return`${Math.round(e/1e3)} ${n.seconds}`}return`${o} ${n.minutes}`}return`${t} ${n.hours}`}return a<0?n.now:a<8?`${a} ${n.days}`:(e=>{const t=We(e.getDate(),2),n=We(e.getMonth()+1,2);return`${We(e.getFullYear(),2)}-${n}-${t}`})(o)},qe=e=>{const t=je("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((o=>{const l={folder:e,...o};return n&&(t.value[e]=l),l}))},Je=(e,t="",n="",o="")=>`${t?`${t}/`:""}${n}${e}${o?`.${o}`:""}`,Ke=e=>{"AbortError"!==e.name&&console.error(e.message)},Ye={"Content-Type":"application/json"},Ze=(e,t="")=>{if("object"==typeof e&&e.errno)throw new TypeError(`Fetch ${t} failed with ${e.errno}: ${e.errmsg}`);return e},Xe=({serverURL:e,lang:t,token:n,objectId:o,...l})=>fetch(`${e}/comment/${o}?lang=${t}`,{method:"PUT",headers:{"Content-Type":"application/json",Authorization:`Bearer ${n}`},body:JSON.stringify(l)}).then((e=>e.json())),Qe=({serverURL:e,lang:t,paths:n,signal:o})=>fetch(`${e}/article?path=${encodeURIComponent(n.join(","))}&lang=${t}`,{signal:o}).then((e=>e.json())).then((e=>Ze(e,"visit count"))).then((e=>Array.isArray(e)?e:[e])),et=({serverURL:e,lang:t,path:n})=>fetch(`${e}/article?lang=${t}`,{method:"POST",headers:Ye,body:JSON.stringify({path:n})}).then((e=>e.json())).then((e=>Ze(e,"visit count"))),tt=e=>e instanceof HTMLElement?e:"string"==typeof e?document.querySelector(e):null,nt=e=>e.type.includes("image"),ot=e=>{const t=Array.from(e).find(nt);return t?t.getAsFile():null},lt=/\$.*?\$/,at=/^\$(.*?)\$/,it=/^(?:\s{0,3})\$\$((?:[^\n]|\n[^\n])+?)\n{0,1}\$\$/,rt=(e="",t={})=>e.replace(/:(.+?):/g,((e,n)=>t[n]?`<img class="wl-emoji" src="${t[n]}" alt="${n}">`:e)),st=(e,{emojiMap:t,highlighter:n,texRenderer:o})=>{if(_.setOptions({highlight:n||void 0,breaks:!0,smartLists:!0,smartypants:!0}),o){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(lt);return-1!==t?t:e.length},tokenizer(t){const n=at.exec(t);if(null!==n)return{type:"html",raw:n[0],text:e(!1,n[1])}}}])(o);_.use({extensions:e})}return _.parse(rt(e,t))},ct=e=>e.dataset.path||e.getAttribute("id"),ut=({key:e,keyword:t,pos:n,limit:o})=>{const l=new URLSearchParams("media_filter=minimal");return l.set("key",e||"PAY5JLFIH6V6"),l.set("limit",(o||20).toString()),l.set("pos",n||""),l.set("q",t),fetch(`https://g.tenor.com/v1/search?${l.toString()}`,{headers:{"Content-Type":"application/json"}}).then((e=>e.json()))};let mt=null;const dt=()=>mt||(mt=je("USER_KEY",{}));let vt=null;const pt=()=>vt||(vt=je("WALIKE_LIKE",[])),gt=({serverURL:e,path:t=window.location.pathname,selector:n=".waline-comment-count",lang:o="zh-CN"})=>{const l=new AbortController,a=document.querySelectorAll(n),i=dt();return a.length&&(({serverURL:e,lang:t,paths:n,signal:o,token:l})=>{const a={};return l&&(a.Authorization=`Bearer ${l}`),fetch(`${e}/comment?type=count&url=${encodeURIComponent(n.join(","))}&lang=${t}`,{signal:o,headers:a}).then((e=>e.json())).then((e=>Ze(e,"comment count"))).then((e=>Array.isArray(e)?e:[e]))})({serverURL:e,paths:Array.from(a).map((e=>He(e.dataset.path||e.getAttribute("id")||t))),lang:o,signal:l.signal,token:i.value?.token}).then((e=>{a.forEach(((t,n)=>{t.innerText=e[n].toString()}))})).catch(Ke),l.abort.bind(l)},ft=["data-index"],ht=c({props:{columnWidth:{default:400},items:null,gap:{default:0},rtl:{type:Boolean,default:!1},ssrColumns:{default:0}},emits:["redraw","redraw-skip"],setup(e,{emit:t}){const a=e,{columnWidth:i,items:r,gap:s,rtl:c,ssrColumns:C}=u(a),$=o([]),I=o();function L(){const e=Math.floor((I.value.getBoundingClientRect().width+s.value)/(i.value+s.value));return e>0?e:1}function x(e){return[...new Array(e)].map((()=>[]))}if(C.value>0){const e=x(C.value);r.value.forEach(((t,n)=>e[n%C.value].push(n))),$.value=e}async function S(e){if(e>=r.value.length)return;await k();const t=[...I.value.children];c.value&&t.reverse();const n=t.reduce(((e,t)=>t.getBoundingClientRect().height<e.getBoundingClientRect().height?t:e));$.value[+n.dataset.index].push(e),await S(e+1)}async function j(e=!1){if($.value.length===L()&&!e)return void t("redraw-skip");$.value=x(L());const n=window.scrollY;await S(0),window.scrollTo({top:n}),t("redraw")}const R=new ResizeObserver((()=>j()));return m((()=>{j(),R.observe(I.value)})),d((()=>R.unobserve(I.value))),n([r,c],(()=>j(!0))),n([i,s],(()=>j())),(e,t)=>(v(),p("div",{ref_key:"wall",ref:I,class:"masonry-wall",style:g({display:"flex",gap:`${l(s)}px`})},[(v(!0),p(f,null,h($.value,((t,n)=>(v(),p("div",{key:n,class:"masonry-column","data-index":n,style:g({display:"flex","flex-basis":0,"flex-direction":"column","flex-grow":1,height:["-webkit-max-content","-moz-max-content","max-content"],gap:`${l(s)}px`})},[(v(!0),p(f,null,h(t,(t=>(v(),p("div",{key:t,class:"masonry-item"},[w(e.$slots,"default",{item:l(r)[t],index:t},(()=>[y(b(l(r)[t]),1)]))])))),128))],12,ft)))),128))],4))}}),wt=(()=>{const e=ht;return e.install=t=>{t.component("MasonryWall",e)},e})(),yt=({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 bt=(e,t)=>{const n=e.__vccOpts||e;for(const[e,o]of t)n[e]=o;return n};const kt=c({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"})]),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:yt,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 l=$("config"),a=je("WALINE_COMMENT_BOX_EDITOR",""),i=je("WALINE_USER_META",{nick:"",mail:"",link:""}),r=dt(),c=o({}),u=o(null),d=o(null),v=o(null),p=o(null),g=o(null),f=o(null),h=o(null),w=o({tabs:[],map:{}}),y=o(0),b=o(!1),k=o(!1),C=o(!1),L=o(""),x=o(0),S=o({cursor:"",loading:!0,list:[]}),j=o(0),R=o(!1),E=o(""),A=o(!1),U=s((()=>l.value.locale)),z=s((()=>Boolean(r.value?.token))),M=s((()=>!1!==l.value.imageUploader)),O=e=>{const t=u.value,n=t.selectionStart,o=t.selectionEnd||0,l=t.scrollTop;a.value=t.value.substring(0,n)+e+t.value.substring(o,t.value.length),t.focus(),t.selectionStart=n+e.length,t.selectionEnd=n+e.length,t.scrollTop=l},P=e=>{const t=`![${l.value.locale.uploading} ${e.name}]()`;return O(t),Promise.resolve().then((()=>l.value.imageUploader(e))).then((n=>{a.value=a.value.replace(t,`\r\n`)}))},T=()=>{const{serverURL:n,lang:o,login:s,wordLimit:m,requiredMeta:d}=l.value,v={comment:E.value,nick:i.value.nick,mail:i.value.mail,link:i.value.link,ua:navigator.userAgent,url:l.value.path};if(r.value?.token)v.nick=r.value.display_name,v.mail=r.value.email,v.link=r.value.url;else{if("force"===s)return;if(d.indexOf("nick")>-1&&!v.nick)return c.value.nick?.focus(),alert(U.value.nickError);if(d.indexOf("mail")>-1&&!v.mail||v.mail&&!/^\w(?:[\w._-]*\w)?@(?:\w(?:[\w-]*\w)?\.)*\w+$/.exec(v.mail))return c.value.mail?.focus(),alert(U.value.mailError);if(!v.comment)return void u.value?.focus();v.nick||(v.nick=U.value.anonymous)}if(!R.value)return alert(U.value.wordHint.replace("$0",m[0].toString()).replace("$1",m[1].toString()).replace("$2",x.value.toString()));v.comment=rt(v.comment,w.value.map),e.replyId&&e.rootId&&(v.pid=e.replyId,v.rid=e.rootId,v.at=e.replyUser),A.value=!0,(({serverURL:e,lang:t,token:n,comment:o})=>{const l={"Content-Type":"application/json"};return n&&(l.Authorization=`Bearer ${n}`),fetch(`${e}/comment?lang=${t}`,{method:"POST",headers:l,body:JSON.stringify(o)}).then((e=>e.json()))})({serverURL:n,lang:o,token:r.value?.token,comment:v}).then((n=>{if(A.value=!1,n.errmsg)return alert(n.errmsg);t("submit",n.data),a.value="",L.value="",e.replyId&&t("cancel-reply")})).catch((e=>{A.value=!1,alert(e.message)}))},H=e=>{v.value.contains(e.target)||p.value.contains(e.target)||(b.value=!1),g.value.contains(e.target)||f.value.contains(e.target)||(k.value=!1)},N=function(e,t=300){let n;return(...o)=>{n&&clearTimeout(n),n=window.setTimeout((()=>{e(...o),n=null}),t)}}((async e=>{S.value.cursor="",S.value.list=[],_(e)})),_=async e=>{const{scrollTop:t,clientHeight:n,scrollHeight:o}=e.target;if((n+t)/o<.9||S.value.loading)return;S.value.loading=!0;const l=await ut({keyword:h.value?.value||"",pos:S.value.cursor}).finally((()=>{S.value.loading=!1}));S.value.cursor=l.next,S.value.list=S.value.list.concat(l.results),setTimeout((()=>{e.target.scrollTop=t}),50)};return n([l,x],(([e,t])=>{const{wordLimit:n}=e;n?t<n[0]&&0!==n[0]?(j.value=n[0],R.value=!1):t>n[1]?(j.value=n[1],R.value=!1):(j.value=n[1],R.value=!0):(j.value=0,R.value=!0)}),{immediate:!0}),n([k],(async([e])=>{if(!e)return;S.value.loading=!0;const t=await ut({keyword:""}).finally((()=>{S.value.loading=!1}));S.value.cursor=t.next,S.value.list=S.value.list.concat(t.results)})),m((()=>{document.body.addEventListener("click",H),n((()=>a.value),(e=>{const{highlighter:t,texRenderer:n}=l.value;E.value=e,L.value=st(e,{emojiMap:w.value.map,highlighter:t,texRenderer:n}),x.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?V(u.value):V.destroy(u.value)}),{immediate:!0}),n((()=>l.value.emoji),(e=>{return(t=Array.isArray(e)?e:[],Promise.all(t.map((e=>"string"==typeof e?qe(Ne(e)):Promise.resolve(e)))).then((e=>{const t={tabs:[],map:{}};return e.forEach((e=>{const{name:n,folder:o,icon:l,prefix:a,type:i,items:r}=e;t.tabs.push({name:n,icon:Je(l,o,a,i),items:r.map((e=>{const n=`${a||""}${e}`;return t.map[n]=Je(e,o,a,i),n}))})})),t}))).then((e=>{w.value=e}));var t}),{immediate:!0})})),I((()=>{document.body.removeEventListener("click",H)})),{config:l,locale:U,insert:O,onChange:()=>{const e=d.value;e.files&&M.value&&P(e.files[0]).then((()=>{e.value=""}))},onDrop:e=>{if(e.dataTransfer?.items){const t=ot(e.dataTransfer.items);t&&M.value&&(P(t),e.preventDefault())}},onKeyDown:e=>{const t=e.key;(e.ctrlKey||e.metaKey)&&"Enter"===t&&T()},onPaste:e=>{if(e.clipboardData){const t=ot(e.clipboardData.items);t&&M.value&&P(t)}},onLogin:e=>{e.preventDefault();const{lang:t,serverURL:n}=l.value,o=(window.innerWidth-450)/2,a=(window.innerHeight-450)/2,i=window.open(`${n}/ui/login?lng=${encodeURIComponent(t)}`,"_blank",`width=450,height=450,left=${o},top=${a},scrollbars=no,resizable=no,status=no,location=no,toolbar=no,menubar=no`);i?.postMessage({type:"TOKEN",data:null},"*");const s=({data:e})=>{e&&"userInfo"===e.type&&e.data.token&&(i?.close(),r.value=e.data,(e.data.remember?localStorage:sessionStorage).setItem("WALINE_USER",JSON.stringify(e.data)),window.removeEventListener("message",s))};window.addEventListener("message",s)},onLogout:()=>{r.value={},localStorage.setItem("WALINE_USER","null"),sessionStorage.setItem("WALINE_USER","null")},onProfile:e=>{e.preventDefault();const{lang:t,serverURL:n}=l.value,o=(window.innerWidth-800)/2,a=(window.innerHeight-800)/2;window.open(`${n}/ui/profile?lng=${encodeURIComponent(t)}`,"_blank",`width=800,height=800,left=${o},top=${a},scrollbars=no,resizable=no,status=no,location=no,toolbar=no,menubar=no`)?.postMessage({type:"TOKEN",data:r.value.token},"*");const i=({data:e})=>{e&&"profile"===e.type&&(r.value={...r.value,...e},[localStorage,sessionStorage].filter((e=>e.getItem("WALINE_USER"))).forEach((e=>e.setItem("WALINE_USER",JSON.stringify(r)))),window.removeEventListener("message",i))};window.addEventListener("message",i)},submitComment:T,onGifMasonryScroll:_,onGifSearch:N,isLogin:z,userInfo:r,isSubmitting:A,wordNumber:x,wordLimit:j,isWordNumberLegal:R,editor:a,userMeta:i,emoji:w,emojiTabIndex:y,showEmoji:b,showGif:k,canUploadImage:M,previewText:L,showPreview:C,inputRefs:c,editorRef:u,emojiButtonRef:v,emojiPopupRef:p,gifButtonRef:g,gifPopupRef:f,imageUploadRef:d,gifSearchInputRef:h,gifData:S}}}),Ct={class:"wl-comment"},$t={key:0,class:"wl-login-info"},It={class:"wl-avatar"},Lt=["title"],xt=["src"],St=["textContent"],jt={class:"wl-panel"},Rt=["for","textContent"],Et=["id","name","type","onUpdate:modelValue"],At=["placeholder"],Ut={class:"wl-preview"},zt=x("hr",null,null,-1),Mt=["innerHTML"],Ot={class:"wl-footer"},Pt={class:"wl-actions"},Tt={href:"https://guides.github.com/features/mastering-markdown/",title:"Markdown Guide","aria-label":"Markdown is supported",class:"wl-action",target:"_blank",rel:"noreferrer"},Ht=["title"],Nt=["title"],Vt=["title"],_t=["title"],Bt={class:"wl-info"},Ft={class:"wl-text-number"},Dt={key:0},Wt=y(" / "),Gt=["textContent"],qt=["textContent"],Jt=["disabled"],Kt=["placeholder"],Yt=["onClick","src","title"],Zt={key:0,class:"wl-loading"},Xt={key:0,class:"wl-tab-wrapper"},Qt=["title","onClick"],en=["src","alt"],tn={key:0,class:"wl-tabs"},nn=["onClick"],on=["src","alt","title"],ln=["title"];var an=bt(kt,[["render",function(e,t,n,o,l,a){const i=L("CloseIcon"),r=L("MarkdownIcon"),s=L("EmojiIcon"),c=L("GifIcon"),u=L("ImageIcon"),m=L("PreviewIcon"),d=L("LoadingIcon"),w=L("masonry-wall");return v(),p("div",Ct,["disable"!==e.config.login&&e.isLogin?(v(),p("div",$t,[x("div",It,[x("button",{class:"wl-logout-btn",title:e.locale.logout,onClick:t[0]||(t[0]=(...t)=>e.onLogout&&e.onLogout(...t))},[S(i,{size:14})],8,Lt),x("img",{src:e.userInfo.avatar,alt:"avatar"},null,8,xt)]),x("a",{href:"#",class:"wl-login-nick","aria-label":"Profile",onClick:t[1]||(t[1]=(...t)=>e.onProfile&&e.onProfile(...t)),textContent:b(e.userInfo.display_name)},null,8,St)])):j("v-if",!0),x("div",jt,["force"!==e.config.login&&e.config.meta.length&&!e.isLogin?(v(),p("div",{key:0,class:R(["wl-header",`item${e.config.meta.length}`])},[(v(!0),p(f,null,h(e.config.meta,(t=>(v(),p("div",{class:"wl-header-item",key:t},[x("label",{for:t,textContent:b(e.locale[t]+(e.config.requiredMeta.includes(t)||!e.config.requiredMeta.length?"":`(${e.locale.optional})`))},null,8,Rt),E(x("input",{ref_for:!0,ref:n=>{n&&(e.inputRefs[t]=n)},id:`wl-${t}`,class:R(["wl-input",`wl-${t}`]),name:t,type:"mail"===t?"email":"text","onUpdate:modelValue":n=>e.userMeta[t]=n},null,10,Et),[[A,e.userMeta[t]]])])))),128))],2)):j("v-if",!0),E(x("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),[[U,e.editor]]),E(x("div",Ut,[zt,x("h4",null,b(e.locale.preview)+":",1),x("div",{class:"wl-content",innerHTML:e.previewText},null,8,Mt)],512),[[z,e.showPreview]]),x("div",Ot,[x("div",Pt,[x("a",Tt,[S(r)]),E(x("button",{ref:"emojiButtonRef",class:R(["wl-action",{actived:e.showEmoji}]),title:e.locale.emoji,onClick:t[6]||(t[6]=t=>e.showEmoji=!e.showEmoji)},[S(s)],10,Ht),[[z,e.emoji.tabs.length]]),x("button",{ref:"gifButtonRef",class:R(["wl-action",{actived:e.showGif}]),title:e.locale.gif,onClick:t[7]||(t[7]=t=>e.showGif=!e.showGif)},[S(c)],10,Nt),x("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(),p("label",{key:0,for:"wl-image-upload",class:"wl-action",title:e.locale.uploadImage},[S(u)],8,Vt)):j("v-if",!0),x("button",{class:R(["wl-action",{actived:e.showPreview}]),title:e.locale.preview,onClick:t[9]||(t[9]=t=>e.showPreview=!e.showPreview)},[S(m)],10,_t)]),x("div",Bt,[x("div",Ft,[y(b(e.wordNumber)+" ",1),e.config.wordLimit?(v(),p("span",Dt,[Wt,x("span",{class:R({illegal:!e.isWordNumberLegal}),textContent:b(e.wordLimit)},null,10,Gt)])):j("v-if",!0),y(" "+b(e.locale.word),1)]),"disable"===e.config.login||e.isLogin?j("v-if",!0):(v(),p("button",{key:0,class:"wl-btn",onClick:t[10]||(t[10]=(...t)=>e.onLogin&&e.onLogin(...t)),textContent:b(e.locale.login)},null,8,qt)),"force"!==e.config.login||e.isLogin?(v(),p("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(),M(d,{key:0,size:16})):(v(),p(f,{key:1},[y(b(e.locale.submit),1)],2112))],8,Jt)):j("v-if",!0)]),x("div",{ref:"gifPopupRef",class:R(["wl-gif-popup",{display:e.showGif}])},[x("input",{type:"text",placeholder:e.locale.gifSearchPlaceholder,ref:"gifSearchInputRef",onInput:t[12]||(t[12]=(...t)=>e.onGifSearch&&e.onGifSearch(...t))},null,40,Kt),S(w,{class:"wl-gif-waterfall",items:e.gifData.list,"ssr-columns":2,"column-width":200,gap:6,onScroll:e.onGifMasonryScroll},{default:O((({item:t})=>[x("img",{onClick:n=>e.insert(``),src:t.media[0].tinygif.url,title:t.title,loading:"lazy",style:g({width:"200px",height:200*t.media[0].tinygif.dims[1]/t.media[0].tinygif.dims[0]+"px"})},null,12,Yt)])),_:1},8,["items","onScroll"]),e.gifData.loading?(v(),p("div",Zt,[S(d,{size:30})])):j("v-if",!0)],2),x("div",{ref:"emojiPopupRef",class:R(["wl-emoji-popup",{display:e.showEmoji}])},[(v(!0),p(f,null,h(e.emoji.tabs,((t,n)=>(v(),p(f,{key:t.name},[n===e.emojiTabIndex?(v(),p("div",Xt,[(v(!0),p(f,null,h(t.items,(t=>(v(),p("button",{key:t,title:t,onClick:n=>e.insert(`:${t}:`)},[e.showEmoji?(v(),p("img",{key:0,class:"wl-emoji",src:e.emoji.map[t],alt:t,loading:"lazy",referrerPolicy:"no-referrer"},null,8,en)):j("v-if",!0)],8,Qt)))),128))])):j("v-if",!0)],64)))),128)),e.emoji.tabs.length>1?(v(),p("div",tn,[(v(!0),p(f,null,h(e.emoji.tabs,((t,n)=>(v(),p("button",{key:t.name,class:R(["wl-tab",{active:e.emojiTabIndex===n}]),onClick:t=>e.emojiTabIndex=n},[x("img",{class:"wl-emoji",src:t.icon,alt:t.name,title:t.name,loading:"lazy",referrerPolicy:"no-referrer"},null,8,on)],10,nn)))),128))])):j("v-if",!0)],2)])]),e.replyId?(v(),p("button",{key:1,class:"wl-close",title:e.locale.cancelReply,onClick:t[13]||(t[13]=t=>e.$emit("cancel-reply"))},[S(i,{size:24})],8,ln)):j("v-if",!0)])}],["__file","CommentBox.vue"]]);const rn=["approved","waiting","spam"],sn=c({props:{comment:{type:Object,required:!0},rootId:{type:String,required:!0},reply:{type:Object}},components:{CommentBox:an,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=pt(),o=dt(),l=s((()=>t.value.locale)),a=s((()=>{let{link:t}=e.comment;return t?Ve(t)?t:`https://${t}`:""})),i=s((()=>n.value.includes(e.comment.objectId))),r=((e,t)=>{const n=Pe();return s((()=>Ge(e,n.value,t)))})(e.comment.insertedAt,l.value),c=s((()=>"administrator"===o.value.type)),u=s((()=>e.comment.user_id&&o.value.objectId===e.comment.user_id)),m=s((()=>e.comment.objectId===e.reply?.objectId));return{config:t,locale:l,isReplyingCurrent:m,link:a,like:i,time:r,isAdmin:c,isOwner:u,commentStatus:rn}}}),cn=["id"],un={class:"wl-user","aria-hidden":"true"},mn=["src"],dn={class:"wl-card"},vn={class:"wl-head"},pn=["href"],gn={key:1,class:"wl-nick"},fn=["textContent"],hn=["textContent"],wn=["textContent"],yn=["textContent"],bn=["textContent"],kn={class:"wl-comment-actions"},Cn=["title"],$n=["textContent"],In=["title"],Ln={class:"wl-meta","aria-hidden":"true"},xn=["textContent"],Sn=["textContent"],jn=["textContent"],Rn=["innerHTML"],En={key:0,class:"wl-admin-actions"},An={class:"wl-comment-status"},Un=["disabled","onClick","textContent"],zn={key:1,class:"wl-reply-wrapper"},Mn={key:2,class:"wl-quote"};const On=c({name:"WalineRoot",components:{CommentBox:an,CommentCard:bt(sn,[["render",function(e,t,n,o,l,a){const i=L("VerifiedIcon"),r=L("DeleteIcon"),s=L("LikeIcon"),c=L("ReplyIcon"),u=L("CommentBox"),m=L("CommentCard",!0);return v(),p("div",{class:"wl-item",id:e.comment.objectId},[x("div",un,[e.comment.avatar?(v(),p("img",{key:0,src:e.comment.avatar},null,8,mn)):j("v-if",!0),e.comment.type?(v(),M(i,{key:1})):j("v-if",!0)]),x("div",dn,[x("div",vn,[e.link?(v(),p("a",{key:0,class:"wl-nick",href:e.link,target:"_blank",rel:"nofollow noreferrer"},b(e.comment.nick),9,pn)):(v(),p("span",gn,b(e.comment.nick),1)),"administrator"===e.comment.type?(v(),p("span",{key:2,class:"wl-badge",textContent:b(e.locale.admin)},null,8,fn)):j("v-if",!0),e.comment.label?(v(),p("span",{key:3,class:"wl-badge",textContent:b(e.comment.label)},null,8,hn)):j("v-if",!0),e.comment.sticky?(v(),p("span",{key:4,class:"wl-badge",textContent:b(e.locale.sticky)},null,8,wn)):j("v-if",!0),e.comment.level&&e.comment.level>=0?(v(),p("span",{key:5,class:R(`wl-badge level${e.comment.level}`),textContent:b(e.locale[`level${e.comment.level}`]||`Level ${e.comment.level}`)},null,10,yn)):j("v-if",!0),x("span",{class:"wl-time",textContent:b(e.time)},null,8,bn),x("div",kn,[e.isAdmin||e.isOwner?(v(),p("button",{key:0,class:"wl-delete",onClick:t[0]||(t[0]=t=>e.$emit("delete",e.comment))},[S(r)])):j("v-if",!0),x("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(),p("span",{key:0,textContent:b(e.comment.like)},null,8,$n)):j("v-if",!0)],8,Cn),x("button",{class:R(["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,In)])]),x("div",Ln,[e.comment.addr?(v(),p("span",{key:0,textContent:b(e.comment.addr)},null,8,xn)):j("v-if",!0),e.comment.browser?(v(),p("span",{key:1,textContent:b(e.comment.browser)},null,8,Sn)):j("v-if",!0),e.comment.os?(v(),p("span",{key:2,textContent:b(e.comment.os)},null,8,jn)):j("v-if",!0)]),x("div",{class:"wl-content",innerHTML:e.comment.comment},null,8,Rn),e.isAdmin?(v(),p("div",En,[x("span",An,[(v(!0),p(f,null,h(e.commentStatus,(t=>(v(),p("button",{key:t,class:R(`wl-btn wl-${t}`),disabled:e.comment.status===t,onClick:n=>e.$emit("status",{status:t,comment:e.comment}),textContent:b(t)},null,10,Un)))),128))]),e.isAdmin&&!e.comment.rid?(v(),p("button",{key:0,class:"wl-btn wl-sticky",onClick:t[3]||(t[3]=t=>e.$emit("sticky",e.comment))},b(e.comment.sticky?"unsticky":"sticky"),1)):j("v-if",!0)])):j("v-if",!0),e.isReplyingCurrent?(v(),p("div",zn,[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"])])):j("v-if",!0),e.comment.children?(v(),p("div",Mn,[(v(!0),p(f,null,h(e.comment.children,(n=>(v(),M(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))])):j("v-if",!0)])],8,cn)}],["__file","CommentCard.vue"]]),LoadingIcon:yt},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:o,emoji:l=["//unpkg.com/@waline/emojis@1.0.1/weibo"],meta:a=["nick","mail","link"],requiredMeta:i=[],dark:r=!1,pageSize:s=10,wordLimit:c,imageUploader:u,highlighter:m,texRenderer:d,copyright:v=!0,login:p="enable",...g})=>({serverURL:_e(e),path:He(t),locale:{...le[n]||le["zh-CN"],..."object"==typeof o?o:{}},wordLimit:Be(c),meta:F(a),requiredMeta:F(i),imageUploader:Fe(u,D),highlighter:Fe(m,K),texRenderer:Fe(d,W),lang:n,dark:r,emoji:l,pageSize:s,login:p,copyright:v,...g}))(e))),l=dt(),a=pt(),r=o("loading"),c=o(0),u=o(1),d=o(0),v=o([]),p=o(null),g=s((()=>{return"string"==typeof(e=t.value.dark)?"auto"===e?`@media(prefers-color-scheme:dark){body${De}}`:`${e}${De}`:!0===e?`:root${De}`:"";var e}));let f;!function(e,t={}){const l=o(!1),{document:a=Ce,immediate:r=!0,manual:s=!1,id:c="vueuse_styletag_"+ ++Te}=t,u=o(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),l.value||(m=n(u,(t=>{e.innerText=t}),{immediate:!0}),l.value=!0)},v=()=>{a&&l.value&&(m(),a.head.removeChild(a.getElementById(c)),l.value=!1)};r&&!s&&d(),s||ae(v),i(l)}(g);const h=e=>{const{serverURL:n,path:o,pageSize:a}=t.value,i=new AbortController;r.value="loading",f?.(),(({serverURL:e,lang:t,path:n,page:o,pageSize:l,signal:a,token:i})=>{const r={};return i&&(r.Authorization=`Bearer ${i}`),fetch(`${e}/comment?path=${encodeURIComponent(n)}&pageSize=${l}&page=${o}&lang=${t}`,{signal:a,headers:r}).then((e=>e.json())).then((e=>Ze(e,"comment list")))})({serverURL:n,lang:t.value.lang,path:o,pageSize:a,page:e,signal:i.signal,token:l.value?.token}).then((t=>{r.value="success",c.value=t.count,v.value.push(...t.data),u.value=e,d.value=t.totalPages})).catch((e=>{"AbortError"!==e.name&&(console.error(e.message),r.value="error")})),f=i.abort.bind(i)},w=()=>{c.value=0,v.value=[],h(1)};return P("config",t),n((()=>e.path),w),m((()=>w())),{config:t,darkmodeStyle:g,i18n:s((()=>t.value.locale)),status:r,count:c,page:u,totalPages:d,data:v,reply:p,loadMore:()=>h(u.value+1),refresh:w,onReply:e=>{p.value=e},onSubmit:e=>{if(e.rid){const t=v.value.find((({objectId:t})=>t===e.rid));if(!t)return;Array.isArray(t.children)||(t.children=[]),t.children.push(e)}else v.value.unshift(e)},onStatusChange:async({comment:e,status:n})=>{if(e.status===n)return;const{serverURL:o,lang:a}=t.value;await Xe({serverURL:o,lang:a,token:l.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:o}=t.value;await(({serverURL:e,lang:t,token:n,objectId:o})=>fetch(`${e}/comment/${o}?lang=${t}`,{method:"DELETE",headers:{Authorization:`Bearer ${n}`}}).then((e=>e.json())))({serverURL:n,lang:o,token:l.value?.token,objectId:e}),v.value.some(((t,n)=>t.objectId===e?(v.value=v.value.filter(((e,t)=>t!==n)),!0):t.children.some(((o,l)=>o.objectId===e&&(v.value[n].children=t.children.filter(((e,t)=>t!==l)),!0)))))},onSticky:async e=>{if(e.rid)return;const{serverURL:n,lang:o}=t.value;await Xe({serverURL:n,lang:o,token:l.value?.token,objectId:e.objectId,sticky:e.sticky?0:1}),e.sticky=!e.sticky},onLike:async e=>{const{serverURL:n,lang:o}=t.value,{objectId:l}=e,i=a.value.includes(l);await(({serverURL:e,lang:t,objectId:n,like:o})=>fetch(`${e}/comment/${n}?lang=${t}`,{method:"PUT",headers:Ye,body:JSON.stringify({like:o})}).then((e=>e.json())))({serverURL:n,lang:o,objectId:l,like:!i}),i?a.value=a.value.filter((e=>e!==l)):(a.value=[...a.value,l],a.value.length>50&&(a.value=a.value.slice(-50))),e.like=(e.like||0)+(i?-1:1)},version:"2.5.0"}}}),Pn={"data-waline":""},Tn={class:"wl-count"},Hn=["textContent"],Nn={class:"wl-cards"},Vn={key:1,class:"wl-operation"},_n=["textContent"],Bn={key:0,class:"wl-loading"},Fn=["textContent"],Dn={class:"wl-operation"},Wn=["textContent"],Gn={key:3,class:"wl-power"},qn=y(" Powered by "),Jn=x("a",{href:"https://github.com/walinejs/waline",target:"_blank",rel:"noreferrer"}," Waline ",-1);var Kn=bt(On,[["render",function(e,t,n,o,l,a){const i=L("CommentBox"),r=L("CommentCard"),s=L("LoadingIcon");return v(),p("div",Pn,[e.reply?j("v-if",!0):(v(),M(i,{key:0,onSubmit:e.onSubmit},null,8,["onSubmit"])),x("div",Tn,[e.count?(v(),p("span",{key:0,class:"wl-num",textContent:b(e.count)},null,8,Hn)):j("v-if",!0),y(" "+b(e.i18n.comment),1)]),x("div",Nn,[(v(!0),p(f,null,h(e.data,(t=>(v(),M(r,{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(),p("div",Vn,[x("button",{type:"button",class:"wl-btn",onClick:t[0]||(t[0]=(...t)=>e.refresh&&e.refresh(...t)),textContent:b(e.i18n.refresh)},null,8,_n)])):(v(),p(f,{key:2},["loading"===e.status?(v(),p("div",Bn,[S(s,{size:30})])):e.data.length?e.page<e.totalPages?(v(),p(f,{key:2},[j(" Load more button "),x("div",Dn,[x("button",{type:"button",class:"wl-btn",onClick:t[1]||(t[1]=(...t)=>e.loadMore&&e.loadMore(...t)),textContent:b(e.i18n.more)},null,8,Wn)])],2112)):j("v-if",!0):(v(),p("div",{key:1,class:"wl-empty",textContent:b(e.i18n.sofa)},null,8,Fn))],2112)),j(" Copyright Information "),e.config.copyright?(v(),p("div",Gn,[qn,Jn,y(" v"+b(e.version),1)])):j("v-if",!0)])}],["__file","Waline.vue"]]);const Yn=(e,t)=>{t.forEach(((t,n)=>{t.innerText=e[n].toString()}))},Zn=({serverURL:e,path:t=window.location.pathname,selector:n=".waline-pageview-count",update:o=!0,lang:l="zh-CN"})=>{const a=new AbortController,i=Array.from(document.querySelectorAll(n)),r=e=>{const n=ct(e);return null!==n&&t!==n},s=n=>Qe({serverURL:e,paths:n.map((e=>ct(e)||t)),lang:l,signal:a.signal}).then((e=>Yn(e,n))).catch(Ke);if(o){const n=i.filter((e=>!r(e))),o=i.filter(r);et({serverURL:e,path:t,lang:l}).then((e=>Yn(new Array(n.length).fill(e),n))),o.length&&s(o)}else s(i);return a.abort.bind(a)},Xn=({el:e="#waline",path:t=window.location.pathname,comment:n=!1,pageview:o=!1,...l})=>{const a=e?tt(e):null;if(e&&!a)throw new Error("Option 'el' do not match any domElement!");if(!l.serverURL)throw new Error("Option 'serverURL' is missing!");const i=T({...l}),r=T({comment:n,pageview:o,path:t}),s=()=>{r.comment&>({serverURL:i.serverURL,path:r.path,selector:"string"==typeof r.comment?r.comment:void 0})},c=()=>{r.pageview&&Zn({serverURL:i.serverURL,path:r.path,selector:"string"==typeof r.pageview?r.pageview:void 0})},u=a?H((()=>C(Kn,{path:r.path,...i}))):null;u&&(u.use(wt),u.mount(a)),s(),c();const m=N(s),d=N(c);return{el:a,update:({comment:e,pageview:t,path:n=window.location.pathname,...o}={})=>{Object.entries(o).forEach((([e,t])=>{i[e]=t})),r.path=n,void 0!==e&&(r.comment=e),void 0!==t&&(r.pageview=t)},destroy:()=>{u?.unmount(),m(),d()}}},Qn="2.5.0",eo=({el:e,serverURL:t,count:n,lang:o="zh-CN"})=>{const l=dt(),a=tt(e),i=new AbortController;return(({serverURL:e,lang:t,count:n,signal:o,token:l})=>{const a={};return l&&(a.Authorization=`Bearer ${l}`),fetch(`${e}/comment?type=recent&count=${n}&lang=${t}`,{signal:o,headers:a}).then((e=>e.json())).then((e=>Ze(e,"recent comment")))})({serverURL:t,count:n,lang:o,signal:i.signal,token:l.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:()=>{i.abort(),a.innerHTML=""}}):{comments:e,destroy:()=>i.abort()}))};export{eo as RecentComments,gt as commentCount,le as defaultLocales,Xn as init,Zn as pageviewCount,Qn 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
|