build-dxf 0.0.23 → 0.0.24

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/src/index3.js CHANGED
@@ -1,71 +1,71 @@
1
- import * as h from "three";
2
- import { i as ht, n as ut, r as Xe, t as $e, c as Be, d as pt, e as gt, f as Ne, g as X, _ as et, u as vt, h as xe, j as Fe, w as ft, k as yt, l as wt, p as bt, m as xt, o as Ct, T as ze, q as Te, s as Et, v as Mt, x as je, y as _e, z as Se, A as Lt, B as It, L as Ce, D as Pt, b as Ve, E as ue, S as kt } from "./selectLocalFile.js";
3
- import { C as Oe, P as R, L as z, B as Me, E as tt, b as Ge, Q as Le, u as Dt, W as St, T as At } from "./build.js";
1
+ import * as m from "three";
2
+ import { i as ht, n as ut, r as Ue, t as qe, c as Pe, d as pt, e as gt, f as De, g as Q, _ as Ze, u as vt, h as fe, j as Be, w as ft, k as yt, l as wt, p as bt, m as xt, o as Ct, T as Ne, q as Oe, s as Et, v as Mt, x as Re, y as Ie, z as Le, A as Lt, B as kt, L as ye, D as It, b as Ke, E as re, S as Pt } from "./selectLocalFile.js";
3
+ import { C as Ae, P as _, L as B, B as Ye, E as Xe, b as Fe, Q as ze, u as Dt, W as At, T as St } from "./build.js";
4
4
  import "clipper-lib";
5
5
  import "dxf-writer";
6
6
  import "three/addons/controls/OrbitControls.js";
