@haluo/biz 2.0.40 → 2.0.41-next.0
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/README.md +36 -34
- package/dist/haluo-biz.js +2104 -727
- package/dist/haluo-biz.umd.cjs +2133 -756
- package/dist/{squire-raw.9f05be24.js → squire-raw-1aaeff0b.js} +18 -15
- package/dist/style.css +112 -32
- package/package.json +49 -47
package/dist/haluo-biz.umd.cjs
CHANGED
|
@@ -2,9 +2,6 @@
|
|
|
2
2
|
typeof exports === "object" && typeof module !== "undefined" ? factory(exports, require("element-plus"), require("vue"), require("@element-plus/icons-vue"), require("@haluo/util"), require("vuedraggable")) : typeof define === "function" && define.amd ? define(["exports", "element-plus", "vue", "@element-plus/icons-vue", "@haluo/util", "vuedraggable"], factory) : (global2 = typeof globalThis !== "undefined" ? globalThis : global2 || self, factory(global2["haluo-biz"] = {}, global2["element-plus"], global2.Vue, global2["@element-plus/icons-vue"], global2.hUtil, global2.vuedraggable));
|
|
3
3
|
})(this, function(exports2, elementPlus, vue, iconsVue, util, draggable) {
|
|
4
4
|
"use strict";
|
|
5
|
-
const _interopDefaultLegacy = (e) => e && typeof e === "object" && "default" in e ? e : { default: e };
|
|
6
|
-
const util__default = /* @__PURE__ */ _interopDefaultLegacy(util);
|
|
7
|
-
const draggable__default = /* @__PURE__ */ _interopDefaultLegacy(draggable);
|
|
8
5
|
const __vite_glob_0_1 = "";
|
|
9
6
|
const __vite_glob_0_2 = "";
|
|
10
7
|
const __vite_glob_0_3 = "";
|
|
@@ -113,7 +110,6 @@
|
|
|
113
110
|
}
|
|
114
111
|
const D = typeof globalThis < "u" ? globalThis : typeof window < "u" ? window : typeof global < "u" ? global : typeof self < "u" ? self : {}, R = "__vueuse_ssr_handlers__";
|
|
115
112
|
D[R] = D[R] || {};
|
|
116
|
-
D[R];
|
|
117
113
|
var q;
|
|
118
114
|
(function(e) {
|
|
119
115
|
e.UP = "UP", e.RIGHT = "RIGHT", e.DOWN = "DOWN", e.LEFT = "LEFT", e.NONE = "NONE";
|
|
@@ -155,7 +151,7 @@
|
|
|
155
151
|
ke({
|
|
156
152
|
linear: me
|
|
157
153
|
}, he);
|
|
158
|
-
const J = (e) => (vue.pushScopeId("data-v-b46fc003"), e = e(), vue.popScopeId(), e), we = { class: "hd" }, Oe = { class: "bd" }, Ie = /* @__PURE__ */ J(() => /* @__PURE__ */ vue.createElementVNode("h3", null, "
|
|
154
|
+
const J = (e) => (vue.pushScopeId("data-v-b46fc003"), e = e(), vue.popScopeId(), e), we = { class: "hd" }, Oe = { class: "bd" }, Ie = /* @__PURE__ */ J(() => /* @__PURE__ */ vue.createElementVNode("h3", null, "主题颜色", -1)), Ee = { class: "tColor" }, Pe = ["onMouseover", "onClick"], Me = { class: "bColor" }, Ae = ["onMouseover", "onClick"], $e = /* @__PURE__ */ J(() => /* @__PURE__ */ vue.createElementVNode("h3", null, "标准颜色", -1)), Te = { class: "tColor" }, Be = ["onMouseover", "onClick"], Ve = {
|
|
159
155
|
name: "colorPicker"
|
|
160
156
|
}, Ne = /* @__PURE__ */ vue.defineComponent({
|
|
161
157
|
...Ve,
|
|
@@ -220,13 +216,13 @@
|
|
|
220
216
|
l.stopPropagation();
|
|
221
217
|
})
|
|
222
218
|
}, [
|
|
223
|
-
vue.createCommentVNode("
|
|
219
|
+
vue.createCommentVNode(" 颜色显示小方块 "),
|
|
224
220
|
vue.createElementVNode("div", {
|
|
225
221
|
class: vue.normalizeClass(["colorBtn", { disabled: e.disabled }]),
|
|
226
222
|
style: vue.normalizeStyle(`background-color: ${vue.unref(a)}`),
|
|
227
223
|
onClick: p
|
|
228
224
|
}, null, 6),
|
|
229
|
-
vue.createCommentVNode("
|
|
225
|
+
vue.createCommentVNode(" 颜色色盘 "),
|
|
230
226
|
vue.createElementVNode("div", {
|
|
231
227
|
class: vue.normalizeClass(["box", { open: s.value }])
|
|
232
228
|
}, [
|
|
@@ -240,7 +236,7 @@
|
|
|
240
236
|
onClick: Y,
|
|
241
237
|
onMouseover: r[0] || (r[0] = (l) => d(e.defaultColor)),
|
|
242
238
|
onMouseout: r[1] || (r[1] = (l) => d(""))
|
|
243
|
-
}, "
|
|
239
|
+
}, "默认颜色", 32)
|
|
244
240
|
]),
|
|
245
241
|
vue.createElementVNode("div", Oe, [
|
|
246
242
|
Ie,
|
|
@@ -276,8 +272,8 @@
|
|
|
276
272
|
onClick: (f) => E(l)
|
|
277
273
|
}, null, 44, Be)), 64))
|
|
278
274
|
]),
|
|
279
|
-
vue.createElementVNode("h3", { onClick: X }, "
|
|
280
|
-
vue.createCommentVNode("
|
|
275
|
+
vue.createElementVNode("h3", { onClick: X }, "更多颜色..."),
|
|
276
|
+
vue.createCommentVNode(" 用以激活HTML5颜色面板 "),
|
|
281
277
|
vue.withDirectives(vue.createElementVNode("input", {
|
|
282
278
|
type: "color",
|
|
283
279
|
ref_key: "html5ColorEl",
|
|
@@ -311,7 +307,7 @@
|
|
|
311
307
|
colorPicker: O
|
|
312
308
|
};
|
|
313
309
|
const style = "";
|
|
314
|
-
const
|
|
310
|
+
const ToolBar_vue_vue_type_style_index_0_scoped_50235bb8_lang = "";
|
|
315
311
|
const ToolBar_vue_vue_type_style_index_1_lang = "";
|
|
316
312
|
const _export_sfc = (sfc, props) => {
|
|
317
313
|
const target = sfc.__vccOpts || sfc;
|
|
@@ -320,7 +316,7 @@
|
|
|
320
316
|
}
|
|
321
317
|
return target;
|
|
322
318
|
};
|
|
323
|
-
const _sfc_main$
|
|
319
|
+
const _sfc_main$8 = {
|
|
324
320
|
components: {
|
|
325
321
|
ElTooltip: elementPlus.ElTooltip,
|
|
326
322
|
ElDivider: elementPlus.ElDivider,
|
|
@@ -341,15 +337,15 @@
|
|
|
341
337
|
activeImgType: false,
|
|
342
338
|
activeAlign: "",
|
|
343
339
|
alignMethods: [
|
|
344
|
-
{ value: "left", name: "
|
|
345
|
-
{ value: "right", name: "
|
|
346
|
-
{ value: "center", name: "
|
|
347
|
-
{ value: "justify", name: "
|
|
340
|
+
{ value: "left", name: "左对齐" },
|
|
341
|
+
{ value: "right", name: "右对齐" },
|
|
342
|
+
{ value: "center", name: "居中对齐" },
|
|
343
|
+
{ value: "justify", name: "两端对齐" }
|
|
348
344
|
],
|
|
349
345
|
activeFontsize: "17",
|
|
350
346
|
fontsizes: [
|
|
351
|
-
{ value: "17px", name: "17", desc: "
|
|
352
|
-
{ value: "18px", name: "18", desc: "
|
|
347
|
+
{ value: "17px", name: "17", desc: "默认正文字号" },
|
|
348
|
+
{ value: "18px", name: "18", desc: "默认标题字号" },
|
|
353
349
|
{ value: "19px", name: "19" },
|
|
354
350
|
{ value: "20px", name: "20" },
|
|
355
351
|
{ value: "24px", name: "24" },
|
|
@@ -430,7 +426,7 @@
|
|
|
430
426
|
this.editor.clearFormat();
|
|
431
427
|
},
|
|
432
428
|
setColor(val) {
|
|
433
|
-
console.log("
|
|
429
|
+
console.log("文字颜色");
|
|
434
430
|
this.updatePosition(() => {
|
|
435
431
|
this.editor.setColor(val);
|
|
436
432
|
});
|
|
@@ -489,6 +485,7 @@
|
|
|
489
485
|
this.popoverVisibleList = false;
|
|
490
486
|
this.popoverVisibleImg = false;
|
|
491
487
|
},
|
|
488
|
+
// todo 富文本设置样式位置会回到顶部
|
|
492
489
|
updatePosition(fn) {
|
|
493
490
|
const scrollTop = document.documentElement.scrollTop;
|
|
494
491
|
fn && fn();
|
|
@@ -521,13 +518,13 @@
|
|
|
521
518
|
}
|
|
522
519
|
}
|
|
523
520
|
};
|
|
524
|
-
const _hoisted_1$
|
|
521
|
+
const _hoisted_1$8 = {
|
|
525
522
|
key: 0,
|
|
526
523
|
class: "tools"
|
|
527
524
|
};
|
|
528
|
-
const _hoisted_2$
|
|
529
|
-
const _hoisted_3$
|
|
530
|
-
const _hoisted_4$
|
|
525
|
+
const _hoisted_2$5 = { class: "tools-content" };
|
|
526
|
+
const _hoisted_3$5 = ["src"];
|
|
527
|
+
const _hoisted_4$3 = ["src"];
|
|
531
528
|
const _hoisted_5$3 = ["src"];
|
|
532
529
|
const _hoisted_6$2 = { class: "box" };
|
|
533
530
|
const _hoisted_7$2 = ["src"];
|
|
@@ -568,9 +565,9 @@
|
|
|
568
565
|
key: 0,
|
|
569
566
|
class: "box-mask"
|
|
570
567
|
};
|
|
571
|
-
const _hoisted_30
|
|
572
|
-
const _hoisted_31
|
|
573
|
-
const _hoisted_32
|
|
568
|
+
const _hoisted_30 = { class: "box" };
|
|
569
|
+
const _hoisted_31 = ["src"];
|
|
570
|
+
const _hoisted_32 = ["src"];
|
|
574
571
|
const _hoisted_33 = ["src"];
|
|
575
572
|
const _hoisted_34 = ["src"];
|
|
576
573
|
const _hoisted_35 = { class: "tools-title" };
|
|
@@ -587,18 +584,18 @@
|
|
|
587
584
|
const _hoisted_43 = ["src"];
|
|
588
585
|
const _hoisted_44 = ["src"];
|
|
589
586
|
const _hoisted_45 = ["src"];
|
|
590
|
-
function _sfc_render$
|
|
587
|
+
function _sfc_render$4(_ctx, _cache, $props, $setup, $data, $options) {
|
|
591
588
|
const _component_el_tooltip = vue.resolveComponent("el-tooltip");
|
|
592
589
|
const _component_el_divider = vue.resolveComponent("el-divider");
|
|
593
590
|
const _component_el_popover = vue.resolveComponent("el-popover");
|
|
594
591
|
const _component_colorPicker = vue.resolveComponent("colorPicker");
|
|
595
592
|
const _directive_click_outside = vue.resolveDirective("click-outside");
|
|
596
|
-
return $props.editor.fontInfo ? (vue.openBlock(), vue.createElementBlock("div", _hoisted_1$
|
|
597
|
-
vue.createElementVNode("div", _hoisted_2$
|
|
593
|
+
return $props.editor.fontInfo ? (vue.openBlock(), vue.createElementBlock("div", _hoisted_1$8, [
|
|
594
|
+
vue.createElementVNode("div", _hoisted_2$5, [
|
|
598
595
|
vue.createVNode(_component_el_tooltip, {
|
|
599
596
|
class: "item",
|
|
600
597
|
effect: "dark",
|
|
601
|
-
content: "
|
|
598
|
+
content: "撤回",
|
|
602
599
|
placement: "top"
|
|
603
600
|
}, {
|
|
604
601
|
default: vue.withCtx(() => [
|
|
@@ -610,14 +607,14 @@
|
|
|
610
607
|
height: "40",
|
|
611
608
|
alt: "",
|
|
612
609
|
onClick: _cache[0] || (_cache[0] = ($event) => $options.back($event))
|
|
613
|
-
}, null, 12, _hoisted_3$
|
|
610
|
+
}, null, 12, _hoisted_3$5)
|
|
614
611
|
]),
|
|
615
612
|
_: 1
|
|
616
613
|
}),
|
|
617
614
|
vue.createVNode(_component_el_tooltip, {
|
|
618
615
|
class: "item",
|
|
619
616
|
effect: "dark",
|
|
620
|
-
content: "
|
|
617
|
+
content: "反撤回",
|
|
621
618
|
placement: "top"
|
|
622
619
|
}, {
|
|
623
620
|
default: vue.withCtx(() => [
|
|
@@ -629,7 +626,7 @@
|
|
|
629
626
|
height: "40",
|
|
630
627
|
alt: "",
|
|
631
628
|
onClick: _cache[1] || (_cache[1] = ($event) => $options.forward($event))
|
|
632
|
-
}, null, 12, _hoisted_4$
|
|
629
|
+
}, null, 12, _hoisted_4$3)
|
|
633
630
|
]),
|
|
634
631
|
_: 1
|
|
635
632
|
}),
|
|
@@ -640,7 +637,7 @@
|
|
|
640
637
|
vue.createVNode(_component_el_tooltip, {
|
|
641
638
|
class: "item",
|
|
642
639
|
effect: "dark",
|
|
643
|
-
content: "
|
|
640
|
+
content: "清除格式",
|
|
644
641
|
placement: "top"
|
|
645
642
|
}, {
|
|
646
643
|
default: vue.withCtx(() => [
|
|
@@ -657,7 +654,7 @@
|
|
|
657
654
|
vue.createVNode(_component_el_tooltip, {
|
|
658
655
|
class: "item",
|
|
659
656
|
effect: "dark",
|
|
660
|
-
content: "
|
|
657
|
+
content: "格式刷",
|
|
661
658
|
placement: "top"
|
|
662
659
|
}, {
|
|
663
660
|
default: vue.withCtx(() => [
|
|
@@ -688,7 +685,7 @@
|
|
|
688
685
|
vue.createVNode(_component_el_tooltip, {
|
|
689
686
|
class: "item",
|
|
690
687
|
effect: "dark",
|
|
691
|
-
content: "
|
|
688
|
+
content: "字号",
|
|
692
689
|
placement: "top"
|
|
693
690
|
}, {
|
|
694
691
|
default: vue.withCtx(() => [
|
|
@@ -738,7 +735,7 @@
|
|
|
738
735
|
vue.createVNode(_component_el_tooltip, {
|
|
739
736
|
class: "item",
|
|
740
737
|
effect: "dark",
|
|
741
|
-
content: "
|
|
738
|
+
content: "标题",
|
|
742
739
|
placement: "top"
|
|
743
740
|
}, {
|
|
744
741
|
default: vue.withCtx(() => [
|
|
@@ -759,7 +756,7 @@
|
|
|
759
756
|
vue.createVNode(_component_el_tooltip, {
|
|
760
757
|
class: "item",
|
|
761
758
|
effect: "dark",
|
|
762
|
-
content: "
|
|
759
|
+
content: "加粗",
|
|
763
760
|
placement: "top"
|
|
764
761
|
}, {
|
|
765
762
|
default: vue.withCtx(() => [
|
|
@@ -787,7 +784,7 @@
|
|
|
787
784
|
vue.createVNode(_component_el_tooltip, {
|
|
788
785
|
class: "item",
|
|
789
786
|
effect: "dark",
|
|
790
|
-
content: "
|
|
787
|
+
content: "列表",
|
|
791
788
|
placement: "top"
|
|
792
789
|
}, {
|
|
793
790
|
default: vue.withCtx(() => [
|
|
@@ -821,13 +818,13 @@
|
|
|
821
818
|
onClick: _cache[8] || (_cache[8] = ($event) => $options.updatePosition(() => {
|
|
822
819
|
$options.setStyle("makeUnorderedList");
|
|
823
820
|
}))
|
|
824
|
-
}, "
|
|
821
|
+
}, "无序列表"),
|
|
825
822
|
vue.createElementVNode("li", {
|
|
826
823
|
"data-editor-id": "makeHeader",
|
|
827
824
|
onClick: _cache[9] || (_cache[9] = ($event) => $options.updatePosition(() => {
|
|
828
825
|
$options.setStyle("makeOrderedList");
|
|
829
826
|
}))
|
|
830
|
-
}, "
|
|
827
|
+
}, "有序列表")
|
|
831
828
|
])), [
|
|
832
829
|
[_directive_click_outside, $options.handlePopover]
|
|
833
830
|
])
|
|
@@ -838,7 +835,7 @@
|
|
|
838
835
|
vue.createVNode(_component_el_tooltip, {
|
|
839
836
|
class: "item",
|
|
840
837
|
effect: "dark",
|
|
841
|
-
content: "
|
|
838
|
+
content: "倾斜",
|
|
842
839
|
placement: "top"
|
|
843
840
|
}, {
|
|
844
841
|
default: vue.withCtx(() => [
|
|
@@ -858,7 +855,7 @@
|
|
|
858
855
|
vue.createVNode(_component_el_tooltip, {
|
|
859
856
|
class: "item",
|
|
860
857
|
effect: "dark",
|
|
861
|
-
content: "
|
|
858
|
+
content: "下划线",
|
|
862
859
|
placement: "top"
|
|
863
860
|
}, {
|
|
864
861
|
default: vue.withCtx(() => [
|
|
@@ -879,18 +876,18 @@
|
|
|
879
876
|
key: 0,
|
|
880
877
|
class: "item",
|
|
881
878
|
effect: "dark",
|
|
882
|
-
content: "
|
|
879
|
+
content: "链接",
|
|
883
880
|
placement: "top"
|
|
884
881
|
}, {
|
|
885
882
|
default: vue.withCtx(() => [
|
|
886
|
-
vue.createElementVNode("div", _hoisted_30
|
|
883
|
+
vue.createElementVNode("div", _hoisted_30, [
|
|
887
884
|
vue.createElementVNode("img", {
|
|
888
885
|
src: $options.getImageUrl("icon_web_link@2x.png"),
|
|
889
886
|
width: "40",
|
|
890
887
|
height: "40",
|
|
891
888
|
alt: "",
|
|
892
889
|
onClick: _cache[12] || (_cache[12] = (...args) => $options.insertLink && $options.insertLink(...args))
|
|
893
|
-
}, null, 8, _hoisted_31
|
|
890
|
+
}, null, 8, _hoisted_31)
|
|
894
891
|
])
|
|
895
892
|
]),
|
|
896
893
|
_: 1
|
|
@@ -898,7 +895,7 @@
|
|
|
898
895
|
vue.createVNode(_component_el_tooltip, {
|
|
899
896
|
class: "item",
|
|
900
897
|
effect: "dark",
|
|
901
|
-
content: "
|
|
898
|
+
content: "首行缩进",
|
|
902
899
|
placement: "top"
|
|
903
900
|
}, {
|
|
904
901
|
default: vue.withCtx(() => [
|
|
@@ -908,14 +905,14 @@
|
|
|
908
905
|
height: "40",
|
|
909
906
|
alt: "",
|
|
910
907
|
onClick: _cache[13] || (_cache[13] = ($event) => $options.setStyle("setIndent"))
|
|
911
|
-
}, null, 8, _hoisted_32
|
|
908
|
+
}, null, 8, _hoisted_32)
|
|
912
909
|
]),
|
|
913
910
|
_: 1
|
|
914
911
|
}),
|
|
915
912
|
vue.createVNode(_component_el_tooltip, {
|
|
916
913
|
class: "item",
|
|
917
914
|
effect: "dark",
|
|
918
|
-
content: "
|
|
915
|
+
content: "文字颜色",
|
|
919
916
|
placement: "top"
|
|
920
917
|
}, {
|
|
921
918
|
default: vue.withCtx(() => [
|
|
@@ -959,7 +956,7 @@
|
|
|
959
956
|
vue.createVNode(_component_el_tooltip, {
|
|
960
957
|
class: "item",
|
|
961
958
|
effect: "dark",
|
|
962
|
-
content: "
|
|
959
|
+
content: "对齐方式",
|
|
963
960
|
placement: "top"
|
|
964
961
|
}, {
|
|
965
962
|
default: vue.withCtx(() => [
|
|
@@ -1017,7 +1014,7 @@
|
|
|
1017
1014
|
vue.createVNode(_component_el_tooltip, {
|
|
1018
1015
|
class: "item",
|
|
1019
1016
|
effect: "dark",
|
|
1020
|
-
content: "
|
|
1017
|
+
content: "插入图片",
|
|
1021
1018
|
placement: "top"
|
|
1022
1019
|
}, {
|
|
1023
1020
|
default: vue.withCtx(() => [
|
|
@@ -1039,11 +1036,11 @@
|
|
|
1039
1036
|
vue.createElementVNode("li", {
|
|
1040
1037
|
class: vue.normalizeClass([$data.activeImgType === "normal" ? "active" : ""]),
|
|
1041
1038
|
onClick: _cache[18] || (_cache[18] = ($event) => $options.insertImg("normal"))
|
|
1042
|
-
}, vue.toDisplayString("
|
|
1039
|
+
}, vue.toDisplayString("上传图片"), 2),
|
|
1043
1040
|
vue.createElementVNode("li", {
|
|
1044
1041
|
class: vue.normalizeClass([$data.activeImgType === "seamless" ? "active" : ""]),
|
|
1045
1042
|
onClick: _cache[19] || (_cache[19] = ($event) => $options.insertImg("seamless"))
|
|
1046
|
-
}, vue.toDisplayString("
|
|
1043
|
+
}, vue.toDisplayString("上传无缝拼接图片"), 2)
|
|
1047
1044
|
])), [
|
|
1048
1045
|
[_directive_click_outside, $options.handlePopover]
|
|
1049
1046
|
])
|
|
@@ -1054,7 +1051,7 @@
|
|
|
1054
1051
|
key: 2,
|
|
1055
1052
|
class: "item",
|
|
1056
1053
|
effect: "dark",
|
|
1057
|
-
content: "
|
|
1054
|
+
content: "插入视频",
|
|
1058
1055
|
placement: "top"
|
|
1059
1056
|
}, {
|
|
1060
1057
|
default: vue.withCtx(() => [
|
|
@@ -1072,7 +1069,7 @@
|
|
|
1072
1069
|
key: 3,
|
|
1073
1070
|
class: "item",
|
|
1074
1071
|
effect: "dark",
|
|
1075
|
-
content: "
|
|
1072
|
+
content: "插入文章/视频",
|
|
1076
1073
|
placement: "top"
|
|
1077
1074
|
}, {
|
|
1078
1075
|
default: vue.withCtx(() => [
|
|
@@ -1090,7 +1087,7 @@
|
|
|
1090
1087
|
key: 4,
|
|
1091
1088
|
class: "item",
|
|
1092
1089
|
effect: "dark",
|
|
1093
|
-
content: "
|
|
1090
|
+
content: "采集文章",
|
|
1094
1091
|
placement: "top"
|
|
1095
1092
|
}, {
|
|
1096
1093
|
default: vue.withCtx(() => [
|
|
@@ -1107,17 +1104,15 @@
|
|
|
1107
1104
|
])
|
|
1108
1105
|
])) : vue.createCommentVNode("", true);
|
|
1109
1106
|
}
|
|
1110
|
-
const ToolBar = /* @__PURE__ */ _export_sfc(_sfc_main$
|
|
1107
|
+
const ToolBar = /* @__PURE__ */ _export_sfc(_sfc_main$8, [["render", _sfc_render$4], ["__scopeId", "data-v-50235bb8"]]);
|
|
1111
1108
|
const __vite_glob_0_0 = "";
|
|
1112
|
-
const
|
|
1113
|
-
const
|
|
1114
|
-
const
|
|
1115
|
-
const _hoisted_3$6 = /* @__PURE__ */ vue.createElementVNode("span", { class: "basic-dialog_divider" }, null, -1);
|
|
1116
|
-
const _hoisted_4$3 = {
|
|
1109
|
+
const _hoisted_1$7 = { key: 0 };
|
|
1110
|
+
const _hoisted_2$4 = { class: "basic-dialog_title" };
|
|
1111
|
+
const _hoisted_3$4 = {
|
|
1117
1112
|
key: 0,
|
|
1118
1113
|
class: "dialog-footer"
|
|
1119
1114
|
};
|
|
1120
|
-
const _sfc_main$
|
|
1115
|
+
const _sfc_main$7 = /* @__PURE__ */ vue.defineComponent({
|
|
1121
1116
|
__name: "index",
|
|
1122
1117
|
props: {
|
|
1123
1118
|
visible: { type: Boolean, default: false },
|
|
@@ -1158,24 +1153,24 @@
|
|
|
1158
1153
|
class: vue.normalizeClass(["basic-dialog", { "hide-title": !_ctx.showTitle }])
|
|
1159
1154
|
}, {
|
|
1160
1155
|
header: vue.withCtx(() => [
|
|
1161
|
-
_ctx.showTitle ? (vue.openBlock(), vue.createElementBlock("div", _hoisted_1$
|
|
1162
|
-
vue.createElementVNode("div", _hoisted_2$
|
|
1163
|
-
|
|
1156
|
+
_ctx.showTitle ? (vue.openBlock(), vue.createElementBlock("div", _hoisted_1$7, [
|
|
1157
|
+
vue.createElementVNode("div", _hoisted_2$4, [
|
|
1158
|
+
_cache[1] || (_cache[1] = vue.createElementVNode("span", { class: "basic-dialog_divider" }, null, -1)),
|
|
1164
1159
|
vue.renderSlot(_ctx.$slots, "title")
|
|
1165
1160
|
])
|
|
1166
1161
|
])) : vue.createCommentVNode("", true)
|
|
1167
1162
|
]),
|
|
1168
1163
|
footer: vue.withCtx(() => [
|
|
1169
|
-
_ctx.showBtn ? (vue.openBlock(), vue.createElementBlock("span",
|
|
1164
|
+
_ctx.showBtn ? (vue.openBlock(), vue.createElementBlock("span", _hoisted_3$4, [
|
|
1170
1165
|
vue.createVNode(vue.unref(elementPlus.ElButton), {
|
|
1171
1166
|
style: { "width": "120px", "border-color": "#cccccc", "color": "#333333" },
|
|
1172
1167
|
plain: "",
|
|
1173
1168
|
round: "",
|
|
1174
1169
|
onClick: handleClose
|
|
1175
1170
|
}, {
|
|
1176
|
-
default: vue.withCtx(() => [
|
|
1177
|
-
vue.createTextVNode("
|
|
1178
|
-
]),
|
|
1171
|
+
default: vue.withCtx(() => _cache[2] || (_cache[2] = [
|
|
1172
|
+
vue.createTextVNode("取消")
|
|
1173
|
+
])),
|
|
1179
1174
|
_: 1
|
|
1180
1175
|
}),
|
|
1181
1176
|
vue.createVNode(vue.unref(elementPlus.ElButton), {
|
|
@@ -1184,9 +1179,9 @@
|
|
|
1184
1179
|
type: "primary",
|
|
1185
1180
|
onClick: confirm
|
|
1186
1181
|
}, {
|
|
1187
|
-
default: vue.withCtx(() => [
|
|
1188
|
-
vue.createTextVNode("
|
|
1189
|
-
]),
|
|
1182
|
+
default: vue.withCtx(() => _cache[3] || (_cache[3] = [
|
|
1183
|
+
vue.createTextVNode("确认")
|
|
1184
|
+
])),
|
|
1190
1185
|
_: 1
|
|
1191
1186
|
})
|
|
1192
1187
|
])) : vue.createCommentVNode("", true)
|
|
@@ -1199,12 +1194,14 @@
|
|
|
1199
1194
|
};
|
|
1200
1195
|
}
|
|
1201
1196
|
});
|
|
1197
|
+
const index_vue_vue_type_style_index_0_lang$5 = "";
|
|
1202
1198
|
var commonjsGlobal = typeof globalThis !== "undefined" ? globalThis : typeof window !== "undefined" ? window : typeof global !== "undefined" ? global : typeof self !== "undefined" ? self : {};
|
|
1203
1199
|
function getDefaultExportFromCjs(x) {
|
|
1204
1200
|
return x && x.__esModule && Object.prototype.hasOwnProperty.call(x, "default") ? x["default"] : x;
|
|
1205
1201
|
}
|
|
1206
|
-
var date$
|
|
1207
|
-
|
|
1202
|
+
var date$2 = { exports: {} };
|
|
1203
|
+
var date = date$2.exports;
|
|
1204
|
+
Object.defineProperty(date, "__esModule", { value: true });
|
|
1208
1205
|
function replacementDate(data, fmt) {
|
|
1209
1206
|
for (var k in data) {
|
|
1210
1207
|
if (new RegExp("(" + k + ")").test(fmt)) {
|
|
@@ -1219,126 +1216,130 @@
|
|
|
1219
1216
|
}
|
|
1220
1217
|
return fmt;
|
|
1221
1218
|
}
|
|
1222
|
-
var DateClass =
|
|
1223
|
-
|
|
1224
|
-
|
|
1225
|
-
|
|
1226
|
-
|
|
1227
|
-
|
|
1228
|
-
|
|
1229
|
-
|
|
1230
|
-
|
|
1231
|
-
|
|
1232
|
-
|
|
1233
|
-
|
|
1234
|
-
"
|
|
1235
|
-
|
|
1236
|
-
|
|
1237
|
-
|
|
1238
|
-
|
|
1239
|
-
|
|
1240
|
-
|
|
1241
|
-
|
|
1219
|
+
var DateClass = (
|
|
1220
|
+
/** @class */
|
|
1221
|
+
function() {
|
|
1222
|
+
function DateClass2() {
|
|
1223
|
+
}
|
|
1224
|
+
DateClass2.prototype.format = function(date2, fmt) {
|
|
1225
|
+
if (fmt === void 0) {
|
|
1226
|
+
fmt = "YYYY-MM-DD HH:mm:ss";
|
|
1227
|
+
}
|
|
1228
|
+
if (!date2)
|
|
1229
|
+
return "";
|
|
1230
|
+
var timeData = typeof date2 === "string" ? new Date(date2.replace(/-/g, "/")) : date2;
|
|
1231
|
+
timeData = typeof date2 === "number" ? new Date(date2) : timeData;
|
|
1232
|
+
var o = {
|
|
1233
|
+
"M+": timeData.getMonth() + 1,
|
|
1234
|
+
"D+": timeData.getDate(),
|
|
1235
|
+
"h+": timeData.getHours() % 12 === 0 ? 12 : timeData.getHours() % 12,
|
|
1236
|
+
"H+": timeData.getHours(),
|
|
1237
|
+
"m+": timeData.getMinutes(),
|
|
1238
|
+
"s+": timeData.getSeconds(),
|
|
1239
|
+
"q+": Math.floor((timeData.getMonth() + 3) / 3),
|
|
1240
|
+
"S": timeData.getMilliseconds()
|
|
1241
|
+
};
|
|
1242
|
+
var week = {
|
|
1243
|
+
"0": "日",
|
|
1244
|
+
"1": "一",
|
|
1245
|
+
"2": "二",
|
|
1246
|
+
"3": "三",
|
|
1247
|
+
"4": "四",
|
|
1248
|
+
"5": "五",
|
|
1249
|
+
"6": "六"
|
|
1250
|
+
};
|
|
1251
|
+
fmt = replacementYear(timeData, fmt);
|
|
1252
|
+
if (/(E+)/.test(fmt)) {
|
|
1253
|
+
fmt = fmt.replace(RegExp.$1, (RegExp.$1.length > 1 ? RegExp.$1.length > 2 ? "星期" : "周" : "") + week["".concat(timeData.getDay(), " ")]);
|
|
1254
|
+
}
|
|
1255
|
+
return replacementDate(o, fmt);
|
|
1242
1256
|
};
|
|
1243
|
-
|
|
1244
|
-
"
|
|
1245
|
-
|
|
1246
|
-
|
|
1247
|
-
"3": "\u4E09",
|
|
1248
|
-
"4": "\u56DB",
|
|
1249
|
-
"5": "\u4E94",
|
|
1250
|
-
"6": "\u516D"
|
|
1257
|
+
DateClass2.prototype.addDaysToDate = function(date2, days) {
|
|
1258
|
+
var d = typeof date2 === "object" ? date2 : new Date(date2);
|
|
1259
|
+
d.setDate(d.getDate() + days);
|
|
1260
|
+
return d.toISOString().split("T")[0];
|
|
1251
1261
|
};
|
|
1252
|
-
|
|
1253
|
-
|
|
1254
|
-
|
|
1255
|
-
|
|
1256
|
-
|
|
1257
|
-
|
|
1258
|
-
|
|
1259
|
-
|
|
1260
|
-
|
|
1261
|
-
|
|
1262
|
-
|
|
1263
|
-
|
|
1264
|
-
|
|
1265
|
-
|
|
1266
|
-
|
|
1267
|
-
|
|
1268
|
-
|
|
1269
|
-
var hh = Math.floor(ts / 1e3 / 60 / 60 % 24);
|
|
1270
|
-
var mm = Math.floor(ts / 1e3 / 60 % 60);
|
|
1271
|
-
var ss = Math.floor(ts / 1e3 % 60);
|
|
1272
|
-
if (ts <= 0)
|
|
1273
|
-
return false;
|
|
1274
|
-
return {
|
|
1275
|
-
dd: dd < 10 ? "0".concat(dd) : dd,
|
|
1276
|
-
hh: hh < 10 ? "0".concat(hh) : hh,
|
|
1277
|
-
mm: mm < 10 ? "0".concat(mm) : mm,
|
|
1278
|
-
ss: ss < 10 ? "0".concat(ss) : ss
|
|
1262
|
+
DateClass2.prototype.remainTime = function(endTime, startTime) {
|
|
1263
|
+
if (startTime === void 0) {
|
|
1264
|
+
startTime = /* @__PURE__ */ new Date();
|
|
1265
|
+
}
|
|
1266
|
+
var ts = Number(endTime) - Number(startTime);
|
|
1267
|
+
var dd = Math.floor(ts / 1e3 / 60 / 60 / 24);
|
|
1268
|
+
var hh = Math.floor(ts / 1e3 / 60 / 60 % 24);
|
|
1269
|
+
var mm = Math.floor(ts / 1e3 / 60 % 60);
|
|
1270
|
+
var ss = Math.floor(ts / 1e3 % 60);
|
|
1271
|
+
if (ts <= 0)
|
|
1272
|
+
return false;
|
|
1273
|
+
return {
|
|
1274
|
+
dd: dd < 10 ? "0".concat(dd) : dd,
|
|
1275
|
+
hh: hh < 10 ? "0".concat(hh) : hh,
|
|
1276
|
+
mm: mm < 10 ? "0".concat(mm) : mm,
|
|
1277
|
+
ss: ss < 10 ? "0".concat(ss) : ss
|
|
1278
|
+
};
|
|
1279
1279
|
};
|
|
1280
|
-
|
|
1281
|
-
|
|
1282
|
-
|
|
1283
|
-
|
|
1284
|
-
|
|
1285
|
-
|
|
1286
|
-
|
|
1287
|
-
|
|
1288
|
-
|
|
1289
|
-
|
|
1290
|
-
|
|
1291
|
-
|
|
1292
|
-
|
|
1293
|
-
|
|
1294
|
-
|
|
1295
|
-
|
|
1296
|
-
|
|
1297
|
-
|
|
1298
|
-
|
|
1299
|
-
|
|
1300
|
-
|
|
1301
|
-
|
|
1302
|
-
|
|
1303
|
-
|
|
1304
|
-
|
|
1305
|
-
|
|
1306
|
-
|
|
1307
|
-
|
|
1308
|
-
|
|
1309
|
-
|
|
1310
|
-
|
|
1311
|
-
|
|
1312
|
-
|
|
1313
|
-
|
|
1314
|
-
|
|
1315
|
-
|
|
1316
|
-
|
|
1317
|
-
|
|
1318
|
-
|
|
1319
|
-
|
|
1320
|
-
|
|
1280
|
+
DateClass2.prototype.formatPassTime = function(startTime) {
|
|
1281
|
+
var currentTime = /* @__PURE__ */ new Date();
|
|
1282
|
+
var time = currentTime - startTime;
|
|
1283
|
+
var year = Math.floor(time / (1e3 * 60 * 60 * 24) / 30 / 12);
|
|
1284
|
+
if (year)
|
|
1285
|
+
return "".concat(year, "年前");
|
|
1286
|
+
var month = Math.floor(time / (1e3 * 60 * 60 * 24) / 30);
|
|
1287
|
+
if (month)
|
|
1288
|
+
return "".concat(month, "个月前");
|
|
1289
|
+
var day = Math.floor(time / (1e3 * 60 * 60 * 24));
|
|
1290
|
+
if (day)
|
|
1291
|
+
return "".concat(day, "天前");
|
|
1292
|
+
var hour = Math.floor(time / (1e3 * 60 * 60));
|
|
1293
|
+
if (hour)
|
|
1294
|
+
return "".concat(hour, "小时前");
|
|
1295
|
+
var min = Math.floor(time / (1e3 * 60));
|
|
1296
|
+
if (min)
|
|
1297
|
+
return "".concat(min, "分钟前");
|
|
1298
|
+
else
|
|
1299
|
+
return "刚刚";
|
|
1300
|
+
};
|
|
1301
|
+
DateClass2.prototype.formatPassTimeForList = function(time) {
|
|
1302
|
+
return DateClass2.prototype.formatPassTimeForDetail(time, "YYYY年MM月DD日", true);
|
|
1303
|
+
};
|
|
1304
|
+
DateClass2.prototype.formatPassTimeForDetail = function(time, fmt, noYear) {
|
|
1305
|
+
if (fmt === void 0) {
|
|
1306
|
+
fmt = "YYYY-MM-DD";
|
|
1307
|
+
}
|
|
1308
|
+
var date2 = typeof time === "number" ? new Date(time) : new Date((time || "").replace(/-/g, "/"));
|
|
1309
|
+
var diff = ((/* @__PURE__ */ new Date()).getTime() - date2.getTime()) / 1e3;
|
|
1310
|
+
var dayDiff = Math.floor(diff / 86400);
|
|
1311
|
+
var isValidDate = Object.prototype.toString.call(date2) === "[object Date]" && !isNaN(date2.getTime());
|
|
1312
|
+
if (!isValidDate)
|
|
1313
|
+
return "";
|
|
1314
|
+
var formatDate = function() {
|
|
1315
|
+
var today = new Date(date2);
|
|
1316
|
+
var o = {
|
|
1317
|
+
"Y+": today.getFullYear(),
|
|
1318
|
+
"M+": ("0" + (today.getMonth() + 1)).slice(-2),
|
|
1319
|
+
"D+": ("0" + today.getDate()).slice(-2)
|
|
1320
|
+
};
|
|
1321
|
+
fmt = replacementYear(date2, fmt);
|
|
1322
|
+
var year = today.getFullYear();
|
|
1323
|
+
if (!((/* @__PURE__ */ new Date()).getFullYear() > year) && noYear) {
|
|
1324
|
+
var backData = replacementDate(o, fmt);
|
|
1325
|
+
return backData.split("年")[1];
|
|
1326
|
+
}
|
|
1327
|
+
return replacementDate(o, fmt);
|
|
1321
1328
|
};
|
|
1322
|
-
|
|
1323
|
-
|
|
1324
|
-
if (
|
|
1325
|
-
|
|
1326
|
-
return backData.split("\u5E74")[1];
|
|
1329
|
+
if (dayDiff === -1) {
|
|
1330
|
+
return "刚刚";
|
|
1331
|
+
} else if (isNaN(dayDiff) || dayDiff < 0 || dayDiff >= 15) {
|
|
1332
|
+
return formatDate();
|
|
1327
1333
|
}
|
|
1328
|
-
return
|
|
1334
|
+
return dayDiff === 0 && (diff < 60 && "刚刚" || diff < 120 && "1分钟前" || diff < 3600 && Math.floor(diff / 60) + "分钟前" || diff < 7200 && "1小时前" || diff < 86400 && Math.floor(diff / 3600) + "小时前") || dayDiff < 16 && dayDiff + "天前";
|
|
1329
1335
|
};
|
|
1330
|
-
|
|
1331
|
-
|
|
1332
|
-
|
|
1333
|
-
|
|
1334
|
-
|
|
1335
|
-
|
|
1336
|
-
|
|
1337
|
-
return DateClass2;
|
|
1338
|
-
}();
|
|
1339
|
-
date$1.exports = new DateClass();
|
|
1340
|
-
const date = /* @__PURE__ */ getDefaultExportFromCjs(date$1.exports);
|
|
1341
|
-
var tools$1 = { exports: {} };
|
|
1336
|
+
return DateClass2;
|
|
1337
|
+
}()
|
|
1338
|
+
);
|
|
1339
|
+
date$2.exports = new DateClass();
|
|
1340
|
+
var dateExports = date$2.exports;
|
|
1341
|
+
const date$1 = /* @__PURE__ */ getDefaultExportFromCjs(dateExports);
|
|
1342
|
+
var tools$2 = { exports: {} };
|
|
1342
1343
|
var _listCacheClear;
|
|
1343
1344
|
var hasRequired_listCacheClear;
|
|
1344
1345
|
function require_listCacheClear() {
|
|
@@ -2245,6 +2246,7 @@
|
|
|
2245
2246
|
stubFalse_1 = stubFalse;
|
|
2246
2247
|
return stubFalse_1;
|
|
2247
2248
|
}
|
|
2249
|
+
isBuffer.exports;
|
|
2248
2250
|
var hasRequiredIsBuffer;
|
|
2249
2251
|
function requireIsBuffer() {
|
|
2250
2252
|
if (hasRequiredIsBuffer)
|
|
@@ -2324,6 +2326,7 @@
|
|
|
2324
2326
|
return _baseUnary;
|
|
2325
2327
|
}
|
|
2326
2328
|
var _nodeUtil = { exports: {} };
|
|
2329
|
+
_nodeUtil.exports;
|
|
2327
2330
|
var hasRequired_nodeUtil;
|
|
2328
2331
|
function require_nodeUtil() {
|
|
2329
2332
|
if (hasRequired_nodeUtil)
|
|
@@ -2373,7 +2376,11 @@
|
|
|
2373
2376
|
function arrayLikeKeys(value, inherited) {
|
|
2374
2377
|
var isArr = isArray(value), isArg = !isArr && isArguments(value), isBuff = !isArr && !isArg && isBuffer2(value), isType = !isArr && !isArg && !isBuff && isTypedArray(value), skipIndexes = isArr || isArg || isBuff || isType, result = skipIndexes ? baseTimes(value.length, String) : [], length = result.length;
|
|
2375
2378
|
for (var key in value) {
|
|
2376
|
-
if ((inherited || hasOwnProperty.call(value, key)) && !(skipIndexes &&
|
|
2379
|
+
if ((inherited || hasOwnProperty.call(value, key)) && !(skipIndexes && // Safari 9 has enumerable `arguments.length` in strict mode.
|
|
2380
|
+
(key == "length" || // Node.js 0.10 has enumerable non-index properties on buffers.
|
|
2381
|
+
isBuff && (key == "offset" || key == "parent") || // PhantomJS 2 has enumerable non-index properties on typed arrays.
|
|
2382
|
+
isType && (key == "buffer" || key == "byteLength" || key == "byteOffset") || // Skip index properties.
|
|
2383
|
+
isIndex(key, length)))) {
|
|
2377
2384
|
result.push(key);
|
|
2378
2385
|
}
|
|
2379
2386
|
}
|
|
@@ -2553,6 +2560,7 @@
|
|
|
2553
2560
|
return _baseAssignIn;
|
|
2554
2561
|
}
|
|
2555
2562
|
var _cloneBuffer = { exports: {} };
|
|
2563
|
+
_cloneBuffer.exports;
|
|
2556
2564
|
var hasRequired_cloneBuffer;
|
|
2557
2565
|
function require_cloneBuffer() {
|
|
2558
2566
|
if (hasRequired_cloneBuffer)
|
|
@@ -3166,13 +3174,13 @@
|
|
|
3166
3174
|
return cloneDeep_1;
|
|
3167
3175
|
}
|
|
3168
3176
|
/*! clipboard-copy. MIT License. Feross Aboukhadijeh <https://feross.org/opensource> */
|
|
3169
|
-
var
|
|
3170
|
-
var
|
|
3171
|
-
function
|
|
3172
|
-
if (
|
|
3173
|
-
return
|
|
3174
|
-
|
|
3175
|
-
|
|
3177
|
+
var clipboardCopy_1;
|
|
3178
|
+
var hasRequiredClipboardCopy;
|
|
3179
|
+
function requireClipboardCopy() {
|
|
3180
|
+
if (hasRequiredClipboardCopy)
|
|
3181
|
+
return clipboardCopy_1;
|
|
3182
|
+
hasRequiredClipboardCopy = 1;
|
|
3183
|
+
clipboardCopy_1 = clipboardCopy;
|
|
3176
3184
|
function makeError() {
|
|
3177
3185
|
return new DOMException("The request is not allowed", "NotAllowedError");
|
|
3178
3186
|
}
|
|
@@ -3215,266 +3223,270 @@
|
|
|
3215
3223
|
}
|
|
3216
3224
|
}
|
|
3217
3225
|
}
|
|
3218
|
-
return
|
|
3226
|
+
return clipboardCopy_1;
|
|
3219
3227
|
}
|
|
3220
|
-
|
|
3228
|
+
var tools = tools$2.exports;
|
|
3229
|
+
Object.defineProperty(tools, "__esModule", { value: true });
|
|
3221
3230
|
var previous = 0;
|
|
3222
3231
|
var timeout = null;
|
|
3223
|
-
var ToolsClass =
|
|
3224
|
-
|
|
3225
|
-
|
|
3226
|
-
|
|
3227
|
-
|
|
3228
|
-
|
|
3229
|
-
|
|
3230
|
-
|
|
3231
|
-
|
|
3232
|
-
|
|
3233
|
-
|
|
3234
|
-
|
|
3235
|
-
|
|
3236
|
-
|
|
3237
|
-
|
|
3238
|
-
|
|
3232
|
+
var ToolsClass = (
|
|
3233
|
+
/** @class */
|
|
3234
|
+
function() {
|
|
3235
|
+
function ToolsClass2() {
|
|
3236
|
+
var _this = this;
|
|
3237
|
+
this.stopScroll = function(className) {
|
|
3238
|
+
if (!(window && window.document)) {
|
|
3239
|
+
return new Error("仅支持浏览器");
|
|
3240
|
+
}
|
|
3241
|
+
var html = document.documentElement;
|
|
3242
|
+
html.style.overflow = "hidden";
|
|
3243
|
+
html.style.height = "100%";
|
|
3244
|
+
var body = document.body;
|
|
3245
|
+
body.style.overflow = "hidden";
|
|
3246
|
+
body.style.height = "100%";
|
|
3247
|
+
if (className) {
|
|
3248
|
+
var dom = document.querySelector(".".concat(className));
|
|
3249
|
+
dom && dom.addEventListener("touchmove", _this.__setDefault__);
|
|
3250
|
+
}
|
|
3251
|
+
};
|
|
3252
|
+
this.startScroll = function(className) {
|
|
3253
|
+
if (!(window && window.document)) {
|
|
3254
|
+
return new Error("仅支持浏览器");
|
|
3255
|
+
}
|
|
3256
|
+
var html = document.documentElement;
|
|
3257
|
+
html.style.overflow = "visible";
|
|
3258
|
+
html.style.height = "auto";
|
|
3259
|
+
var body = document.body;
|
|
3260
|
+
body.style.overflow = "visible";
|
|
3261
|
+
body.style.height = "auto";
|
|
3262
|
+
if (className) {
|
|
3263
|
+
var dom = document.querySelector(".".concat(className));
|
|
3264
|
+
dom && dom.removeEventListener("touchmove", _this.__setDefault__);
|
|
3265
|
+
}
|
|
3266
|
+
};
|
|
3267
|
+
this.objectToArray = function(obj) {
|
|
3268
|
+
var arr = [];
|
|
3269
|
+
if (typeof obj === "object") {
|
|
3270
|
+
for (var key in obj) {
|
|
3271
|
+
if (obj.hasOwnProperty(key)) {
|
|
3272
|
+
arr.push([key, obj[key]].join("="));
|
|
3273
|
+
}
|
|
3274
|
+
}
|
|
3275
|
+
}
|
|
3276
|
+
return arr;
|
|
3277
|
+
};
|
|
3278
|
+
this.convertKeyValueEnum = function(obj) {
|
|
3279
|
+
var result = {};
|
|
3280
|
+
if (typeof obj === "object") {
|
|
3281
|
+
for (var key in obj) {
|
|
3282
|
+
if (obj.hasOwnProperty(key)) {
|
|
3283
|
+
result[obj[key]] = key;
|
|
3284
|
+
}
|
|
3285
|
+
}
|
|
3286
|
+
}
|
|
3287
|
+
return result;
|
|
3288
|
+
};
|
|
3289
|
+
this.isDefined = function(val) {
|
|
3290
|
+
return val !== void 0 && val !== null;
|
|
3291
|
+
};
|
|
3292
|
+
this.__loaded__ = {};
|
|
3293
|
+
this.__setDefault__ = function(e) {
|
|
3294
|
+
e && e.preventDefault();
|
|
3295
|
+
};
|
|
3296
|
+
}
|
|
3297
|
+
ToolsClass2.prototype.deepCopy = function(data) {
|
|
3298
|
+
return JSON.parse(JSON.stringify(data));
|
|
3299
|
+
};
|
|
3300
|
+
ToolsClass2.prototype.deepCopy2 = function(obj) {
|
|
3301
|
+
var _obj = Array.isArray(obj) ? [] : {};
|
|
3302
|
+
for (var i in obj) {
|
|
3303
|
+
_obj[i] = typeof obj[i] === "object" ? this.deepCopy2(obj[i]) : obj[i];
|
|
3239
3304
|
}
|
|
3305
|
+
return _obj;
|
|
3306
|
+
};
|
|
3307
|
+
ToolsClass2.prototype.deepCopy3 = function(obj) {
|
|
3308
|
+
var deepcopy = requireCloneDeep();
|
|
3309
|
+
return deepcopy(obj);
|
|
3310
|
+
};
|
|
3311
|
+
ToolsClass2.prototype.debounce = function(func, wait) {
|
|
3312
|
+
var delay = function() {
|
|
3313
|
+
var args = arguments;
|
|
3314
|
+
if (timeout)
|
|
3315
|
+
clearTimeout(timeout);
|
|
3316
|
+
timeout = setTimeout(function() {
|
|
3317
|
+
func.apply(delay, args);
|
|
3318
|
+
}, wait);
|
|
3319
|
+
};
|
|
3320
|
+
return delay;
|
|
3240
3321
|
};
|
|
3241
|
-
|
|
3322
|
+
ToolsClass2.prototype.throttle = function(func, wait) {
|
|
3323
|
+
var delay = function() {
|
|
3324
|
+
var now = Date.now();
|
|
3325
|
+
if (now - previous > wait) {
|
|
3326
|
+
func.apply(delay, arguments);
|
|
3327
|
+
previous = now;
|
|
3328
|
+
}
|
|
3329
|
+
};
|
|
3330
|
+
return delay;
|
|
3331
|
+
};
|
|
3332
|
+
ToolsClass2.prototype.getUrlName = function(url) {
|
|
3333
|
+
return url && url.split("?")[0].split("/").reverse()[0];
|
|
3334
|
+
};
|
|
3335
|
+
ToolsClass2.prototype.loadJs = function(url) {
|
|
3336
|
+
var _this = this;
|
|
3337
|
+
if (!(window && window.document)) {
|
|
3338
|
+
return new Error("仅支持浏览器");
|
|
3339
|
+
}
|
|
3340
|
+
var name = this.getUrlName(url);
|
|
3341
|
+
var id = "js_" + name;
|
|
3342
|
+
return new Promise(function(resolve, reject) {
|
|
3343
|
+
if (_this.__loaded__[id]) {
|
|
3344
|
+
return resolve();
|
|
3345
|
+
}
|
|
3346
|
+
var script = document.createElement("script");
|
|
3347
|
+
script.type = "text/javascript";
|
|
3348
|
+
script.async = true;
|
|
3349
|
+
script.src = url;
|
|
3350
|
+
script.id = id;
|
|
3351
|
+
script.onload = function() {
|
|
3352
|
+
_this.__loaded__[id] = true;
|
|
3353
|
+
resolve();
|
|
3354
|
+
};
|
|
3355
|
+
script.onerror = function(e) {
|
|
3356
|
+
reject(e);
|
|
3357
|
+
};
|
|
3358
|
+
document.body.appendChild(script);
|
|
3359
|
+
});
|
|
3360
|
+
};
|
|
3361
|
+
ToolsClass2.prototype.loadCss = function(url) {
|
|
3362
|
+
var _this = this;
|
|
3363
|
+
if (!(window && window.document)) {
|
|
3364
|
+
return new Error("仅支持浏览器");
|
|
3365
|
+
}
|
|
3366
|
+
var name = this.getUrlName(url);
|
|
3367
|
+
var id = "css_" + name;
|
|
3368
|
+
return new Promise(function(resolve, reject) {
|
|
3369
|
+
if (_this.__loaded__[id]) {
|
|
3370
|
+
return resolve();
|
|
3371
|
+
}
|
|
3372
|
+
var link = document.createElement("link");
|
|
3373
|
+
link.type = "text/css";
|
|
3374
|
+
link.rel = "stylesheet";
|
|
3375
|
+
link.href = url;
|
|
3376
|
+
link.id = id;
|
|
3377
|
+
link.onload = function() {
|
|
3378
|
+
_this.__loaded__[id] = true;
|
|
3379
|
+
resolve();
|
|
3380
|
+
};
|
|
3381
|
+
link.onerror = function(e) {
|
|
3382
|
+
reject(e);
|
|
3383
|
+
};
|
|
3384
|
+
document.head.appendChild(link);
|
|
3385
|
+
});
|
|
3386
|
+
};
|
|
3387
|
+
ToolsClass2.prototype.clipboard = function(str) {
|
|
3242
3388
|
if (!(window && window.document)) {
|
|
3243
|
-
return new Error("
|
|
3244
|
-
}
|
|
3245
|
-
var html = document.documentElement;
|
|
3246
|
-
html.style.overflow = "visible";
|
|
3247
|
-
html.style.height = "auto";
|
|
3248
|
-
var body = document.body;
|
|
3249
|
-
body.style.overflow = "visible";
|
|
3250
|
-
body.style.height = "auto";
|
|
3251
|
-
if (className) {
|
|
3252
|
-
var dom = document.querySelector(".".concat(className));
|
|
3253
|
-
dom && dom.removeEventListener("touchmove", _this.__setDefault__);
|
|
3389
|
+
return new Error("仅支持浏览器");
|
|
3254
3390
|
}
|
|
3391
|
+
var copy = requireClipboardCopy();
|
|
3392
|
+
return copy(str);
|
|
3255
3393
|
};
|
|
3256
|
-
|
|
3257
|
-
|
|
3258
|
-
|
|
3259
|
-
|
|
3260
|
-
|
|
3261
|
-
|
|
3262
|
-
|
|
3263
|
-
|
|
3394
|
+
ToolsClass2.prototype.firstUpperCase = function(str) {
|
|
3395
|
+
return str.charAt(0).toUpperCase() + str.toString().slice(1);
|
|
3396
|
+
};
|
|
3397
|
+
ToolsClass2.prototype.slice = function(target, length) {
|
|
3398
|
+
if (target === void 0) {
|
|
3399
|
+
target = "";
|
|
3400
|
+
}
|
|
3401
|
+
if (length === void 0) {
|
|
3402
|
+
length = 0;
|
|
3264
3403
|
}
|
|
3265
|
-
return
|
|
3404
|
+
return target.slice(0, length);
|
|
3266
3405
|
};
|
|
3267
|
-
|
|
3268
|
-
|
|
3269
|
-
|
|
3270
|
-
for (var key in obj) {
|
|
3271
|
-
if (obj.hasOwnProperty(key)) {
|
|
3272
|
-
result[obj[key]] = key;
|
|
3273
|
-
}
|
|
3274
|
-
}
|
|
3406
|
+
ToolsClass2.prototype.guid = function() {
|
|
3407
|
+
function S4() {
|
|
3408
|
+
return ((1 + Math.random()) * 65536 | 0).toString(16).substring(1);
|
|
3275
3409
|
}
|
|
3276
|
-
return
|
|
3410
|
+
return S4() + S4() + "-" + S4() + "-" + S4() + "-" + S4() + "-" + S4() + S4() + S4();
|
|
3277
3411
|
};
|
|
3278
|
-
|
|
3279
|
-
|
|
3412
|
+
ToolsClass2.prototype.getBytesOfText = function(str) {
|
|
3413
|
+
if (str === void 0) {
|
|
3414
|
+
str = "";
|
|
3415
|
+
}
|
|
3416
|
+
return str.replace(/[^\u0000-\u00ff]/g, "aa").length;
|
|
3280
3417
|
};
|
|
3281
|
-
|
|
3282
|
-
|
|
3283
|
-
e && e.preventDefault();
|
|
3418
|
+
ToolsClass2.prototype.uniqueArr = function(arr) {
|
|
3419
|
+
return Array.from(new Set(arr));
|
|
3284
3420
|
};
|
|
3285
|
-
|
|
3286
|
-
|
|
3287
|
-
|
|
3288
|
-
|
|
3289
|
-
ToolsClass2.prototype.deepCopy2 = function(obj) {
|
|
3290
|
-
var _obj = Array.isArray(obj) ? [] : {};
|
|
3291
|
-
for (var i in obj) {
|
|
3292
|
-
_obj[i] = typeof obj[i] === "object" ? this.deepCopy2(obj[i]) : obj[i];
|
|
3293
|
-
}
|
|
3294
|
-
return _obj;
|
|
3295
|
-
};
|
|
3296
|
-
ToolsClass2.prototype.deepCopy3 = function(obj) {
|
|
3297
|
-
var deepcopy = requireCloneDeep();
|
|
3298
|
-
return deepcopy(obj);
|
|
3299
|
-
};
|
|
3300
|
-
ToolsClass2.prototype.debounce = function(func, wait) {
|
|
3301
|
-
var delay = function() {
|
|
3302
|
-
var args = arguments;
|
|
3303
|
-
if (timeout)
|
|
3304
|
-
clearTimeout(timeout);
|
|
3305
|
-
timeout = setTimeout(function() {
|
|
3306
|
-
func.apply(delay, args);
|
|
3307
|
-
}, wait);
|
|
3421
|
+
ToolsClass2.prototype.swapArray = function(array, index1, index2) {
|
|
3422
|
+
var _a;
|
|
3423
|
+
_a = [array[index2], array[index1]], array[index1] = _a[0], array[index2] = _a[1];
|
|
3424
|
+
return array;
|
|
3308
3425
|
};
|
|
3309
|
-
|
|
3310
|
-
|
|
3311
|
-
ToolsClass2.prototype.throttle = function(func, wait) {
|
|
3312
|
-
var delay = function() {
|
|
3313
|
-
var now = Date.now();
|
|
3314
|
-
if (now - previous > wait) {
|
|
3315
|
-
func.apply(delay, arguments);
|
|
3316
|
-
previous = now;
|
|
3317
|
-
}
|
|
3426
|
+
ToolsClass2.prototype.filterEmoji = function(str) {
|
|
3427
|
+
return str.replace(/\uD83C[\uDF00-\uDFFF]|\uD83D[\uDC00-\uDE4F]/mg, "");
|
|
3318
3428
|
};
|
|
3319
|
-
|
|
3320
|
-
|
|
3321
|
-
|
|
3322
|
-
|
|
3323
|
-
|
|
3324
|
-
|
|
3325
|
-
|
|
3326
|
-
|
|
3327
|
-
|
|
3328
|
-
|
|
3329
|
-
|
|
3330
|
-
|
|
3331
|
-
|
|
3332
|
-
if (
|
|
3333
|
-
return
|
|
3334
|
-
|
|
3335
|
-
|
|
3336
|
-
|
|
3337
|
-
|
|
3338
|
-
|
|
3339
|
-
|
|
3340
|
-
|
|
3341
|
-
|
|
3342
|
-
|
|
3343
|
-
|
|
3344
|
-
|
|
3345
|
-
|
|
3346
|
-
|
|
3347
|
-
|
|
3348
|
-
|
|
3349
|
-
};
|
|
3350
|
-
ToolsClass2.prototype.loadCss = function(url) {
|
|
3351
|
-
var _this = this;
|
|
3352
|
-
if (!(window && window.document)) {
|
|
3353
|
-
return new Error("\u4EC5\u652F\u6301\u6D4F\u89C8\u5668");
|
|
3354
|
-
}
|
|
3355
|
-
var name = this.getUrlName(url);
|
|
3356
|
-
var id = "css_" + name;
|
|
3357
|
-
return new Promise(function(resolve, reject) {
|
|
3358
|
-
if (_this.__loaded__[id]) {
|
|
3359
|
-
return resolve();
|
|
3360
|
-
}
|
|
3361
|
-
var link = document.createElement("link");
|
|
3362
|
-
link.type = "text/css";
|
|
3363
|
-
link.rel = "stylesheet";
|
|
3364
|
-
link.href = url;
|
|
3365
|
-
link.id = id;
|
|
3366
|
-
link.onload = function() {
|
|
3367
|
-
_this.__loaded__[id] = true;
|
|
3368
|
-
resolve();
|
|
3369
|
-
};
|
|
3370
|
-
link.onerror = function(e) {
|
|
3371
|
-
reject(e);
|
|
3372
|
-
};
|
|
3373
|
-
document.head.appendChild(link);
|
|
3374
|
-
});
|
|
3375
|
-
};
|
|
3376
|
-
ToolsClass2.prototype.clipboard = function(str) {
|
|
3377
|
-
if (!(window && window.document)) {
|
|
3378
|
-
return new Error("\u4EC5\u652F\u6301\u6D4F\u89C8\u5668");
|
|
3379
|
-
}
|
|
3380
|
-
var copy = require_clipboardCopy_4_0_1_clipboardCopy();
|
|
3381
|
-
return copy(str);
|
|
3382
|
-
};
|
|
3383
|
-
ToolsClass2.prototype.firstUpperCase = function(str) {
|
|
3384
|
-
return str.charAt(0).toUpperCase() + str.toString().slice(1);
|
|
3385
|
-
};
|
|
3386
|
-
ToolsClass2.prototype.slice = function(target, length) {
|
|
3387
|
-
if (target === void 0) {
|
|
3388
|
-
target = "";
|
|
3389
|
-
}
|
|
3390
|
-
if (length === void 0) {
|
|
3391
|
-
length = 0;
|
|
3392
|
-
}
|
|
3393
|
-
return target.slice(0, length);
|
|
3394
|
-
};
|
|
3395
|
-
ToolsClass2.prototype.guid = function() {
|
|
3396
|
-
function S4() {
|
|
3397
|
-
return ((1 + Math.random()) * 65536 | 0).toString(16).substring(1);
|
|
3398
|
-
}
|
|
3399
|
-
return S4() + S4() + "-" + S4() + "-" + S4() + "-" + S4() + "-" + S4() + S4() + S4();
|
|
3400
|
-
};
|
|
3401
|
-
ToolsClass2.prototype.getBytesOfText = function(str) {
|
|
3402
|
-
if (str === void 0) {
|
|
3403
|
-
str = "";
|
|
3404
|
-
}
|
|
3405
|
-
return str.replace(/[^\u0000-\u00ff]/g, "aa").length;
|
|
3406
|
-
};
|
|
3407
|
-
ToolsClass2.prototype.uniqueArr = function(arr) {
|
|
3408
|
-
return Array.from(new Set(arr));
|
|
3409
|
-
};
|
|
3410
|
-
ToolsClass2.prototype.swapArray = function(array, index1, index2) {
|
|
3411
|
-
var _a;
|
|
3412
|
-
_a = [array[index2], array[index1]], array[index1] = _a[0], array[index2] = _a[1];
|
|
3413
|
-
return array;
|
|
3414
|
-
};
|
|
3415
|
-
ToolsClass2.prototype.filterEmoji = function(str) {
|
|
3416
|
-
return str.replace(/\uD83C[\uDF00-\uDFFF]|\uD83D[\uDC00-\uDE4F]/mg, "");
|
|
3417
|
-
};
|
|
3418
|
-
ToolsClass2.prototype.containsEmoji = function(str) {
|
|
3419
|
-
var reg = /\uD83C[\uDF00-\uDFFF]|\uD83D[\uDC00-\uDE4F]/mg;
|
|
3420
|
-
return reg.test(str);
|
|
3421
|
-
};
|
|
3422
|
-
ToolsClass2.prototype.containsHanZi = function(str) {
|
|
3423
|
-
var reg = /[\u4e00-\u9fa5]/mg;
|
|
3424
|
-
return reg.test(str);
|
|
3425
|
-
};
|
|
3426
|
-
ToolsClass2.prototype.isEmpty = function(val) {
|
|
3427
|
-
if (val == null)
|
|
3428
|
-
return true;
|
|
3429
|
-
if (typeof val === "boolean")
|
|
3429
|
+
ToolsClass2.prototype.containsEmoji = function(str) {
|
|
3430
|
+
var reg = /\uD83C[\uDF00-\uDFFF]|\uD83D[\uDC00-\uDE4F]/mg;
|
|
3431
|
+
return reg.test(str);
|
|
3432
|
+
};
|
|
3433
|
+
ToolsClass2.prototype.containsHanZi = function(str) {
|
|
3434
|
+
var reg = /[\u4e00-\u9fa5]/mg;
|
|
3435
|
+
return reg.test(str);
|
|
3436
|
+
};
|
|
3437
|
+
ToolsClass2.prototype.isEmpty = function(val) {
|
|
3438
|
+
if (val == null)
|
|
3439
|
+
return true;
|
|
3440
|
+
if (typeof val === "boolean")
|
|
3441
|
+
return false;
|
|
3442
|
+
if (typeof val === "number")
|
|
3443
|
+
return !val;
|
|
3444
|
+
if (val instanceof Error)
|
|
3445
|
+
return val.message === "";
|
|
3446
|
+
switch (Object.prototype.toString.call(val)) {
|
|
3447
|
+
case "[object String]":
|
|
3448
|
+
case "[object Array]":
|
|
3449
|
+
return !val.length;
|
|
3450
|
+
case "[object File]":
|
|
3451
|
+
case "[object Map]":
|
|
3452
|
+
case "[object Set]": {
|
|
3453
|
+
return !val.size;
|
|
3454
|
+
}
|
|
3455
|
+
case "[object Object]": {
|
|
3456
|
+
return !Object.keys(val).length;
|
|
3457
|
+
}
|
|
3458
|
+
}
|
|
3430
3459
|
return false;
|
|
3431
|
-
|
|
3432
|
-
|
|
3433
|
-
|
|
3434
|
-
|
|
3435
|
-
switch (Object.prototype.toString.call(val)) {
|
|
3436
|
-
case "[object String]":
|
|
3437
|
-
case "[object Array]":
|
|
3438
|
-
return !val.length;
|
|
3439
|
-
case "[object File]":
|
|
3440
|
-
case "[object Map]":
|
|
3441
|
-
case "[object Set]": {
|
|
3442
|
-
return !val.size;
|
|
3443
|
-
}
|
|
3444
|
-
case "[object Object]": {
|
|
3445
|
-
return !Object.keys(val).length;
|
|
3460
|
+
};
|
|
3461
|
+
ToolsClass2.prototype.sensitiveField = function(field, before, after) {
|
|
3462
|
+
if (before === void 0) {
|
|
3463
|
+
before = 3;
|
|
3446
3464
|
}
|
|
3447
|
-
|
|
3448
|
-
|
|
3449
|
-
|
|
3450
|
-
|
|
3451
|
-
|
|
3452
|
-
|
|
3453
|
-
|
|
3454
|
-
|
|
3455
|
-
|
|
3456
|
-
|
|
3457
|
-
|
|
3458
|
-
|
|
3459
|
-
|
|
3460
|
-
|
|
3461
|
-
|
|
3462
|
-
|
|
3463
|
-
|
|
3464
|
-
|
|
3465
|
-
|
|
3466
|
-
|
|
3467
|
-
|
|
3468
|
-
|
|
3469
|
-
|
|
3470
|
-
|
|
3471
|
-
}
|
|
3472
|
-
tools$1.exports = new ToolsClass();
|
|
3473
|
-
const tools = /* @__PURE__ */ getDefaultExportFromCjs(tools$1.exports);
|
|
3474
|
-
const index_vue_vue_type_style_index_0_lang$3 = "";
|
|
3475
|
-
const _hoisted_1$5 = { style: { "margin-left": "20px", "color": "#FF5A25" } };
|
|
3476
|
-
const _hoisted_2$5 = { class: "insert-article" };
|
|
3477
|
-
const _hoisted_3$5 = { class: "insert-article_input" };
|
|
3465
|
+
if (after === void 0) {
|
|
3466
|
+
after = 4;
|
|
3467
|
+
}
|
|
3468
|
+
if (!field) {
|
|
3469
|
+
return "";
|
|
3470
|
+
}
|
|
3471
|
+
field = String(field);
|
|
3472
|
+
var sensitiveLen = field.length - before - after;
|
|
3473
|
+
if (sensitiveLen < 0) {
|
|
3474
|
+
sensitiveLen = 0;
|
|
3475
|
+
}
|
|
3476
|
+
var regItem = "[一-龥a-zA-Z0-9]";
|
|
3477
|
+
var regExp = "(".concat(regItem, "{").concat(before, "})").concat(regItem, "*(").concat(regItem, "{").concat(after, "})");
|
|
3478
|
+
var reg = new RegExp(regExp);
|
|
3479
|
+
return field.replace(reg, "$1".concat("*".repeat(sensitiveLen), "$2"));
|
|
3480
|
+
};
|
|
3481
|
+
return ToolsClass2;
|
|
3482
|
+
}()
|
|
3483
|
+
);
|
|
3484
|
+
tools$2.exports = new ToolsClass();
|
|
3485
|
+
var toolsExports = tools$2.exports;
|
|
3486
|
+
const tools$1 = /* @__PURE__ */ getDefaultExportFromCjs(toolsExports);
|
|
3487
|
+
const _hoisted_1$6 = { style: { "margin-left": "20px", "color": "#FF5A25" } };
|
|
3488
|
+
const _hoisted_2$3 = { class: "insert-article" };
|
|
3489
|
+
const _hoisted_3$3 = { class: "insert-article_input" };
|
|
3478
3490
|
const _hoisted_4$2 = {
|
|
3479
3491
|
key: 0,
|
|
3480
3492
|
class: "nodata"
|
|
@@ -3493,7 +3505,7 @@
|
|
|
3493
3505
|
key: 1,
|
|
3494
3506
|
style: { "display": "inline-flex", "flex-direction": "column" }
|
|
3495
3507
|
};
|
|
3496
|
-
const _sfc_main$
|
|
3508
|
+
const _sfc_main$6 = /* @__PURE__ */ vue.defineComponent({
|
|
3497
3509
|
__name: "index",
|
|
3498
3510
|
props: {
|
|
3499
3511
|
visible: { type: Boolean, default: false },
|
|
@@ -3501,7 +3513,7 @@
|
|
|
3501
3513
|
},
|
|
3502
3514
|
emits: ["change", "submit", "update:visible"],
|
|
3503
3515
|
setup(__props, { emit: __emit }) {
|
|
3504
|
-
const { debounce } = tools;
|
|
3516
|
+
const { debounce } = tools$1;
|
|
3505
3517
|
const vInfiniteScroll = elementPlus.ElInfiniteScroll;
|
|
3506
3518
|
const Radio_Type = {
|
|
3507
3519
|
MY_ARITICLE: "1",
|
|
@@ -3552,7 +3564,7 @@
|
|
|
3552
3564
|
};
|
|
3553
3565
|
const confirm = () => {
|
|
3554
3566
|
if (!data.article) {
|
|
3555
|
-
elementPlus.ElMessage.error(
|
|
3567
|
+
elementPlus.ElMessage.error(`请选择${isVideo ? "视频" : "文章"}`);
|
|
3556
3568
|
return;
|
|
3557
3569
|
}
|
|
3558
3570
|
data.article.isVideo = isVideo;
|
|
@@ -3569,11 +3581,14 @@
|
|
|
3569
3581
|
data.busy = true;
|
|
3570
3582
|
const userInfo = JSON.parse(localStorage.getItem("user")) || JSON.parse(localStorage.getItem("userInfo"));
|
|
3571
3583
|
const userId = userInfo.uid || userInfo.userid;
|
|
3584
|
+
if (!getList.value)
|
|
3585
|
+
return;
|
|
3572
3586
|
const res = await getList.value({
|
|
3573
3587
|
uid: data.params.radio !== Radio_Type.ALL_ARITICLE ? userId : "",
|
|
3574
3588
|
autherid: data.params.radio !== Radio_Type.ALL_ARITICLE ? userId : "",
|
|
3575
3589
|
limit: 20,
|
|
3576
3590
|
allType: data.params.radio,
|
|
3591
|
+
// 只有4 是查视频 其他是文章
|
|
3577
3592
|
title: data.params.title,
|
|
3578
3593
|
page: ++data.page
|
|
3579
3594
|
});
|
|
@@ -3587,27 +3602,27 @@
|
|
|
3587
3602
|
data.busy = false;
|
|
3588
3603
|
}, 1e3);
|
|
3589
3604
|
return (_ctx, _cache) => {
|
|
3590
|
-
return vue.openBlock(), vue.createBlock(_sfc_main$
|
|
3605
|
+
return vue.openBlock(), vue.createBlock(_sfc_main$7, {
|
|
3591
3606
|
visible: vue.unref(visible),
|
|
3592
3607
|
onSubmit: confirm
|
|
3593
3608
|
}, {
|
|
3594
3609
|
title: vue.withCtx(() => [
|
|
3595
3610
|
vue.createElementVNode("span", null, [
|
|
3596
|
-
vue.createTextVNode("
|
|
3597
|
-
vue.createElementVNode("strong", _hoisted_1$
|
|
3611
|
+
_cache[8] || (_cache[8] = vue.createTextVNode("插入文章/视频")),
|
|
3612
|
+
vue.createElementVNode("strong", _hoisted_1$6, "平台仅支持插入" + vue.toDisplayString(`${isVideo.value ? "2年" : "18个月"}`) + "内的推荐内容", 1)
|
|
3598
3613
|
])
|
|
3599
3614
|
]),
|
|
3600
3615
|
default: vue.withCtx(() => [
|
|
3601
|
-
vue.createElementVNode("div", _hoisted_2$
|
|
3616
|
+
vue.createElementVNode("div", _hoisted_2$3, [
|
|
3602
3617
|
vue.createElementVNode("div", null, [
|
|
3603
3618
|
vue.createVNode(vue.unref(elementPlus.ElRadio), {
|
|
3604
3619
|
modelValue: data.params.radio,
|
|
3605
3620
|
"onUpdate:modelValue": _cache[0] || (_cache[0] = ($event) => data.params.radio = $event),
|
|
3606
3621
|
label: Radio_Type.MY_ARITICLE
|
|
3607
3622
|
}, {
|
|
3608
|
-
default: vue.withCtx(() => [
|
|
3609
|
-
vue.createTextVNode("
|
|
3610
|
-
]),
|
|
3623
|
+
default: vue.withCtx(() => _cache[9] || (_cache[9] = [
|
|
3624
|
+
vue.createTextVNode("从我的文章中选择")
|
|
3625
|
+
])),
|
|
3611
3626
|
_: 1
|
|
3612
3627
|
}, 8, ["modelValue", "label"]),
|
|
3613
3628
|
vue.createVNode(vue.unref(elementPlus.ElRadio), {
|
|
@@ -3615,9 +3630,9 @@
|
|
|
3615
3630
|
"onUpdate:modelValue": _cache[1] || (_cache[1] = ($event) => data.params.radio = $event),
|
|
3616
3631
|
label: Radio_Type.MY_VIDEO
|
|
3617
3632
|
}, {
|
|
3618
|
-
default: vue.withCtx(() => [
|
|
3619
|
-
vue.createTextVNode("
|
|
3620
|
-
]),
|
|
3633
|
+
default: vue.withCtx(() => _cache[10] || (_cache[10] = [
|
|
3634
|
+
vue.createTextVNode("从我的视频中选择")
|
|
3635
|
+
])),
|
|
3621
3636
|
_: 1
|
|
3622
3637
|
}, 8, ["modelValue", "label"]),
|
|
3623
3638
|
vue.createVNode(vue.unref(elementPlus.ElRadio), {
|
|
@@ -3625,17 +3640,17 @@
|
|
|
3625
3640
|
"onUpdate:modelValue": _cache[2] || (_cache[2] = ($event) => data.params.radio = $event),
|
|
3626
3641
|
label: Radio_Type.ALL_ARITICLE
|
|
3627
3642
|
}, {
|
|
3628
|
-
default: vue.withCtx(() => [
|
|
3629
|
-
vue.createTextVNode("
|
|
3630
|
-
]),
|
|
3643
|
+
default: vue.withCtx(() => _cache[11] || (_cache[11] = [
|
|
3644
|
+
vue.createTextVNode("从所有文章中选择")
|
|
3645
|
+
])),
|
|
3631
3646
|
_: 1
|
|
3632
3647
|
}, 8, ["modelValue", "label"])
|
|
3633
3648
|
]),
|
|
3634
|
-
vue.createElementVNode("div", _hoisted_3$
|
|
3649
|
+
vue.createElementVNode("div", _hoisted_3$3, [
|
|
3635
3650
|
vue.createVNode(vue.unref(elementPlus.ElInput), {
|
|
3636
3651
|
modelValue: data.params.title,
|
|
3637
3652
|
"onUpdate:modelValue": _cache[4] || (_cache[4] = ($event) => data.params.title = $event),
|
|
3638
|
-
placeholder: isVideo.value ? "
|
|
3653
|
+
placeholder: isVideo.value ? "输入视频描述查找平台发布过的视频" : "输入标题名查找平台发过的文章",
|
|
3639
3654
|
onKeyup: _cache[5] || (_cache[5] = vue.withKeys(($event) => vue.unref(getArticleList)(true), ["enter", "native"])),
|
|
3640
3655
|
onInput: _cache[6] || (_cache[6] = ($event) => vue.unref(getArticleList)(true))
|
|
3641
3656
|
}, {
|
|
@@ -3649,7 +3664,7 @@
|
|
|
3649
3664
|
_: 1
|
|
3650
3665
|
}, 8, ["modelValue", "placeholder"])
|
|
3651
3666
|
]),
|
|
3652
|
-
data.data.length === 0 && !data.busy ? (vue.openBlock(), vue.createElementBlock("div", _hoisted_4$2, vue.toDisplayString(
|
|
3667
|
+
data.data.length === 0 && !data.busy ? (vue.openBlock(), vue.createElementBlock("div", _hoisted_4$2, vue.toDisplayString(`没有符合条件的${isVideo.value ? "视频" : "文章"}哦,你可以试试搜索其他${isVideo.value ? "视频" : "文章"}~`), 1)) : vue.withDirectives((vue.openBlock(), vue.createElementBlock("div", {
|
|
3653
3668
|
key: 1,
|
|
3654
3669
|
"infinite-scroll-immediate": false,
|
|
3655
3670
|
class: "insert-article_list",
|
|
@@ -3681,12 +3696,12 @@
|
|
|
3681
3696
|
}, null, 8, _hoisted_9$1)
|
|
3682
3697
|
]),
|
|
3683
3698
|
vue.createElementVNode("div", _hoisted_10$1, [
|
|
3684
|
-
vue.createElementVNode("span", _hoisted_11$1, vue.toDisplayString(item.content || "[
|
|
3685
|
-
vue.createElementVNode("span", null, vue.toDisplayString(vue.unref(date).format(item.createTime * 1e3, "YYYY-MM-DD hh-mm")), 1)
|
|
3699
|
+
vue.createElementVNode("span", _hoisted_11$1, vue.toDisplayString(item.content || "[无标题]"), 1),
|
|
3700
|
+
vue.createElementVNode("span", null, vue.toDisplayString(vue.unref(date$1).format(item.createTime * 1e3, "YYYY-MM-DD hh-mm")), 1)
|
|
3686
3701
|
])
|
|
3687
3702
|
])) : (vue.openBlock(), vue.createElementBlock("div", _hoisted_12$1, [
|
|
3688
|
-
vue.createElementVNode("span", null, vue.toDisplayString(item.title || "[
|
|
3689
|
-
vue.createElementVNode("span", null, vue.toDisplayString(vue.unref(date).format(item.createTime * 1e3, "YYYY-MM-DD")), 1)
|
|
3703
|
+
vue.createElementVNode("span", null, vue.toDisplayString(item.title || "[无标题]"), 1),
|
|
3704
|
+
vue.createElementVNode("span", null, vue.toDisplayString(vue.unref(date$1).format(item.createTime * 1e3, "YYYY-MM-DD")), 1)
|
|
3690
3705
|
]))
|
|
3691
3706
|
];
|
|
3692
3707
|
}),
|
|
@@ -3704,6 +3719,7 @@
|
|
|
3704
3719
|
};
|
|
3705
3720
|
}
|
|
3706
3721
|
});
|
|
3722
|
+
const index_vue_vue_type_style_index_0_lang$4 = "";
|
|
3707
3723
|
let getRandomValues;
|
|
3708
3724
|
const rnds8 = new Uint8Array(16);
|
|
3709
3725
|
function rng() {
|
|
@@ -3743,10 +3759,9 @@
|
|
|
3743
3759
|
}
|
|
3744
3760
|
return unsafeStringify(rnds);
|
|
3745
3761
|
}
|
|
3746
|
-
const
|
|
3747
|
-
const
|
|
3748
|
-
const
|
|
3749
|
-
const _hoisted_3$4 = ["onClick"];
|
|
3762
|
+
const _hoisted_1$5 = { class: "img-upload-content" };
|
|
3763
|
+
const _hoisted_2$2 = { class: "title-box" };
|
|
3764
|
+
const _hoisted_3$2 = ["onClick"];
|
|
3750
3765
|
const _hoisted_4$1 = {
|
|
3751
3766
|
key: 0,
|
|
3752
3767
|
class: "line"
|
|
@@ -3775,41 +3790,38 @@
|
|
|
3775
3790
|
key: 0,
|
|
3776
3791
|
class: "upload-wrap"
|
|
3777
3792
|
};
|
|
3778
|
-
const _hoisted_14 =
|
|
3779
|
-
const _hoisted_15 = /* @__PURE__ */ vue.createElementVNode("span", { class: "remark" }, "\u652F\u6301jpg\u3001jpeg\u3001png\u7B49\u591A\u79CD\u683C\u5F0F\uFF0C\u5355\u5F20\u56FE\u7247\u6700\u5927\u652F\u630120MB", -1);
|
|
3780
|
-
const _hoisted_16 = {
|
|
3793
|
+
const _hoisted_14 = {
|
|
3781
3794
|
key: 1,
|
|
3782
3795
|
class: "img-list"
|
|
3783
3796
|
};
|
|
3784
|
-
const
|
|
3785
|
-
const
|
|
3786
|
-
const
|
|
3797
|
+
const _hoisted_15 = ["src"];
|
|
3798
|
+
const _hoisted_16 = { class: "upload-btn" };
|
|
3799
|
+
const _hoisted_17 = {
|
|
3787
3800
|
key: 2,
|
|
3788
3801
|
class: "map-depot"
|
|
3789
3802
|
};
|
|
3790
|
-
const
|
|
3791
|
-
const
|
|
3792
|
-
const
|
|
3793
|
-
const
|
|
3794
|
-
const
|
|
3803
|
+
const _hoisted_18 = { class: "screen" };
|
|
3804
|
+
const _hoisted_19 = { key: 0 };
|
|
3805
|
+
const _hoisted_20 = { class: "tab-box" };
|
|
3806
|
+
const _hoisted_21 = ["onClick"];
|
|
3807
|
+
const _hoisted_22 = {
|
|
3795
3808
|
key: 0,
|
|
3796
3809
|
class: "line"
|
|
3797
3810
|
};
|
|
3798
|
-
const
|
|
3799
|
-
const
|
|
3800
|
-
const
|
|
3801
|
-
const
|
|
3811
|
+
const _hoisted_23 = { class: "image-list depot-image" };
|
|
3812
|
+
const _hoisted_24 = ["onClick"];
|
|
3813
|
+
const _hoisted_25 = ["src"];
|
|
3814
|
+
const _hoisted_26 = {
|
|
3802
3815
|
key: 0,
|
|
3803
3816
|
class: "shade"
|
|
3804
3817
|
};
|
|
3805
|
-
const
|
|
3806
|
-
const
|
|
3818
|
+
const _hoisted_27 = { class: "num" };
|
|
3819
|
+
const _hoisted_28 = {
|
|
3807
3820
|
key: 1,
|
|
3808
3821
|
class: "protocol-box"
|
|
3809
3822
|
};
|
|
3810
|
-
const
|
|
3811
|
-
const
|
|
3812
|
-
const _sfc_main$4 = vue.defineComponent({
|
|
3823
|
+
const _hoisted_29 = ["href"];
|
|
3824
|
+
const _sfc_main$5 = /* @__PURE__ */ vue.defineComponent({
|
|
3813
3825
|
__name: "index",
|
|
3814
3826
|
props: {
|
|
3815
3827
|
visible: { type: Boolean, default: false },
|
|
@@ -3844,7 +3856,7 @@
|
|
|
3844
3856
|
const tempImgs = [...props.imgList];
|
|
3845
3857
|
Array.from(imgFile).forEach((file) => {
|
|
3846
3858
|
if (file.size > 20 * 1024 * 1024) {
|
|
3847
|
-
elementPlus.ElMessage.error("
|
|
3859
|
+
elementPlus.ElMessage.error("单张图片最大支持20M");
|
|
3848
3860
|
return;
|
|
3849
3861
|
}
|
|
3850
3862
|
const id = v4();
|
|
@@ -3874,14 +3886,14 @@
|
|
|
3874
3886
|
const list = [
|
|
3875
3887
|
{
|
|
3876
3888
|
id: 2,
|
|
3877
|
-
value: "
|
|
3889
|
+
value: "上传图片"
|
|
3878
3890
|
}
|
|
3879
3891
|
];
|
|
3880
3892
|
activeTitle.value = 2;
|
|
3881
3893
|
if (props.imgNum < 20) {
|
|
3882
3894
|
list.unshift({
|
|
3883
3895
|
id: 1,
|
|
3884
|
-
value: "
|
|
3896
|
+
value: "正文图片"
|
|
3885
3897
|
});
|
|
3886
3898
|
activeTitle.value = 1;
|
|
3887
3899
|
getContentImgList();
|
|
@@ -3889,7 +3901,7 @@
|
|
|
3889
3901
|
if (props.chartGallery) {
|
|
3890
3902
|
list.push({
|
|
3891
3903
|
id: 3,
|
|
3892
|
-
value: isEmotofine ? "
|
|
3904
|
+
value: isEmotofine ? "电摩范图库" : "摩托范图库"
|
|
3893
3905
|
});
|
|
3894
3906
|
}
|
|
3895
3907
|
titleList.value = list;
|
|
@@ -4034,13 +4046,13 @@
|
|
|
4034
4046
|
const tabList = vue.ref([]);
|
|
4035
4047
|
const search = () => {
|
|
4036
4048
|
if (!selectData.brandId) {
|
|
4037
|
-
return elementPlus.ElMessage.error("
|
|
4049
|
+
return elementPlus.ElMessage.error("请选择品牌");
|
|
4038
4050
|
}
|
|
4039
4051
|
if (!selectData.goodId) {
|
|
4040
|
-
return elementPlus.ElMessage.error("
|
|
4052
|
+
return elementPlus.ElMessage.error("请选择车型");
|
|
4041
4053
|
}
|
|
4042
4054
|
if (!selectData.carId) {
|
|
4043
|
-
return elementPlus.ElMessage.error("
|
|
4055
|
+
return elementPlus.ElMessage.error("请选择款型");
|
|
4044
4056
|
}
|
|
4045
4057
|
tabList.value = [];
|
|
4046
4058
|
emits("update:imgList", []);
|
|
@@ -4091,13 +4103,13 @@
|
|
|
4091
4103
|
emits("update:imgList", list);
|
|
4092
4104
|
};
|
|
4093
4105
|
return (_ctx, _cache) => {
|
|
4094
|
-
return vue.openBlock(), vue.createBlock(_sfc_main$
|
|
4106
|
+
return vue.openBlock(), vue.createBlock(_sfc_main$7, {
|
|
4095
4107
|
visible: props.visible,
|
|
4096
4108
|
showTitle: false
|
|
4097
4109
|
}, {
|
|
4098
4110
|
default: vue.withCtx(() => [
|
|
4099
|
-
vue.createElementVNode("div", _hoisted_1$
|
|
4100
|
-
vue.createElementVNode("div", _hoisted_2$
|
|
4111
|
+
vue.createElementVNode("div", _hoisted_1$5, [
|
|
4112
|
+
vue.createElementVNode("div", _hoisted_2$2, [
|
|
4101
4113
|
(vue.openBlock(true), vue.createElementBlock(vue.Fragment, null, vue.renderList(titleList.value, (item, index) => {
|
|
4102
4114
|
return vue.openBlock(), vue.createElementBlock("div", {
|
|
4103
4115
|
key: index,
|
|
@@ -4106,10 +4118,10 @@
|
|
|
4106
4118
|
}, [
|
|
4107
4119
|
vue.createTextVNode(vue.toDisplayString(item.value) + " ", 1),
|
|
4108
4120
|
item.id === activeTitle.value ? (vue.openBlock(), vue.createElementBlock("div", _hoisted_4$1)) : vue.createCommentVNode("", true)
|
|
4109
|
-
], 10, _hoisted_3$
|
|
4121
|
+
], 10, _hoisted_3$2);
|
|
4110
4122
|
}), 128)),
|
|
4111
|
-
[1, 3].includes(activeTitle.value) && props.imgList.length ? (vue.openBlock(), vue.createElementBlock("div", _hoisted_5$1, "
|
|
4112
|
-
activeTitle.value === 2 && props.imgList.length > 1 ? (vue.openBlock(), vue.createElementBlock("div", _hoisted_6, vue.toDisplayString(props.imgList.length) + "
|
|
4123
|
+
[1, 3].includes(activeTitle.value) && props.imgList.length ? (vue.openBlock(), vue.createElementBlock("div", _hoisted_5$1, " 最多可选" + vue.toDisplayString(props.imgNum) + "张图片,已选" + vue.toDisplayString(props.imgList.length) + "张 ", 1)) : vue.createCommentVNode("", true),
|
|
4124
|
+
activeTitle.value === 2 && props.imgList.length > 1 ? (vue.openBlock(), vue.createElementBlock("div", _hoisted_6, vue.toDisplayString(props.imgList.length) + "张上传成功 拖动可调整顺序 ", 1)) : vue.createCommentVNode("", true)
|
|
4113
4125
|
]),
|
|
4114
4126
|
activeTitle.value === 1 ? (vue.openBlock(), vue.createElementBlock("div", _hoisted_7, [
|
|
4115
4127
|
vue.createElementVNode("div", _hoisted_8, [
|
|
@@ -4146,11 +4158,11 @@
|
|
|
4146
4158
|
]),
|
|
4147
4159
|
_: 1
|
|
4148
4160
|
}),
|
|
4149
|
-
|
|
4161
|
+
_cache[7] || (_cache[7] = vue.createElementVNode("span", null, "本地上传", -1))
|
|
4150
4162
|
]),
|
|
4151
|
-
|
|
4152
|
-
])) : (vue.openBlock(), vue.createElementBlock("div",
|
|
4153
|
-
vue.createVNode(vue.unref(
|
|
4163
|
+
_cache[8] || (_cache[8] = vue.createElementVNode("span", { class: "remark" }, "支持jpg、jpeg、png等多种格式,单张图片最大支持20MB", -1))
|
|
4164
|
+
])) : (vue.openBlock(), vue.createElementBlock("div", _hoisted_14, [
|
|
4165
|
+
vue.createVNode(vue.unref(draggable), {
|
|
4154
4166
|
modelValue: imgListTemp.value,
|
|
4155
4167
|
"onUpdate:modelValue": _cache[0] || (_cache[0] = ($event) => imgListTemp.value = $event),
|
|
4156
4168
|
handle: ".img-item",
|
|
@@ -4170,7 +4182,7 @@
|
|
|
4170
4182
|
style: { "object-fit": "contain" },
|
|
4171
4183
|
width: "120",
|
|
4172
4184
|
height: "120"
|
|
4173
|
-
}, null, 8,
|
|
4185
|
+
}, null, 8, _hoisted_15),
|
|
4174
4186
|
vue.createVNode(vue.unref(iconsVue.CircleCloseFilled), {
|
|
4175
4187
|
class: "icon pointer",
|
|
4176
4188
|
onClick: ($event) => deleteImg(element)
|
|
@@ -4193,7 +4205,7 @@
|
|
|
4193
4205
|
_: 1
|
|
4194
4206
|
}, 8, ["modelValue"])
|
|
4195
4207
|
])),
|
|
4196
|
-
vue.createElementVNode("div",
|
|
4208
|
+
vue.createElementVNode("div", _hoisted_16, [
|
|
4197
4209
|
vue.createElementVNode("input", {
|
|
4198
4210
|
type: "file",
|
|
4199
4211
|
name: "file",
|
|
@@ -4204,13 +4216,13 @@
|
|
|
4204
4216
|
}, null, 32)
|
|
4205
4217
|
])
|
|
4206
4218
|
], 2)) : vue.createCommentVNode("", true),
|
|
4207
|
-
activeTitle.value === 3 ? (vue.openBlock(), vue.createElementBlock("div",
|
|
4208
|
-
vue.createElementVNode("div",
|
|
4219
|
+
activeTitle.value === 3 ? (vue.openBlock(), vue.createElementBlock("div", _hoisted_17, [
|
|
4220
|
+
vue.createElementVNode("div", _hoisted_18, [
|
|
4209
4221
|
vue.createElementVNode("div", null, [
|
|
4210
4222
|
vue.createVNode(vue.unref(elementPlus.ElSelect), {
|
|
4211
4223
|
modelValue: selectData.brandId,
|
|
4212
4224
|
"onUpdate:modelValue": _cache[4] || (_cache[4] = ($event) => selectData.brandId = $event),
|
|
4213
|
-
placeholder: "
|
|
4225
|
+
placeholder: "请选择品牌",
|
|
4214
4226
|
size: "large",
|
|
4215
4227
|
class: "select_1",
|
|
4216
4228
|
filterable: "",
|
|
@@ -4231,7 +4243,7 @@
|
|
|
4231
4243
|
vue.createVNode(vue.unref(elementPlus.ElSelect), {
|
|
4232
4244
|
modelValue: selectData.goodId,
|
|
4233
4245
|
"onUpdate:modelValue": _cache[5] || (_cache[5] = ($event) => selectData.goodId = $event),
|
|
4234
|
-
placeholder: "
|
|
4246
|
+
placeholder: "请选择车型",
|
|
4235
4247
|
size: "large",
|
|
4236
4248
|
class: "select_1",
|
|
4237
4249
|
filterable: "",
|
|
@@ -4252,7 +4264,7 @@
|
|
|
4252
4264
|
vue.createVNode(vue.unref(elementPlus.ElSelect), {
|
|
4253
4265
|
modelValue: selectData.carId,
|
|
4254
4266
|
"onUpdate:modelValue": _cache[6] || (_cache[6] = ($event) => selectData.carId = $event),
|
|
4255
|
-
placeholder: "
|
|
4267
|
+
placeholder: "请选择款型",
|
|
4256
4268
|
size: "large",
|
|
4257
4269
|
class: "select_2",
|
|
4258
4270
|
filterable: "",
|
|
@@ -4276,14 +4288,14 @@
|
|
|
4276
4288
|
style: { "width": "80px" },
|
|
4277
4289
|
onClick: search
|
|
4278
4290
|
}, {
|
|
4279
|
-
default: vue.withCtx(() => [
|
|
4280
|
-
vue.createTextVNode("
|
|
4281
|
-
]),
|
|
4291
|
+
default: vue.withCtx(() => _cache[9] || (_cache[9] = [
|
|
4292
|
+
vue.createTextVNode("搜索")
|
|
4293
|
+
])),
|
|
4282
4294
|
_: 1
|
|
4283
4295
|
})
|
|
4284
4296
|
]),
|
|
4285
|
-
tabList.value && tabList.value.length ? (vue.openBlock(), vue.createElementBlock("div",
|
|
4286
|
-
vue.createElementVNode("div",
|
|
4297
|
+
tabList.value && tabList.value.length ? (vue.openBlock(), vue.createElementBlock("div", _hoisted_19, [
|
|
4298
|
+
vue.createElementVNode("div", _hoisted_20, [
|
|
4287
4299
|
(vue.openBlock(true), vue.createElementBlock(vue.Fragment, null, vue.renderList(tabList.value, (item, index) => {
|
|
4288
4300
|
return vue.openBlock(), vue.createElementBlock("div", {
|
|
4289
4301
|
key: index,
|
|
@@ -4291,11 +4303,11 @@
|
|
|
4291
4303
|
onClick: ($event) => activeTab.value = item.type
|
|
4292
4304
|
}, [
|
|
4293
4305
|
vue.createTextVNode(vue.toDisplayString(item.name) + " ", 1),
|
|
4294
|
-
item.type === activeTab.value ? (vue.openBlock(), vue.createElementBlock("div",
|
|
4295
|
-
], 10,
|
|
4306
|
+
item.type === activeTab.value ? (vue.openBlock(), vue.createElementBlock("div", _hoisted_22)) : vue.createCommentVNode("", true)
|
|
4307
|
+
], 10, _hoisted_21);
|
|
4296
4308
|
}), 128))
|
|
4297
4309
|
]),
|
|
4298
|
-
vue.createElementVNode("div",
|
|
4310
|
+
vue.createElementVNode("div", _hoisted_23, [
|
|
4299
4311
|
(vue.openBlock(true), vue.createElementBlock(vue.Fragment, null, vue.renderList(imageList.value, (item, index) => {
|
|
4300
4312
|
return vue.openBlock(), vue.createElementBlock("div", {
|
|
4301
4313
|
key: index,
|
|
@@ -4306,25 +4318,25 @@
|
|
|
4306
4318
|
src: item.imgOrgUrl,
|
|
4307
4319
|
alt: "",
|
|
4308
4320
|
class: "image"
|
|
4309
|
-
}, null, 8,
|
|
4310
|
-
item.num ? (vue.openBlock(), vue.createElementBlock("div",
|
|
4311
|
-
vue.createElementVNode("div",
|
|
4321
|
+
}, null, 8, _hoisted_25),
|
|
4322
|
+
item.num ? (vue.openBlock(), vue.createElementBlock("div", _hoisted_26, [
|
|
4323
|
+
vue.createElementVNode("div", _hoisted_27, vue.toDisplayString(item.num), 1)
|
|
4312
4324
|
])) : vue.createCommentVNode("", true)
|
|
4313
|
-
], 8,
|
|
4325
|
+
], 8, _hoisted_24);
|
|
4314
4326
|
}), 128))
|
|
4315
4327
|
])
|
|
4316
|
-
])) : (vue.openBlock(), vue.createElementBlock("div",
|
|
4328
|
+
])) : (vue.openBlock(), vue.createElementBlock("div", _hoisted_28, [
|
|
4317
4329
|
vue.createElementVNode("div", null, [
|
|
4318
|
-
|
|
4330
|
+
_cache[12] || (_cache[12] = vue.createElementVNode("div", null, " 图库中的图片仅限下载摩托范以编辑发布文章使用,不得用于其他任何平台及用途 ", -1)),
|
|
4319
4331
|
vue.createElementVNode("div", null, [
|
|
4320
|
-
vue.createTextVNode("
|
|
4332
|
+
_cache[10] || (_cache[10] = vue.createTextVNode(" 请阅读")),
|
|
4321
4333
|
vue.createElementVNode("a", {
|
|
4322
4334
|
href: `https://${vue.unref(hostName)}/about?type=imageLicenseAgreement`,
|
|
4323
4335
|
target: "_blank",
|
|
4324
4336
|
rel: "noopener noreferrer",
|
|
4325
4337
|
class: "link"
|
|
4326
|
-
}, "
|
|
4327
|
-
vue.createTextVNode("
|
|
4338
|
+
}, "《摩托范图片许可使用协议》", 8, _hoisted_29),
|
|
4339
|
+
_cache[11] || (_cache[11] = vue.createTextVNode(",您的行为视为您已同意该协议。 "))
|
|
4328
4340
|
])
|
|
4329
4341
|
])
|
|
4330
4342
|
]))
|
|
@@ -4336,11 +4348,9 @@
|
|
|
4336
4348
|
};
|
|
4337
4349
|
}
|
|
4338
4350
|
});
|
|
4339
|
-
const index_vue_vue_type_style_index_0_lang$
|
|
4340
|
-
const _hoisted_1$
|
|
4341
|
-
const
|
|
4342
|
-
const _hoisted_3$3 = /* @__PURE__ */ vue.createElementVNode("span", { class: "remark" }, "\u4E3A\u4E86\u83B7\u5F97\u66F4\u9AD8\u7684\u63A8\u8350\u91CF\u548C\u70B9\u51FB\u91CF\uFF0C\u5EFA\u8BAE\u4E0A\u4F20720p\uFF081280*720\uFF09\u6216\u66F4\u9AD8\u5206\u8FA8\u7387\u7684\u89C6\u9891\uFF0C\u89C6\u9891\u683C\u5F0F\u4E3A.mp4\u6216.mov\uFF0C\u5927\u5C0F\u4E0D\u8D85\u8FC71G", -1);
|
|
4343
|
-
const _sfc_main$3 = vue.defineComponent({
|
|
4351
|
+
const index_vue_vue_type_style_index_0_lang$3 = "";
|
|
4352
|
+
const _hoisted_1$4 = { class: "insert-video" };
|
|
4353
|
+
const _sfc_main$4 = /* @__PURE__ */ vue.defineComponent({
|
|
4344
4354
|
__name: "index",
|
|
4345
4355
|
props: {
|
|
4346
4356
|
visible: { type: Boolean, default: false },
|
|
@@ -4362,29 +4372,29 @@
|
|
|
4362
4372
|
ele[0].dispatchEvent(event);
|
|
4363
4373
|
};
|
|
4364
4374
|
return (_ctx, _cache) => {
|
|
4365
|
-
return vue.openBlock(), vue.createBlock(_sfc_main$
|
|
4375
|
+
return vue.openBlock(), vue.createBlock(_sfc_main$7, {
|
|
4366
4376
|
"show-btn": false,
|
|
4367
4377
|
visible: vue.unref(visible),
|
|
4368
4378
|
width: "600px",
|
|
4369
4379
|
height: "100px"
|
|
4370
4380
|
}, {
|
|
4371
|
-
title: vue.withCtx(() => [
|
|
4372
|
-
|
|
4373
|
-
]),
|
|
4381
|
+
title: vue.withCtx(() => _cache[1] || (_cache[1] = [
|
|
4382
|
+
vue.createElementVNode("span", null, "插入视频", -1)
|
|
4383
|
+
])),
|
|
4374
4384
|
default: vue.withCtx(() => [
|
|
4375
|
-
vue.createElementVNode("div",
|
|
4385
|
+
vue.createElementVNode("div", _hoisted_1$4, [
|
|
4376
4386
|
vue.createVNode(vue.unref(elementPlus.ElButton), {
|
|
4377
4387
|
style: { "width": "120px" },
|
|
4378
4388
|
round: "",
|
|
4379
4389
|
type: "primary",
|
|
4380
4390
|
onClick: emitEvent
|
|
4381
4391
|
}, {
|
|
4382
|
-
default: vue.withCtx(() => [
|
|
4383
|
-
vue.createTextVNode("
|
|
4384
|
-
]),
|
|
4392
|
+
default: vue.withCtx(() => _cache[2] || (_cache[2] = [
|
|
4393
|
+
vue.createTextVNode("选择视频")
|
|
4394
|
+
])),
|
|
4385
4395
|
_: 1
|
|
4386
4396
|
}),
|
|
4387
|
-
|
|
4397
|
+
_cache[3] || (_cache[3] = vue.createElementVNode("span", { class: "remark" }, "为了获得更高的推荐量和点击量,建议上传720p(1280*720)或更高分辨率的视频,视频格式为.mp4或.mov,大小不超过1G", -1)),
|
|
4388
4398
|
vue.createElementVNode("input", {
|
|
4389
4399
|
type: "file",
|
|
4390
4400
|
accept: "video/*",
|
|
@@ -4399,121 +4409,822 @@
|
|
|
4399
4409
|
};
|
|
4400
4410
|
}
|
|
4401
4411
|
});
|
|
4402
|
-
const index_vue_vue_type_style_index_0_lang = "";
|
|
4403
|
-
const
|
|
4404
|
-
|
|
4405
|
-
|
|
4406
|
-
vm: this
|
|
4407
|
-
};
|
|
4408
|
-
},
|
|
4409
|
-
components: {
|
|
4410
|
-
ElInput: elementPlus.ElInput,
|
|
4411
|
-
BasicDialog: _sfc_main$6,
|
|
4412
|
-
draggable: draggable__default.default
|
|
4413
|
-
},
|
|
4412
|
+
const index_vue_vue_type_style_index_0_lang$2 = "";
|
|
4413
|
+
const index_vue_vue_type_style_index_0_lang$1 = "";
|
|
4414
|
+
const _sfc_main$3 = {
|
|
4415
|
+
name: "TopicManager",
|
|
4414
4416
|
props: {
|
|
4415
|
-
|
|
4416
|
-
|
|
4417
|
-
|
|
4418
|
-
|
|
4419
|
-
linkContent: {
|
|
4420
|
-
type: String,
|
|
4421
|
-
default: ""
|
|
4417
|
+
// 编辑器DOM引用
|
|
4418
|
+
editorDom: {
|
|
4419
|
+
type: Object,
|
|
4420
|
+
default: null
|
|
4422
4421
|
},
|
|
4423
|
-
|
|
4424
|
-
|
|
4425
|
-
|
|
4426
|
-
|
|
4422
|
+
// 话题API请求方法
|
|
4423
|
+
request: {
|
|
4424
|
+
type: Object,
|
|
4425
|
+
default: null
|
|
4427
4426
|
}
|
|
4428
4427
|
},
|
|
4429
4428
|
data() {
|
|
4430
|
-
return {
|
|
4431
|
-
|
|
4432
|
-
|
|
4433
|
-
|
|
4434
|
-
|
|
4435
|
-
|
|
4436
|
-
|
|
4437
|
-
|
|
4438
|
-
|
|
4429
|
+
return {
|
|
4430
|
+
// 话题弹框相关数据
|
|
4431
|
+
topicPopover: {
|
|
4432
|
+
visible: false,
|
|
4433
|
+
type: "hot",
|
|
4434
|
+
// 'hot' 热门话题, 'search' 搜索话题
|
|
4435
|
+
activeTab: "hot",
|
|
4436
|
+
// 'hot' 热门话题, 'recent' 最近使用
|
|
4437
|
+
position: { top: 0, left: 0 },
|
|
4438
|
+
searchKeyword: "",
|
|
4439
|
+
hotTopics: [],
|
|
4440
|
+
searchTopics: [],
|
|
4441
|
+
recentTopics: [],
|
|
4442
|
+
loading: false,
|
|
4443
|
+
page: 1,
|
|
4444
|
+
hasMore: true,
|
|
4445
|
+
searchPage: 1,
|
|
4446
|
+
searchHasMore: true,
|
|
4447
|
+
// 保存原始的selection和range信息
|
|
4448
|
+
originalRange: null,
|
|
4449
|
+
originalSelection: null,
|
|
4450
|
+
// 保存触发位置信息
|
|
4451
|
+
triggerInfo: {
|
|
4452
|
+
paragraph: null,
|
|
4453
|
+
hashIndex: -1,
|
|
4454
|
+
cursorPosition: 0
|
|
4455
|
+
},
|
|
4456
|
+
// 全局弹框DOM引用
|
|
4457
|
+
globalContainer: null,
|
|
4458
|
+
globalMask: null
|
|
4439
4459
|
}
|
|
4440
|
-
}
|
|
4441
|
-
},
|
|
4442
|
-
mounted() {
|
|
4460
|
+
};
|
|
4443
4461
|
},
|
|
4444
4462
|
methods: {
|
|
4445
|
-
|
|
4446
|
-
|
|
4447
|
-
|
|
4448
|
-
|
|
4463
|
+
// 初始化话题管理器
|
|
4464
|
+
init() {
|
|
4465
|
+
if (!this.editorDom) {
|
|
4466
|
+
console.warn("TopicManager: editorDom is required");
|
|
4467
|
+
return;
|
|
4468
|
+
}
|
|
4469
|
+
setTimeout(() => this.bindEditorEvents(), 0);
|
|
4449
4470
|
},
|
|
4450
|
-
|
|
4451
|
-
|
|
4452
|
-
|
|
4453
|
-
|
|
4454
|
-
|
|
4455
|
-
|
|
4456
|
-
|
|
4457
|
-
|
|
4458
|
-
|
|
4459
|
-
|
|
4460
|
-
|
|
4461
|
-
|
|
4462
|
-
|
|
4463
|
-
|
|
4464
|
-
|
|
4465
|
-
|
|
4466
|
-
|
|
4467
|
-
|
|
4468
|
-
|
|
4469
|
-
|
|
4470
|
-
|
|
4471
|
-
|
|
4472
|
-
|
|
4473
|
-
|
|
4474
|
-
|
|
4475
|
-
|
|
4476
|
-
|
|
4477
|
-
|
|
4478
|
-
|
|
4479
|
-
|
|
4480
|
-
|
|
4481
|
-
]),
|
|
4482
|
-
_: 1
|
|
4483
|
-
}, 8, ["visible"]);
|
|
4484
|
-
}
|
|
4485
|
-
const CollectArticle = /* @__PURE__ */ _export_sfc(_sfc_main$2, [["render", _sfc_render$2]]);
|
|
4486
|
-
const index_vue_vue_type_style_index_0_scoped_true_lang = "";
|
|
4487
|
-
const _sfc_main$1 = {
|
|
4488
|
-
components: {
|
|
4489
|
-
ElIconError: iconsVue.CircleCloseFilled
|
|
4490
|
-
},
|
|
4491
|
-
props: {
|
|
4492
|
-
article: {
|
|
4493
|
-
type: Object,
|
|
4494
|
-
default: () => ({})
|
|
4495
|
-
}
|
|
4496
|
-
},
|
|
4497
|
-
methods: {
|
|
4498
|
-
close(e) {
|
|
4499
|
-
let child = e.target;
|
|
4500
|
-
while (child) {
|
|
4501
|
-
if (child.dataset.article) {
|
|
4502
|
-
child.parentNode.removeChild(child);
|
|
4503
|
-
break;
|
|
4471
|
+
// 绑定编辑器事件
|
|
4472
|
+
bindEditorEvents() {
|
|
4473
|
+
if (!this.editorDom)
|
|
4474
|
+
return;
|
|
4475
|
+
this.editorDom.addEventListener("keydown", this.handleTopicInput.bind(this));
|
|
4476
|
+
},
|
|
4477
|
+
// 解绑编辑器事件
|
|
4478
|
+
unbindEditorEvents() {
|
|
4479
|
+
if (!this.editorDom)
|
|
4480
|
+
return;
|
|
4481
|
+
this.editorDom.removeEventListener("keydown", this.handleTopicInput.bind(this));
|
|
4482
|
+
},
|
|
4483
|
+
// 话题输入处理
|
|
4484
|
+
handleTopicInput(event) {
|
|
4485
|
+
var _a;
|
|
4486
|
+
console.log("handleTopicInput", event.key);
|
|
4487
|
+
const activeElement = document.activeElement;
|
|
4488
|
+
if (activeElement && (activeElement.tagName === "INPUT" || activeElement.tagName === "TEXTAREA")) {
|
|
4489
|
+
return;
|
|
4490
|
+
}
|
|
4491
|
+
const selection = window.getSelection();
|
|
4492
|
+
if (selection.rangeCount === 0)
|
|
4493
|
+
return;
|
|
4494
|
+
const range = selection.getRangeAt(0);
|
|
4495
|
+
const container = range.startContainer;
|
|
4496
|
+
if (!this.editorDom.contains(container))
|
|
4497
|
+
return;
|
|
4498
|
+
let currentNode = container;
|
|
4499
|
+
while (currentNode && currentNode !== this.editorDom) {
|
|
4500
|
+
if (currentNode.nodeType === Node.ELEMENT_NODE && currentNode.tagName === "MDD-TOPIC") {
|
|
4501
|
+
return;
|
|
4504
4502
|
}
|
|
4505
|
-
|
|
4503
|
+
currentNode = currentNode.parentNode;
|
|
4506
4504
|
}
|
|
4507
|
-
|
|
4508
|
-
|
|
4509
|
-
|
|
4510
|
-
|
|
4511
|
-
|
|
4512
|
-
|
|
4513
|
-
|
|
4514
|
-
|
|
4515
|
-
|
|
4516
|
-
|
|
4505
|
+
let paragraph = container;
|
|
4506
|
+
while (paragraph && paragraph.nodeType !== Node.ELEMENT_NODE) {
|
|
4507
|
+
paragraph = paragraph.parentNode;
|
|
4508
|
+
}
|
|
4509
|
+
while (paragraph && !((_a = paragraph.classList) == null ? void 0 : _a.contains("halo-paragraph"))) {
|
|
4510
|
+
paragraph = paragraph.parentNode;
|
|
4511
|
+
}
|
|
4512
|
+
if (!paragraph)
|
|
4513
|
+
return;
|
|
4514
|
+
const { textContent: paragraphText, cursorPosition } = this.getParagraphTextExcludingTopics(paragraph, range);
|
|
4515
|
+
if (event.key === "#") {
|
|
4516
|
+
const afterCursor = paragraphText.substring(cursorPosition);
|
|
4517
|
+
if (afterCursor.length > 0 && afterCursor[0] === " ") {
|
|
4518
|
+
return;
|
|
4519
|
+
}
|
|
4520
|
+
setTimeout(() => {
|
|
4521
|
+
const position = this.getCaretPosition();
|
|
4522
|
+
const triggerInfo = {
|
|
4523
|
+
paragraph,
|
|
4524
|
+
hashIndex: cursorPosition,
|
|
4525
|
+
// #号的位置
|
|
4526
|
+
cursorPosition: cursorPosition + 1
|
|
4527
|
+
// #号后的位置
|
|
4528
|
+
};
|
|
4529
|
+
this.showTopicPopover("hot", position, "", triggerInfo);
|
|
4530
|
+
}, 10);
|
|
4531
|
+
} else if (this.shouldTriggerSearch(event.key)) {
|
|
4532
|
+
setTimeout(() => {
|
|
4533
|
+
this.checkAndTriggerSearch(paragraph);
|
|
4534
|
+
}, 10);
|
|
4535
|
+
} else {
|
|
4536
|
+
this.hideTopicPopover();
|
|
4537
|
+
}
|
|
4538
|
+
},
|
|
4539
|
+
shouldTriggerSearch(key) {
|
|
4540
|
+
return key !== " " && key.length === 1 || key === "Backspace" || key === "Delete";
|
|
4541
|
+
},
|
|
4542
|
+
checkAndTriggerSearch(paragraph) {
|
|
4543
|
+
const selection = window.getSelection();
|
|
4544
|
+
if (selection.rangeCount === 0)
|
|
4545
|
+
return;
|
|
4546
|
+
const range = selection.getRangeAt(0);
|
|
4547
|
+
let currentNode = range.startContainer;
|
|
4548
|
+
while (currentNode && currentNode !== paragraph) {
|
|
4549
|
+
if (currentNode.nodeType === Node.ELEMENT_NODE && currentNode.tagName === "MDD-TOPIC") {
|
|
4550
|
+
this.hideTopicPopover();
|
|
4551
|
+
return;
|
|
4552
|
+
}
|
|
4553
|
+
currentNode = currentNode.parentNode;
|
|
4554
|
+
}
|
|
4555
|
+
const { textContent: paragraphText, cursorPosition } = this.getParagraphTextExcludingTopics(paragraph, range);
|
|
4556
|
+
const beforeCursor = paragraphText.substring(0, cursorPosition);
|
|
4557
|
+
const hashIndex = beforeCursor.lastIndexOf("#");
|
|
4558
|
+
if (hashIndex !== -1) {
|
|
4559
|
+
const afterHash = beforeCursor.substring(hashIndex + 1);
|
|
4560
|
+
if (afterHash.replace(/\u00A0/g, " ").indexOf(" ") === -1) {
|
|
4561
|
+
if (afterHash.length <= 15) {
|
|
4562
|
+
const position = this.getCaretPosition();
|
|
4563
|
+
const triggerInfo = {
|
|
4564
|
+
paragraph,
|
|
4565
|
+
hashIndex,
|
|
4566
|
+
cursorPosition
|
|
4567
|
+
};
|
|
4568
|
+
if (afterHash.length === 0) {
|
|
4569
|
+
this.showTopicPopover("hot", position, "", triggerInfo);
|
|
4570
|
+
} else {
|
|
4571
|
+
this.showTopicPopover("search", position, afterHash, triggerInfo);
|
|
4572
|
+
}
|
|
4573
|
+
} else if (afterHash.length > 15) {
|
|
4574
|
+
this.hideTopicPopover();
|
|
4575
|
+
}
|
|
4576
|
+
} else {
|
|
4577
|
+
this.hideTopicPopover();
|
|
4578
|
+
}
|
|
4579
|
+
} else {
|
|
4580
|
+
this.hideTopicPopover();
|
|
4581
|
+
}
|
|
4582
|
+
},
|
|
4583
|
+
getParagraphTextExcludingTopics(paragraph, range) {
|
|
4584
|
+
let textContent = "";
|
|
4585
|
+
let cursorPosition = 0;
|
|
4586
|
+
let foundCursor = false;
|
|
4587
|
+
const walker = document.createTreeWalker(
|
|
4588
|
+
paragraph,
|
|
4589
|
+
NodeFilter.SHOW_ALL,
|
|
4590
|
+
{
|
|
4591
|
+
acceptNode: function(node2) {
|
|
4592
|
+
if (node2.nodeType === Node.ELEMENT_NODE && node2.tagName === "MDD-TOPIC") {
|
|
4593
|
+
return NodeFilter.FILTER_REJECT;
|
|
4594
|
+
}
|
|
4595
|
+
return NodeFilter.FILTER_ACCEPT;
|
|
4596
|
+
}
|
|
4597
|
+
},
|
|
4598
|
+
false
|
|
4599
|
+
);
|
|
4600
|
+
let node;
|
|
4601
|
+
while (node = walker.nextNode()) {
|
|
4602
|
+
if (node.nodeType === Node.TEXT_NODE) {
|
|
4603
|
+
const nodeText = node.textContent;
|
|
4604
|
+
if (!foundCursor && node === range.startContainer) {
|
|
4605
|
+
cursorPosition = textContent.length + range.startOffset;
|
|
4606
|
+
foundCursor = true;
|
|
4607
|
+
}
|
|
4608
|
+
textContent += nodeText;
|
|
4609
|
+
}
|
|
4610
|
+
}
|
|
4611
|
+
return { textContent, cursorPosition };
|
|
4612
|
+
},
|
|
4613
|
+
getCaretPosition() {
|
|
4614
|
+
const selection = window.getSelection();
|
|
4615
|
+
if (selection.rangeCount === 0)
|
|
4616
|
+
return { top: 0, left: 0 };
|
|
4617
|
+
const range = selection.getRangeAt(0);
|
|
4618
|
+
const rect = range.getBoundingClientRect();
|
|
4619
|
+
return {
|
|
4620
|
+
top: rect.bottom + window.scrollY,
|
|
4621
|
+
left: rect.left + window.scrollX
|
|
4622
|
+
};
|
|
4623
|
+
},
|
|
4624
|
+
// 话题弹框相关方法
|
|
4625
|
+
showTopicPopover(type, position, searchKeyword = "", triggerInfo = null) {
|
|
4626
|
+
if (!this.request || !this.request.getTopic) {
|
|
4627
|
+
console.warn("话题功能需要提供 request.getTopic 方法");
|
|
4628
|
+
return;
|
|
4629
|
+
}
|
|
4630
|
+
const selection = window.getSelection();
|
|
4631
|
+
if (selection.rangeCount > 0) {
|
|
4632
|
+
this.topicPopover.originalRange = selection.getRangeAt(0).cloneRange();
|
|
4633
|
+
this.topicPopover.originalSelection = selection;
|
|
4634
|
+
}
|
|
4635
|
+
if (triggerInfo) {
|
|
4636
|
+
this.topicPopover.triggerInfo = triggerInfo;
|
|
4637
|
+
}
|
|
4638
|
+
this.topicPopover.visible = true;
|
|
4639
|
+
this.topicPopover.type = type;
|
|
4640
|
+
this.topicPopover.position = position;
|
|
4641
|
+
this.topicPopover.searchKeyword = searchKeyword;
|
|
4642
|
+
if (type === "hot") {
|
|
4643
|
+
this.topicPopover.activeTab = "hot";
|
|
4644
|
+
this.loadHotTopics();
|
|
4645
|
+
this.loadRecentTopics();
|
|
4646
|
+
} else if (type === "search") {
|
|
4647
|
+
this.searchTopics(searchKeyword);
|
|
4648
|
+
}
|
|
4649
|
+
this.createGlobalTopicPopover();
|
|
4650
|
+
},
|
|
4651
|
+
hideTopicPopover() {
|
|
4652
|
+
this.topicPopover.visible = false;
|
|
4653
|
+
this.topicPopover.hotTopics = [];
|
|
4654
|
+
this.topicPopover.searchTopics = [];
|
|
4655
|
+
this.topicPopover.page = 1;
|
|
4656
|
+
this.topicPopover.searchPage = 1;
|
|
4657
|
+
this.topicPopover.hasMore = true;
|
|
4658
|
+
this.topicPopover.searchHasMore = true;
|
|
4659
|
+
this.topicPopover.originalRange = null;
|
|
4660
|
+
this.topicPopover.originalSelection = null;
|
|
4661
|
+
this.topicPopover.triggerInfo = {
|
|
4662
|
+
paragraph: null,
|
|
4663
|
+
hashIndex: -1,
|
|
4664
|
+
cursorPosition: 0
|
|
4665
|
+
};
|
|
4666
|
+
this.removeGlobalTopicPopover();
|
|
4667
|
+
},
|
|
4668
|
+
switchTopicTab(tab) {
|
|
4669
|
+
this.topicPopover.activeTab = tab;
|
|
4670
|
+
this.updateGlobalTopicPopover();
|
|
4671
|
+
},
|
|
4672
|
+
async loadHotTopics() {
|
|
4673
|
+
if (this.topicPopover.loading || !this.topicPopover.hasMore)
|
|
4674
|
+
return;
|
|
4675
|
+
this.topicPopover.loading = true;
|
|
4676
|
+
try {
|
|
4677
|
+
const response = await this.request.getTopic({
|
|
4678
|
+
action: "201023",
|
|
4679
|
+
page: this.topicPopover.page,
|
|
4680
|
+
limit: 50,
|
|
4681
|
+
hoopId: 0,
|
|
4682
|
+
type: 0,
|
|
4683
|
+
orderBy: "view"
|
|
4684
|
+
});
|
|
4685
|
+
if (response && response.data && response.data.code === 0) {
|
|
4686
|
+
const topics = response.data.data || [];
|
|
4687
|
+
if (topics.length === 0) {
|
|
4688
|
+
this.topicPopover.hasMore = false;
|
|
4689
|
+
} else {
|
|
4690
|
+
const existingIds = new Set(this.topicPopover.hotTopics.map((t) => t.id));
|
|
4691
|
+
const newTopics = topics.filter((t) => !existingIds.has(t.id));
|
|
4692
|
+
this.topicPopover.hotTopics = [...this.topicPopover.hotTopics, ...newTopics];
|
|
4693
|
+
this.topicPopover.page++;
|
|
4694
|
+
if (newTopics.length === 0) {
|
|
4695
|
+
this.topicPopover.hasMore = false;
|
|
4696
|
+
}
|
|
4697
|
+
}
|
|
4698
|
+
} else {
|
|
4699
|
+
console.warn("加载热门话题失败:", response);
|
|
4700
|
+
this.topicPopover.hasMore = false;
|
|
4701
|
+
}
|
|
4702
|
+
} catch (error) {
|
|
4703
|
+
console.error("加载热门话题失败:", error);
|
|
4704
|
+
this.topicPopover.hasMore = false;
|
|
4705
|
+
} finally {
|
|
4706
|
+
this.topicPopover.loading = false;
|
|
4707
|
+
this.updateGlobalTopicPopover();
|
|
4708
|
+
}
|
|
4709
|
+
},
|
|
4710
|
+
async searchTopics(keyword) {
|
|
4711
|
+
this.topicPopover.searchKeyword = keyword;
|
|
4712
|
+
this.topicPopover.searchTopics = [];
|
|
4713
|
+
this.topicPopover.searchPage = 1;
|
|
4714
|
+
this.topicPopover.searchHasMore = true;
|
|
4715
|
+
if (this.topicPopover.loading) {
|
|
4716
|
+
this.topicPopover.loading = false;
|
|
4717
|
+
}
|
|
4718
|
+
this.topicPopover.loading = true;
|
|
4719
|
+
try {
|
|
4720
|
+
const response = await this.request.getTopic({
|
|
4721
|
+
action: "201023",
|
|
4722
|
+
title: keyword,
|
|
4723
|
+
highlightTitle: "title",
|
|
4724
|
+
page: this.topicPopover.searchPage,
|
|
4725
|
+
limit: 50
|
|
4726
|
+
});
|
|
4727
|
+
if (response && response.data && response.data.code === 0) {
|
|
4728
|
+
const topics = response.data.data || [];
|
|
4729
|
+
this.topicPopover.searchTopics = topics;
|
|
4730
|
+
this.topicPopover.searchPage++;
|
|
4731
|
+
if (topics.length === 0) {
|
|
4732
|
+
this.topicPopover.searchHasMore = false;
|
|
4733
|
+
} else {
|
|
4734
|
+
this.topicPopover.searchHasMore = topics.length >= 50;
|
|
4735
|
+
}
|
|
4736
|
+
} else {
|
|
4737
|
+
console.warn("搜索话题失败:", response);
|
|
4738
|
+
this.topicPopover.searchHasMore = false;
|
|
4739
|
+
}
|
|
4740
|
+
} catch (error) {
|
|
4741
|
+
console.error("搜索话题失败:", error);
|
|
4742
|
+
this.topicPopover.searchHasMore = false;
|
|
4743
|
+
} finally {
|
|
4744
|
+
this.topicPopover.loading = false;
|
|
4745
|
+
this.updateGlobalTopicPopover();
|
|
4746
|
+
}
|
|
4747
|
+
},
|
|
4748
|
+
loadRecentTopics() {
|
|
4749
|
+
try {
|
|
4750
|
+
const localTopics = JSON.parse(localStorage.getItem("localTopic") || "[]");
|
|
4751
|
+
this.topicPopover.recentTopics = localTopics;
|
|
4752
|
+
} catch (error) {
|
|
4753
|
+
console.error("加载最近使用话题失败:", error);
|
|
4754
|
+
this.topicPopover.recentTopics = [];
|
|
4755
|
+
}
|
|
4756
|
+
},
|
|
4757
|
+
selectTopic(topic) {
|
|
4758
|
+
this.saveToRecentTopics(topic);
|
|
4759
|
+
this.insertTopicToEditor(topic);
|
|
4760
|
+
this.hideTopicPopover();
|
|
4761
|
+
this.$emit("topic-inserted", topic);
|
|
4762
|
+
},
|
|
4763
|
+
saveToRecentTopics(topic) {
|
|
4764
|
+
try {
|
|
4765
|
+
let recentTopics = JSON.parse(localStorage.getItem("localTopic") || "[]");
|
|
4766
|
+
recentTopics = recentTopics.filter((item) => item.id !== topic.id);
|
|
4767
|
+
recentTopics.unshift(topic);
|
|
4768
|
+
if (recentTopics.length > 20) {
|
|
4769
|
+
recentTopics = recentTopics.slice(0, 20);
|
|
4770
|
+
}
|
|
4771
|
+
localStorage.setItem("localTopic", JSON.stringify(recentTopics));
|
|
4772
|
+
} catch (error) {
|
|
4773
|
+
console.error("保存最近使用话题失败:", error);
|
|
4774
|
+
}
|
|
4775
|
+
},
|
|
4776
|
+
// 创建全局话题弹框
|
|
4777
|
+
createGlobalTopicPopover() {
|
|
4778
|
+
this.removeGlobalTopicPopover();
|
|
4779
|
+
const mask = document.createElement("div");
|
|
4780
|
+
mask.className = "topic-popover-mask";
|
|
4781
|
+
mask.addEventListener("click", () => {
|
|
4782
|
+
this.hideTopicPopover();
|
|
4783
|
+
});
|
|
4784
|
+
const container = document.createElement("div");
|
|
4785
|
+
container.className = "topic-popover";
|
|
4786
|
+
container.style.position = "fixed";
|
|
4787
|
+
container.style.top = this.topicPopover.position.top + "px";
|
|
4788
|
+
container.style.left = this.topicPopover.position.left + "px";
|
|
4789
|
+
container.style.zIndex = "9999";
|
|
4790
|
+
container.addEventListener("click", (e) => {
|
|
4791
|
+
e.stopPropagation();
|
|
4792
|
+
});
|
|
4793
|
+
container.innerHTML = this.createTopicPopoverContent();
|
|
4794
|
+
document.body.appendChild(mask);
|
|
4795
|
+
document.body.appendChild(container);
|
|
4796
|
+
this.topicPopover.globalMask = mask;
|
|
4797
|
+
this.topicPopover.globalContainer = container;
|
|
4798
|
+
this.bindTopicPopoverEvents();
|
|
4799
|
+
},
|
|
4800
|
+
// 移除全局话题弹框
|
|
4801
|
+
removeGlobalTopicPopover() {
|
|
4802
|
+
if (this.topicPopover.globalMask) {
|
|
4803
|
+
document.body.removeChild(this.topicPopover.globalMask);
|
|
4804
|
+
this.topicPopover.globalMask = null;
|
|
4805
|
+
}
|
|
4806
|
+
if (this.topicPopover.globalContainer) {
|
|
4807
|
+
document.body.removeChild(this.topicPopover.globalContainer);
|
|
4808
|
+
this.topicPopover.globalContainer = null;
|
|
4809
|
+
}
|
|
4810
|
+
},
|
|
4811
|
+
// 更新全局话题弹框内容
|
|
4812
|
+
updateGlobalTopicPopover() {
|
|
4813
|
+
if (!this.topicPopover.globalContainer)
|
|
4814
|
+
return;
|
|
4815
|
+
this.topicPopover.globalContainer.innerHTML = this.createTopicPopoverContent();
|
|
4816
|
+
this.bindTopicPopoverEvents();
|
|
4817
|
+
},
|
|
4818
|
+
// 创建话题弹框内容
|
|
4819
|
+
createTopicPopoverContent() {
|
|
4820
|
+
if (this.topicPopover.type === "hot") {
|
|
4821
|
+
return this.getHotTopicPopoverHTML();
|
|
4822
|
+
} else if (this.topicPopover.type === "search") {
|
|
4823
|
+
return this.getSearchTopicPopoverHTML();
|
|
4824
|
+
}
|
|
4825
|
+
return "";
|
|
4826
|
+
},
|
|
4827
|
+
// 获取热门话题弹框HTML
|
|
4828
|
+
getHotTopicPopoverHTML() {
|
|
4829
|
+
const activeTab = this.topicPopover.activeTab;
|
|
4830
|
+
const hotTopics = this.topicPopover.hotTopics;
|
|
4831
|
+
const recentTopics = this.topicPopover.recentTopics;
|
|
4832
|
+
const loading = this.topicPopover.loading;
|
|
4833
|
+
const hasMore = this.topicPopover.hasMore;
|
|
4834
|
+
let topicListHTML = "";
|
|
4835
|
+
if (activeTab === "hot") {
|
|
4836
|
+
if (loading && hotTopics.length === 0) {
|
|
4837
|
+
topicListHTML = '<div class="topic-loading">加载中...</div>';
|
|
4838
|
+
} else if (hotTopics.length === 0) {
|
|
4839
|
+
topicListHTML = '<div class="topic-empty">暂无热门话题</div>';
|
|
4840
|
+
} else {
|
|
4841
|
+
topicListHTML = hotTopics.map(
|
|
4842
|
+
(topic) => `<div class="topic-item" data-topic-id="${topic.id}">#${topic.exactlyMatchTitle}</div>`
|
|
4843
|
+
).join("");
|
|
4844
|
+
if (loading) {
|
|
4845
|
+
topicListHTML += '<div class="topic-loading">加载更多...</div>';
|
|
4846
|
+
} else if (!hasMore) {
|
|
4847
|
+
topicListHTML += '<div class="topic-empty">没有更多了</div>';
|
|
4848
|
+
}
|
|
4849
|
+
}
|
|
4850
|
+
} else {
|
|
4851
|
+
if (recentTopics.length === 0) {
|
|
4852
|
+
topicListHTML = '<div class="topic-empty">暂无最近使用记录</div>';
|
|
4853
|
+
} else {
|
|
4854
|
+
topicListHTML = recentTopics.map(
|
|
4855
|
+
(topic) => `<div class="topic-item" data-topic-id="${topic.id}">#${topic.exactlyMatchTitle}</div>`
|
|
4856
|
+
).join("");
|
|
4857
|
+
}
|
|
4858
|
+
}
|
|
4859
|
+
return `
|
|
4860
|
+
<div class="topic-popover-content">
|
|
4861
|
+
<div class="topic-tabs">
|
|
4862
|
+
<div class="topic-tab ${activeTab === "hot" ? "active" : ""}" data-tab="hot">
|
|
4863
|
+
热门话题
|
|
4864
|
+
</div>
|
|
4865
|
+
<div class="topic-tab ${activeTab === "recent" ? "active" : ""}" data-tab="recent">
|
|
4866
|
+
最近使用
|
|
4867
|
+
</div>
|
|
4868
|
+
</div>
|
|
4869
|
+
<div class="topic-list-container">
|
|
4870
|
+
<div class="topic-list">
|
|
4871
|
+
${topicListHTML}
|
|
4872
|
+
</div>
|
|
4873
|
+
</div>
|
|
4874
|
+
</div>
|
|
4875
|
+
`;
|
|
4876
|
+
},
|
|
4877
|
+
// 获取搜索话题弹框HTML
|
|
4878
|
+
getSearchTopicPopoverHTML() {
|
|
4879
|
+
const searchKeyword = this.topicPopover.searchKeyword;
|
|
4880
|
+
const searchTopics = this.topicPopover.searchTopics;
|
|
4881
|
+
const loading = this.topicPopover.loading;
|
|
4882
|
+
const searchHasMore = this.topicPopover.searchHasMore;
|
|
4883
|
+
let topicListHTML = "";
|
|
4884
|
+
if (loading && searchTopics.length === 0) {
|
|
4885
|
+
topicListHTML = '<div class="topic-loading">搜索中...</div>';
|
|
4886
|
+
} else if (searchTopics.length === 0) {
|
|
4887
|
+
topicListHTML = '<div class="topic-empty">没有匹配到话题,请重新输入</div>';
|
|
4888
|
+
} else {
|
|
4889
|
+
topicListHTML = searchTopics.map(
|
|
4890
|
+
(topic) => `<div class="topic-item" data-topic-id="${topic.id}">#${topic.exactlyMatchTitle}</div>`
|
|
4891
|
+
).join("");
|
|
4892
|
+
if (loading) {
|
|
4893
|
+
topicListHTML += '<div class="topic-loading">加载更多...</div>';
|
|
4894
|
+
} else if (!searchHasMore) {
|
|
4895
|
+
topicListHTML += '<div class="topic-empty">没有更多了</div>';
|
|
4896
|
+
}
|
|
4897
|
+
}
|
|
4898
|
+
return `
|
|
4899
|
+
<div class="topic-popover-content">
|
|
4900
|
+
<div class="topic-search-header">
|
|
4901
|
+
<span class="topic-search-title">#${searchKeyword}</span>
|
|
4902
|
+
</div>
|
|
4903
|
+
<div class="topic-list-container">
|
|
4904
|
+
<div class="topic-list">
|
|
4905
|
+
${topicListHTML}
|
|
4906
|
+
</div>
|
|
4907
|
+
</div>
|
|
4908
|
+
</div>
|
|
4909
|
+
`;
|
|
4910
|
+
},
|
|
4911
|
+
// 绑定话题弹框事件
|
|
4912
|
+
bindTopicPopoverEvents() {
|
|
4913
|
+
if (!this.topicPopover.globalContainer)
|
|
4914
|
+
return;
|
|
4915
|
+
const tabs = this.topicPopover.globalContainer.querySelectorAll(".topic-tab");
|
|
4916
|
+
tabs.forEach((tab) => {
|
|
4917
|
+
tab.addEventListener("click", (e) => {
|
|
4918
|
+
const tabType = e.target.getAttribute("data-tab");
|
|
4919
|
+
this.switchTopicTab(tabType);
|
|
4920
|
+
});
|
|
4921
|
+
});
|
|
4922
|
+
const topicItems = this.topicPopover.globalContainer.querySelectorAll(".topic-item");
|
|
4923
|
+
topicItems.forEach((item) => {
|
|
4924
|
+
item.addEventListener("click", (e) => {
|
|
4925
|
+
const topicId = parseInt(e.target.getAttribute("data-topic-id"));
|
|
4926
|
+
const topic = this.findTopicById(topicId);
|
|
4927
|
+
if (topic) {
|
|
4928
|
+
this.selectTopic(topic);
|
|
4929
|
+
}
|
|
4930
|
+
});
|
|
4931
|
+
});
|
|
4932
|
+
const listContainer = this.topicPopover.globalContainer.querySelector(".topic-list-container");
|
|
4933
|
+
if (listContainer) {
|
|
4934
|
+
listContainer.addEventListener("scroll", (e) => {
|
|
4935
|
+
if (this.topicPopover.type === "hot") {
|
|
4936
|
+
this.handleTopicScroll(e);
|
|
4937
|
+
} else if (this.topicPopover.type === "search") {
|
|
4938
|
+
this.handleSearchTopicScroll(e);
|
|
4939
|
+
}
|
|
4940
|
+
});
|
|
4941
|
+
}
|
|
4942
|
+
},
|
|
4943
|
+
// 根据ID查找话题
|
|
4944
|
+
findTopicById(topicId) {
|
|
4945
|
+
let topic = this.topicPopover.hotTopics.find((t) => t.id === topicId);
|
|
4946
|
+
if (topic)
|
|
4947
|
+
return topic;
|
|
4948
|
+
topic = this.topicPopover.searchTopics.find((t) => t.id === topicId);
|
|
4949
|
+
if (topic)
|
|
4950
|
+
return topic;
|
|
4951
|
+
topic = this.topicPopover.recentTopics.find((t) => t.id === topicId);
|
|
4952
|
+
if (topic)
|
|
4953
|
+
return topic;
|
|
4954
|
+
return null;
|
|
4955
|
+
},
|
|
4956
|
+
handleTopicScroll(event) {
|
|
4957
|
+
if (this.topicPopover.activeTab !== "hot")
|
|
4958
|
+
return;
|
|
4959
|
+
const container = event.target;
|
|
4960
|
+
const scrollTop = container.scrollTop;
|
|
4961
|
+
const scrollHeight = container.scrollHeight;
|
|
4962
|
+
const clientHeight = container.clientHeight;
|
|
4963
|
+
if (scrollTop + clientHeight >= scrollHeight - 10) {
|
|
4964
|
+
this.loadHotTopics();
|
|
4965
|
+
}
|
|
4966
|
+
},
|
|
4967
|
+
handleSearchTopicScroll(event) {
|
|
4968
|
+
const container = event.target;
|
|
4969
|
+
const scrollTop = container.scrollTop;
|
|
4970
|
+
const scrollHeight = container.scrollHeight;
|
|
4971
|
+
const clientHeight = container.clientHeight;
|
|
4972
|
+
if (scrollTop + clientHeight >= scrollHeight - 10) {
|
|
4973
|
+
this.searchTopics(this.topicPopover.searchKeyword);
|
|
4974
|
+
}
|
|
4975
|
+
},
|
|
4976
|
+
insertTopicToEditor(topic) {
|
|
4977
|
+
const originalRange = this.topicPopover.originalRange;
|
|
4978
|
+
const triggerInfo = this.topicPopover.triggerInfo;
|
|
4979
|
+
const popoverType = this.topicPopover.type;
|
|
4980
|
+
this.hideTopicPopover();
|
|
4981
|
+
let range = originalRange;
|
|
4982
|
+
if (!range) {
|
|
4983
|
+
const selection2 = window.getSelection();
|
|
4984
|
+
if (selection2.rangeCount === 0)
|
|
4985
|
+
return;
|
|
4986
|
+
range = selection2.getRangeAt(0);
|
|
4987
|
+
}
|
|
4988
|
+
const topicText = `#${topic.exactlyMatchTitle}`;
|
|
4989
|
+
if (popoverType === "search" && triggerInfo && triggerInfo.paragraph) {
|
|
4990
|
+
const paragraph = triggerInfo.paragraph;
|
|
4991
|
+
const hashIndex = triggerInfo.hashIndex;
|
|
4992
|
+
const deleteRange = document.createRange();
|
|
4993
|
+
const walker = document.createTreeWalker(
|
|
4994
|
+
paragraph,
|
|
4995
|
+
NodeFilter.SHOW_TEXT,
|
|
4996
|
+
{
|
|
4997
|
+
acceptNode: function(node2) {
|
|
4998
|
+
let parent = node2.parentNode;
|
|
4999
|
+
while (parent && parent !== paragraph) {
|
|
5000
|
+
if (parent.tagName === "MDD-TOPIC") {
|
|
5001
|
+
return NodeFilter.FILTER_REJECT;
|
|
5002
|
+
}
|
|
5003
|
+
parent = parent.parentNode;
|
|
5004
|
+
}
|
|
5005
|
+
return NodeFilter.FILTER_ACCEPT;
|
|
5006
|
+
}
|
|
5007
|
+
},
|
|
5008
|
+
false
|
|
5009
|
+
);
|
|
5010
|
+
let position = 0;
|
|
5011
|
+
let startNode = null;
|
|
5012
|
+
let startOffset = 0;
|
|
5013
|
+
let endNode = null;
|
|
5014
|
+
let endOffset = 0;
|
|
5015
|
+
let node;
|
|
5016
|
+
while (node = walker.nextNode()) {
|
|
5017
|
+
if (position + node.textContent.length > hashIndex) {
|
|
5018
|
+
startNode = node;
|
|
5019
|
+
startOffset = hashIndex - position;
|
|
5020
|
+
break;
|
|
5021
|
+
}
|
|
5022
|
+
position += node.textContent.length;
|
|
5023
|
+
}
|
|
5024
|
+
const currentCursorPosition = triggerInfo.cursorPosition;
|
|
5025
|
+
position = 0;
|
|
5026
|
+
walker.currentNode = paragraph;
|
|
5027
|
+
while (node = walker.nextNode()) {
|
|
5028
|
+
if (position + node.textContent.length >= currentCursorPosition) {
|
|
5029
|
+
endNode = node;
|
|
5030
|
+
endOffset = currentCursorPosition - position;
|
|
5031
|
+
break;
|
|
5032
|
+
}
|
|
5033
|
+
position += node.textContent.length;
|
|
5034
|
+
}
|
|
5035
|
+
if (startNode && endNode) {
|
|
5036
|
+
deleteRange.setStart(startNode, startOffset);
|
|
5037
|
+
deleteRange.setEnd(endNode, endOffset);
|
|
5038
|
+
deleteRange.deleteContents();
|
|
5039
|
+
range = document.createRange();
|
|
5040
|
+
range.setStart(startNode, startOffset);
|
|
5041
|
+
range.collapse(true);
|
|
5042
|
+
}
|
|
5043
|
+
} else if (popoverType === "hot") {
|
|
5044
|
+
const container = range.startContainer;
|
|
5045
|
+
if (container.nodeType === Node.TEXT_NODE && container.textContent) {
|
|
5046
|
+
const offset = range.startOffset;
|
|
5047
|
+
if (offset > 0 && container.textContent[offset - 1] === "#") {
|
|
5048
|
+
const deleteRange = document.createRange();
|
|
5049
|
+
deleteRange.setStart(container, offset - 1);
|
|
5050
|
+
deleteRange.setEnd(container, offset);
|
|
5051
|
+
deleteRange.deleteContents();
|
|
5052
|
+
range.setStart(container, offset - 1);
|
|
5053
|
+
range.collapse(true);
|
|
5054
|
+
}
|
|
5055
|
+
}
|
|
5056
|
+
}
|
|
5057
|
+
const topicElement = document.createElement("mdd-topic");
|
|
5058
|
+
topicElement.setAttribute("data-topic", JSON.stringify({
|
|
5059
|
+
topicId: topic.id,
|
|
5060
|
+
topicType: 0,
|
|
5061
|
+
startIndex: 0,
|
|
5062
|
+
// 会在updateTopicPosition中更新
|
|
5063
|
+
endIndex: 0
|
|
5064
|
+
// 会在updateTopicPosition中更新
|
|
5065
|
+
}));
|
|
5066
|
+
topicElement.textContent = topicText;
|
|
5067
|
+
topicElement.setAttribute("contenteditable", "false");
|
|
5068
|
+
range.deleteContents();
|
|
5069
|
+
range.insertNode(topicElement);
|
|
5070
|
+
const spaceNode = document.createTextNode(" ");
|
|
5071
|
+
range.setStartAfter(topicElement);
|
|
5072
|
+
range.insertNode(spaceNode);
|
|
5073
|
+
const newRange = document.createRange();
|
|
5074
|
+
newRange.setStartAfter(spaceNode);
|
|
5075
|
+
newRange.collapse(true);
|
|
5076
|
+
const selection = window.getSelection();
|
|
5077
|
+
selection.removeAllRanges();
|
|
5078
|
+
selection.addRange(newRange);
|
|
5079
|
+
setTimeout(() => {
|
|
5080
|
+
const currentSelection = window.getSelection();
|
|
5081
|
+
if (currentSelection.rangeCount > 0) {
|
|
5082
|
+
const currentRange = currentSelection.getRangeAt(0);
|
|
5083
|
+
if (currentRange.startContainer !== spaceNode.nextSibling) {
|
|
5084
|
+
const correctRange = document.createRange();
|
|
5085
|
+
correctRange.setStartAfter(spaceNode);
|
|
5086
|
+
correctRange.collapse(true);
|
|
5087
|
+
currentSelection.removeAllRanges();
|
|
5088
|
+
currentSelection.addRange(correctRange);
|
|
5089
|
+
}
|
|
5090
|
+
}
|
|
5091
|
+
}, 0);
|
|
5092
|
+
this.$emit("update-topic-position");
|
|
5093
|
+
},
|
|
5094
|
+
// 销毁话题管理器
|
|
5095
|
+
destroy() {
|
|
5096
|
+
this.unbindEditorEvents();
|
|
5097
|
+
this.hideTopicPopover();
|
|
5098
|
+
}
|
|
5099
|
+
},
|
|
5100
|
+
mounted() {
|
|
5101
|
+
this.init();
|
|
5102
|
+
},
|
|
5103
|
+
beforeUnmount() {
|
|
5104
|
+
this.destroy();
|
|
5105
|
+
}
|
|
5106
|
+
};
|
|
5107
|
+
const _hoisted_1$3 = { class: "topic-manager" };
|
|
5108
|
+
function _sfc_render$3(_ctx, _cache, $props, $setup, $data, $options) {
|
|
5109
|
+
return vue.openBlock(), vue.createElementBlock("div", _hoisted_1$3);
|
|
5110
|
+
}
|
|
5111
|
+
const TopicManager = /* @__PURE__ */ _export_sfc(_sfc_main$3, [["render", _sfc_render$3]]);
|
|
5112
|
+
const index_vue_vue_type_style_index_0_lang = "";
|
|
5113
|
+
const _sfc_main$2 = {
|
|
5114
|
+
provide() {
|
|
5115
|
+
return {
|
|
5116
|
+
vm: this
|
|
5117
|
+
};
|
|
5118
|
+
},
|
|
5119
|
+
components: {
|
|
5120
|
+
ElInput: elementPlus.ElInput,
|
|
5121
|
+
BasicDialog: _sfc_main$7,
|
|
5122
|
+
draggable
|
|
5123
|
+
},
|
|
5124
|
+
props: {
|
|
5125
|
+
visible: {
|
|
5126
|
+
type: Boolean,
|
|
5127
|
+
default: false
|
|
5128
|
+
},
|
|
5129
|
+
linkContent: {
|
|
5130
|
+
type: String,
|
|
5131
|
+
default: ""
|
|
5132
|
+
},
|
|
5133
|
+
fileSelected: {
|
|
5134
|
+
type: Function,
|
|
5135
|
+
default: () => {
|
|
5136
|
+
}
|
|
5137
|
+
}
|
|
5138
|
+
},
|
|
5139
|
+
data() {
|
|
5140
|
+
return {};
|
|
5141
|
+
},
|
|
5142
|
+
computed: {
|
|
5143
|
+
input: {
|
|
5144
|
+
get() {
|
|
5145
|
+
return this.linkContent;
|
|
5146
|
+
},
|
|
5147
|
+
set(val) {
|
|
5148
|
+
this.$emit("update:linkContent", val);
|
|
5149
|
+
}
|
|
5150
|
+
}
|
|
5151
|
+
},
|
|
5152
|
+
mounted() {
|
|
5153
|
+
},
|
|
5154
|
+
methods: {
|
|
5155
|
+
emitEvent() {
|
|
5156
|
+
var event = new MouseEvent("click");
|
|
5157
|
+
var ele = document.getElementsByClassName("video-input");
|
|
5158
|
+
ele[0].dispatchEvent(event);
|
|
5159
|
+
},
|
|
5160
|
+
setStatus(val) {
|
|
5161
|
+
this.$emit("update:visible", val);
|
|
5162
|
+
}
|
|
5163
|
+
// submit() {
|
|
5164
|
+
// this.$emit('submit')
|
|
5165
|
+
// }
|
|
5166
|
+
}
|
|
5167
|
+
};
|
|
5168
|
+
const _hoisted_1$2 = { class: "collect-article_content" };
|
|
5169
|
+
function _sfc_render$2(_ctx, _cache, $props, $setup, $data, $options) {
|
|
5170
|
+
const _component_el_input = vue.resolveComponent("el-input");
|
|
5171
|
+
const _component_BasicDialog = vue.resolveComponent("BasicDialog");
|
|
5172
|
+
return vue.openBlock(), vue.createBlock(_component_BasicDialog, {
|
|
5173
|
+
visible: $props.visible,
|
|
5174
|
+
width: "600px",
|
|
5175
|
+
height: "50px"
|
|
5176
|
+
}, {
|
|
5177
|
+
title: vue.withCtx(() => _cache[1] || (_cache[1] = [
|
|
5178
|
+
vue.createElementVNode("div", null, [
|
|
5179
|
+
vue.createElementVNode("span", null, "采集文章"),
|
|
5180
|
+
vue.createElementVNode("span", { class: "collect-article_lable" }, "如需获得正式使用权,请自行联系版权所有者")
|
|
5181
|
+
], -1)
|
|
5182
|
+
])),
|
|
5183
|
+
default: vue.withCtx(() => [
|
|
5184
|
+
vue.createElementVNode("div", _hoisted_1$2, [
|
|
5185
|
+
_cache[2] || (_cache[2] = vue.createElementVNode("div", { class: "tip" }, "请把需要采集的文章链接粘贴在下方的输入框:", -1)),
|
|
5186
|
+
vue.createVNode(_component_el_input, {
|
|
5187
|
+
modelValue: $options.input,
|
|
5188
|
+
"onUpdate:modelValue": _cache[0] || (_cache[0] = ($event) => $options.input = $event),
|
|
5189
|
+
placeholder: "仅支持微信链接"
|
|
5190
|
+
}, null, 8, ["modelValue"])
|
|
5191
|
+
])
|
|
5192
|
+
]),
|
|
5193
|
+
_: 1
|
|
5194
|
+
}, 8, ["visible"]);
|
|
5195
|
+
}
|
|
5196
|
+
const CollectArticle = /* @__PURE__ */ _export_sfc(_sfc_main$2, [["render", _sfc_render$2]]);
|
|
5197
|
+
const index_vue_vue_type_style_index_0_scoped_4ebe06df_lang = "";
|
|
5198
|
+
const _sfc_main$1 = {
|
|
5199
|
+
components: {
|
|
5200
|
+
ElIconError: iconsVue.CircleCloseFilled
|
|
5201
|
+
},
|
|
5202
|
+
props: {
|
|
5203
|
+
article: {
|
|
5204
|
+
type: Object,
|
|
5205
|
+
default: () => ({})
|
|
5206
|
+
}
|
|
5207
|
+
},
|
|
5208
|
+
methods: {
|
|
5209
|
+
close(e) {
|
|
5210
|
+
let child = e.target;
|
|
5211
|
+
while (child) {
|
|
5212
|
+
if (child.dataset.article) {
|
|
5213
|
+
child.parentNode.removeChild(child);
|
|
5214
|
+
break;
|
|
5215
|
+
}
|
|
5216
|
+
child = child.parentNode;
|
|
5217
|
+
}
|
|
5218
|
+
this.$emit("delete");
|
|
5219
|
+
}
|
|
5220
|
+
}
|
|
5221
|
+
};
|
|
5222
|
+
const _hoisted_1$1 = {
|
|
5223
|
+
class: "article-item",
|
|
5224
|
+
contenteditable: "false"
|
|
5225
|
+
};
|
|
5226
|
+
const _hoisted_2$1 = ["src"];
|
|
5227
|
+
const _hoisted_3$1 = { class: "article-item_right" };
|
|
4517
5228
|
const _hoisted_4 = { class: "name" };
|
|
4518
5229
|
const _hoisted_5 = { class: "score" };
|
|
4519
5230
|
function _sfc_render$1(_ctx, _cache, $props, $setup, $data, $options) {
|
|
@@ -4528,8 +5239,8 @@
|
|
|
4528
5239
|
vue.createElementVNode("div", _hoisted_4, vue.toDisplayString($props.article.title), 1),
|
|
4529
5240
|
vue.createElementVNode("div", _hoisted_5, [
|
|
4530
5241
|
vue.createElementVNode("span", null, vue.toDisplayString($props.article.author), 1),
|
|
4531
|
-
vue.createElementVNode("span", null, vue.toDisplayString($props.article.viewNum) + "
|
|
4532
|
-
vue.createElementVNode("span", null, vue.toDisplayString($props.article.replycnt) + "
|
|
5242
|
+
vue.createElementVNode("span", null, vue.toDisplayString($props.article.viewNum) + "浏览", 1),
|
|
5243
|
+
vue.createElementVNode("span", null, vue.toDisplayString($props.article.replycnt) + "评论", 1)
|
|
4533
5244
|
])
|
|
4534
5245
|
]),
|
|
4535
5246
|
vue.createVNode(_component_el_icon_error, {
|
|
@@ -4541,10 +5252,10 @@
|
|
|
4541
5252
|
class: vue.normalizeClass([{
|
|
4542
5253
|
"article-bg-height": $props.article.img || $props.article.mediaInfo && $props.article.mediaInfo.length
|
|
4543
5254
|
}, "article-bg"])
|
|
4544
|
-
}, "
|
|
5255
|
+
}, " 平台仅支持展示18个月的推荐内容 ", 2)) : vue.createCommentVNode("", true)
|
|
4545
5256
|
]);
|
|
4546
5257
|
}
|
|
4547
|
-
const Item = /* @__PURE__ */ _export_sfc(_sfc_main$1, [["render", _sfc_render$1], ["__scopeId", "data-v-
|
|
5258
|
+
const Item = /* @__PURE__ */ _export_sfc(_sfc_main$1, [["render", _sfc_render$1], ["__scopeId", "data-v-4ebe06df"]]);
|
|
4548
5259
|
const mountArticleDom = (props, del) => {
|
|
4549
5260
|
const className = "article-wrap";
|
|
4550
5261
|
const article = props.article;
|
|
@@ -4578,14 +5289,15 @@
|
|
|
4578
5289
|
name: "Edit",
|
|
4579
5290
|
components: {
|
|
4580
5291
|
ElInput: elementPlus.ElInput,
|
|
4581
|
-
InsertArticle: _sfc_main$
|
|
4582
|
-
ImgUpload: _sfc_main$
|
|
4583
|
-
VideoUpload: _sfc_main$
|
|
5292
|
+
InsertArticle: _sfc_main$6,
|
|
5293
|
+
ImgUpload: _sfc_main$5,
|
|
5294
|
+
VideoUpload: _sfc_main$4,
|
|
4584
5295
|
CollectArticle,
|
|
4585
5296
|
ElFormItem: elementPlus.ElFormItem,
|
|
4586
5297
|
ElForm: elementPlus.ElForm,
|
|
4587
5298
|
ElDialog: elementPlus.ElDialog,
|
|
4588
|
-
ElButton: elementPlus.ElButton
|
|
5299
|
+
ElButton: elementPlus.ElButton,
|
|
5300
|
+
TopicManager
|
|
4589
5301
|
},
|
|
4590
5302
|
props: [
|
|
4591
5303
|
"disabled",
|
|
@@ -4595,13 +5307,15 @@
|
|
|
4595
5307
|
"importEssay",
|
|
4596
5308
|
"uploadImageByOther",
|
|
4597
5309
|
"chartGallery",
|
|
4598
|
-
"request"
|
|
5310
|
+
"request",
|
|
5311
|
+
"placeholder"
|
|
4599
5312
|
],
|
|
4600
5313
|
data() {
|
|
4601
5314
|
return {
|
|
4602
5315
|
hasArticleCard: false,
|
|
4603
5316
|
cursorStyle: "auto",
|
|
4604
5317
|
titleCount: 0,
|
|
5318
|
+
// 标题数量
|
|
4605
5319
|
viewLinkDialog: false,
|
|
4606
5320
|
linkForm: {
|
|
4607
5321
|
linkAddress: "",
|
|
@@ -4609,39 +5323,54 @@
|
|
|
4609
5323
|
},
|
|
4610
5324
|
setAlignFlag: true,
|
|
4611
5325
|
article: {},
|
|
5326
|
+
// 插入的文章
|
|
4612
5327
|
imgList: [],
|
|
4613
5328
|
imgNum: 20,
|
|
4614
5329
|
videoList: [],
|
|
4615
5330
|
visibleVideo: false,
|
|
4616
5331
|
visibleCollectArticle: false,
|
|
4617
5332
|
visibleArticle: false,
|
|
5333
|
+
// 插入文章
|
|
4618
5334
|
visibleImg: false,
|
|
5335
|
+
// 插入图片
|
|
4619
5336
|
imgType: "normal",
|
|
5337
|
+
//
|
|
4620
5338
|
typeEnum: {
|
|
4621
|
-
|
|
4622
|
-
|
|
4623
|
-
|
|
4624
|
-
|
|
4625
|
-
|
|
4626
|
-
|
|
4627
|
-
|
|
5339
|
+
文字: "1",
|
|
5340
|
+
图片: "2",
|
|
5341
|
+
图文: "3",
|
|
5342
|
+
段落标题: "4",
|
|
5343
|
+
关联: "5",
|
|
5344
|
+
// 关联车辆、轨迹、活动、商家、话题
|
|
5345
|
+
单视频: "6",
|
|
5346
|
+
视频文字: "7",
|
|
4628
5347
|
URL: "8",
|
|
4629
|
-
|
|
5348
|
+
文章卡片: "11"
|
|
4630
5349
|
},
|
|
4631
5350
|
fontInfo: {
|
|
4632
5351
|
size: ""
|
|
4633
5352
|
},
|
|
4634
5353
|
user: {},
|
|
5354
|
+
// 用户
|
|
4635
5355
|
editor: {},
|
|
5356
|
+
// 编辑器实例对象
|
|
4636
5357
|
editorDom: {},
|
|
5358
|
+
// 编辑器Dom
|
|
4637
5359
|
uploadStore: {},
|
|
5360
|
+
// 待上传的图片池
|
|
4638
5361
|
linkContent: "",
|
|
5362
|
+
// 插入链接的地址
|
|
4639
5363
|
loadingText: "",
|
|
5364
|
+
// loaing的提示文字
|
|
4640
5365
|
progressPercent: "",
|
|
5366
|
+
// 上传进度
|
|
4641
5367
|
currentIndex: 0,
|
|
4642
5368
|
loading: false,
|
|
5369
|
+
// 是否提交中
|
|
4643
5370
|
viewStatus: false,
|
|
5371
|
+
// todo: 改名
|
|
4644
5372
|
linkStatus: false,
|
|
5373
|
+
// todo: 改名
|
|
4645
5374
|
styleStatus: {
|
|
4646
5375
|
bold: false,
|
|
4647
5376
|
italic: false,
|
|
@@ -4665,6 +5394,7 @@
|
|
|
4665
5394
|
targetMove: "",
|
|
4666
5395
|
moverClasses: ["halo-img-content", "halo-video-content"],
|
|
4667
5396
|
selectDom: null
|
|
5397
|
+
//选中的dom
|
|
4668
5398
|
};
|
|
4669
5399
|
},
|
|
4670
5400
|
computed: {
|
|
@@ -4681,12 +5411,12 @@
|
|
|
4681
5411
|
watch: {
|
|
4682
5412
|
progressPercent(val) {
|
|
4683
5413
|
const inner = document.querySelector(".video-progress .inner");
|
|
4684
|
-
console.log(val, "
|
|
5414
|
+
console.log(val, "视频上传进度");
|
|
4685
5415
|
if (inner) {
|
|
4686
5416
|
inner.style.width = val + "%";
|
|
4687
5417
|
if (val === 100) {
|
|
4688
5418
|
document.querySelector(".video-progress").innerHTML = `
|
|
4689
|
-
<div class="no-calc" style="text-align:center;color:#999999;font-size:18px;"
|
|
5419
|
+
<div class="no-calc" style="text-align:center;color:#999999;font-size:18px;">正在获取视频封面</div>
|
|
4690
5420
|
`;
|
|
4691
5421
|
}
|
|
4692
5422
|
}
|
|
@@ -4705,7 +5435,7 @@
|
|
|
4705
5435
|
me2.user = JSON.parse(
|
|
4706
5436
|
window.localStorage.getItem("user") || window.localStorage.getItem("userInfo") || "{}"
|
|
4707
5437
|
);
|
|
4708
|
-
me2.guid = me2.user.uid + "|" +
|
|
5438
|
+
me2.guid = me2.user.uid + "|" + util.tools.guid();
|
|
4709
5439
|
},
|
|
4710
5440
|
beforeDestroy() {
|
|
4711
5441
|
this.editorDom && this.editorDom.removeEventListener("blur", this.canSetAlign);
|
|
@@ -4738,7 +5468,6 @@
|
|
|
4738
5468
|
},
|
|
4739
5469
|
setCursor() {
|
|
4740
5470
|
this.cursorStyle = this.cursorStyle === cursorImg ? "auto" : cursorImg;
|
|
4741
|
-
console.log(this.styleStatus, 999);
|
|
4742
5471
|
this.curStyle = { ...this.styleStatus };
|
|
4743
5472
|
this.editorDom.addEventListener("mouseup", this.handleCopyFormatUp);
|
|
4744
5473
|
},
|
|
@@ -4776,10 +5505,10 @@
|
|
|
4776
5505
|
this.visibleVideo = false;
|
|
4777
5506
|
const fileName = (files[0] && files[0].name || "").toLowerCase();
|
|
4778
5507
|
if (files[0].size > 1 * 1024 * 1024 * 1024) {
|
|
4779
|
-
return me2.setToast("
|
|
5508
|
+
return me2.setToast("视频大小不能超过1GB");
|
|
4780
5509
|
}
|
|
4781
5510
|
if (fileName.indexOf(".mp4") === -1 && fileName.indexOf(".mov") === -1) {
|
|
4782
|
-
return me2.setToast("
|
|
5511
|
+
return me2.setToast("视频格式不是mp4或mov");
|
|
4783
5512
|
}
|
|
4784
5513
|
const me2 = this;
|
|
4785
5514
|
if (me2.loading)
|
|
@@ -4799,7 +5528,9 @@
|
|
|
4799
5528
|
id: result.videoId,
|
|
4800
5529
|
desc: "",
|
|
4801
5530
|
vodSize: result.vodSize || "",
|
|
5531
|
+
// 视频大小
|
|
4802
5532
|
vodType: result.vodType || ""
|
|
5533
|
+
// 图片尺寸
|
|
4803
5534
|
};
|
|
4804
5535
|
me2.$emit("updateAddVideo", true);
|
|
4805
5536
|
me2.editor["insertVideo"](result.videoUrl, video);
|
|
@@ -4853,11 +5584,11 @@
|
|
|
4853
5584
|
},
|
|
4854
5585
|
insertLink() {
|
|
4855
5586
|
if (!this.linkForm.linkAddress)
|
|
4856
|
-
return elementPlus.ElMessage.error("
|
|
5587
|
+
return elementPlus.ElMessage.error("请输入链接地址");
|
|
4857
5588
|
if (!this.linkForm.linkWriting)
|
|
4858
|
-
return elementPlus.ElMessage.error("
|
|
5589
|
+
return elementPlus.ElMessage.error("请输入链接文案");
|
|
4859
5590
|
if (!this.validUrl(this.linkForm.linkAddress)) {
|
|
4860
|
-
return this.setToast("URL
|
|
5591
|
+
return this.setToast("URL无效");
|
|
4861
5592
|
}
|
|
4862
5593
|
this.editor.insertLink(
|
|
4863
5594
|
this.linkForm.linkAddress,
|
|
@@ -4886,6 +5617,10 @@
|
|
|
4886
5617
|
});
|
|
4887
5618
|
});
|
|
4888
5619
|
},
|
|
5620
|
+
// TopicManager事件处理
|
|
5621
|
+
onTopicInserted(topic) {
|
|
5622
|
+
this.updateData(true);
|
|
5623
|
+
},
|
|
4889
5624
|
getHtml(type) {
|
|
4890
5625
|
this.updateTopicPosition();
|
|
4891
5626
|
const html = this.editor.getHTML();
|
|
@@ -4987,6 +5722,8 @@
|
|
|
4987
5722
|
const frag = document.createDocumentFragment();
|
|
4988
5723
|
frag.appendChild(this.editor.empty(div));
|
|
4989
5724
|
const nodes = [...frag.childNodes];
|
|
5725
|
+
const mddTopics = frag.querySelectorAll("mdd-topic");
|
|
5726
|
+
mddTopics.forEach((topic) => topic.setAttribute("contenteditable", "false"));
|
|
4990
5727
|
for (let i = 0; i < nodes.length; i++) {
|
|
4991
5728
|
const node = nodes[i];
|
|
4992
5729
|
if (node.nodeType === 1) {
|
|
@@ -5080,6 +5817,8 @@
|
|
|
5080
5817
|
},
|
|
5081
5818
|
async parseArticle(node) {
|
|
5082
5819
|
const data = JSON.parse(node.dataset.article);
|
|
5820
|
+
if (!this.getEassyDetail)
|
|
5821
|
+
return;
|
|
5083
5822
|
await this.getEassyDetail(data.id, (info) => {
|
|
5084
5823
|
const el = mountArticleDom(
|
|
5085
5824
|
{
|
|
@@ -5336,7 +6075,7 @@
|
|
|
5336
6075
|
}
|
|
5337
6076
|
this.updateData(true);
|
|
5338
6077
|
} else {
|
|
5339
|
-
this.setToast(rst.origin.name + "
|
|
6078
|
+
this.setToast(rst.origin.name + "上传失败,请重试");
|
|
5340
6079
|
}
|
|
5341
6080
|
},
|
|
5342
6081
|
insertVideoBtns(editor, node) {
|
|
@@ -5351,7 +6090,7 @@
|
|
|
5351
6090
|
me2.currentVideo = node;
|
|
5352
6091
|
e.stopPropagation();
|
|
5353
6092
|
};
|
|
5354
|
-
replaceBtn.innerText = "
|
|
6093
|
+
replaceBtn.innerText = "更换封面";
|
|
5355
6094
|
return replaceBtn;
|
|
5356
6095
|
},
|
|
5357
6096
|
insertImgOperateBtns(editor, data) {
|
|
@@ -5372,13 +6111,12 @@
|
|
|
5372
6111
|
}
|
|
5373
6112
|
});
|
|
5374
6113
|
var descInputWrap;
|
|
5375
|
-
console.log(data.seamlessFlag, "count<<<<<<");
|
|
5376
6114
|
var descInput = editor.createElement("textarea", {
|
|
5377
6115
|
class: "desc-input",
|
|
5378
6116
|
maxlength: "50",
|
|
5379
6117
|
rows: "2",
|
|
5380
6118
|
cols: "50",
|
|
5381
|
-
placeholder: "
|
|
6119
|
+
placeholder: "请输入图片描述(最多50字)",
|
|
5382
6120
|
contenteditable: "false"
|
|
5383
6121
|
});
|
|
5384
6122
|
descInput.disabled = me2.disabled;
|
|
@@ -5387,7 +6125,7 @@
|
|
|
5387
6125
|
const img = parent.querySelector(".halo-picture-area");
|
|
5388
6126
|
img.dataset.desc = e.target.value;
|
|
5389
6127
|
if (e.target.value.length > 49) {
|
|
5390
|
-
return me2.setToast("
|
|
6128
|
+
return me2.setToast("限制50个字符");
|
|
5391
6129
|
}
|
|
5392
6130
|
};
|
|
5393
6131
|
descInput.value = data.content || "";
|
|
@@ -5437,7 +6175,7 @@
|
|
|
5437
6175
|
me2.removeParentByClass(e.target, "halo-img-content");
|
|
5438
6176
|
me2.updateData(true);
|
|
5439
6177
|
};
|
|
5440
|
-
replaceBtn.innerHTML = "
|
|
6178
|
+
replaceBtn.innerHTML = "替换";
|
|
5441
6179
|
return [replaceBtn, delBtn, descInputWrap];
|
|
5442
6180
|
},
|
|
5443
6181
|
removeSeamlessLaster(e) {
|
|
@@ -5461,6 +6199,7 @@
|
|
|
5461
6199
|
}
|
|
5462
6200
|
}
|
|
5463
6201
|
},
|
|
6202
|
+
// 初始化编辑器数据,数据是 html 格式(displayData)
|
|
5464
6203
|
initData(data = "", essayPicRelVOList) {
|
|
5465
6204
|
this.parseHtml(data, essayPicRelVOList).then((res) => {
|
|
5466
6205
|
this.editorDom.innerHTML = "";
|
|
@@ -5468,6 +6207,13 @@
|
|
|
5468
6207
|
this.updateData();
|
|
5469
6208
|
});
|
|
5470
6209
|
},
|
|
6210
|
+
// TODO jsonToHtml、htmlToJson 实现这 2 个方法里面的逻辑,数据结构参考方法里面的注释,出参入参都为字符串,注意:mdd-topic 里面的属性数据 和 json 中的topicPosition数据是一一对应的,startIndex、endIndex为mdd-topic的起止位置 从 content 里面进行分割处理
|
|
6211
|
+
// json、html 数据格式互转,暂时只支持文字、短话题
|
|
6212
|
+
jsonToHtml(json) {
|
|
6213
|
+
},
|
|
6214
|
+
htmlToJson(html) {
|
|
6215
|
+
},
|
|
6216
|
+
// 设置富文本组件
|
|
5471
6217
|
initSquire() {
|
|
5472
6218
|
const me2 = this;
|
|
5473
6219
|
const editorDom = me2.editorDom;
|
|
@@ -5555,7 +6301,8 @@
|
|
|
5555
6301
|
event.preventDefault();
|
|
5556
6302
|
});
|
|
5557
6303
|
me2.editor.addEventListener("keydown", function(event) {
|
|
5558
|
-
|
|
6304
|
+
var _a, _b, _c;
|
|
6305
|
+
if (["Backspace", "Delete"].includes(event.key)) {
|
|
5559
6306
|
try {
|
|
5560
6307
|
const selection2 = getSelection();
|
|
5561
6308
|
if (me2.selectDom && me2.moverClasses.includes(me2.selectDom.className)) {
|
|
@@ -5589,32 +6336,10 @@
|
|
|
5589
6336
|
} catch (error) {
|
|
5590
6337
|
console.log(error);
|
|
5591
6338
|
}
|
|
5592
|
-
|
|
5593
|
-
|
|
5594
|
-
|
|
5595
|
-
|
|
5596
|
-
const startContainer = range.startContainer;
|
|
5597
|
-
let isInMddTopic = false;
|
|
5598
|
-
if (startContainer.nodeType === Node.ELEMENT_NODE && startContainer.tagName === "MDD-TOPIC") {
|
|
5599
|
-
isInMddTopic = true;
|
|
5600
|
-
} else if (startContainer.nodeType === Node.TEXT_NODE) {
|
|
5601
|
-
const parent = startContainer.parentNode;
|
|
5602
|
-
if (parent.tagName === "MDD-TOPIC") {
|
|
5603
|
-
isInMddTopic = true;
|
|
5604
|
-
}
|
|
5605
|
-
}
|
|
5606
|
-
if (isInMddTopic) {
|
|
5607
|
-
if (event.key === "Enter") {
|
|
5608
|
-
event.preventDefault();
|
|
5609
|
-
return;
|
|
5610
|
-
}
|
|
5611
|
-
const isPrintableKey = event.key.length === 1;
|
|
5612
|
-
if (isPrintableKey) {
|
|
5613
|
-
event.preventDefault();
|
|
5614
|
-
return;
|
|
5615
|
-
}
|
|
5616
|
-
}
|
|
5617
|
-
if ((event.key === "Backspace" || event.key === "Delete") && isInMddTopic) {
|
|
6339
|
+
const selection = window.getSelection();
|
|
6340
|
+
if (selection.rangeCount > 0) {
|
|
6341
|
+
const range = selection.getRangeAt(0);
|
|
6342
|
+
const startContainer = range.startContainer;
|
|
5618
6343
|
if (startContainer.nodeType === Node.ELEMENT_NODE && startContainer.tagName === "MDD-TOPIC") {
|
|
5619
6344
|
startContainer.remove();
|
|
5620
6345
|
event.preventDefault();
|
|
@@ -5627,6 +6352,228 @@
|
|
|
5627
6352
|
return;
|
|
5628
6353
|
}
|
|
5629
6354
|
}
|
|
6355
|
+
let currentParagraph = startContainer;
|
|
6356
|
+
while (currentParagraph && currentParagraph.nodeType !== Node.ELEMENT_NODE) {
|
|
6357
|
+
currentParagraph = currentParagraph.parentNode;
|
|
6358
|
+
}
|
|
6359
|
+
while (currentParagraph && !((_a = currentParagraph.classList) == null ? void 0 : _a.contains("halo-paragraph"))) {
|
|
6360
|
+
currentParagraph = currentParagraph.parentNode;
|
|
6361
|
+
}
|
|
6362
|
+
if (currentParagraph && event.key === "Backspace") {
|
|
6363
|
+
const container = range.startContainer;
|
|
6364
|
+
const offset = range.startOffset;
|
|
6365
|
+
let isAtParagraphStart = false;
|
|
6366
|
+
let cursorBeforeContent = null;
|
|
6367
|
+
if (container === currentParagraph && offset === 0) {
|
|
6368
|
+
isAtParagraphStart = true;
|
|
6369
|
+
cursorBeforeContent = currentParagraph.firstChild;
|
|
6370
|
+
} else if (container.nodeType === Node.TEXT_NODE && offset === 0) {
|
|
6371
|
+
let isFirstContent = true;
|
|
6372
|
+
let currentNode = currentParagraph.firstChild;
|
|
6373
|
+
while (currentNode && currentNode !== container) {
|
|
6374
|
+
if (currentNode.nodeType === Node.TEXT_NODE && currentNode.textContent.trim() !== "") {
|
|
6375
|
+
isFirstContent = false;
|
|
6376
|
+
break;
|
|
6377
|
+
} else if (currentNode.nodeType === Node.ELEMENT_NODE) {
|
|
6378
|
+
isFirstContent = false;
|
|
6379
|
+
break;
|
|
6380
|
+
}
|
|
6381
|
+
currentNode = currentNode.nextSibling;
|
|
6382
|
+
}
|
|
6383
|
+
if (isFirstContent) {
|
|
6384
|
+
isAtParagraphStart = true;
|
|
6385
|
+
cursorBeforeContent = container;
|
|
6386
|
+
}
|
|
6387
|
+
} else if (container === currentParagraph && offset > 0) {
|
|
6388
|
+
let hasContentBefore = false;
|
|
6389
|
+
for (let i = 0; i < offset; i++) {
|
|
6390
|
+
const node = currentParagraph.childNodes[i];
|
|
6391
|
+
if (node.nodeType === Node.TEXT_NODE && node.textContent.trim() !== "") {
|
|
6392
|
+
hasContentBefore = true;
|
|
6393
|
+
break;
|
|
6394
|
+
} else if (node.nodeType === Node.ELEMENT_NODE) {
|
|
6395
|
+
hasContentBefore = true;
|
|
6396
|
+
break;
|
|
6397
|
+
}
|
|
6398
|
+
}
|
|
6399
|
+
if (!hasContentBefore && offset < currentParagraph.childNodes.length) {
|
|
6400
|
+
isAtParagraphStart = true;
|
|
6401
|
+
cursorBeforeContent = currentParagraph.childNodes[offset];
|
|
6402
|
+
}
|
|
6403
|
+
}
|
|
6404
|
+
if (isAtParagraphStart) {
|
|
6405
|
+
const prevParagraph = currentParagraph.previousElementSibling;
|
|
6406
|
+
if (prevParagraph && prevParagraph.classList.contains("halo-paragraph")) {
|
|
6407
|
+
const prevContent = prevParagraph.innerHTML.trim();
|
|
6408
|
+
if (prevContent === "<br>" || prevContent === "") {
|
|
6409
|
+
prevParagraph.remove();
|
|
6410
|
+
event.preventDefault();
|
|
6411
|
+
me2.updateData(true);
|
|
6412
|
+
return;
|
|
6413
|
+
} else {
|
|
6414
|
+
const mergePoint = prevParagraph.childNodes.length;
|
|
6415
|
+
if (prevParagraph.lastChild && prevParagraph.lastChild.tagName === "BR") {
|
|
6416
|
+
prevParagraph.removeChild(prevParagraph.lastChild);
|
|
6417
|
+
}
|
|
6418
|
+
const nodesToMove = Array.from(currentParagraph.childNodes);
|
|
6419
|
+
nodesToMove.forEach((node) => {
|
|
6420
|
+
prevParagraph.appendChild(node);
|
|
6421
|
+
});
|
|
6422
|
+
currentParagraph.remove();
|
|
6423
|
+
const newRange = document.createRange();
|
|
6424
|
+
if (cursorBeforeContent && prevParagraph.contains(cursorBeforeContent)) {
|
|
6425
|
+
newRange.setStartBefore(cursorBeforeContent);
|
|
6426
|
+
} else {
|
|
6427
|
+
if (mergePoint < prevParagraph.childNodes.length) {
|
|
6428
|
+
newRange.setStartBefore(prevParagraph.childNodes[mergePoint]);
|
|
6429
|
+
} else {
|
|
6430
|
+
newRange.setStart(prevParagraph, prevParagraph.childNodes.length);
|
|
6431
|
+
}
|
|
6432
|
+
}
|
|
6433
|
+
newRange.collapse(true);
|
|
6434
|
+
const selection2 = window.getSelection();
|
|
6435
|
+
selection2.removeAllRanges();
|
|
6436
|
+
selection2.addRange(newRange);
|
|
6437
|
+
event.preventDefault();
|
|
6438
|
+
me2.updateData(true);
|
|
6439
|
+
return;
|
|
6440
|
+
}
|
|
6441
|
+
}
|
|
6442
|
+
}
|
|
6443
|
+
}
|
|
6444
|
+
}
|
|
6445
|
+
}
|
|
6446
|
+
if (event.key === "Enter") {
|
|
6447
|
+
const selection = window.getSelection();
|
|
6448
|
+
if (selection.rangeCount > 0) {
|
|
6449
|
+
const range = selection.getRangeAt(0);
|
|
6450
|
+
const startContainer = range.startContainer;
|
|
6451
|
+
let currentParagraph = startContainer;
|
|
6452
|
+
while (currentParagraph && currentParagraph.nodeType !== Node.ELEMENT_NODE) {
|
|
6453
|
+
currentParagraph = currentParagraph.parentNode;
|
|
6454
|
+
}
|
|
6455
|
+
while (currentParagraph && !((_b = currentParagraph.classList) == null ? void 0 : _b.contains("halo-paragraph"))) {
|
|
6456
|
+
currentParagraph = currentParagraph.parentNode;
|
|
6457
|
+
}
|
|
6458
|
+
if (!(currentParagraph == null ? void 0 : currentParagraph.querySelector("mdd-topic"))) {
|
|
6459
|
+
return;
|
|
6460
|
+
}
|
|
6461
|
+
if (me2.isBetweenTwoTopics(range)) {
|
|
6462
|
+
event.preventDefault();
|
|
6463
|
+
me2.handleEnterBetweenTopics(range);
|
|
6464
|
+
return;
|
|
6465
|
+
}
|
|
6466
|
+
if (me2.wouldCreateNestedParagraph(range)) {
|
|
6467
|
+
event.preventDefault();
|
|
6468
|
+
me2.handleEnterKeyInParagraphWithTopic(range);
|
|
6469
|
+
return;
|
|
6470
|
+
}
|
|
6471
|
+
if (currentParagraph && currentParagraph.querySelector("mdd-topic")) {
|
|
6472
|
+
event.preventDefault();
|
|
6473
|
+
me2.handleEnterKeyInParagraphWithTopic(range);
|
|
6474
|
+
return;
|
|
6475
|
+
}
|
|
6476
|
+
}
|
|
6477
|
+
}
|
|
6478
|
+
if ((event.metaKey || event.ctrlKey) && event.key === "ArrowLeft") {
|
|
6479
|
+
const selection = window.getSelection();
|
|
6480
|
+
if (selection.rangeCount > 0) {
|
|
6481
|
+
const range = selection.getRangeAt(0);
|
|
6482
|
+
const container = range.startContainer;
|
|
6483
|
+
let currentParagraph = container;
|
|
6484
|
+
while (currentParagraph && currentParagraph.nodeType !== Node.ELEMENT_NODE) {
|
|
6485
|
+
currentParagraph = currentParagraph.parentNode;
|
|
6486
|
+
}
|
|
6487
|
+
while (currentParagraph && !((_c = currentParagraph.classList) == null ? void 0 : _c.contains("halo-paragraph"))) {
|
|
6488
|
+
currentParagraph = currentParagraph.parentNode;
|
|
6489
|
+
}
|
|
6490
|
+
if (currentParagraph) {
|
|
6491
|
+
const firstTopic = currentParagraph.querySelector("mdd-topic");
|
|
6492
|
+
if (firstTopic) {
|
|
6493
|
+
let hasTextBeforeTopic = false;
|
|
6494
|
+
let currentNode = currentParagraph.firstChild;
|
|
6495
|
+
while (currentNode && currentNode !== firstTopic) {
|
|
6496
|
+
if (currentNode.nodeType === Node.TEXT_NODE && currentNode.textContent.trim() !== "") {
|
|
6497
|
+
hasTextBeforeTopic = true;
|
|
6498
|
+
break;
|
|
6499
|
+
}
|
|
6500
|
+
currentNode = currentNode.nextSibling;
|
|
6501
|
+
}
|
|
6502
|
+
if (hasTextBeforeTopic) {
|
|
6503
|
+
if (container === currentParagraph && range.startOffset === 0) {
|
|
6504
|
+
return;
|
|
6505
|
+
}
|
|
6506
|
+
let shouldMoveToStart = false;
|
|
6507
|
+
const offset2 = range.startOffset;
|
|
6508
|
+
if (container.nodeType === Node.TEXT_NODE && container.parentNode === firstTopic) {
|
|
6509
|
+
shouldMoveToStart = true;
|
|
6510
|
+
} else if (container === firstTopic) {
|
|
6511
|
+
shouldMoveToStart = true;
|
|
6512
|
+
} else if (container.nodeType === Node.TEXT_NODE) {
|
|
6513
|
+
let prevSibling = container.previousSibling;
|
|
6514
|
+
while (prevSibling) {
|
|
6515
|
+
if (prevSibling === firstTopic) {
|
|
6516
|
+
shouldMoveToStart = true;
|
|
6517
|
+
break;
|
|
6518
|
+
}
|
|
6519
|
+
prevSibling = prevSibling.previousSibling;
|
|
6520
|
+
}
|
|
6521
|
+
} else if (container === currentParagraph) {
|
|
6522
|
+
const topicRange = document.createRange();
|
|
6523
|
+
topicRange.selectNode(firstTopic);
|
|
6524
|
+
const cursorRange = document.createRange();
|
|
6525
|
+
cursorRange.setStart(container, offset2);
|
|
6526
|
+
cursorRange.collapse(true);
|
|
6527
|
+
if (cursorRange.compareBoundaryPoints(Range.START_TO_END, topicRange) > 0) {
|
|
6528
|
+
shouldMoveToStart = true;
|
|
6529
|
+
}
|
|
6530
|
+
}
|
|
6531
|
+
if (shouldMoveToStart) {
|
|
6532
|
+
event.preventDefault();
|
|
6533
|
+
event.stopPropagation();
|
|
6534
|
+
const newRange = document.createRange();
|
|
6535
|
+
newRange.setStart(currentParagraph, 0);
|
|
6536
|
+
newRange.collapse(true);
|
|
6537
|
+
const selection2 = window.getSelection();
|
|
6538
|
+
selection2.removeAllRanges();
|
|
6539
|
+
selection2.addRange(newRange);
|
|
6540
|
+
return false;
|
|
6541
|
+
}
|
|
6542
|
+
return;
|
|
6543
|
+
}
|
|
6544
|
+
let shouldMoveToTopicStart = false;
|
|
6545
|
+
const offset = range.startOffset;
|
|
6546
|
+
if (container.nodeType === Node.TEXT_NODE && container.parentNode === firstTopic) {
|
|
6547
|
+
shouldMoveToTopicStart = true;
|
|
6548
|
+
} else if (container === firstTopic) {
|
|
6549
|
+
shouldMoveToTopicStart = true;
|
|
6550
|
+
} else if (container.nodeType === Node.TEXT_NODE) {
|
|
6551
|
+
let prevSibling = container.previousSibling;
|
|
6552
|
+
while (prevSibling) {
|
|
6553
|
+
if (prevSibling === firstTopic) {
|
|
6554
|
+
shouldMoveToTopicStart = true;
|
|
6555
|
+
break;
|
|
6556
|
+
}
|
|
6557
|
+
prevSibling = prevSibling.previousSibling;
|
|
6558
|
+
}
|
|
6559
|
+
} else if (container === currentParagraph) {
|
|
6560
|
+
const topicRange = document.createRange();
|
|
6561
|
+
topicRange.selectNode(firstTopic);
|
|
6562
|
+
const cursorRange = document.createRange();
|
|
6563
|
+
cursorRange.setStart(container, offset);
|
|
6564
|
+
cursorRange.collapse(true);
|
|
6565
|
+
if (cursorRange.compareBoundaryPoints(Range.START_TO_END, topicRange) > 0) {
|
|
6566
|
+
shouldMoveToTopicStart = true;
|
|
6567
|
+
}
|
|
6568
|
+
}
|
|
6569
|
+
if (shouldMoveToTopicStart) {
|
|
6570
|
+
event.preventDefault();
|
|
6571
|
+
event.stopPropagation();
|
|
6572
|
+
me2.setCursorBeforeElement(firstTopic);
|
|
6573
|
+
return false;
|
|
6574
|
+
}
|
|
6575
|
+
}
|
|
6576
|
+
}
|
|
5630
6577
|
}
|
|
5631
6578
|
}
|
|
5632
6579
|
});
|
|
@@ -5689,7 +6636,6 @@
|
|
|
5689
6636
|
this.insertElement(p);
|
|
5690
6637
|
};
|
|
5691
6638
|
window.Squire.prototype.makeHeader = function(content, config = { makeHeader: {} }) {
|
|
5692
|
-
console.log(content);
|
|
5693
6639
|
if (content) {
|
|
5694
6640
|
const h2 = this.createElement("h2", {
|
|
5695
6641
|
class: "halo-paragraph-title"
|
|
@@ -5715,6 +6661,7 @@
|
|
|
5715
6661
|
window.Squire.empty(block)
|
|
5716
6662
|
]);
|
|
5717
6663
|
output.appendChild(
|
|
6664
|
+
// 段落才能添加标题
|
|
5718
6665
|
Array.from(block.classList).indexOf("halo-img-content") > -1 ? block : container
|
|
5719
6666
|
);
|
|
5720
6667
|
}
|
|
@@ -5722,7 +6669,6 @@
|
|
|
5722
6669
|
});
|
|
5723
6670
|
const selection = window.getSelection();
|
|
5724
6671
|
const range = document.createRange();
|
|
5725
|
-
console.log(container);
|
|
5726
6672
|
range.setStart(container, 1);
|
|
5727
6673
|
range.collapse(true);
|
|
5728
6674
|
selection.removeAllRanges();
|
|
@@ -5738,18 +6684,18 @@
|
|
|
5738
6684
|
});
|
|
5739
6685
|
loading.innerHTML = `
|
|
5740
6686
|
<img class="img-loading-icon" src="/img/upload-image-loading.png"/>
|
|
5741
|
-
<span class="img-loading-tip"
|
|
6687
|
+
<span class="img-loading-tip">上传中...</span>
|
|
5742
6688
|
`;
|
|
5743
6689
|
var fail = this.createElement("div", {
|
|
5744
6690
|
class: "img-fail hide",
|
|
5745
6691
|
contenteditable: "false"
|
|
5746
6692
|
});
|
|
5747
|
-
fail.innerHTML = "
|
|
6693
|
+
fail.innerHTML = "上传失败<br>请下载图片至本地后重新上传";
|
|
5748
6694
|
var again = this.createElement("button", {
|
|
5749
6695
|
class: "img-again hide",
|
|
5750
6696
|
contenteditable: "false"
|
|
5751
6697
|
});
|
|
5752
|
-
again.innerHTML = "
|
|
6698
|
+
again.innerHTML = "重新上传";
|
|
5753
6699
|
const isGif = src && src.indexOf(".gif") > -1;
|
|
5754
6700
|
if (isGif) {
|
|
5755
6701
|
src = src.replace(".gif", ".gif!nowater");
|
|
@@ -5804,7 +6750,7 @@
|
|
|
5804
6750
|
});
|
|
5805
6751
|
div.innerHTML = `
|
|
5806
6752
|
<div class="video-progress">
|
|
5807
|
-
<div class="label"
|
|
6753
|
+
<div class="label">上传中...</div>
|
|
5808
6754
|
<div class="box">
|
|
5809
6755
|
<div class="inner" style="width:20%"></div>
|
|
5810
6756
|
</div>
|
|
@@ -5827,6 +6773,7 @@
|
|
|
5827
6773
|
data: JSON.stringify(data),
|
|
5828
6774
|
"data-content": data.content || "",
|
|
5829
6775
|
poster: data.img || ""
|
|
6776
|
+
// 'contenteditable': 'true',
|
|
5830
6777
|
});
|
|
5831
6778
|
var delBtn = me2.genIconDom({
|
|
5832
6779
|
class: "pointer video-delete icon",
|
|
@@ -5836,7 +6783,6 @@
|
|
|
5836
6783
|
e.stopPropagation();
|
|
5837
6784
|
}
|
|
5838
6785
|
});
|
|
5839
|
-
console.log(delBtn);
|
|
5840
6786
|
const posterBtn = me2.insertVideoBtns(this, video);
|
|
5841
6787
|
var p = this.createElement(
|
|
5842
6788
|
"DIV",
|
|
@@ -5885,6 +6831,7 @@
|
|
|
5885
6831
|
}
|
|
5886
6832
|
};
|
|
5887
6833
|
},
|
|
6834
|
+
// 撤销重做 会把 所有的监听全都移除,所以需要重新绑定
|
|
5888
6835
|
setListener(dom) {
|
|
5889
6836
|
const me2 = this;
|
|
5890
6837
|
const doms = dom ? [dom] : Array.from(this.editorDom.children);
|
|
@@ -5895,7 +6842,7 @@
|
|
|
5895
6842
|
p.onclick = function(e) {
|
|
5896
6843
|
var _a;
|
|
5897
6844
|
if (area.nodeName === "VIDEO" && ((_a = me2.selectDom) == null ? void 0 : _a.className) === "halo-video-content") {
|
|
5898
|
-
me2.setToast("
|
|
6845
|
+
me2.setToast("不支持播放");
|
|
5899
6846
|
}
|
|
5900
6847
|
if (e.target.className.includes("desc-input")) {
|
|
5901
6848
|
return;
|
|
@@ -5959,6 +6906,7 @@
|
|
|
5959
6906
|
};
|
|
5960
6907
|
return del;
|
|
5961
6908
|
},
|
|
6909
|
+
// 转换数据,返回给业务
|
|
5962
6910
|
getEditorData() {
|
|
5963
6911
|
const me2 = this;
|
|
5964
6912
|
const children = Array.from(me2.editorDom.children);
|
|
@@ -6016,9 +6964,11 @@
|
|
|
6016
6964
|
videoIds
|
|
6017
6965
|
};
|
|
6018
6966
|
},
|
|
6967
|
+
// 是否是摩托范的图片
|
|
6019
6968
|
isHaloImage(url = "") {
|
|
6020
6969
|
return url.indexOf("jddmoto") > -1 || url.indexOf("58moto") > -1 || url.indexOf("emotofine") > -1 || url.indexOf("dronefine") > -1;
|
|
6021
6970
|
},
|
|
6971
|
+
// 获取待上传图片列表
|
|
6022
6972
|
updateUploads() {
|
|
6023
6973
|
const me2 = this;
|
|
6024
6974
|
setTimeout(() => {
|
|
@@ -6065,8 +7015,8 @@
|
|
|
6065
7015
|
const currentImg = me2.uploadStore[key];
|
|
6066
7016
|
const imageUrl = key.split("|")[1] || "";
|
|
6067
7017
|
if (!currentImg) {
|
|
6068
|
-
console.log("
|
|
6069
|
-
return Promise.reject("
|
|
7018
|
+
console.log("图片不存在", key);
|
|
7019
|
+
return Promise.reject("图片不存在");
|
|
6070
7020
|
}
|
|
6071
7021
|
const parent = currentImg.parentNode || "";
|
|
6072
7022
|
const uploadFailHandler = (currentImg2) => {
|
|
@@ -6110,6 +7060,7 @@
|
|
|
6110
7060
|
parent && uploadFailHandler(currentImg);
|
|
6111
7061
|
});
|
|
6112
7062
|
},
|
|
7063
|
+
// 更新上传的图片
|
|
6113
7064
|
updateImage(img, currentImg = {}) {
|
|
6114
7065
|
const data = JSON.parse(currentImg.getAttribute("data") || "{}");
|
|
6115
7066
|
data.img = img;
|
|
@@ -6132,6 +7083,7 @@
|
|
|
6132
7083
|
parent.appendChild(arr[2]);
|
|
6133
7084
|
}
|
|
6134
7085
|
},
|
|
7086
|
+
// 获取ctrl + v 后内容
|
|
6135
7087
|
getSticker(type, handler) {
|
|
6136
7088
|
this.setSticker(type.fragment.children);
|
|
6137
7089
|
},
|
|
@@ -6149,6 +7101,7 @@
|
|
|
6149
7101
|
});
|
|
6150
7102
|
this.updateData(true);
|
|
6151
7103
|
},
|
|
7104
|
+
// 粘贴
|
|
6152
7105
|
setSticker(data) {
|
|
6153
7106
|
const me2 = this;
|
|
6154
7107
|
data = Array.from(data);
|
|
@@ -6187,6 +7140,7 @@
|
|
|
6187
7140
|
const me2 = this;
|
|
6188
7141
|
me2.updateData();
|
|
6189
7142
|
},
|
|
7143
|
+
// 监测 添加、撤回、恢复、删除
|
|
6190
7144
|
setBack(e, type) {
|
|
6191
7145
|
const me2 = this;
|
|
6192
7146
|
me2.refreshImg();
|
|
@@ -6219,6 +7173,7 @@
|
|
|
6219
7173
|
}
|
|
6220
7174
|
});
|
|
6221
7175
|
},
|
|
7176
|
+
// 设置scoll
|
|
6222
7177
|
sticky() {
|
|
6223
7178
|
const me2 = this;
|
|
6224
7179
|
me2.$nextTick(function() {
|
|
@@ -6238,6 +7193,8 @@
|
|
|
6238
7193
|
document.addEventListener("scroll", onScroll);
|
|
6239
7194
|
});
|
|
6240
7195
|
},
|
|
7196
|
+
// ==========toolbox==========
|
|
7197
|
+
// 撤回、恢复、段落标题
|
|
6241
7198
|
setContent(e, obj) {
|
|
6242
7199
|
const me2 = this;
|
|
6243
7200
|
const id = e.target.id || e.target.dataset.editorId;
|
|
@@ -6279,10 +7236,11 @@
|
|
|
6279
7236
|
this.fontInfo = this.editor.getFontInfo();
|
|
6280
7237
|
this.updateData(true);
|
|
6281
7238
|
},
|
|
7239
|
+
// 增加link
|
|
6282
7240
|
addLink(type) {
|
|
6283
7241
|
const me2 = this;
|
|
6284
|
-
me2.linkTitleName = type === "link" ? "
|
|
6285
|
-
me2.linkPlaceholder = type === "link" ? "
|
|
7242
|
+
me2.linkTitleName = type === "link" ? "添加链接" : "添加导入链接地址";
|
|
7243
|
+
me2.linkPlaceholder = type === "link" ? "请输入链接地址" : "仅支持输入微信链接";
|
|
6286
7244
|
me2.viewStatus = true;
|
|
6287
7245
|
me2.linkStatus = true;
|
|
6288
7246
|
},
|
|
@@ -6290,29 +7248,31 @@
|
|
|
6290
7248
|
const objExp = /^(((ht|f)tp(s?)):\/\/)?(www.|[a-zA-Z].)[a-zA-Z0-9-.]+.(com|edu|gov|mil|net|org|biz|info|name|museum|us|ca|uk|cn|im)(:[0-9]+)*(\/($|[a-zA-Z0-9.,;?'&%$#=~_-]+))*$/;
|
|
6291
7249
|
return objExp.test(url);
|
|
6292
7250
|
},
|
|
7251
|
+
// 确认增加link
|
|
6293
7252
|
confirmLink() {
|
|
6294
7253
|
const me2 = this;
|
|
6295
7254
|
if (!me2.linkContent) {
|
|
6296
|
-
return elementPlus.ElMessage.error("
|
|
7255
|
+
return elementPlus.ElMessage.error("请输入链接地址!");
|
|
6297
7256
|
}
|
|
6298
|
-
if (me2.linkTitleName === "
|
|
7257
|
+
if (me2.linkTitleName === "添加导入链接地址" || this.visibleCollectArticle) {
|
|
6299
7258
|
this.visibleCollectArticle = false;
|
|
6300
7259
|
return me2.importLinkData();
|
|
6301
7260
|
}
|
|
6302
7261
|
if (!this.validUrl(me2.linkContent)) {
|
|
6303
|
-
return me2.setToast("URL
|
|
7262
|
+
return me2.setToast("URL无效");
|
|
6304
7263
|
}
|
|
6305
7264
|
if (!me2.isHaloImage(me2.linkContent)) {
|
|
6306
|
-
return me2.setToast("
|
|
7265
|
+
return me2.setToast("请输入摩托范内部网址");
|
|
6307
7266
|
}
|
|
6308
7267
|
me2.editor["insertLink"](me2.linkContent);
|
|
6309
7268
|
me2.linkContent = "";
|
|
6310
7269
|
me2.closeDialog();
|
|
6311
7270
|
},
|
|
7271
|
+
// 增加link导入数据
|
|
6312
7272
|
importLinkData() {
|
|
6313
7273
|
const me2 = this;
|
|
6314
7274
|
if (me2.loading) {
|
|
6315
|
-
return elementPlus.ElMessage("
|
|
7275
|
+
return elementPlus.ElMessage("正在获取信息,请稍后...");
|
|
6316
7276
|
}
|
|
6317
7277
|
me2.loading = true;
|
|
6318
7278
|
const params = {
|
|
@@ -6334,38 +7294,444 @@
|
|
|
6334
7294
|
me2.linkContent = "";
|
|
6335
7295
|
return;
|
|
6336
7296
|
} else {
|
|
6337
|
-
me2.setToast("
|
|
7297
|
+
me2.setToast("导入失败,请重试");
|
|
6338
7298
|
}
|
|
6339
7299
|
}).catch((err) => {
|
|
6340
7300
|
console.log(err.message);
|
|
6341
|
-
me2.setToast("
|
|
7301
|
+
me2.setToast("导入异常,请重试");
|
|
6342
7302
|
}).finally((_) => {
|
|
6343
7303
|
me2.loading = false;
|
|
6344
7304
|
});
|
|
6345
7305
|
},
|
|
7306
|
+
// 打开 图片、视频、一键导入 弹框
|
|
6346
7307
|
openDialog(name) {
|
|
6347
7308
|
const me2 = this;
|
|
6348
|
-
me2.viewName = name === "img" ? "
|
|
6349
|
-
me2.viewButton = name === "img" ? "
|
|
6350
|
-
me2.viewTip = name === "img" ? "" : "
|
|
7309
|
+
me2.viewName = name === "img" ? "添加图片" : "添加视频";
|
|
7310
|
+
me2.viewButton = name === "img" ? "选择图片" : "选择视频";
|
|
7311
|
+
me2.viewTip = name === "img" ? "" : "为了获得更高的推荐和点击量,建议上传720p(1280*720),大小不超过500MB(视频上传需要时间,请耐心等待)";
|
|
6351
7312
|
me2.viewStatus = true;
|
|
6352
7313
|
},
|
|
7314
|
+
// 关闭弹框
|
|
6353
7315
|
closeDialog() {
|
|
6354
7316
|
this.viewStatus = false;
|
|
6355
7317
|
this.linkStatus = false;
|
|
6356
7318
|
this.linkContent = "";
|
|
6357
7319
|
},
|
|
7320
|
+
// ==========toolbox end==========
|
|
7321
|
+
// 弹框提示
|
|
6358
7322
|
setToast(content) {
|
|
6359
7323
|
elementPlus.ElMessage.error(content);
|
|
6360
7324
|
},
|
|
6361
7325
|
setMessageBoxNoCancel(content) {
|
|
6362
7326
|
elementPlus.ElMessageBox.confirm(content, "", {
|
|
6363
|
-
confirmButtonText: "
|
|
6364
|
-
cancelButtonText: "
|
|
7327
|
+
confirmButtonText: "确定",
|
|
7328
|
+
cancelButtonText: "取消",
|
|
6365
7329
|
type: "warning"
|
|
6366
7330
|
}).then(() => {
|
|
6367
7331
|
}).catch(() => {
|
|
6368
7332
|
});
|
|
7333
|
+
},
|
|
7334
|
+
// 检查是否会创建嵌套的halo-paragraph
|
|
7335
|
+
wouldCreateNestedParagraph(range) {
|
|
7336
|
+
let container = range.startContainer;
|
|
7337
|
+
while (container && container !== this.editorDom) {
|
|
7338
|
+
if (container.nodeType === Node.ELEMENT_NODE && container.classList && container.classList.contains("halo-paragraph")) {
|
|
7339
|
+
return true;
|
|
7340
|
+
}
|
|
7341
|
+
container = container.parentNode;
|
|
7342
|
+
}
|
|
7343
|
+
return false;
|
|
7344
|
+
},
|
|
7345
|
+
// 检查光标是否在两个连续的mdd-topic之间
|
|
7346
|
+
isBetweenTwoTopics(range) {
|
|
7347
|
+
const container = range.startContainer;
|
|
7348
|
+
const offset = range.startOffset;
|
|
7349
|
+
if (container.nodeType === Node.ELEMENT_NODE) {
|
|
7350
|
+
const prevElement = container.childNodes[offset - 1];
|
|
7351
|
+
const nextElement = container.childNodes[offset];
|
|
7352
|
+
return prevElement && prevElement.tagName === "MDD-TOPIC" && (nextElement && nextElement.tagName === "MDD-TOPIC");
|
|
7353
|
+
}
|
|
7354
|
+
if (container.nodeType === Node.TEXT_NODE && container.textContent.trim() === "") {
|
|
7355
|
+
const prevSibling = container.previousSibling;
|
|
7356
|
+
const nextSibling = container.nextSibling;
|
|
7357
|
+
return prevSibling && prevSibling.tagName === "MDD-TOPIC" && (nextSibling && nextSibling.tagName === "MDD-TOPIC");
|
|
7358
|
+
}
|
|
7359
|
+
return false;
|
|
7360
|
+
},
|
|
7361
|
+
// 处理两个话题之间的回车或话题前面的回车
|
|
7362
|
+
handleEnterBetweenTopics(range) {
|
|
7363
|
+
var _a;
|
|
7364
|
+
const me2 = this;
|
|
7365
|
+
let currentParagraph = range.startContainer;
|
|
7366
|
+
while (currentParagraph && currentParagraph.nodeType !== Node.ELEMENT_NODE) {
|
|
7367
|
+
currentParagraph = currentParagraph.parentNode;
|
|
7368
|
+
}
|
|
7369
|
+
while (currentParagraph && !((_a = currentParagraph.classList) == null ? void 0 : _a.contains("halo-paragraph"))) {
|
|
7370
|
+
currentParagraph = currentParagraph.parentNode;
|
|
7371
|
+
}
|
|
7372
|
+
if (!currentParagraph)
|
|
7373
|
+
return;
|
|
7374
|
+
const newParagraph = document.createElement("p");
|
|
7375
|
+
newParagraph.className = "halo-paragraph";
|
|
7376
|
+
const afterContent = me2.extractContentAfterCursorPrecise(range, currentParagraph);
|
|
7377
|
+
if (afterContent && afterContent.childNodes.length > 0) {
|
|
7378
|
+
while (afterContent.firstChild) {
|
|
7379
|
+
newParagraph.appendChild(afterContent.firstChild);
|
|
7380
|
+
}
|
|
7381
|
+
} else {
|
|
7382
|
+
newParagraph.innerHTML = "<br>";
|
|
7383
|
+
}
|
|
7384
|
+
currentParagraph.parentNode.insertBefore(newParagraph, currentParagraph.nextSibling);
|
|
7385
|
+
const newRange = document.createRange();
|
|
7386
|
+
if (newParagraph.firstChild && newParagraph.firstChild.nodeType === Node.TEXT_NODE) {
|
|
7387
|
+
newRange.setStart(newParagraph.firstChild, 0);
|
|
7388
|
+
} else if (newParagraph.firstChild && newParagraph.firstChild.nodeType === Node.ELEMENT_NODE) {
|
|
7389
|
+
newRange.setStart(newParagraph, 0);
|
|
7390
|
+
} else {
|
|
7391
|
+
newRange.setStart(newParagraph, 0);
|
|
7392
|
+
}
|
|
7393
|
+
newRange.collapse(true);
|
|
7394
|
+
const selection = window.getSelection();
|
|
7395
|
+
selection.removeAllRanges();
|
|
7396
|
+
selection.addRange(newRange);
|
|
7397
|
+
me2.updateData(true);
|
|
7398
|
+
},
|
|
7399
|
+
// 更精确地提取光标后的内容(专门用于话题分割)
|
|
7400
|
+
extractContentAfterCursorPrecise(range, paragraph) {
|
|
7401
|
+
const fragment = document.createDocumentFragment();
|
|
7402
|
+
const container = range.startContainer;
|
|
7403
|
+
const offset = range.startOffset;
|
|
7404
|
+
if (container.nodeType === Node.ELEMENT_NODE) {
|
|
7405
|
+
const childNodes = Array.from(container.childNodes);
|
|
7406
|
+
for (let i = offset; i < childNodes.length; i++) {
|
|
7407
|
+
fragment.appendChild(childNodes[i]);
|
|
7408
|
+
}
|
|
7409
|
+
} else if (container.nodeType === Node.TEXT_NODE) {
|
|
7410
|
+
if (offset < container.textContent.length) {
|
|
7411
|
+
const afterText = container.textContent.slice(offset);
|
|
7412
|
+
container.textContent = container.textContent.slice(0, offset);
|
|
7413
|
+
const textNode = document.createTextNode(afterText);
|
|
7414
|
+
fragment.appendChild(textNode);
|
|
7415
|
+
}
|
|
7416
|
+
let nextSibling = container.nextSibling;
|
|
7417
|
+
while (nextSibling) {
|
|
7418
|
+
const nodeToMove = nextSibling;
|
|
7419
|
+
nextSibling = nextSibling.nextSibling;
|
|
7420
|
+
fragment.appendChild(nodeToMove);
|
|
7421
|
+
}
|
|
7422
|
+
}
|
|
7423
|
+
return fragment;
|
|
7424
|
+
},
|
|
7425
|
+
// 处理包含话题的段落中的回车键
|
|
7426
|
+
handleEnterKeyInParagraphWithTopic(range) {
|
|
7427
|
+
var _a;
|
|
7428
|
+
const me2 = this;
|
|
7429
|
+
let currentParagraph = range.startContainer;
|
|
7430
|
+
while (currentParagraph && currentParagraph.nodeType !== Node.ELEMENT_NODE) {
|
|
7431
|
+
currentParagraph = currentParagraph.parentNode;
|
|
7432
|
+
}
|
|
7433
|
+
while (currentParagraph && !((_a = currentParagraph.classList) == null ? void 0 : _a.contains("halo-paragraph"))) {
|
|
7434
|
+
currentParagraph = currentParagraph.parentNode;
|
|
7435
|
+
}
|
|
7436
|
+
if (!currentParagraph)
|
|
7437
|
+
return;
|
|
7438
|
+
const newParagraph = document.createElement("p");
|
|
7439
|
+
newParagraph.className = "halo-paragraph";
|
|
7440
|
+
const isAtTopicStart = me2.isCursorBeforeFirstTopic(range, currentParagraph);
|
|
7441
|
+
const isAtEnd = me2.isCursorAtEndOfParagraph(range, currentParagraph);
|
|
7442
|
+
if (isAtTopicStart) {
|
|
7443
|
+
const afterContent = me2.extractContentAfterCursor(range, currentParagraph);
|
|
7444
|
+
if (afterContent && afterContent.childNodes.length > 0) {
|
|
7445
|
+
while (afterContent.firstChild) {
|
|
7446
|
+
newParagraph.appendChild(afterContent.firstChild);
|
|
7447
|
+
}
|
|
7448
|
+
} else {
|
|
7449
|
+
newParagraph.innerHTML = "<br>";
|
|
7450
|
+
}
|
|
7451
|
+
if (currentParagraph.innerHTML.trim() === "" || currentParagraph.childNodes.length === 0) {
|
|
7452
|
+
currentParagraph.innerHTML = "<br>";
|
|
7453
|
+
}
|
|
7454
|
+
currentParagraph.parentNode.insertBefore(newParagraph, currentParagraph.nextSibling);
|
|
7455
|
+
} else if (isAtEnd) {
|
|
7456
|
+
newParagraph.innerHTML = "<br>";
|
|
7457
|
+
currentParagraph.parentNode.insertBefore(newParagraph, currentParagraph.nextSibling);
|
|
7458
|
+
} else {
|
|
7459
|
+
const afterContent = me2.extractContentAfterCursor(range, currentParagraph);
|
|
7460
|
+
if (afterContent && afterContent.childNodes.length > 0) {
|
|
7461
|
+
let hasValidContent = false;
|
|
7462
|
+
for (let i = 0; i < afterContent.childNodes.length; i++) {
|
|
7463
|
+
const node = afterContent.childNodes[i];
|
|
7464
|
+
if (node.nodeType === Node.TEXT_NODE) {
|
|
7465
|
+
if (node.textContent.trim() !== "") {
|
|
7466
|
+
hasValidContent = true;
|
|
7467
|
+
break;
|
|
7468
|
+
}
|
|
7469
|
+
} else {
|
|
7470
|
+
hasValidContent = true;
|
|
7471
|
+
break;
|
|
7472
|
+
}
|
|
7473
|
+
}
|
|
7474
|
+
if (hasValidContent) {
|
|
7475
|
+
while (afterContent.firstChild) {
|
|
7476
|
+
newParagraph.appendChild(afterContent.firstChild);
|
|
7477
|
+
}
|
|
7478
|
+
} else {
|
|
7479
|
+
newParagraph.innerHTML = "<br>";
|
|
7480
|
+
}
|
|
7481
|
+
} else {
|
|
7482
|
+
newParagraph.innerHTML = "<br>";
|
|
7483
|
+
}
|
|
7484
|
+
currentParagraph.parentNode.insertBefore(newParagraph, currentParagraph.nextSibling);
|
|
7485
|
+
}
|
|
7486
|
+
const newRange = document.createRange();
|
|
7487
|
+
if (newParagraph.firstChild && newParagraph.firstChild.nodeType === Node.TEXT_NODE) {
|
|
7488
|
+
newRange.setStart(newParagraph.firstChild, 0);
|
|
7489
|
+
} else if (newParagraph.firstChild) {
|
|
7490
|
+
newRange.setStart(newParagraph, 0);
|
|
7491
|
+
} else {
|
|
7492
|
+
newRange.setStart(newParagraph, 0);
|
|
7493
|
+
}
|
|
7494
|
+
newRange.collapse(true);
|
|
7495
|
+
const selection = window.getSelection();
|
|
7496
|
+
selection.removeAllRanges();
|
|
7497
|
+
selection.addRange(newRange);
|
|
7498
|
+
me2.updateData(true);
|
|
7499
|
+
},
|
|
7500
|
+
// 检查光标是否在第一个话题前面
|
|
7501
|
+
isCursorBeforeFirstTopic(range, paragraph) {
|
|
7502
|
+
const container = range.startContainer;
|
|
7503
|
+
const offset = range.startOffset;
|
|
7504
|
+
const firstTopic = paragraph.querySelector("mdd-topic");
|
|
7505
|
+
if (!firstTopic) {
|
|
7506
|
+
return false;
|
|
7507
|
+
}
|
|
7508
|
+
if (container === paragraph && offset === 0) {
|
|
7509
|
+
return true;
|
|
7510
|
+
}
|
|
7511
|
+
if (container === paragraph && offset > 0 && offset <= paragraph.childNodes.length) {
|
|
7512
|
+
if (offset < paragraph.childNodes.length) {
|
|
7513
|
+
const nodeAtOffset = paragraph.childNodes[offset];
|
|
7514
|
+
if (nodeAtOffset === firstTopic) {
|
|
7515
|
+
return true;
|
|
7516
|
+
}
|
|
7517
|
+
}
|
|
7518
|
+
let nextNonEmptyNode = null;
|
|
7519
|
+
for (let i = offset; i < paragraph.childNodes.length; i++) {
|
|
7520
|
+
const node = paragraph.childNodes[i];
|
|
7521
|
+
if (node.nodeType === Node.ELEMENT_NODE && node.tagName === "MDD-TOPIC") {
|
|
7522
|
+
nextNonEmptyNode = node;
|
|
7523
|
+
break;
|
|
7524
|
+
} else if (node.nodeType === Node.TEXT_NODE && node.textContent.trim() !== "") {
|
|
7525
|
+
break;
|
|
7526
|
+
}
|
|
7527
|
+
}
|
|
7528
|
+
if (nextNonEmptyNode === firstTopic) {
|
|
7529
|
+
return true;
|
|
7530
|
+
}
|
|
7531
|
+
}
|
|
7532
|
+
try {
|
|
7533
|
+
const topicRange = document.createRange();
|
|
7534
|
+
topicRange.setStartBefore(firstTopic);
|
|
7535
|
+
const comparison = topicRange.comparePoint(container, offset);
|
|
7536
|
+
if (comparison < 0) {
|
|
7537
|
+
return true;
|
|
7538
|
+
}
|
|
7539
|
+
} catch (e) {
|
|
7540
|
+
if (container.nodeType === Node.TEXT_NODE) {
|
|
7541
|
+
const tempRange = document.createRange();
|
|
7542
|
+
tempRange.setStart(container, offset);
|
|
7543
|
+
tempRange.collapse(true);
|
|
7544
|
+
const topicRange = document.createRange();
|
|
7545
|
+
topicRange.setStartBefore(firstTopic);
|
|
7546
|
+
if (tempRange.compareBoundaryPoints(Range.START_TO_START, topicRange) < 0) {
|
|
7547
|
+
return true;
|
|
7548
|
+
}
|
|
7549
|
+
}
|
|
7550
|
+
if (container === paragraph) {
|
|
7551
|
+
const testRange = document.createRange();
|
|
7552
|
+
testRange.setStart(paragraph, 0);
|
|
7553
|
+
testRange.setEnd(paragraph, offset);
|
|
7554
|
+
const containsTopic = testRange.intersectsNode(firstTopic);
|
|
7555
|
+
if (!containsTopic) {
|
|
7556
|
+
return true;
|
|
7557
|
+
}
|
|
7558
|
+
}
|
|
7559
|
+
}
|
|
7560
|
+
return false;
|
|
7561
|
+
},
|
|
7562
|
+
// 获取不包含mdd-topic内部文本的段落文本
|
|
7563
|
+
getParagraphTextExcludingTopics(paragraph, range) {
|
|
7564
|
+
let textContent = "";
|
|
7565
|
+
let cursorPosition = 0;
|
|
7566
|
+
let foundCursor = false;
|
|
7567
|
+
const walker = document.createTreeWalker(
|
|
7568
|
+
paragraph,
|
|
7569
|
+
NodeFilter.SHOW_ALL,
|
|
7570
|
+
{
|
|
7571
|
+
acceptNode: function(node2) {
|
|
7572
|
+
if (node2.nodeType === Node.ELEMENT_NODE && node2.tagName === "MDD-TOPIC") {
|
|
7573
|
+
return NodeFilter.FILTER_REJECT;
|
|
7574
|
+
}
|
|
7575
|
+
return NodeFilter.FILTER_ACCEPT;
|
|
7576
|
+
}
|
|
7577
|
+
},
|
|
7578
|
+
false
|
|
7579
|
+
);
|
|
7580
|
+
let node;
|
|
7581
|
+
while (node = walker.nextNode()) {
|
|
7582
|
+
if (node.nodeType === Node.TEXT_NODE) {
|
|
7583
|
+
const nodeText = node.textContent;
|
|
7584
|
+
if (!foundCursor && node === range.startContainer) {
|
|
7585
|
+
cursorPosition = textContent.length + range.startOffset;
|
|
7586
|
+
foundCursor = true;
|
|
7587
|
+
}
|
|
7588
|
+
textContent += nodeText;
|
|
7589
|
+
}
|
|
7590
|
+
}
|
|
7591
|
+
return { textContent, cursorPosition };
|
|
7592
|
+
},
|
|
7593
|
+
// 检查光标是否在段落开头
|
|
7594
|
+
isCursorAtStartOfParagraph(range, paragraph) {
|
|
7595
|
+
const { cursorPosition } = this.getParagraphTextExcludingTopics(paragraph, range);
|
|
7596
|
+
return cursorPosition === 0;
|
|
7597
|
+
},
|
|
7598
|
+
// 检查光标是否在段落末尾
|
|
7599
|
+
isCursorAtEndOfParagraph(range, paragraph) {
|
|
7600
|
+
const walker = document.createTreeWalker(
|
|
7601
|
+
paragraph,
|
|
7602
|
+
NodeFilter.SHOW_TEXT,
|
|
7603
|
+
{
|
|
7604
|
+
acceptNode: function(node2) {
|
|
7605
|
+
let parent = node2.parentNode;
|
|
7606
|
+
while (parent && parent !== paragraph) {
|
|
7607
|
+
if (parent.tagName === "MDD-TOPIC") {
|
|
7608
|
+
return NodeFilter.FILTER_REJECT;
|
|
7609
|
+
}
|
|
7610
|
+
parent = parent.parentNode;
|
|
7611
|
+
}
|
|
7612
|
+
return NodeFilter.FILTER_ACCEPT;
|
|
7613
|
+
}
|
|
7614
|
+
},
|
|
7615
|
+
false
|
|
7616
|
+
);
|
|
7617
|
+
let totalLength = 0;
|
|
7618
|
+
let node;
|
|
7619
|
+
while (node = walker.nextNode()) {
|
|
7620
|
+
totalLength += node.textContent.length;
|
|
7621
|
+
}
|
|
7622
|
+
const { cursorPosition } = this.getParagraphTextExcludingTopics(paragraph, range);
|
|
7623
|
+
return cursorPosition >= totalLength;
|
|
7624
|
+
},
|
|
7625
|
+
// 获取当前段落
|
|
7626
|
+
getCurrentParagraph(range) {
|
|
7627
|
+
let container = range.startContainer;
|
|
7628
|
+
while (container && container !== this.editorDom) {
|
|
7629
|
+
if (container.nodeType === Node.ELEMENT_NODE && container.classList && container.classList.contains("halo-paragraph")) {
|
|
7630
|
+
return container;
|
|
7631
|
+
}
|
|
7632
|
+
container = container.parentNode;
|
|
7633
|
+
}
|
|
7634
|
+
return null;
|
|
7635
|
+
},
|
|
7636
|
+
// 提取光标后的内容
|
|
7637
|
+
extractContentAfterCursor(range, paragraph) {
|
|
7638
|
+
const fragment = document.createDocumentFragment();
|
|
7639
|
+
const container = range.startContainer;
|
|
7640
|
+
const offset = range.startOffset;
|
|
7641
|
+
let topicSpaceNode = null;
|
|
7642
|
+
if (container.nodeType === Node.TEXT_NODE && container.textContent === " " && container.previousSibling && container.previousSibling.tagName === "MDD-TOPIC") {
|
|
7643
|
+
topicSpaceNode = container;
|
|
7644
|
+
}
|
|
7645
|
+
const extractRange = document.createRange();
|
|
7646
|
+
let startNode = null;
|
|
7647
|
+
let hasContentToExtract = false;
|
|
7648
|
+
if (topicSpaceNode) {
|
|
7649
|
+
if (topicSpaceNode.nextSibling) {
|
|
7650
|
+
startNode = topicSpaceNode.nextSibling;
|
|
7651
|
+
hasContentToExtract = true;
|
|
7652
|
+
}
|
|
7653
|
+
} else if (container.nodeType === Node.TEXT_NODE) {
|
|
7654
|
+
if (container.textContent === "" && offset === 0) {
|
|
7655
|
+
if (container.nextSibling) {
|
|
7656
|
+
startNode = container.nextSibling;
|
|
7657
|
+
hasContentToExtract = true;
|
|
7658
|
+
}
|
|
7659
|
+
} else if (offset < container.textContent.length) {
|
|
7660
|
+
const afterText = container.textContent.slice(offset);
|
|
7661
|
+
container.textContent = container.textContent.slice(0, offset);
|
|
7662
|
+
if (afterText.trim()) {
|
|
7663
|
+
const newTextNode = document.createTextNode(afterText);
|
|
7664
|
+
container.parentNode.insertBefore(newTextNode, container.nextSibling);
|
|
7665
|
+
startNode = newTextNode;
|
|
7666
|
+
hasContentToExtract = true;
|
|
7667
|
+
} else if (container.nextSibling) {
|
|
7668
|
+
startNode = container.nextSibling;
|
|
7669
|
+
hasContentToExtract = true;
|
|
7670
|
+
}
|
|
7671
|
+
} else {
|
|
7672
|
+
if (container.nextSibling) {
|
|
7673
|
+
startNode = container.nextSibling;
|
|
7674
|
+
hasContentToExtract = true;
|
|
7675
|
+
}
|
|
7676
|
+
}
|
|
7677
|
+
} else if (container.nodeType === Node.ELEMENT_NODE) {
|
|
7678
|
+
if (offset < container.childNodes.length) {
|
|
7679
|
+
startNode = container.childNodes[offset];
|
|
7680
|
+
hasContentToExtract = true;
|
|
7681
|
+
} else if (offset === 0 && container === paragraph) {
|
|
7682
|
+
if (paragraph.firstChild) {
|
|
7683
|
+
startNode = paragraph.firstChild;
|
|
7684
|
+
hasContentToExtract = true;
|
|
7685
|
+
}
|
|
7686
|
+
}
|
|
7687
|
+
}
|
|
7688
|
+
if (!hasContentToExtract || !startNode) {
|
|
7689
|
+
return fragment;
|
|
7690
|
+
}
|
|
7691
|
+
if (!paragraph.contains(startNode)) {
|
|
7692
|
+
return fragment;
|
|
7693
|
+
}
|
|
7694
|
+
try {
|
|
7695
|
+
extractRange.setStartBefore(startNode);
|
|
7696
|
+
let lastNode = paragraph.lastChild;
|
|
7697
|
+
while (lastNode && lastNode.nodeType === Node.TEXT_NODE && lastNode.textContent === "" && // 只跳过完全空的文本节点
|
|
7698
|
+
lastNode !== startNode) {
|
|
7699
|
+
lastNode = lastNode.previousSibling;
|
|
7700
|
+
}
|
|
7701
|
+
if (lastNode) {
|
|
7702
|
+
extractRange.setEndAfter(lastNode);
|
|
7703
|
+
} else {
|
|
7704
|
+
extractRange.setEnd(paragraph, paragraph.childNodes.length);
|
|
7705
|
+
}
|
|
7706
|
+
const extractedContent = extractRange.extractContents();
|
|
7707
|
+
fragment.appendChild(extractedContent);
|
|
7708
|
+
} catch (e) {
|
|
7709
|
+
let currentNode = startNode;
|
|
7710
|
+
while (currentNode && currentNode.parentNode === paragraph) {
|
|
7711
|
+
const nextNode = currentNode.nextSibling;
|
|
7712
|
+
fragment.appendChild(currentNode);
|
|
7713
|
+
currentNode = nextNode;
|
|
7714
|
+
}
|
|
7715
|
+
}
|
|
7716
|
+
return fragment;
|
|
7717
|
+
},
|
|
7718
|
+
// 统一的光标设置方法 - 设置光标到元素后面
|
|
7719
|
+
setCursorAfterElement(element) {
|
|
7720
|
+
const newRange = document.createRange();
|
|
7721
|
+
newRange.setStartAfter(element);
|
|
7722
|
+
newRange.collapse(true);
|
|
7723
|
+
const selection = window.getSelection();
|
|
7724
|
+
selection.removeAllRanges();
|
|
7725
|
+
selection.addRange(newRange);
|
|
7726
|
+
},
|
|
7727
|
+
// 统一的光标设置方法 - 设置光标到元素前面
|
|
7728
|
+
setCursorBeforeElement(element) {
|
|
7729
|
+
const newRange = document.createRange();
|
|
7730
|
+
newRange.setStartBefore(element);
|
|
7731
|
+
newRange.collapse(true);
|
|
7732
|
+
const selection = window.getSelection();
|
|
7733
|
+
selection.removeAllRanges();
|
|
7734
|
+
selection.addRange(newRange);
|
|
6369
7735
|
}
|
|
6370
7736
|
},
|
|
6371
7737
|
beforeRouteLeave(to, from, next) {
|
|
@@ -6388,11 +7754,12 @@
|
|
|
6388
7754
|
const _component_ImgUpload = vue.resolveComponent("ImgUpload");
|
|
6389
7755
|
const _component_VideoUpload = vue.resolveComponent("VideoUpload");
|
|
6390
7756
|
const _component_CollectArticle = vue.resolveComponent("CollectArticle");
|
|
7757
|
+
const _component_TopicManager = vue.resolveComponent("TopicManager");
|
|
6391
7758
|
return vue.openBlock(), vue.createElementBlock("div", _hoisted_1, [
|
|
6392
7759
|
vue.withDirectives(vue.createElementVNode("div", {
|
|
6393
7760
|
style: vue.normalizeStyle({ textAlign: $options.align }),
|
|
6394
7761
|
class: "placeholder"
|
|
6395
|
-
},
|
|
7762
|
+
}, vue.toDisplayString($props.placeholder || "请输入正文"), 5), [
|
|
6396
7763
|
[vue.vShow, !$options.isInputing && !$data.titleCount && !$data.hasArticleCard]
|
|
6397
7764
|
]),
|
|
6398
7765
|
$data.overLine ? (vue.openBlock(), vue.createElementBlock("div", {
|
|
@@ -6417,26 +7784,26 @@
|
|
|
6417
7784
|
vue.createVNode(_component_el_form, { model: $data.linkForm }, {
|
|
6418
7785
|
default: vue.withCtx(() => [
|
|
6419
7786
|
vue.createVNode(_component_el_form_item, {
|
|
6420
|
-
label: "
|
|
7787
|
+
label: "添加链接",
|
|
6421
7788
|
class: "link-title"
|
|
6422
7789
|
}, {
|
|
6423
7790
|
default: vue.withCtx(() => [
|
|
6424
7791
|
vue.createVNode(_component_el_input, {
|
|
6425
7792
|
modelValue: $data.linkForm.linkAddress,
|
|
6426
7793
|
"onUpdate:modelValue": _cache[1] || (_cache[1] = ($event) => $data.linkForm.linkAddress = $event),
|
|
6427
|
-
placeholder: "
|
|
7794
|
+
placeholder: "请输入链接地址"
|
|
6428
7795
|
}, null, 8, ["modelValue"])
|
|
6429
7796
|
]),
|
|
6430
7797
|
_: 1
|
|
6431
7798
|
}),
|
|
6432
|
-
vue.createVNode(_component_el_form_item, { label: "
|
|
7799
|
+
vue.createVNode(_component_el_form_item, { label: "链接文案" }, {
|
|
6433
7800
|
default: vue.withCtx(() => [
|
|
6434
7801
|
vue.createVNode(_component_el_input, {
|
|
6435
7802
|
modelValue: $data.linkForm.linkWriting,
|
|
6436
7803
|
"onUpdate:modelValue": _cache[2] || (_cache[2] = ($event) => $data.linkForm.linkWriting = $event),
|
|
6437
7804
|
type: "textarea",
|
|
6438
7805
|
autosize: "",
|
|
6439
|
-
placeholder: "
|
|
7806
|
+
placeholder: "请输入链接文案"
|
|
6440
7807
|
}, null, 8, ["modelValue"])
|
|
6441
7808
|
]),
|
|
6442
7809
|
_: 1
|
|
@@ -6449,18 +7816,18 @@
|
|
|
6449
7816
|
vue.createVNode(_component_el_button, {
|
|
6450
7817
|
onClick: _cache[3] || (_cache[3] = ($event) => $data.viewLinkDialog = false)
|
|
6451
7818
|
}, {
|
|
6452
|
-
default: vue.withCtx(() => [
|
|
6453
|
-
vue.createTextVNode("
|
|
6454
|
-
]),
|
|
7819
|
+
default: vue.withCtx(() => _cache[14] || (_cache[14] = [
|
|
7820
|
+
vue.createTextVNode("取 消")
|
|
7821
|
+
])),
|
|
6455
7822
|
_: 1
|
|
6456
7823
|
}),
|
|
6457
7824
|
vue.createVNode(_component_el_button, {
|
|
6458
7825
|
type: "primary",
|
|
6459
7826
|
onClick: $options.insertLink
|
|
6460
7827
|
}, {
|
|
6461
|
-
default: vue.withCtx(() => [
|
|
6462
|
-
vue.createTextVNode("
|
|
6463
|
-
]),
|
|
7828
|
+
default: vue.withCtx(() => _cache[15] || (_cache[15] = [
|
|
7829
|
+
vue.createTextVNode("确 定")
|
|
7830
|
+
])),
|
|
6464
7831
|
_: 1
|
|
6465
7832
|
}, 8, ["onClick"])
|
|
6466
7833
|
])
|
|
@@ -6518,7 +7885,14 @@
|
|
|
6518
7885
|
class: "replace-poster hide",
|
|
6519
7886
|
accept: "image/*",
|
|
6520
7887
|
onChange: _cache[13] || (_cache[13] = (...args) => $options.replacePoster && $options.replacePoster(...args))
|
|
6521
|
-
}, null, 32)
|
|
7888
|
+
}, null, 32),
|
|
7889
|
+
vue.createVNode(_component_TopicManager, {
|
|
7890
|
+
ref: "topicManager",
|
|
7891
|
+
"editor-dom": $data.editorDom,
|
|
7892
|
+
request: $props.request,
|
|
7893
|
+
onTopicInserted: $options.onTopicInserted,
|
|
7894
|
+
onUpdateTopicPosition: $options.updateTopicPosition
|
|
7895
|
+
}, null, 8, ["editor-dom", "request", "onTopicInserted", "onUpdateTopicPosition"])
|
|
6522
7896
|
]);
|
|
6523
7897
|
}
|
|
6524
7898
|
const Editor = /* @__PURE__ */ _export_sfc(_sfc_main, [["render", _sfc_render]]);
|
|
@@ -6538,7 +7912,7 @@
|
|
|
6538
7912
|
var COLOUR_CLASS = "colour";
|
|
6539
7913
|
var FONT_FAMILY_CLASS = "font";
|
|
6540
7914
|
var FONT_SIZE_CLASS = "size";
|
|
6541
|
-
var ZWS = "
|
|
7915
|
+
var ZWS = "";
|
|
6542
7916
|
var win = doc.defaultView;
|
|
6543
7917
|
var ua = navigator.userAgent;
|
|
6544
7918
|
var isAndroid = /Android/.test(ua);
|
|
@@ -6568,11 +7942,17 @@
|
|
|
6568
7942
|
};
|
|
6569
7943
|
}
|
|
6570
7944
|
var typeToBitArray = {
|
|
7945
|
+
// ELEMENT_NODE
|
|
6571
7946
|
1: 1,
|
|
7947
|
+
// ATTRIBUTE_NODE
|
|
6572
7948
|
2: 2,
|
|
7949
|
+
// TEXT_NODE
|
|
6573
7950
|
3: 4,
|
|
7951
|
+
// COMMENT_NODE
|
|
6574
7952
|
8: 128,
|
|
7953
|
+
// DOCUMENT_NODE
|
|
6575
7954
|
9: 256,
|
|
7955
|
+
// DOCUMENT_FRAGMENT_NODE
|
|
6576
7956
|
11: 1024
|
|
6577
7957
|
};
|
|
6578
7958
|
function TreeWalker(root, nodeType, filter) {
|
|
@@ -6906,7 +8286,7 @@
|
|
|
6906
8286
|
node.appendChild(fixer);
|
|
6907
8287
|
} catch (error) {
|
|
6908
8288
|
self2.didError({
|
|
6909
|
-
name: "Squire: fixCursor
|
|
8289
|
+
name: "Squire: fixCursor – " + error,
|
|
6910
8290
|
message: "Parent: " + node.nodeName + "/" + node.innerHTML + " appendChild: " + fixer.nodeName
|
|
6911
8291
|
});
|
|
6912
8292
|
}
|
|
@@ -6923,17 +8303,6 @@
|
|
|
6923
8303
|
child = children[i];
|
|
6924
8304
|
isBR = child.nodeName === "BR";
|
|
6925
8305
|
if (!isBR && isInline(child)) {
|
|
6926
|
-
if (child.classList && child.classList.contains("halo-picture-area")) {
|
|
6927
|
-
return;
|
|
6928
|
-
}
|
|
6929
|
-
if (!wrapper) {
|
|
6930
|
-
wrapper = createElement(
|
|
6931
|
-
doc2,
|
|
6932
|
-
config.blockTag,
|
|
6933
|
-
config.blockAttributes
|
|
6934
|
-
);
|
|
6935
|
-
}
|
|
6936
|
-
wrapper.appendChild(child);
|
|
6937
8306
|
i -= 1;
|
|
6938
8307
|
l -= 1;
|
|
6939
8308
|
} else if (isBR || wrapper) {
|
|
@@ -7252,7 +8621,8 @@
|
|
|
7252
8621
|
block = getStartBlockOfRange(range, root);
|
|
7253
8622
|
firstBlockInFrag = getNextBlock(frag, frag);
|
|
7254
8623
|
replaceBlock = !!block && isEmptyBlock(block);
|
|
7255
|
-
if (block && firstBlockInFrag && !replaceBlock &&
|
|
8624
|
+
if (block && firstBlockInFrag && !replaceBlock && // Don't merge table cells or PRE elements into block
|
|
8625
|
+
!getNearest(firstBlockInFrag, frag, "PRE") && !getNearest(firstBlockInFrag, frag, "TABLE")) {
|
|
7256
8626
|
moveRangeBoundariesUpTree(range, block, block, root);
|
|
7257
8627
|
range.collapse(true);
|
|
7258
8628
|
container = range.endContainer;
|
|
@@ -7268,7 +8638,10 @@
|
|
|
7268
8638
|
container = nodeAfterSplit.parentNode;
|
|
7269
8639
|
offset = indexOf.call(container.childNodes, nodeAfterSplit);
|
|
7270
8640
|
}
|
|
7271
|
-
if (
|
|
8641
|
+
if (
|
|
8642
|
+
/* isBlock( container ) && */
|
|
8643
|
+
offset !== getLength(container)
|
|
8644
|
+
) {
|
|
7272
8645
|
blockContentsAfterSplit = root.ownerDocument.createDocumentFragment();
|
|
7273
8646
|
while (node = container.childNodes[offset]) {
|
|
7274
8647
|
blockContentsAfterSplit.appendChild(node);
|
|
@@ -8317,9 +9690,11 @@
|
|
|
8317
9690
|
if (hasImage) {
|
|
8318
9691
|
this.fireEvent("dragover", {
|
|
8319
9692
|
dataTransfer: clipboardData,
|
|
9693
|
+
/* jshint loopfunc: true */
|
|
8320
9694
|
preventDefault: function() {
|
|
8321
9695
|
fireDrop = true;
|
|
8322
9696
|
}
|
|
9697
|
+
/* jshint loopfunc: false */
|
|
8323
9698
|
});
|
|
8324
9699
|
if (fireDrop) {
|
|
8325
9700
|
this.fireEvent("drop", {
|
|
@@ -8526,7 +9901,9 @@
|
|
|
8526
9901
|
leafNodeNames,
|
|
8527
9902
|
undo: {
|
|
8528
9903
|
documentSizeThreshold: -1,
|
|
9904
|
+
// -1 means no threshold
|
|
8529
9905
|
undoLimit: -1
|
|
9906
|
+
// -1 means no limit
|
|
8530
9907
|
},
|
|
8531
9908
|
isInsertedHTMLSanitized: true,
|
|
8532
9909
|
isSetHTMLSanitized: true,
|
|
@@ -10168,5 +11545,5 @@
|
|
|
10168
11545
|
exports2.Editor = Editor;
|
|
10169
11546
|
exports2.ToolBar = ToolBar;
|
|
10170
11547
|
exports2.ToolsEnum = ToolsEnum;
|
|
10171
|
-
Object.
|
|
11548
|
+
Object.defineProperty(exports2, Symbol.toStringTag, { value: "Module" });
|
|
10172
11549
|
});
|