@pie-element/hotspot 11.1.1 → 11.1.2-next.1

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 (234) hide show
  1. package/configure.js +2 -0
  2. package/controller.js +1 -0
  3. package/dist/author/DeleteWidget.d.ts +38 -0
  4. package/dist/author/DeleteWidget.js +46 -0
  5. package/dist/author/button.d.ts +31 -0
  6. package/dist/author/button.js +27 -0
  7. package/dist/author/buttons/circle.d.ts +18 -0
  8. package/dist/author/buttons/circle.js +25 -0
  9. package/dist/author/buttons/polygon.d.ts +18 -0
  10. package/dist/author/buttons/polygon.js +36 -0
  11. package/dist/author/buttons/rectangle.d.ts +18 -0
  12. package/dist/author/buttons/rectangle.js +36 -0
  13. package/dist/author/defaults.d.ts +157 -0
  14. package/dist/author/defaults.js +119 -0
  15. package/dist/author/hotspot-circle.d.ts +21 -0
  16. package/dist/author/hotspot-circle.js +124 -0
  17. package/dist/author/hotspot-container.d.ts +29 -0
  18. package/dist/author/hotspot-container.js +210 -0
  19. package/dist/author/hotspot-drawable.d.ts +31 -0
  20. package/dist/author/hotspot-drawable.js +312 -0
  21. package/dist/author/hotspot-palette.d.ts +14 -0
  22. package/dist/author/hotspot-palette.js +72 -0
  23. package/dist/author/hotspot-polygon.d.ts +38 -0
  24. package/dist/author/hotspot-polygon.js +200 -0
  25. package/dist/author/hotspot-rectangle.d.ts +20 -0
  26. package/dist/author/hotspot-rectangle.js +119 -0
  27. package/dist/author/icons.d.ts +9 -0
  28. package/dist/author/icons.js +4 -0
  29. package/dist/author/image-konva.d.ts +19 -0
  30. package/dist/author/image-konva.js +49 -0
  31. package/dist/author/index.d.ts +52 -0
  32. package/dist/author/index.js +143 -0
  33. package/dist/author/root.d.ts +15 -0
  34. package/dist/author/root.js +215 -0
  35. package/dist/author/shapes/circle.d.ts +18 -0
  36. package/dist/author/shapes/circle.js +47 -0
  37. package/dist/author/shapes/index.d.ts +12 -0
  38. package/dist/author/shapes/polygon.d.ts +19 -0
  39. package/dist/author/shapes/polygon.js +51 -0
  40. package/dist/author/shapes/rectagle.d.ts +18 -0
  41. package/dist/author/shapes/rectagle.js +57 -0
  42. package/dist/author/shapes/utils.d.ts +19 -0
  43. package/dist/author/shapes/utils.js +16 -0
  44. package/dist/author/upload-control.d.ts +29 -0
  45. package/dist/author/upload-control.js +28 -0
  46. package/dist/author/utils.d.ts +24 -0
  47. package/dist/author/utils.js +83 -0
  48. package/dist/browser/ReactKonva-Z9-1H-UZ.js +19329 -0
  49. package/dist/browser/ReactKonva-Z9-1H-UZ.js.map +1 -0
  50. package/dist/browser/author/index.js +41646 -0
  51. package/dist/browser/author/index.js.map +1 -0
  52. package/dist/browser/browser-CfnAFove.js +219 -0
  53. package/dist/browser/browser-CfnAFove.js.map +1 -0
  54. package/dist/browser/controller/index.js +198 -0
  55. package/dist/browser/controller/index.js.map +1 -0
  56. package/dist/browser/delivery/index.js +2460 -0
  57. package/dist/browser/delivery/index.js.map +1 -0
  58. package/dist/browser/dist-C78LDz6R.js +96 -0
  59. package/dist/browser/dist-C78LDz6R.js.map +1 -0
  60. package/dist/browser/hotspot.css +2 -0
  61. package/dist/controller/defaults.d.ts +35 -0
  62. package/dist/controller/defaults.js +29 -0
  63. package/dist/controller/index.d.ts +22 -0
  64. package/dist/controller/index.js +154 -0
  65. package/dist/controller/utils.d.ts +10 -0
  66. package/dist/controller/utils.js +12 -0
  67. package/dist/delivery/hotspot/circle.d.ts +19 -0
  68. package/dist/delivery/hotspot/circle.js +100 -0
  69. package/dist/delivery/hotspot/container.d.ts +16 -0
  70. package/dist/delivery/hotspot/container.js +150 -0
  71. package/dist/delivery/hotspot/icons.d.ts +10 -0
  72. package/dist/delivery/hotspot/icons.js +4 -0
  73. package/dist/delivery/hotspot/image-konva-tooltip.d.ts +19 -0
  74. package/dist/delivery/hotspot/image-konva-tooltip.js +66 -0
  75. package/dist/delivery/hotspot/index.d.ts +17 -0
  76. package/dist/delivery/hotspot/index.js +114 -0
  77. package/dist/delivery/hotspot/polygon.d.ts +21 -0
  78. package/dist/delivery/hotspot/polygon.js +108 -0
  79. package/dist/delivery/hotspot/rectangle.d.ts +19 -0
  80. package/dist/delivery/hotspot/rectangle.js +104 -0
  81. package/dist/delivery/index.d.ts +20 -0
  82. package/dist/delivery/index.js +107 -0
  83. package/dist/delivery/session-updater.d.ts +10 -0
  84. package/dist/delivery/session-updater.js +14 -0
  85. package/dist/index.d.ts +1 -0
  86. package/dist/index.iife.d.ts +8 -0
  87. package/dist/index.iife.js +169 -0
  88. package/dist/index.js +2 -0
  89. package/dist/runtime-support.d.ts +12 -0
  90. package/dist/runtime-support.js +12 -0
  91. package/package.json +84 -18
  92. package/CHANGELOG.json +0 -997
  93. package/CHANGELOG.md +0 -2214
  94. package/LICENSE.md +0 -5
  95. package/README.md +0 -1
  96. package/configure/CHANGELOG.json +0 -682
  97. package/configure/CHANGELOG.md +0 -1951
  98. package/configure/lib/DeleteWidget.js +0 -64
  99. package/configure/lib/DeleteWidget.js.map +0 -1
  100. package/configure/lib/button.js +0 -42
  101. package/configure/lib/button.js.map +0 -1
  102. package/configure/lib/buttons/circle.js +0 -33
  103. package/configure/lib/buttons/circle.js.map +0 -1
  104. package/configure/lib/buttons/polygon.js +0 -39
  105. package/configure/lib/buttons/polygon.js.map +0 -1
  106. package/configure/lib/buttons/rectangle.js +0 -39
  107. package/configure/lib/buttons/rectangle.js.map +0 -1
  108. package/configure/lib/defaults.js +0 -155
  109. package/configure/lib/defaults.js.map +0 -1
  110. package/configure/lib/hotspot-circle.js +0 -192
  111. package/configure/lib/hotspot-circle.js.map +0 -1
  112. package/configure/lib/hotspot-container.js +0 -320
  113. package/configure/lib/hotspot-container.js.map +0 -1
  114. package/configure/lib/hotspot-drawable.js +0 -519
  115. package/configure/lib/hotspot-drawable.js.map +0 -1
  116. package/configure/lib/hotspot-palette.js +0 -107
  117. package/configure/lib/hotspot-palette.js.map +0 -1
  118. package/configure/lib/hotspot-polygon.js +0 -293
  119. package/configure/lib/hotspot-polygon.js.map +0 -1
  120. package/configure/lib/hotspot-rectangle.js +0 -190
  121. package/configure/lib/hotspot-rectangle.js.map +0 -1
  122. package/configure/lib/icons.js +0 -7
  123. package/configure/lib/icons.js.map +0 -1
  124. package/configure/lib/image-konva.js +0 -66
  125. package/configure/lib/image-konva.js.map +0 -1
  126. package/configure/lib/index.js +0 -194
  127. package/configure/lib/index.js.map +0 -1
  128. package/configure/lib/root.js +0 -330
  129. package/configure/lib/root.js.map +0 -1
  130. package/configure/lib/shapes/circle.js +0 -84
  131. package/configure/lib/shapes/circle.js.map +0 -1
  132. package/configure/lib/shapes/index.js +0 -50
  133. package/configure/lib/shapes/index.js.map +0 -1
  134. package/configure/lib/shapes/polygon.js +0 -82
  135. package/configure/lib/shapes/polygon.js.map +0 -1
  136. package/configure/lib/shapes/rectagle.js +0 -84
  137. package/configure/lib/shapes/rectagle.js.map +0 -1
  138. package/configure/lib/shapes/utils.js +0 -21
  139. package/configure/lib/shapes/utils.js.map +0 -1
  140. package/configure/lib/upload-control.js +0 -41
  141. package/configure/lib/upload-control.js.map +0 -1
  142. package/configure/lib/utils.js +0 -185
  143. package/configure/lib/utils.js.map +0 -1
  144. package/configure/package.json +0 -26
  145. package/configure/src/DeleteWidget.jsx +0 -51
  146. package/configure/src/__tests__/DeleteWidget.test.jsx +0 -366
  147. package/configure/src/__tests__/button.test.jsx +0 -198
  148. package/configure/src/__tests__/hotspot-circle.test.jsx +0 -259
  149. package/configure/src/__tests__/hotspot-container.test.js +0 -366
  150. package/configure/src/__tests__/hotspot-drawable.test.js +0 -271
  151. package/configure/src/__tests__/hotspot-palette.test.jsx +0 -71
  152. package/configure/src/__tests__/image-konva.test.jsx +0 -226
  153. package/configure/src/__tests__/index.test.js +0 -329
  154. package/configure/src/__tests__/root.test.js +0 -400
  155. package/configure/src/__tests__/utils.test.js +0 -241
  156. package/configure/src/button.jsx +0 -35
  157. package/configure/src/buttons/circle.jsx +0 -18
  158. package/configure/src/buttons/polygon.jsx +0 -29
  159. package/configure/src/buttons/rectangle.jsx +0 -29
  160. package/configure/src/defaults.js +0 -109
  161. package/configure/src/hotspot-circle.jsx +0 -183
  162. package/configure/src/hotspot-container.jsx +0 -330
  163. package/configure/src/hotspot-drawable.jsx +0 -527
  164. package/configure/src/hotspot-palette.jsx +0 -90
  165. package/configure/src/hotspot-polygon.jsx +0 -294
  166. package/configure/src/hotspot-rectangle.jsx +0 -169
  167. package/configure/src/icons.js +0 -5
  168. package/configure/src/image-konva.jsx +0 -63
  169. package/configure/src/index.js +0 -208
  170. package/configure/src/root.jsx +0 -346
  171. package/configure/src/shapes/circle.js +0 -81
  172. package/configure/src/shapes/index.js +0 -4
  173. package/configure/src/shapes/polygon.js +0 -81
  174. package/configure/src/shapes/rectagle.js +0 -82
  175. package/configure/src/shapes/utils.js +0 -16
  176. package/configure/src/upload-control.jsx +0 -33
  177. package/configure/src/utils.js +0 -210
  178. package/controller/CHANGELOG.json +0 -362
  179. package/controller/CHANGELOG.md +0 -1304
  180. package/controller/lib/defaults.js +0 -33
  181. package/controller/lib/defaults.js.map +0 -1
  182. package/controller/lib/index.js +0 -341
  183. package/controller/lib/index.js.map +0 -1
  184. package/controller/lib/utils.js +0 -32
  185. package/controller/lib/utils.js.map +0 -1
  186. package/controller/package.json +0 -18
  187. package/controller/src/__tests__/index.test.js +0 -419
  188. package/controller/src/__tests__/utils.test.js +0 -5
  189. package/controller/src/defaults.js +0 -19
  190. package/controller/src/index.js +0 -328
  191. package/controller/src/utils.js +0 -29
  192. package/docs/config-schema.json +0 -2023
  193. package/docs/config-schema.json.md +0 -1495
  194. package/docs/demo/config.js +0 -8
  195. package/docs/demo/generate.js +0 -118
  196. package/docs/demo/index.html +0 -1
  197. package/docs/demo/session.js +0 -11
  198. package/docs/pie-schema.json +0 -1204
  199. package/docs/pie-schema.json.md +0 -851
  200. package/lib/hotspot/circle.js +0 -156
  201. package/lib/hotspot/circle.js.map +0 -1
  202. package/lib/hotspot/container.js +0 -206
  203. package/lib/hotspot/container.js.map +0 -1
  204. package/lib/hotspot/icons.js +0 -8
  205. package/lib/hotspot/icons.js.map +0 -1
  206. package/lib/hotspot/image-konva-tooltip.js +0 -86
  207. package/lib/hotspot/image-konva-tooltip.js.map +0 -1
  208. package/lib/hotspot/index.js +0 -163
  209. package/lib/hotspot/index.js.map +0 -1
  210. package/lib/hotspot/polygon.js +0 -203
  211. package/lib/hotspot/polygon.js.map +0 -1
  212. package/lib/hotspot/rectangle.js +0 -175
  213. package/lib/hotspot/rectangle.js.map +0 -1
  214. package/lib/index.js +0 -213
  215. package/lib/index.js.map +0 -1
  216. package/lib/session-updater.js +0 -42
  217. package/lib/session-updater.js.map +0 -1
  218. package/src/__tests__/container.test.jsx +0 -58
  219. package/src/__tests__/index.test.js +0 -123
  220. package/src/__tests__/session-updater.test.jsx +0 -69
  221. package/src/hotspot/__tests__/circle.test.jsx +0 -464
  222. package/src/hotspot/__tests__/container.test.jsx +0 -546
  223. package/src/hotspot/__tests__/image-konva-tooltip.test.jsx +0 -510
  224. package/src/hotspot/__tests__/polygon.test.jsx +0 -502
  225. package/src/hotspot/__tests__/rectangle.test.jsx +0 -418
  226. package/src/hotspot/circle.jsx +0 -152
  227. package/src/hotspot/container.jsx +0 -217
  228. package/src/hotspot/icons.js +0 -7
  229. package/src/hotspot/image-konva-tooltip.jsx +0 -76
  230. package/src/hotspot/index.jsx +0 -165
  231. package/src/hotspot/polygon.jsx +0 -195
  232. package/src/hotspot/rectangle.jsx +0 -171
  233. package/src/index.js +0 -226
  234. package/src/session-updater.js +0 -29
