// ==UserScript== // @name 论坛快捷回帖 // @namespace bmqy.net // @version 3.0.3 // @author bmqy // @description 使用自定义内容或本扩展预定义的回帖内容,快捷回复支持的论坛的发帖! // @license ISC // @icon data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAEAAAABACAYAAACqaXHeAAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAA4RpVFh0WE1MOmNvbS5hZG9iZS54bXAAAAAAADw/eHBhY2tldCBiZWdpbj0i77u/IiBpZD0iVzVNME1wQ2VoaUh6cmVTek5UY3prYzlkIj8+IDx4OnhtcG1ldGEgeG1sbnM6eD0iYWRvYmU6bnM6bWV0YS8iIHg6eG1wdGs9IkFkb2JlIFhNUCBDb3JlIDUuNi1jMTM4IDc5LjE1OTgyNCwgMjAxNi8wOS8xNC0wMTowOTowMSAgICAgICAgIj4gPHJkZjpSREYgeG1sbnM6cmRmPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5LzAyLzIyLXJkZi1zeW50YXgtbnMjIj4gPHJkZjpEZXNjcmlwdGlvbiByZGY6YWJvdXQ9IiIgeG1sbnM6eG1wTU09Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC9tbS8iIHhtbG5zOnN0UmVmPSJodHRwOi8vbnMuYWRvYmUuY29tL3hhcC8xLjAvc1R5cGUvUmVzb3VyY2VSZWYjIiB4bWxuczp4bXA9Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC8iIHhtcE1NOk9yaWdpbmFsRG9jdW1lbnRJRD0ieG1wLmRpZDo1NjY1Njk3Ni1hNmQ2LWQ1NDAtYTBlZC0yOTc4MzRkMTk3N2EiIHhtcE1NOkRvY3VtZW50SUQ9InhtcC5kaWQ6RUMzMzI0MjVFQUFBMTFFNzg2NzE4QUI1NzM0QThGNTciIHhtcE1NOkluc3RhbmNlSUQ9InhtcC5paWQ6RUMzMzI0MjRFQUFBMTFFNzg2NzE4QUI1NzM0QThGNTciIHhtcDpDcmVhdG9yVG9vbD0iQWRvYmUgUGhvdG9zaG9wIENDIDIwMTcgKFdpbmRvd3MpIj4gPHhtcE1NOkRlcml2ZWRGcm9tIHN0UmVmOmluc3RhbmNlSUQ9InhtcC5paWQ6M2NjNjZkNGUtYzdhMC0wNTQwLWFiODEtZjJmYzJiMmM5MTE3IiBzdFJlZjpkb2N1bWVudElEPSJhZG9iZTpkb2NpZDpwaG90b3Nob3A6YzNjZGU3YmUtZWFhYS0xMWU3LTllYTUt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 // @homepage https://github.com/bmqy/bbs_quickreply#readme // @homepageURL https://github.com/bmqy/bbs_quickreply#readme // @source https://github.com/bmqy/bbs_quickreply.git // @supportURL https://github.com/bmqy/bbs_quickreply/issues // @match *://*/thread*.* // @match *://*/forum.php?mod==viewthread* // @match *://*/forum.php?mod=viewthread* // @match *://*/forum/forum.php?mod=viewthread* // @match *://*/forum/thread* // @match *://*/bbs/forum.php?mod=viewthread* // @match *://*/forum.php?mod=post* // @require https://cdn.jsdelivr.net/npm/vue@3.3.4/dist/vue.global.prod.js // @require data:application/javascript,%3Bwindow.Vue%3DVue%3B // @require https://cdn.jsdelivr.net/npm/element-plus@2.3.5/dist/index.full.min.js // @require https://cdn.jsdelivr.net/npm/@element-plus/icons-vue@2.1.0/dist/index.iife.min.js // @resource element-plus/dist/index.css https://cdn.jsdelivr.net/npm/element-plus@2.3.5/dist/index.css // @connect quickreply.lc.bmqy.net // @grant GM_getResourceText // @grant GM_getValue // @grant GM_info // @grant GM_setValue // @grant GM_xmlhttpRequest // @downloadURL none // ==/UserScript== (a=>{const t=document.createElement("style");t.dataset.source="vite-plugin-monkey",t.textContent=a,document.head.append(t)})(' .quickReplyBox[data-v-3bc25365]{position:relative}v-deep .el-dialog[data-v-3bc25365]{display:flex;flex-direction:column;margin:0!important;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);max-height:calc(100% - 30px);max-width:1300px;min-width:1000px}v-deep .el-dialog__body[data-v-3bc25365]{flex:1;overflow:auto;padding:0}.app-dialog-foot[data-v-3bc25365]{color:#909399;font-size:14px}.quickReplyBoxTitle[data-v-3bc25365]{margin-right:10px;font-weight:700;color:red}.el-form-item--mini.el-form-item[data-v-3bc25365],.el-form-item--small.el-form-item[data-v-3bc25365]{margin-bottom:10px}.el-select[data-v-3bc25365]{width:300px}.app-margin-right-30[data-v-340d6dc3]{margin-right:30px}.list-left[data-v-340d6dc3]{padding-right:15px;display:flex;flex:1;align-items:stretch;justify-content:start}.list-number[data-v-340d6dc3]{margin-right:5px;color:#909399}.list-title[data-v-340d6dc3]{flex:1;font-weight:400}.list-right[data-v-340d6dc3]{min-width:70px}.list-right .el-badge.item[data-v-340d6dc3]{margin-right:30px}.list li[data-v-340d6dc3]{margin-bottom:5px;padding-bottom:5px;font-size:13px;line-height:30px;display:flex;align-items:flex-start;justify-content:space-between;border-bottom:1px solid #ebeef5}.list li[data-v-340d6dc3]:hover{background-color:#f5f5f5}.tips[data-v-340d6dc3]{color:#909399;font-size:14px;text-align:center}.quickReplyLoginBox .tips[data-v-340d6dc3]{margin-left:20px;text-align:left}.addReplyBox[data-v-340d6dc3]{margin-top:15px;padding-top:10px;border-top:1px dashed #ccc}.box-card .el-card__header[data-v-340d6dc3]{padding:10px 20px}.box-card .el-card__header span[data-v-340d6dc3]{font-size:14px}.clearfix[data-v-340d6dc3]:before,.clearfix[data-v-340d6dc3]:after{display:table;content:""}.clearfix[data-v-340d6dc3]:after{clear:both}.el-pagination[data-v-340d6dc3]{padding:15px 5px 0} '); (function (vue, ElementPlus, ElementPlusIconsVue) { 'use strict'; function _interopNamespaceDefault(e) { const n = Object.create(null, { [Symbol.toStringTag]: { value: 'Module' } }); if (e) { for (const k in e) { if (k !== 'default') { const d = Object.getOwnPropertyDescriptor(e, k); Object.defineProperty(n, k, d.get ? d : { enumerable: true, get: () => e[k] }); } } } n.default = e; return Object.freeze(n); } const ElementPlusIconsVue__namespace = /*#__PURE__*/_interopNamespaceDefault(ElementPlusIconsVue); const cssLoader = (e) => { const t = GM_getResourceText(e), o = document.createElement("style"); return o.innerText = t, document.head.append(o), t; }; cssLoader("element-plus/dist/index.css"); const _export_sfc = (sfc, props) => { const target = sfc.__vccOpts || sfc; for (const [key, val] of props) { target[key] = val; } return target; }; const _hoisted_1$1 = { class: "quickReplyBox" }; const _hoisted_2$1 = { slot: "label", class: "quickReplyBoxTitle" }; const _hoisted_3$1 = { class: "app-dialog-foot" }; const _sfc_main$2 = { __name: "App", setup(__props) { const { proxy } = vue.getCurrentInstance(); const list = vue.ref([]); const currentReply = vue.ref(""); const fwin_replyLoaded = vue.ref(false); const hasEditor = vue.ref(false); const lastClickElemet = vue.ref(false); const setShow = vue.ref(false); vue.onBeforeMount(() => { getList(); }); async function getList() { let myListStorage = proxy.$storage.get(); list.value = myListStorage && myListStorage.length > 0 ? myListStorage : []; currentReply.value = ""; } function openSet() { setShow.value = !setShow.value; } function updateMyList() { let myListStorage = proxy.$storage.get(); list.value = myListStorage; } function enterReply() { if (fwin_replyLoaded.value) { enterPostReply(); } else if (hasEditor.value) { enterEditorReply(); } else { enterFastPostReply(); } } function enterPostReply() { let $postmessage = document.querySelector("#postmessage"); $postmessage.value = currentReply.value; } function enterFastPostReply() { try { let $fastpostmessage = document.querySelector( "#fastpostmessage" ); $fastpostmessage.style.background = ""; $fastpostmessage.value = currentReply.value; } catch (err) { console.log("请检查发帖权限!"); } } function enterEditorReply() { let $editorIframe = document.querySelector("#e_iframe").contentWindow.document.body; $editorIframe.style.background = ""; $editorIframe.innerHTML = currentReply.value; } function fastreBindClick() { document.querySelector("body").addEventListener( "click", (e) => { let theElement = `fastre&${e.target.href}`; if (lastClickElemet.value != theElement && e.target.className == "fastre") { lastClickElemet.value = theElement; fwin_replyLoaded.value = false; } }, true ); } function replyfastBindClick() { document.querySelector("body").addEventListener( "click", (e) => { let theElement = `replyfast&${e.target.href}`; if (lastClickElemet.value != theElement && e.target.className == "replyfast") { lastClickElemet.value = theElement; fwin_replyLoaded.value = false; } }, true ); } function flbcBindClick() { document.querySelector("body").addEventListener( "click", (e) => { let theElement = `flbc&${e.target.href}`; if (lastClickElemet.value != theElement && e.target.className == "flbc") { lastClickElemet.value = theElement; fwin_replyLoaded.value = false; } }, true ); } function checkEditor() { hasEditor.value = document.querySelector("#e_iframe"); } function postReplyMutationObserver() { let mos = new MutationObserver(function(mutations, observer) { for (const mutation in mutations) { if (Object.hasOwnProperty.call(mutations, mutation)) { const element = mutations[mutation]; if (element.target.id == "subjecthide") { fwin_replyLoaded.value = true; } } } }); mos.observe(document.querySelector("#append_parent"), { attributes: true, childList: true, subtree: true }); } const title = vue.computed(() => { return `${proxy.$app.getName()}`; }); const tips = vue.computed(() => { return `${proxy.$app.getName()}设置`; }); vue.onMounted(() => { checkEditor(); postReplyMutationObserver(); enterReply(); fastreBindClick(); replyfastBindClick(); flbcBindClick(); }); vue.watch(fwin_replyLoaded, (n) => { if (n) { let $floatlayout_reply = document.querySelector( "#floatlayout_reply" ); $floatlayout_reply.insertBefore( proxy.$el, $floatlayout_reply.childNodes[0] ); enterPostReply(); } else { let $fastposteditor = document.querySelector( "#fastposteditor" ); $fastposteditor.insertBefore( proxy.$el, $fastposteditor.childNodes[0] ); } }); vue.watch(currentReply, (n) => { n && enterReply(); }); return (_ctx, _cache) => { const _component_el_option = vue.resolveComponent("el-option"); const _component_el_select = vue.resolveComponent("el-select"); const _component_el_form_item = vue.resolveComponent("el-form-item"); const _component_el_button = vue.resolveComponent("el-button"); const _component_el_form = vue.resolveComponent("el-form"); const _component_app_set = vue.resolveComponent("app-set"); const _component_el_dialog = vue.resolveComponent("el-dialog"); return vue.openBlock(), vue.createElementBlock("div", _hoisted_1$1, [ vue.createVNode(vue.Transition, { name: "el-fade-in-linear" }, { default: vue.withCtx(() => [ vue.createVNode(_component_el_form, { inline: true, class: "demo-form-inline" }, { default: vue.withCtx(() => [ vue.createVNode(_component_el_form_item, null, { default: vue.withCtx(() => [ vue.createElementVNode("div", _hoisted_2$1, vue.toDisplayString(`${vue.unref(title)}: `), 1), vue.createVNode(_component_el_select, { modelValue: vue.unref(currentReply), "onUpdate:modelValue": _cache[0] || (_cache[0] = ($event) => vue.isRef(currentReply) ? currentReply.value = $event : null), placeholder: "请选择", "no-data-text": "这里啥都没有...", onChange: enterReply }, { default: vue.withCtx(() => [ (vue.openBlock(true), vue.createElementBlock(vue.Fragment, null, vue.renderList(vue.unref(list), (item, index) => { return vue.openBlock(), vue.createBlock(_component_el_option, { key: index, label: item, value: item }, null, 8, ["label", "value"]); }), 128)) ]), _: 1 }, 8, ["modelValue"]) ]), _: 1 }), vue.createVNode(_component_el_form_item, null, { default: vue.withCtx(() => [ vue.createVNode(_component_el_button, { type: "primary", class: "btnQuickReplySet", icon: "tools", onClick: openSet, title: vue.unref(tips) }, null, 8, ["title"]) ]), _: 1 }) ]), _: 1 }) ]), _: 1 }), vue.createVNode(_component_el_dialog, { modelValue: vue.unref(setShow), "onUpdate:modelValue": _cache[1] || (_cache[1] = ($event) => vue.isRef(setShow) ? setShow.value = $event : null), title: _ctx.$app.getName(), width: "75%", "show-close": true, "append-to-body": "" }, { default: vue.withCtx(() => [ vue.createVNode(_component_app_set, { onUpdateMyList: updateMyList }) ]), footer: vue.withCtx(() => [ vue.createElementVNode("span", _hoisted_3$1, vue.toDisplayString(`ver: ${_ctx.$app.getVersion()}`), 1) ]), _: 1 }, 8, ["modelValue", "title"]) ]); }; } }; const App = /* @__PURE__ */ _export_sfc(_sfc_main$2, [["__scopeId", "data-v-3bc25365"]]); const _withScopeId = (n) => (vue.pushScopeId("data-v-340d6dc3"), n = n(), vue.popScopeId(), n); const _hoisted_1 = { class: "setBox" }; const _hoisted_2 = /* @__PURE__ */ _withScopeId(() => /* @__PURE__ */ vue.createElementVNode("span", null, "我在用的", -1)); const _hoisted_3 = { key: 0, class: "list" }; const _hoisted_4 = { class: "list-left" }; const _hoisted_5 = { class: "list-number" }; const _hoisted_6 = { class: "list-title" }; const _hoisted_7 = { class: "list-right" }; const _hoisted_8 = { key: 1, class: "tips" }; const _hoisted_9 = /* @__PURE__ */ _withScopeId(() => /* @__PURE__ */ vue.createElementVNode("p", null, "未设置快速回帖内容!", -1)); const _hoisted_10 = [ _hoisted_9 ]; const _hoisted_11 = /* @__PURE__ */ _withScopeId(() => /* @__PURE__ */ vue.createElementVNode("span", null, "网友分享的", -1)); const _hoisted_12 = { class: "addReplyBox" }; const _sfc_main$1 = { __name: "Set", emits: ["updateMyList"], setup(__props, { emit }) { const { proxy } = vue.getCurrentInstance(); const myList = vue.ref([]); const systemList = vue.ref([]); const systemListCount = vue.ref(0); const loading = vue.ref(false); const newReply = vue.ref(""); const queryData = vue.ref({ skip: 0, prop: "replyId", order: "descending" }); vue.onBeforeMount(() => { getMyList(); getSystemList(); }); function getMyList() { let myListStorage = proxy.$storage.get(); myList.value = myListStorage && myListStorage.length > 0 ? myListStorage : []; } async function getSystemList() { loading.value = true; let res = await proxy.$api.selectList(queryData.value.skip, queryData.value.prop, queryData.value.order); systemList.value = res.data.totalCount > 0 ? res.data.list : []; systemListCount.value = res.data.totalCount; loading.value = false; } function currentPageChange(current) { queryData.value.skip = (current - 1) * 10; getSystemList(); } function sortChange(e) { queryData.value.prop = e.order ? e.prop : "replyId"; queryData.value.order = e.order ? e.order : "descending"; getSystemList(); } function addReply() { if (newReply.value == "") { proxy.$message.error("回复内容不能为空!"); return false; } if (myList.value.indexOf(newReply.value) != -1) { proxy.$message.error("该回复已添加过!"); newReply.value = ""; return false; } if (myList.value.length >= 10) { proxy.$message.warning("自定义回复,超出条数上限!"); return false; } myList.value.push(newReply.value); updateMyList(); newReply.value = ""; return true; } function updateMyList() { proxy.$storage.set(myList.value); emit("updateMyList"); } function delReply(index) { myList.value.splice(index, 1); updateMyList(); } function shareReply(index) { proxy.$api.replyInsert(myList.value[index]).then((res) => { proxy.$message.success(res.memo); }).catch((err) => { proxy.$message.error(err.memo); }); } function likeReply(index) { proxy.$api.likeCountUpdate(systemList.value[index].id).then((res) => { systemList.value[index]["likeCount"] = res.data.likeCount; proxy.$message.success(res.memo); }).catch((err) => { proxy.$message.error(err.memo); }); } function collectReply(index) { let nStr = systemList.value[index].content; if (myList.value.indexOf(nStr) != -1) { proxy.$message.error("该回复已添加过!"); return false; } newReply.value = nStr; proxy.$api.collectCountUpdate(systemList.value[index].id).then((res) => { addReply() && proxy.$message.success(res.memo); }).catch((err) => { proxy.$message.error(err.memo); }); } return (_ctx, _cache) => { const _component_el_col = vue.resolveComponent("el-col"); const _component_el_row = vue.resolveComponent("el-row"); const _component_el_button = vue.resolveComponent("el-button"); const _component_el_tooltip = vue.resolveComponent("el-tooltip"); const _component_el_card = vue.resolveComponent("el-card"); const _component_el_table_column = vue.resolveComponent("el-table-column"); const _component_el_tag = vue.resolveComponent("el-tag"); const _component_el_table = vue.resolveComponent("el-table"); const _component_el_pagination = vue.resolveComponent("el-pagination"); const _component_el_input = vue.resolveComponent("el-input"); const _directive_loading = vue.resolveDirective("loading"); return vue.openBlock(), vue.createElementBlock("div", _hoisted_1, [ vue.createVNode(_component_el_card, { class: "box-card", shadow: "never" }, { default: vue.withCtx(() => [ vue.createVNode(_component_el_row, { gutter: 30 }, { default: vue.withCtx(() => [ vue.createVNode(_component_el_col, { span: 9 }, { default: vue.withCtx(() => [ vue.createVNode(_component_el_card, { class: "box-card", shadow: "never" }, { header: vue.withCtx(() => [ vue.createVNode(_component_el_row, { gutter: 20, justify: "space-between" }, { default: vue.withCtx(() => [ vue.createVNode(_component_el_col, { span: 4, offset: 0 }, { default: vue.withCtx(() => [ _hoisted_2 ]), _: 1 }), vue.createVNode(_component_el_col, { span: 5, offset: 0 }) ]), _: 1 }) ]), default: vue.withCtx(() => [ vue.createElementVNode("div", null, [ vue.unref(myList).length > 0 ? (vue.openBlock(), vue.createElementBlock("ul", _hoisted_3, [ (vue.openBlock(true), vue.createElementBlock(vue.Fragment, null, vue.renderList(vue.unref(myList), (item, index) => { return vue.openBlock(), vue.createElementBlock("li", { key: index }, [ vue.createElementVNode("div", _hoisted_4, [ vue.createElementVNode("div", _hoisted_5, vue.toDisplayString(`${index + 1}、`), 1), vue.createElementVNode("div", _hoisted_6, vue.toDisplayString(`${item}`), 1) ]), vue.createElementVNode("div", _hoisted_7, [ vue.createVNode(_component_el_tooltip, { class: "item", effect: "dark", content: "分享它", placement: "top-start" }, { default: vue.withCtx(() => [ vue.createVNode(_component_el_button, { type: "success", size: "mini", icon: "Share", circle: "", onClick: ($event) => shareReply(index) }, null, 8, ["onClick"]) ]), _: 2 }, 1024), vue.createVNode(_component_el_tooltip, { class: "item", effect: "dark", content: "移除", placement: "top-start" }, { default: vue.withCtx(() => [ vue.createVNode(_component_el_button, { type: "danger", size: "mini", icon: "DeleteFilled", circle: "", onClick: ($event) => delReply(index) }, null, 8, ["onClick"]) ]), _: 2 }, 1024) ]) ]); }), 128)) ])) : vue.createCommentVNode("", true), vue.unref(myList).length == 0 ? (vue.openBlock(), vue.createElementBlock("div", _hoisted_8, _hoisted_10)) : vue.createCommentVNode("", true) ]) ]), _: 1 }) ]), _: 1 }), vue.createVNode(_component_el_col, { span: 15 }, { default: vue.withCtx(() => [ vue.createVNode(_component_el_card, { class: "box-card", shadow: "never", "body-style": { padding: "0 20px 20px" } }, { header: vue.withCtx(() => [ _hoisted_11 ]), default: vue.withCtx(() => [ vue.withDirectives((vue.openBlock(), vue.createBlock(_component_el_table, { ref: "filterTable", data: vue.unref(systemList), size: "small", stripe: "", onSortChange: sortChange }, { default: vue.withCtx(() => [ vue.createVNode(_component_el_table_column, { prop: "replyId", label: "ID", width: "80" }), vue.createVNode(_component_el_table_column, { prop: "content", label: "内容" }), vue.createVNode(_component_el_table_column, { prop: "likeCount", sortable: "custom", width: "100", label: "点赞" }, { default: vue.withCtx((scope) => [ vue.createVNode(_component_el_tag, { type: "info", size: "mini" }, { default: vue.withCtx(() => [ vue.createTextVNode(vue.toDisplayString(scope.row.likeCount), 1) ]), _: 2 }, 1024) ]), _: 1 }), vue.createVNode(_component_el_table_column, { label: "操作", width: "100" }, { default: vue.withCtx((scope) => [ vue.createVNode(_component_el_tooltip, { class: "item", effect: "dark", content: "给个赞", placement: "top-start" }, { default: vue.withCtx(() => [ vue.createVNode(_component_el_button, { type: "success", size: "mini", icon: "Pointer", circle: "", onClick: ($event) => likeReply(scope.$index) }, null, 8, ["onClick"]) ]), _: 2 }, 1024), vue.createVNode(_component_el_tooltip, { class: "item", effect: "dark", content: "收藏进我的", placement: "top-start" }, { default: vue.withCtx(() => [ vue.createVNode(_component_el_button, { type: "danger", size: "mini", icon: "StarFilled", circle: "", onClick: ($event) => collectReply(scope.$index) }, null, 8, ["onClick"]) ]), _: 2 }, 1024) ]), _: 1 }) ]), _: 1 }, 8, ["data"])), [ [_directive_loading, vue.unref(loading)] ]), vue.createVNode(_component_el_pagination, { background: "", layout: "prev, pager, next", "page-size": 10, "pager-count": 5, onCurrentChange: currentPageChange, total: vue.unref(systemListCount) }, null, 8, ["total"]) ]), _: 1 }) ]), _: 1 }) ]), _: 1 }), vue.createElementVNode("div", _hoisted_12, [ vue.createVNode(_component_el_input, { placeholder: "请输入新的回复内容", modelValue: vue.unref(newReply), "onUpdate:modelValue": _cache[0] || (_cache[0] = ($event) => vue.isRef(newReply) ? newReply.value = $event : null), autosize: { minRows: 1, maxRows: 3 }, maxlength: "100", "show-word-limit": true, resize: "none", clearable: "", class: "input-with-select" }, { append: vue.withCtx(() => [ vue.createVNode(_component_el_button, { icon: "Plus", onClick: addReply }) ]), _: 1 }, 8, ["modelValue"]) ]) ]), _: 1 }) ]); }; } }; const Set = /* @__PURE__ */ _export_sfc(_sfc_main$1, [["__scopeId", "data-v-340d6dc3"]]); const _sfc_main = { __name: "Login", setup(__props) { const { proxy } = vue.getCurrentInstance(); const formRef = vue.ref(); const form = vue.ref({ token: "123.75e16f652970fad2398af68c389cb2c4.YGYRkNk2oqS7LucCJ0QSSFFijEdFQnp7bglxtI5.l1mqWw" }); const rules = vue.reactive({ token: [ { required: true, message: "token不能为空", trigger: "blur" } ] }); const onSubmit = () => { formRef.value.validate(async (valid, fields) => { if (valid) { let res = await proxy.$api.selectBaiduData({ "access_token": form.value.token }); if (res.errno != 0) { proxy.$message.error(res.errmsg); return false; } proxy.$storage.setBaiduInfo("token", form.value.token); proxy.$storage.setBaiduInfo("netdisk_name", res.netdisk_name); proxy.$storage.setBaiduInfo("avatar_url", res.avatar_url); form.value.token = ""; } }); }; return (_ctx, _cache) => { const _component_el_input = vue.resolveComponent("el-input"); const _component_el_form_item = vue.resolveComponent("el-form-item"); const _component_el_button = vue.resolveComponent("el-button"); const _component_el_form = vue.resolveComponent("el-form"); return vue.openBlock(), vue.createElementBlock("div", null, [ vue.createVNode(_component_el_form, { ref_key: "formRef", ref: formRef, model: vue.unref(form), rules: vue.unref(rules), "label-width": "120px" }, { default: vue.withCtx(() => [ vue.createVNode(_component_el_form_item, { label: "Token:", prop: "token", required: "" }, { default: vue.withCtx(() => [ vue.createVNode(_component_el_input, { modelValue: vue.unref(form).token, "onUpdate:modelValue": _cache[0] || (_cache[0] = ($event) => vue.unref(form).token = $event) }, null, 8, ["modelValue"]) ]), _: 1 }), vue.createVNode(_component_el_form_item, null, { default: vue.withCtx(() => [ vue.createVNode(_component_el_button, { type: "primary", onClick: onSubmit }, { default: vue.withCtx(() => [ vue.createTextVNode("确认") ]), _: 1 }) ]), _: 1 }) ]), _: 1 }, 8, ["model", "rules"]) ]); }; } }; var _GM_getValue = /* @__PURE__ */ (() => typeof GM_getValue != "undefined" ? GM_getValue : void 0)(); var _GM_info = /* @__PURE__ */ (() => typeof GM_info != "undefined" ? GM_info : void 0)(); var _GM_setValue = /* @__PURE__ */ (() => typeof GM_setValue != "undefined" ? GM_setValue : void 0)(); var _GM_xmlhttpRequest = /* @__PURE__ */ (() => typeof GM_xmlhttpRequest != "undefined" ? GM_xmlhttpRequest : void 0)(); const Storage = { install: (app2, options) => { app2.config.globalProperties.$storage = { key: "QuickReply", set(value) { _GM_setValue(this.key, value); }, get() { if (_GM_getValue(this.key) && _GM_getValue(this.key).length > 0) { return _GM_getValue(this.key); } else { return []; } } }; app2.config.globalProperties.$app = { getName() { return _GM_info["script"]["name"]; }, getVersion: function() { return _GM_info["script"]["version"]; } }; } }; const Api = { install: (app2, options) => { app2.config.globalProperties.$api = { // http http: function(api, data) { return new Promise((resolve, reject) => { _GM_xmlhttpRequest({ method: "POST", url: `https://quickreply.lc.bmqy.net/1.1/functions${api}`, headers: { "Content-Type": "application/json; charset=utf-8", "X-LC-Id": `JLqezdmWrYQOatywxVKmB9pX-gzGzoHsz`, "X-LC-Key": `hemx77fyB2Usg317i2crcuer` }, data: `${JSON.stringify(data)}`, responseType: "json", onload: function(xhr) { if (xhr.status == 200) { resolve(xhr.response.result); } else { reject(xhr.response.result); } }, onerror: function(xhr) { reject(xhr.response); } }); }); }, // 获取网友分享的回复 selectList: async function(skip = 0, prop = "replyId", order = "descending") { return await this.http("/selectList", { skip, prop, order }); }, // 更新收藏数量 collectCountUpdate: async function(replyId) { return await this.http("/collectCountUpdate", { replyId }); }, // 更新点赞数量 likeCountUpdate: async function(replyId) { return await this.http("/likeCountUpdate", { replyId }); }, // 添加网友分享的回复 replyInsert: async function(content) { return await this.http("/replyInsert", { content }); } }; } }; const app = vue.createApp(App); for (const [key, component] of Object.entries(ElementPlusIconsVue__namespace)) { app.component(key, component); } app.component("app-set", Set); app.component("app-login", _sfc_main); app.use(ElementPlus); app.use(Storage); app.use(Api); app.mount( (() => { const $fastposteditor = document.querySelector("#fastposteditor"); const $postbox = document.querySelector("#postbox"); const $appRoot = document.createElement("div"); if ($fastposteditor) { $fastposteditor.insertBefore($appRoot, $fastposteditor.childNodes[0]); } if ($postbox) { $postbox.insertBefore($appRoot, $postbox.childNodes[4]); } return $appRoot; })() ); })(Vue, ElementPlus, ElementPlusIconsVue);