@codernote/record-tree 1.0.0 → 1.0.2

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.
Files changed (3) hide show
  1. package/README.md +58 -0
  2. package/dist/index.js +161 -193
  3. package/package.json +3 -3
package/README.md CHANGED
@@ -1 +1,59 @@
1
1
  # 记录软件 - 记录树
2
+
3
+ 记录软件左侧记录树组件, vue2 使用
4
+
5
+ ### 安装
6
+
7
+ ```bash
8
+ npm install @codernote/record-tree
9
+ ```
10
+
11
+ ### 使用
12
+
13
+ ```js
14
+ import { RecordTree } from "@codernote/record-tree";
15
+
16
+ <RecordTree
17
+ :note="note"
18
+ :tagConfig="tagConfig"
19
+ ></RecordTree>
20
+ ```
21
+
22
+ ### props
23
+
24
+ ```js
25
+ <RecordTree
26
+ {/* 必需,要编辑的note笔记 */}
27
+ :note="note"
28
+
29
+ {/* 是否展示标签及切换标签功能, 默认true */}
30
+ :showTag="true"
31
+
32
+ {/* 标签配置项, showTag为true时启用 */}
33
+ :tagConfig="tagConfig"
34
+
35
+ {/* 是否移动端使用,默认false */}
36
+ :isMobile="false"
37
+
38
+ {/* 是否展示完成按钮,isMobile生效时才启用,默认false */}
39
+ :showComplete="false"
40
+
41
+ {/* 启用双击enter, 标题双击回车,会触发事件, 默认false */}
42
+ :enableDbEnter="false"
43
+
44
+ {/* 监测note内容变动的事件 */}
45
+ @change="handleChange"
46
+
47
+ {/* enableDbEnter=true时生效,标题双击回车时触发事件 */}
48
+ @dbEnter="handleDbEnter"
49
+
50
+ {/* showComplete=true 时生效,点击完成按钮触发事件 */}
51
+ @complete="handleComplete"
52
+ ></RecordTree>
53
+ ```
54
+
55
+ ### 发布
56
+
57
+ ```bash
58
+ npm publish --access public
59
+ ```
package/dist/index.js CHANGED
@@ -1,42 +1,57 @@
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)}})();
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}.record-tree-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}.record-tree-popper-content-item{padding:8px 10px;display:flex;align-items:center;justify-content:center;cursor:pointer}.record-tree-svg{display:inline-block;border-radius:9999px;color:#fff;cursor:pointer}.record-tree-title-bar{position:relative;display:flex;margin-bottom:3px}.record-tree-title{padding-left:25px;font-weight:700;outline:none;font-size:1.125rem;line-height:1.5;width:100%}.record-tree-popper-reference{display:flex;position:absolute;top:0px;left:0px;text-align:center;border-radius:9999px;color:#fff}.record-tree-mobile-options{position:fixed;bottom:0px;left:0px;width:100%;display:flex;justify-content:space-between;padding:5px 0;background:rgb(236,236,236)}.record-tree-option-left{display:flex;padding-left:10px}.record-tree-option-right{padding-right:10px}.record-tree-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}.record-tree-empty-icon{display:inline-block;border-radius:9999px}.record-tree-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}.record-tree-upload-loading{position:absolute;left:0;top:0;bottom:0;right:0;font-size:12px;font-weight:400;color:#666}.record-tree-upload-loading p{display:flex;justify-content:center;align-items:center;position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:200px}.record-tree-icon-loading{background-image:url();animation:rotate 2s linear infinite}@keyframes rotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}")),document.head.appendChild(M)}}catch(T){console.error("vite-plugin-css-injected-by-js",T)}})();
2
2
  import v from "@codernote/tree-editor";
3
- import m from "vue-popperjs";
4
- import { oss as b, icons as p } from "@codernote/utils";
5
- function C(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(
3
+ import b from "vue-popperjs";
4
+ import { oss as m, icons as h } from "@codernote/utils";
5
+ function y(t, e, o, r, n, l, c, f) {
6
+ var i = typeof t == "function" ? t.options : t;
7
+ e && (i.render = e, i.staticRenderFns = o, i._compiled = !0), r && (i.functional = !0), l && (i._scopeId = "data-v-" + l);
8
+ var s;
9
+ if (c ? (s = function(a) {
10
+ a = a || this.$vnode && this.$vnode.ssrContext || this.parent && this.parent.$vnode && this.parent.$vnode.ssrContext, !a && typeof __VUE_SSR_CONTEXT__ < "u" && (a = __VUE_SSR_CONTEXT__), n && n.call(this, a), a && a._registeredComponents && a._registeredComponents.add(c);
11
+ }, i._ssrRegister = s) : n && (s = f ? function() {
12
+ n.call(
13
13
  this,
14
- (s.functional ? this.parent : this).$root.$options.shadowRoot
14
+ (i.functional ? this.parent : this).$root.$options.shadowRoot
15
15
  );
16
- } : r), n)
17
- if (s.functional) {
18
- s._injectStyles = n;
19
- var g = s.render;
20
- s.render = function(_, f) {
21
- return n.call(f), g(_, f);
16
+ } : n), s)
17
+ if (i.functional) {
18
+ i._injectStyles = s;
19
+ var g = i.render;
20
+ i.render = function(_, u) {
21
+ return s.call(u), g(_, u);
22
22
  };
23
23
  } else {
24
- var h = s.beforeCreate;
25
- s.beforeCreate = h ? [].concat(h, n) : [n];
24
+ var p = i.beforeCreate;
25
+ i.beforeCreate = p ? [].concat(p, s) : [s];
26
26
  }
27
27
  return {
28
- exports: e,
29
- options: s
28
+ exports: t,
29
+ options: i
30
30
  };
31
31
  }
32
32
  let d = null;
33
- const y = {
33
+ const C = {
34
+ show: !0,
35
+ // tag总开关,false时取消tag所有功能
36
+ tags: [],
37
+ // 所有注册的图标
38
+ tagSize: 18,
39
+ // 图标大小
40
+ popW: "184px",
41
+ // 显示所有图标容器的宽度
42
+ popH: "auto",
43
+ // 显示所有图标容器的高度
44
+ tagL: "0px",
45
+ // 图标定位left值
46
+ tagT: "0px"
47
+ // 图标定位top值
48
+ }, T = {
34
49
  name: "recordTree",
35
50
  components: {
36
- Popper: m
51
+ Popper: b
37
52
  },
38
53
  props: {
39
- editNote: {
54
+ note: {
40
55
  type: Object,
41
56
  default: function() {
42
57
  return { title: "" };
@@ -47,6 +62,10 @@ const y = {
47
62
  type: Object,
48
63
  default: () => ({})
49
64
  },
65
+ showTag: {
66
+ type: Boolean,
67
+ default: !0
68
+ },
50
69
  // 是否移动端
51
70
  isMobile: {
52
71
  type: Boolean,
@@ -58,260 +77,209 @@ const y = {
58
77
  default: !1
59
78
  },
60
79
  // 是否区分双击enter
61
- isDbEnter: {
80
+ enableDbEnter: {
62
81
  type: Boolean,
63
82
  default: !1
64
83
  }
65
84
  },
66
85
  data() {
67
86
  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
87
+ treeEditor: null,
88
+ uploadLoading: !1
98
89
  };
99
90
  },
100
91
  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,
92
+ this.loadNote();
93
+ },
94
+ computed: {
95
+ curTag() {
96
+ var t;
97
+ return ((t = this.note) == null ? void 0 : t.tag) || {};
98
+ },
99
+ curNodes() {
100
+ const t = this.note.content || '[{"text":""}]';
101
+ try {
102
+ return JSON.parse(t);
103
+ } catch {
104
+ return [
105
+ {
106
+ text: t
107
+ }
108
+ ];
109
+ }
110
+ },
111
+ tagObj() {
112
+ return {
113
+ ...C,
104
114
  ...this.tagConfig
105
- })
106
- ), this.findTagConfig(this.curEditNote.tag_id), this.curData = JSON.parse(JSON.stringify(this.editNote));
115
+ };
116
+ }
107
117
  },
108
118
  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
119
+ note(t, e) {
120
+ t.id !== e.id && this.loadNote();
117
121
  }
118
122
  },
119
123
  mounted() {
120
- let e = this;
121
124
  this.treeEditor = new v("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);
125
+ this.treeEditor.on("fileUpload", (t, e) => {
126
+ this.uploadLoading = !0, m.uploadFile(t, (o, r) => {
127
+ if (this.uploadLoading = !1, r && e) {
128
+ const n = r.filter((l) => l.code === 0).map((l) => l.data);
129
+ e(n);
130
130
  }
131
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();
132
+ }), this.treeEditor.on("dataChanged", (t) => {
133
+ this.treeChange({
134
+ ...this.note,
135
+ content: JSON.stringify(t)
136
+ });
137
137
  }), this.treeEditor.loadTree(this.curNodes);
138
138
  });
139
139
  },
140
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);
141
+ loadNote() {
142
+ this.treeEditor && this.treeEditor.loadTree(this.curNodes, 1);
149
143
  },
150
- refreshTree(e) {
151
- this.curNodes = this.formatContent(e || '[{"text":""}]'), this.treeEditor.loadTree(this.curNodes, 1);
144
+ treeChange(t) {
145
+ "content" in this.note && (this.note.content != t.content || this.note.title != t.title) && this.$emit("change", {
146
+ type: "tree",
147
+ data: t
148
+ });
152
149
  },
153
150
  hideHoverNote() {
154
151
  this.$emit("hideHoverNote");
155
152
  },
156
153
  // 根据svg的icon名找到svg实体
157
- setSvgSrc(e) {
158
- let t = p.findIndex((i) => i.name === e.icon);
159
- return t > -1 ? p[t].value : "";
154
+ getSvgUrl(t) {
155
+ let e = h.findIndex((o) => o.name === t.icon);
156
+ return e > -1 ? h[e].value : "";
160
157
  },
161
158
  // 选择tag图标
162
- tagSelect(e) {
163
- this.curTag = e, this.findTagConfig(e.created_at), Object.assign(this.curData, {
164
- line: 293,
165
- send: !0
166
- });
167
- let t = {
159
+ tagSelect(t) {
160
+ let e = {
168
161
  type: "tag",
169
- data: this.curData
162
+ data: {
163
+ ...this.note,
164
+ tag: t,
165
+ tag_id: t.created_at
166
+ }
170
167
  };
171
- this.$emit("treeChange", t);
172
- },
173
- findTagConfig(e) {
174
- if (!this.tagObj.tags)
175
- return;
176
- let t = this.tagObj.tags.filter((i) => i.created_at === e);
177
- t.length > 0 && (this.curTag = t[0], this.curData.tag_id = t[0].created_at);
178
- },
179
- titleClick(e) {
180
- e.stopPropagation();
168
+ this.$emit("change", e);
181
169
  },
182
170
  // 标题失去焦点
183
- titleBlur() {
184
- let e = document.querySelector("#tree_title").innerText;
185
- if (this.curData.title !== e) {
186
- this.curData.title = e, this.$set(this.curData, "title", e), Object.assign(this.curData, {
187
- line: 328,
188
- send: !0
189
- });
190
- let t = {
191
- type: "title",
192
- data: this.curData
193
- };
194
- this.$emit("treeChange", t);
195
- }
171
+ titleBlur(t) {
172
+ this.$emit("change", {
173
+ type: "title",
174
+ data: {
175
+ ...this.note,
176
+ title: t.target.innerText || ""
177
+ }
178
+ });
196
179
  },
197
180
  // 标题enter输入
198
- handleEnter(e) {
199
- e.preventDefault(), this.isDbEnter ? d ? (clearTimeout(d), d = null, this.titleBlur(), this.$emit("dbEnter")) : d = setTimeout(() => {
200
- d = null, this.keyEnter();
201
- }, 180) : this.keyEnter();
181
+ handleTitleEnter(t) {
182
+ t.preventDefault(), this.enableDbEnter ? d ? (clearTimeout(d), this.titleBlur(t), this.$emit("dbEnter")) : d = setTimeout(() => {
183
+ this.treeEditor.head(!0);
184
+ }, 180) : this.treeEditor.head(!0);
202
185
  },
203
- handlePaste(e) {
204
- if (e.clipboardData) {
205
- const t = e.clipboardData.items;
206
- Array.from(t).some((a) => a.kind === "file") && (e.preventDefault(), this.treeEditor.addFiles(
186
+ handleTitlePaste(t) {
187
+ if (t.clipboardData) {
188
+ const e = t.clipboardData.items;
189
+ Array.from(e).some((r) => r.kind === "file") && (t.preventDefault(), this.treeEditor.addFiles(
207
190
  {
208
- target: this.keyEnter()
191
+ target: this.treeEditor.head(!0)
209
192
  },
210
- e.clipboardData.files,
193
+ t.clipboardData.files,
211
194
  -1
212
195
  ));
213
196
  }
214
197
  },
215
- keyEnter() {
216
- let e = document.querySelector("#outline_tree .node-text");
217
- return e.focus(), document.querySelectorAll(".lzx-tree-focus").forEach((i) => {
218
- i.classList.remove("lzx-tree-focus");
219
- }), e.classList.add("lzx-tree-focus"), e;
220
- },
221
198
  // 移动端=====================
222
199
  setToParent() {
223
- let e = new KeyboardEvent("keydown", {
200
+ let t = new KeyboardEvent("keydown", {
224
201
  bubbles: !0,
225
202
  cancelable: !0,
226
203
  key: "Tab",
227
204
  shiftKey: !0
228
205
  });
229
- window.getSelection().baseNode.parentNode.dispatchEvent(e);
206
+ window.getSelection().baseNode.parentNode.dispatchEvent(t);
230
207
  },
231
208
  setToChild() {
232
- let e = new KeyboardEvent("keydown", {
209
+ let t = new KeyboardEvent("keydown", {
233
210
  bubbles: !0,
234
211
  cancelable: !0,
235
212
  key: "Tab",
236
213
  shiftKey: !1
237
214
  });
238
- window.getSelection().baseNode.parentNode.dispatchEvent(e);
215
+ window.getSelection().baseNode.parentNode.dispatchEvent(t);
239
216
  },
240
217
  setToUp() {
241
- let e = new KeyboardEvent("keydown", {
218
+ let t = new KeyboardEvent("keydown", {
242
219
  bubbles: !0,
243
220
  cancelable: !0,
244
221
  key: "ArrowUp",
245
222
  shiftKey: !1
246
223
  });
247
- window.getSelection().baseNode.parentNode.dispatchEvent(e);
224
+ window.getSelection().baseNode.parentNode.dispatchEvent(t);
248
225
  },
249
226
  setToDown() {
250
- let e = new KeyboardEvent("keydown", {
227
+ let t = new KeyboardEvent("keydown", {
251
228
  bubbles: !0,
252
229
  cancelable: !0,
253
230
  key: "ArrowDown",
254
231
  shiftKey: !1
255
232
  });
256
- window.getSelection().baseNode.parentNode.dispatchEvent(e);
233
+ window.getSelection().baseNode.parentNode.dispatchEvent(t);
257
234
  },
258
235
  complete() {
259
- this.$emit("complete", this.curEditNote);
260
- },
261
- formatContent(e) {
262
- try {
263
- return JSON.parse(e);
264
- } catch {
265
- return [
266
- {
267
- text: e
268
- }
269
- ];
270
- }
236
+ this.$emit("complete", this.note);
271
237
  }
272
238
  }
273
239
  };
274
- var T = function() {
275
- var t = this, i = t._self._c;
276
- 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: {
240
+ var w = function() {
241
+ var e = this, o = e._self._c;
242
+ return o("div", { staticClass: "record-tree", on: { mouseenter: e.hideHoverNote } }, [e._t("default"), o("div", { staticClass: "record-tree-title-bar" }, [e.tagObj.show && e.showTag ? o("popper", { attrs: { trigger: "hover", options: {
277
243
  placement: "bottom",
278
244
  modifiers: { offset: { offset: "0px, 0px" } }
279
- } } }, [i("div", { staticClass: "popper-content", style: { width: t.tagObj.popW, height: t.tagObj.popH } }, t._l(t.tagObj.tags, function(a, r) {
280
- return i("span", { key: r, staticClass: "popper-content-item", on: { click: function(l) {
281
- return t.tagSelect(a);
282
- } } }, [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: {
283
- width: t.tagObj.tagSize + "px",
284
- height: t.tagObj.tagSize + "px",
285
- backgroundColor: a.color
245
+ } } }, [o("div", { staticClass: "record-tree-popper-content", style: { width: e.tagObj.popW, height: e.tagObj.popH } }, e._l(e.tagObj.tags, function(r, n) {
246
+ return o("span", { key: n, staticClass: "record-tree-popper-content-item", on: { click: function(l) {
247
+ return e.tagSelect(r);
248
+ } } }, [e.getSvgUrl(r) ? o("inline-svg", { staticClass: "record-tree-svg", style: { backgroundColor: r.color }, attrs: { src: e.getSvgUrl(r), width: e.tagObj.tagSize, height: e.tagObj.tagSize } }) : o("span", { staticClass: "record-tree-empty-icon", style: {
249
+ width: e.tagObj.tagSize + "px",
250
+ height: e.tagObj.tagSize + "px",
251
+ backgroundColor: r.color
286
252
  } })], 1);
287
- }), 0), i("span", { staticClass: "popper-reference", style: {
288
- backgroundColor: t.curTag.color,
289
- top: t.tagObj.tagT,
290
- left: t.tagObj.tagL
291
- }, 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: {
292
- width: t.tagObj.tagSize + "px",
293
- height: t.tagObj.tagSize + "px",
294
- backgroundColor: t.curTag.color
295
- } })], 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) {
296
- return !a.type.indexOf("key") && t._k(a.keyCode, "enter", 13, a.key, "Enter") ? null : (a.preventDefault(), t.handleEnter.apply(null, arguments));
297
- }, 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);
298
- }, S = [function() {
299
- var e = this, t = e._self._c;
300
- return t("div", { attrs: { id: "outline_tree" } }, [t("div", { attrs: { id: "root_tree" } })]);
253
+ }), 0), o("span", { staticClass: "record-tree-popper-reference", style: {
254
+ backgroundColor: e.curTag.color,
255
+ top: e.tagObj.tagT,
256
+ left: e.tagObj.tagL
257
+ }, attrs: { slot: "reference" }, slot: "reference" }, [e.curTag.icon ? o("inline-svg", { staticClass: "record-tree-svg", attrs: { src: e.curTag.icon, width: e.tagObj.tagSize, height: e.tagObj.tagSize } }) : o("span", { staticClass: "record-tree-svg", style: {
258
+ width: e.tagObj.tagSize + "px",
259
+ height: e.tagObj.tagSize + "px",
260
+ backgroundColor: e.curTag.color
261
+ } })], 1)]) : e._e(), o("div", { staticClass: "record-tree-title", attrs: { contenteditable: "true", id: "tree_title" }, domProps: { innerHTML: e._s(e.note.title) }, on: { blur: e.titleBlur, click: function(r) {
262
+ r.stopPropagation();
263
+ }, keydown: function(r) {
264
+ return !r.type.indexOf("key") && e._k(r.keyCode, "enter", 13, r.key, "Enter") ? null : (r.preventDefault(), e.handleTitleEnter.apply(null, arguments));
265
+ }, paste: e.handleTitlePaste } })], 1), e._m(0), e.isMobile ? o("div", { staticClass: "record-tree-mobile-options" }, [o("div", { staticClass: "record-tree-option-left" }, [o("div", { staticClass: "record-tree-option-item", on: { click: e.setToParent } }, [e._v("向前")]), o("div", { staticClass: "record-tree-option-item", on: { click: e.setToChild } }, [e._v("向后")]), o("div", { staticClass: "record-tree-option-item", on: { click: e.setToUp } }, [e._v("向上")]), o("div", { staticClass: "record-tree-option-item", on: { click: e.setToDown } }, [e._v("向下")])]), o("div", { staticClass: "record-tree-option-right" }, [e.showComplete ? o("div", { staticClass: "record-tree-option-item", on: { click: e.complete } }, [e._v(" 完成 ")]) : e._e()])]) : e._e(), e.uploadLoading ? o("div", { staticClass: "record-tree-upload-loading" }, [e._m(1)]) : e._e()], 2);
266
+ }, E = [function() {
267
+ var t = this, e = t._self._c;
268
+ return e("div", { staticStyle: { "padding-left": "25px" } }, [e("div", { attrs: { id: "root_tree" } })]);
301
269
  }, function() {
302
- var e = this, t = e._self._c;
303
- return t("p", [t("span", { staticClass: "icon icon-loading animate-spin" }), t("b", [e._v("正在上传资源,请稍后...")])]);
304
- }], D = /* @__PURE__ */ C(
305
- y,
270
+ var t = this, e = t._self._c;
271
+ return e("p", [e("span", { staticClass: "record-tree-icon record-tree-icon-loading" }), e("b", [t._v("正在上传资源,请稍后...")])]);
272
+ }], k = /* @__PURE__ */ y(
306
273
  T,
307
- S,
274
+ w,
275
+ E,
308
276
  !1,
309
277
  null,
310
278
  null,
311
279
  null,
312
280
  null
313
281
  );
314
- const w = D.exports;
282
+ const j = k.exports;
315
283
  export {
316
- w as RecordTree
284
+ j as RecordTree
317
285
  };
package/package.json CHANGED
@@ -1,12 +1,12 @@
1
1
  {
2
2
  "name": "@codernote/record-tree",
3
- "version": "1.0.0",
3
+ "version": "1.0.2",
4
4
  "type": "module",
5
5
  "main": "dist/index.js",
6
6
  "dependencies": {
7
7
  "vue-popperjs": "^2.3.0",
8
- "@codernote/tree-editor": "1.0.2",
9
- "@codernote/utils": "1.0.2"
8
+ "@codernote/utils": "1.0.4",
9
+ "@codernote/tree-editor": "1.0.4"
10
10
  },
11
11
  "devDependencies": {
12
12
  "vue": "^2.7.14",