@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
@@ -0,0 +1,171 @@
1
+ import { Rect as i } from "fabric";
2
+ const o = {
3
+ type: "rect",
4
+ name: "矩形",
5
+ icon: "i-tabler:square",
6
+ category: "basic",
7
+ defaultProps: {
8
+ id: "",
9
+ type: "rect",
10
+ left: 100,
11
+ top: 100,
12
+ width: 100,
13
+ height: 100,
14
+ angle: 0,
15
+ scaleX: 1,
16
+ scaleY: 1,
17
+ visible: !0,
18
+ locked: !1,
19
+ fill: "#ff0000",
20
+ stroke: "",
21
+ strokeWidth: 0,
22
+ strokeDashArray: null,
23
+ rx: 0,
24
+ ry: 0,
25
+ opacity: 1,
26
+ label: ""
27
+ },
28
+ createFabricObject: (e) => {
29
+ const t = new i({
30
+ left: e.left,
31
+ top: e.top,
32
+ width: e.width,
33
+ height: e.height,
34
+ fill: e.fill,
35
+ stroke: e.stroke || void 0,
36
+ strokeWidth: e.strokeWidth,
37
+ strokeDashArray: e.strokeDashArray,
38
+ rx: e.rx,
39
+ ry: e.ry,
40
+ angle: e.angle,
41
+ scaleX: e.scaleX,
42
+ scaleY: e.scaleY,
43
+ opacity: e.opacity,
44
+ visible: e.visible,
45
+ selectable: !e.locked,
46
+ evented: !e.locked,
47
+ strokeUniform: !0,
48
+ // 支持等比例缩放:用户可以按住Shift键进行等比例缩放
49
+ uniformScaling: !1
50
+ // 默认不强制等比例,但支持Shift键等比例缩放
51
+ });
52
+ return t.setControlsVisibility({
53
+ mtr: !0,
54
+ // 旋转控制点
55
+ mt: !0,
56
+ // 顶部中间
57
+ mb: !0,
58
+ // 底部中间
59
+ ml: !0,
60
+ // 左侧中间
61
+ mr: !0,
62
+ // 右侧中间
63
+ tl: !0,
64
+ // 左上角 - 支持等比例缩放
65
+ tr: !0,
66
+ // 右上角 - 支持等比例缩放
67
+ bl: !0,
68
+ // 左下角 - 支持等比例缩放
69
+ br: !0
70
+ // 右下角 - 支持等比例缩放
71
+ }), t.label = e.label, t;
72
+ },
73
+ getPropsFromFabricObject: (e) => {
74
+ const t = e, l = t.scaleX || 1, a = t.scaleY || 1;
75
+ return {
76
+ type: "rect",
77
+ left: Math.round(t.left || 0),
78
+ top: Math.round(t.top || 0),
79
+ width: Math.round((t.width || 100) * l),
80
+ height: Math.round((t.height || 100) * a),
81
+ angle: Math.round(t.angle || 0),
82
+ scaleX: 1,
83
+ // 始终重置为1,将缩放应用到实际尺寸
84
+ scaleY: 1,
85
+ // 始终重置为1,将缩放应用到实际尺寸
86
+ visible: t.visible !== !1,
87
+ locked: !t.selectable,
88
+ fill: t.fill || "#ff0000",
89
+ stroke: t.stroke || "",
90
+ strokeWidth: Math.round(t.strokeWidth || 0),
91
+ strokeDashArray: t.strokeDashArray || null,
92
+ rx: Math.round(t.rx || 0),
93
+ ry: Math.round(t.ry || 0),
94
+ opacity: t.opacity || 1,
95
+ label: t.label || ""
96
+ };
97
+ },
98
+ getToolbarControls: (e) => [
99
+ {
100
+ key: "label",
101
+ label: "标签",
102
+ type: "text",
103
+ value: e.label,
104
+ options: { placeholder: "请输入标签" }
105
+ },
106
+ {
107
+ key: "width",
108
+ label: "宽度",
109
+ type: "number",
110
+ value: e.width,
111
+ options: { min: 1, max: 2e3, step: 1 }
112
+ },
113
+ {
114
+ key: "height",
115
+ label: "高度",
116
+ type: "number",
117
+ value: e.height,
118
+ options: { min: 1, max: 2e3, step: 1 }
119
+ },
120
+ {
121
+ key: "fill",
122
+ label: "填充颜色",
123
+ type: "color",
124
+ value: e.fill
125
+ },
126
+ {
127
+ key: "stroke",
128
+ label: "边框颜色",
129
+ type: "color",
130
+ value: e.stroke
131
+ },
132
+ {
133
+ key: "strokeWidth",
134
+ label: "边框宽度",
135
+ type: "number",
136
+ value: e.strokeWidth,
137
+ options: { min: 0, max: 50, step: 1 }
138
+ },
139
+ {
140
+ key: "rx",
141
+ label: "圆角半径",
142
+ type: "number",
143
+ value: e.rx,
144
+ options: { min: 0, max: 100, step: 1 }
145
+ },
146
+ {
147
+ key: "opacity",
148
+ label: "透明度",
149
+ type: "slider",
150
+ value: e.opacity,
151
+ options: { min: 0, max: 1, step: 0.01 }
152
+ }
153
+ ],
154
+ onPropsChange: (e, t) => {
155
+ const l = t;
156
+ l.set({
157
+ width: e.width,
158
+ height: e.height,
159
+ fill: e.fill,
160
+ stroke: e.stroke || void 0,
161
+ strokeWidth: e.strokeWidth,
162
+ rx: e.rx,
163
+ ry: e.rx,
164
+ // 让ry跟随rx
165
+ opacity: e.opacity
166
+ }), l.label = e.label;
167
+ }
168
+ };
169
+ export {
170
+ o as default
171
+ };
@@ -0,0 +1,206 @@
1
+ import { Textbox as o } from "fabric";
2
+ const c = {
3
+ type: "text",
4
+ name: "文本",
5
+ icon: "i-tabler:typography",
6
+ category: "basic",
7
+ defaultProps: {
8
+ id: "",
9
+ type: "text",
10
+ left: 100,
11
+ top: 100,
12
+ width: 200,
13
+ angle: 0,
14
+ scaleX: 1,
15
+ scaleY: 1,
16
+ visible: !0,
17
+ locked: !1,
18
+ text: "双击编辑文本",
19
+ fontSize: 20,
20
+ fontFamily: "Arial",
21
+ fill: "#000000",
22
+ textAlign: "left",
23
+ fontWeight: "normal",
24
+ fontStyle: "normal",
25
+ underline: !1,
26
+ linethrough: !1
27
+ },
28
+ createFabricObject: (e) => {
29
+ const t = new o(e.text, {
30
+ left: e.left,
31
+ top: e.top,
32
+ width: e.width,
33
+ angle: e.angle,
34
+ scaleX: e.scaleX,
35
+ scaleY: e.scaleY,
36
+ visible: e.visible,
37
+ selectable: !e.locked,
38
+ evented: !e.locked,
39
+ fontSize: e.fontSize,
40
+ fontFamily: e.fontFamily,
41
+ fill: e.fill,
42
+ textAlign: e.textAlign,
43
+ fontWeight: e.fontWeight,
44
+ fontStyle: e.fontStyle,
45
+ underline: e.underline,
46
+ linethrough: e.linethrough,
47
+ // 启用自动换行的关键配置
48
+ splitByGrapheme: !0,
49
+ // 锁定高度缩放,只允许宽度缩放
50
+ lockScalingY: !0,
51
+ // 禁用高度手柄
52
+ setControlsVisibility: {
53
+ mt: !1,
54
+ // 顶部中间
55
+ mb: !1
56
+ // 底部中间
57
+ }
58
+ });
59
+ let l = e.fontSize;
60
+ return t.on("mousedown", () => {
61
+ l = t.fontSize || 20;
62
+ }), t.on("scaling", () => {
63
+ const n = t.scaleX || 1, i = Math.round(l * n), a = Math.max(8, Math.min(200, i));
64
+ t.set({
65
+ fontSize: a,
66
+ scaleX: 1,
67
+ scaleY: 1
68
+ }), t.canvas?.requestRenderAll();
69
+ }), t.on("mousedblclick", () => {
70
+ t.enterEditing(), t.selectAll();
71
+ }), t;
72
+ },
73
+ getPropsFromFabricObject: (e) => {
74
+ const t = e;
75
+ return {
76
+ left: Math.round(t.left || 0),
77
+ top: Math.round(t.top || 0),
78
+ width: Math.round(t.width || 0),
79
+ angle: Math.round(t.angle || 0),
80
+ scaleX: t.scaleX || 1,
81
+ scaleY: t.scaleY || 1,
82
+ visible: t.visible !== !1,
83
+ locked: !t.selectable,
84
+ text: t.text || "",
85
+ fontSize: Math.round(t.fontSize || 20),
86
+ fontFamily: t.fontFamily || "Arial",
87
+ fill: t.fill,
88
+ textAlign: t.textAlign || "left",
89
+ fontWeight: t.fontWeight || "normal",
90
+ fontStyle: t.fontStyle || "normal",
91
+ underline: t.underline || !1,
92
+ linethrough: t.linethrough || !1
93
+ };
94
+ },
95
+ onPropsChange: (e, t) => {
96
+ t.set({
97
+ left: e.left,
98
+ top: e.top,
99
+ width: e.width,
100
+ angle: e.angle,
101
+ visible: e.visible,
102
+ selectable: !e.locked,
103
+ evented: !e.locked,
104
+ text: e.text,
105
+ fontSize: e.fontSize,
106
+ fontFamily: e.fontFamily,
107
+ fill: e.fill,
108
+ textAlign: e.textAlign,
109
+ fontWeight: e.fontWeight,
110
+ fontStyle: e.fontStyle,
111
+ underline: e.underline,
112
+ linethrough: e.linethrough
113
+ });
114
+ },
115
+ getToolbarControls: (e) => [
116
+ {
117
+ key: "text",
118
+ label: "文本内容",
119
+ type: "text",
120
+ value: e.text
121
+ },
122
+ {
123
+ key: "fontSize",
124
+ label: "字体大小",
125
+ type: "number",
126
+ value: e.fontSize,
127
+ options: {
128
+ min: 8,
129
+ max: 200,
130
+ step: 1
131
+ }
132
+ },
133
+ {
134
+ key: "fontFamily",
135
+ label: "字体",
136
+ type: "select",
137
+ value: e.fontFamily,
138
+ options: {
139
+ choices: [
140
+ { label: "Arial", value: "Arial" },
141
+ { label: "微软雅黑", value: "Microsoft YaHei" },
142
+ { label: "宋体", value: "SimSun" },
143
+ { label: "黑体", value: "SimHei" }
144
+ ]
145
+ }
146
+ },
147
+ {
148
+ key: "fill",
149
+ label: "颜色",
150
+ type: "color",
151
+ value: e.fill
152
+ },
153
+ {
154
+ key: "textAlign",
155
+ label: "对齐",
156
+ type: "select",
157
+ value: e.textAlign,
158
+ options: {
159
+ choices: [
160
+ { label: "左对齐", value: "left" },
161
+ { label: "居中", value: "center" },
162
+ { label: "右对齐", value: "right" }
163
+ ]
164
+ }
165
+ },
166
+ {
167
+ key: "fontWeight",
168
+ label: "粗体",
169
+ type: "select",
170
+ value: e.fontWeight,
171
+ options: {
172
+ choices: [
173
+ { label: "正常", value: "normal" },
174
+ { label: "粗体", value: "bold" }
175
+ ]
176
+ }
177
+ },
178
+ {
179
+ key: "fontStyle",
180
+ label: "斜体",
181
+ type: "select",
182
+ value: e.fontStyle,
183
+ options: {
184
+ choices: [
185
+ { label: "正常", value: "normal" },
186
+ { label: "斜体", value: "italic" }
187
+ ]
188
+ }
189
+ },
190
+ {
191
+ key: "underline",
192
+ label: "下划线",
193
+ type: "switch",
194
+ value: e.underline
195
+ },
196
+ {
197
+ key: "linethrough",
198
+ label: "删除线",
199
+ type: "switch",
200
+ value: e.linethrough
201
+ }
202
+ ]
203
+ };
204
+ export {
205
+ c as default
206
+ };