@codernote/record-tree 0.0.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +1 -0
- package/dist/record-tree.js +316 -0
- package/package.json +32 -0
package/README.md
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
# 记录软件 - 记录树
|
|
@@ -0,0 +1,316 @@
|
|
|
1
|
+
(function(){"use strict";try{if(typeof document<"u"){var M=document.createElement("style");M.appendChild(document.createTextNode(".popper{width:auto;background-color:#fafafa;color:#212121;text-align:center;padding:2px;display:inline-block;border-radius:3px;position:absolute;font-size:14px;font-weight:400;border:1px #ebebeb solid;z-index:200000;box-shadow:#3a3a3a 0 0 6px}.popper .popper__arrow{width:0;height:0;border-style:solid;position:absolute;margin:5px}.popper[x-placement^=top]{margin-bottom:5px}.popper[x-placement^=top] .popper__arrow{border-width:5px 5px 0 5px;border-color:#fafafa transparent transparent transparent;bottom:-5px;left:calc(50% - 5px);margin-top:0;margin-bottom:0}.popper[x-placement^=bottom]{margin-top:5px}.popper[x-placement^=bottom] .popper__arrow{border-width:0 5px 5px 5px;border-color:transparent transparent #fafafa transparent;top:-5px;left:calc(50% - 5px);margin-top:0;margin-bottom:0}.popper[x-placement^=right]{margin-left:5px}.popper[x-placement^=right] .popper__arrow{border-width:5px 5px 5px 0;border-color:transparent #fafafa transparent transparent;left:-5px;top:calc(50% - 5px);margin-left:0;margin-right:0}.popper[x-placement^=left]{margin-right:5px}.popper[x-placement^=left] .popper__arrow{border-width:5px 0 5px 5px;border-color:transparent transparent transparent #fafafa;right:-5px;top:calc(50% - 5px);margin-left:0;margin-right:0}.popper-content{display:flex;flex-wrap:wrap;padding:10px;box-shadow:0 2px 12px #1d1c1c1f;border:1px solid rgba(29,28,28,.12);border-radius:5px;overflow:hidden;background:#fff;z-index:9999}.popper-content-item{padding:8px 10px;display:flex;align-items:center;justify-content:center;cursor:pointer}.inline-svg{display:inline-block;border-radius:9999px;color:#fff;cursor:pointer}body.is-full-screen .tree-editor{margin-top:0!important}.tree-title-div{position:relative;display:flex;margin-bottom:3px}.tree-title{padding-left:25px;font-weight:700;outline:none;font-size:1.125rem;line-height:1.5;width:100%}.popper-reference{display:flex;position:absolute;top:0px;left:0px;text-align:center;border-radius:9999px;color:#fff}.tree-div{padding-left:25px}.mobile-options{position:fixed;bottom:0px;left:0px;width:100%;display:flex;justify-content:space-between;padding:5px 0;background:rgb(236,236,236)}.option-left{display:flex;padding-left:10px}.option-right{padding-right:10px}.option-item{margin:0 5px;cursor:pointer;-webkit-touch-callout:none;-webkit-user-select:none;-moz-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent}.lzx-waiting-move{box-shadow:0 2px 4px #0000001f,0 0 6px #0000000a}.empty-icon{display:inline-block;border-radius:9999px}.icon{display:inline-block;width:18px;height:18px;margin:0;padding:0!important;line-height:100%;font-size:0;background-position:center;background-repeat:no-repeat;background-size:14px;cursor:pointer}.tree-upload-loading{position:absolute;left:0;top:0;bottom:0;right:0}.tree-upload-loading p{display:flex;justify-content:center;align-items:center;position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:200px}.tree-upload-loading{font-size:12px;font-weight:400;color:#666}.icon.icon-loading{background-image:url(data:image/svg+xml;base64,<?xml version="1.0" standalone="no"?><!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd"><svg t="1706864707974" class="icon" viewBox="0 0 1024 1024" version="1.1" xmlns="http://www.w3.org/2000/svg" p-id="4416" xmlns:xlink="http://www.w3.org/1999/xlink" width="200" height="200"><path d="M742.29455 334.277347l-52.575897-52.575897c-10.06998-10.06998-10.06998-26.401948 0-36.471929l100.717803-100.717803c10.06998-10.06998 26.401948-10.06998 36.471929 0l52.575897 52.575897c10.06998 10.06998 10.06998 26.401948 0 36.471929l-100.717803 100.717803c-10.07398 10.07398-26.401948 10.07398-36.471929 0z" fill="#CEE8FA" p-id="4417"></path><path d="M760.528515 371.305275c-14.759971 0-28.635944-5.747989-39.075924-16.183969l-52.575897-52.575897c-10.43598-10.43598-16.185968-24.315953-16.185969-39.075924 0-14.761971 5.749989-28.641944 16.189969-39.081923l100.713803-100.713804c10.43998-10.43598 24.315953-16.183968 39.077924-16.183968 14.759971 0 28.635944 5.747989 39.075923 16.179968l52.575898 52.579898c10.43598 10.43398 16.185968 24.311953 16.185968 39.075923 0 14.759971-5.749989 28.637944-16.189968 39.077924l-100.713804 100.713803c-10.43598 10.43998-24.313953 16.187968-39.077923 16.187969z m-47.365908-107.83779l47.365908 47.367908 95.505813-95.509814-47.361907-47.367907-95.509814 95.509813z" fill="#2D527C" p-id="4418"></path><path d="M197.087615 879.484282l-52.575897-52.575897c-10.06998-10.06998-10.06998-26.401948 0-36.471929l100.717803-100.717803c10.06998-10.06998 26.401948-10.06998 36.471929 0l52.575897 52.575897c10.06998 10.06998 10.06998 26.401948 0 36.471929l-100.717803 100.717803c-10.06998 10.06998-26.397948 10.06998-36.471929 0z" fill="#CEE8FA" p-id="4419"></path><path d="M215.325579 916.51021c-14.759971 0-28.635944-5.747989-39.075923-16.183968l-52.575898-52.579898c-10.43598-10.43398-16.185968-24.311953-16.185968-39.075923 0-14.759971 5.749989-28.637944 16.189968-39.077924l100.713804-100.713803c10.43598-10.43598 24.315953-16.185968 39.077923-16.185969 14.759971 0 28.635944 5.747989 39.075924 16.183969l52.575897 52.575897c10.43598 10.43598 16.185968 24.315953 16.185969 39.077924 0 14.759971-5.749989 28.637944-16.189969 39.077923l-100.713803 100.713804c-10.44198 10.43798-24.317953 16.187968-39.077924 16.187968z m-47.365907-107.839789l47.361907 47.367907 95.509814-95.509813-47.365908-47.367908-95.505813 95.509814z" fill="#2D527C" p-id="4420"></path><path d="M689.716653 742.29455l52.575897-52.575897c10.06998-10.06998 26.401948-10.06998 36.471929 0l100.717803 100.717803c10.06998 10.06998 10.06998 26.401948 0 36.471929l-52.575897 52.575897c-10.06998 10.06998-26.401948 10.06998-36.471929 0l-100.717803-100.717803c-10.06998-10.07398-10.06998-26.401948 0-36.471929z" fill="#CEE8FA" p-id="4421"></path><path d="M808.672421 916.51021c-14.763971 0-28.637944-5.749989-39.077924-16.185968l-100.717803-100.717804c-10.43598-10.43998-16.185968-24.315953-16.185969-39.077923s5.749989-28.641944 16.189969-39.081924l52.569897-52.569897c10.44198-10.43998 24.317953-16.185968 39.077924-16.185969 14.763971 0 28.641944 5.749989 39.077923 16.185969l100.717804 100.713803c10.43598 10.43998 16.185968 24.315953 16.185968 39.077924s-5.749989 28.641944-16.189968 39.081923l-52.569898 52.569898c-10.44198 10.44398-24.317953 16.189968-39.077923 16.189968z m-95.509814-155.981695l95.509814 95.509813 47.361907-47.367907-95.505813-95.509814-47.365908 47.367908z" fill="#2D527C" p-id="4422"></path><path d="M144.513718 197.087615l52.575897-52.575897c10.06998-10.06998 26.401948-10.06998 36.471929 0l100.717803 100.717803c10.06998 10.06998 10.06998 26.401948 0 36.471929l-52.575897 52.575897c-10.06998 10.06998-26.401948 10.06998-36.471929 0l-100.717803-100.713803c-10.06998-10.07398-10.06998-26.401948 0-36.475929z" fill="#CEE8FA" p-id="4423"></path><path d="M263.469485 371.305275c-14.761971 0-28.641944-5.749989-39.077923-16.185969l-100.717804-100.713803c-10.43598-10.43998-16.185968-24.315953-16.185968-39.077924 0-14.761971 5.749989-28.641944 16.189968-39.081923l52.569898-52.569898c10.44198-10.43998 24.317953-16.185968 39.077923-16.185968 14.761971 0 28.637944 5.747989 39.077924 16.183968l100.717803 100.717804c10.43598 10.43998 16.185968 24.315953 16.185969 39.077923 0 14.759971-5.749989 28.637944-16.189969 39.077924l-52.569897 52.569897c-10.44598 10.43998-24.321952 16.187968-39.077924 16.187969z m-95.509813-155.979696l95.505813 95.509814 47.365908-47.365908-95.505814-95.511813-47.365907 47.367907zM894.768252 604.436819h-68.467866c-30.47194 0-55.263892-24.791952-55.263892-55.261892v-74.353854c0-30.47194 24.791952-55.261892 55.263892-55.261892h142.433722c30.47194 0 55.263892 24.791952 55.263892 55.261892v74.353854c0 16.277968-13.197974 29.471942-29.471942 29.471943s-29.471942-13.195974-29.471943-29.471943v-70.669862h-135.071736v66.98787h64.787873c16.273968 0 29.471942 13.195974 29.471943 29.471942 0 16.279968-13.197974 29.471942-29.473943 29.471942zM197.697614 604.436819H55.263892C24.791952 604.436819 0 579.644868 0 549.176927v-74.353854c0-16.277968 13.197974-29.471942 29.471942-29.471943s29.471942 13.195974 29.471943 29.471943v70.669862h135.071736v-66.98787H128.533749c-16.273968 0-29.471942-13.195974-29.471942-29.471942 0-16.277968 13.197974-29.471942 29.471942-29.471942h69.163865c30.47194 0 55.263892 24.791952 55.263892 55.261892v74.353854c0 30.46794-24.791952 55.259892-55.263892 55.259892zM549.176927 1023.998H474.819073c-16.273968 0-29.471942-13.193974-29.471943-29.471942s13.197974-29.471942 29.471943-29.471943h70.673862v-135.071736h-66.98787v66.177871c0 16.277968-13.197974 29.471942-29.471942 29.471942s-29.471942-13.193974-29.471942-29.471942V826.298386c0-30.47194 24.789952-55.261892 55.261892-55.261892h74.357854c30.47194 0 55.261892 24.791952 55.261892 55.261892v142.435722C604.436819 999.206048 579.648868 1023.998 549.176927 1023.998zM549.176927 252.961506H474.819073c-30.47194 0-55.261892-24.791952-55.261892-55.261892V55.259892C419.557181 24.789952 444.347132 0 474.819073 0h74.357854c16.273968 0 29.471942 13.195974 29.471943 29.471942s-13.197974 29.471942-29.471943 29.471943h-70.673862v135.071736h66.98787V129.589747c0-16.277968 13.197974-29.471942 29.471942-29.471943s29.471942 13.195974 29.471942 29.471943v68.107867c0.002 30.47194-24.785952 55.263892-55.257892 55.263892zM392.091234 541.470942h-37.235927c-16.273968 0-29.471942-13.195974-29.471943-29.471942 0-16.277968 13.197974-29.471942 29.471943-29.471942h37.235927c16.273968 0 29.471942 13.195974 29.471943 29.471942 0.002 16.277968-13.193974 29.471942-29.471943 29.471942zM530.616964 541.470942H493.379036c-16.273968 0-29.471942-13.195974-29.471942-29.471942 0-16.277968 13.197974-29.471942 29.471942-29.471942h37.237928c16.273968 0 29.471942 13.195974 29.471942 29.471942 0 16.277968-13.193974 29.471942-29.471942 29.471942zM669.138693 541.470942h-37.235927c-16.273968 0-29.471942-13.195974-29.471943-29.471942 0-16.277968 13.197974-29.471942 29.471943-29.471942h37.235927c16.273968 0 29.471942 13.195974 29.471943 29.471942 0.002 16.277968-13.193974 29.471942-29.471943 29.471942z" fill="#2D527C" p-id="4424"></path></svg>)}")),document.head.appendChild(M)}}catch(T){console.error("vite-plugin-css-injected-by-js",T)}})();
|
|
2
|
+
import _ from "@codernote/tree-editor";
|
|
3
|
+
import v from "vue-popperjs";
|
|
4
|
+
import { oss as b } from "@codernote/utils";
|
|
5
|
+
function m(e, t, i, a, r, l, u, c) {
|
|
6
|
+
var s = typeof e == "function" ? e.options : e;
|
|
7
|
+
t && (s.render = t, s.staticRenderFns = i, s._compiled = !0), a && (s.functional = !0), l && (s._scopeId = "data-v-" + l);
|
|
8
|
+
var n;
|
|
9
|
+
if (u ? (n = function(o) {
|
|
10
|
+
o = o || this.$vnode && this.$vnode.ssrContext || this.parent && this.parent.$vnode && this.parent.$vnode.ssrContext, !o && typeof __VUE_SSR_CONTEXT__ < "u" && (o = __VUE_SSR_CONTEXT__), r && r.call(this, o), o && o._registeredComponents && o._registeredComponents.add(u);
|
|
11
|
+
}, s._ssrRegister = n) : r && (n = c ? function() {
|
|
12
|
+
r.call(
|
|
13
|
+
this,
|
|
14
|
+
(s.functional ? this.parent : this).$root.$options.shadowRoot
|
|
15
|
+
);
|
|
16
|
+
} : r), n)
|
|
17
|
+
if (s.functional) {
|
|
18
|
+
s._injectStyles = n;
|
|
19
|
+
var p = s.render;
|
|
20
|
+
s.render = function(g, f) {
|
|
21
|
+
return n.call(f), p(g, f);
|
|
22
|
+
};
|
|
23
|
+
} else {
|
|
24
|
+
var h = s.beforeCreate;
|
|
25
|
+
s.beforeCreate = h ? [].concat(h, n) : [n];
|
|
26
|
+
}
|
|
27
|
+
return {
|
|
28
|
+
exports: e,
|
|
29
|
+
options: s
|
|
30
|
+
};
|
|
31
|
+
}
|
|
32
|
+
let d = null;
|
|
33
|
+
const C = {
|
|
34
|
+
name: "recordTree",
|
|
35
|
+
components: {
|
|
36
|
+
Popper: v
|
|
37
|
+
},
|
|
38
|
+
props: {
|
|
39
|
+
editNote: {
|
|
40
|
+
type: Object,
|
|
41
|
+
default: function() {
|
|
42
|
+
return { title: "" };
|
|
43
|
+
}
|
|
44
|
+
},
|
|
45
|
+
// 图标相关配置
|
|
46
|
+
tagConfig: {
|
|
47
|
+
type: Object,
|
|
48
|
+
default: () => ({})
|
|
49
|
+
},
|
|
50
|
+
// 是否移动端
|
|
51
|
+
isMobile: {
|
|
52
|
+
type: Boolean,
|
|
53
|
+
default: !1
|
|
54
|
+
},
|
|
55
|
+
// 是否显示完成按钮
|
|
56
|
+
showComplete: {
|
|
57
|
+
type: Boolean,
|
|
58
|
+
default: !1
|
|
59
|
+
},
|
|
60
|
+
// 是否区分双击enter
|
|
61
|
+
isDbEnter: {
|
|
62
|
+
type: Boolean,
|
|
63
|
+
default: !1
|
|
64
|
+
}
|
|
65
|
+
},
|
|
66
|
+
data() {
|
|
67
|
+
return {
|
|
68
|
+
uploadLoading: !1,
|
|
69
|
+
curEditNote: {},
|
|
70
|
+
curNodes: [],
|
|
71
|
+
curTag: {},
|
|
72
|
+
// 传入图标有关的所有参数集合,外界根据需要传入
|
|
73
|
+
tagDefaultConfig: {
|
|
74
|
+
show: !0,
|
|
75
|
+
// tag总开关,false时取消tag所有功能
|
|
76
|
+
tags: [],
|
|
77
|
+
// 所有注册的图标
|
|
78
|
+
tagSize: 18,
|
|
79
|
+
// 图标大小
|
|
80
|
+
popW: "184px",
|
|
81
|
+
// 显示所有图标容器的宽度
|
|
82
|
+
popH: "auto",
|
|
83
|
+
// 显示所有图标容器的高度
|
|
84
|
+
tagL: "0px",
|
|
85
|
+
// 图标定位left值
|
|
86
|
+
tagT: "0px"
|
|
87
|
+
// 图标定位top值
|
|
88
|
+
},
|
|
89
|
+
tagObj: {},
|
|
90
|
+
curData: {},
|
|
91
|
+
nextDom: null,
|
|
92
|
+
// ->方向键寻找的下一个元素
|
|
93
|
+
touchTimer: null,
|
|
94
|
+
isTouching: !1,
|
|
95
|
+
showTag: !0,
|
|
96
|
+
delayData: {},
|
|
97
|
+
treeEditor: null
|
|
98
|
+
};
|
|
99
|
+
},
|
|
100
|
+
async created() {
|
|
101
|
+
this.curEditNote = JSON.parse(JSON.stringify(this.editNote)), this.curNodes = this.formatContent(this.curEditNote.content), this.tagObj = JSON.parse(
|
|
102
|
+
JSON.stringify({
|
|
103
|
+
...this.tagDefaultConfig,
|
|
104
|
+
...this.tagConfig
|
|
105
|
+
})
|
|
106
|
+
), this.findTagConfig(this.curEditNote.tag_id), this.curData = JSON.parse(JSON.stringify(this.editNote));
|
|
107
|
+
},
|
|
108
|
+
watch: {
|
|
109
|
+
// 1.新增弹框tags获取(Record项目需要)
|
|
110
|
+
tagConfig: {
|
|
111
|
+
handler(e) {
|
|
112
|
+
e && (this.showTag = !1, this.tagObj.tags = e.tags, this.$nextTick(() => {
|
|
113
|
+
this.showTag = !0;
|
|
114
|
+
}));
|
|
115
|
+
},
|
|
116
|
+
deep: !0
|
|
117
|
+
}
|
|
118
|
+
},
|
|
119
|
+
mounted() {
|
|
120
|
+
let e = this;
|
|
121
|
+
this.treeEditor = new _("root_tree"), this.$nextTick(() => {
|
|
122
|
+
function t() {
|
|
123
|
+
e.treeChange(e.delayData);
|
|
124
|
+
}
|
|
125
|
+
this.treeEditor.on("fileUpload", (i, a) => {
|
|
126
|
+
this.uploadLoading = !0, b.uploadFile(i, (r, l) => {
|
|
127
|
+
if (this.uploadLoading = !1, l && a) {
|
|
128
|
+
const u = l.filter((c) => c.code === 0).map((c) => c.data);
|
|
129
|
+
a(u);
|
|
130
|
+
}
|
|
131
|
+
});
|
|
132
|
+
}), this.treeEditor.on("dataChanged", (i, a = !1) => {
|
|
133
|
+
Object.assign(e.curData, { line: 167, send: a }), e.delayData = {
|
|
134
|
+
...e.curData,
|
|
135
|
+
content: JSON.stringify(i)
|
|
136
|
+
}, t();
|
|
137
|
+
}), this.treeEditor.loadTree(this.curNodes);
|
|
138
|
+
});
|
|
139
|
+
},
|
|
140
|
+
methods: {
|
|
141
|
+
treeChange(e) {
|
|
142
|
+
let t = !1;
|
|
143
|
+
this.curData.content != e.content && (t = !0, this.$set(this.curData, "content", e.content)), this.curData.title != e.title && (t = !0, this.$set(this.curData, "title", e.title));
|
|
144
|
+
let i = {
|
|
145
|
+
type: "tree",
|
|
146
|
+
data: e
|
|
147
|
+
};
|
|
148
|
+
(t || e.send) && this.$emit("treeChange", i);
|
|
149
|
+
},
|
|
150
|
+
refreshTree(e) {
|
|
151
|
+
this.curNodes = this.formatContent(e || '[{"text":""}]'), this.treeEditor.loadTree(this.curNodes, 1);
|
|
152
|
+
},
|
|
153
|
+
hideHoverNote() {
|
|
154
|
+
this.$emit("hideHoverNote");
|
|
155
|
+
},
|
|
156
|
+
// 根据svg的icon名找到svg实体
|
|
157
|
+
setSvgSrc(e) {
|
|
158
|
+
return "";
|
|
159
|
+
},
|
|
160
|
+
// 选择tag图标
|
|
161
|
+
tagSelect(e) {
|
|
162
|
+
this.curTag = e, this.findTagConfig(e.created_at), Object.assign(this.curData, {
|
|
163
|
+
line: 293,
|
|
164
|
+
send: !0
|
|
165
|
+
});
|
|
166
|
+
let t = {
|
|
167
|
+
type: "tag",
|
|
168
|
+
data: this.curData
|
|
169
|
+
};
|
|
170
|
+
this.$emit("treeChange", t);
|
|
171
|
+
},
|
|
172
|
+
findTagConfig(e) {
|
|
173
|
+
if (!this.tagObj.tags)
|
|
174
|
+
return;
|
|
175
|
+
let t = this.tagObj.tags.filter((i) => i.created_at === e);
|
|
176
|
+
t.length > 0 && (this.curTag = t[0], this.curData.tag_id = t[0].created_at);
|
|
177
|
+
},
|
|
178
|
+
titleClick(e) {
|
|
179
|
+
e.stopPropagation();
|
|
180
|
+
},
|
|
181
|
+
// 标题失去焦点
|
|
182
|
+
titleBlur() {
|
|
183
|
+
let e = document.querySelector("#tree_title").innerText;
|
|
184
|
+
if (this.curData.title !== e) {
|
|
185
|
+
this.curData.title = e, this.$set(this.curData, "title", e), Object.assign(this.curData, {
|
|
186
|
+
line: 328,
|
|
187
|
+
send: !0
|
|
188
|
+
});
|
|
189
|
+
let t = {
|
|
190
|
+
type: "title",
|
|
191
|
+
data: this.curData
|
|
192
|
+
};
|
|
193
|
+
this.$emit("treeChange", t);
|
|
194
|
+
}
|
|
195
|
+
},
|
|
196
|
+
// 标题enter输入
|
|
197
|
+
handleEnter(e) {
|
|
198
|
+
e.preventDefault(), this.isDbEnter ? d ? (clearTimeout(d), d = null, this.titleBlur(), this.$emit("dbEnter")) : d = setTimeout(() => {
|
|
199
|
+
d = null, this.keyEnter();
|
|
200
|
+
}, 180) : this.keyEnter();
|
|
201
|
+
},
|
|
202
|
+
handlePaste(e) {
|
|
203
|
+
if (e.clipboardData) {
|
|
204
|
+
const t = e.clipboardData.items;
|
|
205
|
+
Array.from(t).some((a) => a.kind === "file") && (e.preventDefault(), this.treeEditor.addFiles(
|
|
206
|
+
{
|
|
207
|
+
target: this.keyEnter()
|
|
208
|
+
},
|
|
209
|
+
e.clipboardData.files,
|
|
210
|
+
-1
|
|
211
|
+
));
|
|
212
|
+
}
|
|
213
|
+
},
|
|
214
|
+
keyEnter() {
|
|
215
|
+
let e = document.querySelector("#outline_tree .node-text");
|
|
216
|
+
return e.focus(), document.querySelectorAll(".lzx-tree-focus").forEach((i) => {
|
|
217
|
+
i.classList.remove("lzx-tree-focus");
|
|
218
|
+
}), e.classList.add("lzx-tree-focus"), e;
|
|
219
|
+
},
|
|
220
|
+
// 移动端=====================
|
|
221
|
+
setToParent() {
|
|
222
|
+
let e = new KeyboardEvent("keydown", {
|
|
223
|
+
bubbles: !0,
|
|
224
|
+
cancelable: !0,
|
|
225
|
+
key: "Tab",
|
|
226
|
+
shiftKey: !0
|
|
227
|
+
});
|
|
228
|
+
window.getSelection().baseNode.parentNode.dispatchEvent(e);
|
|
229
|
+
},
|
|
230
|
+
setToChild() {
|
|
231
|
+
let e = new KeyboardEvent("keydown", {
|
|
232
|
+
bubbles: !0,
|
|
233
|
+
cancelable: !0,
|
|
234
|
+
key: "Tab",
|
|
235
|
+
shiftKey: !1
|
|
236
|
+
});
|
|
237
|
+
window.getSelection().baseNode.parentNode.dispatchEvent(e);
|
|
238
|
+
},
|
|
239
|
+
setToUp() {
|
|
240
|
+
let e = new KeyboardEvent("keydown", {
|
|
241
|
+
bubbles: !0,
|
|
242
|
+
cancelable: !0,
|
|
243
|
+
key: "ArrowUp",
|
|
244
|
+
shiftKey: !1
|
|
245
|
+
});
|
|
246
|
+
window.getSelection().baseNode.parentNode.dispatchEvent(e);
|
|
247
|
+
},
|
|
248
|
+
setToDown() {
|
|
249
|
+
let e = new KeyboardEvent("keydown", {
|
|
250
|
+
bubbles: !0,
|
|
251
|
+
cancelable: !0,
|
|
252
|
+
key: "ArrowDown",
|
|
253
|
+
shiftKey: !1
|
|
254
|
+
});
|
|
255
|
+
window.getSelection().baseNode.parentNode.dispatchEvent(e);
|
|
256
|
+
},
|
|
257
|
+
complete() {
|
|
258
|
+
this.$emit("complete", this.curEditNote);
|
|
259
|
+
},
|
|
260
|
+
formatContent(e) {
|
|
261
|
+
try {
|
|
262
|
+
return JSON.parse(e);
|
|
263
|
+
} catch {
|
|
264
|
+
return [
|
|
265
|
+
{
|
|
266
|
+
text: e
|
|
267
|
+
}
|
|
268
|
+
];
|
|
269
|
+
}
|
|
270
|
+
}
|
|
271
|
+
}
|
|
272
|
+
};
|
|
273
|
+
var y = function() {
|
|
274
|
+
var t = this, i = t._self._c;
|
|
275
|
+
return i("div", { staticClass: "tree-editor", on: { mouseenter: t.hideHoverNote } }, [t._t("default"), i("div", { staticClass: "tree-title-div" }, [t.tagObj.show && t.showTag ? i("popper", { staticClass: "hover-popper", attrs: { trigger: "hover", options: {
|
|
276
|
+
placement: "bottom",
|
|
277
|
+
modifiers: { offset: { offset: "0px, 0px" } }
|
|
278
|
+
} } }, [i("div", { staticClass: "popper-content", style: { width: t.tagObj.popW, height: t.tagObj.popH } }, t._l(t.tagObj.tags, function(a, r) {
|
|
279
|
+
return i("span", { key: r, staticClass: "popper-content-item", on: { click: function(l) {
|
|
280
|
+
return t.tagSelect(a);
|
|
281
|
+
} } }, [t.setSvgSrc(a) ? i("inline-svg", { staticClass: "inline-svg", style: { backgroundColor: a.color }, attrs: { src: t.setSvgSrc(a), width: t.tagObj.tagSize, height: t.tagObj.tagSize } }) : i("span", { staticClass: "empty-icon", style: {
|
|
282
|
+
width: t.tagObj.tagSize + "px",
|
|
283
|
+
height: t.tagObj.tagSize + "px",
|
|
284
|
+
backgroundColor: a.color
|
|
285
|
+
} })], 1);
|
|
286
|
+
}), 0), i("span", { staticClass: "popper-reference", style: {
|
|
287
|
+
backgroundColor: t.curTag.color,
|
|
288
|
+
top: t.tagObj.tagT,
|
|
289
|
+
left: t.tagObj.tagL
|
|
290
|
+
}, attrs: { slot: "reference" }, slot: "reference" }, [t.setSvgSrc(t.curTag) ? i("inline-svg", { staticClass: "inline-svg", attrs: { src: t.setSvgSrc(t.curTag), width: t.tagObj.tagSize, height: t.tagObj.tagSize } }) : i("span", { staticClass: "inline-svg", style: {
|
|
291
|
+
width: t.tagObj.tagSize + "px",
|
|
292
|
+
height: t.tagObj.tagSize + "px",
|
|
293
|
+
backgroundColor: t.curTag.color
|
|
294
|
+
} })], 1)]) : t._e(), i("div", { staticClass: "tree-title", attrs: { contenteditable: "true", id: "tree_title" }, domProps: { innerHTML: t._s(t.editNote.title) }, on: { blur: t.titleBlur, click: t.titleClick, keydown: function(a) {
|
|
295
|
+
return !a.type.indexOf("key") && t._k(a.keyCode, "enter", 13, a.key, "Enter") ? null : (a.preventDefault(), t.handleEnter.apply(null, arguments));
|
|
296
|
+
}, paste: t.handlePaste } })], 1), t._m(0), t.isMobile ? i("div", { staticClass: "mobile-options" }, [i("div", { staticClass: "option-left" }, [i("div", { staticClass: "option-item", on: { click: t.setToParent } }, [t._v("向前")]), i("div", { staticClass: "option-item", on: { click: t.setToChild } }, [t._v("向后")]), i("div", { staticClass: "option-item", on: { click: t.setToUp } }, [t._v("向上")]), i("div", { staticClass: "option-item", on: { click: t.setToDown } }, [t._v("向下")])]), i("div", { staticClass: "option-right" }, [t.showComplete ? i("div", { staticClass: "option-item", on: { click: t.complete } }, [t._v(" 完成 ")]) : t._e()])]) : t._e(), t.uploadLoading ? i("div", { staticClass: "tree-upload-loading" }, [t._m(1)]) : t._e()], 2);
|
|
297
|
+
}, T = [function() {
|
|
298
|
+
var e = this, t = e._self._c;
|
|
299
|
+
return t("div", { attrs: { id: "outline_tree" } }, [t("div", { attrs: { id: "root_tree" } })]);
|
|
300
|
+
}, function() {
|
|
301
|
+
var e = this, t = e._self._c;
|
|
302
|
+
return t("p", [t("span", { staticClass: "icon icon-loading animate-spin" }), t("b", [e._v("正在上传资源,请稍后...")])]);
|
|
303
|
+
}], S = /* @__PURE__ */ m(
|
|
304
|
+
C,
|
|
305
|
+
y,
|
|
306
|
+
T,
|
|
307
|
+
!1,
|
|
308
|
+
null,
|
|
309
|
+
null,
|
|
310
|
+
null,
|
|
311
|
+
null
|
|
312
|
+
);
|
|
313
|
+
const k = S.exports;
|
|
314
|
+
export {
|
|
315
|
+
k as RecordTree
|
|
316
|
+
};
|
package/package.json
ADDED
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "@codernote/record-tree",
|
|
3
|
+
"version": "0.0.1",
|
|
4
|
+
"type": "module",
|
|
5
|
+
"main": "dist/index.js",
|
|
6
|
+
"dependencies": {
|
|
7
|
+
"vue-popperjs": "^2.3.0",
|
|
8
|
+
"@codernote/utils": "1.0.1",
|
|
9
|
+
"@codernote/tree-editor": "1.0.1"
|
|
10
|
+
},
|
|
11
|
+
"devDependencies": {
|
|
12
|
+
"vue": "^2.7.14",
|
|
13
|
+
"@vitejs/plugin-vue2": "^2.3.1",
|
|
14
|
+
"vite-plugin-css-injected-by-js": "^3.4.0",
|
|
15
|
+
"autoprefixer": "^10.4.13",
|
|
16
|
+
"postcss": "^8.4.20",
|
|
17
|
+
"typescript": "^4.9.3",
|
|
18
|
+
"vite": "^4.0.0",
|
|
19
|
+
"vite-svg-loader": "^4.0.0"
|
|
20
|
+
},
|
|
21
|
+
"files": [
|
|
22
|
+
"dist"
|
|
23
|
+
],
|
|
24
|
+
"publishConfig": {
|
|
25
|
+
"registry": "https://registry.npmjs.org/"
|
|
26
|
+
},
|
|
27
|
+
"scripts": {
|
|
28
|
+
"dev": "vite",
|
|
29
|
+
"build": "vite build",
|
|
30
|
+
"watch": "vite build --watch"
|
|
31
|
+
}
|
|
32
|
+
}
|