@@ -1,527 +0,0 @@
1
- import React from 'react';
2
- import PropTypes from 'prop-types';
3
- import { Layer, Stage } from 'react-konva';
4
- import { cloneDeep } from 'lodash-es';
5
- import { styled } from '@mui/material/styles';
6
-
7
- import Rectangle from './hotspot-rectangle';
8
- import Polygon from './hotspot-polygon';
9
- import Circle from './hotspot-circle';
10
- import { getUpdatedShapes, updateImageDimensions } from './utils';
11
- import { RectangleShape, CircleShape, PolygonShape, SUPPORTED_SHAPES, SHAPE_GROUPS } from './shapes';
12
-
13
- const BaseContainer = styled('div')({
14
- position: 'relative',
15
- });
16
-
17
- const ImageContainer = styled('div')({
18
- position: 'relative',
19
- width: 'fit-content',
20
- });
21
-
22
- const Image = styled('img')({
23
- alignItems: 'center',
24
- display: 'flex',
25
- justifyContent: 'center',
26
- });
27
-
28
- const ResizeHandle = styled('div')({
29
- borderBottom: '1px solid #727272',
30
- borderRight: '1px solid #727272',
31
- bottom: '-10px',
32
- cursor: 'se-resize',
33
- height: '10px',
34
- position: 'absolute',
35
- right: '-10px',
36
- width: '10px',
37
- });
38
-
39
- const StyledStage = styled(Stage)({
40
- left: 0,
41
- top: 0,
42
- position: 'absolute',
43
- });
44
-
45
- const IMAGE_MAX_WIDTH = 800;
46
-
47
- export class Drawable extends React.Component {
48
- static getDerivedStateFromProps(nextProps, prevState) {
49
- // Update the state only if the props have changed
50
- if (nextProps.shapes !== prevState.shapes) {
51
- return { shapes: nextProps.shapes };
52
- }
53
-
54
- return null;
55
- }
56
-
57
- constructor(props) {
58
- super(props);
59
-
60
- this.state = {
61
- isDrawing: false,
62
- stateShapes: false,
63
- resizing: false,
64
- temporaryPolygon: null,
65
- shapes: [],
66
- dimensions: {
67
- height: 0,
68
- width: 0,
69
- },
70
- };
71
- }
72
-
73
- handleOnMouseDown = (e) => {
74
- const { shapeType, onUpdateShapes, shapes } = this.props;
75
- let newState, newShapeId;
76
-
77
- // Ensure that the click originated from the expected element
78
- if (e.target !== e.currentTarget) {
79
- return;
80
- }
81
-
82
- if (!Object.values(SUPPORTED_SHAPES).includes(shapeType)) {
83
- return;
84
- }
85
-
86
- switch (shapeType) {
87
- case SUPPORTED_SHAPES.RECTANGLE:
88
- newState = RectangleShape.create(shapes, e);
89
- break;
90
- case SUPPORTED_SHAPES.CIRCLE:
91
- newState = CircleShape.create(shapes, e);
92
- break;
93
- case SUPPORTED_SHAPES.POLYGON:
94
- newShapeId = this.state.isDrawingShapeId;
95
-
96
- if (newShapeId) {
97
- // If a polygon is in progress, add a new point
98
- const shapes = this.addPolygonPoint(e);
99
-
100
- newState = {
101
- isDrawing: true,
102
- isDrawingShapeId: newShapeId,
103
- shapes: shapes,
104
- };
105
- } else {
106
- // Else start a new one
107
- newState = PolygonShape.create(shapes, e);
108
- }
109
- break;
110
- default:
111
- return;
112
- }
113
-
114
- this.setState({
115
- ...newState,
116
- });
117
-
118
- onUpdateShapes(newState.shapes);
119
- };
120
-
121
- addPolygonPoint(e) {
122
- const { shapes } = PolygonShape.addPoint(this.state, e, (newShapes) => {
123
- this.setState({
124
- isDrawing: false,
125
- shapes: newShapes,
126
- isDrawingShapeId: undefined,
127
- });
128
-
129
- this.props.onUpdateShapes(newShapes);
130
- });
131
-
132
- return shapes;
133
- }
134
-
135
- handleOnMouseUp = () => {
136
- const { shapeType, onUpdateShapes } = this.props;
137
- let newState;
138
-
139
- if (shapeType === SUPPORTED_SHAPES.POLYGON) {
140
- return;
141
- }
142
-
143
- switch (shapeType) {
144
- case SUPPORTED_SHAPES.RECTANGLE:
145
- newState = RectangleShape.finalizeCreation(this.state, this.props);
146
- break;
147
- case SUPPORTED_SHAPES.CIRCLE:
148
- newState = CircleShape.finalizeCreation(this.state, this.props);
149
- break;
150
- default:
151
- return;
152
- }
153
-
154
- this.setState({
155
- ...newState,
156
- isDrawing: false,
157
- });
158
-
159
- onUpdateShapes(newState.shapes);
160
- };
161
-
162
- handleMouseMove = (e) => {
163
- const { shapeType, onUpdateShapes } = this.props;
164
- let newState;
165
-
166
- if (!this.state.isDrawing || !Object.values(SUPPORTED_SHAPES).includes(shapeType)) {
167
- return;
168
- }
169
-
170
- switch (shapeType) {
171
- case SUPPORTED_SHAPES.RECTANGLE:
172
- newState = RectangleShape.handleMouseMove(this.state, e);
173
- break;
174
- case SUPPORTED_SHAPES.CIRCLE:
175
- newState = CircleShape.handleMouseMove(this.state, e);
176
- break;
177
- case SUPPORTED_SHAPES.POLYGON:
178
- newState = PolygonShape.handleMouseMove(this.state, e);
179
- break;
180
- default:
181
- return;
182
- }
183
-
184
- this.setState(newState);
185
- onUpdateShapes(newState.shapes);
186
- };
187
-
188
- handleOnMouseOutOrLeave = (e) => {
189
- if (this.state.isDrawing) {
190
- this.handleOnMouseUp(e);
191
- }
192
- };
193
-
194
- handleOnDragEnd = (id, updatedProps) => {
195
- const { shapes, onUpdateShapes, dimensions } = this.props;
196
- const { width: canvasWidth, height: canvasHeight } = dimensions;
197
-
198
- // when a shape is moved completely outside the canvas
199
- // remove that shape
200
- const newShapes = shapes
201
- .map((shape) => {
202
- if (shape.id !== id) {
203
- return shape;
204
- }
205
-
206
- let newX = updatedProps.x;
207
- let newY = updatedProps.y;
208
-
209
- if (shape.group === 'rectangles') {
210
- if (newX + shape.width < 0 || newX > canvasWidth || newY + shape.height < 0 || newY > canvasHeight) {
211
- return null;
212
- }
213
-
214
- return { ...shape, ...updatedProps };
215
- }
216
-
217
- if (shape.group === 'circles') {
218
- const radius = shape.radius;
219
- if (newX + radius < 0 || newX - radius > canvasWidth || newY + radius < 0 || newY - radius > canvasHeight) {
220
- return null;
221
- }
222
-
223
- return { ...shape, ...updatedProps };
224
- }
225
-
226
- if (shape.group === 'polygons') {
227
- const points = shape.points;
228
- const xValues = points.map((point) => point.x);
229
- const yValues = points.map((point) => point.y);
230
-
231
- let minX = Math.min(...xValues);
232
- let minY = Math.min(...yValues);
233
- let maxX = Math.max(...xValues);
234
- let maxY = Math.max(...yValues);
235
-
236
- // Calculate deltas based on the first point as a reference
237
- const deltaX = updatedProps['points'][0].x - points[0].x;
238
- const deltaY = updatedProps['points'][0].y - points[0].y;
239
-
240
- minX = minX + deltaX;
241
- maxX = maxX + deltaX;
242
- minY = minY + deltaY;
243
- maxY = maxY + deltaY;
244
-
245
- if (maxX < 0 || minX > canvasWidth || maxY < 0 || minY > canvasHeight) {
246
- return null;
247
- }
248
-
249
- return { ...shape, ...updatedProps };
250
- }
251
-
252
- return shape;
253
- })
254
- .filter((shape) => shape !== null);
255
-
256
- onUpdateShapes(cloneDeep(newShapes));
257
- };
258
-
259
- closeInProgressPolygons = (id) => {
260
- const { shapes, onUpdateShapes } = this.props;
261
-
262
- const inProgressPolygon = (shapes || []).find((shape) => shape.id === 'newPolygon');
263
- if (id === 'newPolygon' || (inProgressPolygon && this.state.isDrawing)) {
264
- PolygonShape.finalizeCreation(this.state, (newShapes) => {
265
- this.setState({
266
- isDrawing: false,
267
- shapes: newShapes,
268
- isDrawingShapeId: undefined,
269
- });
270
-
271
- onUpdateShapes(cloneDeep(newShapes));
272
- });
273
- }
274
- }
275
-
276
- handleOnSetAsCorrect = (shape) => {
277
- const { id } = shape;
278
- const { multipleCorrect, shapes, onUpdateShapes } = this.props;
279
-
280
- let newShapes;
281
-
282
- if (multipleCorrect) {
283
- newShapes = shapes.map((shape) => {
284
- if (shape.id === id) {
285
- shape.correct = !shape.correct;
286
- }
287
- return shape;
288
- });
289
- } else {
290
- newShapes = shapes.map((shape) => {
291
- shape.correct = shape.id === id;
292
- return shape;
293
- });
294
- }
295
-
296
- onUpdateShapes(cloneDeep(newShapes));
297
-
298
- this.closeInProgressPolygons(id);
299
- };
300
- /// end of handling HotSpots section
301
-
302
- /// start of handling Image section
303
- handleOnImageLoad = ({ target }) => {
304
- const { onUpdateImageDimension } = this.props;
305
- const resizeHandle = this.resize;
306
- const elementStyle = getComputedStyle(target);
307
- const newHeight = parseFloat(elementStyle.height);
308
- const newWidth = parseFloat(elementStyle.width);
309
- const aspectWidth = newWidth / IMAGE_MAX_WIDTH;
310
-
311
- const dimensions =
312
- newWidth > IMAGE_MAX_WIDTH
313
- ? {
314
- height: newHeight / aspectWidth,
315
- width: IMAGE_MAX_WIDTH,
316
- }
317
- : {
318
- height: newHeight,
319
- width: newWidth,
320
- };
321
-
322
- this.setState({ dimensions }, () => onUpdateImageDimension(dimensions));
323
-
324
- resizeHandle.addEventListener('mousedown', this.initialiseResize, false);
325
- };
326
-
327
- initialiseResize = () => {
328
- window.addEventListener('mousemove', this.startResizing, false);
329
- window.addEventListener('mouseup', this.stopResizing, false);
330
- };
331
-
332
- checkIfResizeValid(x, y) {
333
- const { shapes } = this.state;
334
- let drawable = true;
335
-
336
- // Do not allow resizing over the hotspots
337
- shapes &&
338
- shapes.forEach((shape) => {
339
- const right = shape.x + shape.width + 5;
340
- const bottom = shape.y + shape.height + 5;
341
- if (x <= right || y <= bottom) {
342
- drawable = false;
343
- }
344
- });
345
- return drawable;
346
- }
347
-
348
- startResizing = (e) => {
349
- const bounds = e.target.getBoundingClientRect();
350
- const box = this.image;
351
- const { disableDrag, preserveAspectRatioEnabled, dimensions, shapes } = this.props;
352
-
353
- const { width, height } = updateImageDimensions(
354
- dimensions,
355
- {
356
- width: e.clientX - bounds.left,
357
- height: e.clientY - bounds.top,
358
- },
359
- preserveAspectRatioEnabled,
360
- );
361
-
362
- const resizeValid = this.checkIfResizeValid(width, height);
363
- const hasMinimumWidth = width > 150 && height > 150;
364
-
365
- if (resizeValid && hasMinimumWidth && box) {
366
- box.style.width = `${width}px`;
367
- box.style.height = `${height}px`;
368
-
369
- this.setState({
370
- resizing: true,
371
- dimensions: { height: height, width: width },
372
- stateShapes: getUpdatedShapes(dimensions, { width, height }, shapes),
373
- });
374
- }
375
-
376
- disableDrag();
377
- };
378
-
379
- stopResizing = () => {
380
- const { enableDrag, onUpdateImageDimension, onUpdateShapes } = this.props;
381
- const { dimensions, stateShapes } = this.state;
382
-
383
- enableDrag();
384
-
385
- if (stateShapes) {
386
- onUpdateShapes(cloneDeep(stateShapes));
387
- }
388
-
389
- onUpdateImageDimension(dimensions);
390
-
391
- window.removeEventListener('mousemove', this.startResizing, false);
392
- window.removeEventListener('mouseup', this.stopResizing, false);
393
-
394
- this.setState({ resizing: false, stateShapes: false });
395
- };
396
-
397
- deleteShape = (id) => {
398
- this.setState({
399
- isDrawing: false,
400
- isDrawingShapeId: undefined,
401
- });
402
- this.props.onDeleteShape(id);
403
- };
404
-
405
- /// end of handling Image section
406
-
407
- render() {
408
- const {
409
- imageUrl,
410
- dimensions: { height, width },
411
- hotspotColor,
412
- outlineColor,
413
- shapes,
414
- strokeWidth,
415
- hoverOutlineColor,
416
- selectedHotspotColor,
417
- } = this.props;
418
-
419
- const {
420
- stateShapes,
421
- isDrawing,
422
- dimensions: { height: heightFromState, width: widthFromState },
423
- } = this.state;
424
- const shapesToUse = stateShapes || shapes;
425
-
426
- return (
427
- <BaseContainer>
428
- {imageUrl && (
429
- <ImageContainer>
430
- <Image
431
- onLoad={this.handleOnImageLoad}
432
- ref={(ref) => {
433
- this.image = ref;
434
- }}
435
- src={imageUrl}
436
- {...(height && width ? { style: { height, width } } : {})}
437
- />
438
- <ResizeHandle
439
- ref={(ref) => {
440
- this.resize = ref;
441
- }}
442
- />
443
- </ImageContainer>
444
- )}
445
-
446
- <StyledStage
447
- height={heightFromState || height}
448
- width={widthFromState || width}
449
- onMouseDown={this.handleOnMouseDown}
450
- onMouseUp={this.handleOnMouseUp}
451
- onMouseMove={this.handleMouseMove}
452
- onContentMouseOut={this.handleOnMouseOutOrLeave}
453
- onContentMouseLeave={this.handleOnMouseOutOrLeave}
454
- >
455
- <Layer>
456
- {shapesToUse.map((shape, i) => {
457
- let Tag;
458
- switch (shape.group) {
459
- case SHAPE_GROUPS.RECTANGLES:
460
- Tag = Rectangle;
461
- break;
462
- case SHAPE_GROUPS.CIRCLES:
463
- Tag = Circle;
464
- break;
465
- case SHAPE_GROUPS.POLYGONS:
466
- Tag = Polygon;
467
- break;
468
- default:
469
- return null;
470
- }
471
-
472
- return (
473
- <Tag
474
- {...(shape.group === SHAPE_GROUPS.CIRCLES ? { radius: shape.radius } : {})}
475
- {...(shape.group === SHAPE_GROUPS.RECTANGLES ? { height: shape.height, width: shape.width } : {})}
476
- {...(shape.group === SHAPE_GROUPS.POLYGONS
477
- ? { points: shape.points, addPolygonPoint: (e) => this.addPolygonPoint(e) }
478
- : {})}
479
- correct={shape.correct}
480
- isDrawing={isDrawing}
481
- hotspotColor={hotspotColor}
482
- hoverOutlineColor={hoverOutlineColor}
483
- selectedHotspotColor={selectedHotspotColor}
484
- id={shape.id}
485
- key={i}
486
- onClick={() => this.handleOnSetAsCorrect(shape)}
487
- onDragEnd={this.handleOnDragEnd}
488
- onDeleteShape={this.deleteShape}
489
- outlineColor={outlineColor}
490
- width={shape.width}
491
- x={shape.x}
492
- y={shape.y}
493
- strokeWidth={strokeWidth}
494
- imageHeight={heightFromState || height}
495
- imageWidth={widthFromState || width}
496
- {...(shape.group === 'polygons' ? { addPolygonPoint: (e) => this.addPolygonPoint(e) } : {})}
497
- />
498
- );
499
- })}
500
- </Layer>
501
- </StyledStage>
502
- </BaseContainer>
503
- );
504
- }
505
- }
506
-
507
- Drawable.propTypes = {
508
- disableDrag: PropTypes.func.isRequired,
509
- dimensions: PropTypes.object.isRequired,
510
- enableDrag: PropTypes.func.isRequired,
511
- shapeType: PropTypes.oneOf(Object.values(SUPPORTED_SHAPES)),
512
- imageUrl: PropTypes.string.isRequired,
513
- handleFinishDrawing: PropTypes.func.isRequired,
514
- hotspotColor: PropTypes.string.isRequired,
515
- selectedHotspotColor: PropTypes.string,
516
- hoverOutlineColor: PropTypes.string,
517
- multipleCorrect: PropTypes.bool.isRequired,
518
- onUpdateImageDimension: PropTypes.func.isRequired,
519
- onUpdateShapes: PropTypes.func.isRequired,
520
- onDeleteShape: PropTypes.func.isRequired,
521
- outlineColor: PropTypes.string.isRequired,
522
- shapes: PropTypes.array.isRequired,
523
- strokeWidth: PropTypes.number,
524
- preserveAspectRatioEnabled: PropTypes.bool,
525
- };
526
-
527
- export default Drawable;
@@ -1,90 +0,0 @@
1
- import React from 'react';
2
- import PropTypes from 'prop-types';
3
- import { InputContainer } from '@pie-lib/config-ui';
4
- import Select from '@mui/material/Select';
5
- import MenuItem from '@mui/material/MenuItem';
6
- import { styled } from '@mui/material/styles';
7
-
8
- const BaseContainer = styled('div')(({ theme }) => ({
9
- marginTop: theme.spacing(2),
10
- display: 'flex',
11
- }));
12
-
13
- const StyledInputContainer = styled(InputContainer)({
14
- flex: 1,
15
- width: '90%',
16
- });
17
-
18
- const StyledMenuItem = styled(MenuItem)(({ theme }) => ({
19
- borderRadius: '2px',
20
- height: '22px',
21
- marginLeft: theme.spacing(2),
22
- marginRight: theme.spacing(2),
23
- marginTop: theme.spacing(2),
24
- }));
25
-
26
- class Palette extends React.Component {
27
- onChange = (name) => (event) => {
28
- const { value } = event.target;
29
- const { onHotspotColorChange, onOutlineColorChange } = this.props;
30
-
31
- if (name === 'hotspot') {
32
- onHotspotColorChange(value);
33
- } else {
34
- onOutlineColorChange(value);
35
- }
36
- };
37
-
38
- render() {
39
- const { hotspotColor, outlineColor, hotspotList, outlineList } = this.props;
40
-
41
- return (
42
- <BaseContainer>
43
- <StyledInputContainer label="Hot Spot">
44
- <Select
45
- onChange={this.onChange('hotspot')}
46
- value={hotspotColor}
47
- variant='standard'
48
- MenuProps={{ transitionDuration: { enter: 225, exit: 195 } }}
49
- >
50
- {hotspotList.map((hotspot) => (
51
- <StyledMenuItem key={hotspot} value={hotspot} style={{ backgroundColor: hotspot }}>
52
- {hotspot}
53
- </StyledMenuItem>
54
- ))}
55
- </Select>
56
- </StyledInputContainer>
57
-
58
- <StyledInputContainer label="Response Outline">
59
- <Select
60
- onChange={this.onChange('outline')}
61
- value={outlineColor}
62
- variant='standard'
63
- MenuProps={{ transitionDuration: { enter: 225, exit: 195 } }}
64
- >
65
- {outlineList.map((outline) => (
66
- <StyledMenuItem
67
- key={outline}
68
- value={outline}
69
- style={{ border: `2px solid ${outline}` }}
70
- >
71
- {outline}
72
- </StyledMenuItem>
73
- ))}
74
- </Select>
75
- </StyledInputContainer>
76
- </BaseContainer>
77
- );
78
- }
79
- }
80
-
81
- Palette.propTypes = {
82
- hotspotColor: PropTypes.string.isRequired,
83
- hotspotList: PropTypes.array.isRequired,
84
- onHotspotColorChange: PropTypes.func.isRequired,
85
- onOutlineColorChange: PropTypes.func.isRequired,
86
- outlineColor: PropTypes.string.isRequired,
87
- outlineList: PropTypes.array.isRequired,
88
- };
89
-
90
- export default Palette;