@meta2d/core 1.0.56 → 1.0.57

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 (299) hide show
  1. package/{index.ts → index.d.ts} +9 -9
  2. package/index.js +10 -0
  3. package/index.js.map +1 -0
  4. package/package.json +38 -39
  5. package/src/canvas/canvas.d.ts +456 -0
  6. package/src/canvas/canvas.js +7584 -0
  7. package/src/canvas/canvas.js.map +1 -0
  8. package/src/canvas/canvasImage.d.ts +27 -0
  9. package/src/canvas/canvasImage.js +441 -0
  10. package/src/canvas/canvasImage.js.map +1 -0
  11. package/src/canvas/canvasTemplate.d.ts +18 -0
  12. package/src/canvas/canvasTemplate.js +209 -0
  13. package/src/canvas/canvasTemplate.js.map +1 -0
  14. package/src/canvas/{index.ts → index.d.ts} +2 -2
  15. package/src/canvas/index.js +3 -0
  16. package/src/canvas/index.js.map +1 -0
  17. package/src/canvas/magnifierCanvas.d.ts +19 -0
  18. package/src/canvas/magnifierCanvas.js +102 -0
  19. package/src/canvas/magnifierCanvas.js.map +1 -0
  20. package/src/canvas/offscreen.d.ts +1 -0
  21. package/src/canvas/offscreen.js +14 -0
  22. package/src/canvas/offscreen.js.map +1 -0
  23. package/src/core.d.ts +479 -0
  24. package/src/core.js +4590 -0
  25. package/src/core.js.map +1 -0
  26. package/src/data.d.ts +34 -0
  27. package/src/data.js +85 -0
  28. package/src/data.js.map +1 -0
  29. package/src/diagrams/arrow.d.ts +4 -0
  30. package/src/diagrams/arrow.js +47 -0
  31. package/src/diagrams/arrow.js.map +1 -0
  32. package/src/diagrams/circle.d.ts +2 -0
  33. package/src/diagrams/circle.js +9 -0
  34. package/src/diagrams/circle.js.map +1 -0
  35. package/src/diagrams/cloud.d.ts +2 -0
  36. package/src/diagrams/cloud.js +12 -0
  37. package/src/diagrams/cloud.js.map +1 -0
  38. package/src/diagrams/cube.d.ts +2 -0
  39. package/src/diagrams/cube.js +68 -0
  40. package/src/diagrams/cube.js.map +1 -0
  41. package/src/diagrams/diamond.d.ts +2 -0
  42. package/src/diagrams/diamond.js +13 -0
  43. package/src/diagrams/diamond.js.map +1 -0
  44. package/src/diagrams/file.d.ts +2 -0
  45. package/src/diagrams/file.js +18 -0
  46. package/src/diagrams/file.js.map +1 -0
  47. package/src/diagrams/gif.d.ts +5 -0
  48. package/src/diagrams/gif.js +89 -0
  49. package/src/diagrams/gif.js.map +1 -0
  50. package/src/diagrams/hexagon.d.ts +2 -0
  51. package/src/diagrams/{hexagon.ts → hexagon.js} +55 -60
  52. package/src/diagrams/hexagon.js.map +1 -0
  53. package/src/diagrams/iframe.d.ts +2 -0
  54. package/src/diagrams/iframe.js +338 -0
  55. package/src/diagrams/iframe.js.map +1 -0
  56. package/src/diagrams/index.d.ts +71 -0
  57. package/src/diagrams/{index.ts → index.js} +77 -79
  58. package/src/diagrams/index.js.map +1 -0
  59. package/src/diagrams/line/arrow.d.ts +2 -0
  60. package/src/diagrams/line/arrow.js +128 -0
  61. package/src/diagrams/line/arrow.js.map +1 -0
  62. package/src/diagrams/line/curve.d.ts +16 -0
  63. package/src/diagrams/line/curve.js +227 -0
  64. package/src/diagrams/line/curve.js.map +1 -0
  65. package/src/diagrams/line/{index.ts → index.d.ts} +5 -5
  66. package/src/diagrams/line/index.js +6 -0
  67. package/src/diagrams/line/index.js.map +1 -0
  68. package/src/diagrams/line/line.d.ts +42 -0
  69. package/src/diagrams/line/line.js +370 -0
  70. package/src/diagrams/line/line.js.map +1 -0
  71. package/src/diagrams/line/polyline.d.ts +10 -0
  72. package/src/diagrams/line/polyline.js +627 -0
  73. package/src/diagrams/line/polyline.js.map +1 -0
  74. package/src/diagrams/line/smooth.d.ts +3 -0
  75. package/src/diagrams/line/smooth.js +136 -0
  76. package/src/diagrams/line/smooth.js.map +1 -0
  77. package/src/diagrams/message.d.ts +2 -0
  78. package/src/diagrams/message.js +15 -0
  79. package/src/diagrams/message.js.map +1 -0
  80. package/src/diagrams/mindLine.d.ts +3 -0
  81. package/src/diagrams/mindLine.js +30 -0
  82. package/src/diagrams/mindLine.js.map +1 -0
  83. package/src/diagrams/mindNode.d.ts +3 -0
  84. package/src/diagrams/mindNode.js +161 -0
  85. package/src/diagrams/mindNode.js.map +1 -0
  86. package/src/diagrams/panel.d.ts +2 -0
  87. package/src/diagrams/panel.js +131 -0
  88. package/src/diagrams/panel.js.map +1 -0
  89. package/src/diagrams/pentagon.d.ts +3 -0
  90. package/src/diagrams/pentagon.js +45 -0
  91. package/src/diagrams/pentagon.js.map +1 -0
  92. package/src/diagrams/pentagram.d.ts +3 -0
  93. package/src/diagrams/pentagram.js +51 -0
  94. package/src/diagrams/pentagram.js.map +1 -0
  95. package/src/diagrams/people.d.ts +2 -0
  96. package/src/diagrams/people.js +19 -0
  97. package/src/diagrams/people.js.map +1 -0
  98. package/src/diagrams/rectangle.d.ts +3 -0
  99. package/src/diagrams/rectangle.js +26 -0
  100. package/src/diagrams/rectangle.js.map +1 -0
  101. package/src/diagrams/svg/parse.d.ts +15 -0
  102. package/src/diagrams/svg/parse.js +279 -0
  103. package/src/diagrams/svg/parse.js.map +1 -0
  104. package/src/diagrams/svgPath.d.ts +2 -0
  105. package/src/diagrams/svgPath.js +29 -0
  106. package/src/diagrams/svgPath.js.map +1 -0
  107. package/src/diagrams/triangle.d.ts +3 -0
  108. package/src/diagrams/triangle.js +40 -0
  109. package/src/diagrams/triangle.js.map +1 -0
  110. package/src/diagrams/video.d.ts +5 -0
  111. package/src/diagrams/video.js +184 -0
  112. package/src/diagrams/video.js.map +1 -0
  113. package/src/dialog/dialog.d.ts +21 -0
  114. package/src/dialog/dialog.js +157 -0
  115. package/src/dialog/dialog.js.map +1 -0
  116. package/src/dialog/{index.ts → index.d.ts} +1 -1
  117. package/src/dialog/index.js +2 -0
  118. package/src/dialog/index.js.map +1 -0
  119. package/src/event/event.d.ts +102 -0
  120. package/src/event/event.js +22 -0
  121. package/src/event/event.js.map +1 -0
  122. package/src/event/{index.ts → index.d.ts} +1 -1
  123. package/src/event/index.js +2 -0
  124. package/src/event/index.js.map +1 -0
  125. package/src/map/{index.ts → index.d.ts} +1 -1
  126. package/src/map/index.js +2 -0
  127. package/src/map/index.js.map +1 -0
  128. package/src/map/map.d.ts +21 -0
  129. package/src/map/map.js +212 -0
  130. package/src/map/map.js.map +1 -0
  131. package/src/options.d.ts +130 -0
  132. package/src/options.js +80 -0
  133. package/src/options.js.map +1 -0
  134. package/src/pen/arrow.d.ts +4 -0
  135. package/src/pen/arrow.js +188 -0
  136. package/src/pen/arrow.js.map +1 -0
  137. package/src/pen/{index.ts → index.d.ts} +6 -6
  138. package/src/pen/index.js +7 -0
  139. package/src/pen/index.js.map +1 -0
  140. package/src/pen/math.d.ts +28 -0
  141. package/src/pen/math.js +213 -0
  142. package/src/pen/math.js.map +1 -0
  143. package/src/pen/model.d.ts +514 -0
  144. package/src/pen/model.js +210 -0
  145. package/src/pen/model.js.map +1 -0
  146. package/src/pen/plugin.d.ts +5 -0
  147. package/src/pen/plugin.js +58 -0
  148. package/src/pen/plugin.js.map +1 -0
  149. package/src/pen/render.d.ts +146 -0
  150. package/src/pen/render.js +3234 -0
  151. package/src/pen/render.js.map +1 -0
  152. package/src/pen/text.d.ts +8 -0
  153. package/src/pen/text.js +316 -0
  154. package/src/pen/text.js.map +1 -0
  155. package/src/pen/utils.d.ts +2 -0
  156. package/src/pen/utils.js +19 -0
  157. package/src/pen/utils.js.map +1 -0
  158. package/src/point/{index.ts → index.d.ts} +1 -1
  159. package/src/point/index.js +2 -0
  160. package/src/point/index.js.map +1 -0
  161. package/src/point/point.d.ts +65 -0
  162. package/src/point/point.js +178 -0
  163. package/src/point/point.js.map +1 -0
  164. package/src/rect/{index.ts → index.d.ts} +1 -1
  165. package/src/rect/index.js +2 -0
  166. package/src/rect/index.js.map +1 -0
  167. package/src/rect/rect.d.ts +52 -0
  168. package/src/rect/rect.js +427 -0
  169. package/src/rect/rect.js.map +1 -0
  170. package/src/rect/triangle.d.ts +2 -0
  171. package/src/rect/triangle.js +10 -0
  172. package/src/rect/triangle.js.map +1 -0
  173. package/src/scroll/{index.ts → index.d.ts} +1 -1
  174. package/src/scroll/index.js +2 -0
  175. package/src/scroll/index.js.map +1 -0
  176. package/src/scroll/scroll.d.ts +35 -0
  177. package/src/scroll/scroll.js +234 -0
  178. package/src/scroll/scroll.js.map +1 -0
  179. package/src/store/global.d.ts +25 -0
  180. package/src/store/global.js +18 -0
  181. package/src/store/global.js.map +1 -0
  182. package/src/store/{index.ts → index.d.ts} +2 -2
  183. package/src/store/index.js +3 -0
  184. package/src/store/index.js.map +1 -0
  185. package/src/store/store.d.ts +228 -0
  186. package/src/store/store.js +87 -0
  187. package/src/store/store.js.map +1 -0
  188. package/src/theme.d.ts +13 -0
  189. package/src/theme.js +23 -0
  190. package/src/theme.js.map +1 -0
  191. package/src/title/{index.ts → index.d.ts} +1 -1
  192. package/src/title/index.js +2 -0
  193. package/src/title/index.js.map +1 -0
  194. package/src/title/title.d.ts +30 -0
  195. package/src/title/title.js +99 -0
  196. package/src/title/title.js.map +1 -0
  197. package/src/tooltip/{index.ts → index.d.ts} +1 -1
  198. package/src/tooltip/index.js +2 -0
  199. package/src/tooltip/index.js.map +1 -0
  200. package/src/tooltip/tooltip.d.ts +40 -0
  201. package/src/tooltip/tooltip.js +172 -0
  202. package/src/tooltip/tooltip.js.map +1 -0
  203. package/src/utils/clone.d.ts +8 -0
  204. package/src/utils/clone.js +84 -0
  205. package/src/utils/clone.js.map +1 -0
  206. package/src/utils/color.d.ts +3 -0
  207. package/src/utils/color.js +110 -0
  208. package/src/utils/color.js.map +1 -0
  209. package/src/utils/error.d.ts +2 -0
  210. package/src/utils/error.js +6 -0
  211. package/src/utils/error.js.map +1 -0
  212. package/src/utils/file.d.ts +3 -0
  213. package/src/utils/file.js +40 -0
  214. package/src/utils/file.js.map +1 -0
  215. package/src/utils/{index.ts → index.d.ts} +9 -9
  216. package/src/utils/index.js +10 -0
  217. package/src/utils/index.js.map +1 -0
  218. package/src/utils/math.d.ts +18 -0
  219. package/src/utils/math.js +114 -0
  220. package/src/utils/math.js.map +1 -0
  221. package/src/utils/object.d.ts +2 -0
  222. package/src/utils/object.js +21 -0
  223. package/src/utils/object.js.map +1 -0
  224. package/src/utils/padding.d.ts +7 -0
  225. package/src/utils/padding.js +47 -0
  226. package/src/utils/padding.js.map +1 -0
  227. package/src/utils/time.d.ts +1 -0
  228. package/src/utils/time.js +17 -0
  229. package/src/utils/time.js.map +1 -0
  230. package/src/utils/url.d.ts +4 -0
  231. package/src/utils/url.js +27 -0
  232. package/src/utils/url.js.map +1 -0
  233. package/src/utils/uuid.d.ts +4 -0
  234. package/src/utils/uuid.js +13 -0
  235. package/src/utils/uuid.js.map +1 -0
  236. package/README.md +0 -13
  237. package/package.build.json +0 -39
  238. package/src/canvas/canvas.ts +0 -8639
  239. package/src/canvas/canvasImage.ts +0 -525
  240. package/src/canvas/canvasTemplate.ts +0 -257
  241. package/src/canvas/magnifierCanvas.ts +0 -142
  242. package/src/canvas/offscreen.ts +0 -14
  243. package/src/core.ts +0 -5128
  244. package/src/data.ts +0 -86
  245. package/src/diagrams/arrow.ts +0 -50
  246. package/src/diagrams/circle.ts +0 -19
  247. package/src/diagrams/cloud.ts +0 -34
  248. package/src/diagrams/cube.ts +0 -94
  249. package/src/diagrams/diamond.ts +0 -14
  250. package/src/diagrams/file.ts +0 -19
  251. package/src/diagrams/gif.ts +0 -105
  252. package/src/diagrams/iframe.ts +0 -365
  253. package/src/diagrams/line/arrow.ts +0 -175
  254. package/src/diagrams/line/curve.ts +0 -260
  255. package/src/diagrams/line/line.ts +0 -409
  256. package/src/diagrams/line/polyline.ts +0 -676
  257. package/src/diagrams/line/smooth.ts +0 -133
  258. package/src/diagrams/message.ts +0 -17
  259. package/src/diagrams/mindLine.ts +0 -31
  260. package/src/diagrams/mindNode.ts +0 -177
  261. package/src/diagrams/panel.ts +0 -149
  262. package/src/diagrams/pentagon.ts +0 -48
  263. package/src/diagrams/pentagram.ts +0 -63
  264. package/src/diagrams/people.ts +0 -23
  265. package/src/diagrams/rectangle.ts +0 -29
  266. package/src/diagrams/svg/parse.ts +0 -319
  267. package/src/diagrams/svgPath.ts +0 -53
  268. package/src/diagrams/triangle.ts +0 -43
  269. package/src/diagrams/video.ts +0 -202
  270. package/src/dialog/dialog.ts +0 -177
  271. package/src/event/event.ts +0 -142
  272. package/src/map/map.ts +0 -239
  273. package/src/options.ts +0 -205
  274. package/src/pen/arrow.ts +0 -259
  275. package/src/pen/math.ts +0 -253
  276. package/src/pen/model.ts +0 -785
  277. package/src/pen/plugin.ts +0 -57
  278. package/src/pen/render.ts +0 -3725
  279. package/src/pen/text.ts +0 -341
  280. package/src/pen/utils.ts +0 -21
  281. package/src/point/point.ts +0 -232
  282. package/src/rect/rect.ts +0 -507
  283. package/src/rect/triangle.ts +0 -16
  284. package/src/scroll/scroll.ts +0 -277
  285. package/src/store/global.ts +0 -38
  286. package/src/store/store.ts +0 -293
  287. package/src/theme.ts +0 -35
  288. package/src/title/title.ts +0 -115
  289. package/src/tooltip/tooltip.ts +0 -199
  290. package/src/utils/clone.ts +0 -79
  291. package/src/utils/color.ts +0 -126
  292. package/src/utils/error.ts +0 -7
  293. package/src/utils/file.ts +0 -46
  294. package/src/utils/math.ts +0 -120
  295. package/src/utils/object.ts +0 -23
  296. package/src/utils/padding.ts +0 -48
  297. package/src/utils/time.ts +0 -25
  298. package/src/utils/url.ts +0 -30
  299. package/src/utils/uuid.ts +0 -15
