@pie-element/hotspot 11.1.2-next.5 → 11.1.3

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/CHANGELOG.json +997 -0
  2. package/CHANGELOG.md +2226 -0
  3. package/LICENSE.md +5 -0
  4. package/README.md +1 -0
  5. package/configure/CHANGELOG.json +682 -0
  6. package/configure/CHANGELOG.md +1963 -0
  7. package/configure/lib/DeleteWidget.js +64 -0
  8. package/configure/lib/DeleteWidget.js.map +1 -0
  9. package/configure/lib/button.js +42 -0
  10. package/configure/lib/button.js.map +1 -0
  11. package/configure/lib/buttons/circle.js +33 -0
  12. package/configure/lib/buttons/circle.js.map +1 -0
  13. package/configure/lib/buttons/polygon.js +39 -0
  14. package/configure/lib/buttons/polygon.js.map +1 -0
  15. package/configure/lib/buttons/rectangle.js +39 -0
  16. package/configure/lib/buttons/rectangle.js.map +1 -0
  17. package/configure/lib/defaults.js +155 -0
  18. package/configure/lib/defaults.js.map +1 -0
  19. package/configure/lib/hotspot-circle.js +192 -0
  20. package/configure/lib/hotspot-circle.js.map +1 -0
  21. package/configure/lib/hotspot-container.js +320 -0
  22. package/configure/lib/hotspot-container.js.map +1 -0
  23. package/configure/lib/hotspot-drawable.js +519 -0
  24. package/configure/lib/hotspot-drawable.js.map +1 -0
  25. package/configure/lib/hotspot-palette.js +107 -0
  26. package/configure/lib/hotspot-palette.js.map +1 -0
  27. package/configure/lib/hotspot-polygon.js +293 -0
  28. package/configure/lib/hotspot-polygon.js.map +1 -0
  29. package/configure/lib/hotspot-rectangle.js +190 -0
  30. package/configure/lib/hotspot-rectangle.js.map +1 -0
  31. package/configure/lib/icons.js +7 -0
  32. package/configure/lib/icons.js.map +1 -0
  33. package/configure/lib/image-konva.js +66 -0
  34. package/configure/lib/image-konva.js.map +1 -0
  35. package/configure/lib/index.js +194 -0
  36. package/configure/lib/index.js.map +1 -0
  37. package/configure/lib/root.js +330 -0
  38. package/configure/lib/root.js.map +1 -0
  39. package/configure/lib/shapes/circle.js +84 -0
  40. package/configure/lib/shapes/circle.js.map +1 -0
  41. package/configure/lib/shapes/index.js +50 -0
  42. package/configure/lib/shapes/index.js.map +1 -0
  43. package/configure/lib/shapes/polygon.js +82 -0
  44. package/configure/lib/shapes/polygon.js.map +1 -0
  45. package/configure/lib/shapes/rectagle.js +84 -0
  46. package/configure/lib/shapes/rectagle.js.map +1 -0
  47. package/configure/lib/shapes/utils.js +21 -0
  48. package/configure/lib/shapes/utils.js.map +1 -0
  49. package/configure/lib/upload-control.js +41 -0
  50. package/configure/lib/upload-control.js.map +1 -0
  51. package/configure/lib/utils.js +185 -0
  52. package/configure/lib/utils.js.map +1 -0
  53. package/configure/package.json +26 -0
  54. package/configure/src/DeleteWidget.jsx +51 -0
  55. package/configure/src/__tests__/DeleteWidget.test.jsx +366 -0
  56. package/configure/src/__tests__/button.test.jsx +198 -0
  57. package/configure/src/__tests__/hotspot-circle.test.jsx +259 -0
  58. package/configure/src/__tests__/hotspot-container.test.js +366 -0
  59. package/configure/src/__tests__/hotspot-drawable.test.js +271 -0
  60. package/configure/src/__tests__/hotspot-palette.test.jsx +71 -0
  61. package/configure/src/__tests__/image-konva.test.jsx +226 -0
  62. package/configure/src/__tests__/index.test.js +329 -0
  63. package/configure/src/__tests__/root.test.js +400 -0
  64. package/configure/src/__tests__/utils.test.js +241 -0
  65. package/configure/src/button.jsx +35 -0
  66. package/configure/src/buttons/circle.jsx +18 -0
  67. package/configure/src/buttons/polygon.jsx +29 -0
  68. package/configure/src/buttons/rectangle.jsx +29 -0
  69. package/configure/src/defaults.js +109 -0
  70. package/configure/src/hotspot-circle.jsx +183 -0
  71. package/configure/src/hotspot-container.jsx +330 -0
  72. package/configure/src/hotspot-drawable.jsx +527 -0
  73. package/configure/src/hotspot-palette.jsx +90 -0
  74. package/configure/src/hotspot-polygon.jsx +294 -0
  75. package/configure/src/hotspot-rectangle.jsx +169 -0
  76. package/configure/src/icons.js +5 -0
  77. package/configure/src/image-konva.jsx +63 -0
  78. package/configure/src/index.js +208 -0
  79. package/configure/src/root.jsx +346 -0
  80. package/configure/src/shapes/circle.js +81 -0
  81. package/configure/src/shapes/index.js +4 -0
  82. package/configure/src/shapes/polygon.js +81 -0
  83. package/configure/src/shapes/rectagle.js +82 -0
  84. package/configure/src/shapes/utils.js +16 -0
  85. package/configure/src/upload-control.jsx +33 -0
  86. package/configure/src/utils.js +210 -0
  87. package/controller/CHANGELOG.json +362 -0
  88. package/controller/CHANGELOG.md +1304 -0
  89. package/controller/lib/defaults.js +33 -0
  90. package/controller/lib/defaults.js.map +1 -0
  91. package/controller/lib/index.js +341 -0
  92. package/controller/lib/index.js.map +1 -0
  93. package/controller/lib/utils.js +32 -0
  94. package/controller/lib/utils.js.map +1 -0
  95. package/controller/package.json +18 -0
  96. package/controller/src/__tests__/index.test.js +419 -0
  97. package/controller/src/__tests__/utils.test.js +5 -0
  98. package/controller/src/defaults.js +19 -0
  99. package/controller/src/index.js +328 -0
  100. package/controller/src/utils.js +29 -0
  101. package/docs/config-schema.json +2023 -0
  102. package/docs/config-schema.json.md +1495 -0
  103. package/docs/demo/config.js +8 -0
  104. package/docs/demo/generate.js +118 -0
  105. package/docs/demo/index.html +1 -0
  106. package/docs/demo/session.js +11 -0
  107. package/docs/pie-schema.json +1204 -0
  108. package/docs/pie-schema.json.md +851 -0
  109. package/lib/hotspot/circle.js +156 -0
  110. package/lib/hotspot/circle.js.map +1 -0
  111. package/lib/hotspot/container.js +206 -0
  112. package/lib/hotspot/container.js.map +1 -0
  113. package/lib/hotspot/icons.js +8 -0
  114. package/lib/hotspot/icons.js.map +1 -0
  115. package/lib/hotspot/image-konva-tooltip.js +86 -0
  116. package/lib/hotspot/image-konva-tooltip.js.map +1 -0
  117. package/lib/hotspot/index.js +163 -0
  118. package/lib/hotspot/index.js.map +1 -0
  119. package/lib/hotspot/polygon.js +203 -0
  120. package/lib/hotspot/polygon.js.map +1 -0
  121. package/lib/hotspot/rectangle.js +175 -0
  122. package/lib/hotspot/rectangle.js.map +1 -0
  123. package/lib/index.js +213 -0
  124. package/lib/index.js.map +1 -0
  125. package/lib/session-updater.js +42 -0
  126. package/lib/session-updater.js.map +1 -0
  127. package/package.json +18 -83
  128. package/src/__tests__/container.test.jsx +58 -0
  129. package/src/__tests__/index.test.js +123 -0
  130. package/src/__tests__/session-updater.test.jsx +69 -0
  131. package/src/hotspot/__tests__/circle.test.jsx +464 -0
  132. package/src/hotspot/__tests__/container.test.jsx +546 -0
  133. package/src/hotspot/__tests__/image-konva-tooltip.test.jsx +510 -0
  134. package/src/hotspot/__tests__/polygon.test.jsx +502 -0
  135. package/src/hotspot/__tests__/rectangle.test.jsx +418 -0
  136. package/src/hotspot/circle.jsx +152 -0
  137. package/src/hotspot/container.jsx +217 -0
  138. package/src/hotspot/icons.js +7 -0
  139. package/src/hotspot/image-konva-tooltip.jsx +76 -0
  140. package/src/hotspot/index.jsx +165 -0
  141. package/src/hotspot/polygon.jsx +195 -0
  142. package/src/hotspot/rectangle.jsx +171 -0
  143. package/src/index.js +226 -0
  144. package/src/session-updater.js +29 -0
  145. package/configure.js +0 -2
  146. package/controller.js +0 -1
  147. package/dist/author/DeleteWidget.d.ts +0 -38
  148. package/dist/author/DeleteWidget.js +0 -46
  149. package/dist/author/button.d.ts +0 -31
  150. package/dist/author/button.js +0 -27
  151. package/dist/author/buttons/circle.d.ts +0 -18
  152. package/dist/author/buttons/circle.js +0 -25
  153. package/dist/author/buttons/polygon.d.ts +0 -18
  154. package/dist/author/buttons/polygon.js +0 -36
  155. package/dist/author/buttons/rectangle.d.ts +0 -18
  156. package/dist/author/buttons/rectangle.js +0 -36
  157. package/dist/author/defaults.d.ts +0 -157
  158. package/dist/author/defaults.js +0 -119
  159. package/dist/author/hotspot-circle.d.ts +0 -21
  160. package/dist/author/hotspot-circle.js +0 -124
  161. package/dist/author/hotspot-container.d.ts +0 -29
  162. package/dist/author/hotspot-container.js +0 -210
  163. package/dist/author/hotspot-drawable.d.ts +0 -31
  164. package/dist/author/hotspot-drawable.js +0 -312
  165. package/dist/author/hotspot-palette.d.ts +0 -14
  166. package/dist/author/hotspot-palette.js +0 -72
  167. package/dist/author/hotspot-polygon.d.ts +0 -38
  168. package/dist/author/hotspot-polygon.js +0 -200
  169. package/dist/author/hotspot-rectangle.d.ts +0 -20
  170. package/dist/author/hotspot-rectangle.js +0 -119
  171. package/dist/author/icons.d.ts +0 -9
  172. package/dist/author/icons.js +0 -4
  173. package/dist/author/image-konva.d.ts +0 -19
  174. package/dist/author/image-konva.js +0 -49
  175. package/dist/author/index.d.ts +0 -52
  176. package/dist/author/index.js +0 -143
  177. package/dist/author/root.d.ts +0 -15
  178. package/dist/author/root.js +0 -215
  179. package/dist/author/shapes/circle.d.ts +0 -18
  180. package/dist/author/shapes/circle.js +0 -47
  181. package/dist/author/shapes/index.d.ts +0 -12
  182. package/dist/author/shapes/polygon.d.ts +0 -19
  183. package/dist/author/shapes/polygon.js +0 -51
  184. package/dist/author/shapes/rectagle.d.ts +0 -18
  185. package/dist/author/shapes/rectagle.js +0 -57
  186. package/dist/author/shapes/utils.d.ts +0 -19
  187. package/dist/author/shapes/utils.js +0 -16
  188. package/dist/author/upload-control.d.ts +0 -29
  189. package/dist/author/upload-control.js +0 -28
  190. package/dist/author/utils.d.ts +0 -24
  191. package/dist/author/utils.js +0 -83
  192. package/dist/browser/ReactKonva-CFo7dxdy.js +0 -19336
  193. package/dist/browser/ReactKonva-CFo7dxdy.js.map +0 -1
  194. package/dist/browser/author/index.js +0 -47549
  195. package/dist/browser/author/index.js.map +0 -1
  196. package/dist/browser/browser-CfnAFove.js +0 -219
  197. package/dist/browser/browser-CfnAFove.js.map +0 -1
  198. package/dist/browser/controller/index.js +0 -198
  199. package/dist/browser/controller/index.js.map +0 -1
  200. package/dist/browser/delivery/index.js +0 -2460
  201. package/dist/browser/delivery/index.js.map +0 -1
  202. package/dist/browser/dist-CeB-1djc.js +0 -100
  203. package/dist/browser/dist-CeB-1djc.js.map +0 -1
  204. package/dist/browser/hotspot.css +0 -2
  205. package/dist/controller/defaults.d.ts +0 -35
  206. package/dist/controller/defaults.js +0 -29
  207. package/dist/controller/index.d.ts +0 -22
  208. package/dist/controller/index.js +0 -154
  209. package/dist/controller/utils.d.ts +0 -10
  210. package/dist/controller/utils.js +0 -12
  211. package/dist/delivery/hotspot/circle.d.ts +0 -19
  212. package/dist/delivery/hotspot/circle.js +0 -100
  213. package/dist/delivery/hotspot/container.d.ts +0 -16
  214. package/dist/delivery/hotspot/container.js +0 -150
  215. package/dist/delivery/hotspot/icons.d.ts +0 -10
  216. package/dist/delivery/hotspot/icons.js +0 -4
  217. package/dist/delivery/hotspot/image-konva-tooltip.d.ts +0 -19
  218. package/dist/delivery/hotspot/image-konva-tooltip.js +0 -66
  219. package/dist/delivery/hotspot/index.d.ts +0 -17
  220. package/dist/delivery/hotspot/index.js +0 -114
  221. package/dist/delivery/hotspot/polygon.d.ts +0 -21
  222. package/dist/delivery/hotspot/polygon.js +0 -108
  223. package/dist/delivery/hotspot/rectangle.d.ts +0 -19
  224. package/dist/delivery/hotspot/rectangle.js +0 -104
  225. package/dist/delivery/index.d.ts +0 -20
  226. package/dist/delivery/index.js +0 -107
  227. package/dist/delivery/session-updater.d.ts +0 -10
  228. package/dist/delivery/session-updater.js +0 -14
  229. package/dist/index.d.ts +0 -1
  230. package/dist/index.iife.d.ts +0 -8
  231. package/dist/index.iife.js +0 -169
  232. package/dist/index.js +0 -2
  233. package/dist/runtime-support.d.ts +0 -12
  234. package/dist/runtime-support.js +0 -12