7
- import { watch as ee, ref as T, defineComponent as ve, computed as F, createElementBlock as H, openBlock as K, normalizeClass as Z, unref as L, renderSlot as Ie, createVNode as J, Transition as Pe, withCtx as q, withDirectives as nt, createElementVNode as O, normalizeStyle as Re, createTextVNode as se, toDisplayString as pe, vShow as st, shallowReactive as _t, onMounted as ot, createBlock as we, createCommentVNode as ne, resolveDynamicComponent as Bt, Fragment as be, withModifiers as Nt, nextTick as Ee, isVNode as at, render as Qe, toRaw as Ot, onUnmounted as Rt, renderList as Ae, createStaticVNode as Kt, TransitionGroup as Ft, createApp as zt } from "vue";
8
- function it(c) {
7
+ import { watch as J, ref as S, defineComponent as ce, computed as P, createElementBlock as O, openBlock as I, normalizeClass as V, unref as f, renderSlot as be, createVNode as F, Transition as xe, withCtx as j, withDirectives as $e, createElementVNode as k, normalizeStyle as Se, createTextVNode as Y, toDisplayString as de, vShow as et, shallowReactive as _t, onMounted as tt, createBlock as ge, createCommentVNode as q, resolveDynamicComponent as Bt, Fragment as ve, withModifiers as Nt, nextTick as we, isVNode as nt, render as Te, toRaw as Ot, onUnmounted as Rt, renderList as ke, createStaticVNode as Kt, TransitionGroup as Ft, createApp as zt } from "vue";
8
+ function st(d) {
9
9
  var e;
10
- const t = Xe(c);
10
+ const t = Ue(d);
11
11
  return (e = t?.$el) != null ? e : t;
12
12
  }
13
- const rt = Be ? window : void 0;
14
- function Tt(...c) {
13
+ const ot = Pe ? window : void 0;
14
+ function Tt(...d) {
15
15
  let e, t, n, s;
16
- if (ht(c[0]) || Array.isArray(c[0]) ? ([t, n, s] = c, e = rt) : [e, t, n, s] = c, !e)
16
+ if (ht(d[0]) || Array.isArray(d[0]) ? ([t, n, s] = d, e = ot) : [e, t, n, s] = d, !e)
17
17
  return ut;
18
18
  Array.isArray(t) || (t = [t]), Array.isArray(n) || (n = [n]);
19
19
  const o = [], a = () => {
20
- o.forEach((d) => d()), o.length = 0;
21
- }, r = (d, p, E, f) => (d.addEventListener(p, E, f), () => d.removeEventListener(p, E, f)), l = ee(() => [it(e), Xe(s)], ([d, p]) => {
22
- a(), d && o.push(...t.flatMap((E) => n.map((f) => r(d, E, f, p))));
20
+ o.forEach((c) => c()), o.length = 0;
21
+ }, r = (c, h, y, u) => (c.addEventListener(h, y, u), () => c.removeEventListener(h, y, u)), l = J(() => [st(e), Ue(s)], ([c, h]) => {
22
+ a(), c && o.push(...t.flatMap((y) => n.map((u) => r(c, y, u, h))));
23
23
  }, { immediate: !0, flush: "post" }), i = () => {
24
24
  l(), a();
25
25
  };
26
- return $e(i), i;
26
+ return qe(i), i;
27
27
  }
28
- function jt(c, e = !1) {
29
- const t = T(), n = () => t.value = !!c();
28
+ function jt(d, e = !1) {
29
+ const t = S(), n = () => t.value = !!d();
30
30
  return n(), pt(n, e), t;
31
31
  }
32
- const He = typeof globalThis < "u" ? globalThis : typeof window < "u" ? window : typeof global < "u" ? global : typeof self < "u" ? self : {}, We = "__vueuse_ssr_handlers__";
33
- He[We] = He[We] || {};
34
- var Je = Object.getOwnPropertySymbols, Vt = Object.prototype.hasOwnProperty, Gt = Object.prototype.propertyIsEnumerable, Qt = (c, e) => {
32
+ const je = typeof globalThis < "u" ? globalThis : typeof window < "u" ? window : typeof global < "u" ? global : typeof self < "u" ? self : {}, Ve = "__vueuse_ssr_handlers__";
33
+ je[Ve] = je[Ve] || {};
34
+ var Ge = Object.getOwnPropertySymbols, Vt = Object.prototype.hasOwnProperty, Gt = Object.prototype.propertyIsEnumerable, Qt = (d, e) => {
35
35
  var t = {};
36
- for (var n in c)
37
- Vt.call(c, n) && e.indexOf(n) < 0 && (t[n] = c[n]);
38
- if (c != null && Je)
39
- for (var n of Je(c))
40
- e.indexOf(n) < 0 && Gt.call(c, n) && (t[n] = c[n]);
36
+ for (var n in d)
37
+ Vt.call(d, n) && e.indexOf(n) < 0 && (t[n] = d[n]);
38
+ if (d != null && Ge)
39
+ for (var n of Ge(d))
40
+ e.indexOf(n) < 0 && Gt.call(d, n) && (t[n] = d[n]);
41
41
  return t;
42
42
  };
43
- function Ht(c, e, t = {}) {
44
- const n = t, { window: s = rt } = n, o = Qt(n, ["window"]);
43
+ function Ht(d, e, t = {}) {
44
+ const n = t, { window: s = ot } = n, o = Qt(n, ["window"]);
45
45
  let a;
46
46
  const r = jt(() => s && "ResizeObserver" in s), l = () => {
47
47
  a && (a.disconnect(), a = void 0);
48
- }, i = ee(() => it(c), (p) => {
49
- l(), r.value && s && p && (a = new ResizeObserver(e), a.observe(p, o));
50
- }, { immediate: !0, flush: "post" }), d = () => {
48
+ }, i = J(() => st(d), (h) => {
49
+ l(), r.value && s && h && (a = new ResizeObserver(e), a.observe(h, o));
50
+ }, { immediate: !0, flush: "post" }), c = () => {
51
51
  l(), i();
52
52
  };
53
- return $e(d), {
53
+ return qe(c), {
54
54
  isSupported: r,
55
- stop: d
55
+ stop: c
56
56
  };
57
57
  }
58
- var Ue;
59
- (function(c) {
60
- c.UP = "UP", c.RIGHT = "RIGHT", c.DOWN = "DOWN", c.LEFT = "LEFT", c.NONE = "NONE";
61
- })(Ue || (Ue = {}));
62
- var Wt = Object.defineProperty, qe = Object.getOwnPropertySymbols, Jt = Object.prototype.hasOwnProperty, Ut = Object.prototype.propertyIsEnumerable, Ze = (c, e, t) => e in c ? Wt(c, e, { enumerable: !0, configurable: !0, writable: !0, value: t }) : c[e] = t, qt = (c, e) => {
58
+ var Qe;
59
+ (function(d) {
60
+ d.UP = "UP", d.RIGHT = "RIGHT", d.DOWN = "DOWN", d.LEFT = "LEFT", d.NONE = "NONE";
61
+ })(Qe || (Qe = {}));
62
+ var Wt = Object.defineProperty, He = Object.getOwnPropertySymbols, Jt = Object.prototype.hasOwnProperty, Ut = Object.prototype.propertyIsEnumerable, We = (d, e, t) => e in d ? Wt(d, e, { enumerable: !0, configurable: !0, writable: !0, value: t }) : d[e] = t, qt = (d, e) => {
63
63
  for (var t in e || (e = {}))
64
- Jt.call(e, t) && Ze(c, t, e[t]);
65
- if (qe)
66
- for (var t of qe(e))
67
- Ut.call(e, t) && Ze(c, t, e[t]);
68
- return c;
64
+ Jt.call(e, t) && We(d, t, e[t]);
65
+ if (He)
66
+ for (var t of He(e))
67
+ Ut.call(e, t) && We(d, t, e[t]);
68
+ return d;
69
69
  };
70
70
  const Zt = {
71
71
  easeInSine: [0.12, 0, 0.39, 0],
@@ -96,9 +96,9 @@ const Zt = {
96
96
  qt({
97
97
  linear: gt
98
98
  }, Zt);
99
- const Yt = (c) => c, Xt = {
99
+ const Yt = (d) => d, Xt = {
100
100
  esc: "Escape"
101
- }, $t = Ne({
101
+ }, $t = De({
102
102
  value: {
103
103
  type: [String, Number],
104
104
  default: ""
@@ -120,59 +120,59 @@ const Yt = (c) => c, Xt = {
120
120
  },
121
121
  color: String,
122
122
  badgeStyle: {
123
- type: X([String, Object, Array])
123
+ type: Q([String, Object, Array])
124
124
  },
125
125
  offset: {
126
- type: X(Array),
126
+ type: Q(Array),
127
127
  default: [0, 0]
128
128
  },
129
129
  badgeClass: {
130
130
  type: String
131
131
  }
132
- }), en = ve({
132
+ }), en = ce({
133
133
  name: "ElBadge"
134
- }), tn = /* @__PURE__ */ ve({
134
+ }), tn = /* @__PURE__ */ ce({
135
135
  ...en,
136
136
  props: $t,
137
- setup(c, { expose: e }) {
138
- const t = c, n = vt("badge"), s = F(() => t.isDot ? "" : xe(t.value) && xe(t.max) ? t.max < t.value ? `${t.max}+` : `${t.value}` : `${t.value}`), o = F(() => {
139
- var a, r, l, i, d;
137
+ setup(d, { expose: e }) {
138
+ const t = d, n = vt("badge"), s = P(() => t.isDot ? "" : fe(t.value) && fe(t.max) ? t.max < t.value ? `${t.max}+` : `${t.value}` : `${t.value}`), o = P(() => {
139
+ var a, r, l, i, c;
140
140
  return [
141
141
  {
142
142
  backgroundColor: t.color,
143
- marginRight: Fe(-((r = (a = t.offset) == null ? void 0 : a[0]) != null ? r : 0)),
144
- marginTop: Fe((i = (l = t.offset) == null ? void 0 : l[1]) != null ? i : 0)
143
+ marginRight: Be(-((r = (a = t.offset) == null ? void 0 : a[0]) != null ? r : 0)),
144
+ marginTop: Be((i = (l = t.offset) == null ? void 0 : l[1]) != null ? i : 0)
145
145
  },
146
- (d = t.badgeStyle) != null ? d : {}
146
+ (c = t.badgeStyle) != null ? c : {}
147
147
  ];
148
148
  });
149
149
  return e({
150
150
  content: s
151
- }), (a, r) => (K(), H("div", {
152
- class: Z(L(n).b())
151
+ }), (a, r) => (I(), O("div", {
152
+ class: V(f(n).b())
153
153
  }, [
154
- Ie(a.$slots, "default"),
155
- J(Pe, {
156
- name: `${L(n).namespace.value}-zoom-in-center`,
154
+ be(a.$slots, "default"),
155
+ F(xe, {
156
+ name: `${f(n).namespace.value}-zoom-in-center`,
157
157
  persisted: ""
158
158
  }, {
159
- default: q(() => [
160
- nt(O("sup", {
161
- class: Z([
162
- L(n).e("content"),
163
- L(n).em("content", a.type),
164
- L(n).is("fixed", !!a.$slots.default),
165
- L(n).is("dot", a.isDot),
166
- L(n).is("hide-zero", !a.showZero && t.value === 0),
159
+ default: j(() => [
160
+ $e(k("sup", {
161
+ class: V([
162
+ f(n).e("content"),
163
+ f(n).em("content", a.type),
164
+ f(n).is("fixed", !!a.$slots.default),
165
+ f(n).is("dot", a.isDot),
166
+ f(n).is("hide-zero", !a.showZero && t.value === 0),
167
167
  a.badgeClass
168
168
  ]),
169
- style: Re(L(o))
169
+ style: Se(f(o))
170
170
  }, [
171
- Ie(a.$slots, "content", { value: L(s) }, () => [
172
- se(pe(L(s)), 1)
171
+ be(a.$slots, "content", { value: f(s) }, () => [
172
+ Y(de(f(s)), 1)
173
173
  ])
174
174
  ], 6), [
175
- [st, !a.hidden && (L(s) || a.isDot || a.$slots.content)]
175
+ [et, !a.hidden && (f(s) || a.isDot || a.$slots.content)]
176
176
  ])
177
177
  ]),
178
178
  _: 3
@@ -180,37 +180,37 @@ const Yt = (c) => c, Xt = {
180
180
  ], 2));
181
181
  }
182
182
  });
183
- var nn = /* @__PURE__ */ et(tn, [["__file", "badge.vue"]]);
184
- const sn = ft(nn), on = Ne({
183
+ var nn = /* @__PURE__ */ Ze(tn, [["__file", "badge.vue"]]);
184
+ const sn = ft(nn), on = De({
185
185
  a11y: {
186
186
  type: Boolean,
187
187
  default: !0
188
188
  },
189
189
  locale: {
190
- type: X(Object)
190
+ type: Q(Object)
191
191
  },
192
192
  size: wt,
193
193
  button: {
194
- type: X(Object)
194
+ type: Q(Object)
195
195
  },
196
196
  card: {
197
- type: X(Object)
197
+ type: Q(Object)
198
198
  },
199
199
  dialog: {
200
- type: X(Object)
200
+ type: Q(Object)
201
201
  },
202
202
  link: {
203
- type: X(Object)
203
+ type: Q(Object)
204
204
  },
205
205
  experimentalFeatures: {
206
- type: X(Object)
206
+ type: Q(Object)
207
207
  },
208
208
  keyboardNavigation: {
209
209
  type: Boolean,
210
210
  default: !0
211
211
  },
212
212
  message: {
213
- type: X(Object)
213
+ type: Q(Object)
214
214
  },
215
215
  zIndex: Number,
216
216
  namespace: {
@@ -218,25 +218,25 @@ const sn = ft(nn), on = Ne({
218
218
  default: "el"
219
219
  },
220
220
  ...yt
221
- }), U = {};
222
- ve({
221
+ }), T = {};
222
+ ce({
223
223
  name: "ElConfigProvider",
224
224
  props: on,
225
- setup(c, { slots: e }) {
226
- const t = bt(c);
227
- return ee(() => c.message, (n) => {
225
+ setup(d, { slots: e }) {
226
+ const t = bt(d);
227
+ return J(() => d.message, (n) => {
228
228
  var s, o;
229
- Object.assign(U, (o = (s = t?.value) == null ? void 0 : s.message) != null ? o : {}, n ?? {});
230
- }, { immediate: !0, deep: !0 }), () => Ie(e, "default", { config: t?.value });
229
+ Object.assign(T, (o = (s = t?.value) == null ? void 0 : s.message) != null ? o : {}, n ?? {});
230
+ }, { immediate: !0, deep: !0 }), () => be(e, "default", { config: t?.value });
231
231
  }
232
232
  });
233
- const dt = [
233
+ const at = [
234
234
  "primary",
235
235
  "success",
236
236
  "info",
237
237
  "warning",
238
238
  "error"
239
- ], Q = Yt({
239
+ ], N = Yt({
240
240
  customClass: "",
241
241
  dangerouslyUseHTMLString: !1,
242
242
  duration: 3e3,
@@ -251,226 +251,226 @@ const dt = [
251
251
  zIndex: 0,
252
252
  grouping: !1,
253
253
  repeatNum: 1,
254
- appendTo: Be ? document.body : void 0
255
- }), an = Ne({
254
+ appendTo: Pe ? document.body : void 0
255
+ }), an = De({
256
256
  customClass: {
257
257
  type: String,
258
- default: Q.customClass
258
+ default: N.customClass
259
259
  },
260
260
  dangerouslyUseHTMLString: {
261
261
  type: Boolean,
262
- default: Q.dangerouslyUseHTMLString
262
+ default: N.dangerouslyUseHTMLString
263
263
  },
264
264
  duration: {
265
265
  type: Number,
266
- default: Q.duration
266
+ default: N.duration
267
267
  },
268
268
  icon: {
269
269
  type: xt,
270
- default: Q.icon
270
+ default: N.icon
271
271
  },
272
272
  id: {
273
273
  type: String,
274
- default: Q.id
274
+ default: N.id
275
275
  },
276
276
  message: {
277
- type: X([
277
+ type: Q([
278
278
  String,
279
279
  Object,
280
280
  Function
281
281
  ]),
282
- default: Q.message
282
+ default: N.message
283
283
  },
284
284
  onClose: {
285
- type: X(Function),
286
- default: Q.onClose
285
+ type: Q(Function),
286
+ default: N.onClose
287
287
  },
288
288
  showClose: {
289
289
  type: Boolean,
290
- default: Q.showClose
290
+ default: N.showClose
291
291
  },
292
292
  type: {
293
293
  type: String,
294
- values: dt,
295
- default: Q.type
294
+ values: at,
295
+ default: N.type
296
296
  },
297
297
  plain: {
298
298
  type: Boolean,
299
- default: Q.plain
299
+ default: N.plain
300
300
  },
301
301
  offset: {
302
302
  type: Number,
303
- default: Q.offset
303
+ default: N.offset
304
304
  },
305
305
  zIndex: {
306
306
  type: Number,
307
- default: Q.zIndex
307
+ default: N.zIndex
308
308
  },
309
309
  grouping: {
310
310
  type: Boolean,
311
- default: Q.grouping
311
+ default: N.grouping
312
312
  },
313
313
  repeatNum: {
314
314
  type: Number,
315
- default: Q.repeatNum
315
+ default: N.repeatNum
316
316
  }
317
317
  }), rn = {
318
318
  destroy: () => !0
319
- }, $ = _t([]), dn = (c) => {
320
- const e = $.findIndex((s) => s.id === c), t = $[e];
319
+ }, H = _t([]), dn = (d) => {
320
+ const e = H.findIndex((s) => s.id === d), t = H[e];
321
321
  let n;
322
- return e > 0 && (n = $[e - 1]), { current: t, prev: n };
323
- }, ln = (c) => {
324
- const { prev: e } = dn(c);
322
+ return e > 0 && (n = H[e - 1]), { current: t, prev: n };
323
+ }, ln = (d) => {
324
+ const { prev: e } = dn(d);
325
325
  return e ? e.vm.exposed.bottom.value : 0;
326
- }, cn = (c, e) => $.findIndex((n) => n.id === c) > 0 ? 16 : e, mn = ve({
326
+ }, cn = (d, e) => H.findIndex((n) => n.id === d) > 0 ? 16 : e, mn = ce({
327
327
  name: "ElMessage"
328
- }), hn = /* @__PURE__ */ ve({
328
+ }), hn = /* @__PURE__ */ ce({
329
329
  ...mn,
330
330
  props: an,
331
331
  emits: rn,
332
- setup(c, { expose: e, emit: t }) {
333
- const n = c, { Close: s } = Et, o = T(!1), { ns: a, zIndex: r } = Ct("message"), { currentZIndex: l, nextZIndex: i } = r, d = T(), p = T(!1), E = T(0);
334
- let f;
335
- const y = F(() => n.type ? n.type === "error" ? "danger" : n.type : "info"), C = F(() => {
336
- const m = n.type;
337
- return { [a.bm("icon", m)]: m && ze[m] };
338
- }), v = F(() => n.icon || ze[n.type] || ""), w = F(() => ln(n.id)), g = F(() => cn(n.id, n.offset) + w.value), S = F(() => E.value + g.value), A = F(() => ({
339
- top: `${g.value}px`,
332
+ setup(d, { expose: e, emit: t }) {
333
+ const n = d, { Close: s } = Et, o = S(!1), { ns: a, zIndex: r } = Ct("message"), { currentZIndex: l, nextZIndex: i } = r, c = S(), h = S(!1), y = S(0);
334
+ let u;
335
+ const v = P(() => n.type ? n.type === "error" ? "danger" : n.type : "info"), g = P(() => {
336
+ const b = n.type;
337
+ return { [a.bm("icon", b)]: b && Ne[b] };
338
+ }), E = P(() => n.icon || Ne[n.type] || ""), x = P(() => ln(n.id)), D = P(() => cn(n.id, n.offset) + x.value), z = P(() => y.value + D.value), me = P(() => ({
339
+ top: `${D.value}px`,
340
340
  zIndex: l.value
341
341
  }));
342
- function M() {
343
- n.duration !== 0 && ({ stop: f } = Mt(() => {
344
- D();
342
+ function Z() {
343
+ n.duration !== 0 && ({ stop: u } = Mt(() => {
344
+ A();
345
345
  }, n.duration));
346
346
  }
347
- function u() {
348
- f?.();
347
+ function G() {
348
+ u?.();
349
349
  }
350
- function D() {
351
- p.value = !1, Ee(() => {
352
- var m;
353
- o.value || ((m = n.onClose) == null || m.call(n), t("destroy"));
350
+ function A() {
351
+ h.value = !1, we(() => {
352
+ var b;
353
+ o.value || ((b = n.onClose) == null || b.call(n), t("destroy"));
354
354
  });
355
355
  }
356
- function b({ code: m }) {
357
- m === Xt.esc && D();
356
+ function M({ code: b }) {
357
+ b === Xt.esc && A();
358
358
  }
359
- return ot(() => {
360
- M(), i(), p.value = !0;
361
- }), ee(() => n.repeatNum, () => {
362
- u(), M();
363
- }), Tt(document, "keydown", b), Ht(d, () => {
364
- E.value = d.value.getBoundingClientRect().height;
359
+ return tt(() => {
360
+ Z(), i(), h.value = !0;
361
+ }), J(() => n.repeatNum, () => {
362
+ G(), Z();
363
+ }), Tt(document, "keydown", M), Ht(c, () => {
364
+ y.value = c.value.getBoundingClientRect().height;
365
365
  }), e({
366
- visible: p,
367
- bottom: S,
368
- close: D
369
- }), (m, I) => (K(), we(Pe, {
370
- name: L(a).b("fade"),
371
- onBeforeEnter: (_) => o.value = !0,
372
- onBeforeLeave: m.onClose,
373
- onAfterLeave: (_) => m.$emit("destroy"),
366
+ visible: h,
367
+ bottom: z,
368
+ close: A
369
+ }), (b, K) => (I(), ge(xe, {
370
+ name: f(a).b("fade"),
371
+ onBeforeEnter: (W) => o.value = !0,
372
+ onBeforeLeave: b.onClose,
373
+ onAfterLeave: (W) => b.$emit("destroy"),
374
374
  persisted: ""
375
375
  }, {
376
- default: q(() => [
377
- nt(O("div", {
378
- id: m.id,
376
+ default: j(() => [
377
+ $e(k("div", {
378
+ id: b.id,
379
379
  ref_key: "messageRef",
380
- ref: d,
381
- class: Z([
382
- L(a).b(),
383
- { [L(a).m(m.type)]: m.type },
384
- L(a).is("closable", m.showClose),
385
- L(a).is("plain", m.plain),
386
- m.customClass
380
+ ref: c,
381
+ class: V([
382
+ f(a).b(),
383
+ { [f(a).m(b.type)]: b.type },
384
+ f(a).is("closable", b.showClose),
385
+ f(a).is("plain", b.plain),
386
+ b.customClass
387
387
  ]),
388
- style: Re(L(A)),
388
+ style: Se(f(me)),
389
389
  role: "alert",
390
- onMouseenter: u,
391
- onMouseleave: M
390
+ onMouseenter: G,
391
+ onMouseleave: Z
392
392
  }, [
393
- m.repeatNum > 1 ? (K(), we(L(sn), {
393
+ b.repeatNum > 1 ? (I(), ge(f(sn), {
394
394
  key: 0,
395
- value: m.repeatNum,
396
- type: L(y),
397
- class: Z(L(a).e("badge"))
398
- }, null, 8, ["value", "type", "class"])) : ne("v-if", !0),
399
- L(v) ? (K(), we(L(Te), {
395
+ value: b.repeatNum,
396
+ type: f(v),
397
+ class: V(f(a).e("badge"))
398
+ }, null, 8, ["value", "type", "class"])) : q("v-if", !0),
399
+ f(E) ? (I(), ge(f(Oe), {
400
400
  key: 1,
401
- class: Z([L(a).e("icon"), L(C)])
401
+ class: V([f(a).e("icon"), f(g)])
402
402
  }, {
403
- default: q(() => [
404
- (K(), we(Bt(L(v))))
403
+ default: j(() => [
404
+ (I(), ge(Bt(f(E))))
405
405
  ]),
406
406
  _: 1
407
- }, 8, ["class"])) : ne("v-if", !0),
408
- Ie(m.$slots, "default", {}, () => [
409
- m.dangerouslyUseHTMLString ? (K(), H(be, { key: 1 }, [
410
- ne(" Caution here, message could've been compromised, never use user's input as message "),
411
- O("p", {
412
- class: Z(L(a).e("content")),
413
- innerHTML: m.message
407
+ }, 8, ["class"])) : q("v-if", !0),
408
+ be(b.$slots, "default", {}, () => [
409
+ b.dangerouslyUseHTMLString ? (I(), O(ve, { key: 1 }, [
410
+ q(" Caution here, message could've been compromised, never use user's input as message "),
411
+ k("p", {
412
+ class: V(f(a).e("content")),
413
+ innerHTML: b.message
414
414
  }, null, 10, ["innerHTML"])
415
- ], 2112)) : (K(), H("p", {
415
+ ], 2112)) : (I(), O("p", {
416
416
  key: 0,
417
- class: Z(L(a).e("content"))
418
- }, pe(m.message), 3))
417
+ class: V(f(a).e("content"))
418
+ }, de(b.message), 3))
419
419
  ]),
420
- m.showClose ? (K(), we(L(Te), {
420
+ b.showClose ? (I(), ge(f(Oe), {
421
421
  key: 2,
422
- class: Z(L(a).e("closeBtn")),
423
- onClick: Nt(D, ["stop"])
422
+ class: V(f(a).e("closeBtn")),
423
+ onClick: Nt(A, ["stop"])
424
424
  }, {
425
- default: q(() => [
426
- J(L(s))
425
+ default: j(() => [
426
+ F(f(s))
427
427
  ]),
428
428
  _: 1
429
- }, 8, ["class", "onClick"])) : ne("v-if", !0)
429
+ }, 8, ["class", "onClick"])) : q("v-if", !0)
430
430
  ], 46, ["id"]), [
431
- [st, p.value]
431
+ [et, h.value]
432
432
  ])
433
433
  ]),
434
434
  _: 3
435
435
  }, 8, ["name", "onBeforeEnter", "onBeforeLeave", "onAfterLeave"]));
436
436
  }
437
437
  });
438
- var un = /* @__PURE__ */ et(hn, [["__file", "message.vue"]]);
438
+ var un = /* @__PURE__ */ Ze(hn, [["__file", "message.vue"]]);
439
439
  let pn = 1;
440
- const lt = (c) => {
441
- const e = !c || je(c) || at(c) || _e(c) ? { message: c } : c, t = {
442
- ...Q,
440
+ const it = (d) => {
441
+ const e = !d || Re(d) || nt(d) || Ie(d) ? { message: d } : d, t = {
442
+ ...N,
443
443
  ...e
444
444
  };
445
445
  if (!t.appendTo)
446
446
  t.appendTo = document.body;
447
- else if (je(t.appendTo)) {
447
+ else if (Re(t.appendTo)) {
448
448
  let n = document.querySelector(t.appendTo);
449
449
  Lt(n) || (n = document.body), t.appendTo = n;
450
450
  }
451
- return Se(U.grouping) && !t.grouping && (t.grouping = U.grouping), xe(U.duration) && t.duration === 3e3 && (t.duration = U.duration), xe(U.offset) && t.offset === 16 && (t.offset = U.offset), Se(U.showClose) && !t.showClose && (t.showClose = U.showClose), Se(U.plain) && !t.plain && (t.plain = U.plain), t;
452
- }, gn = (c) => {
453
- const e = $.indexOf(c);
451
+ return Le(T.grouping) && !t.grouping && (t.grouping = T.grouping), fe(T.duration) && t.duration === 3e3 && (t.duration = T.duration), fe(T.offset) && t.offset === 16 && (t.offset = T.offset), Le(T.showClose) && !t.showClose && (t.showClose = T.showClose), Le(T.plain) && !t.plain && (t.plain = T.plain), t;
452
+ }, gn = (d) => {
453
+ const e = H.indexOf(d);
454
454
  if (e === -1)
455
455
  return;
456
- $.splice(e, 1);
457
- const { handler: t } = c;
456
+ H.splice(e, 1);
457
+ const { handler: t } = d;
458
458
  t.close();
459
- }, vn = ({ appendTo: c, ...e }, t) => {
459
+ }, vn = ({ appendTo: d, ...e }, t) => {
460
460
  const n = `message_${pn++}`, s = e.onClose, o = document.createElement("div"), a = {
461
461
  ...e,
462
462
  id: n,
463
463
  onClose: () => {
464
- s?.(), gn(d);
464
+ s?.(), gn(c);
465
465
  },
466
466
  onDestroy: () => {
467
- Qe(null, o);
467
+ Te(null, o);
468
468
  }
469
- }, r = J(un, a, _e(a.message) || at(a.message) ? {
470
- default: _e(a.message) ? a.message : () => a.message
469
+ }, r = F(un, a, Ie(a.message) || nt(a.message) ? {
470
+ default: Ie(a.message) ? a.message : () => a.message
471
471
  } : null);
472
- r.appContext = t || ge._context, Qe(r, o), c.appendChild(o.firstElementChild);
473
- const l = r.component, d = {
472
+ r.appContext = t || le._context, Te(r, o), d.appendChild(o.firstElementChild);
473
+ const l = r.component, c = {
474
474
  id: n,
475
475
  vnode: r,
476
476
  vm: l,
@@ -481,41 +481,41 @@ const lt = (c) => {
481
481
  },
482
482
  props: r.component.props
483
483
  };
484
- return d;
485
- }, ge = (c = {}, e) => {
486
- if (!Be)
484
+ return c;
485
+ }, le = (d = {}, e) => {
486
+ if (!Pe)
487
487
  return { close: () => {
488
488
  } };
489
- const t = lt(c);
490
- if (t.grouping && $.length) {
491
- const s = $.find(({ vnode: o }) => {
489
+ const t = it(d);
490
+ if (t.grouping && H.length) {
491
+ const s = H.find(({ vnode: o }) => {
492
492
  var a;
493
493
  return ((a = o.props) == null ? void 0 : a.message) === t.message;
494
494
  });
495
495
  if (s)
496
496
  return s.props.repeatNum += 1, s.props.type = t.type, s.handler;
497
497
  }
498
- if (xe(U.max) && $.length >= U.max)
498
+ if (fe(T.max) && H.length >= T.max)
499
499
  return { close: () => {
500
500
  } };
501
501
  const n = vn(t, e);
502
- return $.push(n), n.handler;
502
+ return H.push(n), n.handler;
503
503
  };
504
- dt.forEach((c) => {
505
- ge[c] = (e = {}, t) => {
506
- const n = lt(e);
507
- return ge({ ...n, type: c }, t);
504
+ at.forEach((d) => {
505
+ le[d] = (e = {}, t) => {
506
+ const n = it(e);
507
+ return le({ ...n, type: d }, t);
508
508
  };
509
509
  });
510
- function fn(c) {
511
- const e = [...$];
510
+ function fn(d) {
511
+ const e = [...H];
512
512
  for (const t of e)
513
- (!c || c === t.props.type) && t.handler.close();
513
+ (!d || d === t.props.type) && t.handler.close();
514
514
  }
515
- ge.closeAll = fn;
516
- ge._context = null;
517
- const B = It(ge, "$message");
518
- class W extends Oe {
515
+ le.closeAll = fn;
516
+ le._context = null;
517
+ const L = kt(le, "$message");
518
+ class R extends Ae {
519
519
  _renderer;
520
520
  get renderer() {
521
521
  return this._renderer || (this._renderer = this.parent?.findComponentByName("Renderer")), this._renderer;
@@ -603,19 +603,19 @@ class W extends Oe {
603
603
  * @returns
604
604
  */
605
605
  createPointerMove(e) {
606
- const t = this.editor, n = new R();
606
+ const t = this.editor, n = new _();
607
607
  let s = null, o = null, a = null;
608
608
  const r = t.addEventListener("pointerPositionChange", () => {
609
- const l = R.from(t.pointerPosition);
609
+ const l = _.from(t.pointerPosition);
610
610
  if (s && t.eventInput.isKeyDown("shift")) {
611
- const i = Math.abs(l.x - s.x), d = Math.abs(l.y - s.y);
612
- i > d ? n.set(l.x, s.y) : n.set(s.x, l.y), e(n, !1);
611
+ const i = Math.abs(l.x - s.x), c = Math.abs(l.y - s.y);
612
+ i > c ? n.set(l.x, s.y) : n.set(s.x, l.y), e(n, !1);
613
613
  } else if (o && a && t.eventInput.isKeyDown("alt")) {
614
- const i = o.projectPoint(l, !1), d = a.projectPoint(l, !1);
615
- i && d ? l.distance(i) < l.distance(d) ? n.copy(i) : n.copy(d) : i ? n.copy(i) : d && n.copy(d), e(n, !1);
614
+ const i = o.projectPoint(l, !1), c = a.projectPoint(l, !1);
615
+ i && c ? l.distance(i) < l.distance(c) ? n.copy(i) : n.copy(c) : i ? n.copy(i) : c && n.copy(c), e(n, !1);
616
616
  } else {
617
- const { point: i, find: d } = t.renderManager.adsorption();
618
- n.copy(i), e(n, d);
617
+ const { point: i, find: c } = t.renderManager.adsorption();
618
+ n.copy(i), e(n, c);
619
619
  }
620
620
  });
621
621
  return {
@@ -624,19 +624,19 @@ class W extends Oe {
624
624
  },
625
625
  setBaseLine(l, i) {
626
626
  if (o = l, s = i, l && i) {
627
- const d = l.normal();
628
- a = new z(
629
- i.clone().add(d.clone().multiplyScalar(10)),
630
- i.clone().add(d.multiplyScalar(-10))
627
+ const c = l.normal();
628
+ a = new B(
629
+ i.clone().add(c.clone().multiplyScalar(10)),
630
+ i.clone().add(c.multiplyScalar(-10))
631
631
  );
632
632
  } else a = null;
633
633
  }
634
634
  };
635
635
  }
636
636
  }
637
- class yn extends W {
637
+ class yn extends R {
638
638
  static name = "DrawLine";
639
- container = new h.Group();
639
+ container = new m.Group();
640
640
  interruptKeys = ["escape"];
641
641
  withdrawalKeys = ["control", "z"];
642
642
  shortcutKeys = ["control", "l"];
@@ -651,41 +651,41 @@ class yn extends W {
651
651
  * @param next
652
652
  */
653
653
  selectPoint(e) {
654
- let t = this.parent?.findComponentByName("Editor"), n = null, s = null, o = [], a = new h.Mesh(new h.SphereGeometry(0.04), new h.MeshBasicMaterial({ color: 65280 })), r = t.domContainer.domElement, l = new Ce([], 16711935), i = new Ce([
655
- new h.Vector3(-1e4, 0, 0),
656
- new h.Vector3(1e4, 0, 0),
657
- new h.Vector3(0, -1e4, 0),
658
- new h.Vector3(0, 1e4, 0)
654
+ let t = this.parent?.findComponentByName("Editor"), n = null, s = null, o = [], a = new m.Mesh(new m.SphereGeometry(0.04), new m.MeshBasicMaterial({ color: 65280 })), r = t.domContainer.domElement, l = new ye([], 16711935), i = new ye([
655
+ new m.Vector3(-1e4, 0, 0),
656
+ new m.Vector3(1e4, 0, 0),
657
+ new m.Vector3(0, -1e4, 0),
658
+ new m.Vector3(0, 1e4, 0)
659
659
  ], 16711935);
660
- i.material = new h.LineDashedMaterial({
660
+ i.material = new m.LineDashedMaterial({
661
661
  color: 4235007,
662
662
  dashSize: 0.1,
663
663
  gapSize: 0.1,
664
664
  linewidth: 0.1
665
665
  }), this.container.add(l);
666
- const d = () => {
666
+ const c = () => {
667
667
  l.setPoint(...o, n, s), i.position.copy(s), this.container.add(i), i.computeLineDistances();
668
- }, p = new h.Vector3(), E = this.createPointerMove((f, y) => {
669
- p.set(f.x, f.y, 0), this.dispatchEvent({ type: "pointerMove", point: p }), y ? (a.position.set(f.x, f.y, 0), this.container.add(a), r.style.cursor = "none") : (a.removeFromParent(), r.style.cursor = "crosshair"), n && s && (d(), s.copy(p));
668
+ }, h = new m.Vector3(), y = this.createPointerMove((u, v) => {
669
+ h.set(u.x, u.y, 0), this.dispatchEvent({ type: "pointerMove", point: h }), v ? (a.position.set(u.x, u.y, 0), this.container.add(a), r.style.cursor = "none") : (a.removeFromParent(), r.style.cursor = "crosshair"), n && s && (c(), s.copy(h));
670
670
  });
671
671
  this.addEventRecord(
672
672
  "clear",
673
- () => E.destroy(),
673
+ () => y.destroy(),
674
674
  t.eventInput.addEventListener("codeChange", async () => {
675
675
  if (t.eventInput.isKeyDown("mouse_0")) {
676
676
  if (!n) {
677
- n = p.clone(), s = p.clone(), d(), E.setBaseLine(null, R.from(n));
677
+ n = h.clone(), s = h.clone(), c(), y.setBaseLine(null, _.from(n));
678
678
  return;
679
679
  }
680
- s = p.clone(), o.push(n.clone(), s.clone());
681
- const f = new z(R.from(n), R.from(s));
682
- E.setBaseLine(f, f.end), n.copy(s), d();
680
+ s = h.clone(), o.push(n.clone(), s.clone());
681
+ const u = new B(_.from(n), _.from(s));
682
+ y.setBaseLine(u, u.end), n.copy(s), c();
683
683
  } else if (t.eventInput.isOnlyKeyDowns(this.withdrawalKeys)) {
684
684
  if (o.length) {
685
- const { point: f } = t.renderManager.adsorption();
686
- if (o.pop(), s?.copy(f), n?.copy(o.pop()), d(), o.length >= 2) {
687
- const y = new z(R.from(o[o.length - 2]), R.from(o[o.length - 1]));
688
- E.setBaseLine(y, y.end);
685
+ const { point: u } = t.renderManager.adsorption();
686
+ if (o.pop(), s?.copy(u), n?.copy(o.pop()), c(), o.length >= 2) {
687
+ const v = new B(_.from(o[o.length - 2]), _.from(o[o.length - 1]));
688
+ y.setBaseLine(v, v.end);
689
689
  }
690
690
  }
691
691
  } else t.eventInput.isKeyDowns(this.confirmKeys) && e(o);
@@ -701,7 +701,7 @@ class yn extends W {
701
701
  end(e, t) {
702
702
  const n = [];
703
703
  for (let s = 0; s < t.length; s += 2)
704
- n.push(new z(R.from(t[s]), R.from(t[s + 1])));
704
+ n.push(new B(_.from(t[s]), _.from(t[s + 1])));
705
705
  e(n);
706
706
  }
707
707
  /** 执行完成
@@ -723,9 +723,9 @@ class yn extends W {
723
723
  return this.completed(e), e;
724
724
  }
725
725
  }
726
- class Ke extends W {
726
+ class _e extends R {
727
727
  static name = "Default";
728
- container = new h.Group();
728
+ container = new m.Group();
729
729
  onAddFromParent() {
730
730
  const e = this.editor, t = e.commandManager;
731
731
  e.container.add(this.container), t.addCommandFlow("default").add(this.start.bind(this)).addEventListener("finally", this.finally.bind(this)), t.addEventListener("startedBefore", (n) => {
@@ -733,7 +733,7 @@ class Ke extends W {
733
733
  }), t.addEventListener("finally", (n) => n.name !== "default" && t.start("default")), e.eventInput.addCancelDefaultBehavior(() => e.eventInput.isOnlyKeyDowns(["control", "g"]));
734
734
  }
735
735
  selectLines = [];
736
- selectLineObject3D = new h.Mesh();
736
+ selectLineObject3D = new m.Mesh();
737
737
  /** 添加选择的线段
738
738
  * @param lineSegment
739
739
  */
@@ -776,46 +776,46 @@ class Ke extends W {
776
776
  * @param next
777
777
  */
778
778
  start() {
779
- const e = this.editor, t = e.eventInput, n = new h.Mesh(), s = e.domContainer.domElement;
779
+ const e = this.editor, t = e.eventInput, n = new m.Mesh(), s = e.domContainer.domElement;
780
780
  let o = null;
781
- n.position.z = 1e-3, this.selectLineObject3D.position.z = n.position.z + 1e-3, n.material = new h.MeshBasicMaterial({ color: 55561 });
781
+ n.position.z = 1e-3, this.selectLineObject3D.position.z = n.position.z + 1e-3, n.material = new m.MeshBasicMaterial({ color: 55561 });
782
782
  const a = () => {
783
- const r = e.pointerPosition.clone(), l = e.pointerPosition.clone(), i = new h.Mesh();
784
- this.container.add(i), i.position.z = 0.05, i.material = new h.MeshBasicMaterial({
783
+ const r = e.pointerPosition.clone(), l = e.pointerPosition.clone(), i = new m.Mesh();
784
+ this.container.add(i), i.position.z = 0.05, i.material = new m.MeshBasicMaterial({
785
785
  color: 16777215,
786
786
  transparent: !0,
787
787
  opacity: 0.5
788
788
  });
789
- const d = () => {
790
- const f = Math.min(r.x, l.x), y = Math.max(r.x, l.x), C = Math.min(r.y, l.y), v = Math.max(r.y, l.y), w = [
791
- f,
792
- v,
793
- 0,
794
- y,
795
- C,
789
+ const c = () => {
790
+ const u = Math.min(r.x, l.x), v = Math.max(r.x, l.x), g = Math.min(r.y, l.y), E = Math.max(r.y, l.y), x = [
791
+ u,
792
+ E,
796
793
  0,
797
- y,
798
794
  v,
795
+ g,
799
796
  0,
800
- f,
801
797
  v,
798
+ E,
802
799
  0,
803
- f,
804
- C,
800
+ u,
801
+ E,
805
802
  0,
806
- y,
807
- C,
803
+ u,
804
+ g,
805
+ 0,
806
+ v,
807
+ g,
808
808
  0
809
809
  ];
810
- i.geometry = e.renderManager.createGeometry({ position: w }, w.length / 3);
811
- }, p = () => {
812
- l.copy(e.pointerPosition), d();
813
- }, E = () => {
814
- document.removeEventListener("mousemove", p), document.removeEventListener("mouseup", E), i.removeFromParent();
815
- const f = Math.min(r.x, l.x), y = Math.max(r.x, l.x), C = Math.min(r.y, l.y), v = Math.max(r.y, l.y), w = new Me(f, y, C, v), g = e.renderManager.quadtree.queryBox(w);
816
- this.removeSelectLineAll(), g.forEach((S) => this.addSelectLine(S.line)), this.updateSelectLinesGeometry();
810
+ i.geometry = e.renderManager.createGeometry({ position: x }, x.length / 3);
811
+ }, h = () => {
812
+ l.copy(e.pointerPosition), c();
813
+ }, y = () => {
814
+ document.removeEventListener("mousemove", h), document.removeEventListener("mouseup", y), i.removeFromParent();
815
+ const u = Math.min(r.x, l.x), v = Math.max(r.x, l.x), g = Math.min(r.y, l.y), E = Math.max(r.y, l.y), x = new Ye(u, v, g, E), D = e.renderManager.quadtree.queryBox(x);
816
+ this.removeSelectLineAll(), D.forEach((z) => this.addSelectLine(z.line)), this.updateSelectLinesGeometry();
817
817
  };
818
- document.addEventListener("mousemove", p), document.addEventListener("mouseup", E);
818
+ document.addEventListener("mousemove", h), document.addEventListener("mouseup", y);
819
819
  };
820
820
  this.addEventRecord(
821
821
  "clear",
@@ -854,7 +854,7 @@ class Ke extends W {
854
854
  this.canceEventRecord("clear"), this.removeSelectLineAll(), this.updateSelectLinesGeometry();
855
855
  }
856
856
  }
857
- class wn extends tt {
857
+ class wn extends Xe {
858
858
  list = [];
859
859
  rollbacklist = [];
860
860
  revokeRollbacklist = [];
@@ -882,7 +882,7 @@ class wn extends tt {
882
882
  return this.revokeRollbacklist.push(e), this;
883
883
  }
884
884
  }
885
- class bn extends tt {
885
+ class bn extends Xe {
886
886
  commandFlowMap = /* @__PURE__ */ new Map();
887
887
  lock = !1;
888
888
  abortController = null;
@@ -993,18 +993,18 @@ const xn = "", es = new h.TextureLoader(), ts = es.load($n);
1039
- class ns extends Oe {
1038
+ }, Symbol.toStringTag, { value: "Module" })), $n = "", es = new m.TextureLoader(), ts = es.load($n);
1039
+ class ns extends Ae {
1040
1040
  static name = "RenderManager";
1041
- container = new h.Group();
1041
+ container = new m.Group();
1042
1042
  lines = [];
1043
- pointVirtualGrid = new Ge();
1044
- quadtree = new Le(new Me());
1045
- verticalReferenceLineFlag = new h.Mesh(new h.PlaneGeometry(0.3, 0.3), new h.MeshBasicMaterial({ map: ts, color: 58111, transparent: !0 }));
1043
+ pointVirtualGrid = new Fe();
1044
+ quadtree = new ze(new Ye());
1045
+ verticalReferenceLineFlag = new m.Mesh(new m.PlaneGeometry(0.3, 0.3), new m.MeshBasicMaterial({ map: ts, color: 58111, transparent: !0 }));
1046
1046
  onAddFromParent() {
1047
1047
  const e = this.dxfLineModel;
1048
- this.editor.container.add(this.container), this.editor.container.add(e.dxfModelGroup), e.dxfLineModel.material = new h.LineBasicMaterial({
1048
+ this.editor.container.add(this.container), this.editor.container.add(e.dxfModelGroup), e.dxfLineModel.material = new m.LineBasicMaterial({
1049
1049
  transparent: !0,
1050
1050
  opacity: 0.5,
1051
1051
  color: 16777215
@@ -1062,9 +1062,9 @@ class ns extends Oe {
1062
1062
  return;
1063
1063
  } else
1064
1064
  this.updatedMode = "dxf";
1065
- this.pointVirtualGrid = new Ge();
1065
+ this.pointVirtualGrid = new Fe();
1066
1066
  const e = this.dxf.box.clone().expansion(Math.max(this.dxf.box.width, this.dxf.box.height) * 2);
1067
- (e.width === 0 || e.height === 0) && e.set(-200, -200, 200, 200), this.quadtree = new Le(e), this.lines.length = 0, this.dxf.lineSegments.forEach((t) => {
1067
+ (e.width === 0 || e.height === 0) && e.set(-200, -200, 200, 200), this.quadtree = new ze(e), this.lines.length = 0, this.dxf.lineSegments.forEach((t) => {
1068
1068
  t.userData.isDoor || this.addLine(t.clone());
1069
1069
  }), this.dxf.doorLineSegment.forEach((t) => {
1070
1070
  const n = t.clone();
@@ -1131,8 +1131,8 @@ class ns extends Oe {
1131
1131
  if (o.points.forEach((a) => {
1132
1132
  o.userData.isDoor ? n.push(a.x, a.y, 0) : t.push(a.x, a.y, 0);
1133
1133
  }), o.userData.isWindow && o.userData.drawWindow && o.userData.drawWindow.forEach(({ width: a, p: r }) => {
1134
- const l = R.from(r), i = o.direction(), d = l.clone().add(i.clone().multiplyScalar(a * 0.5)), p = l.clone().add(i.clone().multiplyScalar(-a * 0.5));
1135
- s.push(d.x, d.y, 1e-3), s.push(p.x, p.y, 1e-3);
1134
+ const l = _.from(r), i = o.direction(), c = l.clone().add(i.clone().multiplyScalar(a * 0.5)), h = l.clone().add(i.clone().multiplyScalar(-a * 0.5));
1135
+ s.push(c.x, c.y, 1e-3), s.push(h.x, h.y, 1e-3);
1136
1136
  }), o.userData.isVerticalReferenceLine) {
1137
1137
  const a = o.center;
1138
1138
  this.verticalReferenceLineFlag.position.set(a.x, a.y, 0), this.container.add(this.verticalReferenceLineFlag);
@@ -1156,9 +1156,9 @@ class ns extends Oe {
1156
1156
  * @returns
1157
1157
  */
1158
1158
  adsorption(e = 0.04, t = this.pointVirtualGrid, n = this.quadtree) {
1159
- const s = this.parent?.findComponentByName("Editor"), o = R.from(s.pointerPosition), a = t.queryCircle(o, e).sort((l, i) => l.point.distance(o) - i.point.distance(o));
1159
+ const s = this.parent?.findComponentByName("Editor"), o = _.from(s.pointerPosition), a = t.queryCircle(o, e).sort((l, i) => l.point.distance(o) - i.point.distance(o));
1160
1160
  if (a.length) return {
1161
- point: new h.Vector3(a[0].point.x, a[0].point.y, 0),
1161
+ point: new m.Vector3(a[0].point.x, a[0].point.y, 0),
1162
1162
  find: !0,
1163
1163
  mode: "point",
1164
1164
  line: a[0].userData
@@ -1166,15 +1166,15 @@ class ns extends Oe {
1166
1166
  let r = n.queryCircle(o, e);
1167
1167
  if (r.length) {
1168
1168
  let l = r.map((i) => i.line.projectPoint(o));
1169
- return l.sort((i, d) => i && d ? i.distance(o) - d.distance(o) : 0), r = r.filter((i, d) => !!l[d]), l = l.filter((i, d) => !!l[d]), {
1170
- point: new h.Vector3(l[0].x, l[0].y, 0),
1169
+ return l.sort((i, c) => i && c ? i.distance(o) - c.distance(o) : 0), r = r.filter((i, c) => !!l[c]), l = l.filter((i, c) => !!l[c]), {
1170
+ point: new m.Vector3(l[0].x, l[0].y, 0),
1171
1171
  find: !0,
1172
1172
  mode: "line",
1173
1173
  line: r[0].line
1174
1174
  };
1175
1175
  }
1176
1176
  return {
1177
- point: new h.Vector3(s.pointerPosition.x, s.pointerPosition.y, 0),
1177
+ point: new m.Vector3(s.pointerPosition.x, s.pointerPosition.y, 0),
1178
1178
  find: !1
1179
1179
  };
1180
1180
  }
@@ -1182,9 +1182,9 @@ class ns extends Oe {
1182
1182
  * @param rectangle
1183
1183
  */
1184
1184
  createGeometry(e, t) {
1185
- const n = new h.BufferGeometry();
1185
+ const n = new m.BufferGeometry();
1186
1186
  return Object.keys(e).forEach((s) => {
1187
- n.setAttribute("position", new h.BufferAttribute(new Float32Array(e[s]), e[s].length / t));
1187
+ n.setAttribute("position", new m.BufferAttribute(new Float32Array(e[s]), e[s].length / t));
1188
1188
  }), n;
1189
1189
  }
1190
1190
  /**
@@ -1247,9 +1247,9 @@ class ns extends Oe {
1247
1247
  return this.parent?.findComponentByName("DxfLineModel");
1248
1248
  }
1249
1249
  }
1250
- class ss extends W {
1250
+ class ss extends R {
1251
1251
  static name = "DrawDoorLine";
1252
- container = new h.Group();
1252
+ container = new m.Group();
1253
1253
  interruptKeys = ["escape"];
1254
1254
  shortcutKeys = ["control", "m"];
1255
1255
  commandName = "draw-door-line";
@@ -1266,13 +1266,13 @@ class ss extends W {
1266
1266
  * @param next
1267
1267
  */
1268
1268
  selectPoint(e) {
1269
- let t = this.parent?.findComponentByName("Editor"), n = null, s = new h.Mesh(new h.SphereGeometry(0.04), new h.MeshBasicMaterial({ color: 65280 })), o = new Ce([], 16711935), a = new Ce([
1270
- new h.Vector3(-1e4, 0, 0),
1271
- new h.Vector3(1e4, 0, 0),
1272
- new h.Vector3(0, -1e4, 0),
1273
- new h.Vector3(0, 1e4, 0)
1269
+ let t = this.parent?.findComponentByName("Editor"), n = null, s = new m.Mesh(new m.SphereGeometry(0.04), new m.MeshBasicMaterial({ color: 65280 })), o = new ye([], 16711935), a = new ye([
1270
+ new m.Vector3(-1e4, 0, 0),
1271
+ new m.Vector3(1e4, 0, 0),
1272
+ new m.Vector3(0, -1e4, 0),
1273
+ new m.Vector3(0, 1e4, 0)
1274
1274
  ], 16711935);
1275
- a.material = new h.LineDashedMaterial({
1275
+ a.material = new m.LineDashedMaterial({
1276
1276
  color: 4235007,
1277
1277
  dashSize: 0.1,
1278
1278
  gapSize: 0.1,
@@ -1307,22 +1307,22 @@ class ss extends W {
1307
1307
  end(e, t) {
1308
1308
  const n = [];
1309
1309
  for (let s = 0; s < t.length; s += 2) {
1310
- const o = R.from(t[s]), a = R.from(t[s + 1]), r = this.renderManager.quadtree.queryCircle(o, 1e-3)[0].line, l = this.renderManager.quadtree.queryCircle(a, 1e-3)[0].line;
1310
+ const o = _.from(t[s]), a = _.from(t[s + 1]), r = this.renderManager.quadtree.queryCircle(o, 1e-3)[0].line, l = this.renderManager.quadtree.queryCircle(a, 1e-3)[0].line;
1311
1311
  let i = null;
1312
1312
  r === l && (i = {
1313
1313
  oldLine: r,
1314
- newLine1: new z(
1314
+ newLine1: new B(
1315
1315
  r.start,
1316
1316
  r.start.distance(o) < r.start.distance(a) ? o.clone() : a.clone()
1317
1317
  ),
1318
- newLine2: new z(
1318
+ newLine2: new B(
1319
1319
  r.end,
1320
1320
  r.end.distance(o) < r.end.distance(a) ? o.clone() : a.clone()
1321
1321
  )
1322
1322
  });
1323
- const d = new z(o, a);
1324
- d.userData.isDoor = !0, d.userData.doorDirectConnection = !0, n.push({
1325
- line: d,
1323
+ const c = new B(o, a);
1324
+ c.userData.isDoor = !0, c.userData.doorDirectConnection = !0, n.push({
1325
+ line: c,
1326
1326
  option: i
1327
1327
  });
1328
1328
  }
@@ -1351,9 +1351,9 @@ class ss extends W {
1351
1351
  return this.completed(e), e;
1352
1352
  }
1353
1353
  }
1354
- class os extends W {
1354
+ class os extends R {
1355
1355
  static name = "DrawWindow";
1356
- container = new h.Group();
1356
+ container = new m.Group();
1357
1357
  interruptKeys = ["escape"];
1358
1358
  shortcutKeys = ["control", "q"];
1359
1359
  commandName = "draw-window-line";
@@ -1366,7 +1366,7 @@ class os extends W {
1366
1366
  * @param next
1367
1367
  */
1368
1368
  selectPointStart(e) {
1369
- let t = null, n = new h.Mesh(new h.SphereGeometry(0.04), new h.MeshBasicMaterial({ color: 16711935 })), s = null;
1369
+ let t = null, n = new m.Mesh(new m.SphereGeometry(0.04), new m.MeshBasicMaterial({ color: 16711935 })), s = null;
1370
1370
  this.addEventRecord("selectPointStart").add(this.editor.addEventListener("pointerPositionChange", () => {
1371
1371
  const { point: o, line: a, find: r } = this.editor.renderManager.adsorption();
1372
1372
  this.dispatchEvent({ type: "pointerMove", point: o }), r ? (this.domElement.style.cursor = "none", n.position.copy(o), s = a, t = o.clone(), this.container.add(n)) : (this.domElement.style.cursor = "no-drop", t = null, n.removeFromParent());
@@ -1378,7 +1378,7 @@ class os extends W {
1378
1378
  * @param next
1379
1379
  */
1380
1380
  selectPointEnd(e, { point: t, line: n }) {
1381
- let s = null, o = new h.Mesh(new h.SphereGeometry(0.04), new h.MeshBasicMaterial({ color: 16711935 }));
1381
+ let s = null, o = new m.Mesh(new m.SphereGeometry(0.04), new m.MeshBasicMaterial({ color: 16711935 }));
1382
1382
  this.addEventRecord("clear").add(() => o.removeFromParent()).add(this.editor.addEventListener("pointerPositionChange", () => {
1383
1383
  const { point: a, find: r, line: l } = this.editor.renderManager.adsorption();
1384
1384
  this.dispatchEvent({ type: "pointerMove", point: a }), r && l === n ? (this.domElement.style.cursor = "none", o.position.copy(a), s = a.clone(), this.container.add(o)) : (this.domElement.style.cursor = "no-drop", s = null, o.removeFromParent());
@@ -1392,8 +1392,8 @@ class os extends W {
1392
1392
  * @param points
1393
1393
  */
1394
1394
  end(e, { start: t, end: n, line: s }) {
1395
- const o = new z(R.from(t), R.from(n)), a = o.center, r = o.length(), l = {
1396
- p: new h.Vector3(a.x, a.y, 0),
1395
+ const o = new B(_.from(t), _.from(n)), a = o.center, r = o.length(), l = {
1396
+ p: new m.Vector3(a.x, a.y, 0),
1397
1397
  width: r,
1398
1398
  full: Math.abs(r - s.length()) < 0.01
1399
1399
  };
@@ -1423,9 +1423,9 @@ class os extends W {
1423
1423
  return this.completed(e), e;
1424
1424
  }
1425
1425
  }
1426
- class oe extends W {
1426
+ class X extends R {
1427
1427
  static name = "VerticalCorrection";
1428
- container = new h.Group();
1428
+ container = new m.Group();
1429
1429
  shortcutKeys = ["control", "c"];
1430
1430
  shortcutKeys2 = ["control", "shift", "c"];
1431
1431
  shortcutKeys3 = ["shift", "c"];
@@ -1434,18 +1434,18 @@ class oe extends W {
1434
1434
  axisAlignment = !1;
1435
1435
  onAddFromParent(e) {
1436
1436
  super.onAddFromParent(e), this.editor.container.add(this.container), this.container.position.z = 1e-3;
1437
- const t = this.commandManager.addCommandFlow(oe.commandName).add(this.createInterrupt()).add(this.constraint.bind(this)).add(this.verticalCorrection.bind(this)).addRollback(this.rollback.bind(this)).addRevokeRollback(this.revokeRollback.bind(this));
1437
+ const t = this.commandManager.addCommandFlow(X.commandName).add(this.createInterrupt()).add(this.constraint.bind(this)).add(this.verticalCorrection.bind(this)).addRollback(this.rollback.bind(this)).addRevokeRollback(this.revokeRollback.bind(this));
1438
1438
  t.addEventListener("finally", this.createFinally()), t.addEventListener("completed", (n) => this.completed(n.data)), t.addEventListener("started", () => {
1439
1439
  !this.eventInput.isOnlyKeyDowns(this.shortcutKeys) && !this.eventInput.isOnlyKeyDowns(this.shortcutKeys2) && (this.recursion = !1);
1440
1440
  }), this.eventInput.addEventListener("codeChange", async () => {
1441
- this.eventInput.isOnlyKeyDowns(this.shortcutKeys) ? (this.recursion = !1, this.axisAlignment = !1, this.commandManager.start(oe.commandName, [...this.default.selectLines])) : this.eventInput.isOnlyKeyDowns(this.shortcutKeys2) ? (this.recursion = !0, this.axisAlignment = !1, this.commandManager.start(oe.commandName, [...this.default.selectLines])) : this.eventInput.isOnlyKeyDowns(this.shortcutKeys3) && (this.axisAlignment = !0, this.commandManager.start(oe.commandName, [...this.default.selectLines]));
1441
+ this.eventInput.isOnlyKeyDowns(this.shortcutKeys) ? (this.recursion = !1, this.axisAlignment = !1, this.commandManager.start(X.commandName, [...this.default.selectLines])) : this.eventInput.isOnlyKeyDowns(this.shortcutKeys2) ? (this.recursion = !0, this.axisAlignment = !1, this.commandManager.start(X.commandName, [...this.default.selectLines])) : this.eventInput.isOnlyKeyDowns(this.shortcutKeys3) && (this.axisAlignment = !0, this.commandManager.start(X.commandName, [...this.default.selectLines]));
1442
1442
  }), this.eventInput.addCancelDefaultBehavior(() => this.eventInput.isOnlyKeyDowns(this.shortcutKeys) || this.eventInput.isOnlyKeyDowns(this.shortcutKeys2));
1443
1443
  }
1444
1444
  /**
1445
1445
  * 进入命令约束
1446
1446
  */
1447
1447
  constraint(e, t) {
1448
- Array.isArray(t) ? t.length !== 1 ? (B({ message: "请选择一条线段", type: "warning" }), this.cancel()) : e(t) : (B({ message: "进入命令失败", type: "warning" }), this.cancel());
1448
+ Array.isArray(t) ? t.length !== 1 ? (L({ message: "请选择一条线段", type: "warning" }), this.cancel()) : e(t) : (L({ message: "进入命令失败", type: "warning" }), this.cancel());
1449
1449
  }
1450
1450
  /**
1451
1451
  * @param line0
@@ -1467,42 +1467,42 @@ class oe extends W {
1467
1467
  if (e.userData.setLinePointUUid === a) return [];
1468
1468
  e.userData.setLinePointUUid = a;
1469
1469
  let r = [], l = [];
1470
- (s === "start" || s === "all") && (r = this.renderManager.pointVirtualGrid.queryPoint(e.start).filter((E) => E.userData !== e)), (s === "end" || s === "all") && (l = this.renderManager.pointVirtualGrid.queryPoint(e.end).filter((E) => E.userData !== e));
1470
+ (s === "start" || s === "all") && (r = this.renderManager.pointVirtualGrid.queryPoint(e.start).filter((y) => y.userData !== e)), (s === "end" || s === "all") && (l = this.renderManager.pointVirtualGrid.queryPoint(e.end).filter((y) => y.userData !== e));
1471
1471
  const i = e.clone();
1472
- let d = "";
1473
- t && (e.start.equal(t) || (d = "start"), o.push({
1472
+ let c = "";
1473
+ t && (e.start.equal(t) || (c = "start"), o.push({
1474
1474
  point: e.start,
1475
1475
  oldPoint: e.start.clone(),
1476
1476
  newPoint: t,
1477
1477
  line: e
1478
- }), e.start.copy(t)), n && (e.end.equal(n) || (d = d === "start" ? "all" : "end"), o.push({
1478
+ }), e.start.copy(t)), n && (e.end.equal(n) || (c = c === "start" ? "all" : "end"), o.push({
1479
1479
  point: e.end,
1480
1480
  oldPoint: e.end.clone(),
1481
1481
  newPoint: n,
1482
1482
  line: e
1483
1483
  }), e.end.copy(n));
1484
- const p = (E, f, y) => {
1485
- E.forEach((C) => {
1486
- const { point: v, userData: w } = C, g = w.start === v ? "start" : "end";
1487
- if (w.directionEqual(i))
1488
- if (g === "start") {
1489
- const S = e.projectPoint(w.end, !1);
1490
- if (S) return this.setLinePoint(w, f, S, "end", o, a);
1484
+ const h = (y, u, v) => {
1485
+ y.forEach((g) => {
1486
+ const { point: E, userData: x } = g, D = x.start === E ? "start" : "end";
1487
+ if (x.directionEqual(i))
1488
+ if (D === "start") {
1489
+ const z = e.projectPoint(x.end, !1);
1490
+ if (z) return this.setLinePoint(x, u, z, "end", o, a);
1491
1491
  } else {
1492
- const S = e.projectPoint(w.start, !1);
1493
- if (S) return this.setLinePoint(w, S, f, "start", o, a);
1492
+ const z = e.projectPoint(x.start, !1);
1493
+ if (z) return this.setLinePoint(x, z, u, "start", o, a);
1494
1494
  }
1495
- (d === "all" || y === d) && this.setLinePoint(
1496
- w,
1497
- w.start === v ? f : w.start,
1498
- w.end === v ? f : w.end,
1499
- w.start === v ? "end" : "start",
1495
+ (c === "all" || v === c) && this.setLinePoint(
1496
+ x,
1497
+ x.start === E ? u : x.start,
1498
+ x.end === E ? u : x.end,
1499
+ x.start === E ? "end" : "start",
1500
1500
  o,
1501
1501
  a
1502
1502
  );
1503
1503
  });
1504
1504
  };
1505
- return p(r, e.start, "start"), p(l, e.end, "end"), [...r, ...l];
1505
+ return h(r, e.start, "start"), h(l, e.end, "end"), [...r, ...l];
1506
1506
  }
1507
1507
  /** 修正2
1508
1508
  * 第一步:确定需要修复的线段
@@ -1516,46 +1516,46 @@ class oe extends W {
1516
1516
  */
1517
1517
  correction(e, t = [], n = /* @__PURE__ */ new Set()) {
1518
1518
  n.add(e);
1519
- const s = this.renderManager.quadtree.queryLineSegment(e).filter(({ line: i }) => !(i === e || i.userData.isDoor || n.has(i))).map((i) => i.line), o = e.direction(), [a, r] = s.reduce((i, d) => {
1520
- const [p, E] = i;
1521
- return d.sameEndpoint(e) ? p.push(d) : E.push(d), i;
1519
+ const s = this.renderManager.quadtree.queryLineSegment(e).filter(({ line: i }) => !(i === e || i.userData.isDoor || n.has(i))).map((i) => i.line), o = e.direction(), [a, r] = s.reduce((i, c) => {
1520
+ const [h, y] = i;
1521
+ return c.sameEndpoint(e) ? h.push(c) : y.push(c), i;
1522
1522
  }, [[], []]);
1523
1523
  a.forEach((i) => {
1524
- const d = i.direction(), p = o.angleBetween(d, "angle");
1525
- if (Math.abs(90 - p) > 45) return !1;
1526
- const f = e.sameEndpointAsStart(i) ? e.start : e.end, y = i.sameEndpointAsStart(e) ? i.end : i.start, C = new z(
1527
- y.clone().add(o.clone().multiplyScalar(1)),
1528
- y.clone().add(o.clone().multiplyScalar(-1))
1529
- ), v = C.projectPoint(f, !1);
1530
- if (v) {
1531
- const w = [];
1524
+ const c = i.direction(), h = o.angleBetween(c, "angle");
1525
+ if (Math.abs(90 - h) > 45) return !1;
1526
+ const u = e.sameEndpointAsStart(i) ? e.start : e.end, v = i.sameEndpointAsStart(e) ? i.end : i.start, g = new B(
1527
+ v.clone().add(o.clone().multiplyScalar(1)),
1528
+ v.clone().add(o.clone().multiplyScalar(-1))
1529
+ ), E = g.projectPoint(u, !1);
1530
+ if (E) {
1531
+ const x = [];
1532
1532
  this.setLinePoint(
1533
1533
  i,
1534
- i.start === y ? v : i.start,
1535
- i.end === y ? v : i.end,
1536
- i.start === y ? "start" : "end",
1537
- w
1538
- ), t.push(w);
1534
+ i.start === v ? E : i.start,
1535
+ i.end === v ? E : i.end,
1536
+ i.start === v ? "start" : "end",
1537
+ x
1538
+ ), t.push(x);
1539
1539
  }
1540
1540
  return n.add(i), !1;
1541
1541
  }), o.copy(e.direction());
1542
- const l = (i, d, p) => {
1543
- const E = e.projectPoint(d);
1544
- if (E) i.copy(E);
1542
+ const l = (i, c, h) => {
1543
+ const y = e.projectPoint(c);
1544
+ if (y) i.copy(y);
1545
1545
  else {
1546
- const f = new z(
1547
- d.clone().add(o.clone().multiplyScalar(1)),
1548
- d.clone().add(o.clone().multiplyScalar(-1))
1549
- ), y = f.projectPoint(i, !1);
1550
- if (y) {
1551
- const C = [];
1546
+ const u = new B(
1547
+ c.clone().add(o.clone().multiplyScalar(1)),
1548
+ c.clone().add(o.clone().multiplyScalar(-1))
1549
+ ), v = u.projectPoint(i, !1);
1550
+ if (v) {
1551
+ const g = [];
1552
1552
  this.setLinePoint(
1553
- p,
1554
- p.start === d ? y : p.start,
1555
- p.end === d ? y : p.end,
1556
- p.start === d ? "start" : "end",
1557
- C
1558
- ), t.push(C);
1553
+ h,
1554
+ h.start === c ? v : h.start,
1555
+ h.end === c ? v : h.end,
1556
+ h.start === c ? "start" : "end",
1557
+ g
1558
+ ), t.push(g);
1559
1559
  }
1560
1560
  }
1561
1561
  };
@@ -1565,23 +1565,23 @@ class oe extends W {
1565
1565
  else if (e.containsPoint(i.end))
1566
1566
  l(i.end, i.start, i);
1567
1567
  else {
1568
- const d = e.getIntersection(i);
1569
- if (d) {
1570
- const p = new z(
1568
+ const c = e.getIntersection(i);
1569
+ if (c) {
1570
+ const h = new B(
1571
1571
  i.start.clone().add(o.clone().multiplyScalar(1)),
1572
1572
  i.start.clone().add(o.clone().multiplyScalar(-1))
1573
- ), E = p.projectPoint(d, !1);
1574
- if (E) {
1575
- const C = [];
1576
- this.setLinePoint(i, E, i.end, "start", C), t.push(C);
1573
+ ), y = h.projectPoint(c, !1);
1574
+ if (y) {
1575
+ const g = [];
1576
+ this.setLinePoint(i, y, i.end, "start", g), t.push(g);
1577
1577
  }
1578
- const f = new z(
1578
+ const u = new B(
1579
1579
  i.end.clone().add(o.clone().multiplyScalar(1)),
1580
1580
  i.end.clone().add(o.clone().multiplyScalar(-1))
1581
- ), y = f.projectPoint(d, !1);
1582
- if (y) {
1583
- const C = [];
1584
- this.setLinePoint(i, i.start, y, "end", C), t.push(C);
1581
+ ), v = u.projectPoint(c, !1);
1582
+ if (v) {
1583
+ const g = [];
1584
+ this.setLinePoint(i, i.start, v, "end", g), t.push(g);
1585
1585
  }
1586
1586
  }
1587
1587
  }
@@ -1592,149 +1592,8 @@ class oe extends W {
1592
1592
  * @returns
1593
1593
  */
1594
1594
  axisAlignmentCorrection(e) {
1595
- function t(v, w) {
1596
- const g = [v], S = [], A = [];
1597
- for (let M = 0; M < w.length; M++) {
1598
- const u = w[M];
1599
- if (v !== u) {
1600
- if (u.userData.isDoor) {
1601
- A.push(u);
1602
- continue;
1603
- }
1604
- if (u.parallel(v, 45)) {
1605
- const D = Math.atan2(u.end.y - u.start.y, u.end.x - u.start.x);
1606
- let m = Math.atan2(v.end.y - v.start.y, v.end.x - v.start.x) - D;
1607
- for (; m > Math.PI; ) m -= 2 * Math.PI;
1608
- for (; m < -Math.PI; ) m += 2 * Math.PI;
1609
- const I = u.center;
1610
- u.start.rotate(I, m), u.end.rotate(I, m), g.push(u);
1611
- } else {
1612
- const D = Math.atan2(u.end.y - u.start.y, u.end.x - u.start.x), b = Math.atan2(v.end.y - v.start.y, v.end.x - v.start.x);
1613
- let m = b + Math.PI / 2 - D, I = b - Math.PI / 2 - D;
1614
- for (; m > Math.PI; ) m -= 2 * Math.PI;
1615
- for (; m < -Math.PI; ) m += 2 * Math.PI;
1616
- for (; I > Math.PI; ) I -= 2 * Math.PI;
1617
- for (; I < -Math.PI; ) I += 2 * Math.PI;
1618
- const _ = Math.abs(m) < Math.abs(I) ? m : I, j = u.center;
1619
- u.start.rotate(j, _), u.end.rotate(j, _), S.push(u);
1620
- }
1621
- }
1622
- }
1623
- return { parallelLines: g, verticalLines: S, doorLines: A };
1624
- }
1625
- function n(v, w, g, S = 0.3, A = 0.06) {
1626
- const M = [];
1627
- v.forEach((b) => {
1628
- const m = g.projectPoint(b.start, !1);
1629
- m && (m.userData = b, M.push(m));
1630
- }), M.sort((b, m) => m.distance(g.start) - b.distance(g.start));
1631
- const u = [], D = [];
1632
- for (let b = 0; b < M.length; b++) {
1633
- const m = M[b];
1634
- if (b === 0) {
1635
- D.push(m);
1636
- continue;
1637
- }
1638
- M[b - 1].distance(m) < A || (u.push([...D]), D.length = 0), D.push(m), b === M.length - 1 && u.push(D);
1639
- }
1640
- return u.flatMap((b) => {
1641
- const m = b.flatMap((N) => {
1642
- const G = N.userData;
1643
- return G.points.map((Y) => {
1644
- const V = w.projectPoint(Y, !1);
1645
- return V.userData = G, V;
1646
- });
1647
- });
1648
- m.sort((N, G) => N.distance(w.start) - G.distance(w.start));
1649
- const I = /* @__PURE__ */ new Map(), _ = [], j = [];
1650
- return m.forEach((N, G) => {
1651
- I.size === 0 && G > 0 && m[G - 1].distance(N) > S && (_.push([...j]), j.length = 0), I.set(N.userData, (I.get(N.userData) ?? 0) + 1);
1652
- for (const Y of I.values()) if (Y !== 2) return;
1653
- j.push(...I.keys()), I.clear();
1654
- }), _.push([...j]), _;
1655
- });
1656
- }
1657
- function s(v, w = 0.1) {
1658
- return v.map((g) => {
1659
- if (g.length === 0) return;
1660
- if (g.length === 1) return g[0];
1661
- const S = [];
1662
- g.forEach((V) => {
1663
- S.push(V.start.clone(), V.end.clone());
1664
- });
1665
- const A = g[0].direction().normalize();
1666
- let M = 1 / 0, u = -1 / 0, D = 0, b = 0;
1667
- S.forEach((V) => {
1668
- const k = V.x * A.x + V.y * A.y;
1669
- M = Math.min(M, k), u = Math.max(u, k), D += V.x, b += V.y;
1670
- });
1671
- const m = new R(D / S.length, b / S.length), I = m.x * A.x + m.y * A.y, _ = new R(m.x + (M - I) * A.x, m.y + (M - I) * A.y), j = new R(m.x + (u - I) * A.x, m.y + (u - I) * A.y), N = new z(_, j), G = g[0].normal().normalize();
1672
- M = 1 / 0, u = -1 / 0, S.forEach((V) => {
1673
- const k = V.x * G.x + V.y * G.y;
1674
- M = Math.min(M, k), u = Math.max(u, k);
1675
- });
1676
- const Y = u - M;
1677
- return Y >= w && (N.userData.wallWidth = Y), N;
1678
- }).filter((g) => !!g);
1679
- }
1680
- function o(v, w = 0.2) {
1681
- const g = new Le(Me.fromByLineSegment(...v)), S = /* @__PURE__ */ new Map();
1682
- v.forEach((M) => {
1683
- S.set(M, { line: M, userData: void 0 }), g.insert(S.get(M));
1684
- });
1685
- const A = new z();
1686
- for (let M = 0; M < v.length; M++) {
1687
- const u = v[M], D = u.direction().multiplyScalar(w), [b, m] = u.points.map((I) => {
1688
- A.set(I, I), A.start.add(D), A.end.add(D.multiplyScalar(-1));
1689
- const _ = /* @__PURE__ */ new Map(), j = g.queryRect(A.expandToRectangle(0.05, "bothSides")).filter((N) => N.line !== u).map((N) => {
1690
- const G = N.line.getIntersection(A);
1691
- return _.set(N.line, G), N.line;
1692
- }).sort((N, G) => {
1693
- const Y = _.get(N), V = _.get(G);
1694
- return Y && V ? Y.distance(I) - V.distance(I) : 0;
1695
- });
1696
- return j.length ? _.get(j[0]) : void 0;
1697
- });
1698
- if (b && m)
1699
- if (b.equal(m)) {
1700
- const I = u.start.distance(b), _ = u.end.distance(m);
1701
- I < _ ? u.directionMove(u.start.direction(u.end), I) : u.directionMove(u.end.direction(u.start), _);
1702
- } else
1703
- u.start.copy(b), u.end.copy(m);
1704
- else b ? u.start.copy(b) : m && u.end.copy(m);
1705
- g.remove(S.get(u)), g.insert(S.get(u));
1706
- }
1707
- return v.filter((M) => M.length() > 1e-3);
1708
- }
1709
- function a(v) {
1710
- const w = new Le(Me.fromByLineSegment(...v));
1711
- return v.forEach((g) => w.insert({ line: g, userData: void 0 })), v.flatMap((g) => {
1712
- const S = w.queryLineSegment(g, !0).map((A) => {
1713
- if (A.line === g) return;
1714
- const M = A.line.getIntersection(g);
1715
- if (!(!M || g.start.equal(M) || g.end.equal(M)))
1716
- return M;
1717
- }).filter((A) => !!A);
1718
- return S.length ? (g = g.clone(), S.sort((M, u) => g.start.distance(M) - g.start.distance(u)), [...S.map((M) => {
1719
- const u = g.clone();
1720
- return u.set(g.start.clone(), M), g.start.copy(M), u;
1721
- }), g]) : g;
1722
- }).filter((g) => g.length() > 0.1);
1723
- }
1724
- const { parallelLines: r, verticalLines: l } = t(e, this.renderManager.lines.map((v) => v.clone())), i = e.normal(), d = e.center, p = e.direction(), E = new z(
1725
- d.clone().add(i.clone().multiplyScalar(-1e3)),
1726
- d.clone().add(i.clone().multiplyScalar(1e3))
1727
- ), f = new z(
1728
- d.clone().add(p.clone().multiplyScalar(-1e3)),
1729
- d.clone().add(p.clone().multiplyScalar(1e3))
1730
- );
1731
- let y = s([
1732
- ...n.call(this, r, f, E),
1733
- ...n.call(this, l, E, f)
1734
- ]);
1735
- y = o.call(this, y), y = o.call(this, y), y = a.call(this, y);
1736
- const C = [...this.renderManager.lines];
1737
- return { newLines: y, oldLines: C };
1595
+ const t = [...this.renderManager.lines];
1596
+ return { newLines: B.axisAlignmentCorrection(t, e), oldLines: t };
1738
1597
  }
1739
1598
  /** 开始
1740
1599
  * @param next
@@ -1778,22 +1637,22 @@ class oe extends W {
1778
1637
  return this.completed(e), e;
1779
1638
  }
1780
1639
  }
1781
- class ae extends W {
1640
+ class $ extends R {
1782
1641
  static name = "MergeLine";
1783
1642
  shortcutKeys = ["control", "g"];
1784
1643
  static commandName = "merge-line";
1785
1644
  onAddFromParent(e) {
1786
1645
  super.onAddFromParent(e);
1787
- const t = e.findComponentByType(Ke), n = this.commandManager.addCommandFlow(ae.commandName).add(this.createInterrupt()).add(this.constraint.bind(this)).add(this.mergeLine.bind(this)).addRollback(this.rollback.bind(this)).addRevokeRollback(this.revokeRollback.bind(this));
1788
- n.addEventListener("finally", this.createFinally()), n.addEventListener("completed", (s) => this.completed(s.data)), this.eventInput.addKeyCombination(ae.commandName, this.shortcutKeys), this.eventInput.addEventListener("codeChange", async () => {
1789
- t?.selectLines.length === 2 && this.eventInput.isKeyCombination(ae.commandName) && await this.commandManager.start(ae.commandName, [...this.default.selectLines]);
1646
+ const t = e.findComponentByType(_e), n = this.commandManager.addCommandFlow($.commandName).add(this.createInterrupt()).add(this.constraint.bind(this)).add(this.mergeLine.bind(this)).addRollback(this.rollback.bind(this)).addRevokeRollback(this.revokeRollback.bind(this));
1647
+ n.addEventListener("finally", this.createFinally()), n.addEventListener("completed", (s) => this.completed(s.data)), this.eventInput.addKeyCombination($.commandName, this.shortcutKeys), this.eventInput.addEventListener("codeChange", async () => {
1648
+ t?.selectLines.length === 2 && this.eventInput.isKeyCombination($.commandName) && await this.commandManager.start($.commandName, [...this.default.selectLines]);
1790
1649
  }), this.eventInput.addCancelDefaultBehavior(() => this.eventInput.isOnlyKeyDowns(this.shortcutKeys));
1791
1650
  }
1792
1651
  /**
1793
1652
  * 进入命令约束
1794
1653
  */
1795
1654
  constraint(e, t) {
1796
- Array.isArray(t) ? t.length !== 2 ? (B({ message: "未执行线段合并,请选择两条线段", type: "warning" }), this.cancel()) : e(t) : (B({ message: "进入命令失败", type: "warning" }), this.cancel());
1655
+ Array.isArray(t) ? t.length !== 2 ? (L({ message: "未执行线段合并,请选择两条线段", type: "warning" }), this.cancel()) : e(t) : (L({ message: "进入命令失败", type: "warning" }), this.cancel());
1797
1656
  }
1798
1657
  /** 开始
1799
1658
  * @param next
@@ -1806,12 +1665,12 @@ class ae extends W {
1806
1665
  for (let r = 0; r < s.points.length; r++) {
1807
1666
  const l = s.points[r];
1808
1667
  if (a.equal(l)) {
1809
- const i = n.points[(o + 1) % 2], d = s.points[(r + 1) % 2], p = new z(i, d);
1810
- return e({ line1: n, line2: s, newLine: p }), B({ message: "已合并", type: "success" });
1668
+ const i = n.points[(o + 1) % 2], c = s.points[(r + 1) % 2], h = new B(i, c);
1669
+ return e({ line1: n, line2: s, newLine: h }), L({ message: "已合并", type: "success" });
1811
1670
  }
1812
1671
  }
1813
1672
  }
1814
- B({ message: "合并失败,两条线未找到共用点", type: "warning" }), this.commandManager.cancel();
1673
+ L({ message: "合并失败,两条线未找到共用点", type: "warning" }), this.commandManager.cancel();
1815
1674
  }
1816
1675
  /** 执行完成
1817
1676
  * @param data
@@ -1833,26 +1692,26 @@ class ae extends W {
1833
1692
  return this.completed(e), e;
1834
1693
  }
1835
1694
  }
1836
- class ie extends W {
1695
+ class ee extends R {
1837
1696
  static name = "DeleteSelectLine";
1838
1697
  shortcutKeys = ["Delete"];
1839
1698
  static commandName = "deleteSelectLine";
1840
1699
  onAddFromParent(e) {
1841
- super.onAddFromParent(e), this.commandManager.addCommandFlow(ie.commandName).add(this.createInterrupt()).add(this.constraint.bind(this)).add(this.delete.bind(this)).addRollback(this.rollback.bind(this)).addRevokeRollback(this.revokeRollback.bind(this)).addEventListener("finally", this.createFinally()), this.eventInput.addKeyCombination(ie.commandName, this.shortcutKeys), this.eventInput.addEventListener("codeChange", async () => {
1842
- this.eventInput.isKeyCombination(ie.commandName) && await this.commandManager.start(ie.commandName, [...this.default.selectLines]);
1700
+ super.onAddFromParent(e), this.commandManager.addCommandFlow(ee.commandName).add(this.createInterrupt()).add(this.constraint.bind(this)).add(this.delete.bind(this)).addRollback(this.rollback.bind(this)).addRevokeRollback(this.revokeRollback.bind(this)).addEventListener("finally", this.createFinally()), this.eventInput.addKeyCombination(ee.commandName, this.shortcutKeys), this.eventInput.addEventListener("codeChange", async () => {
1701
+ this.eventInput.isKeyCombination(ee.commandName) && await this.commandManager.start(ee.commandName, [...this.default.selectLines]);
1843
1702
  }), this.eventInput.addCancelDefaultBehavior(() => this.eventInput.isOnlyKeyDowns(this.shortcutKeys));
1844
1703
  }
1845
1704
  /**
1846
1705
  * 进入命令约束
1847
1706
  */
1848
1707
  constraint(e, t) {
1849
- Array.isArray(t) ? t.length === 0 ? (B({ message: "请选择线段", type: "warning" }), this.cancel()) : e(t) : (B({ message: "进入命令失败", type: "warning" }), this.cancel());
1708
+ Array.isArray(t) ? t.length === 0 ? (L({ message: "请选择线段", type: "warning" }), this.cancel()) : e(t) : (L({ message: "进入命令失败", type: "warning" }), this.cancel());
1850
1709
  }
1851
1710
  /** 开始
1852
1711
  * @param next
1853
1712
  */
1854
1713
  delete(e, t) {
1855
- t.forEach((n) => this.renderManager.removeLine(n)), B({ message: "删除成功", type: "success" }), e(t);
1714
+ t.forEach((n) => this.renderManager.removeLine(n)), L({ message: "删除成功", type: "success" }), e(t);
1856
1715
  }
1857
1716
  /** 回滚操作
1858
1717
  * @param data
@@ -1868,22 +1727,22 @@ class ie extends W {
1868
1727
  return e.forEach((t) => this.renderManager.removeLine(t)), e;
1869
1728
  }
1870
1729
  }
1871
- class re extends W {
1730
+ class te extends R {
1872
1731
  static name = "ConnectionLine";
1873
1732
  shortcutKeys = ["Shift", "L"];
1874
1733
  static commandName = "connectionLine";
1875
1734
  onAddFromParent(e) {
1876
1735
  super.onAddFromParent(e);
1877
- const t = this.commandManager.addCommandFlow(re.commandName).add(this.createInterrupt()).add(this.constraint.bind(this)).add(this.connection.bind(this)).addRollback(this.rollback.bind(this)).addRevokeRollback(this.revokeRollback.bind(this));
1878
- t.addEventListener("finally", this.createFinally()), t.addEventListener("completed", (n) => this.completed(n.data)), this.eventInput.addKeyCombination(re.commandName, this.shortcutKeys), this.eventInput.addEventListener("codeChange", async () => {
1879
- this.eventInput.isKeyCombination(re.commandName) && await this.commandManager.start(re.commandName, [...this.default.selectLines]);
1736
+ const t = this.commandManager.addCommandFlow(te.commandName).add(this.createInterrupt()).add(this.constraint.bind(this)).add(this.connection.bind(this)).addRollback(this.rollback.bind(this)).addRevokeRollback(this.revokeRollback.bind(this));
1737
+ t.addEventListener("finally", this.createFinally()), t.addEventListener("completed", (n) => this.completed(n.data)), this.eventInput.addKeyCombination(te.commandName, this.shortcutKeys), this.eventInput.addEventListener("codeChange", async () => {
1738
+ this.eventInput.isKeyCombination(te.commandName) && await this.commandManager.start(te.commandName, [...this.default.selectLines]);
1880
1739
  }), this.eventInput.addCancelDefaultBehavior(() => this.eventInput.isOnlyKeyDowns(this.shortcutKeys));
1881
1740
  }
1882
1741
  /**
1883
1742
  * 进入命令约束
1884
1743
  */
1885
1744
  constraint(e, t) {
1886
- Array.isArray(t) ? t.length !== 2 ? (B({ message: "请选择2条线段", type: "warning" }), this.cancel()) : e(t) : (B({ message: "进入命令失败", type: "warning" }), this.cancel());
1745
+ Array.isArray(t) ? t.length !== 2 ? (L({ message: "请选择2条线段", type: "warning" }), this.cancel()) : e(t) : (L({ message: "进入命令失败", type: "warning" }), this.cancel());
1887
1746
  }
1888
1747
  /** 连接
1889
1748
  * @param next
@@ -1892,12 +1751,12 @@ class re extends W {
1892
1751
  let n, s, o = 1 / 0;
1893
1752
  for (let a = 0; a < 2; a++)
1894
1753
  for (let r = 0; r < 2; r++) {
1895
- const l = t[0].points[a], i = t[1].points[r], d = l.distance(i);
1896
- d < o && (n = l, s = i, o = d);
1754
+ const l = t[0].points[a], i = t[1].points[r], c = l.distance(i);
1755
+ c < o && (n = l, s = i, o = c);
1897
1756
  }
1898
1757
  if (n && s) {
1899
- const a = new z(n.clone(), s.clone());
1900
- e(a), B({ message: "连接成功", type: "success" });
1758
+ const a = new B(n.clone(), s.clone());
1759
+ e(a), L({ message: "连接成功", type: "success" });
1901
1760
  } else this.cancel();
1902
1761
  }
1903
1762
  /** 成功
@@ -1921,22 +1780,22 @@ class re extends W {
1921
1780
  return this.completed(e), e;
1922
1781
  }
1923
1782
  }
1924
- class de extends W {
1783
+ class ne extends R {
1925
1784
  static name = "IntersectionConnectionLine";
1926
1785
  shortcutKeys = ["control", "Shift", "L"];
1927
1786
  static commandName = "intersectionConnectionLine";
1928
1787
  onAddFromParent(e) {
1929
1788
  super.onAddFromParent(e);
1930
- const t = this.commandManager.addCommandFlow(de.commandName).add(this.createInterrupt()).add(this.constraint.bind(this)).add(this.connection.bind(this)).addRollback(this.rollback.bind(this)).addRevokeRollback(this.revokeRollback.bind(this));
1931
- t.addEventListener("finally", this.createFinally()), t.addEventListener("completed", (n) => this.completed(n.data)), this.eventInput.addKeyCombination(de.commandName, this.shortcutKeys), this.eventInput.addEventListener("codeChange", async () => {
1932
- this.eventInput.isKeyCombination(de.commandName) && await this.commandManager.start(de.commandName, [...this.default.selectLines]);
1789
+ const t = this.commandManager.addCommandFlow(ne.commandName).add(this.createInterrupt()).add(this.constraint.bind(this)).add(this.connection.bind(this)).addRollback(this.rollback.bind(this)).addRevokeRollback(this.revokeRollback.bind(this));
1790
+ t.addEventListener("finally", this.createFinally()), t.addEventListener("completed", (n) => this.completed(n.data)), this.eventInput.addKeyCombination(ne.commandName, this.shortcutKeys), this.eventInput.addEventListener("codeChange", async () => {
1791
+ this.eventInput.isKeyCombination(ne.commandName) && await this.commandManager.start(ne.commandName, [...this.default.selectLines]);
1933
1792
  }), this.eventInput.addCancelDefaultBehavior(() => this.eventInput.isOnlyKeyDowns(this.shortcutKeys));
1934
1793
  }
1935
1794
  /**
1936
1795
  * 进入命令约束
1937
1796
  */
1938
1797
  constraint(e, t) {
1939
- Array.isArray(t) ? t.length !== 2 ? (B({ message: "请选择2条线段", type: "warning" }), this.cancel()) : e(t) : (B({ message: "进入命令失败", type: "warning" }), this.cancel());
1798
+ Array.isArray(t) ? t.length !== 2 ? (L({ message: "请选择2条线段", type: "warning" }), this.cancel()) : e(t) : (L({ message: "进入命令失败", type: "warning" }), this.cancel());
1940
1799
  }
1941
1800
  /** 开始
1942
1801
  * @param next
@@ -1944,10 +1803,10 @@ class de extends W {
1944
1803
  connection(e, t) {
1945
1804
  const n = t[0], s = t[1], o = t[0].getIntersection(t[1]);
1946
1805
  if (!o) return;
1947
- const a = n.points.map((d) => d.clone()), r = s.points.map((d) => d.clone());
1806
+ const a = n.points.map((c) => c.clone()), r = s.points.map((c) => c.clone());
1948
1807
  n.start.distance(o) < n.end.distance(o) ? n.start.copy(o) : n.end.copy(o), s.start.distance(o) < s.end.distance(o) ? s.start.copy(o) : s.end.copy(o);
1949
- const l = n.points.map((d) => d.clone()), i = s.points.map((d) => d.clone());
1950
- e({ line1: n, line2: s, oldLine1: a, oldLine2: r, newLine1: l, newLine2: i }), B({ message: "连接成功", type: "success" });
1808
+ const l = n.points.map((c) => c.clone()), i = s.points.map((c) => c.clone());
1809
+ e({ line1: n, line2: s, oldLine1: a, oldLine2: r, newLine1: l, newLine2: i }), L({ message: "连接成功", type: "success" });
1951
1810
  }
1952
1811
  /** 执行完成
1953
1812
  * @param next
@@ -1971,22 +1830,22 @@ class de extends W {
1971
1830
  return this.completed(e), e;
1972
1831
  }
1973
1832
  }
1974
- class le extends W {
1833
+ class se extends R {
1975
1834
  static name = "DeleteSelectWindow";
1976
1835
  shortcutKeys = ["Q", "Delete"];
1977
1836
  static commandName = "deleteSelectWindow";
1978
1837
  onAddFromParent(e) {
1979
1838
  super.onAddFromParent(e);
1980
- const t = this.commandManager.addCommandFlow(le.commandName).add(this.createInterrupt()).add(this.constraint.bind(this)).add(this.end.bind(this)).addRollback(this.rollback.bind(this)).addRevokeRollback(this.revokeRollback.bind(this));
1981
- t.addEventListener("finally", this.createFinally()), t.addEventListener("completed", (n) => this.completed(n.data)), this.eventInput.addKeyCombination(le.commandName, this.shortcutKeys), this.eventInput.addEventListener("codeChange", async () => {
1982
- this.eventInput.isKeyCombination(le.commandName) && await this.commandManager.start(le.commandName, [...this.default.selectLines]);
1839
+ const t = this.commandManager.addCommandFlow(se.commandName).add(this.createInterrupt()).add(this.constraint.bind(this)).add(this.end.bind(this)).addRollback(this.rollback.bind(this)).addRevokeRollback(this.revokeRollback.bind(this));
1840
+ t.addEventListener("finally", this.createFinally()), t.addEventListener("completed", (n) => this.completed(n.data)), this.eventInput.addKeyCombination(se.commandName, this.shortcutKeys), this.eventInput.addEventListener("codeChange", async () => {
1841
+ this.eventInput.isKeyCombination(se.commandName) && await this.commandManager.start(se.commandName, [...this.default.selectLines]);
1983
1842
  }), this.eventInput.addCancelDefaultBehavior(() => this.eventInput.isOnlyKeyDowns(this.shortcutKeys));
1984
1843
  }
1985
1844
  /**
1986
1845
  * 进入命令约束
1987
1846
  */
1988
1847
  constraint(e, t) {
1989
- Array.isArray(t) ? t.some((n) => n.userData.isWindow) ? e(t) : (B({ message: "请选择有窗户线段", type: "warning" }), this.cancel()) : (B({ message: "进入命令失败", type: "warning" }), this.cancel());
1848
+ Array.isArray(t) ? t.some((n) => n.userData.isWindow) ? e(t) : (L({ message: "请选择有窗户线段", type: "warning" }), this.cancel()) : (L({ message: "进入命令失败", type: "warning" }), this.cancel());
1990
1849
  }
1991
1850
  /** 开始
1992
1851
  * @param next
@@ -1998,7 +1857,7 @@ class le extends W {
1998
1857
  line: o,
1999
1858
  drawDoorData: o.userData.drawDoorData
2000
1859
  }), n = !0);
2001
- }), n && B({ message: "删除窗户成功", type: "success" }), e(s);
1860
+ }), n && L({ message: "删除窗户成功", type: "success" }), e(s);
2002
1861
  }
2003
1862
  /**
2004
1863
  * 完成
@@ -2028,16 +1887,16 @@ class le extends W {
2028
1887
  return this.completed(e), e;
2029
1888
  }
2030
1889
  }
2031
- class ce extends W {
1890
+ class oe extends R {
2032
1891
  static name = "SelectAll";
2033
- container = new h.Group();
1892
+ container = new m.Group();
2034
1893
  shortcutKeys = ["control", "a"];
2035
1894
  static commandName = "selectAll";
2036
1895
  onAddFromParent(e) {
2037
1896
  super.onAddFromParent(e), this.editor.container.add(this.container), this.container.position.z = 1e-3;
2038
- const t = this.commandManager.addCommandFlow(ce.commandName).add(this.createInterrupt()).add(this.selectAll.bind(this)).addRollback(this.rollback.bind(this)).addRevokeRollback(this.revokeRollback.bind(this));
2039
- t.writeOperationList = !1, t.addEventListener("finally", this.createFinally()), t.addEventListener("completed", (n) => this.completed(n.data)), this.eventInput.addKeyCombination(ce.commandName, this.shortcutKeys), this.eventInput.addEventListener("codeChange", async () => {
2040
- this.eventInput.isKeyCombination(ce.commandName) && await this.commandManager.start(ce.commandName);
1897
+ const t = this.commandManager.addCommandFlow(oe.commandName).add(this.createInterrupt()).add(this.selectAll.bind(this)).addRollback(this.rollback.bind(this)).addRevokeRollback(this.revokeRollback.bind(this));
1898
+ t.writeOperationList = !1, t.addEventListener("finally", this.createFinally()), t.addEventListener("completed", (n) => this.completed(n.data)), this.eventInput.addKeyCombination(oe.commandName, this.shortcutKeys), this.eventInput.addEventListener("codeChange", async () => {
1899
+ this.eventInput.isKeyCombination(oe.commandName) && await this.commandManager.start(oe.commandName);
2041
1900
  }), this.eventInput.addCancelDefaultBehavior(() => this.eventInput.isOnlyKeyDowns(this.shortcutKeys));
2042
1901
  }
2043
1902
  /** 开始
@@ -2065,22 +1924,22 @@ class ce extends W {
2065
1924
  return this.completed(e), e;
2066
1925
  }
2067
1926
  }
2068
- class me extends W {
1927
+ class ae extends R {
2069
1928
  static name = "ViewAngle";
2070
1929
  shortcutKeys = ["r"];
2071
1930
  static commandName = "viewAngle";
2072
1931
  onAddFromParent(e) {
2073
1932
  super.onAddFromParent(e);
2074
- const t = this.commandManager.addCommandFlow(me.commandName).add(this.createInterrupt()).add(this.constraint.bind(this)).add(this.viewAngle.bind(this));
2075
- t.writeOperationList = !1, t.addEventListener("finally", this.createFinally()), this.eventInput.addKeyCombination(me.commandName, this.shortcutKeys), this.eventInput.addEventListener("codeChange", async () => {
2076
- this.eventInput.isKeyCombination(me.commandName) && await this.commandManager.start(me.commandName, [...this.default.selectLines]);
1933
+ const t = this.commandManager.addCommandFlow(ae.commandName).add(this.createInterrupt()).add(this.constraint.bind(this)).add(this.viewAngle.bind(this));
1934
+ t.writeOperationList = !1, t.addEventListener("finally", this.createFinally()), this.eventInput.addKeyCombination(ae.commandName, this.shortcutKeys), this.eventInput.addEventListener("codeChange", async () => {
1935
+ this.eventInput.isKeyCombination(ae.commandName) && await this.commandManager.start(ae.commandName, [...this.default.selectLines]);
2077
1936
  }), this.eventInput.addCancelDefaultBehavior(() => this.eventInput.isOnlyKeyDowns(this.shortcutKeys));
2078
1937
  }
2079
1938
  /**
2080
1939
  * 进入命令约束
2081
1940
  */
2082
1941
  constraint(e, t) {
2083
- Array.isArray(t) ? t.length !== 2 || !t[0].sameEndpoint(t[1]) ? (B({ message: "请选择两条具有端点相交的线段", type: "warning" }), this.cancel()) : e(t) : (B({ message: "进入命令失败", type: "warning" }), this.cancel());
1942
+ Array.isArray(t) ? t.length !== 2 || !t[0].sameEndpoint(t[1]) ? (L({ message: "请选择两条具有端点相交的线段", type: "warning" }), this.cancel()) : e(t) : (L({ message: "进入命令失败", type: "warning" }), this.cancel());
2084
1943
  }
2085
1944
  /**
2086
1945
  *
@@ -2089,37 +1948,37 @@ class me extends W {
2089
1948
  */
2090
1949
  viewAngle(e, t) {
2091
1950
  const [n, s] = t, o = Math.min(0.5, n.length(), s.length());
2092
- let a, r, l, i = 0, d = 0;
1951
+ let a, r, l, i = 0, c = 0;
2093
1952
  n.sameEndpointAsStart(s) ? (a = n.start, r = n.end) : (a = n.end, r = n.start), s.sameEndpointAsStart(n) ? l = s.end : l = s.start;
2094
- function p(D, b) {
2095
- const m = b.x - D.x, I = b.y - D.y;
2096
- let _ = Math.atan2(I, m) * (180 / Math.PI);
2097
- return _ < 0 && (_ += 360), _;
1953
+ function h(A, M) {
1954
+ const b = M.x - A.x, K = M.y - A.y;
1955
+ let W = Math.atan2(K, b) * (180 / Math.PI);
1956
+ return W < 0 && (W += 360), W;
2098
1957
  }
2099
- const E = p(a, r), f = p(a, l), y = Math.min(E, f), C = Math.max(E, f), v = [];
2100
- function w(D, b) {
2101
- for (let m = D; m <= b; m++) {
2102
- const I = Math.cos(m * Math.PI / 180) * o + a.x, _ = Math.sin(m * Math.PI / 180) * o + a.y, j = Math.cos((m + 1) * Math.PI / 180) * o + a.x, N = Math.sin((m + 1) * Math.PI / 180) * o + a.y;
2103
- v.push(I, _, 0, j, N, 0);
1958
+ const y = h(a, r), u = h(a, l), v = Math.min(y, u), g = Math.max(y, u), E = [];
1959
+ function x(A, M) {
1960
+ for (let b = A; b <= M; b++) {
1961
+ const K = Math.cos(b * Math.PI / 180) * o + a.x, W = Math.sin(b * Math.PI / 180) * o + a.y, he = Math.cos((b + 1) * Math.PI / 180) * o + a.x, Ce = Math.sin((b + 1) * Math.PI / 180) * o + a.y;
1962
+ E.push(K, W, 0, he, Ce, 0);
2104
1963
  }
2105
1964
  }
2106
- C - y > 180 ? (w(0, y), w(C, 360), i = 360 - (C - y), d = (C + i / 2) % 360) : (w(y, C), i = C - y, d = y + i / 2);
2107
- const g = new h.LineSegments();
2108
- g.geometry = this.renderManager.createGeometry({
2109
- position: v
2110
- }, v.length / 3), g.material = new h.LineBasicMaterial({ color: 16711935 }), this.renderManager.container.add(g);
2111
- const S = Math.cos(d * Math.PI / 180) * o + a.x, A = Math.sin(d * Math.PI / 180) * o + a.y, M = this.renderer.createText(Number(i.toFixed(2)), new h.Vector3(S, A, 0), {
1965
+ g - v > 180 ? (x(0, v), x(g, 360), i = 360 - (g - v), c = (g + i / 2) % 360) : (x(v, g), i = g - v, c = v + i / 2);
1966
+ const D = new m.LineSegments();
1967
+ D.geometry = this.renderManager.createGeometry({
1968
+ position: E
1969
+ }, E.length / 3), D.material = new m.LineBasicMaterial({ color: 16711935 }), this.renderManager.container.add(D);
1970
+ const z = Math.cos(c * Math.PI / 180) * o + a.x, me = Math.sin(c * Math.PI / 180) * o + a.y, Z = this.renderer.createText(Number(i.toFixed(2)), new m.Vector3(z, me, 0), {
2112
1971
  textShadow: "0px 0px 2px #000"
2113
1972
  }, this.renderManager.container);
2114
- let u = 0;
2115
- this.addEventRecord("clear").add(() => g.removeFromParent()).add(() => M.removeFromParent()).add(this.eventInput.addEventListener("codeChange", () => {
2116
- this.eventInput.isOnlyKeyDown("enter") ? e() : this.eventInput.isOnlyKeyDown("mouse_0") && (u++, u === 1 ? setTimeout(() => u = 0, 500) : u === 2 && (e(), u = 0));
1973
+ let G = 0;
1974
+ this.addEventRecord("clear").add(() => D.removeFromParent()).add(() => Z.removeFromParent()).add(this.eventInput.addEventListener("codeChange", () => {
1975
+ this.eventInput.isOnlyKeyDown("enter") ? e() : this.eventInput.isOnlyKeyDown("mouse_0") && (G++, G === 1 ? setTimeout(() => G = 0, 500) : G === 2 && (e(), G = 0));
2117
1976
  }));
2118
1977
  }
2119
1978
  }
2120
- class ct extends W {
1979
+ class rt extends R {
2121
1980
  static name = "ClippingLine";
2122
- container = new h.Group();
1981
+ container = new m.Group();
2123
1982
  shortcutKeys = ["control", "x"];
2124
1983
  commandName = "clippingLine";
2125
1984
  static commandName = "clippingLine";
@@ -2132,7 +1991,7 @@ class ct extends W {
2132
1991
  * @param next
2133
1992
  */
2134
1993
  selectPointStart(e) {
2135
- let t = null, n = new h.Mesh(new h.SphereGeometry(0.04), new h.MeshBasicMaterial({ color: 16711935 })), s = null;
1994
+ let t = null, n = new m.Mesh(new m.SphereGeometry(0.04), new m.MeshBasicMaterial({ color: 16711935 })), s = null;
2136
1995
  this.addEventRecord("selectPointStart").add(this.editor.addEventListener("pointerPositionChange", () => {
2137
1996
  const { point: o, line: a, find: r } = this.editor.renderManager.adsorption();
2138
1997
  this.dispatchEvent({ type: "pointerMove", point: o }), r ? (this.domElement.style.cursor = "none", n.position.copy(o), s = a, t = o.clone(), this.container.add(n)) : (this.domElement.style.cursor = "no-drop", t = null, n.removeFromParent());
@@ -2144,7 +2003,7 @@ class ct extends W {
2144
2003
  * @param next
2145
2004
  */
2146
2005
  selectPointEnd(e, { point: t, line: n }) {
2147
- let s = null, o = new h.Mesh(new h.SphereGeometry(0.04), new h.MeshBasicMaterial({ color: 16711935 }));
2006
+ let s = null, o = new m.Mesh(new m.SphereGeometry(0.04), new m.MeshBasicMaterial({ color: 16711935 }));
2148
2007
  this.addEventRecord("clear").add(() => o.removeFromParent()).add(this.editor.addEventListener("pointerPositionChange", () => {
2149
2008
  const { point: a, find: r, line: l } = this.editor.renderManager.adsorption();
2150
2009
  this.dispatchEvent({ type: "pointerMove", point: a }), r && l === n ? (this.domElement.style.cursor = "none", o.position.copy(a), s = a.clone(), this.container.add(o)) : (this.domElement.style.cursor = "no-drop", s = null, o.removeFromParent());
@@ -2158,14 +2017,14 @@ class ct extends W {
2158
2017
  * @param points
2159
2018
  */
2160
2019
  end(e, { start: t, end: n, line: s }) {
2161
- const o = R.from(t), a = R.from(n);
2020
+ const o = _.from(t), a = _.from(n);
2162
2021
  e({
2163
2022
  oldLine: s,
2164
- newLine1: new z(
2023
+ newLine1: new B(
2165
2024
  s.start,
2166
2025
  s.start.distance(o) < s.start.distance(a) ? o.clone() : a.clone()
2167
2026
  ),
2168
- newLine2: new z(
2027
+ newLine2: new B(
2169
2028
  s.end,
2170
2029
  s.end.distance(o) < s.end.distance(a) ? o.clone() : a.clone()
2171
2030
  )
@@ -2190,22 +2049,22 @@ class ct extends W {
2190
2049
  return this.completed(e), e;
2191
2050
  }
2192
2051
  }
2193
- class he extends W {
2052
+ class ie extends R {
2194
2053
  static name = "VerticalReferenceLine";
2195
2054
  shortcutKeys = ["v"];
2196
2055
  static commandName = "VerticalReferenceLine";
2197
2056
  onAddFromParent(e) {
2198
2057
  super.onAddFromParent(e);
2199
- const t = this.commandManager.addCommandFlow(he.commandName).add(this.createInterrupt()).add(this.constraint.bind(this)).add(this.verticalReferenceLine.bind(this));
2200
- t.writeOperationList = !1, t.addEventListener("finally", this.createFinally()), this.eventInput.addKeyCombination(he.commandName, this.shortcutKeys), this.eventInput.addEventListener("codeChange", async () => {
2201
- this.eventInput.isKeyCombination(he.commandName) && await this.commandManager.start(he.commandName, [...this.default.selectLines]);
2058
+ const t = this.commandManager.addCommandFlow(ie.commandName).add(this.createInterrupt()).add(this.constraint.bind(this)).add(this.verticalReferenceLine.bind(this));
2059
+ t.writeOperationList = !1, t.addEventListener("finally", this.createFinally()), this.eventInput.addKeyCombination(ie.commandName, this.shortcutKeys), this.eventInput.addEventListener("codeChange", async () => {
2060
+ this.eventInput.isKeyCombination(ie.commandName) && await this.commandManager.start(ie.commandName, [...this.default.selectLines]);
2202
2061
  }), this.eventInput.addCancelDefaultBehavior(() => this.eventInput.isOnlyKeyDowns(this.shortcutKeys));
2203
2062
  }
2204
2063
  /**
2205
2064
  * 进入命令约束
2206
2065
  */
2207
2066
  constraint(e, t) {
2208
- Array.isArray(t) ? t.length !== 1 ? (B({ message: "请选择一条墙壁线段", type: "warning" }), this.cancel()) : t[0].userData.isDoor ? (B({ message: "请选择一条墙壁线段", type: "warning" }), this.cancel()) : e(t) : (B({ message: "进入命令失败", type: "warning" }), this.cancel());
2067
+ Array.isArray(t) ? t.length !== 1 ? (L({ message: "请选择一条墙壁线段", type: "warning" }), this.cancel()) : t[0].userData.isDoor ? (L({ message: "请选择一条墙壁线段", type: "warning" }), this.cancel()) : e(t) : (L({ message: "进入命令失败", type: "warning" }), this.cancel());
2209
2068
  }
2210
2069
  /**
2211
2070
  *
@@ -2233,52 +2092,52 @@ const as = {
2233
2092
  }, fs = {
2234
2093
  key: 0,
2235
2094
  class: "flex flex-row items-center flex-wrap justify-between gap-[10px] mt-[10px] text-[10px]"
2236
- }, ys = { class: "flex-wrap border-t-1 border-t-[#eee] mt-[5px] pt-[5px] flex items-center gap-[10px]" }, ws = ["onClick", "title"], bs = ["src"], xs = /* @__PURE__ */ ve({
2095
+ }, ys = { class: "flex-wrap border-t-1 border-t-[#eee] mt-[5px] pt-[5px] flex items-center gap-[10px]" }, ws = ["onClick", "title"], bs = ["src"], xs = /* @__PURE__ */ ce({
2237
2096
  __name: "EditorTool",
2238
2097
  props: {
2239
2098
  dxfSystem: {},
2240
2099
  permission: {}
2241
2100
  },
2242
- setup(c) {
2243
- function e(k, x, P = p.value.getBoundingClientRect(), te = E.value.getBoundingClientRect()) {
2244
- const fe = P.width - te.width, ye = 0, De = P.height - te.height;
2245
- k = Math.max(0, Math.min(k, fe)), x = Math.max(ye, Math.min(x, De)), D.value = { left: k, top: x };
2101
+ setup(d) {
2102
+ function e(C, p, w = h.value.getBoundingClientRect(), U = y.value.getBoundingClientRect()) {
2103
+ const ue = w.width - U.width, pe = 0, Me = w.height - U.height;
2104
+ C = Math.max(0, Math.min(C, ue)), p = Math.max(pe, Math.min(p, Me)), A.value = { left: C, top: p };
2246
2105
  }
2247
- function t(k) {
2248
- y.value === k.command || y.value !== "default" || w.commandManager.start(k.command);
2106
+ function t(C) {
2107
+ v.value === C.command || v.value !== "default" || x.commandManager.start(C.command);
2249
2108
  }
2250
- function n(k) {
2251
- if (k) {
2252
- localStorage.setItem("lines", JSON.stringify(k));
2109
+ function n(C) {
2110
+ if (C) {
2111
+ localStorage.setItem("lines", JSON.stringify(C));
2253
2112
  try {
2254
- C.Dxf.set(k), C.Dxf.lineOffset();
2255
- } catch (x) {
2256
- console.log(x);
2113
+ g.Dxf.set(C), g.Dxf.lineOffset();
2114
+ } catch (p) {
2115
+ console.log(p);
2257
2116
  }
2258
2117
  }
2259
2118
  }
2260
2119
  async function s() {
2261
- const k = await kt.json();
2262
- Array.isArray(k) && (localStorage.removeItem("orbitControls"), n(k));
2120
+ const C = await Pt.json();
2121
+ Array.isArray(C) && (localStorage.removeItem("orbitControls"), n(C));
2263
2122
  }
2264
- function o({ offsetX: k, offsetY: x }) {
2265
- v.mouseMoveEventProxylock = !0;
2266
- const P = document.body.style.cursor;
2123
+ function o({ offsetX: C, offsetY: p }) {
2124
+ E.mouseMoveEventProxylock = !0;
2125
+ const w = document.body.style.cursor;
2267
2126
  document.body.style.cursor = "move";
2268
- const te = (fe) => {
2269
- const ye = p.value.getBoundingClientRect(), De = E.value.getBoundingClientRect();
2127
+ const U = (ue) => {
2128
+ const pe = h.value.getBoundingClientRect(), Me = y.value.getBoundingClientRect();
2270
2129
  e(
2271
- fe.pageX - ye.left - k,
2272
- fe.pageY - ye.top - x,
2273
- ye,
2274
- De
2275
- ), fe.stopPropagation(), document.body.style.cursor = "move";
2276
- }, ke = () => {
2277
- document.body.removeEventListener("mousemove", te), document.removeEventListener("mouseup", ke), document.body.style.cursor = P, v.mouseMoveEventProxylock = !1;
2130
+ ue.pageX - pe.left - C,
2131
+ ue.pageY - pe.top - p,
2132
+ pe,
2133
+ Me
2134
+ ), ue.stopPropagation(), document.body.style.cursor = "move";
2135
+ }, Ee = () => {
2136
+ document.body.removeEventListener("mousemove", U), document.removeEventListener("mouseup", Ee), document.body.style.cursor = w, E.mouseMoveEventProxylock = !1;
2278
2137
  };
2279
- document.body.addEventListener("mousemove", te), document.addEventListener("mouseup", ke);
2138
+ document.body.addEventListener("mousemove", U), document.addEventListener("mouseup", Ee);
2280
2139
  }
2281
- const a = c, r = T(!0), l = T(!0), i = T(!0), d = T(!1), p = T(), E = T(), f = T(!0), y = T(""), C = Ot(a.dxfSystem), v = C.findComponentByType(Pt), w = C.findComponentByType(mt), g = C.findComponentByType(Ke), S = C.findComponentByType(St), A = C.findComponentByType(At), M = T(0), u = T(0), D = T({ left: 10, top: 100 }), b = /* @__PURE__ */ Object.assign({ "./assets/images/angle.svg": Cn, "./assets/images/connection.svg": Mn, "./assets/images/cutLine.svg": In, "./assets/images/deleteSelectLine.svg": kn, "./assets/images/deleteSelectWindow.svg": Sn, "./assets/images/door.svg": _n, "./assets/images/intersectionConnection.svg": Nn, "./assets/images/line.svg": Rn, "./assets/images/mergeLine.svg": Fn, "./assets/images/revokeRollback.svg": Tn, "./assets/images/rollback.svg": Vn, "./assets/images/selectAll.svg": Qn, "./assets/images/selectPoint.svg": Wn, "./assets/images/verticalCorrection.svg": Un, "./assets/images/verticalLine.svg": Zn, "./assets/images/window.svg": Xn }), m = T(!1), I = T(0), _ = T(!1), j = new ResizeObserver(() => e(D.value.left, D.value.top)), N = [
2140
+ const a = d, r = S(!0), l = S(!0), i = S(!0), c = S(!1), h = S(), y = S(), u = S(!0), v = S(""), g = Ot(a.dxfSystem), E = g.findComponentByType(It), x = g.findComponentByType(dt), D = g.findComponentByType(_e), z = g.findComponentByType(At), me = g.findComponentByType(St), Z = S(0), G = S(0), A = S({ left: 10, top: 100 }), M = /* @__PURE__ */ Object.assign({ "./assets/images/angle.svg": Cn, "./assets/images/connection.svg": Mn, "./assets/images/cutLine.svg": kn, "./assets/images/deleteSelectLine.svg": Pn, "./assets/images/deleteSelectWindow.svg": An, "./assets/images/door.svg": _n, "./assets/images/intersectionConnection.svg": Nn, "./assets/images/line.svg": Rn, "./assets/images/mergeLine.svg": Fn, "./assets/images/revokeRollback.svg": Tn, "./assets/images/rollback.svg": Vn, "./assets/images/selectAll.svg": Qn, "./assets/images/selectPoint.svg": Wn, "./assets/images/verticalCorrection.svg": Un, "./assets/images/verticalLine.svg": Zn, "./assets/images/window.svg": Xn }), b = S(!1), K = S(0), W = S(!1), he = new ResizeObserver(() => e(A.value.left, A.value.top)), Ce = [
2282
2141
  { name: "开启绘制线段命令", shortcut: "Ctrl + L" },
2283
2142
  { name: "开启绘制门线命令", shortcut: "Ctrl + M" },
2284
2143
  { name: "开启绘制窗户线命令", shortcut: "Ctrl + Q" },
@@ -2298,7 +2157,7 @@ const as = {
2298
2157
  { name: "取消命令", shortcut: "Esc" },
2299
2158
  { name: "回滚操作", shortcut: "Ctrl + Z" },
2300
2159
  { name: "取消回滚操作", shortcut: "Ctrl + Y" }
2301
- ], G = [
2160
+ ], lt = [
2302
2161
  {
2303
2162
  command: "default",
2304
2163
  name: "默认",
@@ -2308,7 +2167,7 @@ const as = {
2308
2167
  {
2309
2168
  command: "draw-line",
2310
2169
  name: "绘制线段",
2311
- src: b["./assets/images/line.svg"].default,
2170
+ src: M["./assets/images/line.svg"].default,
2312
2171
  show: !0,
2313
2172
  shortcut: "Ctrl + L"
2314
2173
  },
@@ -2316,78 +2175,78 @@ const as = {
2316
2175
  command: "draw-door-line",
2317
2176
  name: "绘制门线",
2318
2177
  show: !0,
2319
- src: b["./assets/images/door.svg"].default,
2178
+ src: M["./assets/images/door.svg"].default,
2320
2179
  shortcut: "Ctrl + M"
2321
2180
  },
2322
2181
  {
2323
2182
  command: "draw-window-line",
2324
2183
  name: "绘制窗户线",
2325
2184
  show: !0,
2326
- src: b["./assets/images/window.svg"].default,
2185
+ src: M["./assets/images/window.svg"].default,
2327
2186
  shortcut: "Ctrl + Q"
2328
2187
  },
2329
2188
  {
2330
2189
  command: "point",
2331
2190
  name: "点修改",
2332
2191
  show: !0,
2333
- src: b["./assets/images/selectPoint.svg"].default,
2192
+ src: M["./assets/images/selectPoint.svg"].default,
2334
2193
  shortcut: "Ctrl + P"
2335
2194
  },
2336
2195
  {
2337
- command: ct.commandName,
2196
+ command: rt.commandName,
2338
2197
  name: "裁剪线段",
2339
2198
  show: !0,
2340
- src: b["./assets/images/cutLine.svg"].default,
2199
+ src: M["./assets/images/cutLine.svg"].default,
2341
2200
  shortcut: "Ctrl + X"
2342
2201
  }
2343
- ], Y = [
2202
+ ], ct = [
2344
2203
  {
2345
2204
  command: "",
2346
2205
  name: "操作回滚",
2347
- src: b["./assets/images/rollback.svg"].default,
2348
- show: F(() => M.value !== 0),
2206
+ src: M["./assets/images/rollback.svg"].default,
2207
+ show: P(() => Z.value !== 0),
2349
2208
  shortcut: "Ctrl + Z",
2350
2209
  action() {
2351
- w.commandManager.rollback();
2210
+ x.commandManager.rollback();
2352
2211
  }
2353
2212
  },
2354
2213
  {
2355
2214
  command: "",
2356
2215
  name: "撤销操作回滚",
2357
- src: b["./assets/images/revokeRollback.svg"].default,
2358
- show: F(() => u.value !== 0),
2216
+ src: M["./assets/images/revokeRollback.svg"].default,
2217
+ show: P(() => G.value !== 0),
2359
2218
  shortcut: "Ctrl + Y",
2360
2219
  class: "rotateY-[180deg]",
2361
2220
  action() {
2362
- w.commandManager.revokeRollback();
2221
+ x.commandManager.revokeRollback();
2363
2222
  }
2364
2223
  },
2365
2224
  {
2366
- command: ae.commandName,
2225
+ command: $.commandName,
2367
2226
  name: "合并",
2368
- src: b["./assets/images/mergeLine.svg"].default,
2369
- show: F(() => I.value === 2),
2227
+ src: M["./assets/images/mergeLine.svg"].default,
2228
+ show: P(() => K.value === 2),
2370
2229
  shortcut: "Ctrl + G"
2371
2230
  },
2372
2231
  {
2373
- command: re.commandName,
2232
+ command: te.commandName,
2374
2233
  name: "两点连接",
2375
- show: F(() => I.value === 2),
2376
- src: b["./assets/images/connection.svg"].default,
2234
+ show: P(() => K.value === 2),
2235
+ src: M["./assets/images/connection.svg"].default,
2377
2236
  shortcut: "Shift + L"
2378
2237
  },
2379
2238
  {
2380
- command: de.commandName,
2239
+ command: ne.commandName,
2381
2240
  name: "延长线交点连接",
2382
- show: F(() => I.value === 2),
2383
- src: b["./assets/images/intersectionConnection.svg"].default,
2241
+ show: P(() => K.value === 2),
2242
+ src: M["./assets/images/intersectionConnection.svg"].default,
2384
2243
  shortcut: "Ctrl + Shift + L"
2385
2244
  },
2386
2245
  {
2387
- command: oe.commandName,
2246
+ command: X.commandName,
2388
2247
  name: "线段垂直纠正",
2389
- show: F(() => I.value === 1),
2390
- src: b["./assets/images/verticalCorrection.svg"].default,
2248
+ show: P(() => K.value === 1),
2249
+ src: M["./assets/images/verticalCorrection.svg"].default,
2391
2250
  shortcut: `
2392
2251
  Ctrl + C 垂直纠正
2393
2252
  Ctrl + Shift + C 全部垂直纠正
@@ -2395,147 +2254,147 @@ const as = {
2395
2254
  `
2396
2255
  },
2397
2256
  {
2398
- command: he.commandName,
2257
+ command: ie.commandName,
2399
2258
  name: "y轴垂直基准线",
2400
- show: F(
2401
- () => I.value === 1 && !g.selectLines[0].userData.isDoor
2259
+ show: P(
2260
+ () => K.value === 1 && !D.selectLines[0].userData.isDoor
2402
2261
  ),
2403
- src: b["./assets/images/verticalLine.svg"].default,
2262
+ src: M["./assets/images/verticalLine.svg"].default,
2404
2263
  shortcut: "V"
2405
2264
  },
2406
2265
  {
2407
- command: me.commandName,
2266
+ command: ae.commandName,
2408
2267
  name: "角度显示",
2409
- show: F(() => I.value === 2 && g.selectLines[0].sameEndpoint(g.selectLines[1])),
2410
- src: b["./assets/images/angle.svg"].default,
2268
+ show: P(() => K.value === 2 && D.selectLines[0].sameEndpoint(D.selectLines[1])),
2269
+ src: M["./assets/images/angle.svg"].default,
2411
2270
  shortcut: "r"
2412
2271
  },
2413
2272
  {
2414
- command: ce.commandName,
2273
+ command: oe.commandName,
2415
2274
  name: "全选",
2416
- show: F(() => I.value !== w.renderManager.lines.length),
2417
- src: b["./assets/images/selectAll.svg"].default,
2275
+ show: P(() => K.value !== x.renderManager.lines.length),
2276
+ src: M["./assets/images/selectAll.svg"].default,
2418
2277
  shortcut: "Ctrl + A"
2419
2278
  },
2420
2279
  {
2421
- command: le.commandName,
2280
+ command: se.commandName,
2422
2281
  name: "清除窗户",
2423
- show: F(() => _.value),
2424
- src: b["./assets/images/deleteSelectWindow.svg"].default,
2282
+ show: P(() => W.value),
2283
+ src: M["./assets/images/deleteSelectWindow.svg"].default,
2425
2284
  shortcut: "Q + Delete"
2426
2285
  },
2427
2286
  {
2428
- command: ie.commandName,
2287
+ command: ee.commandName,
2429
2288
  name: "删除",
2430
- show: F(() => I.value > 0),
2431
- src: b["./assets/images/deleteSelectLine.svg"].default,
2289
+ show: P(() => K.value > 0),
2290
+ src: M["./assets/images/deleteSelectLine.svg"].default,
2432
2291
  shortcut: "Delete"
2433
2292
  }
2434
2293
  ];
2435
- ee(D, () => localStorage.setItem("editorToolPosition", JSON.stringify(D.value))), ee(m, () => localStorage.setItem("showShortcutKey", m.value + "")), ee(f, () => {
2436
- localStorage.setItem("toolBarExpand", f.value + ""), f.value && Ee(() => e(D.value.left, D.value.top));
2437
- }), ee(r, () => C.Variable.set("originalLineVisible", r.value)), ee(l, () => C.Variable.set("dxfVisible", l.value)), ee(i, () => C.Variable.set("whiteModelVisible", i.value)), C.Variable.addEventListener("isLook", (k) => d.value = k.value), C.Variable.addEventListener("originalLineVisible", (k) => r.value = k.value), C.Variable.addEventListener("dxfVisible", (k) => l.value = k.value), C.Variable.addEventListener("whiteModelVisible", (k) => i.value = k.value);
2438
- const V = w.commandManager.addEventListener("started", (k) => {
2439
- y.value = k.name;
2294
+ J(A, () => localStorage.setItem("editorToolPosition", JSON.stringify(A.value))), J(b, () => localStorage.setItem("showShortcutKey", b.value + "")), J(u, () => {
2295
+ localStorage.setItem("toolBarExpand", u.value + ""), u.value && we(() => e(A.value.left, A.value.top));
2296
+ }), J(r, () => g.Variable.set("originalLineVisible", r.value)), J(l, () => g.Variable.set("dxfVisible", l.value)), J(i, () => g.Variable.set("whiteModelVisible", i.value)), g.Variable.addEventListener("isLook", (C) => c.value = C.value), g.Variable.addEventListener("originalLineVisible", (C) => r.value = C.value), g.Variable.addEventListener("dxfVisible", (C) => l.value = C.value), g.Variable.addEventListener("whiteModelVisible", (C) => i.value = C.value);
2297
+ const mt = x.commandManager.addEventListener("started", (C) => {
2298
+ v.value = C.name;
2440
2299
  });
2441
- return localStorage.getItem("showShortcutKey") && (m.value = localStorage.getItem("showShortcutKey") === "true"), localStorage.getItem("toolBarExpand") && (f.value = localStorage.getItem("toolBarExpand") === "true"), ot(() => {
2442
- E.value.style.display = "none", setTimeout(() => {
2443
- if (E.value.style.display = "block", localStorage.getItem("editorToolPosition")) {
2444
- const { left: k, top: x } = JSON.parse(localStorage.getItem("editorToolPosition") ?? "{}");
2445
- e(k, x), Ee(() => j.observe(p.value));
2300
+ return localStorage.getItem("showShortcutKey") && (b.value = localStorage.getItem("showShortcutKey") === "true"), localStorage.getItem("toolBarExpand") && (u.value = localStorage.getItem("toolBarExpand") === "true"), tt(() => {
2301
+ y.value.style.display = "none", setTimeout(() => {
2302
+ if (y.value.style.display = "block", localStorage.getItem("editorToolPosition")) {
2303
+ const { left: C, top: p } = JSON.parse(localStorage.getItem("editorToolPosition") ?? "{}");
2304
+ e(C, p), we(() => he.observe(h.value));
2446
2305
  } else
2447
- Ee(() => j.observe(p.value));
2448
- }, 100), g.addEventListener("selectLineChange", () => {
2449
- I.value = g.selectLines.length, _.value = g.selectLines.some((k) => k.userData.isWindow);
2450
- }), ["rollback", "completed", "revokeRollback"].forEach((k) => {
2451
- w.commandManager.addEventListener(k, () => {
2306
+ we(() => he.observe(h.value));
2307
+ }, 100), D.addEventListener("selectLineChange", () => {
2308
+ K.value = D.selectLines.length, W.value = D.selectLines.some((C) => C.userData.isWindow);
2309
+ }), ["rollback", "completed", "revokeRollback"].forEach((C) => {
2310
+ x.commandManager.addEventListener(C, () => {
2452
2311
  setTimeout(() => {
2453
- M.value = w.commandManager.operationList.length, u.value = w.commandManager.rollbackList.length;
2312
+ Z.value = x.commandManager.operationList.length, G.value = x.commandManager.rollbackList.length;
2454
2313
  });
2455
2314
  });
2456
2315
  });
2457
2316
  }), Rt(() => {
2458
- v.mouseMoveEventProxylock = !1, V(), j.disconnect();
2459
- }), (k, x) => (K(), H("div", {
2317
+ E.mouseMoveEventProxylock = !1, mt(), he.disconnect();
2318
+ }), (C, p) => (I(), O("div", {
2460
2319
  ref_key: "elRef",
2461
- ref: p,
2320
+ ref: h,
2462
2321
  class: "editorTool pointer-events-none overflow-hidden absolute left-0 top-0 w-full h-full z-[20] flex flex-row justify-between p-[5px] box-border select-none pointer-events-[all]"
2463
2322
  }, [
2464
- J(Pe, null, {
2465
- default: q(() => [
2466
- m.value ? (K(), H("div", as, [
2467
- (K(), H(be, null, Ae(N, (P) => O("div", {
2323
+ F(xe, null, {
2324
+ default: j(() => [
2325
+ b.value ? (I(), O("div", as, [
2326
+ (I(), O(ve, null, ke(Ce, (w) => k("div", {
2468
2327
  class: "p-[4px_0px] flex justify-between text-right border-b-1 border-b-[rgba(255,255,255,0.1)] last-of-type:border-b-0",
2469
- key: P.name
2328
+ key: w.name
2470
2329
  }, [
2471
- O("p", is, pe(P.name), 1),
2472
- O("span", rs, pe(P.shortcut), 1)
2330
+ k("p", is, de(w.name), 1),
2331
+ k("span", rs, de(w.shortcut), 1)
2473
2332
  ])), 64))
2474
- ])) : ne("", !0)
2333
+ ])) : q("", !0)
2475
2334
  ]),
2476
2335
  _: 1
2477
2336
  }),
2478
- O("div", {
2337
+ k("div", {
2479
2338
  ref_key: "toolBarRef",
2480
- ref: E,
2481
- style: Re({ left: D.value.left + "px", top: D.value.top + "px" }),
2482
- class: Z(["overflow-hidden pointer-events-auto w-fit max-w-[260px] transition-[border-radius] text-[#333] absolute z-[11] bg-white select-none", { "rounded-[8px] ": f.value }]),
2483
- onMousedown: x[10] || (x[10] = (P) => P.stopPropagation())
2339
+ ref: y,
2340
+ style: Se({ left: A.value.left + "px", top: A.value.top + "px" }),
2341
+ class: V(["overflow-hidden pointer-events-auto w-fit max-w-[260px] transition-[border-radius] text-[#333] absolute z-[11] bg-white select-none", { "rounded-[8px] ": u.value }]),
2342
+ onMousedown: p[10] || (p[10] = (w) => w.stopPropagation())
2484
2343
  }, [
2485
- O("div", {
2344
+ k("div", {
2486
2345
  onMousedown: o,
2487
- class: Z([{ "border-b-[#eee] border-b-1": f.value }, "flex flex-row justify-between header text-[14px] font-bold p-[10px 0px]"])
2346
+ class: V([{ "border-b-[#eee] border-b-1": u.value }, "flex flex-row justify-between header text-[14px] font-bold p-[10px 0px]"])
2488
2347
  }, [
2489
- x[12] || (x[12] = Kt('<div class="flex flex-row" data-v-d89e5fb2><div class="p-[2px_5px] flex items-center pointer-events-none" data-v-d89e5fb2><svg fill="#aaa" width="20" height="20" viewBox="0 0 1024 1024" version="1.1" xmlns="http://www.w3.org/2000/svg" data-v-d89e5fb2><path d="M341.333333 298.666667a85.333333 85.333333 0 1 0 0-170.666667 85.333333 85.333333 0 0 0 0 170.666667z m0 298.666666a85.333333 85.333333 0 1 0 0-170.666666 85.333333 85.333333 0 0 0 0 170.666666z m85.333334 213.333334a85.333333 85.333333 0 1 1-170.666667 0 85.333333 85.333333 0 0 1 170.666667 0z m256-512a85.333333 85.333333 0 1 0 0-170.666667 85.333333 85.333333 0 0 0 0 170.666667z m85.333333 213.333333a85.333333 85.333333 0 1 1-170.666667 0 85.333333 85.333333 0 0 1 170.666667 0z m-85.333333 384a85.333333 85.333333 0 1 0 0-170.666667 85.333333 85.333333 0 0 0 0 170.666667z" data-v-d89e5fb2></path></svg></div><h5 class="flex text-nowrap text-[12px] items-center pointer-events-none" data-v-d89e5fb2>绘制工具</h5></div>', 1)),
2490
- O("div", {
2491
- onMousedown: x[0] || (x[0] = (P) => P.stopPropagation()),
2492
- onClick: x[1] || (x[1] = (P) => f.value = !f.value),
2348
+ p[12] || (p[12] = Kt('<div class="flex flex-row" data-v-09e4c536><div class="p-[2px_5px] flex items-center pointer-events-none" data-v-09e4c536><svg fill="#aaa" width="20" height="20" viewBox="0 0 1024 1024" version="1.1" xmlns="http://www.w3.org/2000/svg" data-v-09e4c536><path d="M341.333333 298.666667a85.333333 85.333333 0 1 0 0-170.666667 85.333333 85.333333 0 0 0 0 170.666667z m0 298.666666a85.333333 85.333333 0 1 0 0-170.666666 85.333333 85.333333 0 0 0 0 170.666666z m85.333334 213.333334a85.333333 85.333333 0 1 1-170.666667 0 85.333333 85.333333 0 0 1 170.666667 0z m256-512a85.333333 85.333333 0 1 0 0-170.666667 85.333333 85.333333 0 0 0 0 170.666667z m85.333333 213.333333a85.333333 85.333333 0 1 1-170.666667 0 85.333333 85.333333 0 0 1 170.666667 0z m-85.333333 384a85.333333 85.333333 0 1 0 0-170.666667 85.333333 85.333333 0 0 0 0 170.666667z" data-v-09e4c536></path></svg></div><h5 class="flex text-nowrap text-[12px] items-center pointer-events-none" data-v-09e4c536>绘制工具</h5></div>', 1)),
2349
+ k("div", {
2350
+ onMousedown: p[0] || (p[0] = (w) => w.stopPropagation()),
2351
+ onClick: p[1] || (p[1] = (w) => u.value = !u.value),
2493
2352
  class: "cursor-pointer flex items-center p-[0px_5px]"
2494
2353
  }, [
2495
- (K(), H("svg", {
2354
+ (I(), O("svg", {
2496
2355
  fill: "#666",
2497
- class: Z([{ "rotate-90": f.value }, "transition-all"]),
2356
+ class: V([{ "rotate-90": u.value }, "transition-all"]),
2498
2357
  viewBox: "0 0 1024 1024",
2499
2358
  version: "1.1",
2500
2359
  xmlns: "http://www.w3.org/2000/svg",
2501
2360
  width: "12",
2502
2361
  height: "12"
2503
- }, x[11] || (x[11] = [
2504
- O("path", { d: "M315.050667 938.666667a60.757333 60.757333 0 0 0 41.813333-16.298667L750.933333 551.338667a53.418667 53.418667 0 0 0 0-78.677334L356.864 101.632a61.696 61.696 0 0 0-83.541333 0 53.418667 53.418667 0 0 0-0.256 78.677333L625.408 512 273.066667 843.690667a53.418667 53.418667 0 0 0 0 78.677333 60.757333 60.757333 0 0 0 41.984 16.298667z" }, null, -1)
2362
+ }, p[11] || (p[11] = [
2363
+ k("path", { d: "M315.050667 938.666667a60.757333 60.757333 0 0 0 41.813333-16.298667L750.933333 551.338667a53.418667 53.418667 0 0 0 0-78.677334L356.864 101.632a61.696 61.696 0 0 0-83.541333 0 53.418667 53.418667 0 0 0-0.256 78.677333L625.408 512 273.066667 843.690667a53.418667 53.418667 0 0 0 0 78.677333 60.757333 60.757333 0 0 0 41.984 16.298667z" }, null, -1)
2505
2364
  ]), 2))
2506
2365
  ], 32)
2507
2366
  ], 34),
2508
- f.value ? (K(), H("div", ds, [
2509
- O("ul", ls, [
2510
- (K(), H(be, null, Ae(G, (P) => (K(), H(be, {
2511
- key: P.command
2367
+ u.value ? (I(), O("div", ds, [
2368
+ k("ul", ls, [
2369
+ (I(), O(ve, null, ke(lt, (w) => (I(), O(ve, {
2370
+ key: w.command
2512
2371
  }, [
2513
- P.show ? (K(), H("li", {
2372
+ w.show ? (I(), O("li", {
2514
2373
  key: 0,
2515
- onClick: (te) => t(P),
2516
- class: Z([{
2517
- "!bg-[var(--primary-color)] text-[#fff]": y.value === P.command,
2518
- "!cursor-no-drop": y.value !== P.command && y.value !== "default"
2374
+ onClick: (U) => t(w),
2375
+ class: V([{
2376
+ "!bg-[var(--primary-color)] text-[#fff]": v.value === w.command,
2377
+ "!cursor-no-drop": v.value !== w.command && v.value !== "default"
2519
2378
  }, "gap-[10px] text-[12px] hover:bg-[#ddd] transition-all rounded-[6px] p-[5px] flex flex-row items-center justify-between cursor-pointer"])
2520
2379
  }, [
2521
- O("div", ms, [
2522
- O("div", hs, [
2523
- O("img", {
2380
+ k("div", ms, [
2381
+ k("div", hs, [
2382
+ k("img", {
2524
2383
  class: "size-[14px]",
2525
- src: P.src,
2384
+ src: w.src,
2526
2385
  alt: "",
2527
2386
  srcset: ""
2528
2387
  }, null, 8, us)
2529
2388
  ]),
2530
- O("span", ps, pe(P.name), 1)
2389
+ k("span", ps, de(w.name), 1)
2531
2390
  ]),
2532
- y.value === P.command ? (K(), H("div", {
2391
+ v.value === w.command ? (I(), O("div", {
2533
2392
  key: 0,
2534
2393
  title: "取消命令(Esc)",
2535
2394
  class: "active:scale-[0.7] transition-all",
2536
- onClick: x[2] || (x[2] = (te) => (L(w).cancelCommand(), te.stopPropagation()))
2537
- }, x[13] || (x[13] = [
2538
- O("svg", {
2395
+ onClick: p[2] || (p[2] = (U) => (f(x).cancelCommand(), U.stopPropagation()))
2396
+ }, p[13] || (p[13] = [
2397
+ k("svg", {
2539
2398
  fill: "#fff",
2540
2399
  width: "16",
2541
2400
  height: "16",
@@ -2543,118 +2402,118 @@ const as = {
2543
2402
  version: "1.1",
2544
2403
  xmlns: "http://www.w3.org/2000/svg"
2545
2404
  }, [
2546
- O("path", { d: "M511.104 0C228.821333 0 0 228.821333 0 511.104c0 282.282667 228.821333 511.104 511.104 511.104 282.282667 0 511.104-228.842667 511.104-511.104C1022.208 228.821333 793.386667 0 511.104 0zM511.104 898.496c-213.973333 0-387.434667-173.44-387.434667-387.413333 0-213.952 173.44-387.413333 387.434667-387.413333 213.952 0 387.392 173.44 387.392 387.413333C898.496 725.056 725.056 898.496 511.104 898.496z" }),
2547
- O("path", { d: "M236.437333 463.914667l549.333333 0 0 96.874667-549.333333 0 0-96.874667Z" })
2405
+ k("path", { d: "M511.104 0C228.821333 0 0 228.821333 0 511.104c0 282.282667 228.821333 511.104 511.104 511.104 282.282667 0 511.104-228.842667 511.104-511.104C1022.208 228.821333 793.386667 0 511.104 0zM511.104 898.496c-213.973333 0-387.434667-173.44-387.434667-387.413333 0-213.952 173.44-387.413333 387.434667-387.413333 213.952 0 387.392 173.44 387.392 387.413333C898.496 725.056 725.056 898.496 511.104 898.496z" }),
2406
+ k("path", { d: "M236.437333 463.914667l549.333333 0 0 96.874667-549.333333 0 0-96.874667Z" })
2548
2407
  ], -1)
2549
- ]))) : P.shortcut ? (K(), H("div", gs, pe(P.shortcut), 1)) : ne("", !0)
2550
- ], 10, cs)) : ne("", !0)
2408
+ ]))) : w.shortcut ? (I(), O("div", gs, de(w.shortcut), 1)) : q("", !0)
2409
+ ], 10, cs)) : q("", !0)
2551
2410
  ], 64))), 64))
2552
2411
  ]),
2553
- O("div", vs, [
2554
- J(L(Ve), {
2412
+ k("div", vs, [
2413
+ F(f(Ke), {
2555
2414
  size: "small",
2556
- modelValue: m.value,
2557
- "onUpdate:modelValue": x[3] || (x[3] = (P) => m.value = P),
2415
+ modelValue: b.value,
2416
+ "onUpdate:modelValue": p[3] || (p[3] = (w) => b.value = w),
2558
2417
  label: "快捷键提示"
2559
2418
  }, null, 8, ["modelValue"]),
2560
- J(L(Ve), {
2419
+ F(f(Ke), {
2561
2420
  size: "small",
2562
2421
  modelValue: l.value,
2563
- "onUpdate:modelValue": x[4] || (x[4] = (P) => l.value = P),
2422
+ "onUpdate:modelValue": p[4] || (p[4] = (w) => l.value = w),
2564
2423
  label: "dxf"
2565
2424
  }, null, 8, ["modelValue"])
2566
2425
  ]),
2567
- k.permission === "admin" ? (K(), H("div", fs, [
2568
- J(L(ue), {
2426
+ C.permission === "admin" ? (I(), O("div", fs, [
2427
+ F(f(re), {
2569
2428
  style: { padding: "5px", "font-size": "10px" },
2570
2429
  size: "small",
2571
2430
  type: "success",
2572
2431
  onClick: s
2573
2432
  }, {
2574
- default: q(() => x[14] || (x[14] = [
2575
- se(" 选择文件 ", -1)
2433
+ default: j(() => p[14] || (p[14] = [
2434
+ Y(" 选择文件 ", -1)
2576
2435
  ])),
2577
2436
  _: 1,
2578
2437
  __: [14]
2579
2438
  }),
2580
- J(L(ue), {
2439
+ F(f(re), {
2581
2440
  style: { padding: "5px", "font-size": "10px" },
2582
2441
  size: "small",
2583
2442
  type: "primary",
2584
- onClick: x[5] || (x[5] = (P) => console.log(L(C).Dxf.originalData))
2443
+ onClick: p[5] || (p[5] = (w) => f(g).Dxf.downloadOriginalData("json.json"))
2585
2444
  }, {
2586
- default: q(() => x[15] || (x[15] = [
2587
- se(" 打印Json ", -1)
2445
+ default: j(() => p[15] || (p[15] = [
2446
+ Y(" 下载Json ", -1)
2588
2447
  ])),
2589
2448
  _: 1,
2590
2449
  __: [15]
2591
2450
  }),
2592
- J(L(ue), {
2451
+ F(f(re), {
2593
2452
  style: { padding: "5px", "font-size": "10px" },
2594
2453
  size: "small",
2595
2454
  type: "primary",
2596
- onClick: x[6] || (x[6] = (P) => L(C).AngleCorrectionDxf.download("test.dxf"))
2455
+ onClick: p[6] || (p[6] = (w) => f(g).AngleCorrectionDxf.download("test.dxf"))
2597
2456
  }, {
2598
- default: q(() => x[16] || (x[16] = [
2599
- se(" 下载DXF ", -1)
2457
+ default: j(() => p[16] || (p[16] = [
2458
+ Y(" 下载DXF ", -1)
2600
2459
  ])),
2601
2460
  _: 1,
2602
2461
  __: [16]
2603
2462
  }),
2604
- J(L(ue), {
2463
+ F(f(re), {
2605
2464
  style: { padding: "5px", "font-size": "10px" },
2606
2465
  size: "small",
2607
2466
  type: "primary",
2608
- onClick: x[7] || (x[7] = (P) => L(C).AngleCorrectionDxf.downloadImage("dxf.jpg"))
2467
+ onClick: p[7] || (p[7] = (w) => f(g).AngleCorrectionDxf.downloadImage("dxf.jpg"))
2609
2468
  }, {
2610
- default: q(() => x[17] || (x[17] = [
2611
- se(" 下载JPG ", -1)
2469
+ default: j(() => p[17] || (p[17] = [
2470
+ Y(" 下载JPG ", -1)
2612
2471
  ])),
2613
2472
  _: 1,
2614
2473
  __: [17]
2615
2474
  }),
2616
- J(L(ue), {
2475
+ F(f(re), {
2617
2476
  style: { padding: "5px", "font-size": "10px" },
2618
2477
  size: "small",
2619
2478
  type: "primary",
2620
- onClick: x[8] || (x[8] = (P) => L(S).downloadGltf("test.glb", !0))
2479
+ onClick: p[8] || (p[8] = (w) => f(z).downloadGltf("test.glb", !0))
2621
2480
  }, {
2622
- default: q(() => x[18] || (x[18] = [
2623
- se(" 下载白膜 ", -1)
2481
+ default: j(() => p[18] || (p[18] = [
2482
+ Y(" 下载白膜 ", -1)
2624
2483
  ])),
2625
2484
  _: 1,
2626
2485
  __: [18]
2627
2486
  }),
2628
- J(L(ue), {
2487
+ F(f(re), {
2629
2488
  style: { padding: "5px", "font-size": "10px" },
2630
2489
  size: "small",
2631
2490
  type: "primary",
2632
- onClick: x[9] || (x[9] = (P) => L(A).download())
2491
+ onClick: p[9] || (p[9] = (w) => f(me).download())
2633
2492
  }, {
2634
- default: q(() => x[19] || (x[19] = [
2635
- se(" 下载三维家JSON ", -1)
2493
+ default: j(() => p[19] || (p[19] = [
2494
+ Y(" 下载三维家JSON ", -1)
2636
2495
  ])),
2637
2496
  _: 1,
2638
2497
  __: [19]
2639
2498
  })
2640
- ])) : ne("", !0),
2641
- J(Pe, null, {
2642
- default: q(() => [
2643
- O("div", ys, [
2644
- J(Ft, null, {
2645
- default: q(() => [
2646
- (K(), H(be, null, Ae(Y, (P) => O("div", {
2647
- onClick: (te) => P.show.value && y.value === "default" && (P.action ? P.action() : L(w).commandManager.start(P.command, [...L(g).selectLines])),
2648
- title: `${P.name}(${P.shortcut})`,
2649
- class: Z(["size-[20px] flex justify-center items-center relative overflow-hidden active:scale-[0.8] border-1 border-[#ccc] rounded-[4px] transition-all cursor-pointer", {
2650
- "opacity-30 bg-[#ccc] !cursor-no-drop active:!scale-[1]": !P.show.value || y.value !== "default",
2651
- [P.class ?? ""]: !0
2499
+ ])) : q("", !0),
2500
+ F(xe, null, {
2501
+ default: j(() => [
2502
+ k("div", ys, [
2503
+ F(Ft, null, {
2504
+ default: j(() => [
2505
+ (I(), O(ve, null, ke(ct, (w) => k("div", {
2506
+ onClick: (U) => w.show.value && v.value === "default" && (w.action ? w.action() : f(x).commandManager.start(w.command, [...f(D).selectLines])),
2507
+ title: `${w.name}(${w.shortcut})`,
2508
+ class: V(["size-[20px] flex justify-center items-center relative overflow-hidden active:scale-[0.8] border-1 border-[#ccc] rounded-[4px] transition-all cursor-pointer", {
2509
+ "opacity-30 bg-[#ccc] !cursor-no-drop active:!scale-[1]": !w.show.value || v.value !== "default",
2510
+ [w.class ?? ""]: !0
2652
2511
  }]),
2653
- key: P.command
2512
+ key: w.command
2654
2513
  }, [
2655
- O("img", {
2514
+ k("img", {
2656
2515
  class: "size-[14px]",
2657
- src: P.src
2516
+ src: w.src
2658
2517
  }, null, 8, bs)
2659
2518
  ], 10, ws)), 64))
2660
2519
  ]),
@@ -2664,19 +2523,19 @@ const as = {
2664
2523
  ]),
2665
2524
  _: 1
2666
2525
  })
2667
- ])) : ne("", !0)
2526
+ ])) : q("", !0)
2668
2527
  ], 38)
2669
2528
  ], 512));
2670
2529
  }
2671
- }), Cs = (c, e) => {
2672
- const t = c.__vccOpts || c;
2530
+ }), Cs = (d, e) => {
2531
+ const t = d.__vccOpts || d;
2673
2532
  for (const [n, s] of e)
2674
2533
  t[n] = s;
2675
2534
  return t;
2676
- }, Es = /* @__PURE__ */ Cs(xs, [["__scopeId", "data-v-d89e5fb2"]]);
2677
- let mt = class extends Oe {
2535
+ }, Es = /* @__PURE__ */ Cs(xs, [["__scopeId", "data-v-09e4c536"]]);
2536
+ let dt = class extends Ae {
2678
2537
  static name = "Editor";
2679
- container = new h.Group();
2538
+ container = new m.Group();
2680
2539
  get renderer() {
2681
2540
  return this.parent?.findComponentByName("Renderer");
2682
2541
  }
@@ -2699,7 +2558,7 @@ let mt = class extends Oe {
2699
2558
  return this.parent?.findComponentByName("DomContainer");
2700
2559
  }
2701
2560
  commandManager = new bn();
2702
- plane = new h.Mesh(new h.PlaneGeometry(2e3, 2e3, 2, 2));
2561
+ plane = new m.Mesh(new m.PlaneGeometry(2e3, 2e3, 2, 2));
2703
2562
  app;
2704
2563
  domElement = document.createElement("div");
2705
2564
  viewPermission;
@@ -2722,7 +2581,7 @@ let mt = class extends Oe {
2722
2581
  }
2723
2582
  onAddFromParent(e) {
2724
2583
  setTimeout(() => this.openEdit(), 10);
2725
- const t = new h.GridHelper(200, 100, 6710886, 4473924);
2584
+ const t = new m.GridHelper(200, 100, 6710886, 4473924);
2726
2585
  t.rotation.x = Math.PI * 0.5, t.position.z = -0.01, this.container.add(t), this.container.add(this.plane), this.plane.visible = !1;
2727
2586
  const n = this.addEventListener("update", () => {
2728
2587
  this.domContainer.domElement.parentElement && (this.domContainer.domElement.parentElement.appendChild(this.domElement), this.domContainer.domElement.parentElement.appendChild(this.imgEl), n());
@@ -2757,27 +2616,27 @@ let mt = class extends Oe {
2757
2616
  type: "cancelCommand"
2758
2617
  });
2759
2618
  }
2760
- coords = new h.Vector2();
2761
- pointerPosition = new h.Vector2();
2619
+ coords = new m.Vector2();
2620
+ pointerPosition = new m.Vector2();
2762
2621
  _exitEditCallBack;
2763
2622
  /**
2764
2623
  * 打开编辑器
2765
2624
  */
2766
2625
  openEdit() {
2767
- const e = this.renderer, t = this.domEventRegister, n = this.dxf, s = e.orbitControls, o = e.camera, a = n.box.center, r = e.camera.position.clone(), l = s?.target?.clone(), i = new h.Vector2(), d = new h.Raycaster(), p = this.coords, E = this.pointerPosition;
2626
+ const e = this.renderer, t = this.domEventRegister, n = this.dxf, s = e.orbitControls, o = e.camera, a = n.box.center, r = e.camera.position.clone(), l = s?.target?.clone(), i = new m.Vector2(), c = new m.Raycaster(), h = this.coords, y = this.pointerPosition;
2768
2627
  this.container.position.z = n.originalZAverage, e.scene.add(this.container), s && (o.position.set(a.x, a.y, 15), s.target.set(a.x, a.y, 0), s.enableRotate = !1);
2769
- const f = () => {
2628
+ const u = () => {
2770
2629
  e.renderer.getSize(i);
2771
- const y = t.pointer.x / i.x * 2 - 1, C = -(t.pointer.y / i.y * 2 - 1);
2772
- p.set(y, C), d.setFromCamera(p, e.camera.children.length ? e.camera.children[0] : e.camera);
2773
- const v = d.intersectObject(this.plane);
2774
- v.length && (E.copy(v[0].point), this.dispatchEvent({
2630
+ const v = t.pointer.x / i.x * 2 - 1, g = -(t.pointer.y / i.y * 2 - 1);
2631
+ h.set(v, g), c.setFromCamera(h, e.camera.children.length ? e.camera.children[0] : e.camera);
2632
+ const E = c.intersectObject(this.plane);
2633
+ E.length && (y.copy(E[0].point), this.dispatchEvent({
2775
2634
  type: "pointerPositionChange",
2776
- position: E
2635
+ position: y
2777
2636
  }));
2778
2637
  };
2779
- t.addEventListener("mousemove", f), this.commandManager.disabled = !1, this.commandManager.start("default"), this._exitEditCallBack = () => {
2780
- t.removeEventListener("mousemove", f), s && (o.position.copy(r), s.enableRotate = !0, s.target.copy(l));
2638
+ t.addEventListener("mousemove", u), this.commandManager.disabled = !1, this.commandManager.start("default"), this._exitEditCallBack = () => {
2639
+ t.removeEventListener("mousemove", u), s && (o.position.copy(r), s.enableRotate = !0, s.target.copy(l));
2781
2640
  };
2782
2641
  }
2783
2642
  /**
@@ -2790,9 +2649,9 @@ let mt = class extends Oe {
2790
2649
  super.destroy(), this.exitEdit(), this.renderer.scene.remove(this.container), this.domElement.remove(), this.app?.unmount();
2791
2650
  }
2792
2651
  };
2793
- class Ms extends W {
2652
+ class Ms extends R {
2794
2653
  static name = "PointDrag";
2795
- container = new h.Group();
2654
+ container = new m.Group();
2796
2655
  interruptKeys = ["escape"];
2797
2656
  shortcutKeys = ["control", "p"];
2798
2657
  commandName = "point";
@@ -2805,7 +2664,7 @@ class Ms extends W {
2805
2664
  * @param next
2806
2665
  */
2807
2666
  selectPoint(e) {
2808
- let t = null, n = new h.Mesh(new h.SphereGeometry(0.04), new h.MeshBasicMaterial({ color: 16711935 })), s = null;
2667
+ let t = null, n = new m.Mesh(new m.SphereGeometry(0.04), new m.MeshBasicMaterial({ color: 16711935 })), s = null;
2809
2668
  this.addEventRecord("selectPointStart").add(this.editor.addEventListener("pointerPositionChange", () => {
2810
2669
  const { point: o, line: a, find: r, mode: l } = this.editor.renderManager.adsorption();
2811
2670
  this.dispatchEvent({ type: "pointerMove", point: o }), r && l === "point" ? (this.domElement.style.cursor = "none", n.position.copy(o), s = a, t = o.clone(), this.container.add(n)) : (this.domElement.style.cursor = "no-drop", t = null, n.removeFromParent());
@@ -2820,15 +2679,15 @@ class Ms extends W {
2820
2679
  */
2821
2680
  drag(e, { point: t, line: n }) {
2822
2681
  this.domElement.style.cursor = "crosshair";
2823
- const s = n.start.equal(R.from(t)) ? "start" : "end", o = s == "start" ? new h.Vector3(n.end.x, n.end.y, 0) : new h.Vector3(n.start.x, n.start.y, 0), a = t.clone(), r = new Ce([o, a], 16711935), l = new h.Mesh(new h.SphereGeometry(0.03), new h.MeshBasicMaterial({ color: 16711935 }));
2682
+ const s = n.start.equal(_.from(t)) ? "start" : "end", o = s == "start" ? new m.Vector3(n.end.x, n.end.y, 0) : new m.Vector3(n.start.x, n.start.y, 0), a = t.clone(), r = new ye([o, a], 16711935), l = new m.Mesh(new m.SphereGeometry(0.03), new m.MeshBasicMaterial({ color: 16711935 }));
2824
2683
  this.container.add(r), this.addEventRecord("clear").add(this.editor.addEventListener("pointerPositionChange", () => {
2825
- let { point: i, find: d } = this.editor.renderManager.adsorption(), p = "none";
2684
+ let { point: i, find: c } = this.editor.renderManager.adsorption(), h = "none";
2826
2685
  if (i) {
2827
2686
  if (this.dispatchEvent({ type: "pointerMove", point: i }), this.eventInput.isKeyDown("shift")) {
2828
- const E = n.projectPoint(R.from(i), !1);
2829
- i.set(E?.x ?? i.x, E?.y ?? i.y, 0), d = !0, p = "crosshair";
2687
+ const y = n.projectPoint(_.from(i), !1);
2688
+ i.set(y?.x ?? i.x, y?.y ?? i.y, 0), c = !0, h = "crosshair";
2830
2689
  }
2831
- d ? (l.position.copy(i), this.container.add(l)) : (l.removeFromParent(), p = "crosshair"), a.copy(i), r.setPoint(o, a), this.domElement.style.cursor = p;
2690
+ c ? (l.position.copy(i), this.container.add(l)) : (l.removeFromParent(), h = "crosshair"), a.copy(i), r.setPoint(o, a), this.domElement.style.cursor = h;
2832
2691
  }
2833
2692
  })).add(this.eventInput.addEventListener("codeChange", () => {
2834
2693
  this.eventInput.isKeyDown("mouse_0") && (this.canceEventRecord("selectPointStart"), e({ point: a, oldPoint: s === "end" ? n.end.clone() : n.start.clone(), line: n, mode: s }));
@@ -2855,15 +2714,15 @@ class Ms extends W {
2855
2714
  return this.completed(e), e;
2856
2715
  }
2857
2716
  }
2858
- function Ye(c, e = {}) {
2859
- c.addComponent(new mt(e.viewPermission)), c.addComponent(new ns()), c.addComponent(new Ke()), c.addComponent(new yn()), c.addComponent(new ss()), c.addComponent(new os()), c.addComponent(new Ms()), c.addComponent(new ie()), c.addComponent(new ae()), c.addComponent(new oe()), c.addComponent(new re()), c.addComponent(new de()), c.addComponent(new le()), c.addComponent(new ce()), c.addComponent(new me()), c.addComponent(new he()), c.addComponent(new ct());
2717
+ function Je(d, e = {}) {
2718
+ d.addComponent(new dt(e.viewPermission)), d.addComponent(new ns()), d.addComponent(new _e()), d.addComponent(new yn()), d.addComponent(new ss()), d.addComponent(new os()), d.addComponent(new Ms()), d.addComponent(new ee()), d.addComponent(new $()), d.addComponent(new X()), d.addComponent(new te()), d.addComponent(new ne()), d.addComponent(new se()), d.addComponent(new oe()), d.addComponent(new ae()), d.addComponent(new ie()), d.addComponent(new rt());
2860
2719
  }
2861
- const _s = Object.assign(Ye, {
2862
- create(c = {}) {
2863
- return (e) => Ye(e, c);
2720
+ const _s = Object.assign(Je, {
2721
+ create(d = {}) {
2722
+ return (e) => Je(e, d);
2864
2723
  }
2865
2724
  });
2866
2725
  export {
2867
2726
  _s as Editor,
2868
- Ye as Editor_
2727
+ Je as Editor_
2869
2728
  };