@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 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()}")),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
+ }