@hprint/plugins 0.0.1-alpha.0

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 (153) hide show
  1. package/dist/index.css +1 -0
  2. package/dist/index.js +478 -0
  3. package/dist/index.mjs +41731 -0
  4. package/dist/src/index.d.ts +8 -0
  5. package/dist/src/index.d.ts.map +1 -0
  6. package/dist/src/objects/Arrow.d.ts +2 -0
  7. package/dist/src/objects/Arrow.d.ts.map +1 -0
  8. package/dist/src/objects/ThinTailArrow.d.ts +2 -0
  9. package/dist/src/objects/ThinTailArrow.d.ts.map +1 -0
  10. package/dist/src/plugins/AddBaseTypePlugin.d.ts +26 -0
  11. package/dist/src/plugins/AddBaseTypePlugin.d.ts.map +1 -0
  12. package/dist/src/plugins/AlignGuidLinePlugin.d.ts +16 -0
  13. package/dist/src/plugins/AlignGuidLinePlugin.d.ts.map +1 -0
  14. package/dist/src/plugins/BarCodePlugin.d.ts +68 -0
  15. package/dist/src/plugins/BarCodePlugin.d.ts.map +1 -0
  16. package/dist/src/plugins/CenterAlignPlugin.d.ts +29 -0
  17. package/dist/src/plugins/CenterAlignPlugin.d.ts.map +1 -0
  18. package/dist/src/plugins/ControlsPlugin.d.ts +11 -0
  19. package/dist/src/plugins/ControlsPlugin.d.ts.map +1 -0
  20. package/dist/src/plugins/ControlsRotatePlugin.d.ts +11 -0
  21. package/dist/src/plugins/ControlsRotatePlugin.d.ts.map +1 -0
  22. package/dist/src/plugins/CopyPlugin.d.ts +30 -0
  23. package/dist/src/plugins/CopyPlugin.d.ts.map +1 -0
  24. package/dist/src/plugins/CreateElementPlugin.d.ts +121 -0
  25. package/dist/src/plugins/CreateElementPlugin.d.ts.map +1 -0
  26. package/dist/src/plugins/DeleteHotKeyPlugin.d.ts +25 -0
  27. package/dist/src/plugins/DeleteHotKeyPlugin.d.ts.map +1 -0
  28. package/dist/src/plugins/DrawLinePlugin.d.ts +26 -0
  29. package/dist/src/plugins/DrawLinePlugin.d.ts.map +1 -0
  30. package/dist/src/plugins/DrawPolygonPlugin.d.ts +41 -0
  31. package/dist/src/plugins/DrawPolygonPlugin.d.ts.map +1 -0
  32. package/dist/src/plugins/DringPlugin.d.ts +33 -0
  33. package/dist/src/plugins/DringPlugin.d.ts.map +1 -0
  34. package/dist/src/plugins/FlipPlugin.d.ts +26 -0
  35. package/dist/src/plugins/FlipPlugin.d.ts.map +1 -0
  36. package/dist/src/plugins/FontPlugin.d.ts +33 -0
  37. package/dist/src/plugins/FontPlugin.d.ts.map +1 -0
  38. package/dist/src/plugins/FreeDrawPlugin.d.ts +23 -0
  39. package/dist/src/plugins/FreeDrawPlugin.d.ts.map +1 -0
  40. package/dist/src/plugins/GroupAlignPlugin.d.ts +24 -0
  41. package/dist/src/plugins/GroupAlignPlugin.d.ts.map +1 -0
  42. package/dist/src/plugins/GroupPlugin.d.ts +24 -0
  43. package/dist/src/plugins/GroupPlugin.d.ts.map +1 -0
  44. package/dist/src/plugins/GroupTextEditorPlugin.d.ts +18 -0
  45. package/dist/src/plugins/GroupTextEditorPlugin.d.ts.map +1 -0
  46. package/dist/src/plugins/HistoryPlugin.d.ts +30 -0
  47. package/dist/src/plugins/HistoryPlugin.d.ts.map +1 -0
  48. package/dist/src/plugins/ImageStroke.d.ts +18 -0
  49. package/dist/src/plugins/ImageStroke.d.ts.map +1 -0
  50. package/dist/src/plugins/LayerPlugin.d.ts +31 -0
  51. package/dist/src/plugins/LayerPlugin.d.ts.map +1 -0
  52. package/dist/src/plugins/LockPlugin.d.ts +27 -0
  53. package/dist/src/plugins/LockPlugin.d.ts.map +1 -0
  54. package/dist/src/plugins/MaskPlugin.d.ts +38 -0
  55. package/dist/src/plugins/MaskPlugin.d.ts.map +1 -0
  56. package/dist/src/plugins/MaterialPlugin.d.ts +45 -0
  57. package/dist/src/plugins/MaterialPlugin.d.ts.map +1 -0
  58. package/dist/src/plugins/MiddleMousePlugin.d.ts +18 -0
  59. package/dist/src/plugins/MiddleMousePlugin.d.ts.map +1 -0
  60. package/dist/src/plugins/MoveHotKeyPlugin.d.ts +12 -0
  61. package/dist/src/plugins/MoveHotKeyPlugin.d.ts.map +1 -0
  62. package/dist/src/plugins/PathTextPlugin.d.ts +30 -0
  63. package/dist/src/plugins/PathTextPlugin.d.ts.map +1 -0
  64. package/dist/src/plugins/PolygonModifyPlugin.d.ts +28 -0
  65. package/dist/src/plugins/PolygonModifyPlugin.d.ts.map +1 -0
  66. package/dist/src/plugins/PrintPlugin.d.ts +39 -0
  67. package/dist/src/plugins/PrintPlugin.d.ts.map +1 -0
  68. package/dist/src/plugins/PsdPlugin.d.ts +17 -0
  69. package/dist/src/plugins/PsdPlugin.d.ts.map +1 -0
  70. package/dist/src/plugins/QrCodePlugin.d.ts +137 -0
  71. package/dist/src/plugins/QrCodePlugin.d.ts.map +1 -0
  72. package/dist/src/plugins/ResizePlugin.d.ts +44 -0
  73. package/dist/src/plugins/ResizePlugin.d.ts.map +1 -0
  74. package/dist/src/plugins/RulerPlugin.d.ts +24 -0
  75. package/dist/src/plugins/RulerPlugin.d.ts.map +1 -0
  76. package/dist/src/plugins/SimpleClipImagePlugin.d.ts +18 -0
  77. package/dist/src/plugins/SimpleClipImagePlugin.d.ts.map +1 -0
  78. package/dist/src/plugins/UnitPlugin.d.ts +84 -0
  79. package/dist/src/plugins/UnitPlugin.d.ts.map +1 -0
  80. package/dist/src/plugins/WaterMarkPlugin.d.ts +40 -0
  81. package/dist/src/plugins/WaterMarkPlugin.d.ts.map +1 -0
  82. package/dist/src/plugins/WorkspacePlugin.d.ts +57 -0
  83. package/dist/src/plugins/WorkspacePlugin.d.ts.map +1 -0
  84. package/dist/src/types/eventType.d.ts +11 -0
  85. package/dist/src/types/eventType.d.ts.map +1 -0
  86. package/dist/src/utils/psd.d.ts +3 -0
  87. package/dist/src/utils/psd.d.ts.map +1 -0
  88. package/dist/src/utils/ruler/guideline.d.ts +4 -0
  89. package/dist/src/utils/ruler/guideline.d.ts.map +1 -0
  90. package/dist/src/utils/ruler/index.d.ts +5 -0
  91. package/dist/src/utils/ruler/index.d.ts.map +1 -0
  92. package/dist/src/utils/ruler/ruler.d.ts +147 -0
  93. package/dist/src/utils/ruler/ruler.d.ts.map +1 -0
  94. package/dist/src/utils/ruler/utils.d.ts +50 -0
  95. package/dist/src/utils/ruler/utils.d.ts.map +1 -0
  96. package/dist/src/utils/units.d.ts +22 -0
  97. package/dist/src/utils/units.d.ts.map +1 -0
  98. package/package.json +51 -0
  99. package/src/assets/edgecontrol.svg +17 -0
  100. package/src/assets/lock.svg +7 -0
  101. package/src/assets/middlecontrol.svg +17 -0
  102. package/src/assets/middlecontrolhoz.svg +17 -0
  103. package/src/assets/rotateicon.svg +20 -0
  104. package/src/assets/style/resizePlugin.css +27 -0
  105. package/src/index.ts +121 -0
  106. package/src/objects/Arrow.js +47 -0
  107. package/src/objects/ThinTailArrow.js +50 -0
  108. package/src/plugins/AddBaseTypePlugin.ts +107 -0
  109. package/src/plugins/AlignGuidLinePlugin.ts +1141 -0
  110. package/src/plugins/BarCodePlugin.ts +860 -0
  111. package/src/plugins/CenterAlignPlugin.ts +133 -0
  112. package/src/plugins/ControlsPlugin.ts +251 -0
  113. package/src/plugins/ControlsRotatePlugin.ts +111 -0
  114. package/src/plugins/CopyPlugin.ts +255 -0
  115. package/src/plugins/CreateElementPlugin.ts +548 -0
  116. package/src/plugins/DeleteHotKeyPlugin.ts +57 -0
  117. package/src/plugins/DrawLinePlugin.ts +162 -0
  118. package/src/plugins/DrawPolygonPlugin.ts +205 -0
  119. package/src/plugins/DringPlugin.ts +125 -0
  120. package/src/plugins/FlipPlugin.ts +59 -0
  121. package/src/plugins/FontPlugin.ts +165 -0
  122. package/src/plugins/FreeDrawPlugin.ts +49 -0
  123. package/src/plugins/GroupAlignPlugin.ts +365 -0
  124. package/src/plugins/GroupPlugin.ts +82 -0
  125. package/src/plugins/GroupTextEditorPlugin.ts +198 -0
  126. package/src/plugins/HistoryPlugin.ts +181 -0
  127. package/src/plugins/ImageStroke.ts +121 -0
  128. package/src/plugins/LayerPlugin.ts +108 -0
  129. package/src/plugins/LockPlugin.ts +240 -0
  130. package/src/plugins/MaskPlugin.ts +155 -0
  131. package/src/plugins/MaterialPlugin.ts +224 -0
  132. package/src/plugins/MiddleMousePlugin.ts +45 -0
  133. package/src/plugins/MoveHotKeyPlugin.ts +46 -0
  134. package/src/plugins/PathTextPlugin.ts +89 -0
  135. package/src/plugins/PolygonModifyPlugin.ts +224 -0
  136. package/src/plugins/PrintPlugin.ts +81 -0
  137. package/src/plugins/PsdPlugin.ts +52 -0
  138. package/src/plugins/QrCodePlugin.ts +393 -0
  139. package/src/plugins/ResizePlugin.ts +274 -0
  140. package/src/plugins/RulerPlugin.ts +78 -0
  141. package/src/plugins/SimpleClipImagePlugin.ts +244 -0
  142. package/src/plugins/UnitPlugin.ts +327 -0
  143. package/src/plugins/WaterMarkPlugin.ts +257 -0
  144. package/src/plugins/WorkspacePlugin.ts +307 -0
  145. package/src/types/eventType.ts +11 -0
  146. package/src/utils/psd.js +432 -0
  147. package/src/utils/ruler/guideline.ts +145 -0
  148. package/src/utils/ruler/index.ts +91 -0
  149. package/src/utils/ruler/ruler.ts +924 -0
  150. package/src/utils/ruler/utils.ts +162 -0
  151. package/src/utils/units.ts +133 -0
  152. package/tsconfig.json +10 -0
  153. package/vite.config.ts +29 -0