@@ -1,35 +0,0 @@
1
- /**
2
- * @synced-from pie-elements/packages/hotspot/controller/src/defaults.js
3
- * @auto-generated
4
- *
5
- * This file is automatically synced from pie-elements and converted to TypeScript.
6
- * Manual edits will be overwritten on next sync.
7
- * To make changes, edit the upstream JavaScript file and run sync again.
8
- */
9
- declare const _default: {
10
- dimensions: {
11
- height: number;
12
- width: number;
13
- };
14
- hotspotColor: string;
15
- hotspotList: string[];
16
- imageUrl: string;
17
- multipleCorrect: boolean;
18
- outlineColor: string;
19
- outlineList: string[];
20
- partialScoring: boolean;
21
- prompt: string;
22
- promptEnabled: boolean;
23
- rationaleEnabled: boolean;
24
- shapes: {
25
- rectangles: never[];
26
- polygons: never[];
27
- circles: never[];
28
- };
29
- strokeWidth: number;
30
- studentInstructionsEnabled: boolean;
31
- teacherInstructions: string;
32
- teacherInstructionsEnabled: boolean;
33
- toolbarEditorPosition: string;
34
- };
35
- export default _default;
@@ -1,29 +0,0 @@
1
- //#region src/controller/defaults.ts
2
- var e = {
3
- dimensions: {
4
- height: 0,
5
- width: 0
6
- },
7
- hotspotColor: "rgba(137, 183, 244, 0.25)",
8
- hotspotList: ["rgba(137, 183, 244, 0.25)"],
9
- imageUrl: "",
10
- multipleCorrect: !0,
11
- outlineColor: "blue",
12
- outlineList: ["blue"],
13
- partialScoring: !1,
14
- prompt: "",
15
- promptEnabled: !0,
16
- rationaleEnabled: !0,
17
- shapes: {
18
- rectangles: [],
19
- polygons: [],
20
- circles: []
21
- },
22
- strokeWidth: 5,
23
- studentInstructionsEnabled: !0,
24
- teacherInstructions: "",
25
- teacherInstructionsEnabled: !0,
26
- toolbarEditorPosition: "bottom"
27
- };
28
- //#endregion
29
- export { e as default };
@@ -1,22 +0,0 @@
1
- /**
2
- * @synced-from pie-elements/packages/hotspot/controller/src/index.js
3
- * @auto-generated
4
- *
5
- * This file is automatically synced from pie-elements and converted to TypeScript.
6
- * Manual edits will be overwritten on next sync.
7
- * To make changes, edit the upstream JavaScript file and run sync again.
8
- */
9
- export declare const normalize: (question: any) => any;
10
- export declare function model(question: any, session: any, env: any): Promise<unknown>;
11
- export declare const createDefaultModel: (model?: {}) => Promise<unknown>;
12
- /**
13
- * Generates detailed trace log for scoring evaluation
14
- * @param {Object} model - the question model
15
- * @param {Object} session - the student session
16
- * @param {Object} env - the environment
17
- * @returns {Array} traceLog - array of trace messages
18
- */
19
- export declare const getLogTrace: (model: any, session: any, env: any) => string[];
20
- export declare function outcome(config: any, session: any, env?: {}): Promise<unknown>;
21
- export declare const createCorrectResponseSession: (question: any, env: any) => Promise<unknown>;
22
- export declare const validate: (model?: {}, config?: {}) => {};
@@ -1,154 +0,0 @@
1
- import { isResponseCorrect as e } from "./utils.js";
2
- import t from "./defaults.js";
3
- import n from "debug";
4
- import { isEmpty as r } from "@pie-element/shared-lodash";
5
- import { partialScoring as i } from "@pie-element/shared-controller-utils";
6
- //#region src/controller/index.ts
7
- var a = n("pie-elements:hotspot:controller"), o = (e) => ({
8
- ...t,
9
- ...e
10
- });
11
- function s(t, n, r) {
12
- let i = o(t), { imageUrl: a, dimensions: s, hotspotColor: c, hoverOutlineColor: l, selectedHotspotColor: u, multipleCorrect: d, outlineColor: f, partialScoring: p, prompt: m, shapes: h, language: g, fontSizeFactor: _, autoplayAudioEnabled: v, completeAudioEnabled: y, customAudioButton: b } = i, { rectangles: x, polygons: S, circles: C } = h || {}, w = r.mode === "evaluate" || r.role === "instructor" && r.mode === "view";
13
- return new Promise((t) => {
14
- let o = {
15
- disabled: r.mode !== "gather",
16
- mode: r.mode,
17
- dimensions: s,
18
- imageUrl: a,
19
- outlineColor: f,
20
- hotspotColor: c,
21
- hoverOutlineColor: l,
22
- selectedHotspotColor: u,
23
- multipleCorrect: d,
24
- partialScoring: p,
25
- language: g,
26
- fontSizeFactor: _,
27
- autoplayAudioEnabled: v,
28
- completeAudioEnabled: y,
29
- customAudioButton: b,
30
- shapes: {
31
- ...h,
32
- rectangles: (x || []).map(({ index: e, correct: t, ...n }) => w ? {
33
- correct: t,
34
- ...n
35
- } : { ...n }),
36
- polygons: (S || []).map(({ index: e, correct: t, ...n }) => w ? {
37
- correct: t,
38
- ...n
39
- } : { ...n }),
40
- circles: (C || []).map(({ index: e, correct: t, ...n }) => w ? {
41
- correct: t,
42
- ...n
43
- } : { ...n })
44
- },
45
- responseCorrect: r.mode === "evaluate" ? e(i, n) : void 0,
46
- extraCSSRules: i.extraCSSRules
47
- };
48
- r.role === "instructor" && (r.mode === "view" || r.mode === "evaluate") ? (o.rationale = i.rationaleEnabled ? i.rationale : null, o.teacherInstructions = i.teacherInstructionsEnabled ? i.teacherInstructions : null) : (o.rationale = null, o.teacherInstructions = null), o.prompt = i.promptEnabled ? m : null, o.strokeWidth = i.strokeWidth, t(o);
49
- });
50
- }
51
- var c = (e = {}) => new Promise((n) => {
52
- n({
53
- ...t,
54
- ...e
55
- });
56
- }), l = (t, n, r = {}) => {
57
- let { answers: a } = n || {};
58
- if (!t.shapes || !t.shapes.rectangles && !t.shapes.polygons && !t.shapes.circles) return 0;
59
- let { shapes: { rectangles: o = [], polygons: s = [], circles: c = [] } = {} } = t;
60
- if (!i.enabled(t, r)) return +!!e(t, n);
61
- let l = 0, u = 0, d = [
62
- ...o,
63
- ...s,
64
- ...c
65
- ], f = d.filter((e) => e.correct);
66
- d.forEach((e) => {
67
- let t = a && a.filter((t) => t.id === e.id)[0], n = e.correct && t;
68
- t && (u += 1), n && (l += 1);
69
- });
70
- let p = u > f.length ? u - f.length : 0, m = f.length === 0 ? 1 : f.length, h = ((l - p) / m).toFixed(2);
71
- return h < 0 ? 0 : parseFloat(h);
72
- }, u = (e, t, n) => {
73
- let r = [], { answers: a } = t || {}, { shapes: o } = e || {}, s = [];
74
- o && (o.rectangles && s.push(...o.rectangles), o.polygons && s.push(...o.polygons), o.circles && s.push(...o.circles));
75
- let c = s.filter((e) => e.correct), u = s.length;
76
- if (r.push(`Total of ${u} hotspot(s) defined, ${c.length} correct.`), a && a.length > 0) {
77
- r.push(`Student selected ${a.length} hotspot(s).`);
78
- let e = 0, t = 0;
79
- a.forEach((n) => {
80
- let r = s.find((e) => e.id === n.id);
81
- r && r.correct ? e++ : t++;
82
- });
83
- let n = c.filter((e) => !a.some((t) => t.id === e.id)).length;
84
- e > 0 && r.push(`${e} correct hotspot(s) selected.`), t > 0 && r.push(`${t} incorrect hotspot(s) selected.`), n > 0 && r.push(`${n} correct hotspot(s) missed.`);
85
- } else r.push("No hotspots selected.");
86
- if (i.enabled(e, n)) {
87
- if (r.push("Score calculated using partial scoring."), a && a.length > 0) {
88
- let e = 0, t = 0;
89
- a.forEach((n) => {
90
- let r = s.find((e) => e.id === n.id);
91
- r && r.correct ? e++ : t++;
92
- });
93
- let n = c.length;
94
- if (r.push(`Partial scoring calculation: ${e} correct selections out of ${n} available.`), t > n) {
95
- let i = t - (n - e);
96
- r.push(`${i} extra incorrect selection(s) beyond required amount are deducted from score.`);
97
- }
98
- }
99
- } else r.push("Score calculated using all-or-nothing scoring.");
100
- let d = l(e, t, n);
101
- return r.push(`Score: ${d}.`), r;
102
- };
103
- function d(e, t, n = {}) {
104
- return new Promise((i) => {
105
- if (a("outcome..."), (!t || r(t)) && i({
106
- score: 0,
107
- empty: !0,
108
- traceLog: ["No hotspots selected. Score: 0."]
109
- }), t.answers) {
110
- let r = u(e, t, n);
111
- i({
112
- score: l(e, t, n),
113
- empty: !1,
114
- traceLog: r
115
- });
116
- } else i({
117
- score: 0,
118
- empty: !0,
119
- traceLog: ["No hotspots selected. Score: 0."]
120
- });
121
- });
122
- }
123
- var f = (e) => {
124
- let t = [];
125
- return e.forEach((e) => {
126
- let { correct: n, id: r } = e;
127
- n && t.push({ id: r });
128
- }), t;
129
- }, p = (e, t) => new Promise((n) => {
130
- if (t.mode !== "evaluate" && t.role === "instructor") {
131
- let { shapes: { rectangles: t = [], circles: r = [], polygons: i = {} } = {} } = e, a = f(t), o = f(i), s = f(r);
132
- n({
133
- answers: [
134
- ...a,
135
- ...o,
136
- ...s
137
- ],
138
- id: "1"
139
- });
140
- } else n(null);
141
- }), m = (e) => (e || "").replace(/(<(?!img|iframe|source)([^>]+)>)/gi, ""), h = (e = {}, t = {}) => {
142
- let { shapes: n } = e, { minShapes: r = 2, maxShapes: i, maxSelections: a } = t, o = {};
143
- [
144
- "teacherInstructions",
145
- "prompt",
146
- "rationale"
147
- ].forEach((n) => {
148
- t[n]?.required && !m(e[n]) && (o[n] = "This field is required.");
149
- });
150
- let s = Object.values(n || {}).reduce((e, t) => [...e, ...t], []), c = (s || []).reduce((e, t) => t.correct ? e + 1 : e, 0), l = (s || []).length;
151
- return l < r ? o.shapes = `There should be at least ${r} shapes defined.` : l > i && (o.shapes = `No more than ${i} shapes should be defined.`), c < 1 ? o.selections = "There should be at least 1 shape selected." : c > a && (o.selections = `No more than ${a} shapes should be selected.`), o;
152
- };
153
- //#endregion
154
- export { p as createCorrectResponseSession, c as createDefaultModel, u as getLogTrace, s as model, o as normalize, d as outcome, h as validate };
@@ -1,10 +0,0 @@
1
- /**
2
- * @synced-from pie-elements/packages/hotspot/controller/src/utils.js
3
- * @auto-generated
4
- *
5
- * This file is automatically synced from pie-elements and converted to TypeScript.
6
- * Manual edits will be overwritten on next sync.
7
- * To make changes, edit the upstream JavaScript file and run sync again.
8
- */
9
- export declare const getCorrectResponse: (choices: any) => any;
10
- export declare const isResponseCorrect: (question: any, session: any) => boolean;
@@ -1,12 +0,0 @@
1
- import { isEmpty as e, isEqual as t } from "@pie-element/shared-lodash";
2
- //#region src/controller/utils.ts
3
- var n = (e) => e.filter((e) => e.correct).map((e) => e.id).sort(), r = (r, i) => {
4
- let { shapes: { rectangles: a = [], polygons: o = [], circles: s = [] } } = r, c = n([
5
- ...a,
6
- ...o,
7
- ...s
8
- ]);
9
- return !i || e(i) ? !1 : i.answers && i.answers.length ? t((i.answers || []).map((e) => e.id).sort(), c) : !(c && c.length);
10
- };
11
- //#endregion
12
- export { r as isResponseCorrect };
@@ -1,19 +0,0 @@
1
- /**
2
- * @synced-from pie-elements/packages/hotspot/src/hotspot/circle.jsx
3
- * @auto-generated
4
- *
5
- * This file is automatically synced from pie-elements and converted to TypeScript.
6
- * Manual edits will be overwritten on next sync.
7
- * To make changes, edit the upstream JavaScript file and run sync again.
8
- */
9
- import React from 'react';
10
- declare class CircleComponent extends React.Component {
11
- constructor(props: any);
12
- handleClick: any;
13
- handleMouseEnter: any;
14
- handleMouseLeave: any;
15
- getEvaluateOutlineColor: (isCorrect: any, markAsCorrect: any, outlineColor: any) => any;
16
- getOutlineWidth: (showCorrectEnabled: any, selected: any, markAsCorrect: any, strokeWidth: any) => any;
17
- render(): React.JSX.Element;
18
- }
19
- export default CircleComponent;
@@ -1,100 +0,0 @@
1
- import e from "./image-konva-tooltip.js";
2
- import { faCorrect as t, faWrong as n } from "./icons.js";
3
- import r from "react";
4
- import i from "prop-types";
5
- import { jsx as a, jsxs as o } from "react/jsx-runtime";
6
- import { Circle as s, Group as c, Rect as l } from "react-konva";
7
- //#region src/delivery/hotspot/circle.tsx
8
- function u(e) {
9
- return typeof e == "function" || typeof e == "object" && !!e && typeof e.$$typeof == "symbol";
10
- }
11
- function d(e, t) {
12
- return !e || u(e) ? e : u(e.default) ? e.default : t && u(e[t]) ? e[t] : t && u(e[t]?.default) ? e[t].default : e;
13
- }
14
- var f = d(l, "Rect"), p = d(c, "Group"), m = d(s, "Circle"), h = class extends r.Component {
15
- constructor(e) {
16
- super(e), this.state = { hovered: !1 };
17
- }
18
- handleClick = (e) => {
19
- let { onClick: t, id: n, selected: r, disabled: i } = this.props;
20
- i || (e.cancelBubble = !0, t({
21
- id: n,
22
- selected: !r,
23
- selector: "Mouse"
24
- }));
25
- };
26
- handleMouseEnter = () => {
27
- let { disabled: e } = this.props;
28
- e || (document.body.style.cursor = "pointer"), this.setState({ hovered: !0 });
29
- };
30
- handleMouseLeave = () => {
31
- document.body.style.cursor = "default", this.setState({ hovered: !1 });
32
- };
33
- getEvaluateOutlineColor = (e, t, n) => t ? "green" : e ? n : "red";
34
- getOutlineWidth = (e, t, n, r) => n || !n && !e && t ? r : 0;
35
- render() {
36
- let { radius: r, hotspotColor: i, isCorrect: s, isEvaluateMode: c, hoverOutlineColor: l, outlineColor: u, selected: d, x: h, y: g, evaluateText: _, strokeWidth: v, scale: y, markAsCorrect: b, selectedHotspotColor: x, showCorrectEnabled: S } = this.props, { hovered: C } = this.state, w = c ? this.getEvaluateOutlineColor(s, b, u) : u, T = this.getOutlineWidth(S, d, b, v), E = h - 10, D = g - 10, O;
37
- S ? (d && s || !d && !s) && (O = t) : d ? O = s ? t : n : s || (O = n);
38
- let k = C && l;
39
- return /* @__PURE__ */ o(p, {
40
- scaleX: y,
41
- scaleY: y,
42
- children: [
43
- k && /* @__PURE__ */ a(f, {
44
- x: h - r,
45
- y: g - r,
46
- width: r * 2,
47
- height: r * 2,
48
- stroke: d ? "transparent" : l,
49
- strokeWidth: v
50
- }),
51
- /* @__PURE__ */ a(m, {
52
- radius: r,
53
- fill: d && x ? x : i,
54
- onClick: this.handleClick,
55
- onTap: this.handleClick,
56
- draggable: !1,
57
- stroke: k && !d ? "transparent" : w,
58
- strokeWidth: k && !d ? 0 : T,
59
- onMouseLeave: this.handleMouseLeave,
60
- onMouseEnter: this.handleMouseEnter,
61
- x: h,
62
- y: g
63
- }),
64
- c && O ? /* @__PURE__ */ a(e, {
65
- src: O,
66
- x: E,
67
- y: D,
68
- tooltip: _
69
- }) : null
70
- ]
71
- });
72
- }
73
- };
74
- h.propTypes = {
75
- radius: i.number.isRequired,
76
- hotspotColor: i.string.isRequired,
77
- id: i.string.isRequired,
78
- isCorrect: i.oneOfType([i.bool, i.string]),
79
- isEvaluateMode: i.bool.isRequired,
80
- disabled: i.bool.isRequired,
81
- hoverOutlineColor: i.string,
82
- onClick: i.func.isRequired,
83
- outlineColor: i.string.isRequired,
84
- selected: i.bool.isRequired,
85
- x: i.number.isRequired,
86
- y: i.number.isRequired,
87
- evaluateText: i.string,
88
- strokeWidth: i.number,
89
- scale: i.number,
90
- selectedHotspotColor: i.string,
91
- markAsCorrect: i.bool.isRequired,
92
- showCorrectEnabled: i.bool.isRequired
93
- }, h.defaultProps = {
94
- isCorrect: !1,
95
- evaluateText: null,
96
- strokeWidth: 5,
97
- scale: 1
98
- };
99
- //#endregion
100
- export { h as default };
@@ -1,16 +0,0 @@
1
- /**
2
- * @synced-from pie-elements/packages/hotspot/src/hotspot/container.jsx
3
- * @auto-generated
4
- *
5
- * This file is automatically synced from pie-elements and converted to TypeScript.
6
- * Manual edits will be overwritten on next sync.
7
- * To make changes, edit the upstream JavaScript file and run sync again.
8
- */
9
- import React from 'react';
10
- export declare class Container extends React.Component {
11
- isSelected(shape: any): boolean;
12
- correctness: (isCorrect: any, isChecked: any) => any;
13
- getEvaluateText: any;
14
- render(): React.JSX.Element;
15
- }
16
- export default Container;
@@ -1,150 +0,0 @@
1
- import e from "./rectangle.js";
2
- import t from "./polygon.js";
3
- import n from "./circle.js";
4
- import r from "react";
5
- import i from "prop-types";
6
- import { jsx as a, jsxs as o } from "react/jsx-runtime";
7
- import { styled as s } from "@mui/material/styles";
8
- import { Layer as c, Stage as l } from "react-konva";
9
- //#region src/delivery/hotspot/container.tsx
10
- function u(e) {
11
- return typeof e == "function" || typeof e == "object" && !!e && typeof e.$$typeof == "symbol";
12
- }
13
- function d(e, t) {
14
- return !e || u(e) ? e : u(e.default) ? e.default : t && u(e[t]) ? e[t] : t && u(e[t]?.default) ? e[t].default : e;
15
- }
16
- var f = d(l, "Stage"), p = d(c, "Layer"), m = s("div")(({ theme: e }) => ({
17
- marginTop: e.spacing(2),
18
- marginBottom: e.spacing(2),
19
- position: "relative",
20
- background: e.palette.common.white,
21
- border: `${e.spacing(1)} solid ${e.palette.common.white}`,
22
- width: "fit-content"
23
- })), h = s("div")({
24
- position: "relative",
25
- width: "fit-content"
26
- }), g = s("img")({
27
- alignItems: "center",
28
- display: "flex",
29
- justifyContent: "center"
30
- }), _ = s(f)({
31
- left: 0,
32
- top: 0,
33
- position: "absolute"
34
- }), v = class extends r.Component {
35
- isSelected(e) {
36
- return !!this.props.session.answers.filter((t) => t.id === e.id)[0];
37
- }
38
- correctness = (e, t) => e ? t : !t;
39
- getEvaluateText = (e, t) => t && e ? "Correctly\nselected" : t && !e ? "Should not have\nbeen selected" : !t && e ? "Should have\nbeen selected" : null;
40
- render() {
41
- let { dimensions: { width: r, height: i }, disabled: s, hotspotColor: c, hoverOutlineColor: l, selectedHotspotColor: u, imageUrl: d, isEvaluateMode: f, outlineColor: v, onSelectChoice: y, shapes: { rectangles: b = [], polygons: x = [], circles: S = [] }, scale: C, strokeWidth: w, showCorrect: T } = this.props, E = r * C, D = i * C;
42
- return /* @__PURE__ */ o(m, {
43
- style: { padding: w / 2 },
44
- children: [d ? /* @__PURE__ */ a(h, { children: /* @__PURE__ */ a(g, {
45
- alt: "hotspot-image",
46
- height: "auto",
47
- src: d,
48
- style: {
49
- width: E,
50
- height: D,
51
- maxWidth: E,
52
- maxHeight: D
53
- }
54
- }) }) : null, /* @__PURE__ */ a(_, {
55
- height: D + w,
56
- width: E + w,
57
- x: w / 2,
58
- y: w / 2,
59
- children: /* @__PURE__ */ o(p, { children: [
60
- b.map((t) => {
61
- let n = this.isSelected(t), r = f ? this.correctness(t.correct, n) : void 0, i = f ? this.getEvaluateText(t.correct, n) : null, o = !!(f && T && t.correct);
62
- return /* @__PURE__ */ a(e, {
63
- scale: C,
64
- isEvaluateMode: f,
65
- isCorrect: r,
66
- evaluateText: i,
67
- disabled: s,
68
- selected: n,
69
- height: t.height,
70
- hotspotColor: c,
71
- hoverOutlineColor: l,
72
- selectedHotspotColor: u,
73
- id: t.id,
74
- onClick: y,
75
- outlineColor: v,
76
- width: t.width,
77
- x: t.x,
78
- y: t.y,
79
- strokeWidth: w,
80
- markAsCorrect: o,
81
- showCorrectEnabled: T
82
- }, t.id);
83
- }),
84
- x.map((e) => {
85
- let n = this.isSelected(e), r = f ? this.correctness(e.correct, n) : void 0, i = f ? this.getEvaluateText(e.correct, n) : null, o = !!(f && T && e.correct);
86
- return /* @__PURE__ */ a(t, {
87
- scale: C,
88
- isEvaluateMode: f,
89
- isCorrect: !!r,
90
- evaluateText: i,
91
- disabled: s,
92
- selected: n,
93
- hotspotColor: c,
94
- id: e.id,
95
- onClick: y,
96
- outlineColor: v,
97
- points: e.points,
98
- strokeWidth: w,
99
- markAsCorrect: o,
100
- selectedHotspotColor: u,
101
- hoverOutlineColor: l,
102
- showCorrectEnabled: T
103
- }, e.id);
104
- }),
105
- S.map((e) => {
106
- let t = this.isSelected(e), r = f ? this.correctness(e.correct, t) : void 0, i = f ? this.getEvaluateText(e.correct, t) : null, o = !!(f && T && e.correct);
107
- return /* @__PURE__ */ a(n, {
108
- scale: C,
109
- isEvaluateMode: f,
110
- isCorrect: r,
111
- evaluateText: i,
112
- disabled: s,
113
- selected: t,
114
- radius: e.radius,
115
- hotspotColor: c,
116
- id: e.id,
117
- onClick: y,
118
- outlineColor: v,
119
- x: e.x,
120
- y: e.y,
121
- strokeWidth: w,
122
- markAsCorrect: o,
123
- selectedHotspotColor: u,
124
- hoverOutlineColor: l,
125
- showCorrectEnabled: T
126
- }, e.id);
127
- })
128
- ] })
129
- })]
130
- });
131
- }
132
- };
133
- v.propTypes = {
134
- dimensions: i.object.isRequired,
135
- disabled: i.bool.isRequired,
136
- hotspotColor: i.string.isRequired,
137
- hoverOutlineColor: i.string,
138
- imageUrl: i.string.isRequired,
139
- isEvaluateMode: i.bool.isRequired,
140
- onSelectChoice: i.func.isRequired,
141
- outlineColor: i.string.isRequired,
142
- selectedHotspotColor: i.string,
143
- session: i.object.isRequired,
144
- shapes: i.object.isRequired,
145
- strokeWidth: i.number,
146
- scale: i.number,
147
- showCorrect: i.bool
148
- }, v.defaultProps = { scale: 1 };
149
- //#endregion
150
- export { v as default };