@@ -0,0 +1,234 @@
1
+ import { getRect } from '../rect';
2
+ export class Scroll {
3
+ parent;
4
+ h;
5
+ v;
6
+ isDownH;
7
+ isDownV;
8
+ x;
9
+ y;
10
+ hSize;
11
+ vSize;
12
+ scrollX;
13
+ scrollY;
14
+ lastScrollX;
15
+ lastScrollY;
16
+ rect;
17
+ isShow;
18
+ pageMode; //页面模式
19
+ constructor(parent) {
20
+ this.parent = parent;
21
+ this.h = document.createElement('div');
22
+ this.v = document.createElement('div');
23
+ this.parent.externalElements.appendChild(this.h);
24
+ this.parent.externalElements.appendChild(this.v);
25
+ this.h.className = 'meta2d-scroll h';
26
+ this.h.onmousedown = this.onMouseDownH;
27
+ this.v.className = 'meta2d-scroll v';
28
+ this.v.onmousedown = this.onMouseDownV;
29
+ document.addEventListener('mousemove', this.onMouseMove);
30
+ document.addEventListener('mouseup', this.onMouseUp);
31
+ let sheet;
32
+ for (let i = 0; i < document.styleSheets.length; i++) {
33
+ if (document.styleSheets[i].title === 'le5le/scroll') {
34
+ sheet = document.styleSheets[i];
35
+ }
36
+ }
37
+ if (!sheet) {
38
+ let style = document.createElement('style');
39
+ style.type = 'text/css';
40
+ style.title = 'le5le.com/scroll';
41
+ document.head.appendChild(style);
42
+ style = document.createElement('style');
43
+ style.type = 'text/css';
44
+ document.head.appendChild(style);
45
+ sheet = style.sheet;
46
+ sheet.insertRule('.meta2d-scroll{position:absolute;width:8px;height:200px;background:#dddddd;border-radius:10px;z-index:20;cursor:default;}');
47
+ sheet.insertRule('.meta2d-scroll:hover{background:#cccccc;cursor:pointer}');
48
+ sheet.insertRule('.meta2d-scroll.v{right:0;top:calc(50% - 100px);}');
49
+ sheet.insertRule('.meta2d-scroll.h{bottom:2px;left:calc(50% - 100px);width:200px;height:8px;}');
50
+ }
51
+ this.init();
52
+ }
53
+ init() {
54
+ this.isShow = true;
55
+ this.resize();
56
+ this.initPos();
57
+ }
58
+ onMouseDownH = (e) => {
59
+ e.preventDefault();
60
+ e.stopPropagation();
61
+ this.isDownH = e.x;
62
+ this.x = this.parent.store.data.x || 0;
63
+ this.lastScrollX = this.scrollX;
64
+ };
65
+ onMouseDownV = (e) => {
66
+ e.preventDefault();
67
+ e.stopPropagation();
68
+ this.isDownV = e.y;
69
+ this.y = this.parent.store.data.y || 0;
70
+ this.lastScrollY = this.scrollY;
71
+ };
72
+ onMouseMove = (e) => {
73
+ if (this.isDownH) {
74
+ const x = e.x - this.isDownH;
75
+ this.scrollX = this.lastScrollX + x;
76
+ this.h.style.left = `${this.scrollX}px`;
77
+ this.parent.store.data.x =
78
+ this.x - (x * this.rect.width) / this.parent.parentElement.clientWidth;
79
+ }
80
+ if (this.isDownV) {
81
+ const y = e.y - this.isDownV;
82
+ if (this.pageMode && this.canMouseMove(y)) {
83
+ return;
84
+ }
85
+ this.scrollY = this.lastScrollY + y;
86
+ this.v.style.top = `${this.scrollY}px`;
87
+ this.parent.store.data.y =
88
+ this.y -
89
+ (y * this.rect.height) / this.parent.parentElement.clientHeight;
90
+ }
91
+ if (this.isDownH || this.isDownV) {
92
+ this.parent.onMovePens();
93
+ this.parent.canvasTemplate.init();
94
+ this.parent.canvasImage.init();
95
+ this.parent.canvasImageBottom.init();
96
+ this.parent.render();
97
+ }
98
+ };
99
+ onMouseUp = (e) => {
100
+ if (!this.isDownH && !this.isDownV) {
101
+ return;
102
+ }
103
+ this.isDownH = undefined;
104
+ this.isDownV = undefined;
105
+ if (this.scrollX < 20) {
106
+ this.scrollX = 20;
107
+ this.h.style.left = `${this.scrollX}px`;
108
+ }
109
+ else if (this.scrollX >
110
+ this.parent.parentElement.clientWidth - this.hSize - 20) {
111
+ this.scrollX = this.parent.parentElement.clientWidth - this.hSize - 20;
112
+ this.h.style.left = `${this.scrollX}px`;
113
+ }
114
+ if (this.scrollY < 20) {
115
+ this.scrollY = 20;
116
+ this.v.style.top = `${this.scrollY}px`;
117
+ }
118
+ else if (this.scrollY >
119
+ this.parent.parentElement.clientHeight - this.vSize - 20) {
120
+ this.scrollY = this.parent.parentElement.clientHeight - this.vSize - 20;
121
+ this.v.style.top = `${this.scrollY}px`;
122
+ }
123
+ this.resize();
124
+ };
125
+ canMouseMove(y) {
126
+ const rect = this.parent.parent.getRect();
127
+ if (y < 0 && rect.y + this.parent.store.data.y >= 0) {
128
+ return true;
129
+ }
130
+ if (y > 0 && rect.ey - this.parent.height + this.parent.store.data.y <= 0) {
131
+ return true;
132
+ }
133
+ return false;
134
+ }
135
+ changeMode() {
136
+ this.pageMode = true;
137
+ this.h.style.display = `none`;
138
+ const rect = this.parent.parent.getRect();
139
+ if (rect.height < this.parent.height) {
140
+ this.v.style.display = `none`;
141
+ }
142
+ }
143
+ initPos() {
144
+ this.scrollX = (this.parent.parentElement.clientWidth - this.hSize) / 2;
145
+ this.scrollY = (this.parent.parentElement.clientHeight - this.vSize) / 2;
146
+ this.h.style.left = `${this.scrollX}px`;
147
+ this.v.style.top = `${this.scrollY}px`;
148
+ }
149
+ resize() {
150
+ this.rect = getRect(this.parent.store.data.pens);
151
+ if (this.rect.width < 1400) {
152
+ this.rect.width = 1400;
153
+ }
154
+ if (this.rect.height < 900) {
155
+ this.rect.height = 900;
156
+ }
157
+ if (this.parent.store.data.x > 0) {
158
+ this.rect.width +=
159
+ this.parent.store.data.x + (this.rect.x > 0 ? 0 : this.rect.x);
160
+ }
161
+ else {
162
+ this.rect.width -=
163
+ this.parent.store.data.x + (this.rect.x > 0 ? 0 : this.rect.x);
164
+ }
165
+ if (this.parent.store.data.y > 0) {
166
+ this.rect.height +=
167
+ this.parent.store.data.y + (this.rect.y > 0 ? 0 : this.rect.y);
168
+ }
169
+ else {
170
+ this.rect.height -=
171
+ this.parent.store.data.y + (this.rect.y > 0 ? 0 : this.rect.y);
172
+ }
173
+ if (this.rect.width < 1400) {
174
+ this.rect.width = 1400;
175
+ }
176
+ if (this.rect.height < 900) {
177
+ this.rect.height = 900;
178
+ }
179
+ this.hSize =
180
+ (1000 * this.parent.parentElement.clientWidth) / this.rect.width / 3;
181
+ this.vSize =
182
+ (1000 * this.parent.parentElement.clientHeight) / this.rect.height / 3;
183
+ this.h.style.width = this.hSize + 'px';
184
+ this.v.style.height = this.vSize + 'px';
185
+ }
186
+ show() {
187
+ this.isShow = true;
188
+ this.h.style.display = `block`;
189
+ this.v.style.display = `block`;
190
+ document.addEventListener('mousemove', this.onMouseMove);
191
+ document.addEventListener('mouseup', this.onMouseUp);
192
+ }
193
+ hide() {
194
+ this.isShow = false;
195
+ this.h.style.display = `none`;
196
+ this.v.style.display = `none`;
197
+ this.destroy();
198
+ }
199
+ translate(x, y) {
200
+ if (x) {
201
+ this.scrollX -=
202
+ (x * this.parent.parentElement.clientWidth) / this.rect.width;
203
+ this.h.style.left = `${this.scrollX}px`;
204
+ }
205
+ if (y) {
206
+ this.scrollY -=
207
+ (y * this.parent.parentElement.clientHeight) / this.rect.height;
208
+ this.v.style.top = `${this.scrollY}px`;
209
+ }
210
+ }
211
+ wheel(up) {
212
+ let y = 10;
213
+ if (up) {
214
+ y = -10;
215
+ }
216
+ if (this.pageMode && this.canMouseMove(y)) {
217
+ return;
218
+ }
219
+ this.scrollY += y;
220
+ this.v.style.top = `${this.scrollY}px`;
221
+ this.parent.store.data.y -=
222
+ (y * this.rect.height) / this.parent.parentElement.clientHeight;
223
+ this.parent.onMovePens();
224
+ this.parent.canvasTemplate.init();
225
+ this.parent.canvasImage.init();
226
+ this.parent.canvasImageBottom.init();
227
+ this.parent.render();
228
+ }
229
+ destroy() {
230
+ document.removeEventListener('mousemove', this.onMouseMove);
231
+ document.removeEventListener('mouseup', this.onMouseUp);
232
+ }
233
+ }
234
+ //# sourceMappingURL=scroll.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"scroll.js","sourceRoot":"","sources":["../../../../packages/core/src/scroll/scroll.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,25 @@
1
+ import { Pen } from '../pen';
2
+ export declare const globalStore: {
3
+ version: string;
4
+ path2dDraws: {
5
+ [key: string]: (pen: Pen, ctx?: CanvasRenderingContext2D) => Path2D;
6
+ };
7
+ canvasDraws: {
8
+ [key: string]: (ctx: CanvasRenderingContext2D, pen: Pen) => void;
9
+ };
10
+ anchors: {
11
+ [key: string]: (pen: Pen) => void;
12
+ };
13
+ htmlElements: {
14
+ [key: string]: HTMLImageElement;
15
+ };
16
+ };
17
+ export declare function register(path2dFns: {
18
+ [key: string]: (pen: Pen, ctx?: CanvasRenderingContext2D) => Path2D;
19
+ }): void;
20
+ export declare function registerCanvasDraw(drawFns: {
21
+ [key: string]: (ctx: CanvasRenderingContext2D, pen: Pen) => void;
22
+ }): void;
23
+ export declare function registerAnchors(anchorsFns: {
24
+ [key: string]: (pen: Pen) => void;
25
+ }): void;
@@ -0,0 +1,18 @@
1
+ import pkg from '../../package.json';
2
+ export const globalStore = {
3
+ version: pkg.version,
4
+ path2dDraws: {},
5
+ canvasDraws: {},
6
+ anchors: {},
7
+ htmlElements: {},
8
+ };
9
+ export function register(path2dFns) {
10
+ Object.assign(globalStore.path2dDraws, path2dFns);
11
+ }
12
+ export function registerCanvasDraw(drawFns) {
13
+ Object.assign(globalStore.canvasDraws, drawFns);
14
+ }
15
+ export function registerAnchors(anchorsFns) {
16
+ Object.assign(globalStore.anchors, anchorsFns);
17
+ }
18
+ //# sourceMappingURL=global.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"global.js","sourceRoot":"","sources":["../../../../packages/core/src/store/global.ts"],"names":[],"mappings":"AAAA,OAAO,GAAG,MAAM,oBAAoB,CAAC;AAGrC,MAAM,CAAC,MAAM,WAAW,GAUpB;IACF,OAAO,EAAE,GAAG,CAAC,OAAO;IACpB,WAAW,EAAE,EAAE;IACf,WAAW,EAAE,EAAE;IACf,OAAO,EAAE,EAAE;IACX,YAAY,EAAE,EAAE;CACjB,CAAC;AAEF,MAAM,UAAU,QAAQ,CAAC,SAExB;IACC,MAAM,CAAC,MAAM,CAAC,WAAW,CAAC,WAAW,EAAE,SAAS,CAAC,CAAC;AACpD,CAAC;AAED,MAAM,UAAU,kBAAkB,CAAC,OAElC;IACC,MAAM,CAAC,MAAM,CAAC,WAAW,CAAC,WAAW,EAAE,OAAO,CAAC,CAAC;AAClD,CAAC;AAED,MAAM,UAAU,eAAe,CAAC,UAE/B;IACC,MAAM,CAAC,MAAM,CAAC,WAAW,CAAC,OAAO,EAAE,UAAU,CAAC,CAAC;AACjD,CAAC"}
@@ -1,2 +1,2 @@
1
- export * from './global';
2
- export * from './store';
1
+ export * from './global';
2
+ export * from './store';
@@ -0,0 +1,3 @@
1
+ export * from './global';
2
+ export * from './store';
3
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../packages/core/src/store/index.ts"],"names":[],"mappings":"AAAA,cAAc,UAAU,CAAC;AACzB,cAAc,SAAS,CAAC"}
@@ -0,0 +1,228 @@
1
+ import { Emitter } from 'mitt';
2
+ import { FormItem, LockState, Pen } from '../pen';
3
+ import { Options } from '../options';
4
+ import { Theme } from '../theme';
5
+ import { Point } from '../point';
6
+ import { Rect } from '../rect';
7
+ import { Event, Trigger } from '../event';
8
+ export interface Meta2dData {
9
+ pens: Pen[];
10
+ x: number;
11
+ y: number;
12
+ scale: number;
13
+ origin: Point;
14
+ center: Point;
15
+ locked?: LockState;
16
+ websocket?: string;
17
+ mqtt?: string;
18
+ mqttOptions?: {
19
+ clientId?: string;
20
+ username?: string;
21
+ password?: string;
22
+ customClientId?: boolean;
23
+ };
24
+ mqttTopics?: string;
25
+ websocketProtocols?: string | string[];
26
+ background?: string;
27
+ globalAlpha?: number;
28
+ socketCbJs?: string;
29
+ initJs?: string;
30
+ grid?: boolean;
31
+ gridColor?: string;
32
+ gridSize?: number;
33
+ gridRotate?: number;
34
+ rule?: boolean;
35
+ ruleColor?: string;
36
+ fromArrow?: string;
37
+ toArrow?: string;
38
+ lineWidth?: number;
39
+ color?: string;
40
+ textColor?: string;
41
+ penBackground?: string;
42
+ paths?: {
43
+ [key: string]: string;
44
+ };
45
+ bkImage?: string;
46
+ http?: string;
47
+ httpTimeInterval?: number;
48
+ httpHeaders?: HeadersInit;
49
+ version?: string;
50
+ id?: string;
51
+ _id?: string;
52
+ https?: HttpOptions[];
53
+ width?: number;
54
+ height?: number;
55
+ networkInterval?: number;
56
+ networks?: Network[];
57
+ iconUrls?: string[];
58
+ mockData?: Function;
59
+ name?: string;
60
+ enableMock?: boolean;
61
+ minScale?: number;
62
+ maxScale?: number;
63
+ template?: string;
64
+ cancelFirstConnect?: boolean;
65
+ component?: boolean;
66
+ theme?: string;
67
+ smoothNum?: number;
68
+ triggers?: Trigger[];
69
+ dataPoints?: string[];
70
+ dataset?: {
71
+ devices?: DataMock[];
72
+ };
73
+ dataEvents?: Event[];
74
+ fits?: Fit[];
75
+ disableTranslate?: boolean;
76
+ disableScale?: boolean;
77
+ }
78
+ export interface Fit {
79
+ id?: string;
80
+ name?: string;
81
+ x?: number;
82
+ y?: number;
83
+ ex?: number;
84
+ ey?: number;
85
+ width?: number;
86
+ height?: number;
87
+ children?: string[];
88
+ active?: boolean;
89
+ left?: boolean;
90
+ right?: boolean;
91
+ top?: boolean;
92
+ bottom?: boolean;
93
+ leftValue?: number;
94
+ rightValue?: number;
95
+ topValue?: number;
96
+ bottomValue?: number;
97
+ }
98
+ export interface DataMock {
99
+ id: string;
100
+ label?: string;
101
+ mock?: string;
102
+ type?: string;
103
+ enableMock?: boolean;
104
+ }
105
+ export interface Network {
106
+ name?: string;
107
+ protocol?: 'mqtt' | 'websocket' | 'http';
108
+ type?: string;
109
+ url?: string;
110
+ protocols?: string;
111
+ topics?: string;
112
+ options?: {
113
+ clientId?: string;
114
+ username?: string;
115
+ password?: string;
116
+ customClientId?: boolean;
117
+ };
118
+ headers?: any;
119
+ method?: string;
120
+ body?: any;
121
+ data?: Network;
122
+ interval?: number;
123
+ times?: number;
124
+ index?: number;
125
+ }
126
+ export interface HttpOptions {
127
+ http?: string;
128
+ httpTimeInterval?: number;
129
+ httpHeaders?: HeadersInit;
130
+ method?: string;
131
+ body?: BodyInit | null;
132
+ times?: number;
133
+ }
134
+ export declare enum EditType {
135
+ Add = 0,
136
+ Update = 1,
137
+ Delete = 2,
138
+ Replace = 3
139
+ }
140
+ export interface EditAction {
141
+ type?: EditType;
142
+ initPens?: Pen[];
143
+ pens?: Pen[];
144
+ step?: number;
145
+ origin?: Point;
146
+ scale?: number;
147
+ }
148
+ export interface Meta2dStore {
149
+ id: string;
150
+ data: Meta2dData;
151
+ pens: {
152
+ [key: string]: Pen;
153
+ };
154
+ histories?: EditAction[];
155
+ historyIndex?: number;
156
+ path2dMap: WeakMap<Pen, Path2D>;
157
+ animateMap: WeakMap<Pen, Pen>;
158
+ bindDatas: {
159
+ [key: string]: {
160
+ id: string;
161
+ formItem: FormItem;
162
+ }[];
163
+ };
164
+ bind?: {
165
+ [key: string]: {
166
+ id: string;
167
+ key: string;
168
+ }[];
169
+ };
170
+ active?: Pen[];
171
+ hover?: Pen;
172
+ lastHover?: Pen;
173
+ hoverContainer?: Pen;
174
+ lastHoverContainer?: Pen;
175
+ activeAnchor?: Point;
176
+ hoverAnchor?: Point;
177
+ pointAt?: Point;
178
+ pointAtIndex?: number;
179
+ animates: Set<Pen>;
180
+ options: Options;
181
+ theme: Theme;
182
+ emitter: Emitter;
183
+ dpiRatio?: number;
184
+ clipboard?: Meta2dClipboard;
185
+ patchFlagsBackground?: boolean;
186
+ patchFlagsTop?: boolean;
187
+ bkImg?: HTMLImageElement;
188
+ fillWorldTextRect?: boolean;
189
+ cacheDatas?: {
190
+ data: Meta2dData;
191
+ }[];
192
+ patchFlagsLast?: boolean;
193
+ messageEvents?: {
194
+ [key: string]: {
195
+ pen: Pen;
196
+ event: Event;
197
+ }[];
198
+ };
199
+ templatePens?: {
200
+ [key: string]: Pen;
201
+ };
202
+ sameTemplate?: boolean;
203
+ lastScale?: number;
204
+ pensNetwork?: {
205
+ [key: string]: {
206
+ url?: string;
207
+ method?: string;
208
+ headers?: any;
209
+ body?: any;
210
+ };
211
+ };
212
+ globalTriggers?: {
213
+ [key: string]: Trigger[];
214
+ };
215
+ }
216
+ export interface Meta2dClipboard {
217
+ meta2d?: boolean;
218
+ pens: Pen[];
219
+ origin: Point;
220
+ scale: number;
221
+ offset?: number;
222
+ page: string;
223
+ initRect?: Rect;
224
+ pos?: Point;
225
+ }
226
+ export declare const createStore: () => Meta2dStore;
227
+ export declare const useStore: (id?: string) => Meta2dStore;
228
+ export declare const clearStore: (store: Meta2dStore, template?: string) => void;
@@ -0,0 +1,87 @@
1
+ import { default as mitt } from 'mitt';
2
+ import { CanvasLayer } from '../pen';
3
+ import { defaultOptions } from '../options';
4
+ import { defaultTheme } from '../theme';
5
+ import { globalStore } from './global';
6
+ export var EditType;
7
+ (function (EditType) {
8
+ EditType[EditType["Add"] = 0] = "Add";
9
+ EditType[EditType["Update"] = 1] = "Update";
10
+ EditType[EditType["Delete"] = 2] = "Delete";
11
+ EditType[EditType["Replace"] = 3] = "Replace";
12
+ })(EditType || (EditType = {}));
13
+ export const createStore = () => {
14
+ return {
15
+ data: {
16
+ x: 0,
17
+ y: 0,
18
+ scale: 1,
19
+ pens: [],
20
+ origin: { x: 0, y: 0 },
21
+ center: { x: 0, y: 0 },
22
+ paths: {},
23
+ theme: 'light'
24
+ },
25
+ histories: [],
26
+ pens: {},
27
+ path2dMap: new WeakMap(),
28
+ animateMap: new WeakMap(),
29
+ active: [],
30
+ animates: new Set(),
31
+ options: { ...defaultOptions },
32
+ theme: { ...defaultTheme },
33
+ emitter: mitt(),
34
+ bindDatas: {},
35
+ bind: {},
36
+ pensNetwork: {},
37
+ cacheDatas: [],
38
+ messageEvents: {},
39
+ templatePens: {},
40
+ globalTriggers: {},
41
+ };
42
+ };
43
+ // Return a data store, if not exists will create a store.
44
+ export const useStore = (id = 'default') => {
45
+ if (!globalStore[id]) {
46
+ globalStore[id] = createStore();
47
+ globalStore[id].id = id;
48
+ }
49
+ return globalStore[id];
50
+ };
51
+ export const clearStore = (store, template) => {
52
+ const isSame = store.data.template === template;
53
+ if (isSame) {
54
+ //模版一样
55
+ for (const pen of store.data.pens) {
56
+ // if (pen.template) {
57
+ if (pen.canvasLayer === CanvasLayer.CanvasTemplate) {
58
+ store.templatePens[pen.id] = pen;
59
+ }
60
+ }
61
+ }
62
+ store.lastScale = store.data.scale;
63
+ store.data = {
64
+ x: 0,
65
+ y: 0,
66
+ scale: 1,
67
+ pens: [],
68
+ origin: { x: 0, y: 0 },
69
+ center: { x: 0, y: 0 },
70
+ paths: {},
71
+ template: isSame ? template : null,
72
+ };
73
+ store.sameTemplate = isSame;
74
+ store.pens = {};
75
+ store.histories = [];
76
+ store.historyIndex = null;
77
+ store.path2dMap = new WeakMap();
78
+ store.animateMap = new WeakMap();
79
+ store.bindDatas = {};
80
+ store.bind = {};
81
+ store.pensNetwork = {};
82
+ store.active = [];
83
+ store.hover = undefined;
84
+ store.lastHover = undefined;
85
+ store.animates.clear();
86
+ };
87
+ //# sourceMappingURL=store.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"store.js","sourceRoot":"","sources":["../../../../packages/core/src/store/store.ts"],"names":[],"mappings":"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"}
package/src/theme.d.ts ADDED
@@ -0,0 +1,13 @@
1
+ export interface Theme {
2
+ [key: string]: {
3
+ color?: string;
4
+ background?: string;
5
+ parentBackground?: string;
6
+ ruleColor?: string;
7
+ ruleOptions?: {
8
+ background?: string;
9
+ textColor?: string;
10
+ };
11
+ };
12
+ }
13
+ export declare const defaultTheme: Theme;
package/src/theme.js ADDED
@@ -0,0 +1,23 @@
1
+ export const defaultTheme = {
2
+ dark: {
3
+ color: '#bdc7db',
4
+ background: '#1e2430',
5
+ parentBackground: '#080b0f',
6
+ ruleColor: '#222E47',
7
+ ruleOptions: {
8
+ background: '#121924',
9
+ textColor: '#6E7B91'
10
+ },
11
+ },
12
+ light: {
13
+ color: '#222222',
14
+ background: '#FFFFFF',
15
+ parentBackground: '#F0F1F2',
16
+ ruleColor: '#C8D0E1',
17
+ ruleOptions: {
18
+ background: '#F7F8FA',
19
+ textColor: '#C8D0E1'
20
+ },
21
+ }
22
+ };
23
+ //# sourceMappingURL=theme.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"theme.js","sourceRoot":"","sources":["../../../packages/core/src/theme.ts"],"names":[],"mappings":"AAaA,MAAM,CAAC,MAAM,YAAY,GAAU;IACjC,IAAI,EAAC;QACH,KAAK,EAAC,SAAS;QACf,UAAU,EAAC,SAAS;QACpB,gBAAgB,EAAC,SAAS;QAC1B,SAAS,EAAC,SAAS;QACnB,WAAW,EAAC;YACV,UAAU,EAAC,SAAS;YACpB,SAAS,EAAC,SAAS;SACpB;KACF;IACD,KAAK,EAAC;QACJ,KAAK,EAAC,SAAS;QACf,UAAU,EAAC,SAAS;QACpB,gBAAgB,EAAC,SAAS;QAC1B,SAAS,EAAC,SAAS;QACnB,WAAW,EAAC;YACV,UAAU,EAAC,SAAS;YACpB,SAAS,EAAC,SAAS;SACpB;KACF;CACF,CAAA"}
@@ -1 +1 @@
1
- export * from './title';
1
+ export * from './title';