@duxweb/dvha-pro 1.0.24 → 1.0.25

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (120) hide show
  1. package/dist/cjs/component.cjs +1 -1
  2. package/dist/cjs/components/chart/echart.cjs +1 -1
  3. package/dist/cjs/components/crop/imageCrop.cjs +1 -1
  4. package/dist/cjs/components/data/dynamicSelect.cjs +1 -1
  5. package/dist/cjs/components/data/selectModal.cjs +1 -1
  6. package/dist/cjs/components/form/drawerForm.cjs +1 -1
  7. package/dist/cjs/components/form/modalForm.cjs +1 -1
  8. package/dist/cjs/components/form/pageForm.cjs +1 -1
  9. package/dist/cjs/components/form/settingForm.cjs +1 -1
  10. package/dist/cjs/components/icon/icon.cjs +1 -1
  11. package/dist/cjs/components/image/components/CanvasRuler.cjs +1 -0
  12. package/dist/cjs/components/image/elements/circle.cjs +1 -0
  13. package/dist/cjs/components/image/elements/image.cjs +1 -0
  14. package/dist/cjs/components/image/elements/index.cjs +1 -0
  15. package/dist/cjs/components/image/elements/rect.cjs +1 -0
  16. package/dist/cjs/components/image/elements/text.cjs +1 -0
  17. package/dist/cjs/components/image/hooks/usePosterEditor.cjs +1 -0
  18. package/dist/cjs/components/image/pages/LeftToolbar.cjs +1 -0
  19. package/dist/cjs/components/image/pages/Panel.cjs +1 -0
  20. package/dist/cjs/components/image/pages/PanelItem.cjs +1 -0
  21. package/dist/cjs/components/image/pages/RightPanel.cjs +1 -0
  22. package/dist/cjs/components/image/posterEditor.cjs +1 -0
  23. package/dist/cjs/components/layout/list.cjs +1 -1
  24. package/dist/cjs/components/layout/table.cjs +1 -1
  25. package/dist/cjs/components/level/level.cjs +1 -1
  26. package/dist/cjs/components/table/table.cjs +1 -1
  27. package/dist/cjs/components/upload/file.cjs +1 -1
  28. package/dist/cjs/components/upload/image.cjs +1 -1
  29. package/dist/cjs/components/upload/manage/item.cjs +1 -1
  30. package/dist/cjs/components/upload/manager.cjs +1 -1
  31. package/dist/cjs/hooks/dialog.cjs +1 -1
  32. package/dist/cjs/hooks/drawer.cjs +1 -1
  33. package/dist/cjs/hooks/modal.cjs +1 -1
  34. package/dist/cjs/hooks/table/image.cjs +1 -1
  35. package/dist/cjs/hooks/table/media.cjs +1 -1
  36. package/dist/cjs/index.cjs +1 -1
  37. package/dist/cjs/pages/authLayout.cjs +1 -1
  38. package/dist/cjs/pages/layout/page.cjs +1 -1
  39. package/dist/cjs/pages/layout.cjs +1 -1
  40. package/dist/cjs/pages/login.cjs +1 -1
  41. package/dist/cjs/pages/menu/avatar.cjs +1 -1
  42. package/dist/cjs/pages/menu/button.cjs +1 -1
  43. package/dist/cjs/pages/menu/cmd.cjs +1 -1
  44. package/dist/cjs/pages/menu/main.cjs +1 -1
  45. package/dist/cjs/pages/menu/mobile.cjs +1 -1
  46. package/dist/cjs/pages/page404.cjs +1 -1
  47. package/dist/cjs/pages/pageStatus.cjs +1 -1
  48. package/dist/cjs/theme/uno.css.cjs +25 -1
  49. package/dist/esm/component.js +49 -47
  50. package/dist/esm/components/chart/echart.js +15 -13
  51. package/dist/esm/components/crop/imageCrop.js +15 -13
  52. package/dist/esm/components/data/dynamicSelect.js +15 -13
  53. package/dist/esm/components/data/selectModal.js +20 -18
  54. package/dist/esm/components/form/drawerForm.js +21 -19
  55. package/dist/esm/components/form/modalForm.js +15 -13
  56. package/dist/esm/components/form/pageForm.js +13 -11
  57. package/dist/esm/components/form/settingForm.js +12 -10
  58. package/dist/esm/components/icon/icon.js +15 -13
  59. package/dist/esm/components/image/components/CanvasRuler.js +113 -0
  60. package/dist/esm/components/image/elements/circle.js +127 -0
  61. package/dist/esm/components/image/elements/image.js +131 -0
  62. package/dist/esm/components/image/elements/index.js +46 -0
  63. package/dist/esm/components/image/elements/rect.js +171 -0
  64. package/dist/esm/components/image/elements/text.js +206 -0
  65. package/dist/esm/components/image/hooks/usePosterEditor.js +434 -0
  66. package/dist/esm/components/image/pages/LeftToolbar.js +40 -0
  67. package/dist/esm/components/image/pages/Panel.js +31 -0
  68. package/dist/esm/components/image/pages/PanelItem.js +22 -0
  69. package/dist/esm/components/image/pages/RightPanel.js +421 -0
  70. package/dist/esm/components/image/posterEditor.js +227 -0
  71. package/dist/esm/components/layout/list.js +16 -14
  72. package/dist/esm/components/layout/table.js +16 -14
  73. package/dist/esm/components/level/level.js +15 -13
  74. package/dist/esm/components/table/table.js +15 -13
  75. package/dist/esm/components/upload/file.js +98 -88
  76. package/dist/esm/components/upload/image.js +106 -94
  77. package/dist/esm/components/upload/manage/item.js +15 -13
  78. package/dist/esm/components/upload/manager.js +65 -63
  79. package/dist/esm/hooks/dialog.js +15 -13
  80. package/dist/esm/hooks/drawer.js +15 -13
  81. package/dist/esm/hooks/modal.js +15 -13
  82. package/dist/esm/hooks/table/image.js +15 -13
  83. package/dist/esm/hooks/table/media.js +15 -13
  84. package/dist/esm/index.js +213 -202
  85. package/dist/esm/pages/authLayout.js +15 -13
  86. package/dist/esm/pages/layout/page.js +15 -13
  87. package/dist/esm/pages/layout.js +7 -6
  88. package/dist/esm/pages/login.js +16 -15
  89. package/dist/esm/pages/menu/avatar.js +15 -13
  90. package/dist/esm/pages/menu/button.js +15 -13
  91. package/dist/esm/pages/menu/cmd.js +26 -24
  92. package/dist/esm/pages/menu/main.js +25 -23
  93. package/dist/esm/pages/menu/mobile.js +15 -13
  94. package/dist/esm/pages/page404.js +13 -11
  95. package/dist/esm/pages/pageStatus.js +15 -13
  96. package/dist/esm/theme/uno.css.js +25 -1
  97. package/dist/types/components/image/components/CanvasRuler.d.ts +43 -0
  98. package/dist/types/components/image/components/index.d.ts +1 -0
  99. package/dist/types/components/image/elements/circle.d.ts +3 -0
  100. package/dist/types/components/image/elements/image.d.ts +3 -0
  101. package/dist/types/components/image/elements/index.d.ts +15 -0
  102. package/dist/types/components/image/elements/rect.d.ts +3 -0
  103. package/dist/types/components/image/elements/text.d.ts +3 -0
  104. package/dist/types/components/image/elements/types.d.ts +51 -0
  105. package/dist/types/components/image/hooks/index.d.ts +1 -0
  106. package/dist/types/components/image/hooks/usePosterEditor.d.ts +48 -0
  107. package/dist/types/components/image/index.d.ts +4 -0
  108. package/dist/types/components/image/pages/LeftToolbar.d.ts +33 -0
  109. package/dist/types/components/image/pages/Panel.d.ts +11 -0
  110. package/dist/types/components/image/pages/PanelItem.d.ts +11 -0
  111. package/dist/types/components/image/pages/RightPanel.d.ts +208 -0
  112. package/dist/types/components/image/pages/index.d.ts +4 -0
  113. package/dist/types/components/image/posterEditor.d.ts +61 -0
  114. package/dist/types/components/image/types/editor.d.ts +47 -0
  115. package/dist/types/components/index.d.ts +2 -2
  116. package/dist/types/components/stats/number.d.ts +1 -1
  117. package/dist/types/components/upload/file.d.ts +5 -3
  118. package/dist/types/index.d.ts +1 -0
  119. package/dist/types/pages/layout/global.d.ts +0 -1
  120. package/package.json +6 -3
@@ -13,6 +13,17 @@ import "@tanstack/vue-query";
13
13
  import "@duxweb/dvha-naiveui";