@@ -0,0 +1,255 @@
1
+ import { fabric } from '@hprint/core';
2
+ import { v4 as uuid } from 'uuid';
3
+ import { utils } from '@hprint/shared';
4
+ import type { IEditor, IPluginTempl } from '@hprint/core';
5
+
6
+ type IPlugin = Pick<CopyPlugin, 'clone'>;
7
+
8
+ declare module '@hprint/core' {
9
+ // eslint-disable-next-line @typescript-eslint/no-empty-interface
10
+ interface IEditor extends IPlugin {}
11
+ }
12
+
13
+ class CopyPlugin implements IPluginTempl {
14
+ static pluginName = 'CopyPlugin';
15
+ static apis = ['clone'];
16
+ hotkeys: string[] = ['ctrl+v', 'ctrl+c'];
17
+ private cache: null | fabric.ActiveSelection | fabric.Object = null;
18
+ constructor(
19
+ public canvas: fabric.Canvas,
20
+ public editor: IEditor
21
+ ) {
22
+ this.initPaste();
23
+ }
24
+
25
+ // 多选对象复制
26
+ _copyActiveSelection(activeObject: fabric.Object) {
27
+ // 间距设置
28
+ const grid = 10;
29
+ const canvas = this.canvas;
30
+ const keys = this.editor.getExtensionKey();
31
+ activeObject?.clone((cloned: fabric.Object) => {
32
+ // 再次进行克隆,处理选择多个对象的情况
33
+ cloned.clone((clonedObj: fabric.ActiveSelection) => {
34
+ canvas.discardActiveObject();
35
+ if (clonedObj.left === undefined || clonedObj.top === undefined)
36
+ return;
37
+ // 将克隆的画布重新赋值
38
+ clonedObj.canvas = canvas;
39
+ // 设置位置信息
40
+ clonedObj.set({
41
+ left: clonedObj.left + grid,
42
+ top: clonedObj.top + grid,
43
+ evented: true,
44
+ id: uuid(),
45
+ });
46
+ clonedObj.forEachObject((obj: fabric.Object) => {
47
+ obj.id = uuid();
48
+ canvas.add(obj);
49
+ });
50
+ // 解决不可选择问题
51
+ clonedObj.setCoords();
52
+ canvas.setActiveObject(clonedObj);
53
+ canvas.requestRenderAll();
54
+ });
55
+ }, keys);
56
+ }
57
+
58
+ // 单个对象复制
59
+ _copyObject(activeObject: fabric.Object) {
60
+ // 间距设置
61
+ const grid = 10;
62
+ const canvas = this.canvas;
63
+ const keys = this.editor.getExtensionKey();
64
+ activeObject?.clone((cloned: fabric.Object) => {
65
+ if (cloned.left === undefined || cloned.top === undefined) return;
66
+ canvas.discardActiveObject();
67
+ // 设置位置信息
68
+ cloned.set({
69
+ left: cloned.left + grid,
70
+ top: cloned.top + grid,
71
+ evented: true,
72
+ id: uuid(),
73
+ });
74
+ canvas.add(cloned);
75
+ canvas.setActiveObject(cloned);
76
+ canvas.requestRenderAll();
77
+ }, keys);
78
+ }
79
+
80
+ // 复制元素
81
+ clone(paramsActiveObeject?: fabric.ActiveSelection | fabric.Object) {
82
+ const activeObject =
83
+ paramsActiveObeject || this.canvas.getActiveObject();
84
+ if (!activeObject) return;
85
+ if (activeObject?.type === 'activeSelection') {
86
+ this._copyActiveSelection(activeObject);
87
+ } else {
88
+ this._copyObject(activeObject);
89
+ }
90
+ }
91
+
92
+ // 快捷键扩展回调
93
+ hotkeyEvent(eventName: string, e: KeyboardEvent) {
94
+ if (eventName === 'ctrl+c' && e.type === 'keydown') {
95
+ const activeObject = this.canvas.getActiveObject();
96
+ this.cache = activeObject;
97
+ // 清空剪切板
98
+ navigator.clipboard.writeText('');
99
+ }
100
+ if (eventName === 'ctrl+v' && e.type === 'keydown') {
101
+ // 确保clone元素操作的执行晚于pasteListener
102
+ setTimeout(() => {
103
+ if (this.cache) {
104
+ this.clone(this.cache);
105
+ }
106
+ }, 0);
107
+ }
108
+ }
109
+
110
+ contextMenu() {
111
+ const activeObject = this.canvas.getActiveObject();
112
+ if (activeObject) {
113
+ return [
114
+ {
115
+ text: '复制',
116
+ hotkey: 'Ctrl+V',
117
+ disabled: false,
118
+ onclick: () => this.clone(),
119
+ },
120
+ ];
121
+ }
122
+ }
123
+
124
+ destroy() {
125
+ console.log('pluginDestroy');
126
+ window.removeEventListener('paste', (e) => this.pasteListener(e));
127
+ }
128
+
129
+ initPaste() {
130
+ window.addEventListener('paste', (e) => this.pasteListener(e));
131
+ }
132
+
133
+ async pasteListener(event: any) {
134
+ const canvas = this.canvas;
135
+ if (document.activeElement === document.body) {
136
+ event.preventDefault(); // 阻止默认粘贴行为
137
+ } else {
138
+ return;
139
+ }
140
+
141
+ const items = (event.clipboardData || event.originalEvent.clipboardData)
142
+ .items;
143
+ const fileAccept =
144
+ '.pdf,.psd,.cdr,.ai,.svg,.jpg,.jpeg,.png,.webp,.json';
145
+ for (const item of items) {
146
+ if (item.kind === 'file') {
147
+ const file = item.getAsFile();
148
+ const curFileSuffix: string | undefined = file.name
149
+ .split('.')
150
+ .pop();
151
+ if (!fileAccept.split(',').includes(`.${curFileSuffix}`))
152
+ return;
153
+ if (curFileSuffix === 'svg') {
154
+ const svgFile = await utils.getImgStr(file);
155
+ if (!svgFile) throw new Error('file is undefined');
156
+ fabric.loadSVGFromURL(
157
+ svgFile as string,
158
+ (objects, options) => {
159
+ const item = fabric.util.groupSVGElements(objects, {
160
+ ...options,
161
+ name: 'defaultSVG',
162
+ id: uuid(),
163
+ });
164
+ canvas.add(item).centerObject(item).renderAll();
165
+ }
166
+ );
167
+ }
168
+ // if (curFileSuffix === 'json') {
169
+ // const dataText = await getImageText(file);
170
+ // const template = JSON.parse(dataText);
171
+ // addTemplate(template);
172
+ // }
173
+ if (item.type.indexOf('image/') === 0) {
174
+ // 这是一个图片文件
175
+ const imageUrl = URL.createObjectURL(file);
176
+ const imgEl = document.createElement('img');
177
+ imgEl.src = imageUrl;
178
+ // 插入页面
179
+ document.body.appendChild(imgEl);
180
+ imgEl.onload = () => {
181
+ // 创建图片对象
182
+ const imgInstance = new fabric.Image(imgEl, {
183
+ id: uuid(),
184
+ name: '图片1',
185
+ left: 100,
186
+ top: 100,
187
+ });
188
+ // 设置缩放
189
+ canvas.add(imgInstance);
190
+ canvas.setActiveObject(imgInstance);
191
+ canvas.renderAll();
192
+ // 删除页面中的图片元素
193
+ imgEl.remove();
194
+ };
195
+ }
196
+ } else if (
197
+ item.kind === 'string' &&
198
+ item.type.indexOf('text/plain') === 0
199
+ ) {
200
+ // 文本数据
201
+ item.getAsString((text: any) => {
202
+ // 插入到文本框
203
+ const activeObject =
204
+ canvas.getActiveObject() as fabric.Textbox;
205
+ // 如果是激活的文字把复制的内容插入到对应光标位置
206
+ if (
207
+ activeObject &&
208
+ (activeObject.type === 'textbox' ||
209
+ activeObject.type === 'i-text') &&
210
+ activeObject.text
211
+ ) {
212
+ const cursorPosition = activeObject.selectionStart;
213
+ const textBeforeCursorPosition =
214
+ activeObject.text.substring(0, cursorPosition);
215
+ const textAfterCursorPosition =
216
+ activeObject.text.substring(
217
+ cursorPosition as number
218
+ );
219
+
220
+ // 更新文本对象的文本
221
+ activeObject.set(
222
+ 'text',
223
+ textBeforeCursorPosition +
224
+ text +
225
+ textAfterCursorPosition
226
+ );
227
+
228
+ // 重新设置光标的位置
229
+ activeObject.selectionStart =
230
+ cursorPosition + text.length;
231
+ activeObject.selectionEnd =
232
+ cursorPosition + text.length;
233
+
234
+ // 重新渲染画布展示更新后的文本
235
+ activeObject.dirty = true;
236
+ canvas.renderAll();
237
+ } else {
238
+ const fabricText = new fabric.IText(text, {
239
+ left: 100,
240
+ top: 100,
241
+ fontSize: 80,
242
+ id: uuid(),
243
+ });
244
+ canvas.add(fabricText);
245
+ canvas.setActiveObject(fabricText);
246
+ }
247
+ });
248
+ }
249
+ }
250
+ // 复制浏览器外的元素时,清空暂存的画布内粘贴元素
251
+ if (items.length) this.cache = null;
252
+ }
253
+ }
254
+
255
+ export default CopyPlugin;