@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,271 +0,0 @@
1
- import { render } from '@testing-library/react';
2
- import React from 'react';
3
- import { Drawable } from '../hotspot-drawable';
4
-
5
- jest.mock('react-konva', () => {
6
- const React = require('react');
7
- return {
8
- Stage: ({ children, ...props }) => React.createElement('div', { 'data-testid': 'stage', ...props }, children),
9
- Layer: ({ children, ...props }) => React.createElement('div', { 'data-testid': 'layer', ...props }, children),
10
- Rect: (props) => React.createElement('div', { 'data-testid': 'rect', ...props }),
11
- Circle: (props) => React.createElement('div', { 'data-testid': 'circle', ...props }),
12
- Line: (props) => React.createElement('div', { 'data-testid': 'line', ...props }),
13
- Group: ({ children, ...props }) => React.createElement('div', { 'data-testid': 'group', ...props }, children),
14
- Image: (props) => React.createElement('div', { 'data-testid': 'image', ...props }),
15
- };
16
- });
17
-
18
- const model = () => ({
19
- imageUrl: 'https://cdn.fluence.net/image/0240eb1455ce4c4bb6180232347b6aef_W',
20
- shapes: [
21
- {
22
- id: '0',
23
- height: 140,
24
- width: 130,
25
- x: 1,
26
- y: 1,
27
- correct: true,
28
- group: 'rectangles',
29
- },
30
- {
31
- id: '1',
32
- height: 140,
33
- width: 130,
34
- x: 140,
35
- y: 1,
36
- group: 'rectangles',
37
- },
38
- {
39
- id: '2',
40
- height: 140,
41
- width: 130,
42
- x: 280,
43
- y: 1,
44
- group: 'rectangles',
45
- },
46
- {
47
- id: '3',
48
- points: [
49
- { x: 1, y: 148 },
50
- { x: 1, y: 288 },
51
- { y: 288, x: 129 },
52
- { y: 148, x: 129 },
53
- ],
54
- correct: true,
55
- group: 'polygons',
56
- },
57
- {
58
- id: '4',
59
- points: [
60
- { y: 151, x: 141 },
61
- { y: 289, x: 141 },
62
- { y: 289, x: 269 },
63
- { x: 269, y: 151 },
64
- ],
65
- correct: false,
66
- group: 'polygons',
67
- },
68
- {
69
- id: '5',
70
- points: [
71
- { x: 279, y: 150 },
72
- { x: 279, y: 289 },
73
- { x: 407, y: 289 },
74
- { x: 407, y: 150 },
75
- ],
76
- correct: false,
77
- group: 'polygons',
78
- },
79
- ],
80
- dimensions: {
81
- height: 291,
82
- width: 410,
83
- },
84
- hotspotColor: 'rgba(137, 183, 244, 0.65)',
85
- outlineColor: 'blue',
86
- multipleCorrect: true,
87
- });
88
-
89
- describe('HotspotDrawable', () => {
90
- let w,
91
- handleDisableDrag = jest.fn(),
92
- handleEnableDrag = jest.fn(),
93
- onUpdateImageDimension = jest.fn(),
94
- onUpdateShapes = jest.fn(),
95
- initialModel = model();
96
- beforeEach(() => {
97
- w = (extras) => {
98
- const props = {
99
- classes: {},
100
- dimensions: initialModel.dimensions,
101
- disableDrag: handleDisableDrag,
102
- enableDrag: handleEnableDrag,
103
- imageUrl: initialModel.imageUrl,
104
- hotspotColor: initialModel.hotspotColor,
105
- multipleCorrect: initialModel.multipleCorrect,
106
- onUpdateImageDimension: onUpdateImageDimension,
107
- onUpdateShapes: onUpdateShapes,
108
- outlineColor: initialModel.outlineColor,
109
- shapes: initialModel.shapes,
110
- strokeWidth: 5,
111
- shapeType: 'rectangle',
112
- handleFinishDrawing: jest.fn(),
113
- onDeleteShape: jest.fn(),
114
- ...extras,
115
- };
116
-
117
- return render(<Drawable {...props} />);
118
- };
119
- });
120
-
121
- describe('logic', () => {
122
- const createInstance = () => {
123
- const props = {
124
- classes: {},
125
- dimensions: initialModel.dimensions,
126
- disableDrag: handleDisableDrag,
127
- enableDrag: handleEnableDrag,
128
- imageUrl: initialModel.imageUrl,
129
- hotspotColor: initialModel.hotspotColor,
130
- multipleCorrect: initialModel.multipleCorrect,
131
- onUpdateImageDimension: onUpdateImageDimension,
132
- onUpdateShapes: onUpdateShapes,
133
- outlineColor: initialModel.outlineColor,
134
- shapes: initialModel.shapes,
135
- strokeWidth: 5,
136
- shapeType: 'rectangle',
137
- handleFinishDrawing: jest.fn(),
138
- onDeleteShape: jest.fn(),
139
- };
140
- return new Drawable(props);
141
- };
142
-
143
- it('handleOnMouseDown target != Stage', () => {
144
- const instance = createInstance();
145
- instance.state.stateShapes = initialModel.shapes;
146
-
147
- const event = {
148
- target: 'Line',
149
- currentTarget: 'Stage',
150
- evt: {
151
- layerX: 20,
152
- layerY: 30,
153
- },
154
- };
155
-
156
- instance.handleOnMouseDown(event);
157
-
158
- expect(onUpdateShapes).not.toBeCalled();
159
- });
160
-
161
- it('handleOnMouseDown target = Stage', () => {
162
- const instance = createInstance();
163
- const event = {
164
- target: 'Stage',
165
- currentTarget: 'Stage',
166
- evt: {
167
- layerX: 20,
168
- layerY: 30,
169
- },
170
- };
171
-
172
- instance.handleOnMouseDown(event);
173
-
174
- expect(onUpdateShapes).toHaveBeenCalledWith([
175
- ...initialModel.shapes,
176
- {
177
- id: '6',
178
- height: 0,
179
- width: 0,
180
- x: 20,
181
- y: 30,
182
- group: 'rectangles',
183
- index: 6,
184
- },
185
- ]);
186
- });
187
-
188
- it('handleOnMouseUp isDrawing = true', () => {
189
- const instance = createInstance();
190
- instance.state.isDrawing = true;
191
- instance.state.shapes = initialModel.shapes.slice(0, 2);
192
-
193
- instance.handleOnMouseUp({
194
- evt: {
195
- layerX: 20,
196
- layerY: 30,
197
- },
198
- });
199
-
200
- expect(onUpdateShapes).toHaveBeenCalledWith([...initialModel.shapes.slice(0, 2)]);
201
-
202
- // at this point, state.stateShapes is false, so we don't want to update shapes with false (onUpdateShapes)
203
- expect(instance.state.stateShapes).toEqual(false);
204
-
205
- instance.handleOnMouseUp({
206
- evt: {
207
- layerX: 20,
208
- layerY: 30,
209
- },
210
- });
211
-
212
- expect(onUpdateShapes).not.toBeCalledWith(false);
213
-
214
- instance.handleOnMouseUp({});
215
-
216
- expect(onUpdateShapes).toHaveBeenCalledWith(initialModel.shapes.slice(0, 2));
217
- });
218
-
219
- it('handleOnSetAsCorrect correct', () => {
220
- const instance = createInstance();
221
- instance.handleOnSetAsCorrect({
222
- id: '1',
223
- });
224
-
225
- expect(onUpdateShapes).toHaveBeenCalledWith([
226
- initialModel.shapes[0],
227
- {
228
- ...initialModel.shapes[1],
229
- correct: true,
230
- },
231
- ...initialModel.shapes.slice(2),
232
- ]);
233
- });
234
-
235
- it('handleOnSetAsCorrect incorrect', () => {
236
- const instance = createInstance();
237
- instance.handleOnSetAsCorrect({
238
- id: '0',
239
- });
240
-
241
- expect(onUpdateShapes).toHaveBeenCalledWith([
242
- {
243
- ...initialModel.shapes[0],
244
- correct: false,
245
- },
246
- ...initialModel.shapes.slice(1),
247
- ]);
248
- });
249
-
250
- it('handleOnDragEnd', () => {
251
- const instance = createInstance();
252
- instance.handleOnDragEnd('0', { x: 1, y: 1 });
253
-
254
- expect(onUpdateShapes).toHaveBeenCalledWith([
255
- {
256
- ...initialModel.shapes[0],
257
- x: 1,
258
- y: 1,
259
- },
260
- ...initialModel.shapes.slice(1),
261
- ]);
262
- });
263
-
264
- it('handleOnDragEnd unexistent id', () => {
265
- const instance = createInstance();
266
- instance.handleOnDragEnd('10', { x: 1, y: 1 });
267
-
268
- expect(onUpdateShapes).toHaveBeenCalledWith(initialModel.shapes);
269
- });
270
- });
271
- });
@@ -1,71 +0,0 @@
1
- import React from 'react';
2
- import { render, fireEvent } from '@testing-library/react';
3
- import Palette from '../hotspot-palette';
4
-
5
- describe('Palette', () => {
6
- let defaultProps;
7
-
8
- beforeEach(() => {
9
- defaultProps = {
10
- hotspotColor: '#FF0000',
11
- outlineColor: '#0000FF',
12
- hotspotList: ['#FF0000', '#00FF00', '#0000FF', '#FFFF00'],
13
- outlineList: ['#000000', '#0000FF', '#FF0000', '#00FF00'],
14
- onHotspotColorChange: jest.fn(),
15
- onOutlineColorChange: jest.fn(),
16
- };
17
- });
18
-
19
- describe('rendering', () => {
20
- it('should render without crashing', () => {
21
- const { container } = render(<Palette {...defaultProps} />);
22
- expect(container).toBeTruthy();
23
- });
24
- });
25
-
26
- describe('edge cases', () => {
27
- it('should handle empty hotspot list gracefully', () => {
28
- const { container } = render(<Palette {...defaultProps} hotspotList={[]} />);
29
- expect(container).toBeTruthy();
30
- });
31
-
32
- it('should handle empty outline list gracefully', () => {
33
- const { container } = render(<Palette {...defaultProps} outlineList={[]} />);
34
- expect(container).toBeTruthy();
35
- });
36
- });
37
-
38
- describe('onChange handler', () => {
39
- it('should create onChange handler for hotspot', () => {
40
- const component = new Palette(defaultProps);
41
- const handler = component.onChange('hotspot');
42
- expect(typeof handler).toBe('function');
43
- });
44
-
45
- it('should create onChange handler for outline', () => {
46
- const component = new Palette(defaultProps);
47
- const handler = component.onChange('outline');
48
- expect(typeof handler).toBe('function');
49
- });
50
-
51
- it('should call onHotspotColorChange when hotspot handler is invoked', () => {
52
- const onHotspotColorChange = jest.fn();
53
- const component = new Palette({ ...defaultProps, onHotspotColorChange });
54
- const handler = component.onChange('hotspot');
55
-
56
- handler({ target: { value: '#00FF00' } });
57
-
58
- expect(onHotspotColorChange).toHaveBeenCalledWith('#00FF00');
59
- });
60
-
61
- it('should call onOutlineColorChange when outline handler is invoked', () => {
62
- const onOutlineColorChange = jest.fn();
63
- const component = new Palette({ ...defaultProps, onOutlineColorChange });
64
- const handler = component.onChange('outline');
65
-
66
- handler({ target: { value: '#FF0000' } });
67
-
68
- expect(onOutlineColorChange).toHaveBeenCalledWith('#FF0000');
69
- });
70
- });
71
- });
@@ -1,226 +0,0 @@
1
- import React from 'react';
2
- import { render, waitFor } from '@testing-library/react';
3
- import Konva from 'konva';
4
- import ImageComponent from '../image-konva';
5
-
6
- Konva.isBrowser = false;
7
-
8
- jest.mock('react-konva', () => {
9
- const React = require('react');
10
- return {
11
- Image: (props) => React.createElement('div', { 'data-testid': 'image', ...props }),
12
- };
13
- });
14
-
15
- describe('ImageComponent', () => {
16
- let defaultProps;
17
-
18
- beforeEach(() => {
19
- defaultProps = {
20
- src: 'test-image.png',
21
- x: 100,
22
- y: 150,
23
- };
24
- });
25
-
26
- describe('rendering', () => {
27
- it('should render without crashing', () => {
28
- const { container } = render(<ImageComponent {...defaultProps} />);
29
- expect(container).toBeTruthy();
30
- });
31
-
32
- it('should render Image component', () => {
33
- const { getByTestId } = render(<ImageComponent {...defaultProps} />);
34
- expect(getByTestId('image')).toBeInTheDocument();
35
- });
36
-
37
- it('should render with correct position', () => {
38
- const { getByTestId } = render(<ImageComponent {...defaultProps} x={200} y={250} />);
39
- const image = getByTestId('image');
40
- expect(image).toHaveAttribute('x', '200');
41
- expect(image).toHaveAttribute('y', '250');
42
- });
43
-
44
- it('should render with fixed dimensions', () => {
45
- const { getByTestId } = render(<ImageComponent {...defaultProps} />);
46
- const image = getByTestId('image');
47
- expect(image).toHaveAttribute('width', '20');
48
- expect(image).toHaveAttribute('height', '20');
49
- });
50
-
51
- it('should render at origin (0, 0)', () => {
52
- const { getByTestId } = render(<ImageComponent {...defaultProps} x={0} y={0} />);
53
- const image = getByTestId('image');
54
- expect(image).toHaveAttribute('x', '0');
55
- expect(image).toHaveAttribute('y', '0');
56
- });
57
- });
58
-
59
- describe('image loading', () => {
60
- it('should load image on mount', async () => {
61
- const { getByTestId } = render(<ImageComponent {...defaultProps} />);
62
-
63
- const image = getByTestId('image');
64
- expect(image).toBeInTheDocument();
65
- });
66
-
67
- it('should call loadImage on mount', () => {
68
- const { container } = render(<ImageComponent {...defaultProps} src="custom-image.jpg" />);
69
-
70
- expect(container).toBeTruthy();
71
- });
72
- });
73
-
74
- describe('component lifecycle', () => {
75
- it('should reload image when src changes', async () => {
76
- const { rerender, container } = render(<ImageComponent {...defaultProps} src="image1.png" />);
77
-
78
- expect(container).toBeTruthy();
79
-
80
- rerender(<ImageComponent {...defaultProps} src="image2.png" />);
81
-
82
- expect(container).toBeTruthy();
83
- });
84
-
85
- it('should not reload image when src stays the same', async () => {
86
- const { rerender, getByTestId } = render(<ImageComponent {...defaultProps} src="same-image.png" />);
87
-
88
- const image = getByTestId('image');
89
- expect(image).toBeInTheDocument();
90
-
91
- rerender(<ImageComponent {...defaultProps} src="same-image.png" x={200} y={250} />);
92
-
93
- const updatedImage = getByTestId('image');
94
- expect(updatedImage).toHaveAttribute('x', '200');
95
- expect(updatedImage).toHaveAttribute('y', '250');
96
- });
97
-
98
- it('should clean up event listener on unmount', () => {
99
- const { unmount } = render(<ImageComponent {...defaultProps} />);
100
-
101
- expect(() => {
102
- unmount();
103
- }).not.toThrow();
104
- });
105
-
106
- it('should handle multiple mount/unmount cycles', () => {
107
- const { unmount } = render(<ImageComponent {...defaultProps} />);
108
- unmount();
109
-
110
- expect(() => {
111
- render(<ImageComponent {...defaultProps} />);
112
- }).not.toThrow();
113
- });
114
- });
115
-
116
- describe('position updates', () => {
117
- it('should update x position', () => {
118
- const { getByTestId, rerender } = render(<ImageComponent {...defaultProps} x={100} />);
119
- let image = getByTestId('image');
120
- expect(image).toHaveAttribute('x', '100');
121
-
122
- rerender(<ImageComponent {...defaultProps} x={200} />);
123
- image = getByTestId('image');
124
- expect(image).toHaveAttribute('x', '200');
125
- });
126
-
127
- it('should update y position', () => {
128
- const { getByTestId, rerender } = render(<ImageComponent {...defaultProps} y={150} />);
129
- let image = getByTestId('image');
130
- expect(image).toHaveAttribute('y', '150');
131
-
132
- rerender(<ImageComponent {...defaultProps} y={250} />);
133
- image = getByTestId('image');
134
- expect(image).toHaveAttribute('y', '250');
135
- });
136
-
137
- it('should update both x and y positions', () => {
138
- const { getByTestId, rerender } = render(<ImageComponent {...defaultProps} x={100} y={150} />);
139
- let image = getByTestId('image');
140
- expect(image).toHaveAttribute('x', '100');
141
- expect(image).toHaveAttribute('y', '150');
142
-
143
- rerender(<ImageComponent {...defaultProps} x={300} y={400} />);
144
- image = getByTestId('image');
145
- expect(image).toHaveAttribute('x', '300');
146
- expect(image).toHaveAttribute('y', '400');
147
- });
148
- });
149
-
150
- describe('edge cases', () => {
151
- it('should handle negative positions', () => {
152
- const { getByTestId } = render(<ImageComponent {...defaultProps} x={-50} y={-75} />);
153
- const image = getByTestId('image');
154
- expect(image).toHaveAttribute('x', '-50');
155
- expect(image).toHaveAttribute('y', '-75');
156
- });
157
-
158
- it('should handle very large positions', () => {
159
- const { getByTestId } = render(<ImageComponent {...defaultProps} x={10000} y={20000} />);
160
- const image = getByTestId('image');
161
- expect(image).toHaveAttribute('x', '10000');
162
- expect(image).toHaveAttribute('y', '20000');
163
- });
164
-
165
- it('should handle data URI as src', () => {
166
- const dataUri = 'data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAABCAYAAAAfFcSJAAAADUlEQVR42mNk+M9QDwADhgGAWjR9awAAAABJRU5ErkJggg==';
167
- const { container } = render(<ImageComponent {...defaultProps} src={dataUri} />);
168
-
169
- expect(container).toBeTruthy();
170
- });
171
-
172
- it('should handle SVG as src', () => {
173
- const { container } = render(<ImageComponent {...defaultProps} src="icon.svg" />);
174
- expect(container).toBeTruthy();
175
- });
176
-
177
- it('should handle empty src', () => {
178
- const { container } = render(<ImageComponent {...defaultProps} src="" />);
179
- expect(container).toBeTruthy();
180
- });
181
-
182
- it('should handle URL with query parameters', () => {
183
- const srcWithParams = 'image.png?width=100&height=100';
184
- const { container } = render(<ImageComponent {...defaultProps} src={srcWithParams} />);
185
-
186
- expect(container).toBeTruthy();
187
- });
188
-
189
- it('should handle relative paths', () => {
190
- const { container } = render(<ImageComponent {...defaultProps} src="./images/icon.png" />);
191
- expect(container).toBeTruthy();
192
- });
193
-
194
- it('should handle absolute paths', () => {
195
- const { container } = render(<ImageComponent {...defaultProps} src="/assets/icon.png" />);
196
- expect(container).toBeTruthy();
197
- });
198
- });
199
-
200
- describe('image state', () => {
201
- it('should initially render without image loaded', () => {
202
- const { getByTestId } = render(<ImageComponent {...defaultProps} />);
203
- const image = getByTestId('image');
204
- expect(image).toBeInTheDocument();
205
- });
206
-
207
- it('should render component regardless of image load state', () => {
208
- const { getByTestId } = render(<ImageComponent {...defaultProps} />);
209
- const image = getByTestId('image');
210
- expect(image).toBeInTheDocument();
211
- });
212
- });
213
-
214
- describe('error handling', () => {
215
- it('should handle image load error gracefully', () => {
216
- const { container } = render(<ImageComponent {...defaultProps} src="nonexistent.png" />);
217
-
218
- const imgElements = document.querySelectorAll('img[src="nonexistent.png"]');
219
- imgElements.forEach(img => {
220
- img.dispatchEvent(new Event('error'));
221
- });
222
-
223
- expect(container).toBeTruthy();
224
- });
225
- });
226
- });