14
14
  import "@vueuse/core";
15
15
  import "pinia";
16
+ import "vue3-ace-editor";
17
+ import "ace-builds/src-noconflict/mode-vue";
18
+ import "ace-builds/src-noconflict/mode-javascript";
19
+ import "ace-builds/src-noconflict/mode-html";
20
+ import "ace-builds/src-noconflict/mode-json";
21
+ import "ace-builds/src-noconflict/mode-json5";
22
+ import "ace-builds/src-noconflict/theme-tomorrow_night";
23
+ import "ace-builds/src-noconflict/theme-tomorrow";
24
+ import "ace-builds/src-noconflict/ext-searchbox";
25
+ import "ace-builds/src-noconflict/ext-language_tools";
26
+ import "ace-builds/src-noconflict/mode-snippets";
16
27
  import "vue-cropper";
17
28
  import "jinrishici";
18
29
  import "vue-draggable-plus";
@@ -31,18 +42,9 @@ import G from "./button.js";
31
42
  import "vue-command-palette";
32
43
  import "../page404.js";
33
44
  import "@iconify-json/tabler/icons.json";
34
- import "vue3-ace-editor";
35
- import "ace-builds/src-noconflict/mode-vue";
36
- import "ace-builds/src-noconflict/mode-javascript";
37
- import "ace-builds/src-noconflict/mode-html";
38
- import "ace-builds/src-noconflict/mode-json";
39
- import "ace-builds/src-noconflict/mode-json5";
40
- import "ace-builds/src-noconflict/theme-tomorrow_night";
41
- import "ace-builds/src-noconflict/theme-tomorrow";
42
- import "ace-builds/src-noconflict/ext-searchbox";
43
- import "ace-builds/src-noconflict/ext-language_tools";
44
- import "ace-builds/src-noconflict/mode-snippets";
45
- const $e = /* @__PURE__ */ A({
45
+ import "../../components/image/elements/index.js";
46
+ import "fabric";
47
+ const Ae = /* @__PURE__ */ A({
46
48
  name: "DuxMenuAvatar",
47
49
  props: {
48
50
  collapsed: {
@@ -229,5 +231,5 @@ const $e = /* @__PURE__ */ A({
229
231
  }
230
232
  });
231
233
  export {
232
- $e as default
234
+ Ae as default
233
235
  };
@@ -6,6 +6,17 @@ import "@overlastic/vue";
6
6
  import "clsx";
7
7
  import "vue-echarts";
8
8
  import "@vueuse/core";
9
+ import "vue3-ace-editor";
10
+ import "ace-builds/src-noconflict/mode-vue";
11
+ import "ace-builds/src-noconflict/mode-javascript";
12
+ import "ace-builds/src-noconflict/mode-html";
13
+ import "ace-builds/src-noconflict/mode-json";
14
+ import "ace-builds/src-noconflict/mode-json5";
15
+ import "ace-builds/src-noconflict/theme-tomorrow_night";
16
+ import "ace-builds/src-noconflict/theme-tomorrow";
17
+ import "ace-builds/src-noconflict/ext-searchbox";
18
+ import "ace-builds/src-noconflict/ext-language_tools";
19
+ import "ace-builds/src-noconflict/mode-snippets";
9
20
  import "vue-cropper";
10
21
  import "jinrishici";
11
22
  import "lodash-es";
@@ -25,22 +36,13 @@ import "vue-command-palette";
25
36
  import "@duxweb/dvha-naiveui";
26
37
  import "../page404.js";
27
38
  import "@iconify-json/tabler/icons.json";
39
+ import "../../components/image/elements/index.js";
40
+ import "fabric";
28
41
  import "mime";
29
- import "vue3-ace-editor";
30
- import "ace-builds/src-noconflict/mode-vue";
31
- import "ace-builds/src-noconflict/mode-javascript";
32
- import "ace-builds/src-noconflict/mode-html";
33
- import "ace-builds/src-noconflict/mode-json";
34
- import "ace-builds/src-noconflict/mode-json5";
35
- import "ace-builds/src-noconflict/theme-tomorrow_night";
36
- import "ace-builds/src-noconflict/theme-tomorrow";
37
- import "ace-builds/src-noconflict/ext-searchbox";
38
- import "ace-builds/src-noconflict/ext-language_tools";
39
- import "ace-builds/src-noconflict/mode-snippets";
40
42
  import "dayjs";
41
43
  import "@tanstack/vue-query";
42
44
  import { useUI as m } from "../../hooks/ui.js";
43
- const X = /* @__PURE__ */ p({
45
+ const Z = /* @__PURE__ */ p({
44
46
  name: "DuxMenuButton",
45
47
  props: {
46
48
  class: {
@@ -79,5 +81,5 @@ const X = /* @__PURE__ */ p({
79
81
  }
80
82
  });
81
83
  export {
82
- X as default
84
+ Z as default
83
85
  };
@@ -8,6 +8,17 @@ import { useRouter as L } from "vue-router";
8
8
  import "@overlastic/vue";
9
9
  import "clsx";
10
10
  import "vue-echarts";
11
+ import "vue3-ace-editor";
12
+ import "ace-builds/src-noconflict/mode-vue";
13
+ import "ace-builds/src-noconflict/mode-javascript";
14
+ import "ace-builds/src-noconflict/mode-html";
15
+ import "ace-builds/src-noconflict/mode-json";
16
+ import "ace-builds/src-noconflict/mode-json5";
17
+ import "ace-builds/src-noconflict/theme-tomorrow_night";
18
+ import "ace-builds/src-noconflict/theme-tomorrow";
19
+ import "ace-builds/src-noconflict/ext-searchbox";
20
+ import "ace-builds/src-noconflict/ext-language_tools";
21
+ import "ace-builds/src-noconflict/mode-snippets";
11
22
  import "vue-cropper";
12
23
  import "jinrishici";
13
24
  import "vue-draggable-plus";
@@ -25,50 +36,41 @@ import "@vee-validate/i18n/dist/locale/zh_CN.json";
25
36
  import "@duxweb/dvha-naiveui";
26
37
  import "../page404.js";
27
38
  import "@iconify-json/tabler/icons.json";
39
+ import "../../components/image/elements/index.js";
40
+ import "fabric";
28
41
  import "mime";
29
- import "vue3-ace-editor";
30
- import "ace-builds/src-noconflict/mode-vue";
31
- import "ace-builds/src-noconflict/mode-javascript";
32
- import "ace-builds/src-noconflict/mode-html";
33
- import "ace-builds/src-noconflict/mode-json";
34
- import "ace-builds/src-noconflict/mode-json5";
35
- import "ace-builds/src-noconflict/theme-tomorrow_night";
36
- import "ace-builds/src-noconflict/theme-tomorrow";
37
- import "ace-builds/src-noconflict/ext-searchbox";
38
- import "ace-builds/src-noconflict/ext-language_tools";
39
- import "ace-builds/src-noconflict/mode-snippets";
40
42
  import "dayjs";
41
43
  import "@tanstack/vue-query";
42
44
  import { useUI as q } from "../../hooks/ui.js";
43
- const we = /* @__PURE__ */ M({
45
+ const Be = /* @__PURE__ */ M({
44
46
  name: "DuxMenuCmd",
45
47
  setup() {
46
48
  const {
47
49
  cmdVisible: h,
48
50
  setCmdVisible: m
49
- } = q(), p = R(), y = p["Meta+K"], u = c(), a = c([]), S = L(), n = D(), {
51
+ } = q(), p = R(), y = p["Meta+K"], u = c(), a = c([]), S = L(), i = D(), {
50
52
  setMode: v
51
- } = T(), i = c(""), {
53
+ } = T(), n = c(""), {
52
54
  t: r
53
55
  } = K(), b = c(), g = (e) => {
54
- const l = n.routes.filter((I) => I.parent === e);
56
+ const l = i.routes.filter((I) => I.parent === e);
55
57
  u.value = e, a.value = l;
56
58
  }, C = () => {
57
59
  m(!0);
58
60
  }, N = () => {
59
61
  m(!1);
60
62
  }, z = (e) => {
61
- e ? a.value = [...E(n.routes).filter((l) => l.label?.includes(e))] : a.value = n.routes.filter((l) => !l.parent);
63
+ e ? a.value = [...E(i.routes).filter((l) => l.label?.includes(e))] : a.value = i.routes.filter((l) => !l.parent);
62
64
  };
63
65
  s(h, (e) => {
64
- e ? a.value = n.routes.filter((l) => !l.parent) : a.value = n.routes.filter((l) => !l.parent);
65
- }), j(i, () => {
66
- z(i.value);
66
+ e ? a.value = i.routes.filter((l) => !l.parent) : a.value = i.routes.filter((l) => !l.parent);
67
+ }), j(n, () => {
68
+ z(n.value);
67
69
  }, {
68
70
  throttle: 500
69
71
  });
70
72
  const x = () => {
71
- const e = n.routes.find((l) => l.name === u.value);
73
+ const e = i.routes.find((l) => l.name === u.value);
72
74
  g(e?.parent);
73
75
  };
74
76
  s(y, (e) => {
@@ -76,7 +78,7 @@ const we = /* @__PURE__ */ M({
76
78
  }), s(p.Escape, (e) => {
77
79
  e && m(!1);
78
80
  }), s(p.Backspace, (e) => {
79
- e && i.value === "" && u.value && x();
81
+ e && n.value === "" && u.value && x();
80
82
  }), s(b, (e) => {
81
83
  e && e.focus();
82
84
  });
@@ -105,7 +107,7 @@ const we = /* @__PURE__ */ M({
105
107
  ref: b,
106
108
  placeholder: r("common.search"),
107
109
  onInput: (e) => {
108
- i.value = e.target.value;
110
+ n.value = e.target.value;
109
111
  },
110
112
  class: "w-full h-12 text-base/5 rounded-md border-0 placeholder:text-dimmed outline-0 px-2.5 py-1.5 text-sm gap-1.5 text-highlighted bg-transparent ps-10 pe-10"
111
113
  }, null), t("span", {
@@ -130,7 +132,7 @@ const we = /* @__PURE__ */ M({
130
132
  "aria-hidden": "true"
131
133
  }, null)
132
134
  })])]),
133
- body: () => t(V, null, [d.value.length === 0 && i.value && t("div", {
135
+ body: () => t(V, null, [d.value.length === 0 && n.value && t("div", {
134
136
  class: "flex items-center justify-center h-20 border-t border-muted"
135
137
  }, [r("common.empty")]), d.value.length > 0 && t(o.List, null, {
136
138
  default: () => [t(o.Group, {
@@ -173,5 +175,5 @@ const we = /* @__PURE__ */ M({
173
175
  }
174
176
  });
175
177
  export {
176
- we as DuxMenuCmd
178
+ Be as DuxMenuCmd
177
179
  };
@@ -1,4 +1,4 @@
1
- import { defineComponent as c, createVNode as e, createTextVNode as i } from "vue";
1
+ import { defineComponent as c, createVNode as e, createTextVNode as l } from "vue";
2
2
  import { useManage as f, useI18n as v, DuxLogoIcon as x } from "@duxweb/dvha-core";
3
3
  import { useNaiveMenu as g } from "@duxweb/dvha-naiveui";
4
4
  import { NTag as r, NScrollbar as h, NMenu as b } from "naive-ui";
@@ -7,6 +7,17 @@ import "@overlastic/vue";
7
7
  import "clsx";
8
8
  import "vue-echarts";
9
9
  import "@vueuse/core";
10
+ import "vue3-ace-editor";
11
+ import "ace-builds/src-noconflict/mode-vue";
12
+ import "ace-builds/src-noconflict/mode-javascript";
13
+ import "ace-builds/src-noconflict/mode-html";
14
+ import "ace-builds/src-noconflict/mode-json";
15
+ import "ace-builds/src-noconflict/mode-json5";
16
+ import "ace-builds/src-noconflict/theme-tomorrow_night";
17
+ import "ace-builds/src-noconflict/theme-tomorrow";
18
+ import "ace-builds/src-noconflict/ext-searchbox";
19
+ import "ace-builds/src-noconflict/ext-language_tools";
20
+ import "ace-builds/src-noconflict/mode-snippets";
10
21
  import "vue-cropper";
11
22
  import "jinrishici";
12
23
  import "lodash-es";
@@ -27,22 +38,13 @@ import p from "./button.js";
27
38
  import "vue-command-palette";
28
39
  import "../page404.js";
29
40
  import "@iconify-json/tabler/icons.json";
41
+ import "../../components/image/elements/index.js";
42
+ import "fabric";
30
43
  import "mime";
31
- import "vue3-ace-editor";
32
- import "ace-builds/src-noconflict/mode-vue";
33
- import "ace-builds/src-noconflict/mode-javascript";
34
- import "ace-builds/src-noconflict/mode-html";
35
- import "ace-builds/src-noconflict/mode-json";
36
- import "ace-builds/src-noconflict/mode-json5";
37
- import "ace-builds/src-noconflict/theme-tomorrow_night";
38
- import "ace-builds/src-noconflict/theme-tomorrow";
39
- import "ace-builds/src-noconflict/ext-searchbox";
40
- import "ace-builds/src-noconflict/ext-language_tools";
41
- import "ace-builds/src-noconflict/mode-snippets";
42
44
  import "dayjs";
43
45
  import "@tanstack/vue-query";
44
46
  import { useUI as y } from "../../hooks/ui.js";
45
- const ue = /* @__PURE__ */ c({
47
+ const fe = /* @__PURE__ */ c({
46
48
  name: "DuxMenuMain",
47
49
  props: {
48
50
  collapsed: {
@@ -52,12 +54,12 @@ const ue = /* @__PURE__ */ c({
52
54
  },
53
55
  setup(o) {
54
56
  const {
55
- options: a,
56
- active: m
57
+ options: m,
58
+ active: a
57
59
  } = g({}), {
58
60
  menuCollapsed: t,
59
61
  setCmdVisible: s,
60
- menuMobileCollapsed: l,
62
+ menuMobileCollapsed: i,
61
63
  setMenuCollapsed: d
62
64
  } = y(), {
63
65
  config: n
@@ -99,21 +101,21 @@ const ue = /* @__PURE__ */ c({
99
101
  bordered: !1,
100
102
  type: "primary"
101
103
  }, {
102
- default: () => [i("⌘")]
104
+ default: () => [l("⌘")]
103
105
  }), e(r, {
104
106
  size: "small",
105
107
  bordered: !1,
106
108
  type: "primary"
107
109
  }, {
108
- default: () => [i("K")]
110
+ default: () => [l("K")]
109
111
  })])])
110
112
  })]), e("div", {
111
- class: ["flex-1 min-h-0", l.value ? "border-t border-muted" : ""]
113
+ class: ["flex-1 min-h-0", i.value ? "border-t border-muted" : ""]
112
114
  }, [e(h, null, {
113
115
  default: () => [e(b, {
114
- options: a.value,
115
- value: m.value,
116
- collapsed: t.value && !l.value,
116
+ options: m.value,
117
+ value: a.value,
118
+ collapsed: t.value && !i.value,
117
119
  indent: 20,
118
120
  collapsedWidth: 60,
119
121
  collapsedIconSize: 20
@@ -126,5 +128,5 @@ const ue = /* @__PURE__ */ c({
126
128
  }
127
129
  });
128
130
  export {
129
- ue as DuxMenuMain
131
+ fe as DuxMenuMain
130
132
  };
@@ -6,6 +6,17 @@ import "@overlastic/vue";
6
6
  import "clsx";
7
7
  import "vue-echarts";
8
8
  import "@vueuse/core";
9
+ import "vue3-ace-editor";
10
+ import "ace-builds/src-noconflict/mode-vue";
11
+ import "ace-builds/src-noconflict/mode-javascript";
12
+ import "ace-builds/src-noconflict/mode-html";
13
+ import "ace-builds/src-noconflict/mode-json";
14
+ import "ace-builds/src-noconflict/mode-json5";
15
+ import "ace-builds/src-noconflict/theme-tomorrow_night";
16
+ import "ace-builds/src-noconflict/theme-tomorrow";
17
+ import "ace-builds/src-noconflict/ext-searchbox";
18
+ import "ace-builds/src-noconflict/ext-language_tools";
19
+ import "ace-builds/src-noconflict/mode-snippets";
9
20
  import "vue-cropper";
10
21
  import "jinrishici";
11
22
  import "lodash-es";
@@ -26,22 +37,13 @@ import { DuxMenuMain as i } from "./main.js";
26
37
  import "@duxweb/dvha-naiveui";
27
38
  import "../page404.js";
28
39
  import "@iconify-json/tabler/icons.json";
40
+ import "../../components/image/elements/index.js";
41
+ import "fabric";
29
42
  import "mime";
30
- import "vue3-ace-editor";
31
- import "ace-builds/src-noconflict/mode-vue";
32
- import "ace-builds/src-noconflict/mode-javascript";
33
- import "ace-builds/src-noconflict/mode-html";
34
- import "ace-builds/src-noconflict/mode-json";
35
- import "ace-builds/src-noconflict/mode-json5";
36
- import "ace-builds/src-noconflict/theme-tomorrow_night";
37
- import "ace-builds/src-noconflict/theme-tomorrow";
38
- import "ace-builds/src-noconflict/ext-searchbox";
39
- import "ace-builds/src-noconflict/ext-language_tools";
40
- import "ace-builds/src-noconflict/mode-snippets";
41
43
  import "dayjs";
42
44
  import "@tanstack/vue-query";
43
45
  import { useUI as e } from "../../hooks/ui.js";
44
- const Y = /* @__PURE__ */ p({
46
+ const $ = /* @__PURE__ */ p({
45
47
  name: "DuxMobileMenu",
46
48
  props: {},
47
49
  setup(l) {
@@ -61,5 +63,5 @@ const Y = /* @__PURE__ */ p({
61
63
  }
62
64
  });
63
65
  export {
64
- Y as DuxMobileMenu
66
+ $ as DuxMobileMenu
65
67
  };
@@ -12,6 +12,17 @@ import "@tanstack/vue-query";
12
12
  import "@duxweb/dvha-naiveui";
13
13
  import "@vueuse/core";
14
14
  import "pinia";
15
+ import "vue3-ace-editor";
16
+ import "ace-builds/src-noconflict/mode-vue";
17
+ import "ace-builds/src-noconflict/mode-javascript";
18
+ import "ace-builds/src-noconflict/mode-html";
19
+ import "ace-builds/src-noconflict/mode-json";
20
+ import "ace-builds/src-noconflict/mode-json5";
21
+ import "ace-builds/src-noconflict/theme-tomorrow_night";
22
+ import "ace-builds/src-noconflict/theme-tomorrow";
23
+ import "ace-builds/src-noconflict/ext-searchbox";
24
+ import "ace-builds/src-noconflict/ext-language_tools";
25
+ import "ace-builds/src-noconflict/mode-snippets";
15
26
  import "vue-cropper";
16
27
  import "jinrishici";
17
28
  import "vue-draggable-plus";
@@ -30,17 +41,8 @@ import "@vee-validate/i18n/dist/locale/zh_CN.json";
30
41
  import "vue-command-palette";
31
42
  import { DuxPageStatus as d } from "./pageStatus.js";
32
43
  import "@iconify-json/tabler/icons.json";
33
- import "vue3-ace-editor";
34
- import "ace-builds/src-noconflict/mode-vue";
35
- import "ace-builds/src-noconflict/mode-javascript";
36
- import "ace-builds/src-noconflict/mode-html";
37
- import "ace-builds/src-noconflict/mode-json";
38
- import "ace-builds/src-noconflict/mode-json5";
39
- import "ace-builds/src-noconflict/theme-tomorrow_night";
40
- import "ace-builds/src-noconflict/theme-tomorrow";
41
- import "ace-builds/src-noconflict/ext-searchbox";
42
- import "ace-builds/src-noconflict/ext-language_tools";
43
- import "ace-builds/src-noconflict/mode-snippets";
44
+ import "../components/image/elements/index.js";
45
+ import "fabric";
44
46
  function g(o) {
45
47
  return typeof o == "function" || Object.prototype.toString.call(o) === "[object Object]" && !u(o);
46
48
  }
@@ -13,6 +13,17 @@ import "@tanstack/vue-query";
13
13
  import "@duxweb/dvha-naiveui";
14
14
  import "@vueuse/core";
15
15
  import "pinia";
16
+ import "vue3-ace-editor";
17
+ import "ace-builds/src-noconflict/mode-vue";
18
+ import "ace-builds/src-noconflict/mode-javascript";
19
+ import "ace-builds/src-noconflict/mode-html";
20
+ import "ace-builds/src-noconflict/mode-json";
21
+ import "ace-builds/src-noconflict/mode-json5";
22
+ import "ace-builds/src-noconflict/theme-tomorrow_night";
23
+ import "ace-builds/src-noconflict/theme-tomorrow";
24
+ import "ace-builds/src-noconflict/ext-searchbox";
25
+ import "ace-builds/src-noconflict/ext-language_tools";
26
+ import "ace-builds/src-noconflict/mode-snippets";
16
27
  import "vue-cropper";
17
28
  import "jinrishici";
18
29
  import "vue-draggable-plus";
@@ -30,18 +41,9 @@ import "@vee-validate/i18n/dist/locale/zh_CN.json";
30
41
  import "vue-command-palette";
31
42
  import "./page404.js";
32
43
  import "@iconify-json/tabler/icons.json";
33
- import "vue3-ace-editor";
34
- import "ace-builds/src-noconflict/mode-vue";
35
- import "ace-builds/src-noconflict/mode-javascript";
36
- import "ace-builds/src-noconflict/mode-html";
37
- import "ace-builds/src-noconflict/mode-json";
38
- import "ace-builds/src-noconflict/mode-json5";
39
- import "ace-builds/src-noconflict/theme-tomorrow_night";
40
- import "ace-builds/src-noconflict/theme-tomorrow";
41
- import "ace-builds/src-noconflict/ext-searchbox";
42
- import "ace-builds/src-noconflict/ext-language_tools";
43
- import "ace-builds/src-noconflict/mode-snippets";
44
- const W = /* @__PURE__ */ e({
44
+ import "../components/image/elements/index.js";
45
+ import "fabric";
46
+ const Y = /* @__PURE__ */ e({
45
47
  name: "DuxPageStatus",
46
48
  props: {
47
49
  title: String,
@@ -75,5 +77,5 @@ const W = /* @__PURE__ */ e({
75
77
  }
76
78
  });
77
79
  export {
78
- W as DuxPageStatus
80
+ Y as DuxPageStatus
79
81
  };
@@ -1,5 +1,5 @@
1
1
  const r = `/* layer: properties */
2
- @supports ((-webkit-hyphens: none) and (not (margin-trim: inline))) or ((-moz-orient: inline) and (not (color:rgb(from red r g b)))){*, ::before, ::after, ::backdrop{--un-text-opacity:100%;--un-bg-opacity:100%;--un-from-opacity:100%;--un-divide-y-reverse:initial;--un-border-style:solid;--un-divide-x-reverse:initial;--un-divide-opacity:100%;--un-shadow-opacity:100%;--un-ease:initial;--un-translate-x:initial;--un-translate-y:initial;--un-translate-z:initial;--un-border-opacity:100%;--un-fill-opacity:100%;--un-to-opacity:100%;--un-outline-style:solid;}}
2
+ @supports ((-webkit-hyphens: none) and (not (margin-trim: inline))) or ((-moz-orient: inline) and (not (color:rgb(from red r g b)))){*, ::before, ::after, ::backdrop{--un-text-opacity:100%;--un-bg-opacity:100%;--un-from-opacity:100%;--un-divide-y-reverse:initial;--un-border-style:solid;--un-divide-x-reverse:initial;--un-divide-opacity:100%;--un-shadow-opacity:100%;--un-ease:initial;--un-translate-x:initial;--un-translate-y:initial;--un-translate-z:initial;--un-border-opacity:100%;--un-outline-style:solid;--un-fill-opacity:100%;--un-to-opacity:100%;}}
3
3
  @property --un-text-opacity{syntax:"<percentage>";inherits:false;initial-value:100%;}
4
4
  @property --un-outline-style{syntax:"*";inherits:false;initial-value:solid;}
5
5
  @property --un-border-opacity{syntax:"<percentage>";inherits:false;initial-value:100%;}
@@ -917,11 +917,16 @@ input:where([type='button'], [type='reset'], [type='submit']),
917
917
  }
918
918
  /* layer: icons */
919
919
  .i-tabler\\:alert-triangle{--un-icon:url("data:image/svg+xml;utf8,%3Csvg viewBox='0 0 24 24' width='1em' height='1em' xmlns='http://www.w3.org/2000/svg' %3E%3Cpath fill='none' stroke='currentColor' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M12 9v4m-1.637-9.409L2.257 17.125a1.914 1.914 0 0 0 1.636 2.871h16.214a1.914 1.914 0 0 0 1.636-2.87L13.637 3.59a1.914 1.914 0 0 0-3.274 0zM12 16h.01'/%3E%3C/svg%3E");-webkit-mask:var(--un-icon) no-repeat;mask:var(--un-icon) no-repeat;-webkit-mask-size:100% 100%;mask-size:100% 100%;background-color:currentColor;color:inherit;width:1em;height:1em;}
920
+ .i-tabler\\:arrow-bar-to-down{--un-icon:url("data:image/svg+xml;utf8,%3Csvg viewBox='0 0 24 24' width='1em' height='1em' xmlns='http://www.w3.org/2000/svg' %3E%3Cpath fill='none' stroke='currentColor' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M4 20h16m-8-6V4m0 10l4-4m-4 4l-4-4'/%3E%3C/svg%3E");-webkit-mask:var(--un-icon) no-repeat;mask:var(--un-icon) no-repeat;-webkit-mask-size:100% 100%;mask-size:100% 100%;background-color:currentColor;color:inherit;width:1em;height:1em;}
921
+ .i-tabler\\:arrow-bar-to-up{--un-icon:url("data:image/svg+xml;utf8,%3Csvg viewBox='0 0 24 24' width='1em' height='1em' xmlns='http://www.w3.org/2000/svg' %3E%3Cpath fill='none' stroke='currentColor' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M12 10v10m0-10l4 4m-4-4l-4 4M4 4h16'/%3E%3C/svg%3E");-webkit-mask:var(--un-icon) no-repeat;mask:var(--un-icon) no-repeat;-webkit-mask-size:100% 100%;mask-size:100% 100%;background-color:currentColor;color:inherit;width:1em;height:1em;}
920
922
  .i-tabler\\:arrow-down{--un-icon:url("data:image/svg+xml;utf8,%3Csvg viewBox='0 0 24 24' width='1em' height='1em' xmlns='http://www.w3.org/2000/svg' %3E%3Cpath fill='none' stroke='currentColor' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M12 5v14m6-6l-6 6m-6-6l6 6'/%3E%3C/svg%3E");-webkit-mask:var(--un-icon) no-repeat;mask:var(--un-icon) no-repeat;-webkit-mask-size:100% 100%;mask-size:100% 100%;background-color:currentColor;color:inherit;width:1em;height:1em;}
921
923
  .i-tabler\\:arrow-left{--un-icon:url("data:image/svg+xml;utf8,%3Csvg viewBox='0 0 24 24' width='1em' height='1em' xmlns='http://www.w3.org/2000/svg' %3E%3Cpath fill='none' stroke='currentColor' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M5 12h14M5 12l6 6m-6-6l6-6'/%3E%3C/svg%3E");-webkit-mask:var(--un-icon) no-repeat;mask:var(--un-icon) no-repeat;-webkit-mask-size:100% 100%;mask-size:100% 100%;background-color:currentColor;color:inherit;width:1em;height:1em;}
924
+ .i-tabler\\:arrow-narrow-down{--un-icon:url("data:image/svg+xml;utf8,%3Csvg viewBox='0 0 24 24' width='1em' height='1em' xmlns='http://www.w3.org/2000/svg' %3E%3Cpath fill='none' stroke='currentColor' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M12 5v14m4-4l-4 4m-4-4l4 4'/%3E%3C/svg%3E");-webkit-mask:var(--un-icon) no-repeat;mask:var(--un-icon) no-repeat;-webkit-mask-size:100% 100%;mask-size:100% 100%;background-color:currentColor;color:inherit;width:1em;height:1em;}
925
+ .i-tabler\\:arrow-narrow-up{--un-icon:url("data:image/svg+xml;utf8,%3Csvg viewBox='0 0 24 24' width='1em' height='1em' xmlns='http://www.w3.org/2000/svg' %3E%3Cpath fill='none' stroke='currentColor' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M12 5v14m4-10l-4-4M8 9l4-4'/%3E%3C/svg%3E");-webkit-mask:var(--un-icon) no-repeat;mask:var(--un-icon) no-repeat;-webkit-mask-size:100% 100%;mask-size:100% 100%;background-color:currentColor;color:inherit;width:1em;height:1em;}
922
926
  .i-tabler\\:brightness-half{--un-icon:url("data:image/svg+xml;utf8,%3Csvg viewBox='0 0 24 24' width='1em' height='1em' xmlns='http://www.w3.org/2000/svg' %3E%3Cg fill='none' stroke='currentColor' stroke-linecap='round' stroke-linejoin='round' stroke-width='2'%3E%3Cpath d='M12 9a3 3 0 0 0 0 6z'/%3E%3Cpath d='M6 6h3.5L12 3.5L14.5 6H18v3.5l2.5 2.5l-2.5 2.5V18h-3.5L12 20.5L9.5 18H6v-3.5L3.5 12L6 9.5z'/%3E%3C/g%3E%3C/svg%3E");-webkit-mask:var(--un-icon) no-repeat;mask:var(--un-icon) no-repeat;-webkit-mask-size:100% 100%;mask-size:100% 100%;background-color:currentColor;color:inherit;width:1em;height:1em;}
923
927
  .i-tabler\\:check{--un-icon:url("data:image/svg+xml;utf8,%3Csvg viewBox='0 0 24 24' width='1em' height='1em' xmlns='http://www.w3.org/2000/svg' %3E%3Cpath fill='none' stroke='currentColor' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='m5 12l5 5L20 7'/%3E%3C/svg%3E");-webkit-mask:var(--un-icon) no-repeat;mask:var(--un-icon) no-repeat;-webkit-mask-size:100% 100%;mask-size:100% 100%;background-color:currentColor;color:inherit;width:1em;height:1em;}
924
928
  .i-tabler\\:chevrons-down{--un-icon:url("data:image/svg+xml;utf8,%3Csvg viewBox='0 0 24 24' width='1em' height='1em' xmlns='http://www.w3.org/2000/svg' %3E%3Cpath fill='none' stroke='currentColor' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='m7 7l5 5l5-5M7 13l5 5l5-5'/%3E%3C/svg%3E");-webkit-mask:var(--un-icon) no-repeat;mask:var(--un-icon) no-repeat;-webkit-mask-size:100% 100%;mask-size:100% 100%;background-color:currentColor;color:inherit;width:1em;height:1em;}
929
+ .i-tabler\\:circle{--un-icon:url("data:image/svg+xml;utf8,%3Csvg viewBox='0 0 24 24' width='1em' height='1em' xmlns='http://www.w3.org/2000/svg' %3E%3Cpath fill='none' stroke='currentColor' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M3 12a9 9 0 1 0 18 0a9 9 0 1 0-18 0'/%3E%3C/svg%3E");-webkit-mask:var(--un-icon) no-repeat;mask:var(--un-icon) no-repeat;-webkit-mask-size:100% 100%;mask-size:100% 100%;background-color:currentColor;color:inherit;width:1em;height:1em;}
925
930
  .i-tabler\\:circle-check-filled{--un-icon:url("data:image/svg+xml;utf8,%3Csvg viewBox='0 0 24 24' width='1em' height='1em' xmlns='http://www.w3.org/2000/svg' %3E%3Cpath fill='currentColor' d='M17 3.34a10 10 0 1 1-14.995 8.984L2 12l.005-.324A10 10 0 0 1 17 3.34m-1.293 5.953a1 1 0 0 0-1.32-.083l-.094.083L11 12.585l-1.293-1.292l-.094-.083a1 1 0 0 0-1.403 1.403l.083.094l2 2l.094.083a1 1 0 0 0 1.226 0l.094-.083l4-4l.083-.094a1 1 0 0 0-.083-1.32'/%3E%3C/svg%3E");-webkit-mask:var(--un-icon) no-repeat;mask:var(--un-icon) no-repeat;-webkit-mask-size:100% 100%;mask-size:100% 100%;background-color:currentColor;color:inherit;width:1em;height:1em;}
926
931
  .i-tabler\\:circle-x-filled{--un-icon:url("data:image/svg+xml;utf8,%3Csvg viewBox='0 0 24 24' width='1em' height='1em' xmlns='http://www.w3.org/2000/svg' %3E%3Cpath fill='currentColor' d='M17 3.34a10 10 0 1 1-14.995 8.984L2 12l.005-.324A10 10 0 0 1 17 3.34m-6.489 5.8a1 1 0 0 0-1.218 1.567L10.585 12l-1.292 1.293l-.083.094a1 1 0 0 0 1.497 1.32L12 13.415l1.293 1.292l.094.083a1 1 0 0 0 1.32-1.497L13.415 12l1.292-1.293l.083-.094a1 1 0 0 0-1.497-1.32L12 10.585l-1.293-1.292l-.094-.083z'/%3E%3C/svg%3E");-webkit-mask:var(--un-icon) no-repeat;mask:var(--un-icon) no-repeat;-webkit-mask-size:100% 100%;mask-size:100% 100%;background-color:currentColor;color:inherit;width:1em;height:1em;}
927
932
  .i-tabler\\:columns{--un-icon:url("data:image/svg+xml;utf8,%3Csvg viewBox='0 0 24 24' width='1em' height='1em' xmlns='http://www.w3.org/2000/svg' %3E%3Cpath fill='none' stroke='currentColor' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M4 6h5.5M4 10h5.5M4 14h5.5M4 18h5.5m5-12H20m-5.5 4H20m-5.5 4H20m-5.5 4H20'/%3E%3C/svg%3E");-webkit-mask:var(--un-icon) no-repeat;mask:var(--un-icon) no-repeat;-webkit-mask-size:100% 100%;mask-size:100% 100%;background-color:currentColor;color:inherit;width:1em;height:1em;}
@@ -942,6 +947,14 @@ input:where([type='button'], [type='reset'], [type='submit']),
942
947
  .i-tabler\\:info-circle{--un-icon:url("data:image/svg+xml;utf8,%3Csvg viewBox='0 0 24 24' width='1em' height='1em' xmlns='http://www.w3.org/2000/svg' %3E%3Cg fill='none' stroke='currentColor' stroke-linecap='round' stroke-linejoin='round' stroke-width='2'%3E%3Cpath d='M3 12a9 9 0 1 0 18 0a9 9 0 0 0-18 0m9-3h.01'/%3E%3Cpath d='M11 12h1v4h1'/%3E%3C/g%3E%3C/svg%3E");-webkit-mask:var(--un-icon) no-repeat;mask:var(--un-icon) no-repeat;-webkit-mask-size:100% 100%;mask-size:100% 100%;background-color:currentColor;color:inherit;width:1em;height:1em;}
943
948
  .i-tabler\\:info-circle-filled{--un-icon:url("data:image/svg+xml;utf8,%3Csvg viewBox='0 0 24 24' width='1em' height='1em' xmlns='http://www.w3.org/2000/svg' %3E%3Cpath fill='currentColor' d='M12 2c5.523 0 10 4.477 10 10a10 10 0 0 1-19.995.324L2 12l.004-.28C2.152 6.327 6.57 2 12 2m0 9h-1l-.117.007a1 1 0 0 0 0 1.986L11 13v3l.007.117a1 1 0 0 0 .876.876L12 17h1l.117-.007a1 1 0 0 0 .876-.876L14 16l-.007-.117a1 1 0 0 0-.764-.857l-.112-.02L13 15v-3l-.007-.117a1 1 0 0 0-.876-.876zm.01-3l-.127.007a1 1 0 0 0 0 1.986L12 10l.127-.007a1 1 0 0 0 0-1.986z'/%3E%3C/svg%3E");-webkit-mask:var(--un-icon) no-repeat;mask:var(--un-icon) no-repeat;-webkit-mask-size:100% 100%;mask-size:100% 100%;background-color:currentColor;color:inherit;width:1em;height:1em;}
944
949
  .i-tabler\\:language{--un-icon:url("data:image/svg+xml;utf8,%3Csvg viewBox='0 0 24 24' width='1em' height='1em' xmlns='http://www.w3.org/2000/svg' %3E%3Cg fill='none' stroke='currentColor' stroke-linecap='round' stroke-linejoin='round' stroke-width='2'%3E%3Cpath d='M4 5h7M9 3v2c0 4.418-2.239 8-5 8'/%3E%3Cpath d='M5 9c0 2.144 2.952 3.908 6.7 4m.3 7l4-9l4 9m-.9-2h-6.2'/%3E%3C/g%3E%3C/svg%3E");-webkit-mask:var(--un-icon) no-repeat;mask:var(--un-icon) no-repeat;-webkit-mask-size:100% 100%;mask-size:100% 100%;background-color:currentColor;color:inherit;width:1em;height:1em;}
950
+ .i-tabler\\:layout-align-bottom{--un-icon:url("data:image/svg+xml;utf8,%3Csvg viewBox='0 0 24 24' width='1em' height='1em' xmlns='http://www.w3.org/2000/svg' %3E%3Cpath fill='none' stroke='currentColor' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M4 20h16M9 6a2 2 0 0 1 2-2h2a2 2 0 0 1 2 2v8a2 2 0 0 1-2 2h-2a2 2 0 0 1-2-2z'/%3E%3C/svg%3E");-webkit-mask:var(--un-icon) no-repeat;mask:var(--un-icon) no-repeat;-webkit-mask-size:100% 100%;mask-size:100% 100%;background-color:currentColor;color:inherit;width:1em;height:1em;}
951
+ .i-tabler\\:layout-align-center{--un-icon:url("data:image/svg+xml;utf8,%3Csvg viewBox='0 0 24 24' width='1em' height='1em' xmlns='http://www.w3.org/2000/svg' %3E%3Cpath fill='none' stroke='currentColor' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M12 4v5m0 6v5m-6-9a2 2 0 0 1 2-2h8a2 2 0 0 1 2 2v2a2 2 0 0 1-2 2H8a2 2 0 0 1-2-2z'/%3E%3C/svg%3E");-webkit-mask:var(--un-icon) no-repeat;mask:var(--un-icon) no-repeat;-webkit-mask-size:100% 100%;mask-size:100% 100%;background-color:currentColor;color:inherit;width:1em;height:1em;}
952
+ .i-tabler\\:layout-align-left{--un-icon:url("data:image/svg+xml;utf8,%3Csvg viewBox='0 0 24 24' width='1em' height='1em' xmlns='http://www.w3.org/2000/svg' %3E%3Cpath fill='none' stroke='currentColor' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M4 4v16m4-9a2 2 0 0 1 2-2h8a2 2 0 0 1 2 2v2a2 2 0 0 1-2 2h-8a2 2 0 0 1-2-2z'/%3E%3C/svg%3E");-webkit-mask:var(--un-icon) no-repeat;mask:var(--un-icon) no-repeat;-webkit-mask-size:100% 100%;mask-size:100% 100%;background-color:currentColor;color:inherit;width:1em;height:1em;}
953
+ .i-tabler\\:layout-align-middle{--un-icon:url("data:image/svg+xml;utf8,%3Csvg viewBox='0 0 24 24' width='1em' height='1em' xmlns='http://www.w3.org/2000/svg' %3E%3Cpath fill='none' stroke='currentColor' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M4 12h5m6 0h5M9 8a2 2 0 0 1 2-2h2a2 2 0 0 1 2 2v8a2 2 0 0 1-2 2h-2a2 2 0 0 1-2-2z'/%3E%3C/svg%3E");-webkit-mask:var(--un-icon) no-repeat;mask:var(--un-icon) no-repeat;-webkit-mask-size:100% 100%;mask-size:100% 100%;background-color:currentColor;color:inherit;width:1em;height:1em;}
954
+ .i-tabler\\:layout-align-right{--un-icon:url("data:image/svg+xml;utf8,%3Csvg viewBox='0 0 24 24' width='1em' height='1em' xmlns='http://www.w3.org/2000/svg' %3E%3Cpath fill='none' stroke='currentColor' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M20 4v16M4 11a2 2 0 0 1 2-2h8a2 2 0 0 1 2 2v2a2 2 0 0 1-2 2H6a2 2 0 0 1-2-2z'/%3E%3C/svg%3E");-webkit-mask:var(--un-icon) no-repeat;mask:var(--un-icon) no-repeat;-webkit-mask-size:100% 100%;mask-size:100% 100%;background-color:currentColor;color:inherit;width:1em;height:1em;}
955
+ .i-tabler\\:layout-align-top{--un-icon:url("data:image/svg+xml;utf8,%3Csvg viewBox='0 0 24 24' width='1em' height='1em' xmlns='http://www.w3.org/2000/svg' %3E%3Cpath fill='none' stroke='currentColor' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M4 4h16M9 10a2 2 0 0 1 2-2h2a2 2 0 0 1 2 2v8a2 2 0 0 1-2 2h-2a2 2 0 0 1-2-2z'/%3E%3C/svg%3E");-webkit-mask:var(--un-icon) no-repeat;mask:var(--un-icon) no-repeat;-webkit-mask-size:100% 100%;mask-size:100% 100%;background-color:currentColor;color:inherit;width:1em;height:1em;}
956
+ .i-tabler\\:layout-distribute-horizontal{--un-icon:url("data:image/svg+xml;utf8,%3Csvg viewBox='0 0 24 24' width='1em' height='1em' xmlns='http://www.w3.org/2000/svg' %3E%3Cpath fill='none' stroke='currentColor' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M4 4h16M4 20h16M6 11a2 2 0 0 1 2-2h8a2 2 0 0 1 2 2v2a2 2 0 0 1-2 2H8a2 2 0 0 1-2-2z'/%3E%3C/svg%3E");-webkit-mask:var(--un-icon) no-repeat;mask:var(--un-icon) no-repeat;-webkit-mask-size:100% 100%;mask-size:100% 100%;background-color:currentColor;color:inherit;width:1em;height:1em;}
957
+ .i-tabler\\:layout-distribute-vertical{--un-icon:url("data:image/svg+xml;utf8,%3Csvg viewBox='0 0 24 24' width='1em' height='1em' xmlns='http://www.w3.org/2000/svg' %3E%3Cpath fill='none' stroke='currentColor' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M4 4v16M20 4v16M9 8a2 2 0 0 1 2-2h2a2 2 0 0 1 2 2v8a2 2 0 0 1-2 2h-2a2 2 0 0 1-2-2z'/%3E%3C/svg%3E");-webkit-mask:var(--un-icon) no-repeat;mask:var(--un-icon) no-repeat;-webkit-mask-size:100% 100%;mask-size:100% 100%;background-color:currentColor;color:inherit;width:1em;height:1em;}
945
958
  .i-tabler\\:layout-sidebar-inactive{--un-icon:url("data:image/svg+xml;utf8,%3Csvg viewBox='0 0 24 24' width='1em' height='1em' xmlns='http://www.w3.org/2000/svg' %3E%3Cpath fill='none' stroke='currentColor' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M4 6a2 2 0 0 1 2-2h12a2 2 0 0 1 2 2v12a2 2 0 0 1-2 2H6a2 2 0 0 1-2-2zm5-2v1m0 4v1m0 4v1m0 4v1'/%3E%3C/svg%3E");-webkit-mask:var(--un-icon) no-repeat;mask:var(--un-icon) no-repeat;-webkit-mask-size:100% 100%;mask-size:100% 100%;background-color:currentColor;color:inherit;width:1em;height:1em;}
946
959
  .i-tabler\\:layout-sidebar-right-inactive{--un-icon:url("data:image/svg+xml;utf8,%3Csvg viewBox='0 0 24 24' width='1em' height='1em' xmlns='http://www.w3.org/2000/svg' %3E%3Cpath fill='none' stroke='currentColor' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M4 6a2 2 0 0 1 2-2h12a2 2 0 0 1 2 2v12a2 2 0 0 1-2 2H6a2 2 0 0 1-2-2zm11-2v1m0 4v1m0 4v1m0 4v1'/%3E%3C/svg%3E");-webkit-mask:var(--un-icon) no-repeat;mask:var(--un-icon) no-repeat;-webkit-mask-size:100% 100%;mask-size:100% 100%;background-color:currentColor;color:inherit;width:1em;height:1em;}
947
960
  .i-tabler\\:link{--un-icon:url("data:image/svg+xml;utf8,%3Csvg viewBox='0 0 24 24' width='1em' height='1em' xmlns='http://www.w3.org/2000/svg' %3E%3Cpath fill='none' stroke='currentColor' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='m9 15l6-6m-4-3l.463-.536a5 5 0 0 1 7.071 7.072L18 13m-5 5l-.397.534a5.07 5.07 0 0 1-7.127 0a4.97 4.97 0 0 1 0-7.071L6 11'/%3E%3C/svg%3E");-webkit-mask:var(--un-icon) no-repeat;mask:var(--un-icon) no-repeat;-webkit-mask-size:100% 100%;mask-size:100% 100%;background-color:currentColor;color:inherit;width:1em;height:1em;}
@@ -959,8 +972,10 @@ input:where([type='button'], [type='reset'], [type='submit']),
959
972
  .i-tabler\\:rotate{--un-icon:url("data:image/svg+xml;utf8,%3Csvg viewBox='0 0 24 24' width='1em' height='1em' xmlns='http://www.w3.org/2000/svg' %3E%3Cpath fill='none' stroke='currentColor' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M19.95 11a8 8 0 1 0-.5 4m.5 5v-5h-5'/%3E%3C/svg%3E");-webkit-mask:var(--un-icon) no-repeat;mask:var(--un-icon) no-repeat;-webkit-mask-size:100% 100%;mask-size:100% 100%;background-color:currentColor;color:inherit;width:1em;height:1em;}
960
973
  .i-tabler\\:rotate-clockwise{--un-icon:url("data:image/svg+xml;utf8,%3Csvg viewBox='0 0 24 24' width='1em' height='1em' xmlns='http://www.w3.org/2000/svg' %3E%3Cpath fill='none' stroke='currentColor' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M4.05 11a8 8 0 1 1 .5 4m-.5 5v-5h5'/%3E%3C/svg%3E");-webkit-mask:var(--un-icon) no-repeat;mask:var(--un-icon) no-repeat;-webkit-mask-size:100% 100%;mask-size:100% 100%;background-color:currentColor;color:inherit;width:1em;height:1em;}
961
974
  .i-tabler\\:search{--un-icon:url("data:image/svg+xml;utf8,%3Csvg viewBox='0 0 24 24' width='1em' height='1em' xmlns='http://www.w3.org/2000/svg' %3E%3Cpath fill='none' stroke='currentColor' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M3 10a7 7 0 1 0 14 0a7 7 0 1 0-14 0m18 11l-6-6'/%3E%3C/svg%3E");-webkit-mask:var(--un-icon) no-repeat;mask:var(--un-icon) no-repeat;-webkit-mask-size:100% 100%;mask-size:100% 100%;background-color:currentColor;color:inherit;width:1em;height:1em;}
975
+ .i-tabler\\:square{--un-icon:url("data:image/svg+xml;utf8,%3Csvg viewBox='0 0 24 24' width='1em' height='1em' xmlns='http://www.w3.org/2000/svg' %3E%3Cpath fill='none' stroke='currentColor' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M3 5a2 2 0 0 1 2-2h14a2 2 0 0 1 2 2v14a2 2 0 0 1-2 2H5a2 2 0 0 1-2-2z'/%3E%3C/svg%3E");-webkit-mask:var(--un-icon) no-repeat;mask:var(--un-icon) no-repeat;-webkit-mask-size:100% 100%;mask-size:100% 100%;background-color:currentColor;color:inherit;width:1em;height:1em;}
962
976
  .i-tabler\\:sun{--un-icon:url("data:image/svg+xml;utf8,%3Csvg viewBox='0 0 24 24' width='1em' height='1em' xmlns='http://www.w3.org/2000/svg' %3E%3Cpath fill='none' stroke='currentColor' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M8 12a4 4 0 1 0 8 0a4 4 0 1 0-8 0m-5 0h1m8-9v1m8 8h1m-9 8v1M5.6 5.6l.7.7m12.1-.7l-.7.7m0 11.4l.7.7m-12.1-.7l-.7.7'/%3E%3C/svg%3E");-webkit-mask:var(--un-icon) no-repeat;mask:var(--un-icon) no-repeat;-webkit-mask-size:100% 100%;mask-size:100% 100%;background-color:currentColor;color:inherit;width:1em;height:1em;}
963
977
  .i-tabler\\:trash{--un-icon:url("data:image/svg+xml;utf8,%3Csvg viewBox='0 0 24 24' width='1em' height='1em' xmlns='http://www.w3.org/2000/svg' %3E%3Cpath fill='none' stroke='currentColor' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M4 7h16m-10 4v6m4-6v6M5 7l1 12a2 2 0 0 0 2 2h8a2 2 0 0 0 2-2l1-12M9 7V4a1 1 0 0 1 1-1h4a1 1 0 0 1 1 1v3'/%3E%3C/svg%3E");-webkit-mask:var(--un-icon) no-repeat;mask:var(--un-icon) no-repeat;-webkit-mask-size:100% 100%;mask-size:100% 100%;background-color:currentColor;color:inherit;width:1em;height:1em;}
978
+ .i-tabler\\:typography{--un-icon:url("data:image/svg+xml;utf8,%3Csvg viewBox='0 0 24 24' width='1em' height='1em' xmlns='http://www.w3.org/2000/svg' %3E%3Cpath fill='none' stroke='currentColor' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M4 20h3m7 0h7M6.9 15h6.9m-3.6-8.7L16 20M5 20l6-16h2l7 16'/%3E%3C/svg%3E");-webkit-mask:var(--un-icon) no-repeat;mask:var(--un-icon) no-repeat;-webkit-mask-size:100% 100%;mask-size:100% 100%;background-color:currentColor;color:inherit;width:1em;height:1em;}
964
979
  .i-tabler\\:upload{--un-icon:url("data:image/svg+xml;utf8,%3Csvg viewBox='0 0 24 24' width='1em' height='1em' xmlns='http://www.w3.org/2000/svg' %3E%3Cpath fill='none' stroke='currentColor' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M4 17v2a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2v-2M7 9l5-5l5 5m-5-5v12'/%3E%3C/svg%3E");-webkit-mask:var(--un-icon) no-repeat;mask:var(--un-icon) no-repeat;-webkit-mask-size:100% 100%;mask-size:100% 100%;background-color:currentColor;color:inherit;width:1em;height:1em;}
965
980
  .i-tabler\\:user{--un-icon:url("data:image/svg+xml;utf8,%3Csvg viewBox='0 0 24 24' width='1em' height='1em' xmlns='http://www.w3.org/2000/svg' %3E%3Cpath fill='none' stroke='currentColor' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M8 7a4 4 0 1 0 8 0a4 4 0 0 0-8 0M6 21v-2a4 4 0 0 1 4-4h4a4 4 0 0 1 4 4v2'/%3E%3C/svg%3E");-webkit-mask:var(--un-icon) no-repeat;mask:var(--un-icon) no-repeat;-webkit-mask-size:100% 100%;mask-size:100% 100%;background-color:currentColor;color:inherit;width:1em;height:1em;}
966
981
  .i-tabler\\:x{--un-icon:url("data:image/svg+xml;utf8,%3Csvg viewBox='0 0 24 24' width='1em' height='1em' xmlns='http://www.w3.org/2000/svg' %3E%3Cpath fill='none' stroke='currentColor' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M18 6L6 18M6 6l12 12'/%3E%3C/svg%3E");-webkit-mask:var(--un-icon) no-repeat;mask:var(--un-icon) no-repeat;-webkit-mask-size:100% 100%;mask-size:100% 100%;background-color:currentColor;color:inherit;width:1em;height:1em;}
@@ -1056,6 +1071,7 @@ input:where([type='button'], [type='reset'], [type='submit']),
1056
1071
  .pb-4{padding-bottom:calc(var(--spacing) * 4);}
1057
1072
  .pe-10{padding-inline-end:calc(var(--spacing) * 10);}
1058
1073
  .pe-3{padding-inline-end:calc(var(--spacing) * 3);}
1074
+ .pl-12{padding-left:calc(var(--spacing) * 12);}
1059
1075
  .pl-2{padding-left:calc(var(--spacing) * 2);}
1060
1076
  .pl-4{padding-left:calc(var(--spacing) * 4);}
1061
1077
  .pr-4{padding-right:calc(var(--spacing) * 4);}
@@ -1063,6 +1079,7 @@ input:where([type='button'], [type='reset'], [type='submit']),
1063
1079
  .ps-3{padding-inline-start:calc(var(--spacing) * 3);}
1064
1080
  .pt-0\\.5{padding-top:calc(var(--spacing) * 0.5);}
1065
1081
  .pt-1{padding-top:calc(var(--spacing) * 1);}
1082
+ .pt-12{padding-top:calc(var(--spacing) * 12);}
1066
1083
  .pt-2{padding-top:calc(var(--spacing) * 2);}
1067
1084
  .pt-4{padding-top:calc(var(--spacing) * 4);}
1068
1085
  .pt-6{padding-top:calc(var(--spacing) * 6);}
@@ -1074,6 +1091,8 @@ input:where([type='button'], [type='reset'], [type='submit']),
1074
1091
  .dark .dark\\:border{border-width:1px;}
1075
1092
  .border-0{border-width:0px;}
1076
1093
  .border-b{border-bottom-width:1px;}
1094
+ .border-l{border-left-width:1px;}
1095
+ .border-r{border-right-width:1px;}
1077
1096
  .border-t{border-top-width:1px;}
1078
1097
  .border-primary,
1079
1098
  .group:hover .group-hover\\:border-primary{border-color:color-mix(in srgb, var(--colors-primary-DEFAULT) var(--un-border-opacity), transparent) /* color-mix(in oklab, rgb(var(--ui-color-primary)) var(--un-text-opacity, 100%), transparent) */;}
@@ -1145,6 +1164,7 @@ input:where([type='button'], [type='reset'], [type='submit']),
1145
1164
  .grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr));}
1146
1165
  .grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr));}
1147
1166
  .grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr));}
1167
+ .grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr));}
1148
1168
  .grid-cols-6{grid-template-columns:repeat(6,minmax(0,1fr));}
1149
1169
  .size-10{width:calc(var(--spacing) * 10);height:calc(var(--spacing) * 10);}
1150
1170
  .size-12{width:calc(var(--spacing) * 12);height:calc(var(--spacing) * 12);}
@@ -1199,6 +1219,7 @@ input:where([type='button'], [type='reset'], [type='submit']),
1199
1219
  .w-40{width:calc(var(--spacing) * 40);}
1200
1220
  .w-400px{width:400px;}
1201
1221
  .w-5{width:calc(var(--spacing) * 5);}
1222
+ .w-60{width:calc(var(--spacing) * 60);}
1202
1223
  .w-70{width:calc(var(--spacing) * 70);}
1203
1224
  .w-auto{width:auto;}
1204
1225
  .w-full{width:100%;}
@@ -1221,6 +1242,7 @@ input:where([type='button'], [type='reset'], [type='submit']),
1221
1242
  .whitespace-nowrap{white-space:nowrap;}
1222
1243
  .text-pretty{text-wrap:pretty;}
1223
1244
  .truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
1245
+ .italic{font-style:italic;}
1224
1246
  .ring{--un-ring-shadow:var(--un-ring-inset,) 0 0 0 calc(1px + var(--un-ring-offset-width)) var(--un-ring-color, currentColor);box-shadow:var(--un-inset-shadow), var(--un-inset-ring-shadow), var(--un-ring-offset-shadow), var(--un-ring-shadow), var(--un-shadow);}
1225
1247
  .dark .dark\\:shadow-gray-950\\/80{--un-shadow-color:color-mix(in srgb, var(--colors-gray-950) 80%, transparent) /* color-mix(in oklab, rgb(var(--ui-color-gray-950)) var(--un-text-opacity, 100%), transparent) */;}
1226
1248
  .shadow,
@@ -1261,12 +1283,14 @@ input:where([type='button'], [type='reset'], [type='submit']),
1261
1283
  .bottom-2{bottom:calc(var(--spacing) * 2);}
1262
1284
  .left-0{left:calc(var(--spacing) * 0);}
1263
1285
  .left-2{left:calc(var(--spacing) * 2);}
1286
+ .left-6{left:calc(var(--spacing) * 6);}
1264
1287
  .right-0{right:calc(var(--spacing) * 0);}
1265
1288
  .right-2{right:calc(var(--spacing) * 2);}
1266
1289
  .right-2\\.5{right:calc(var(--spacing) * 2.5);}
1267
1290
  .top-0{top:calc(var(--spacing) * 0);}
1268
1291
  .top-1\\.3{top:calc(var(--spacing) * 1.3);}
1269
1292
  .top-2{top:calc(var(--spacing) * 2);}
1293
+ .top-6{top:calc(var(--spacing) * 6);}
1270
1294
  .top-7{top:calc(var(--spacing) * 7);}
1271
1295
  .justify-start{justify-content:flex-start;}
1272
1296
  .justify-end{justify-content:flex-end;}
@@ -0,0 +1,43 @@
1
+ export interface CanvasRulerProps {
2
+ canvasWidth: number;
3
+ canvasHeight: number;
4
+ canvasScale: number;
5
+ rulerSize?: number;
6
+ }
7
+ export declare const CanvasRuler: import("vue").DefineComponent<import("vue").ExtractPropTypes<{
8
+ canvasWidth: {
9
+ type: NumberConstructor;
10
+ required: true;
11
+ };
12
+ canvasHeight: {
13
+ type: NumberConstructor;
14
+ required: true;
15
+ };
16
+ canvasScale: {
17
+ type: NumberConstructor;
18
+ required: true;
19
+ };
20
+ rulerSize: {
21
+ type: NumberConstructor;
22
+ default: number;
23
+ };
24
+ }>, () => import("vue/jsx-runtime").JSX.Element, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").PublicProps, Readonly<import("vue").ExtractPropTypes<{
25
+ canvasWidth: {
26
+ type: NumberConstructor;
27
+ required: true;
28
+ };
29
+ canvasHeight: {
30
+ type: NumberConstructor;
31
+ required: true;
32
+ };
33
+ canvasScale: {
34
+ type: NumberConstructor;
35
+ required: true;
36
+ };
37
+ rulerSize: {
38
+ type: NumberConstructor;
39
+ default: number;
40
+ };
41
+ }>> & Readonly<{}>, {
42
+ rulerSize: number;
43
+ }, {}, {}, {}, string, import("vue").ComponentProvideOptions, true, {}, any>;
@@ -0,0 +1 @@
1
+ export { CanvasRuler } from './CanvasRuler';