@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
@@ -0,0 +1,52 @@
1
+ /**
2
+ * @synced-from pie-elements/packages/hotspot/configure/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 default class HotspotConfigure extends HTMLElement {
10
+ static createDefaultModel: (model?: {}) => {
11
+ hotspotList: any;
12
+ outlineList: any;
13
+ shapes: any;
14
+ dimensions: {
15
+ height: number;
16
+ width: number;
17
+ };
18
+ hotspotColor: string;
19
+ imageUrl: string;
20
+ multipleCorrect: boolean;
21
+ outlineColor: string;
22
+ partialScoring: boolean;
23
+ prompt: string;
24
+ promptEnabled: boolean;
25
+ rationaleEnabled: boolean;
26
+ strokeWidth: number;
27
+ studentInstructionsEnabled: boolean;
28
+ teacherInstructions: string;
29
+ teacherInstructionsEnabled: boolean;
30
+ toolbarEditorPosition: string;
31
+ };
32
+ constructor();
33
+ set model(s: any);
34
+ set configuration(c: any);
35
+ dispatchModelUpdated(reset: any): void;
36
+ onModelChanged(m: any, reset: any): void;
37
+ onConfigurationChanged: any;
38
+ onModelChangedByConfig: any;
39
+ onColorChanged: any;
40
+ onPromptChanged: any;
41
+ onRationaleChanged: any;
42
+ onTeacherInstructionsChanged: any;
43
+ onUpdateImageDimension: any;
44
+ onUpdateShapes: any;
45
+ onImageUpload: any;
46
+ insertImage: any;
47
+ onDeleteImage: any;
48
+ insertSound(handler: any): void;
49
+ onDeleteSound(src: any, done: any): void;
50
+ _render(): void;
51
+ disconnectedCallback(): void;
52
+ }
@@ -0,0 +1,143 @@
1
+ import e from "./root.js";
2
+ import t from "./defaults.js";
3
+ import n from "react";
4
+ import { createRoot as r } from "react-dom/client";
5
+ import i from "debug";
6
+ import { DeleteImageEvent as a, DeleteSoundEvent as o, InsertImageEvent as s, InsertSoundEvent as c, ModelUpdatedEvent as l } from "@pie-element/shared-configure-events";
7
+ //#region src/author/index.ts
8
+ var u = i("hotspot:configure"), d = class i extends HTMLElement {
9
+ static createDefaultModel = (e = {}) => ({
10
+ ...t.model,
11
+ ...e,
12
+ hotspotList: e.hotspotList || [e.hotspotColor],
13
+ outlineList: e.outlineList || [e.outlineColor],
14
+ shapes: e.shapes || t.model.shapes || {}
15
+ });
16
+ constructor() {
17
+ super(), this._root = null, this._model = i.createDefaultModel(), this._configuration = t.configuration, this.onModelChanged = this.onModelChanged.bind(this);
18
+ }
19
+ set model(e) {
20
+ this._model = i.createDefaultModel(e), this._render();
21
+ }
22
+ set configuration(e) {
23
+ let n = {
24
+ ...t.configuration,
25
+ ...e
26
+ };
27
+ this._configuration = n, n?.language?.enabled ? n?.languageChoices?.options?.length && (this._model.language = n?.languageChoices.options[0].value) : n.language.settings && this._model.language ? (this._configuration.language.enabled = !0, (!this._configuration.languageChoices.options || !this._configuration.languageChoices.options.length) && (this._configuration.languageChoices.options = []), this._configuration.languageChoices.options.find((e) => e.value === this._model.language) || this._configuration.languageChoices.options.push({
28
+ value: this._model.language,
29
+ label: this._model.language
30
+ })) : delete this._model.language, this._render();
31
+ }
32
+ dispatchModelUpdated(e) {
33
+ let t = !!e;
34
+ this.dispatchEvent(new l(this._model, t));
35
+ }
36
+ onModelChanged(e, t) {
37
+ this._model = e, this.dispatchModelUpdated(t), this._render();
38
+ }
39
+ onConfigurationChanged = (e) => {
40
+ this._configuration = e, this._render();
41
+ };
42
+ onModelChangedByConfig = (e, t) => {
43
+ let n = e;
44
+ if (t === "multipleCorrect") {
45
+ let { rectangles: e = [], polygons: t = [], circles: r = [] } = n.shapes || {};
46
+ n.shapes.rectangles = e.map((e) => ({
47
+ ...e,
48
+ correct: !1
49
+ })), n.shapes.polygons = t.map((e) => ({
50
+ ...e,
51
+ correct: !1
52
+ })), n.shapes.circles = r.map((e) => ({
53
+ ...e,
54
+ correct: !1
55
+ }));
56
+ }
57
+ this.onModelChanged(n);
58
+ };
59
+ onColorChanged = (e, t) => {
60
+ this.onModelChanged({
61
+ ...this._model,
62
+ [e]: t
63
+ });
64
+ };
65
+ onPromptChanged = (e) => {
66
+ this.onModelChanged({
67
+ ...this._model,
68
+ prompt: e
69
+ });
70
+ };
71
+ onRationaleChanged = (e) => {
72
+ this.onModelChanged({
73
+ ...this._model,
74
+ rationale: e
75
+ });
76
+ };
77
+ onTeacherInstructionsChanged = (e) => {
78
+ this.onModelChanged({
79
+ ...this._model,
80
+ teacherInstructions: e
81
+ });
82
+ };
83
+ onUpdateImageDimension = (e) => {
84
+ this.onModelChanged({
85
+ ...this._model,
86
+ dimensions: e
87
+ });
88
+ };
89
+ onUpdateShapes = (e) => {
90
+ this.onModelChanged({
91
+ ...this._model,
92
+ shapes: e
93
+ });
94
+ };
95
+ onImageUpload = (e) => {
96
+ this.onModelChanged({
97
+ ...this._model,
98
+ imageUrl: e
99
+ });
100
+ };
101
+ insertImage = (e) => {
102
+ this.dispatchEvent(new s(e));
103
+ };
104
+ onDeleteImage = (e, t) => {
105
+ this.dispatchEvent(new a(e, t));
106
+ };
107
+ insertSound(e) {
108
+ this.dispatchEvent(new c(e));
109
+ }
110
+ onDeleteSound(e, t) {
111
+ this.dispatchEvent(new o(e, t));
112
+ }
113
+ _render() {
114
+ u("_render");
115
+ let t = n.createElement(e, {
116
+ configuration: this._configuration,
117
+ model: this._model,
118
+ onColorChanged: this.onColorChanged,
119
+ onImageUpload: this.onImageUpload,
120
+ onRationaleChanged: this.onRationaleChanged,
121
+ onConfigurationChanged: this.onConfigurationChanged,
122
+ onPromptChanged: this.onPromptChanged,
123
+ onUpdateImageDimension: this.onUpdateImageDimension,
124
+ imageSupport: {
125
+ add: this.insertImage,
126
+ delete: this.onDeleteImage
127
+ },
128
+ uploadSoundSupport: {
129
+ add: this.insertSound.bind(this),
130
+ delete: this.onDeleteSound.bind(this)
131
+ },
132
+ onUpdateShapes: this.onUpdateShapes,
133
+ onModelChangedByConfig: this.onModelChangedByConfig,
134
+ onTeacherInstructionsChanged: this.onTeacherInstructionsChanged
135
+ });
136
+ this._root ||= r(this), this._root.render(t);
137
+ }
138
+ disconnectedCallback() {
139
+ this._root && this._root.unmount();
140
+ }
141
+ };
142
+ //#endregion
143
+ export { d as default };
@@ -0,0 +1,15 @@
1
+ /**
2
+ * @synced-from pie-elements/packages/hotspot/configure/src/root.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 Root extends React.Component {
11
+ handleColorChange: any;
12
+ handleOnUpdateImageDimensions: any;
13
+ render(): React.JSX.Element;
14
+ }
15
+ export default Root;
@@ -0,0 +1,215 @@
1
+ import e from "./hotspot-palette.js";
2
+ import { generateValidationMessage as t, getAllShapes as n, getUpdatedShapes as r, groupShapes as i, updateImageDimensions as a } from "./utils.js";
3
+ import o from "./hotspot-container.js";
4
+ import s from "react";
5
+ import c from "prop-types";
6
+ import { jsx as l, jsxs as u } from "react/jsx-runtime";
7
+ import { styled as d } from "@mui/material/styles";
8
+ import { InputContainer as f, NumberTextField as p, layout as m, settings as h } from "@pie-lib/config-ui";
9
+ import g from "@pie-lib/editable-html-tip-tap";
10
+ import _ from "@mui/material/Typography";
11
+ import v from "@mui/icons-material/Info";
12
+ import y from "@mui/material/Tooltip";
13
+ //#region src/author/root.tsx
14
+ var { Panel: ee, toggle: b, dropdown: te } = h, ne = d("div")(({ theme: e }) => ({
15
+ display: "flex",
16
+ marginBottom: e.spacing(1.5)
17
+ })), x = d("div")({
18
+ flex: 1,
19
+ width: "90%"
20
+ }), S = d(f)(({ theme: e }) => ({
21
+ paddingTop: e.spacing(1),
22
+ marginTop: e.spacing(2),
23
+ marginBottom: e.spacing(2),
24
+ width: "100%"
25
+ })), C = d(_)(({ theme: e }) => ({ marginRight: e.spacing(1) })), re = d("div")({
26
+ display: "flex",
27
+ alignItems: "center"
28
+ }), ie = d(y)(({ theme: e }) => ({ "& .MuiTooltip-tooltip": {
29
+ fontSize: e.typography.fontSize - 2,
30
+ whiteSpace: "pre",
31
+ maxWidth: "500px"
32
+ } })), w = d("div")(({ theme: e }) => ({
33
+ fontSize: e.typography.fontSize - 2,
34
+ color: e.palette.error.main,
35
+ paddingTop: e.spacing(1)
36
+ })), T = class extends s.Component {
37
+ handleColorChange = (e, t) => {
38
+ let { onColorChanged: n } = this.props;
39
+ n(`${e}Color`, t);
40
+ };
41
+ handleOnUpdateImageDimensions = (e, t) => {
42
+ let { model: { dimensions: o, shapes: s }, configuration: { preserveAspectRatio: c = {} }, onUpdateImageDimension: l, onUpdateShapes: u } = this.props, d = a(o, {
43
+ ...o,
44
+ [t]: e
45
+ }, c.enabled, t);
46
+ u(i(r(o, d, n(s)))), l(d);
47
+ };
48
+ render() {
49
+ let { configuration: n, model: r, imageSupport: i, uploadSoundSupport: a, onConfigurationChanged: c, onImageUpload: d, onModelChangedByConfig: f, onPromptChanged: h, onRationaleChanged: y, onUpdateImageDimension: T, onTeacherInstructionsChanged: ae, onUpdateShapes: E } = this.props, { baseInputConfiguration: oe = {}, contentDimensions: se = {}, maxImageWidth: D = {}, maxImageHeight: O = {}, multipleCorrect: k = {}, partialScoring: A = {}, preserveAspectRatio: j = {}, prompt: M = {}, rationale: N = {}, settingsPanelDisabled: ce, spellCheck: P = {}, teacherInstructions: F = {}, withRubric: I = {}, mathMlOptions: L = {}, language: R = {}, languageChoices: z = {} } = n || {}, { errors: B, extraCSSRules: V, promptEnabled: H, rationaleEnabled: U, spellCheckEnabled: W, teacherInstructionsEnabled: le, toolbarEditorPosition: ue } = r || {}, { prompt: G, rationale: K, shapes: q, selections: J, teacherInstructions: Y } = B || {}, de = t(n), X = D && D.prompt, Z = O && O.prompt, Q = { position: ue === "top" ? "top" : "bottom" }, fe = {
50
+ multipleCorrect: k.settings && b(k.label),
51
+ partialScoring: A.settings && b(A.label),
52
+ promptEnabled: M.settings && b(M.label),
53
+ "language.enabled": R.settings && b(R.label, !0),
54
+ language: R.settings && R.enabled && te(z.label, z.options)
55
+ }, pe = {
56
+ teacherInstructionsEnabled: F.settings && b(F.label),
57
+ rationaleEnabled: N.settings && b(N.label),
58
+ spellCheckEnabled: P.settings && b(P.label),
59
+ rubricEnabled: I?.settings && b(I?.label)
60
+ }, $ = (e = {}) => ({
61
+ ...oe,
62
+ ...e
63
+ });
64
+ return /* @__PURE__ */ u(m.ConfigLayout, {
65
+ extraCSSRules: V,
66
+ dimensions: se,
67
+ hideSettings: ce,
68
+ settings: /* @__PURE__ */ l(ee, {
69
+ model: r,
70
+ onChangeModel: f,
71
+ configuration: n,
72
+ onChangeConfiguration: c,
73
+ groups: {
74
+ Settings: fe,
75
+ Properties: pe
76
+ }
77
+ }),
78
+ children: [
79
+ le && /* @__PURE__ */ u(S, {
80
+ label: F.label,
81
+ children: [/* @__PURE__ */ l(g, {
82
+ markup: r.teacherInstructions || "",
83
+ onChange: ae,
84
+ imageSupport: i,
85
+ nonEmpty: !1,
86
+ error: Y,
87
+ toolbarOpts: Q,
88
+ pluginProps: $(F?.inputConfiguration),
89
+ spellCheck: W,
90
+ maxImageWidth: D && D.teacherInstructions || X,
91
+ maxImageHeight: O && O.teacherInstructions || Z,
92
+ uploadSoundSupport: a,
93
+ languageCharactersProps: [{ language: "spanish" }, { language: "special" }],
94
+ mathMlOptions: L
95
+ }), Y && /* @__PURE__ */ l(w, { children: Y })]
96
+ }),
97
+ H && /* @__PURE__ */ u(S, {
98
+ label: M.label,
99
+ children: [/* @__PURE__ */ l(g, {
100
+ markup: r.prompt || "",
101
+ onChange: h,
102
+ imageSupport: i,
103
+ nonEmpty: !1,
104
+ error: G,
105
+ toolbarOpts: Q,
106
+ pluginProps: $(M?.inputConfiguration),
107
+ spellCheck: W,
108
+ maxImageWidth: X,
109
+ maxImageHeight: Z,
110
+ uploadSoundSupport: a,
111
+ languageCharactersProps: [{ language: "spanish" }, { language: "special" }],
112
+ mathMlOptions: L
113
+ }), G && /* @__PURE__ */ l(w, { children: G })]
114
+ }),
115
+ /* @__PURE__ */ u(re, { children: [/* @__PURE__ */ l(C, {
116
+ variant: "h6",
117
+ children: "Define Hotspot"
118
+ }), /* @__PURE__ */ l(ie, {
119
+ disableFocusListener: !0,
120
+ disableTouchListener: !0,
121
+ placement: "left",
122
+ title: de,
123
+ children: /* @__PURE__ */ l(v, {
124
+ fontSize: "small",
125
+ color: "primary",
126
+ style: { float: "right" }
127
+ })
128
+ })] }),
129
+ /* @__PURE__ */ l(e, {
130
+ hotspotColor: r.hotspotColor,
131
+ hotspotList: r.hotspotList,
132
+ outlineColor: r.outlineColor,
133
+ outlineList: r.outlineList,
134
+ onHotspotColorChange: (e) => this.handleColorChange("hotspot", e),
135
+ onOutlineColorChange: (e) => this.handleColorChange("outline", e)
136
+ }),
137
+ /* @__PURE__ */ l(o, {
138
+ dimensions: r.dimensions,
139
+ imageUrl: r.imageUrl,
140
+ multipleCorrect: r.multipleCorrect,
141
+ hasErrors: !!q || !!J,
142
+ hotspotColor: r.hotspotColor,
143
+ outlineColor: r.outlineColor,
144
+ selectedHotspotColor: r.selectedHotspotColor,
145
+ hoverOutlineColor: r.hoverOutlineColor,
146
+ onUpdateImageDimension: T,
147
+ onUpdateShapes: E,
148
+ onImageUpload: d,
149
+ shapes: r.shapes,
150
+ strokeWidth: r.strokeWidth,
151
+ preserveAspectRatioEnabled: j.enabled,
152
+ insertImage: i && i.add
153
+ }),
154
+ q && /* @__PURE__ */ l(w, { children: q }),
155
+ J && /* @__PURE__ */ l(w, { children: J }),
156
+ r.imageUrl && /* @__PURE__ */ u(s.Fragment, { children: [/* @__PURE__ */ l(_, {
157
+ variant: "h6",
158
+ children: "Image Dimensions"
159
+ }), /* @__PURE__ */ u(ne, { children: [/* @__PURE__ */ l(x, { children: /* @__PURE__ */ l(p, {
160
+ label: "Width",
161
+ value: r.dimensions.width,
162
+ min: 0,
163
+ onChange: (e, t) => this.handleOnUpdateImageDimensions(t, "width"),
164
+ showErrorWhenOutsideRange: !0
165
+ }, "hotspot-manual-width") }), /* @__PURE__ */ l(x, { children: /* @__PURE__ */ l(p, {
166
+ label: "Height",
167
+ value: r.dimensions.height,
168
+ min: 0,
169
+ onChange: (e, t) => this.handleOnUpdateImageDimensions(t, "height"),
170
+ showErrorWhenOutsideRange: !0
171
+ }, "hotspot-manual-height") })] })] }),
172
+ U && /* @__PURE__ */ u(S, {
173
+ label: N.label,
174
+ children: [/* @__PURE__ */ l(g, {
175
+ markup: r.rationale || "",
176
+ onChange: y,
177
+ imageSupport: i,
178
+ error: K,
179
+ toolbarOpts: Q,
180
+ pluginProps: $(N?.inputConfiguration),
181
+ spellCheck: W,
182
+ maxImageWidth: D && D.rationale || X,
183
+ maxImageHeight: O && O.rationale || Z,
184
+ uploadSoundSupport: a,
185
+ languageCharactersProps: [{ language: "spanish" }, { language: "special" }],
186
+ mathMlOptions: L
187
+ }), K && /* @__PURE__ */ l(w, { children: K })]
188
+ })
189
+ ]
190
+ });
191
+ }
192
+ };
193
+ T.propTypes = {
194
+ configuration: c.object,
195
+ model: c.object.isRequired,
196
+ imageSupport: c.shape({
197
+ add: c.func,
198
+ delete: c.func
199
+ }),
200
+ uploadSoundSupport: c.shape({
201
+ add: c.func,
202
+ delete: c.func
203
+ }),
204
+ onImageUpload: c.func.isRequired,
205
+ onColorChanged: c.func.isRequired,
206
+ onPromptChanged: c.func.isRequired,
207
+ onUpdateImageDimension: c.func.isRequired,
208
+ onUpdateShapes: c.func.isRequired,
209
+ onModelChangedByConfig: c.func.isRequired,
210
+ onRationaleChanged: c.func.isRequired,
211
+ onConfigurationChanged: c.func.isRequired,
212
+ onTeacherInstructionsChanged: c.func.isRequired
213
+ };
214
+ //#endregion
215
+ export { T as default };
@@ -0,0 +1,18 @@
1
+ /**
2
+ * @synced-from pie-elements/packages/hotspot/configure/src/shapes/circle.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 class CircleShape {
10
+ static name: string;
11
+ static create(shapes: any, e: any): {
12
+ shapes: any[];
13
+ isDrawing: boolean;
14
+ isDrawingShapeId: string;
15
+ };
16
+ static finalizeCreation(state: any, props: any): any;
17
+ static handleMouseMove(state: any, e: any): any;
18
+ }
@@ -0,0 +1,47 @@
1
+ //#region src/author/shapes/circle.ts
2
+ var e = class {
3
+ static name = "circle";
4
+ static create(e, t) {
5
+ let n = [...e], r = {
6
+ id: `${Math.max(...n.map((e) => parseInt(e.id)), 0) + 1}`,
7
+ radius: 0,
8
+ x: t.evt.layerX,
9
+ y: t.evt.layerY,
10
+ group: "circles",
11
+ index: n.length
12
+ };
13
+ return n.push(r), {
14
+ shapes: n,
15
+ isDrawing: !0,
16
+ isDrawingShapeId: r.id
17
+ };
18
+ }
19
+ static finalizeCreation(e, t) {
20
+ let n = e.shapes.findIndex((t) => t.id === e.isDrawingShapeId);
21
+ return n === -1 || e.shapes[n].radius > 0 ? {
22
+ ...e,
23
+ isDrawing: !1,
24
+ stateShapes: !1,
25
+ isDrawingShapeId: void 0
26
+ } : {
27
+ ...e,
28
+ isDrawing: !1,
29
+ stateShapes: !1,
30
+ isDrawingShapeId: void 0,
31
+ shapes: e.shapes.filter((t) => t.id !== e.isDrawingShapeId)
32
+ };
33
+ }
34
+ static handleMouseMove(e, t) {
35
+ let { isDrawing: n, isDrawingShapeId: r, shapes: i } = e;
36
+ if (n) {
37
+ let e = [...i], n = e.findIndex((e) => e.id === r);
38
+ if (n !== -1) {
39
+ let r = e[n], i = t.evt.layerX - r.x, a = t.evt.layerY - r.y;
40
+ return r.radius = Math.sqrt(i * i + a * a), { shapes: e };
41
+ }
42
+ }
43
+ return e;
44
+ }
45
+ };
46
+ //#endregion
47
+ export { e as CircleShape };
@@ -0,0 +1,12 @@
1
+ /**
2
+ * @synced-from pie-elements/packages/hotspot/configure/src/shapes/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 * from './circle.js';
10
+ export * from './rectagle.js';
11
+ export * from './polygon.js';
12
+ export * from './utils.js';
@@ -0,0 +1,19 @@
1
+ /**
2
+ * @synced-from pie-elements/packages/hotspot/configure/src/shapes/polygon.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 class PolygonShape {
10
+ static name: string;
11
+ static create(shapes: any, e: any): {
12
+ shapes: any[];
13
+ isDrawing: boolean;
14
+ isDrawingShapeId: string;
15
+ };
16
+ static addPoint(state: any, e: any, onPolygonComplete: any): any;
17
+ static finalizeCreation(state: any, onPolygonComplete: any): any;
18
+ static handleMouseMove(state: any, e: any): any;
19
+ }
@@ -0,0 +1,51 @@
1
+ //#region src/author/shapes/polygon.ts
2
+ var e = class e {
3
+ static name = "polygon";
4
+ static create(e, t) {
5
+ let n = [...e], r = {
6
+ id: "newPolygon",
7
+ points: [{
8
+ x: t.evt.layerX,
9
+ y: t.evt.layerY
10
+ }],
11
+ group: "polygons",
12
+ index: n.length
13
+ };
14
+ return n.push(r), {
15
+ shapes: n,
16
+ isDrawing: !0,
17
+ isDrawingShapeId: r.id
18
+ };
19
+ }
20
+ static addPoint(t, n, r) {
21
+ let i = JSON.parse(JSON.stringify(t.shapes)), a = i.findIndex((e) => e.id === t.isDrawingShapeId);
22
+ if (a !== -1) {
23
+ let o = i[a];
24
+ if (o.points && Array.isArray(o.points)) {
25
+ let s = o.points[0];
26
+ return Math.abs(s.x - n.evt.layerX) <= 5 && Math.abs(s.y - n.evt.layerY) <= 5 ? e.finalizeCreation(t, r) : (o.points.push({
27
+ x: n.evt.layerX,
28
+ y: n.evt.layerY
29
+ }), i[a] = o, { shapes: i });
30
+ }
31
+ }
32
+ return t;
33
+ }
34
+ static finalizeCreation(e, t) {
35
+ let { shapes: n } = e, r = [...n], i = Math.max(...e.shapes.map((e) => parseInt(e.id) || 0), 0), a = r.findIndex((t) => t.id === e.isDrawingShapeId);
36
+ if (a !== -1 && r[a].points.length > 2) {
37
+ let e = r[a];
38
+ return e.id = `${i + 1}`, t(r), {
39
+ isDrawing: !1,
40
+ shapes: r,
41
+ isDrawingShapeId: void 0
42
+ };
43
+ }
44
+ return e;
45
+ }
46
+ static handleMouseMove(e, t) {
47
+ return e;
48
+ }
49
+ };
50
+ //#endregion
51
+ export { e as PolygonShape };
@@ -0,0 +1,18 @@
1
+ /**
2
+ * @synced-from pie-elements/packages/hotspot/configure/src/shapes/rectagle.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 class RectangleShape {
10
+ static name: string;
11
+ static create(shapes: any, e: any): {
12
+ shapes: any[];
13
+ isDrawing: boolean;
14
+ isDrawingShapeId: string;
15
+ };
16
+ static finalizeCreation(state: any, props: any): any;
17
+ static handleMouseMove(state: any, e: any): any;
18
+ }
@@ -0,0 +1,57 @@
1
+ //#region src/author/shapes/rectagle.ts
2
+ var e = class {
3
+ static name = "rectangle";
4
+ static create(e, t) {
5
+ let n = [...e], r = {
6
+ id: `${(Math.max(...n.map((e) => parseInt(e.id)), 0) || 0) + 1}`,
7
+ height: 0,
8
+ width: 0,
9
+ x: t.evt.layerX,
10
+ y: t.evt.layerY,
11
+ group: "rectangles",
12
+ index: n.length
13
+ };
14
+ return n.push(r), {
15
+ shapes: n,
16
+ isDrawing: !0,
17
+ isDrawingShapeId: r.id
18
+ };
19
+ }
20
+ static finalizeCreation(e, t) {
21
+ let n = e.shapes.findIndex((t) => t.id === e.isDrawingShapeId);
22
+ if (n !== -1) {
23
+ let t = e.shapes[n];
24
+ return t.width > 0 && t.height > 0 ? {
25
+ ...e,
26
+ isDrawing: !1,
27
+ stateShapes: !1,
28
+ isDrawingShapeId: void 0
29
+ } : {
30
+ ...e,
31
+ isDrawing: !1,
32
+ stateShapes: !1,
33
+ isDrawingShapeId: void 0,
34
+ shapes: e.shapes.filter((t) => t.id !== e.isDrawingShapeId)
35
+ };
36
+ }
37
+ return {
38
+ ...e,
39
+ isDrawing: !1,
40
+ stateShapes: !1,
41
+ isDrawingShapeId: void 0
42
+ };
43
+ }
44
+ static handleMouseMove(e, t) {
45
+ let { isDrawing: n, isDrawingShapeId: r, shapes: i } = e;
46
+ if (n) {
47
+ let e = [...i], n = e.findIndex((e) => e.id === r);
48
+ if (n !== -1) {
49
+ let r = e[n];
50
+ return r.width = t.evt.layerX - r.x, r.height = t.evt.layerY - r.y, { shapes: e };
51
+ }
52
+ }
53
+ return e;
54
+ }
55
+ };
56
+ //#endregion
57
+ export { e as RectangleShape };
@@ -0,0 +1,19 @@
1
+ /**
2
+ * @synced-from pie-elements/packages/hotspot/configure/src/shapes/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 SUPPORTED_SHAPES: {
10
+ CIRCLE: string;
11
+ POLYGON: string;
12
+ RECTANGLE: string;
13
+ NONE: string;
14
+ };
15
+ export declare const SHAPE_GROUPS: {
16
+ CIRCLES: string;
17
+ POLYGONS: string;
18
+ RECTANGLES: string;
19
+ };
@@ -0,0 +1,16 @@
1
+ import { CircleShape as e } from "./circle.js";
2
+ import { RectangleShape as t } from "./rectagle.js";
3
+ import { PolygonShape as n } from "./polygon.js";
4
+ //#region src/author/shapes/utils.ts
5
+ var r = {
6
+ CIRCLE: e.name,
7
+ POLYGON: n.name,
8
+ RECTANGLE: t.name,
9
+ NONE: "none"
10
+ }, i = {
11
+ CIRCLES: "circles",
12
+ POLYGONS: "polygons",
13
+ RECTANGLES: "rectangles"
14
+ };
15
+ //#endregion
16
+ export { i as SHAPE_GROUPS, r as SUPPORTED_SHAPES };