@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,418 +0,0 @@
1
- import React from 'react';
2
- import { render, fireEvent } from '@testing-library/react';
3
- import Konva from 'konva';
4
- import RectComponent from '../rectangle';
5
-
6
- Konva.isBrowser = false;
7
-
8
- jest.mock('react-konva', () => {
9
- const React = require('react');
10
- return {
11
- Rect: ({ onClick, onTap, onMouseEnter, onMouseLeave, ...props }) => {
12
- const handleClick = (e) => {
13
- if (onClick) onClick(e);
14
- if (onTap) onTap(e);
15
- };
16
- return React.createElement('div', {
17
- 'data-testid': 'rect',
18
- onClick: handleClick,
19
- onMouseEnter,
20
- onMouseLeave,
21
- ...props,
22
- });
23
- },
24
- Group: ({ children, ...props }) => React.createElement('div', { 'data-testid': 'group', ...props }, children),
25
- };
26
- });
27
-
28
- jest.mock('../image-konva-tooltip', () => {
29
- return function ImageComponent({ src, x, y, tooltip }) {
30
- return <div data-testid="icon-image" data-src={src} data-x={x} data-y={y} data-tooltip={tooltip} />;
31
- };
32
- });
33
-
34
- describe('RectComponent', () => {
35
- let defaultProps;
36
-
37
- beforeEach(() => {
38
- defaultProps = {
39
- id: 'rect1',
40
- x: 10,
41
- y: 20,
42
- width: 100,
43
- height: 80,
44
- hotspotColor: '#FF0000',
45
- selectedHotspotColor: '#00FF00',
46
- outlineColor: '#0000FF',
47
- hoverOutlineColor: '#FFFF00',
48
- selected: false,
49
- isCorrect: false,
50
- isEvaluateMode: false,
51
- disabled: false,
52
- onClick: jest.fn(),
53
- strokeWidth: 5,
54
- scale: 1,
55
- markAsCorrect: false,
56
- showCorrectEnabled: false,
57
- };
58
- });
59
-
60
- afterEach(() => {
61
- document.body.style.cursor = 'default';
62
- });
63
-
64
- describe('rendering', () => {
65
- it('should render without crashing', () => {
66
- const { container } = render(<RectComponent {...defaultProps} />);
67
- expect(container).toBeTruthy();
68
- });
69
-
70
- it('should render with correct dimensions', () => {
71
- const { container } = render(<RectComponent {...defaultProps} />);
72
- const rects = container.querySelectorAll('[data-testid="rect"]');
73
- const mainRect = rects[rects.length - 1];
74
-
75
- expect(mainRect).toHaveAttribute('x', '10');
76
- expect(mainRect).toHaveAttribute('y', '20');
77
- expect(mainRect).toHaveAttribute('width', '100');
78
- expect(mainRect).toHaveAttribute('height', '80');
79
- });
80
-
81
- it('should render with hotspot color when not selected', () => {
82
- const { container } = render(<RectComponent {...defaultProps} />);
83
- const rects = container.querySelectorAll('[data-testid="rect"]');
84
- const mainRect = rects[rects.length - 1];
85
-
86
- expect(mainRect).toHaveAttribute('fill', '#FF0000');
87
- });
88
-
89
- it('should render with selected color when selected', () => {
90
- const { container } = render(<RectComponent {...defaultProps} selected={true} />);
91
- const rects = container.querySelectorAll('[data-testid="rect"]');
92
- const mainRect = rects[rects.length - 1];
93
-
94
- expect(mainRect).toHaveAttribute('fill', '#00FF00');
95
- });
96
-
97
- it('should apply scale transform', () => {
98
- const { getByTestId } = render(<RectComponent {...defaultProps} scale={1.5} />);
99
- const group = getByTestId('group');
100
-
101
- expect(group).toHaveAttribute('scaleX', '1.5');
102
- expect(group).toHaveAttribute('scaleY', '1.5');
103
- });
104
-
105
- it('should render with default scale of 1', () => {
106
- const { getByTestId } = render(<RectComponent {...defaultProps} />);
107
- const group = getByTestId('group');
108
-
109
- expect(group).toHaveAttribute('scaleX', '1');
110
- expect(group).toHaveAttribute('scaleY', '1');
111
- });
112
- });
113
-
114
- describe('interactions', () => {
115
- it('should call onClick when clicked', () => {
116
- const onClick = jest.fn();
117
- const { container } = render(<RectComponent {...defaultProps} onClick={onClick} />);
118
- const rects = container.querySelectorAll('[data-testid="rect"]');
119
- const mainRect = rects[rects.length - 1];
120
-
121
- fireEvent.click(mainRect);
122
-
123
- expect(onClick).toHaveBeenCalledWith({
124
- id: 'rect1',
125
- selected: true,
126
- selector: 'Mouse',
127
- });
128
- });
129
-
130
- it('should toggle selection state on click', () => {
131
- const onClick = jest.fn();
132
- const { container, rerender } = render(<RectComponent {...defaultProps} onClick={onClick} selected={false} />);
133
- const rects = container.querySelectorAll('[data-testid="rect"]');
134
- const mainRect = rects[rects.length - 1];
135
-
136
- fireEvent.click(mainRect);
137
-
138
- expect(onClick).toHaveBeenCalledWith({
139
- id: 'rect1',
140
- selected: true,
141
- selector: 'Mouse',
142
- });
143
-
144
- rerender(<RectComponent {...defaultProps} onClick={onClick} selected={true} />);
145
-
146
- const rectsAfter = container.querySelectorAll('[data-testid="rect"]');
147
- const mainRectAfter = rectsAfter[rectsAfter.length - 1];
148
- fireEvent.click(mainRectAfter);
149
-
150
- expect(onClick).toHaveBeenCalledWith({
151
- id: 'rect1',
152
- selected: false,
153
- selector: 'Mouse',
154
- });
155
- });
156
-
157
- it('should not call onClick when disabled', () => {
158
- const onClick = jest.fn();
159
- const { container } = render(<RectComponent {...defaultProps} onClick={onClick} disabled={true} />);
160
- const rects = container.querySelectorAll('[data-testid="rect"]');
161
- const mainRect = rects[rects.length - 1];
162
-
163
- fireEvent.click(mainRect);
164
-
165
- expect(onClick).not.toHaveBeenCalled();
166
- });
167
-
168
- it('should change cursor to pointer on mouse enter when not disabled', () => {
169
- const { container } = render(<RectComponent {...defaultProps} />);
170
- const rects = container.querySelectorAll('[data-testid="rect"]');
171
- const mainRect = rects[rects.length - 1];
172
-
173
- fireEvent.mouseEnter(mainRect);
174
-
175
- expect(document.body.style.cursor).toBe('pointer');
176
- });
177
-
178
- it('should not change cursor when disabled', () => {
179
- const { container } = render(<RectComponent {...defaultProps} disabled={true} />);
180
- const rects = container.querySelectorAll('[data-testid="rect"]');
181
- const mainRect = rects[rects.length - 1];
182
-
183
- fireEvent.mouseEnter(mainRect);
184
-
185
- expect(document.body.style.cursor).toBe('default');
186
- });
187
-
188
- it('should reset cursor to default on mouse leave', () => {
189
- const { container } = render(<RectComponent {...defaultProps} />);
190
- const rects = container.querySelectorAll('[data-testid="rect"]');
191
- const mainRect = rects[rects.length - 1];
192
-
193
- fireEvent.mouseEnter(mainRect);
194
- fireEvent.mouseLeave(mainRect);
195
-
196
- expect(document.body.style.cursor).toBe('default');
197
- });
198
- });
199
-
200
- describe('hover styling', () => {
201
- it('should show hover outline when hoverOutlineColor is provided', () => {
202
- const { container } = render(<RectComponent {...defaultProps} hoverOutlineColor="#FFFF00" />);
203
- const rects = container.querySelectorAll('[data-testid="rect"]');
204
- const mainRect = rects[rects.length - 1];
205
-
206
- fireEvent.mouseEnter(mainRect);
207
-
208
- const rectsAfterHover = container.querySelectorAll('[data-testid="rect"]');
209
- expect(rectsAfterHover.length).toBeGreaterThan(1);
210
- });
211
-
212
- it('should not show hover outline when selected', () => {
213
- const { container } = render(
214
- <RectComponent {...defaultProps} selected={true} hoverOutlineColor="#FFFF00" />
215
- );
216
- const rects = container.querySelectorAll('[data-testid="rect"]');
217
- const mainRect = rects[rects.length - 1];
218
-
219
- fireEvent.mouseEnter(mainRect);
220
-
221
- const hoverRect = container.querySelector('[stroke="#FFFF00"]');
222
- if (hoverRect) {
223
- expect(hoverRect).toHaveAttribute('stroke', 'transparent');
224
- }
225
- });
226
- });
227
-
228
- describe('evaluate mode', () => {
229
- it('should show correct icon when correctly selected in evaluate mode', () => {
230
- const { getByTestId } = render(
231
- <RectComponent
232
- {...defaultProps}
233
- isEvaluateMode={true}
234
- selected={true}
235
- isCorrect={true}
236
- showCorrectEnabled={false}
237
- />
238
- );
239
-
240
- const icon = getByTestId('icon-image');
241
- expect(icon).toBeInTheDocument();
242
- expect(icon).toHaveAttribute('data-src');
243
- });
244
-
245
- it('should show wrong icon when incorrectly selected in evaluate mode', () => {
246
- const { getByTestId } = render(
247
- <RectComponent
248
- {...defaultProps}
249
- isEvaluateMode={true}
250
- selected={true}
251
- isCorrect={false}
252
- showCorrectEnabled={false}
253
- />
254
- );
255
-
256
- const icon = getByTestId('icon-image');
257
- expect(icon).toBeInTheDocument();
258
- });
259
-
260
- it('should show wrong icon when incorrectly not selected', () => {
261
- const { getByTestId } = render(
262
- <RectComponent
263
- {...defaultProps}
264
- isEvaluateMode={true}
265
- selected={false}
266
- isCorrect={false}
267
- showCorrectEnabled={false}
268
- />
269
- );
270
-
271
- const icon = getByTestId('icon-image');
272
- expect(icon).toBeInTheDocument();
273
- });
274
-
275
- it('should not show icon when correctly not selected in evaluate mode', () => {
276
- const { queryByTestId } = render(
277
- <RectComponent
278
- {...defaultProps}
279
- isEvaluateMode={true}
280
- selected={false}
281
- isCorrect={true}
282
- showCorrectEnabled={false}
283
- />
284
- );
285
-
286
- const icon = queryByTestId('icon-image');
287
- expect(icon).not.toBeInTheDocument();
288
- });
289
-
290
- it('should show correct icon for showCorrect mode when correctly selected', () => {
291
- const { getByTestId } = render(
292
- <RectComponent
293
- {...defaultProps}
294
- isEvaluateMode={true}
295
- selected={true}
296
- isCorrect={true}
297
- showCorrectEnabled={true}
298
- />
299
- );
300
-
301
- const icon = getByTestId('icon-image');
302
- expect(icon).toBeInTheDocument();
303
- });
304
-
305
- it('should show correct icon for showCorrect mode when incorrectly not selected', () => {
306
- const { getByTestId } = render(
307
- <RectComponent
308
- {...defaultProps}
309
- isEvaluateMode={true}
310
- selected={false}
311
- isCorrect={false}
312
- showCorrectEnabled={true}
313
- />
314
- );
315
-
316
- const icon = getByTestId('icon-image');
317
- expect(icon).toBeInTheDocument();
318
- });
319
-
320
- it('should not show icon in showCorrect mode when correctly not selected', () => {
321
- const { queryByTestId } = render(
322
- <RectComponent
323
- {...defaultProps}
324
- isEvaluateMode={true}
325
- selected={false}
326
- isCorrect={true}
327
- showCorrectEnabled={true}
328
- />
329
- );
330
-
331
- const icon = queryByTestId('icon-image');
332
- expect(icon).not.toBeInTheDocument();
333
- });
334
-
335
- it('should not show icon in showCorrect mode when incorrectly selected', () => {
336
- const { queryByTestId } = render(
337
- <RectComponent
338
- {...defaultProps}
339
- isEvaluateMode={true}
340
- selected={true}
341
- isCorrect={false}
342
- showCorrectEnabled={true}
343
- />
344
- );
345
-
346
- const icon = queryByTestId('icon-image');
347
- expect(icon).not.toBeInTheDocument();
348
- });
349
-
350
- it('should show green outline when markAsCorrect is true', () => {
351
- const { container } = render(
352
- <RectComponent
353
- {...defaultProps}
354
- isEvaluateMode={true}
355
- markAsCorrect={true}
356
- />
357
- );
358
-
359
- const rects = container.querySelectorAll('[data-testid="rect"]');
360
- const mainRect = rects[rects.length - 1];
361
- expect(mainRect).toHaveAttribute('stroke', 'green');
362
- });
363
-
364
- it('should show red outline when incorrect and not markAsCorrect', () => {
365
- const { container } = render(
366
- <RectComponent
367
- {...defaultProps}
368
- isEvaluateMode={true}
369
- isCorrect={false}
370
- markAsCorrect={false}
371
- />
372
- );
373
-
374
- const rects = container.querySelectorAll('[data-testid="rect"]');
375
- const mainRect = rects[rects.length - 1];
376
- expect(mainRect).toHaveAttribute('stroke', 'red');
377
- });
378
-
379
- it('should display evaluate text in tooltip', () => {
380
- const { getByTestId } = render(
381
- <RectComponent
382
- {...defaultProps}
383
- isEvaluateMode={true}
384
- selected={true}
385
- isCorrect={true}
386
- evaluateText="Correct answer!"
387
- showCorrectEnabled={false}
388
- />
389
- );
390
-
391
- const icon = getByTestId('icon-image');
392
- expect(icon).toHaveAttribute('data-tooltip', 'Correct answer!');
393
- });
394
- });
395
-
396
- describe('icon positioning', () => {
397
- it('should position icon at center of rectangle', () => {
398
- const { getByTestId } = render(
399
- <RectComponent
400
- {...defaultProps}
401
- x={10}
402
- y={20}
403
- width={100}
404
- height={80}
405
- isEvaluateMode={true}
406
- selected={true}
407
- isCorrect={true}
408
- showCorrectEnabled={false}
409
- />
410
- );
411
-
412
- const icon = getByTestId('icon-image');
413
- // Icon should be centered: x + width/2 - 10, y + height/2 - 10
414
- expect(icon).toHaveAttribute('data-x', '50'); // 10 + 100/2 - 10
415
- expect(icon).toHaveAttribute('data-y', '50'); // 20 + 80/2 - 10
416
- });
417
- });
418
- });
@@ -1,152 +0,0 @@
1
- import React from 'react';
2
- import PropTypes from 'prop-types';
3
- import { Circle, Group, Rect } from 'react-konva';
4
- import ImageComponent from './image-konva-tooltip';
5
- import { faCorrect, faWrong } from './icons';
6
-
7
- class CircleComponent extends React.Component {
8
- constructor(props) {
9
- super(props);
10
- this.state = {
11
- hovered: false,
12
- };
13
- }
14
-
15
- handleClick = (e) => {
16
- const { onClick, id, selected, disabled } = this.props;
17
-
18
- if (!disabled) {
19
- e.cancelBubble = true;
20
- onClick({ id, selected: !selected, selector: 'Mouse' });
21
- }
22
- };
23
-
24
- handleMouseEnter = () => {
25
- const { disabled } = this.props;
26
-
27
- if (!disabled) {
28
- document.body.style.cursor = 'pointer';
29
- }
30
- this.setState({ hovered: true });
31
- };
32
-
33
- handleMouseLeave = () => {
34
- document.body.style.cursor = 'default';
35
- this.setState({ hovered: false });
36
- };
37
-
38
- getEvaluateOutlineColor = (isCorrect, markAsCorrect, outlineColor) =>
39
- markAsCorrect ? 'green' : isCorrect ? outlineColor : 'red';
40
-
41
- getOutlineWidth = (showCorrectEnabled, selected, markAsCorrect, strokeWidth) =>
42
- markAsCorrect || (!markAsCorrect && !showCorrectEnabled && selected) ? strokeWidth : 0;
43
-
44
- render() {
45
- const {
46
- radius,
47
- hotspotColor,
48
- isCorrect,
49
- isEvaluateMode,
50
- hoverOutlineColor,
51
- outlineColor,
52
- selected,
53
- x,
54
- y,
55
- evaluateText,
56
- strokeWidth,
57
- scale,
58
- markAsCorrect,
59
- selectedHotspotColor,
60
- showCorrectEnabled,
61
- } = this.props;
62
-
63
- const { hovered } = this.state;
64
-
65
- const outlineColorParsed = isEvaluateMode
66
- ? this.getEvaluateOutlineColor(isCorrect, markAsCorrect, outlineColor)
67
- : outlineColor;
68
-
69
- const outlineWidth = this.getOutlineWidth(showCorrectEnabled, selected, markAsCorrect, strokeWidth);
70
-
71
- const iconX = x - 10;
72
- const iconY = y - 10; // Adjust position for the icon
73
-
74
- let iconSrc;
75
- if (showCorrectEnabled) {
76
- if ((selected && isCorrect) || (!selected && !isCorrect)) {
77
- iconSrc = faCorrect;
78
- }
79
- } else {
80
- if (selected) {
81
- if (isCorrect) {
82
- iconSrc = faCorrect;
83
- } else {
84
- iconSrc = faWrong;
85
- }
86
- } else if (!isCorrect) {
87
- iconSrc = faWrong;
88
- }
89
- }
90
-
91
- const useHoveredStyle = hovered && hoverOutlineColor;
92
-
93
- return (
94
- <Group scaleX={scale} scaleY={scale}>
95
- {useHoveredStyle && (
96
- <Rect
97
- x={x - radius}
98
- y={y - radius}
99
- width={radius * 2}
100
- height={radius * 2}
101
- stroke={selected ? 'transparent' : hoverOutlineColor}
102
- strokeWidth={strokeWidth}
103
- />
104
- )}
105
- <Circle
106
- radius={radius}
107
- fill={selected && selectedHotspotColor ? selectedHotspotColor : hotspotColor}
108
- onClick={this.handleClick}
109
- onTap={this.handleClick}
110
- draggable={false}
111
- stroke={useHoveredStyle && !selected ? 'transparent' : outlineColorParsed}
112
- strokeWidth={useHoveredStyle && !selected ? 0 : outlineWidth}
113
- onMouseLeave={this.handleMouseLeave}
114
- onMouseEnter={this.handleMouseEnter}
115
- x={x}
116
- y={y}
117
- />
118
- {isEvaluateMode && iconSrc ? <ImageComponent src={iconSrc} x={iconX} y={iconY} tooltip={evaluateText} /> : null}
119
- </Group>
120
- );
121
- }
122
- }
123
-
124
- CircleComponent.propTypes = {
125
- radius: PropTypes.number.isRequired,
126
- hotspotColor: PropTypes.string.isRequired,
127
- id: PropTypes.string.isRequired,
128
- isCorrect: PropTypes.oneOfType([PropTypes.bool, PropTypes.string]),
129
- isEvaluateMode: PropTypes.bool.isRequired,
130
- disabled: PropTypes.bool.isRequired,
131
- hoverOutlineColor: PropTypes.string,
132
- onClick: PropTypes.func.isRequired,
133
- outlineColor: PropTypes.string.isRequired,
134
- selected: PropTypes.bool.isRequired,
135
- x: PropTypes.number.isRequired,
136
- y: PropTypes.number.isRequired,
137
- evaluateText: PropTypes.string,
138
- strokeWidth: PropTypes.number,
139
- scale: PropTypes.number,
140
- selectedHotspotColor: PropTypes.string,
141
- markAsCorrect: PropTypes.bool.isRequired,
142
- showCorrectEnabled: PropTypes.bool.isRequired,
143
- };
144
-
145
- CircleComponent.defaultProps = {
146
- isCorrect: false,
147
- evaluateText: null,
148
- strokeWidth: 5,
149
- scale: 1,
150
- };
151
-
152
- export default CircleComponent;