UNPKG

@ovv/artalk

Version:

A self-hosted comment system

10 lines 126 kB
!function(t,e){"object"==typeof exports&&"undefined"!=typeof module?e(exports,require("marked")):"function"==typeof define&&define.amd?define(["exports","marked"],e):e((t="undefined"!=typeof globalThis?globalThis:t||self).Artalk={},t.marked)}(this,(function(t,e){"use strict";var n=Object.defineProperty,s=Object.defineProperties,i=Object.getOwnPropertyDescriptors,o=Object.getOwnPropertySymbols,a=Object.prototype.hasOwnProperty,r=Object.prototype.propertyIsEnumerable,l=(t,e,s)=>e in t?n(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,c=(t,e)=>{for(var n in e||(e={}))a.call(e,n)&&l(t,n,e[n]);if(o)for(var n of o(e))r.call(e,n)&&l(t,n,e[n]);return t},d=(t,e)=>s(t,i(e)),h=(t,e,n)=>l(t,"symbol"!=typeof e?e+"":e,n),u=(t,e,n)=>new Promise(((s,i)=>{var o=t=>{try{r(n.next(t))}catch(e){i(e)}},a=t=>{try{r(n.throw(t))}catch(e){i(e)}},r=t=>t.done?s(t.value):Promise.resolve(t.value).then(o,a);r((n=n.apply(t,e)).next())}));function p(t=""){const e=document.createElement("div");return e.innerHTML=t.trim(),e.firstElementChild||e}function m(t){const e=document.createElement("div");e.innerText=t;return e.innerHTML}function g(t){const e=RegExp(`[?&]${t}=([^&]*)`).exec(window.location.search);return e&&decodeURIComponent(e[1].replace(/\+/g," "))}function f(t,e){const n=t=>{const e=t.getBoundingClientRect(),n=window.pageXOffset||document.documentElement.scrollLeft,s=window.pageYOffset||document.documentElement.scrollTop;return{top:e.top+s,left:e.left+n}},s=n(t);if(!e)return s;const i=n(e);return{top:s.top-i.top,left:s.left-i.left}}function v(t,e){let n=t.toString();for(;n.length<e;)n=`0${n}`;return n}function y(t,e=t=>t){try{const n=t.getTime(),s=(new Date).getTime()-n,i=Math.floor(s/864e5);if(0===i){const t=s%864e5,n=Math.floor(t/36e5);if(0===n){const n=t%36e5,s=Math.floor(n/6e4);if(0===s){const t=n%6e4,s=Math.round(t/1e3);return s<10?e("now"):`${s} ${e("seconds")}`}return`${s} ${e("minutes")}`}return`${n} ${e("hours")}`}return i<0?e("now"):i<8?`${i} ${e("days")}`:function(t){const e=v(t.getDate(),2),n=v(t.getMonth()+1,2);return`${v(t.getFullYear(),2)}-${n}-${e}`}(t)}catch(n){return console.error(n)," - "}}function k(){return u(this,null,(function*(){const t=navigator.userAgent;if(!navigator.userAgentData||!navigator.userAgentData.getHighEntropyValues)return t;const e=navigator.userAgentData;let n=null;try{n=yield e.getHighEntropyValues(["platformVersion"])}catch(i){return console.error(i),t}const s=Number(n.platformVersion.split(".")[0]);return"Windows"===e.platform&&s>=13?t.replace(/Windows NT 10.0/,"Windows NT 11.0"):"macOS"===e.platform&&s>=11?t.replace(/(Mac OS X \d+_\d+_\d+|Mac OS X)/,`Mac OS X ${n.platformVersion.replace(/\./g,"_")}`):t}))}function $(t){let e;try{e=new URL(t)}catch(n){return!1}return"http:"===e.protocol||"https:"===e.protocol}function w(t){return e=t.base,n=t.path,`${e.replace(/\/$/,"")}/${n.replace(/^\//,"")}`;var e,n}const E={placeholder:"Leave a comment",noComment:"No Comment",send:"Send",signIn:"Sign in",signUp:"Sign up",save:"Save",nick:"Nickname",email:"Email",link:"Website",emoticon:"Emoji",preview:"Preview",uploadImage:"Upload Image",uploadFail:"Upload Failed",commentFail:"Failed to comment",restoredMsg:"Content has been restored",onlyAdminCanReply:"Only admin can reply",uploadLoginMsg:"Please fill in your name and email to upload",counter:"{count} Comments",sortLatest:"Latest",sortOldest:"Oldest",sortBest:"Best",sortAuthor:"Author",openComment:"Open Comment",closeComment:"Close Comment",listLoadFailMsg:"Failed to load comments",listRetry:"Retry",loadMore:"Load More",admin:"Admin",reply:"Reply",voteUp:"Up",voteDown:"Down",voteFail:"Vote Failed",readMore:"Read More",actionConfirm:"Confirm",collapse:"Collapse",collapsed:"Collapsed",collapsedMsg:"This comment has been collapsed",expand:"Expand",approved:"Approved",pending:"Pending",pendingMsg:"Pending, visible only to commenter.",edit:"Edit",editCancel:"Cancel Edit",delete:"Delete",deleteConfirm:"Confirm",pin:"Pin",unpin:"Unpin",seconds:"seconds ago",minutes:"minutes ago",hours:"hours ago",days:"days ago",now:"just now",adminCheck:"Enter admin password:",captchaCheck:"Enter the CAPTCHA to continue:",confirm:"Confirm",cancel:"Cancel",msgCenter:"Messages",ctrlCenter:"Dashboard",userProfile:"Profile",noAccountPrompt:"Don't have an account?",haveAccountPrompt:"Already have an account?",forgetPassword:"Forget Password",resetPassword:"Reset Password",changePassword:"Change Password",confirmPassword:"Confirm Password",passwordMismatch:"Passwords do not match",verificationCode:"Verification Code",verifySend:"Send Code",verifyResend:"Resend",waitSeconds:"Wait {seconds}s",emailVerified:"Email has been verified",password:"Password",username:"Username",nextStep:"Next Step",skipVerify:"Skip verification",logoutConfirm:"Are you sure to logout?",accountMergeNotice:"Your email has multiple accounts with different id.",accountMergeSelectOne:"Please select one you want to merge all the data into it.",accountMergeConfirm:"All data will be merged into one account, the id is {id}.",dismiss:"Dismiss",merge:"Merge",client:"Client",server:"Server",loading:"Loading",loadFail:"Load Failed",editing:"Editing",editFail:"Edit Failed",deleting:"Deleting",deleteFail:"Delete Failed",reqGot:"Request got",reqAborted:"Request timed out or terminated unexpectedly",updateMsg:"Please update Artalk {name} to get the best experience!",currentVersion:"Current Version",ignore:"Ignore",open:"Open",openName:"Open {name}"},C="ArtalkI18n",b={en:E,"en-US":E,"zh-CN":{placeholder:"键入内容...",noComment:"「此时无声胜有声」",send:"发送",signIn:"登录",signUp:"注册",save:"保存",nick:"昵称",email:"邮箱",link:"网址",emoticon:"表情",preview:"预览",uploadImage:"上传图片",uploadFail:"上传失败",commentFail:"评论失败",restoredMsg:"内容已自动恢复",onlyAdminCanReply:"仅管理员可评论",uploadLoginMsg:"填入你的名字邮箱才能上传哦",counter:"{count} 条评论",sortLatest:"最新",sortOldest:"最早",sortBest:"最热",sortAuthor:"作者",openComment:"打开评论",closeComment:"关闭评论",listLoadFailMsg:"无法获取评论列表数据",listRetry:"点击重新获取",loadMore:"加载更多",admin:"管理员",reply:"回复",voteUp:"赞同",voteDown:"反对",voteFail:"投票失败",readMore:"阅读更多",actionConfirm:"确认操作",collapse:"折叠",collapsed:"已折叠",collapsedMsg:"该评论已被系统或管理员折叠",expand:"展开",approved:"已审",pending:"待审",pendingMsg:"审核中,仅本人可见。",edit:"编辑",editCancel:"取消编辑",delete:"删除",deleteConfirm:"确认删除",pin:"置顶",unpin:"取消置顶",seconds:"秒前",minutes:"分钟前",hours:"小时前",days:"天前",now:"刚刚",adminCheck:"键入密码来验证管理员身份:",captchaCheck:"键入验证码继续:",confirm:"确认",cancel:"取消",msgCenter:"通知中心",ctrlCenter:"控制中心",userProfile:"个人资料",noAccountPrompt:"没有账号?",haveAccountPrompt:"已有账号?",forgetPassword:"忘记密码",resetPassword:"重置密码",changePassword:"修改密码",confirmPassword:"确认密码",passwordMismatch:"两次输入的密码不一致",verificationCode:"验证码",verifySend:"发送验证码",verifyResend:"重新发送",waitSeconds:"等待 {seconds}秒",emailVerified:"邮箱已验证",password:"密码",username:"用户名",nextStep:"下一步",skipVerify:"跳过验证",logoutConfirm:"确定要退出登录吗?",accountMergeNotice:"您的电子邮件下有多个不同 ID 的账户。",accountMergeSelectOne:"请选择将所有数据合并到其中的一个。",accountMergeConfirm:"所有数据将合并到 ID 为 {id} 的账户中。",dismiss:"忽略",merge:"合并",client:"客户端",server:"服务器",loading:"加载中",loadFail:"加载失败",editing:"修改中",editFail:"修改失败",deleting:"删除中",deleteFail:"删除失败",reqGot:"请求响应",reqAborted:"请求超时或意外终止",updateMsg:"请更新 Artalk {name} 以获得更好的体验!",currentVersion:"当前版本",ignore:"忽略",open:"打开",openName:"打开{name}"}};function S(t){return t=t.replace(/^([a-zA-Z]+)(-[a-zA-Z]+)?$/,((t,e,n)=>e.toLowerCase()+(n||"").toUpperCase())),b[t]?b[t]:window[C]&&window[C][t]?window[C][t]:b.en}let x="en",T=S(x);function L(t,e={}){let n=(null==T?void 0:T[t])||t;return n=n.replace(/\{\s*(\w+?)\s*\}/g,((t,n)=>e[n]||"")),m(n)}"undefined"!=typeof globalThis?globalThis:"undefined"!=typeof window?window:"undefined"!=typeof global?global:"undefined"!=typeof self&&self;function A(t){return t&&t.__esModule&&Object.prototype.hasOwnProperty.call(t,"default")?t.default:t}var M={"&":"&amp;","<":"&lt;",">":"&gt;",'"':"&quot;","'":"&#39;"},P={"&amp;":"&","&lt;":"<","&gt;":">","&quot;":'"',"&#39;":"'"},U=/(&amp;|&lt;|&gt;|&quot;|&#39;)/g,j=/[&<>"']/g;function I(t){return M[t]}function O(t){return P[t]}function D(t){return null==t?"":String(t).replace(j,I)}function q(t){return null==t?"":String(t).replace(U,O)}D.options=q.options={};var B={encode:D,escape:D,decode:q,unescape:q,version:"1.0.0-browser"};var R=function t(e){for(var n,s,i=Array.prototype.slice.call(arguments,1);i.length;)for(s in n=i.shift())n.hasOwnProperty(s)&&("[object Object]"===Object.prototype.toString.call(e[s])?e[s]=t(e[s],n[s]):e[s]=n[s]);return e},_=function(t){return"string"==typeof t?t.toLowerCase():t};function F(t,e){return t[e]=!0,t}var W=function(t){return t.reduce(F,{})},N={uris:W(["background","base","cite","href","longdesc","src","usemap"])},H={voids:W(["area","br","col","hr","img","wbr","input","base","basefont","link","meta"])},V=B,z=_,K=H,Q=/^<\s*([\w:-]+)((?:\s+[\w:-]+(?:\s*=\s*(?:(?:"[^"]*")|(?:'[^']*')|[^>\s]+))?)*)\s*(\/?)\s*>/,G=/^<\s*\/\s*([\w:-]+)[^>]*>/,Y=/([\w:-]+)(?:\s*=\s*(?:(?:"((?:[^"])*)")|(?:'((?:[^'])*)')|([^>\s]+)))?/g,J=/^</,X=/^<\s*\//;var Z=B,tt=_,et=N,nt=H;var st=R,it=function(t,e){for(var n,s=function(){var t=[];return t.lastItem=function(){return t[t.length-1]},t}(),i=t;t;)o();function o(){n=!0,function(){"\x3c!--"===t.substr(0,4)?(s=t.indexOf("--\x3e"))>=0&&(e.comment&&e.comment(t.substring(4,s)),t=t.substring(s+3),n=!1):X.test(t)?a(G,l):J.test(t)&&a(Q,r);var s;!function(){if(!n)return;var s,i=t.indexOf("<");i>=0?(s=t.substring(0,i),t=t.substring(i)):(s=t,t="");e.chars&&e.chars(s)}()}();var s=t===i;i=t,s&&(t="")}function a(e,s){var i=t.match(e);i&&(t=t.substring(i[0].length),i[0].replace(e,s),n=!1)}function r(t,n,i,o){var a={},r=z(n),l=K.voids[r]||!!o;i.replace(Y,(function(t,e,n,s,i){a[e]=void 0===n&&void 0===s&&void 0===i?void 0:V.decode(n||s||i||"")})),l||s.push(r),e.start&&e.start(r,a,l)}function l(t,n){var i,o=0,a=z(n);if(a)for(o=s.length-1;o>=0&&s[o]!==a;o--);if(o>=0){for(i=s.length-1;i>=o;i--)e.end&&e.end(s[i]);s.length=o}}l()},ot=function(t,e){var n,s=e||{};return r(),{start:function(t,e,a){var r=tt(t);if(n.ignoring)return void o(r);if(-1===(s.allowedTags||[]).indexOf(r))return void o(r);if(s.filter&&!s.filter({tag:r,attrs:e}))return void o(r);i("<"),i(r),Object.keys(e).forEach((function(t){var n=e[t],o=(s.allowedClasses||{})[r]||[],a=(s.allowedAttributes||{})[r]||[],l=tt(t);("class"===l&&-1===a.indexOf(l)?(n=n.split(" ").filter((function(t){return o&&-1!==o.indexOf(t)})).join(" ").trim()).length:-1!==a.indexOf(l)&&(!0!==et.uris[l]||function(t){var e=t[0];if("#"===e||"/"===e)return!0;var n=t.indexOf(":");if(-1===n)return!0;var i=t.indexOf("?");if(-1!==i&&n>i)return!0;var o=t.indexOf("#");return-1!==o&&n>o||s.allowedSchemes.some(a);function a(e){return 0===t.indexOf(e+":")}}(n)))&&(i(" "),i(t),"string"==typeof n&&(i('="'),i(Z.encode(n)),i('"')))})),i(a?"/>":">")},end:function(t){var e=tt(t);-1!==(s.allowedTags||[]).indexOf(e)&&!1===n.ignoring?(i("</"),i(e),i(">")):a(e)},chars:function(t){!1===n.ignoring&&i(s.transformText?s.transformText(t):t)}};function i(e){t.push(e)}function o(t){nt.voids[t]||(!1===n.ignoring?n={ignoring:t,depth:1}:n.ignoring===t&&n.depth++)}function a(t){n.ignoring===t&&--n.depth<=0&&r()}function r(){n={ignoring:!1,depth:0}}},at={allowedAttributes:{a:["href","name","target","title","aria-label"],iframe:["allowfullscreen","frameborder","src"],img:["src","alt","title","aria-label"]},allowedClasses:{},allowedSchemes:["http","https","mailto"],allowedTags:["a","abbr","article","b","blockquote","br","caption","code","del","details","div","em","h1","h2","h3","h4","h5","h6","hr","i","img","ins","kbd","li","main","mark","ol","p","pre","section","span","strike","strong","sub","summary","sup","table","tbody","td","th","thead","tr","u","ul"],filter:null};function rt(t,e,n){var s=[],i=!0===n?e:st({},at,e),o=ot(s,i);return it(t,o),s.join("")}rt.defaults=at;const lt=A(rt),ct={allowedClasses:{},allowedSchemes:["http","https","mailto","data"],allowedTags:["a","abbr","article","b","blockquote","br","caption","code","del","details","div","em","h1","h2","h3","h4","h5","h6","hr","i","img","ins","kbd","li","main","mark","ol","p","pre","section","span","strike","strong","sub","summary","sup","table","tbody","td","th","thead","tr","u","ul"],allowedAttributes:{"*":["title","accesskey"],a:["href","name","target","aria-label","rel"],img:["src","alt","title","atk-emoticon","aria-label","data-src","class","loading"],code:["class"],span:["class","style"]},filter:t=>([["code",/^hljs\W+language-(.*)$/],["span",/^(hljs-.*)$/],["img",/^lazyload$/]].forEach((([e,n])=>{t.tag===e&&t.attrs.class&&!n.test(t.attrs.class)&&delete t.attrs.class})),"span"===t.tag&&t.attrs.style&&!/^color:(\W+)?#[0-9a-f]{3,6};?$/i.test(t.attrs.style)&&delete t.attrs.style,!0)};function dt(t){return lt(t,ct)}var ht={exports:{}};ht.exports=function(){function t(t,e){return t(e={exports:{}},e.exports),e.exports}var e=t((function(t){var e=t.exports=function(){return new RegExp("(?:"+e.line().source+")|(?:"+e.block().source+")","gm")};e.line=function(){return/(?:^|\s)\/\/(.+?)$/gm},e.block=function(){return/\/\*([\S\s]*?)\*\//gm}})),n=["23AC69","91C132","F19726","E8552D","1AAB8E","E1147F","2980C1","1BA1E6","9FA0A0","F19726","E30B20","E30B20","A3338B"];function s(t){return'<span style="color: slategray">'+t+"</span>"}return function(t,i){void 0===i&&(i={});var o=i.colors;void 0===o&&(o=n);var a=0,r={},l=new RegExp("("+/[\u4E00-\u9FFF\u3400-\u4dbf\uf900-\ufaff\u3040-\u309f\uac00-\ud7af\u0400-\u04FF]+|\w+/.source+"|"+/</.source+")|("+e().source+")","gmi");return t.replace(l,(function(t,e,n){if(n)return s(n);if("<"===e)return"&lt;";var i;r[e]?i=r[e]:(i=o[a],r[e]=i);var l='<span style="color: #'+i+'">'+e+"</span>";return a=++a%o.length,l}))}}();const ut=A(ht.exports);function pt(t){return ut(t)}function mt(t){const n=new e.marked.Renderer;return n.link=gt(n,n.link),n.code=ft(),n.image=vt(n,n.image,t),n}const gt=(t,e)=>n=>{const s=(t=>{try{return new URL(t).origin}catch(e){return""}})(n.href)===window.location.origin;return e.call(t,n).replace(/^<a /,`<a target="_blank" ${s?"":'rel="noreferrer noopener nofollow"'} `)},ft=()=>({lang:t,text:e})=>{const n=t||"plaintext";let s=e;return window.hljs?n&&window.hljs.getLanguage(n)&&(s=window.hljs.highlight(n,e).value):s=pt(e),`<pre rel="${n}">\n<code class="hljs language-${n}">${s.replace(/&amp;/g,"&")}</code>\n</pre>`},vt=(t,e,{imgLazyLoad:n})=>s=>{const i=e.call(t,s);return n?"native"===n||!0===n?i.replace(/^<img /,'<img class="lazyload" loading="lazy" '):"data-src"===n?i.replace(/^<img /,'<img class="lazyload" ').replace("src=","data-src="):i:i};let yt,kt=[];const $t={gfm:!0,breaks:!0,async:!1};function wt(){return yt}function Et(t){var e;let n=null==(e=wt())?void 0:e.parse(t);n||(n=function(t){return t.replace(/```\s*([^]+?.*?[^]+?[^]+?)```/g,((t,e)=>`<pre><code>${pt(e)}</code></pre>`)).replace(/!\[(.*?)\]\((.*?)\)/g,((t,e,n)=>`<img src="${n}" alt="${e}" />`)).replace(/\[(.*?)\]\((.*?)\)/g,((t,e,n)=>`<a href="${n}" target="_blank">${e}</a>`)).replace(/\n/g,"<br>")}(t));let s=dt(n);return kt.forEach((t=>{"function"==typeof t&&(s=t(s))})),s}class Ct{constructor(t){h(this,"_deps",function(){const t=new Map,e=new Map,n=s=>{const i=t.get(s);if(!i)throw new Error(`No provide for ${String(s)}`);if("singleton"===i.lifecycle&&e.has(s))return e.get(s);const{impl:o,deps:a}=i,r=o(...a.map((t=>n(t))));return e.set(s,r),r};return{provide:(e,n,s,i={})=>{t.set(e,{impl:n,deps:s||[],lifecycle:i.lifecycle||"singleton"})},inject:n}}()),h(this,"provide",((t,e,n,s)=>{this._deps.provide(t,e,n,s)})),h(this,"inject",(t=>this._deps.inject(t))),h(this,"get",this.inject),h(this,"on",((t,e)=>{this.inject("events").on(t,e)})),h(this,"off",((t,e)=>{this.inject("events").off(t,e)})),h(this,"trigger",((t,e)=>{this.inject("events").trigger(t,e)})),h(this,"getCommentList",this.getCommentNodes),h(this,"getCommentDataList",this.getComments),this._$root=t}getEl(){return this._$root}destroy(){for(this.trigger("unmounted");this._$root.firstChild;)this._$root.removeChild(this._$root.firstChild)}getConf(){return this.inject("config").get()}updateConf(t){this.inject("config").update(t)}watchConf(t,e){this.inject("config").watchConf(t,e)}getMarked(){return wt()}setDarkMode(t){this.updateConf({darkMode:t})}get conf(){return this.getConf()}set conf(t){console.error("Cannot set config directly, please call updateConf()")}get $root(){return this.getEl()}set $root(t){console.error("set $root is prohibited")}$t(t,e={}){return L(t,e)}getApi(){return this.inject("api")}getApiHandlers(){return this.inject("apiHandlers")}getUser(){return this.inject("user")}getData(){return this.inject("data")}fetch(t){this.getData().fetchComments(t)}reload(){this.getData().fetchComments({offset:0})}listGotoFirst(){this.trigger("list-goto-first")}getCommentNodes(){return this.inject("list").getCommentNodes()}getComments(){return this.getData().getComments()}replyComment(t,e){this.inject("editor").setReplyComment(t,e)}editComment(t,e){this.inject("editor").setEditComment(t,e)}editorShowLoading(){this.inject("editor").showLoading()}editorHideLoading(){this.inject("editor").hideLoading()}editorShowNotify(t,e){this.inject("editor").showNotify(t,e)}editorResetState(){this.inject("editor").resetState()}showSidebar(t){this.inject("sidebar").show(t)}hideSidebar(){this.inject("sidebar").hide()}checkAdmin(t){return this.inject("checkers").checkAdmin(t)}checkCaptcha(t){return this.inject("checkers").checkCaptcha(t)}}function bt(...t){const e=t=>t&&"object"==typeof t&&t.constructor===Object;return t.reduce(((t,n)=>(Object.keys(null!=n?n:{}).forEach((s=>{if("__proto__"===s||"constructor"===s||"prototype"===s)return;const i=t[s],o=n[s];Array.isArray(i)&&Array.isArray(o)?t[s]=i.concat(...o):e(i)&&e(o)?t[s]=bt(i,o):t[s]=o})),t)),{})}const St={el:"",pageKey:"",pageTitle:"",server:"",site:"",placeholder:"",noComment:"",sendBtn:"",darkMode:!1,editorTravel:!0,flatMode:"auto",nestMax:2,nestSort:"DATE_ASC",emoticons:"https://cdn.jsdelivr.net/gh/ArtalkJS/Emoticons/grps/default.json",pageVote:!0,vote:!0,voteDown:!1,uaBadge:!0,listSort:!0,preview:!0,countEl:".artalk-comment-count",pvEl:".artalk-pv-count",statPageKeyAttr:"data-page-key",gravatar:{mirror:"https://www.gravatar.com/avatar/",params:"sha256=1&d=mp&s=240"},pagination:{pageSize:20,readMore:!0,autoLoad:!0},heightLimit:{content:300,children:400,scrollable:!1},imgUpload:!0,imgLazyLoad:!1,reqTimeout:15e3,versionCheck:!0,useBackendConf:!0,preferRemoteConf:!1,listUnreadHighlight:!1,pvAdd:!0,fetchCommentsOnInit:!0,locale:"en",apiVersion:"",pluginURLs:[],markedReplacers:[],markedOptions:{}};function xt(t,e=!1){const n=e?bt(St,t):t;return""===n.pageKey&&(n.pageKey=`${window.location.pathname}`),""===n.pageTitle&&(n.pageTitle=`${document.title}`),n.server&&(n.server=n.server.replace(/\/$/,"").replace(/\/api\/?$/,"")),"auto"===n.locale&&(n.locale=navigator.language),"auto"===n.flatMode&&(n.flatMode=window.matchMedia("(max-width: 768px)").matches),"number"==typeof n.nestMax&&Number(n.nestMax)<=1&&(n.flatMode=!0),n}function Tt(t,e,n){return{baseURL:`${t.server}/api/v2`,siteName:t.site||"",pageKey:t.pageKey||"",pageTitle:t.pageTitle||"",timeout:t.reqTimeout,getApiToken:()=>null==e?void 0:e.getData().token,userInfo:(null==e?void 0:e.checkHasBasicUserInfo())?{name:null==e?void 0:e.getData().name,email:null==e?void 0:e.getData().email}:void 0,handlers:n}}function Lt(t){return u(this,null,(function*(){yield function(t){return u(this,null,(function*(){yield At({opt:t,query:"page_comment",containers:[t.countEl,"#ArtalkCount"]})}))}(t);const e=yield function(t){return u(this,null,(function*(){if(!t.pvAdd||!t.pageKey)return;const e=(yield t.getApi().pages.logPv({page_key:t.pageKey,page_title:t.pageTitle,site_name:t.siteName})).data.pv;return{[t.pageKey]:e}}))}(t);yield function(t,e){return u(this,null,(function*(){yield At({opt:t,query:"page_pv",containers:[t.pvEl,"#ArtalkPV"],cache:e})}))}(t,e)}))}function At(t){return u(this,null,(function*(){const{opt:e}=t;let n=t.cache||{};const s=function(t){const e=new Set;return new Set(t).forEach((t=>{document.querySelectorAll(t).forEach((t=>e.add(t)))})),e}(t.containers),i=function(t,e,n,s){const i=Array.from(t).map((t=>t.getAttribute(e)||n)).filter((t=>t&&"number"!=typeof s[t]));return[...new Set(i)]}(s,e.pageKeyAttr,e.pageKey,n);if(i.length>0){const s=(yield e.getApi().stats.getStats(t.query,{page_keys:i.join(","),site_name:e.siteName})).data.data;n=c(c({},n),s)}!function(t,e,n){t.forEach((t=>{const s=t.getAttribute("data-page-key"),i=s&&e[s]||n&&e[n]||0;t.innerText=`${Number(i)}`}))}(s,n,e.pageKey)}))}class Mt{constructor(t={}){h(this,"baseUrl","/api/v2"),h(this,"securityData",null),h(this,"securityWorker"),h(this,"abortControllers",new Map),h(this,"customFetch",((...t)=>fetch(...t))),h(this,"baseApiParams",{credentials:"same-origin",headers:{},redirect:"follow",referrerPolicy:"no-referrer"}),h(this,"setSecurityData",(t=>{this.securityData=t})),h(this,"contentFormatters",{"application/json":t=>null===t||"object"!=typeof t&&"string"!=typeof t?t:JSON.stringify(t),"text/plain":t=>null!==t&&"string"!=typeof t?JSON.stringify(t):t,"multipart/form-data":t=>Object.keys(t||{}).reduce(((e,n)=>{const s=t[n];return e.append(n,s instanceof Blob?s:"object"==typeof s&&null!==s?JSON.stringify(s):`${s}`),e}),new FormData),"application/x-www-form-urlencoded":t=>this.toQueryString(t)}),h(this,"createAbortSignal",(t=>{if(this.abortControllers.has(t)){const e=this.abortControllers.get(t);return e?e.signal:void 0}const e=new AbortController;return this.abortControllers.set(t,e),e.signal})),h(this,"abortRequest",(t=>{const e=this.abortControllers.get(t);e&&(e.abort(),this.abortControllers.delete(t))})),h(this,"request",(t=>u(this,null,(function*(){var e=t,{body:n,secure:s,path:i,type:l,query:h,format:p,baseUrl:m,cancelToken:g}=e,f=((t,e)=>{var n={};for(var s in t)a.call(t,s)&&e.indexOf(s)<0&&(n[s]=t[s]);if(null!=t&&o)for(var s of o(t))e.indexOf(s)<0&&r.call(t,s)&&(n[s]=t[s]);return n})(e,["body","secure","path","type","query","format","baseUrl","cancelToken"]);const v=("boolean"==typeof s?s:this.baseApiParams.secure)&&this.securityWorker&&(yield this.securityWorker(this.securityData))||{},y=this.mergeRequestParams(f,v),k=h&&this.toQueryString(h),$=this.contentFormatters[l||"application/json"],w=p||y.format;return this.customFetch(`${m||this.baseUrl||""}${i}${k?`?${k}`:""}`,d(c({},y),{headers:c(c({},y.headers||{}),l&&"multipart/form-data"!==l?{"Content-Type":l}:{}),signal:(g?this.createAbortSignal(g):y.signal)||null,body:null==n?null:$(n)})).then((t=>u(this,null,(function*(){const e=t.clone();e.data=null,e.error=null;const n=w?yield t[w]().then((t=>(e.ok?e.data=t:e.error=t,e))).catch((t=>(e.error=t,e))):e;if(g&&this.abortControllers.delete(g),!t.ok)throw n;return n}))))})))),Object.assign(this,t)}encodeQueryParam(t,e){return`${encodeURIComponent(t)}=${encodeURIComponent("number"==typeof e?e:`${e}`)}`}addQueryParam(t,e){return this.encodeQueryParam(e,t[e])}addArrayQueryParam(t,e){return t[e].map((t=>this.encodeQueryParam(e,t))).join("&")}toQueryString(t){const e=t||{};return Object.keys(e).filter((t=>void 0!==e[t])).map((t=>Array.isArray(e[t])?this.addArrayQueryParam(e,t):this.addQueryParam(e,t))).join("&")}addQueryParams(t){const e=this.toQueryString(t);return e?`?${e}`:""}mergeRequestParams(t,e){return d(c(c(c({},this.baseApiParams),t),e||{}),{headers:c(c(c({},this.baseApiParams.headers||{}),t.headers||{}),e&&e.headers||{})})}} /** * @title Artalk API * @version 2.0 * @license MIT (https://github.com/ArtalkJS/Artalk/blob/master/LICENSE) * @baseUrl /api/v2 * @contact API Support <artalkjs@gmail.com> (https://artalk.js.org) * * Artalk is a modern comment system based on Golang. */let Pt=class extends Mt{constructor(){super(...arguments),h(this,"auth",{loginByEmail:(t,e={})=>this.request(c({path:"/auth/email/login",method:"POST",body:t,type:"application/json",format:"json"},e)),registerByEmail:(t,e={})=>this.request(c({path:"/auth/email/register",method:"POST",body:t,type:"application/json",format:"json"},e)),sendVerifyEmail:(t,e={})=>this.request(c({path:"/auth/email/send",method:"POST",body:t,type:"application/json",format:"json"},e)),checkDataMerge:(t={})=>this.request(c({path:"/auth/merge",method:"GET",secure:!0,format:"json"},t)),applyDataMerge:(t,e={})=>this.request(c({path:"/auth/merge",method:"POST",body:t,secure:!0,type:"application/json",format:"json"},e))}),h(this,"cache",{flushCache:(t={})=>this.request(c({path:"/cache/flush",method:"POST",secure:!0,format:"json"},t)),warmUpCache:(t={})=>this.request(c({path:"/cache/warm_up",method:"POST",secure:!0,format:"json"},t))}),h(this,"captcha",{getCaptcha:(t={})=>this.request(c({path:"/captcha",method:"GET",format:"json"},t)),getCaptchaStatus:(t={})=>this.request(c({path:"/captcha/status",method:"GET",format:"json"},t)),verifyCaptcha:(t,e={})=>this.request(c({path:"/captcha/verify",method:"POST",body:t,type:"application/json",format:"json"},e))}),h(this,"comments",{getComments:(t,e={})=>this.request(c({path:"/comments",method:"GET",query:t,secure:!0,type:"application/json",format:"json"},e)),createComment:(t,e={})=>this.request(c({path:"/comments",method:"POST",body:t,secure:!0,type:"application/json",format:"json"},e)),getComment:(t,e={})=>this.request(c({path:`/comments/${t}`,method:"GET",type:"application/json",format:"json"},e)),updateComment:(t,e,n={})=>this.request(c({path:`/comments/${t}`,method:"PUT",body:e,secure:!0,type:"application/json",format:"json"},n)),deleteComment:(t,e={})=>this.request(c({path:`/comments/${t}`,method:"DELETE",secure:!0,format:"json"},e))}),h(this,"conf",{conf:(t={})=>this.request(c({path:"/conf",method:"GET",format:"json"},t)),getSocialLoginProviders:(t={})=>this.request(c({path:"/conf/auth/providers",method:"GET",format:"json"},t)),getDomain:(t,e={})=>this.request(c({path:"/conf/domain",method:"GET",query:t,format:"json"},e))}),h(this,"notifies",{getNotifies:(t,e={})=>this.request(c({path:"/notifies",method:"GET",query:t,type:"application/json",format:"json"},e)),markAllNotifyRead:(t,e={})=>this.request(c({path:"/notifies/read",method:"POST",body:t,type:"application/json",format:"json"},e)),markNotifyRead:(t,e,n={})=>this.request(c({path:`/notifies/${t}/${e}`,method:"POST",format:"json"},n))}),h(this,"pages",{getPages:(t,e={})=>this.request(c({path:"/pages",method:"GET",query:t,secure:!0,type:"application/json",format:"json"},e)),fetchAllPages:(t,e={})=>this.request(c({path:"/pages/fetch",method:"POST",body:t,secure:!0,type:"application/json",format:"json"},e)),getPageFetchStatus:(t={})=>this.request(c({path:"/pages/fetch/status",method:"GET",secure:!0,format:"json"},t)),logPv:(t,e={})=>this.request(c({path:"/pages/pv",method:"POST",body:t,type:"application/json",format:"json"},e)),updatePage:(t,e,n={})=>this.request(c({path:`/pages/${t}`,method:"PUT",body:e,secure:!0,type:"application/json",format:"json"},n)),deletePage:(t,e={})=>this.request(c({path:`/pages/${t}`,method:"DELETE",secure:!0,format:"json"},e)),fetchPage:(t,e={})=>this.request(c({path:`/pages/${t}/fetch`,method:"POST",secure:!0,type:"application/json",format:"json"},e))}),h(this,"sendEmail",{sendEmail:(t,e={})=>this.request(c({path:"/send_email",method:"POST",body:t,secure:!0,type:"application/json",format:"json"},e))}),h(this,"settings",{getSettings:(t={})=>this.request(c({path:"/settings",method:"GET",secure:!0,format:"json"},t)),applySettings:(t,e={})=>this.request(c({path:"/settings",method:"PUT",body:t,secure:!0,type:"application/json",format:"json"},e)),getSettingsTemplate:(t,e={})=>this.request(c({path:`/settings/template/${t}`,method:"GET",secure:!0,format:"json"},e))}),h(this,"sites",{getSites:(t={})=>this.request(c({path:"/sites",method:"GET",secure:!0,format:"json"},t)),createSite:(t,e={})=>this.request(c({path:"/sites",method:"POST",body:t,secure:!0,type:"application/json",format:"json"},e)),updateSite:(t,e,n={})=>this.request(c({path:`/sites/${t}`,method:"PUT",body:e,secure:!0,type:"application/json",format:"json"},n)),deleteSite:(t,e={})=>this.request(c({path:`/sites/${t}`,method:"DELETE",secure:!0,format:"json"},e))}),h(this,"stats",{getStats:(t,e,n={})=>this.request(c({path:`/stats/${t}`,method:"GET",query:e,type:"application/json",format:"json"},n))}),h(this,"transfer",{exportArtrans:(t={})=>this.request(c({path:"/transfer/export",method:"GET",secure:!0,format:"json"},t)),importArtrans:(t,e={})=>this.request(c({path:"/transfer/import",method:"POST",body:t,secure:!0,type:"application/json"},e)),uploadArtrans:(t,e={})=>this.request(c({path:"/transfer/upload",method:"POST",body:t,secure:!0,type:"multipart/form-data",format:"json"},e))}),h(this,"upload",{upload:(t,e={})=>this.request(c({path:"/upload",method:"POST",body:t,secure:!0,type:"multipart/form-data",format:"json"},e))}),h(this,"user",{getUser:(t,e={})=>this.request(c({path:"/user",method:"GET",query:t,secure:!0,format:"json"},e)),updateProfile:(t,e={})=>this.request(c({path:"/user",method:"POST",body:t,secure:!0,type:"application/json",format:"json"},e)),login:(t,e={})=>this.request(c({path:"/user/access_token",method:"POST",body:t,type:"application/json",format:"json"},e)),getUserStatus:(t,e={})=>this.request(c({path:"/user/status",method:"GET",query:t,secure:!0,format:"json"},e))}),h(this,"users",{createUser:(t,e={})=>this.request(c({path:"/users",method:"POST",body:t,secure:!0,type:"application/json",format:"json"},e)),updateUser:(t,e,n={})=>this.request(c({path:`/users/${t}`,method:"PUT",body:e,secure:!0,type:"application/json",format:"json"},n)),deleteUser:(t,e={})=>this.request(c({path:`/users/${t}`,method:"DELETE",secure:!0,format:"json"},e)),getUsers:(t,e,n={})=>this.request(c({path:`/users/${t}`,method:"GET",query:e,secure:!0,type:"application/json",format:"json"},n))}),h(this,"version",{getVersion:(t={})=>this.request(c({path:"/version",method:"GET",format:"json"},t))}),h(this,"votes",{syncVotes:(t={})=>this.request(c({path:"/votes/sync",method:"POST",secure:!0,format:"json"},t)),getVote:(t,e,n={})=>this.request(c({path:`/votes/${t}/${e}`,method:"GET",type:"application/json",format:"json"},n)),createVote:(t,e,n,s,i={})=>this.request(c({path:`/votes/${t}/${e}/${n}`,method:"POST",body:s,type:"application/json",format:"json"},i))})}};const Ut=(t,e,n)=>u(this,null,(function*(){const s=t.getApiToken&&t.getApiToken(),i=new Headers(c({Authorization:s?`Bearer ${s}`:""},null==n?void 0:n.headers));i.get("Authorization")||i.delete("Authorization");const o=yield fetch(e,d(c({},n),{headers:i}));if(!o.ok){const s=(yield o.json().catch((()=>{})))||{};let i=!1;if(t.handlers&&(yield t.handlers.get().reduce(((t,e)=>u(this,null,(function*(){yield t,!0===s[e.action]&&(yield e.handler(s),i=!0)}))),Promise.resolve())),i)return Ut(t,e,n);throw function(t,e){const n=new jt;return n.message=e.msg||e.message||"fetch error",n.code=t,n.data=e,console.error(n),n}(o.status,s)}return o}));class jt extends Error{constructor(){super(...arguments),h(this,"code",0),h(this,"message","fetch error"),h(this,"data")}}class It extends Pt{constructor(t){super({baseUrl:t.baseURL,customFetch:(e,n)=>Ut(t,e,n)}),h(this,"_opts"),this._opts=t}getUserFields(){const t=this._opts.userInfo;if((null==t?void 0:t.name)&&(null==t?void 0:t.email))return{name:t.name,email:t.email}}}class Ot{constructor(t){h(this,"$btn"),h(this,"$panel"),h(this,"editorStateEffectWhen"),this.kit=t}useBtn(t="<div></div>"){return this.$btn=p(`<span class="atk-plug-btn">${t}</span>`),this.$btn}usePanel(t="<div></div>"){return this.$panel=p(t),this.$panel}useContentTransformer(t){this.contentTransformer=t}usePanelShow(t){this.kit.useEvents().on("panel-show",(e=>{e===this&&t()}))}usePanelHide(t){this.kit.useEvents().on("panel-hide",(e=>{e===this&&t()}))}useEditorStateEffect(t,e){this.editorStateEffectWhen=t,this.editorStateEffect=e}}const Dt="ArtalkContent";class qt{constructor(t){this.kit=t}reqAdd(){return u(this,null,(function*(){return(yield this.kit.useApi().comments.createComment(c({},yield this.getSubmitAddParams()))).data}))}getSubmitAddParams(){return u(this,null,(function*(){const{name:t,email:e,link:n}=this.kit.useUser().getData(),s=this.kit.useConf();return{content:this.kit.useEditor().getContentFinal(),name:t,email:e,link:n,rid:0,page_key:s.pageKey,page_title:s.pageTitle,site_name:s.site,ua:yield k()}}))}postSubmitAdd(t){this.kit.useData().insertComment(t)}}class Bt extends Ot{constructor(t){super(t),h(this,"customs",[]),h(this,"defaultPreset"),this.defaultPreset=new qt(this.kit);const e=()=>this.do();this.kit.useMounted((()=>{this.kit.useEvents().on("editor-submit",e)})),this.kit.useUnmounted((()=>{this.kit.useEvents().off("editor-submit",e)}))}registerCustom(t){this.customs.push(t)}do(){return u(this,null,(function*(){if(""===this.kit.useEditor().getContentFinal().trim())return void this.kit.useEditor().focus();const t=this.customs.find((t=>t.activeCond()));this.kit.useEditor().showLoading();try{let e;(null==t?void 0:t.pre)&&t.pre(),e=(null==t?void 0:t.req)?yield t.req():yield this.defaultPreset.reqAdd(),(null==t?void 0:t.post)?t.post(e):this.defaultPreset.postSubmitAdd(e)}catch(e){return console.error(e),void this.kit.useEditor().showNotify(`${L("commentFail")}: ${e.message||String(e)}`,"e")}finally{this.kit.useEditor().hideLoading()}this.kit.useEditor().reset(),this.kit.useEvents().trigger("editor-submitted")}))}}class Rt extends Ot{constructor(){super(...arguments),h(this,"isMoved",!1)}move(t){if(this.isMoved)return;this.isMoved=!0;const e=this.kit.useUI().$el;e.after(p('<div class="atk-editor-travel-placeholder"></div>'));const n=p("<div></div>");t.after(n),n.replaceWith(e),e.classList.add("atk-fade-in"),e.classList.add("editor-traveling")}back(){var t;this.isMoved&&(this.isMoved=!1,null==(t=this.kit.useArtalkRootEl().querySelector(".atk-editor-travel-placeholder"))||t.replaceWith(this.kit.useUI().$el),this.kit.useUI().$el.classList.remove("editor-traveling"))}}function _t(t,e){let n=t.querySelector(":scope > .atk-loading");n||(n=p('<div class="atk-loading" style="display: none;">\n <div class="atk-loading-spinner">\n <svg viewBox="25 25 50 50"><circle cx="50" cy="50" r="20" fill="none" stroke-width="2" stroke-miterlimit="10"></circle></svg>\n </div>\n </div>'),(null==e?void 0:e.transparentBg)&&(n.style.background="transparent"),t.appendChild(n)),n.style.display="";const s=n.querySelector(".atk-loading-spinner");s&&(s.style.display="none",window.setTimeout((()=>{s.isConnected&&(s.style.display="")}),500))}function Ft(t){const e=t.querySelector(":scope > .atk-loading");e&&(e.style.display="none")}function Wt(t,e){t?_t(e):Ft(e)}function Nt(t,e=!0,n){let s;if(n){const e=n.getBoundingClientRect();s=t.getBoundingClientRect().top-e.top+n.scrollTop-n.clientHeight/2+t.clientHeight/2}else{const e=t.getBoundingClientRect();s=e.top+window.scrollY-(window.innerHeight/2-e.height/2)}const i={top:s,left:0,behavior:"instant"};n?n.scroll(i):window.scroll(i)}function Ht(t,e){!function(t,e,n="in"){t.classList.add(`atk-fade-${n}`);const s=()=>{t.classList.remove(`atk-fade-${n}`),t.removeEventListener("animationend",s)};t.addEventListener("animationend",s)}(t,0,"in")}function Vt(t,e,n='<span class="atk-error-title">Artalk Error</span>'){let s=t.querySelector(".atk-error-layer");if(null===e)return void(null!==s&&s.remove());s||(s=p(`<div class="atk-error-layer">${n}<span class="atk-error-text"></span></div>`),t.appendChild(s));const i=s.querySelector(".atk-error-text");i.innerHTML="",null!==e&&(e instanceof HTMLElement?i.appendChild(e):i.innerText=e)}class zt extends Ot{constructor(t){super(t),h(this,"emoticons",[]),h(this,"loadingTask",null),h(this,"$grpWrap"),h(this,"$grpSwitcher"),h(this,"isListLoaded",!1),h(this,"isImgLoaded",!1),this.kit.useMounted((()=>{this.usePanel('<div class="atk-editor-plug-emoticons"></div>'),this.useBtn(`<i aria-label="${L("emoticon")}"><svg fill="currentColor" aria-hidden="true" height="14" viewBox="0 0 14 14" width="14"><path d="m4.26829 5.29294c0-.94317.45893-1.7074 1.02439-1.7074.56547 0 1.02439.76423 1.02439 1.7074s-.45892 1.7074-1.02439 1.7074c-.56546 0-1.02439-.76423-1.02439-1.7074zm4.43903 1.7074c.56546 0 1.02439-.76423 1.02439-1.7074s-.45893-1.7074-1.02439-1.7074c-.56547 0-1.02439.76423-1.02439 1.7074s.45892 1.7074 1.02439 1.7074zm-1.70732 2.73184c-1.51883 0-2.06312-1.52095-2.08361-1.58173l-1.29551.43231c.03414.10244.868 2.51604 3.3798 2.51604 2.51181 0 3.34502-2.41291 3.37982-2.51604l-1.29484-.43573c-.02254.06488-.56683 1.58583-2.08498 1.58583zm7-2.73252c0 3.86004-3.1401 7.00034-7 7.00034s-7-3.1396-7-6.99966c0-3.86009 3.1401-7.00034 7-7.00034s7 3.14025 7 7.00034zm-1.3659 0c0-3.10679-2.5275-5.63442-5.6341-5.63442-3.10663 0-5.63415 2.52832-5.63415 5.6351 0 3.10676 2.52752 5.63446 5.63415 5.63446 3.1066 0 5.6341-2.5277 5.6341-5.63446z"/></svg></i>`)})),this.kit.useUnmounted((()=>{})),this.useContentTransformer((t=>this.transEmoticonImageText(t))),this.usePanelShow((()=>{(()=>{u(this,null,(function*(){yield this.loadEmoticonsData(),this.isImgLoaded||(this.initEmoticonsList(),this.isImgLoaded=!0),setTimeout((()=>{this.changeListHeight()}),30)}))})()})),this.usePanelHide((()=>{this.$panel.parentElement.style.height=""})),window.setTimeout((()=>{this.loadEmoticonsData()}),1e3)}loadEmoticonsData(){return u(this,null,(function*(){this.isListLoaded||(null===this.loadingTask?(this.loadingTask=(()=>u(this,null,(function*(){_t(this.$panel),this.emoticons=yield this.handleData(this.kit.useConf().emoticons),Ft(this.$panel),this.loadingTask=null,this.isListLoaded=!0})))(),yield this.loadingTask):yield this.loadingTask)}))}handleData(t){return u(this,null,(function*(){if(!Array.isArray(t)&&["object","string"].includes(typeof t)&&(t=[t]),!Array.isArray(t))return Vt(this.$panel,`[${L("emoticon")}] Data must be of Array/Object/String type`),Ft(this.$panel),[];const e=e=>{"object"==typeof e&&(e.name&&t.find((t=>t.name===e.name))||t.push(e))},n=t=>u(this,null,(function*(){yield Promise.all(t.map(((t,s)=>u(this,null,(function*(){if("object"!=typeof t||Array.isArray(t)){if(Array.isArray(t))yield n(t);else if("string"==typeof t){const s=yield this.remoteLoad(t);Array.isArray(s)?yield n(s):"object"==typeof s&&e(s)}}else e(t)})))))}));return yield n(t),t.forEach((t=>{if(this.isOwOFormat(t)){this.convertOwO(t).forEach((t=>{e(t)}))}else Array.isArray(t)&&t.forEach((t=>{e(t)}))})),t=t.filter((t=>"object"==typeof t&&!Array.isArray(t)&&!!t&&!!t.name)),this.solveNullKey(t),this.solveSameKey(t),t}))}remoteLoad(t){return u(this,null,(function*(){if(!t)return[];try{const e=yield fetch(t);return yield e.json()}catch(e){return Ft(this.$panel),console.error("[Emoticons] Load Failed:",e),Vt(this.$panel,`[${L("emoticon")}] ${L("loadFail")}: ${String(e)}`),[]}}))}solveNullKey(t){t.forEach((t=>{t.items.forEach(((e,n)=>{e.key||(e.key=`${t.name} ${n+1}`)}))}))}solveSameKey(t){const e={};t.forEach((t=>{t.items.forEach((t=>{t.key&&""!==String(t.key).trim()&&(e[t.key]?e[t.key]++:e[t.key]=1,e[t.key]>1&&(t.key=`${t.key} ${e[t.key]}`))}))}))}isOwOFormat(t){try{return"object"==typeof t&&!!Object.values(t).length&&Array.isArray(Object.keys(Object.values(t)[0].container))&&Object.keys(Object.values(t)[0].container[0]).includes("icon")}catch(e){return!1}}convertOwO(t){const e=[];return Object.entries(t).forEach((([t,n])=>{const s={name:t,type:n.type,items:[]};n.container.forEach(((e,n)=>{const i=e.icon;if(/<(img|IMG)/.test(i)){const t=/src=["'](.*?)["']/.exec(i);t&&t.length>1&&(e.icon=t[1])}s.items.push({key:e.text||`${t} ${n+1}`,val:e.icon})})),e.push(s)})),e}initEmoticonsList(){this.$grpWrap=p('<div class="atk-grp-wrap"></div>'),this.$panel.append(this.$grpWrap),this.emoticons.forEach(((t,e)=>{const n=p('<div class="atk-grp" style="display: none;"></div>');this.$grpWrap.append(n),n.setAttribute("data-index",String(e)),n.setAttribute("data-grp-name",t.name),n.setAttribute("data-type",t.type),t.items.forEach((e=>{const s=p('<span class="atk-item"></span>');if(n.append(s),e.key&&!new RegExp(`^(${t.name})?\\s?[0-9]+$`).test(e.key)&&s.setAttribute("title",e.key),"image"===t.type){const t=document.createElement("img");t.src=e.val,t.alt=e.key,s.append(t)}else s.innerText=e.val;s.onclick=()=>{"image"===t.type?this.kit.useEditor().insertContent(`:[${e.key}]`):this.kit.useEditor().insertContent(e.val||"")}}))})),this.emoticons.length>1&&(this.$grpSwitcher=p('<div class="atk-grp-switcher"></div>'),this.$panel.append(this.$grpSwitcher),this.emoticons.forEach(((t,e)=>{const n=p("<span />");n.innerText=t.name,n.setAttribute("data-index",String(e)),n.onclick=()=>this.openGrp(e),this.$grpSwitcher.append(n)}))),this.emoticons.length>0&&this.openGrp(0)}openGrp(t){var e,n,s;Array.from(this.$grpWrap.children).forEach((e=>{const n=e;n.getAttribute("data-index")!==String(t)?n.style.display="none":n.style.display=""})),null==(e=this.$grpSwitcher)||e.querySelectorAll("span.active").forEach((t=>t.classList.remove("active"))),null==(s=null==(n=this.$grpSwitcher)?void 0:n.querySelector(`span[data-index="${t}"]`))||s.classList.add("active"),this.changeListHeight()}changeListHeight(){}transEmoticonImageText(t){return this.emoticons&&Array.isArray(this.emoticons)?(this.emoticons.forEach((e=>{"image"===e.type&&Object.entries(e.items).forEach((([e,n])=>{t=t.split(`:[${n.key}]`).join(`<img src="${n.val}" atk-emoticon="${n.key}">`)}))})),t):t}}const Kt=["png","jpg","jpeg","gif","bmp","svg","webp"];class Qt extends Ot{constructor(t){super(t),h(this,"$imgUploadInput"),this.kit.useMounted((()=>this.init())),this.initDragImg()}init(){this.$imgUploadInput=document.createElement("input"),this.$imgUploadInput.type="file",this.$imgUploadInput.style.display="none",this.$imgUploadInput.accept=Kt.map((t=>`.${t}`)).join(",");const t=this.useBtn(`<i aria-label="${L("uploadImage")}"><svg fill="currentColor" aria-hidden="true" height="14" viewBox="0 0 14 14" width="14"><path d="m0 1.94444c0-1.074107.870333-1.94444 1.94444-1.94444h10.11116c1.0741 0 1.9444.870333 1.9444 1.94444v10.11116c0 1.0741-.8703 1.9444-1.9444 1.9444h-10.11116c-1.074107 0-1.94444-.8703-1.94444-1.9444zm1.94444-.38888c-.21466 0-.38888.17422-.38888.38888v7.06689l2.33333-2.33333 2.33333 2.33333 3.88888-3.88889 2.3333 2.33334v-5.51134c0-.21466-.1742-.38888-.3888-.38888zm10.49996 8.09977-2.3333-2.33333-3.88888 3.8889-2.33333-2.33334-2.33333 2.33334v.8447c0 .2146.17422.3888.38888.3888h10.11116c.2146 0 .3888-.1742.3888-.3888zm-7.1944-6.54422c-.75133 0-1.36111.60978-1.36111 1.36111 0 .75134.60978 1.36111 1.36111 1.36111s1.36111-.60977 1.36111-1.36111c0-.75133-.60978-1.36111-1.36111-1.36111z"/></svg></i>`);t.after(this.$imgUploadInput),t.onclick=()=>{const t=this.$imgUploadInput;t.onchange=()=>{(()=>{u(this,null,(function*(){if(!t.files||0===t.files.length)return;const e=t.files[0];this.uploadImg(e)}))})()},t.click()},this.kit.useConf().imgUpload||this.$btn.setAttribute("atk-only-admin-show","")}initDragImg(){const t=t=>{if(t)for(let e=0;e<t.length;e++){const n=t[e];this.uploadImg(n)}},e=t=>{t.stopPropagation(),t.preventDefault()},n=e=>{var n;const s=null==(n=e.dataTransfer)?void 0:n.files;(null==s?void 0:s.length)&&(e.preventDefault(),t(s))},s=e=>{var n;const s=null==(n=e.clipboardData)?void 0:n.files;(null==s?void 0:s.length)&&(e.preventDefault(),t(s))};this.kit.useMounted((()=>{this.kit.useUI().$textarea.addEventListener("dragover",e),this.kit.useUI().$textarea.addEventListener("drop",n),this.kit.useUI().$textarea.addEventListener("paste",s)})),this.kit.useUnmounted((()=>{this.kit.useUI().$textarea.removeEventListener("dragover",e),this.kit.useUI().$textarea.removeEventListener("drop",n),this.kit.useUI().$textarea.removeEventListener("paste",s)}))}uploadImg(t){return u(this,null,(function*(){const e=/[^.]+$/.exec(t.name);if(!e||!Kt.includes(String(e[0]).toLowerCase()))return;if(!this.kit.useUser().checkHasBasicUserInfo())return void this.kit.useEditor().showNotify(L("uploadLoginMsg"),"w");let n="\n";""===this.kit.useUI().$textarea.value.trim()&&(n="");const s=`${n}![](Uploading ${t.name}...)`;let i;this.kit.useEditor().insertContent(s);try{const e=this.kit.useConf().imgUploader;i=e?{public_url:yield e(t)}:(yield this.kit.useApi().upload.upload({file:t})).data}catch(o){console.error(o),this.kit.useEditor().showNotify(`${L("uploadFail")}: ${o.message}`,"e")}if(i&&i.public_url){let t=i.public_url;$(t)||(t=w({base:this.kit.useConf().server,path:t})),this.kit.useEditor().setContent(this.kit.useUI().$textarea.value.replace(s,`${n}![](${t})`))}else this.kit.useEditor().setContent(this.kit.useUI().$textarea.value.replace(s,""))}))}}class Gt extends Ot{constructor(t){super(t),h(this,"isPlugPanelShow",!1),this.kit.useMounted((()=>{this.usePanel('<div class="atk-editor-plug-preview"></div>'),this.useBtn(`<i aria-label="${L("preview")}"><svg fill="currentColor" aria-hidden="true" viewBox="0 0 16 16" width="16" height="16"><path fill-rule="evenodd" 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"></path></svg></i>`)})),this.kit.useUnmounted((()=>{})),this.kit.useEvents().on("content-updated",(t=>{this.isPlugPanelShow&&this.updateContent()})),this.usePanelShow((()=>{this.isPlugPanelShow=!0,this.updateContent()})),this.usePanelHide((()=>{this.isPlugPanelShow=!1}))}updateContent(){this.$panel.innerHTML=this.kit.useEditor().getContentMarked()}}const Yt=[class extends Ot{constructor(t){super(t);const e=()=>{this.save()};this.kit.useMounted((()=>{const t=window.localStorage.getItem(Dt)||"";""!==t.trim()&&(this.kit.useEditor().showNotify(L("restoredMsg"),"i"),this.kit.useEditor().setContent(t)),this.kit.useEvents().on("content-updated",e)})),this.kit.useUnmounted((()=>{this.kit.useEvents().off("content-updated",e)}))}save(){window.localStorage.setItem(Dt,this.kit.useEditor().getContentRaw().trim())}},class extends Ot{get $inputs(){return this.kit.useEditor().getHeaderInputEls()}constructor(t){super(t);const e={},n={},s=(t,e,n)=>()=>{this.kit.useEvents().trigger(t,{field:n,$input:e})};this.kit.useMounted((()=>{Object.entries(this.$inputs).forEach((([t,i])=>{i.addEventListener("input",e[t]=s("header-input",i,t)),i.addEventListener("change",n[t]=s("header-change",i,t))}))})),this.kit.useUnmounted((()=>{Object.entries(this.$inputs).forEach((([t,s])=>{s.removeEventListener("input",e[t]),s.removeEventListener("change",n[t])}))}))}},class extends Ot{constructor(t){super(t),h(this,"query",{timer:null,abortFn:null});const e=({$input:t,field:e})=>{"edit"!==this.kit.useEditor().getState()&&(this.kit.useUser().update({[e]:t.value.trim()}),"name"!==e&&"email"!==e||this.fetchUserInfo())},n={name:L("nick"),email:L("email"),link:L("link")};this.kit.useMounted((()=>{Object.entries(this.kit.useEditor().getHeaderInputEls()).forEach((([t,e])=>{e.placeholder=n[t],e.value=this.kit.useUser().getData()[t]||""})),this.kit.useEvents().on("header-input",e)})),this.kit.useUnmounted((()=>{this.kit.useEvents().off("header-input",e)}))}fetchUserInfo(){this.kit.useUser().logout(),this.query.timer&&window.clearTimeout(this.query.timer),this.query.abortFn&&this.query.abortFn(),this.query.timer=window.setTimeout((()=>{this.query.timer=null;const t=this.kit.useApi(),e="getUserCancelToken";this.query.abortFn=()=>t.abortRequest(e),t.user.getUser(c({},t.getUserFields()),{cancelToken:e}).then((t=>this.onUserInfoFetched(t.data))).catch((t=>{})).finally((()=>{this.query.abortFn=null}))}),400)}onUserInfoFetched(t){var e;t.is_login||this.kit.useUser().logout(),this.kit.useData().updateNotifies(t.notifies),this.kit.useUser().checkHasBasicUserInfo()&&!t.is_login&&(null==(e=t.user)?void 0:e.is_admin)&&this.kit.useCheckers().checkAdmin({onSuccess:()=>{}}),t.user&&t.user.link&&(this.kit.useUI().$link.value=t.user.link,this.kit.useUser().update({link:t.user.link}))}},class extends Ot{constructor(t){super(t);const e=({field:t})=>{"link"===t&&this.onLinkInputChange()};this.kit.useMounted((()=>{this.kit.useEvents().on("header-change",e)})),this.kit.useUnmounted((()=>{this.kit.useEvents().off("header-change",e)}))}onLinkInputChange(){const t=this.kit.useUI().$link.value.trim();t&&!/^(http|https):\/\//.test(t)&&(this.kit.useUI().$link.value=`https://${t}`,this.kit.useUser().update({link:this.kit.useUI().$link.value}))}},class extends Ot{constructor(t){super(t);const e=t=>this.onKeydown(t),n=()=>this.onInput();this.kit.useMounted((()=>{this.kit.useUI().$textarea.placeholder=this.kit.useConf().placeholder||L("placeholder"),this.kit.useUI().$textarea.addEventListener("keydown",e),this.kit.useUI().$textarea.addEventListener("input",n)})),this.kit.useUnmounted((()=>{this.kit.useUI().$textarea.removeEventListener("keydown",e),this.kit.useUI().$textarea.removeEventListener("input",n)})),this.kit.useEvents().on("content-updated",(()=>{window.setTimeout((()=>{this.adaptiveHeightByContent()}),80)}))}onKeydown(t){9===(t.keyCode||t.which)&&(t.preventDefault(),this.kit.useEditor().insertContent("\t"))}onInput(){this.kit.useEvents().trigger("content-updated",this.kit.useEditor().getContentRaw())}adaptiveHeightByContent(){const t=this.kit.useUI().$textarea.offsetHeight-this.kit.useUI().$textarea.clientHeight;this.kit.useUI().$textarea.style.height="0px",this.kit.useUI().$textarea.style.height=`${this.kit.useUI().$textarea.scrollHeight+t}px`}},Bt,class extends Ot{constructor(t){super(t);const e=()=>{this.kit.useEditor().submit()};this.kit.useMounted((()=>{this.kit.useUI().$submitBtn.innerText=this.kit.useConf().sendBtn||L("send"),this.kit.useUI().$submitBtn.addEventListener("click",e)})),this.kit.useUnmounted((()=>{this.kit.useUI().$submitBtn.removeEventListener("click",e)}))}},Rt,class extends Ot{constructor(t){super(t),h(this,"comment"),this.useEditorStateEffect("reply",(t=>(this.setReply(t),()=>{this.cancelReply()}))),this.kit.useEvents().on("mounted",(()=>{const t=this.kit.useDeps(Bt);if(!t)throw Error("SubmitPlug not initialized");const e=new qt(this.kit);t.registerCustom({activeCond:()=>!!this.comment,req:()=>u(this,null,(function*(){if(!this.comment)throw new Error("reply comment cannot be empty");return(yield this.kit.useApi().comments.createComment(d(c({},yield e.getSubmitAddParams()),{rid:this.comment.id,page_key:this.commen