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

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 (354) 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 +42297 -0
  51. package/dist/browser/author/index.js.map +1 -0
  52. package/dist/browser/browser-CfnAFove.js +210 -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/hotspot.css +2 -0
  59. package/dist/browser/isEqual-D3CTSc6W.js +601 -0
  60. package/dist/browser/isEqual-D3CTSc6W.js.map +1 -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 +13 -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/node_modules/.bun/lodash-es@4.18.1/node_modules/lodash-es/_DataView.js +6 -0
  90. package/dist/node_modules/.bun/lodash-es@4.18.1/node_modules/lodash-es/_Hash.js +16 -0
  91. package/dist/node_modules/.bun/lodash-es@4.18.1/node_modules/lodash-es/_ListCache.js +16 -0
  92. package/dist/node_modules/.bun/lodash-es@4.18.1/node_modules/lodash-es/_Map.js +6 -0
  93. package/dist/node_modules/.bun/lodash-es@4.18.1/node_modules/lodash-es/_MapCache.js +16 -0
  94. package/dist/node_modules/.bun/lodash-es@4.18.1/node_modules/lodash-es/_Promise.js +6 -0
  95. package/dist/node_modules/.bun/lodash-es@4.18.1/node_modules/lodash-es/_Set.js +6 -0
  96. package/dist/node_modules/.bun/lodash-es@4.18.1/node_modules/lodash-es/_SetCache.js +11 -0
  97. package/dist/node_modules/.bun/lodash-es@4.18.1/node_modules/lodash-es/_Stack.js +14 -0
  98. package/dist/node_modules/.bun/lodash-es@4.18.1/node_modules/lodash-es/_Symbol.js +5 -0
  99. package/dist/node_modules/.bun/lodash-es@4.18.1/node_modules/lodash-es/_Uint8Array.js +5 -0
  100. package/dist/node_modules/.bun/lodash-es@4.18.1/node_modules/lodash-es/_WeakMap.js +6 -0
  101. package/dist/node_modules/.bun/lodash-es@4.18.1/node_modules/lodash-es/_arrayEach.js +7 -0
  102. package/dist/node_modules/.bun/lodash-es@4.18.1/node_modules/lodash-es/_arrayFilter.js +10 -0
  103. package/dist/node_modules/.bun/lodash-es@4.18.1/node_modules/lodash-es/_arrayLikeKeys.js +15 -0
  104. package/dist/node_modules/.bun/lodash-es@4.18.1/node_modules/lodash-es/_arrayPush.js +7 -0
  105. package/dist/node_modules/.bun/lodash-es@4.18.1/node_modules/lodash-es/_arraySome.js +7 -0
  106. package/dist/node_modules/.bun/lodash-es@4.18.1/node_modules/lodash-es/_assignValue.js +10 -0
  107. package/dist/node_modules/.bun/lodash-es@4.18.1/node_modules/lodash-es/_assocIndexOf.js +8 -0
  108. package/dist/node_modules/.bun/lodash-es@4.18.1/node_modules/lodash-es/_baseAssign.js +8 -0
  109. package/dist/node_modules/.bun/lodash-es@4.18.1/node_modules/lodash-es/_baseAssignIn.js +8 -0
  110. package/dist/node_modules/.bun/lodash-es@4.18.1/node_modules/lodash-es/_baseAssignValue.js +12 -0
  111. package/dist/node_modules/.bun/lodash-es@4.18.1/node_modules/lodash-es/_baseClone.js +57 -0
  112. package/dist/node_modules/.bun/lodash-es@4.18.1/node_modules/lodash-es/_baseCreate.js +14 -0
  113. package/dist/node_modules/.bun/lodash-es@4.18.1/node_modules/lodash-es/_baseGetAllKeys.js +9 -0
  114. package/dist/node_modules/.bun/lodash-es@4.18.1/node_modules/lodash-es/_baseGetTag.js +10 -0
  115. package/dist/node_modules/.bun/lodash-es@4.18.1/node_modules/lodash-es/_baseIsArguments.js +9 -0
  116. package/dist/node_modules/.bun/lodash-es@4.18.1/node_modules/lodash-es/_baseIsEqual.js +8 -0
  117. package/dist/node_modules/.bun/lodash-es@4.18.1/node_modules/lodash-es/_baseIsEqualDeep.js +30 -0
  118. package/dist/node_modules/.bun/lodash-es@4.18.1/node_modules/lodash-es/_baseIsMap.js +9 -0
  119. package/dist/node_modules/.bun/lodash-es@4.18.1/node_modules/lodash-es/_baseIsNative.js +11 -0
  120. package/dist/node_modules/.bun/lodash-es@4.18.1/node_modules/lodash-es/_baseIsSet.js +9 -0
  121. package/dist/node_modules/.bun/lodash-es@4.18.1/node_modules/lodash-es/_baseIsTypedArray.js +11 -0
  122. package/dist/node_modules/.bun/lodash-es@4.18.1/node_modules/lodash-es/_baseKeys.js +12 -0
  123. package/dist/node_modules/.bun/lodash-es@4.18.1/node_modules/lodash-es/_baseKeysIn.js +13 -0
  124. package/dist/node_modules/.bun/lodash-es@4.18.1/node_modules/lodash-es/_baseTimes.js +7 -0
  125. package/dist/node_modules/.bun/lodash-es@4.18.1/node_modules/lodash-es/_baseUnary.js +8 -0
  126. package/dist/node_modules/.bun/lodash-es@4.18.1/node_modules/lodash-es/_cacheHas.js +6 -0
  127. package/dist/node_modules/.bun/lodash-es@4.18.1/node_modules/lodash-es/_cloneArrayBuffer.js +8 -0
  128. package/dist/node_modules/.bun/lodash-es@4.18.1/node_modules/lodash-es/_cloneBuffer.js +10 -0
  129. package/dist/node_modules/.bun/lodash-es@4.18.1/node_modules/lodash-es/_cloneDataView.js +8 -0
  130. package/dist/node_modules/.bun/lodash-es@4.18.1/node_modules/lodash-es/_cloneRegExp.js +8 -0
  131. package/dist/node_modules/.bun/lodash-es@4.18.1/node_modules/lodash-es/_cloneSymbol.js +8 -0
  132. package/dist/node_modules/.bun/lodash-es@4.18.1/node_modules/lodash-es/_cloneTypedArray.js +8 -0
  133. package/dist/node_modules/.bun/lodash-es@4.18.1/node_modules/lodash-es/_copyArray.js +8 -0
  134. package/dist/node_modules/.bun/lodash-es@4.18.1/node_modules/lodash-es/_copyObject.js +14 -0
  135. package/dist/node_modules/.bun/lodash-es@4.18.1/node_modules/lodash-es/_copySymbols.js +8 -0
  136. package/dist/node_modules/.bun/lodash-es@4.18.1/node_modules/lodash-es/_copySymbolsIn.js +8 -0
  137. package/dist/node_modules/.bun/lodash-es@4.18.1/node_modules/lodash-es/_coreJsData.js +5 -0
  138. package/dist/node_modules/.bun/lodash-es@4.18.1/node_modules/lodash-es/_defineProperty.js +10 -0
  139. package/dist/node_modules/.bun/lodash-es@4.18.1/node_modules/lodash-es/_equalArrays.js +35 -0
  140. package/dist/node_modules/.bun/lodash-es@4.18.1/node_modules/lodash-es/_equalByTag.js +35 -0
  141. package/dist/node_modules/.bun/lodash-es@4.18.1/node_modules/lodash-es/_equalObjects.js +32 -0
  142. package/dist/node_modules/.bun/lodash-es@4.18.1/node_modules/lodash-es/_freeGlobal.js +4 -0
  143. package/dist/node_modules/.bun/lodash-es@4.18.1/node_modules/lodash-es/_getAllKeys.js +9 -0
  144. package/dist/node_modules/.bun/lodash-es@4.18.1/node_modules/lodash-es/_getAllKeysIn.js +9 -0
  145. package/dist/node_modules/.bun/lodash-es@4.18.1/node_modules/lodash-es/_getMapData.js +8 -0
  146. package/dist/node_modules/.bun/lodash-es@4.18.1/node_modules/lodash-es/_getNative.js +9 -0
  147. package/dist/node_modules/.bun/lodash-es@4.18.1/node_modules/lodash-es/_getPrototype.js +5 -0
  148. package/dist/node_modules/.bun/lodash-es@4.18.1/node_modules/lodash-es/_getRawTag.js +14 -0
  149. package/dist/node_modules/.bun/lodash-es@4.18.1/node_modules/lodash-es/_getSymbols.js +10 -0
  150. package/dist/node_modules/.bun/lodash-es@4.18.1/node_modules/lodash-es/_getSymbolsIn.js +11 -0
  151. package/dist/node_modules/.bun/lodash-es@4.18.1/node_modules/lodash-es/_getTag.js +23 -0
  152. package/dist/node_modules/.bun/lodash-es@4.18.1/node_modules/lodash-es/_getValue.js +6 -0
  153. package/dist/node_modules/.bun/lodash-es@4.18.1/node_modules/lodash-es/_hashClear.js +7 -0
  154. package/dist/node_modules/.bun/lodash-es@4.18.1/node_modules/lodash-es/_hashDelete.js +7 -0
  155. package/dist/node_modules/.bun/lodash-es@4.18.1/node_modules/lodash-es/_hashGet.js +13 -0
  156. package/dist/node_modules/.bun/lodash-es@4.18.1/node_modules/lodash-es/_hashHas.js +9 -0
  157. package/dist/node_modules/.bun/lodash-es@4.18.1/node_modules/lodash-es/_hashSet.js +9 -0
  158. package/dist/node_modules/.bun/lodash-es@4.18.1/node_modules/lodash-es/_initCloneArray.js +8 -0
  159. package/dist/node_modules/.bun/lodash-es@4.18.1/node_modules/lodash-es/_initCloneByTag.js +33 -0
  160. package/dist/node_modules/.bun/lodash-es@4.18.1/node_modules/lodash-es/_initCloneObject.js +9 -0
  161. package/dist/node_modules/.bun/lodash-es@4.18.1/node_modules/lodash-es/_isIndex.js +8 -0
  162. package/dist/node_modules/.bun/lodash-es@4.18.1/node_modules/lodash-es/_isKeyable.js +7 -0
  163. package/dist/node_modules/.bun/lodash-es@4.18.1/node_modules/lodash-es/_isMasked.js +11 -0
  164. package/dist/node_modules/.bun/lodash-es@4.18.1/node_modules/lodash-es/_isPrototype.js +8 -0
  165. package/dist/node_modules/.bun/lodash-es@4.18.1/node_modules/lodash-es/_listCacheClear.js +6 -0
  166. package/dist/node_modules/.bun/lodash-es@4.18.1/node_modules/lodash-es/_listCacheDelete.js +9 -0
  167. package/dist/node_modules/.bun/lodash-es@4.18.1/node_modules/lodash-es/_listCacheGet.js +8 -0
  168. package/dist/node_modules/.bun/lodash-es@4.18.1/node_modules/lodash-es/_listCacheHas.js +7 -0
  169. package/dist/node_modules/.bun/lodash-es@4.18.1/node_modules/lodash-es/_listCacheSet.js +8 -0
  170. package/dist/node_modules/.bun/lodash-es@4.18.1/node_modules/lodash-es/_mapCacheClear.js +13 -0
  171. package/dist/node_modules/.bun/lodash-es@4.18.1/node_modules/lodash-es/_mapCacheDelete.js +8 -0
  172. package/dist/node_modules/.bun/lodash-es@4.18.1/node_modules/lodash-es/_mapCacheGet.js +7 -0
  173. package/dist/node_modules/.bun/lodash-es@4.18.1/node_modules/lodash-es/_mapCacheHas.js +7 -0
  174. package/dist/node_modules/.bun/lodash-es@4.18.1/node_modules/lodash-es/_mapCacheSet.js +8 -0
  175. package/dist/node_modules/.bun/lodash-es@4.18.1/node_modules/lodash-es/_mapToArray.js +9 -0
  176. package/dist/node_modules/.bun/lodash-es@4.18.1/node_modules/lodash-es/_nativeCreate.js +5 -0
  177. package/dist/node_modules/.bun/lodash-es@4.18.1/node_modules/lodash-es/_nativeKeys.js +5 -0
  178. package/dist/node_modules/.bun/lodash-es@4.18.1/node_modules/lodash-es/_nativeKeysIn.js +8 -0
  179. package/dist/node_modules/.bun/lodash-es@4.18.1/node_modules/lodash-es/_nodeUtil.js +9 -0
  180. package/dist/node_modules/.bun/lodash-es@4.18.1/node_modules/lodash-es/_objectToString.js +7 -0
  181. package/dist/node_modules/.bun/lodash-es@4.18.1/node_modules/lodash-es/_overArg.js +8 -0
  182. package/dist/node_modules/.bun/lodash-es@4.18.1/node_modules/lodash-es/_root.js +5 -0
  183. package/dist/node_modules/.bun/lodash-es@4.18.1/node_modules/lodash-es/_setCacheAdd.js +7 -0
  184. package/dist/node_modules/.bun/lodash-es@4.18.1/node_modules/lodash-es/_setCacheHas.js +6 -0
  185. package/dist/node_modules/.bun/lodash-es@4.18.1/node_modules/lodash-es/_setToArray.js +9 -0
  186. package/dist/node_modules/.bun/lodash-es@4.18.1/node_modules/lodash-es/_stackClear.js +7 -0
  187. package/dist/node_modules/.bun/lodash-es@4.18.1/node_modules/lodash-es/_stackDelete.js +7 -0
  188. package/dist/node_modules/.bun/lodash-es@4.18.1/node_modules/lodash-es/_stackGet.js +6 -0
  189. package/dist/node_modules/.bun/lodash-es@4.18.1/node_modules/lodash-es/_stackHas.js +6 -0
  190. package/dist/node_modules/.bun/lodash-es@4.18.1/node_modules/lodash-es/_stackSet.js +16 -0
  191. package/dist/node_modules/.bun/lodash-es@4.18.1/node_modules/lodash-es/_toSource.js +15 -0
  192. package/dist/node_modules/.bun/lodash-es@4.18.1/node_modules/lodash-es/cloneDeep.js +8 -0
  193. package/dist/node_modules/.bun/lodash-es@4.18.1/node_modules/lodash-es/eq.js +6 -0
  194. package/dist/node_modules/.bun/lodash-es@4.18.1/node_modules/lodash-es/isArguments.js +10 -0
  195. package/dist/node_modules/.bun/lodash-es@4.18.1/node_modules/lodash-es/isArray.js +4 -0
  196. package/dist/node_modules/.bun/lodash-es@4.18.1/node_modules/lodash-es/isArrayLike.js +8 -0
  197. package/dist/node_modules/.bun/lodash-es@4.18.1/node_modules/lodash-es/isBuffer.js +6 -0
  198. package/dist/node_modules/.bun/lodash-es@4.18.1/node_modules/lodash-es/isEmpty.js +21 -0
  199. package/dist/node_modules/.bun/lodash-es@4.18.1/node_modules/lodash-es/isEqual.js +7 -0
  200. package/dist/node_modules/.bun/lodash-es@4.18.1/node_modules/lodash-es/isFunction.js +11 -0
  201. package/dist/node_modules/.bun/lodash-es@4.18.1/node_modules/lodash-es/isLength.js +7 -0
  202. package/dist/node_modules/.bun/lodash-es@4.18.1/node_modules/lodash-es/isMap.js +7 -0
  203. package/dist/node_modules/.bun/lodash-es@4.18.1/node_modules/lodash-es/isObject.js +7 -0
  204. package/dist/node_modules/.bun/lodash-es@4.18.1/node_modules/lodash-es/isObjectLike.js +6 -0
  205. package/dist/node_modules/.bun/lodash-es@4.18.1/node_modules/lodash-es/isSet.js +7 -0
  206. package/dist/node_modules/.bun/lodash-es@4.18.1/node_modules/lodash-es/isTypedArray.js +7 -0
  207. package/dist/node_modules/.bun/lodash-es@4.18.1/node_modules/lodash-es/keys.js +9 -0
  208. package/dist/node_modules/.bun/lodash-es@4.18.1/node_modules/lodash-es/keysIn.js +9 -0
  209. package/dist/node_modules/.bun/lodash-es@4.18.1/node_modules/lodash-es/stubArray.js +6 -0
  210. package/dist/node_modules/.bun/lodash-es@4.18.1/node_modules/lodash-es/stubFalse.js +6 -0
  211. package/package.json +78 -16
  212. package/CHANGELOG.json +0 -997
  213. package/CHANGELOG.md +0 -2214
  214. package/LICENSE.md +0 -5
  215. package/README.md +0 -1
  216. package/configure/CHANGELOG.json +0 -682
  217. package/configure/CHANGELOG.md +0 -1951
  218. package/configure/lib/DeleteWidget.js +0 -64
  219. package/configure/lib/DeleteWidget.js.map +0 -1
  220. package/configure/lib/button.js +0 -42
  221. package/configure/lib/button.js.map +0 -1
  222. package/configure/lib/buttons/circle.js +0 -33
  223. package/configure/lib/buttons/circle.js.map +0 -1
  224. package/configure/lib/buttons/polygon.js +0 -39
  225. package/configure/lib/buttons/polygon.js.map +0 -1
  226. package/configure/lib/buttons/rectangle.js +0 -39
  227. package/configure/lib/buttons/rectangle.js.map +0 -1
  228. package/configure/lib/defaults.js +0 -155
  229. package/configure/lib/defaults.js.map +0 -1
  230. package/configure/lib/hotspot-circle.js +0 -192
  231. package/configure/lib/hotspot-circle.js.map +0 -1
  232. package/configure/lib/hotspot-container.js +0 -320
  233. package/configure/lib/hotspot-container.js.map +0 -1
  234. package/configure/lib/hotspot-drawable.js +0 -519
  235. package/configure/lib/hotspot-drawable.js.map +0 -1
  236. package/configure/lib/hotspot-palette.js +0 -107
  237. package/configure/lib/hotspot-palette.js.map +0 -1
  238. package/configure/lib/hotspot-polygon.js +0 -293
  239. package/configure/lib/hotspot-polygon.js.map +0 -1
  240. package/configure/lib/hotspot-rectangle.js +0 -190
  241. package/configure/lib/hotspot-rectangle.js.map +0 -1
  242. package/configure/lib/icons.js +0 -7
  243. package/configure/lib/icons.js.map +0 -1
  244. package/configure/lib/image-konva.js +0 -66
  245. package/configure/lib/image-konva.js.map +0 -1
  246. package/configure/lib/index.js +0 -194
  247. package/configure/lib/index.js.map +0 -1
  248. package/configure/lib/root.js +0 -330
  249. package/configure/lib/root.js.map +0 -1
  250. package/configure/lib/shapes/circle.js +0 -84
  251. package/configure/lib/shapes/circle.js.map +0 -1
  252. package/configure/lib/shapes/index.js +0 -50
  253. package/configure/lib/shapes/index.js.map +0 -1
  254. package/configure/lib/shapes/polygon.js +0 -82
  255. package/configure/lib/shapes/polygon.js.map +0 -1
  256. package/configure/lib/shapes/rectagle.js +0 -84
  257. package/configure/lib/shapes/rectagle.js.map +0 -1
  258. package/configure/lib/shapes/utils.js +0 -21
  259. package/configure/lib/shapes/utils.js.map +0 -1
  260. package/configure/lib/upload-control.js +0 -41
  261. package/configure/lib/upload-control.js.map +0 -1
  262. package/configure/lib/utils.js +0 -185
  263. package/configure/lib/utils.js.map +0 -1
  264. package/configure/package.json +0 -26
  265. package/configure/src/DeleteWidget.jsx +0 -51
  266. package/configure/src/__tests__/DeleteWidget.test.jsx +0 -366
  267. package/configure/src/__tests__/button.test.jsx +0 -198
  268. package/configure/src/__tests__/hotspot-circle.test.jsx +0 -259
  269. package/configure/src/__tests__/hotspot-container.test.js +0 -366
  270. package/configure/src/__tests__/hotspot-drawable.test.js +0 -271
  271. package/configure/src/__tests__/hotspot-palette.test.jsx +0 -71
  272. package/configure/src/__tests__/image-konva.test.jsx +0 -226
  273. package/configure/src/__tests__/index.test.js +0 -329
  274. package/configure/src/__tests__/root.test.js +0 -400
  275. package/configure/src/__tests__/utils.test.js +0 -241
  276. package/configure/src/button.jsx +0 -35
  277. package/configure/src/buttons/circle.jsx +0 -18
  278. package/configure/src/buttons/polygon.jsx +0 -29
  279. package/configure/src/buttons/rectangle.jsx +0 -29
  280. package/configure/src/defaults.js +0 -109
  281. package/configure/src/hotspot-circle.jsx +0 -183
  282. package/configure/src/hotspot-container.jsx +0 -330
  283. package/configure/src/hotspot-drawable.jsx +0 -527
  284. package/configure/src/hotspot-palette.jsx +0 -90
  285. package/configure/src/hotspot-polygon.jsx +0 -294
  286. package/configure/src/hotspot-rectangle.jsx +0 -169
  287. package/configure/src/icons.js +0 -5
  288. package/configure/src/image-konva.jsx +0 -63
  289. package/configure/src/index.js +0 -208
  290. package/configure/src/root.jsx +0 -346
  291. package/configure/src/shapes/circle.js +0 -81
  292. package/configure/src/shapes/index.js +0 -4
  293. package/configure/src/shapes/polygon.js +0 -81
  294. package/configure/src/shapes/rectagle.js +0 -82
  295. package/configure/src/shapes/utils.js +0 -16
  296. package/configure/src/upload-control.jsx +0 -33
  297. package/configure/src/utils.js +0 -210
  298. package/controller/CHANGELOG.json +0 -362
  299. package/controller/CHANGELOG.md +0 -1304
  300. package/controller/lib/defaults.js +0 -33
  301. package/controller/lib/defaults.js.map +0 -1
  302. package/controller/lib/index.js +0 -341
  303. package/controller/lib/index.js.map +0 -1
  304. package/controller/lib/utils.js +0 -32
  305. package/controller/lib/utils.js.map +0 -1
  306. package/controller/package.json +0 -18
  307. package/controller/src/__tests__/index.test.js +0 -419
  308. package/controller/src/__tests__/utils.test.js +0 -5
  309. package/controller/src/defaults.js +0 -19
  310. package/controller/src/index.js +0 -328
  311. package/controller/src/utils.js +0 -29
  312. package/docs/config-schema.json +0 -2023
  313. package/docs/config-schema.json.md +0 -1495
  314. package/docs/demo/config.js +0 -8
  315. package/docs/demo/generate.js +0 -118
  316. package/docs/demo/index.html +0 -1
  317. package/docs/demo/session.js +0 -11
  318. package/docs/pie-schema.json +0 -1204
  319. package/docs/pie-schema.json.md +0 -851
  320. package/lib/hotspot/circle.js +0 -156
  321. package/lib/hotspot/circle.js.map +0 -1
  322. package/lib/hotspot/container.js +0 -206
  323. package/lib/hotspot/container.js.map +0 -1
  324. package/lib/hotspot/icons.js +0 -8
  325. package/lib/hotspot/icons.js.map +0 -1
  326. package/lib/hotspot/image-konva-tooltip.js +0 -86
  327. package/lib/hotspot/image-konva-tooltip.js.map +0 -1
  328. package/lib/hotspot/index.js +0 -163
  329. package/lib/hotspot/index.js.map +0 -1
  330. package/lib/hotspot/polygon.js +0 -203
  331. package/lib/hotspot/polygon.js.map +0 -1
  332. package/lib/hotspot/rectangle.js +0 -175
  333. package/lib/hotspot/rectangle.js.map +0 -1
  334. package/lib/index.js +0 -213
  335. package/lib/index.js.map +0 -1
  336. package/lib/session-updater.js +0 -42
  337. package/lib/session-updater.js.map +0 -1
  338. package/src/__tests__/container.test.jsx +0 -58
  339. package/src/__tests__/index.test.js +0 -123
  340. package/src/__tests__/session-updater.test.jsx +0 -69
  341. package/src/hotspot/__tests__/circle.test.jsx +0 -464
  342. package/src/hotspot/__tests__/container.test.jsx +0 -546
  343. package/src/hotspot/__tests__/image-konva-tooltip.test.jsx +0 -510
  344. package/src/hotspot/__tests__/polygon.test.jsx +0 -502
  345. package/src/hotspot/__tests__/rectangle.test.jsx +0 -418
  346. package/src/hotspot/circle.jsx +0 -152
  347. package/src/hotspot/container.jsx +0 -217
  348. package/src/hotspot/icons.js +0 -7
  349. package/src/hotspot/image-konva-tooltip.jsx +0 -76
  350. package/src/hotspot/index.jsx +0 -165
  351. package/src/hotspot/polygon.jsx +0 -195
  352. package/src/hotspot/rectangle.jsx +0 -171
  353. package/src/index.js +0 -226
  354. package/src/session-updater.js +0 -29
@@ -0,0 +1,2460 @@
1
+ import { s as e } from "../browser-CfnAFove.js";
2
+ import { D as t, E as n, Et as r, Gt as i, Jt as a, Kt as o, L as s, O as c, Ot as l, W as u, a as d, b as f, c as p, i as m, k as h, l as g, n as _, o as v, r as y, s as b, t as x } from "../ReactKonva-Z9-1H-UZ.js";
3
+ import S, { useRef as C } from "react";
4
+ import { createRoot as w } from "react-dom/client";
5
+ import { jsx as T, jsxs as E } from "react/jsx-runtime";
6
+ //#region ../../lib-react/icons/dist/correct-response-icon.js
7
+ var D = /* @__PURE__ */ e(i(), 1), O = ({ bgFill: e, fgFill: t }) => /* @__PURE__ */ E("svg", {
8
+ preserveAspectRatio: "xMinYMin meet",
9
+ version: "1.1",
10
+ viewBox: "-283 359 34 35",
11
+ style: { enableBackground: "new -283 359 34 35" },
12
+ children: [
13
+ /* @__PURE__ */ T("circle", {
14
+ cx: "-266",
15
+ cy: "375.9",
16
+ r: "14",
17
+ fill: e
18
+ }),
19
+ /* @__PURE__ */ T("path", {
20
+ d: "M-280.5,375.9c0-8,6.5-14.5,14.5-14.5s14.5,6.5,14.5,14.5s-6.5,14.5-14.5,14.5S-280.5,383.9-280.5,375.9z\n M-279.5,375.9c0,7.4,6.1,13.5,13.5,13.5c7.4,0,13.5-6.1,13.5-13.5s-6.1-13.5-13.5-13.5C-273.4,362.4-279.5,368.5-279.5,375.9z",
21
+ fill: e
22
+ }),
23
+ /* @__PURE__ */ T("polygon", {
24
+ points: "-265.4,383.1 -258.6,377.2 -261.2,374.2 -264.3,376.9 -268.9,368.7 -272.4,370.6",
25
+ fill: t
26
+ })
27
+ ]
28
+ });
29
+ O.propTypes = {
30
+ bgFill: D.default.string.isRequired,
31
+ fgFill: D.default.string.isRequired
32
+ };
33
+ var k = ({ bgFill: e, fgFill: t, borderFill: n }) => /* @__PURE__ */ E("svg", {
34
+ preserveAspectRatio: "xMinYMin meet",
35
+ version: "1.1",
36
+ viewBox: "-129.5 127 34 35",
37
+ style: { enableBackground: "new -129.5 127 34 35" },
38
+ children: [
39
+ /* @__PURE__ */ T("path", {
40
+ style: {
41
+ fill: "#D0CAC5",
42
+ stroke: "#E6E3E0",
43
+ strokeWidth: .75,
44
+ strokeMiterlimit: 10
45
+ },
46
+ d: "M-112.9,160.4c-8.5,0-15.5-6.9-15.5-15.5c0-8.5,6.9-15.5,15.5-15.5s15.5,6.9,15.5,15.5\n C-97.4,153.5-104.3,160.4-112.9,160.4z"
47
+ }),
48
+ /* @__PURE__ */ T("path", {
49
+ style: {
50
+ fill: "#B3ABA4",
51
+ stroke: "#CDC7C2",
52
+ strokeWidth: .5,
53
+ strokeMiterlimit: 10
54
+ },
55
+ d: "M-113.2,159c-8,0-14.5-6.5-14.5-14.5s6.5-14.5,14.5-14.5s14.5,6.5,14.5,14.5S-105.2,159-113.2,159z"
56
+ }),
57
+ /* @__PURE__ */ T("circle", {
58
+ cx: "-114.2",
59
+ cy: "143.5",
60
+ r: "14",
61
+ fill: e
62
+ }),
63
+ /* @__PURE__ */ T("path", {
64
+ d: "M-114.2,158c-8,0-14.5-6.5-14.5-14.5s6.5-14.5,14.5-14.5s14.5,6.5,14.5,14.5S-106.2,158-114.2,158z\n M-114.2,130c-7.4,0-13.5,6.1-13.5,13.5s6.1,13.5,13.5,13.5s13.5-6.1,13.5-13.5S-106.8,130-114.2,130z",
65
+ fill: n
66
+ }),
67
+ /* @__PURE__ */ T("polygon", {
68
+ points: "-114.8,150.7 -121.6,144.8 -119,141.8 -115.9,144.5 -111.3,136.3 -107.8,138.2",
69
+ fill: t
70
+ })
71
+ ]
72
+ });
73
+ k.propTypes = {
74
+ bgFill: D.default.string.isRequired,
75
+ fgFill: D.default.string.isRequired,
76
+ borderFill: D.default.string.isRequired
77
+ };
78
+ var ee = l("div")(({ size: e }) => ({
79
+ width: e || "25px",
80
+ height: e || "25px"
81
+ })), A = ({ open: e, size: t }) => /* @__PURE__ */ T(ee, {
82
+ size: t,
83
+ children: e ? /* @__PURE__ */ T(O, {
84
+ bgFill: "#bce2ff",
85
+ fgFill: "#1a9cff"
86
+ }) : /* @__PURE__ */ T(k, {
87
+ bgFill: "white",
88
+ fgFill: "#1a9cff",
89
+ borderFill: "#bce2ff"
90
+ })
91
+ });
92
+ A.propTypes = {
93
+ open: D.default.bool,
94
+ size: D.default.string
95
+ }, A.defaultProps = { open: !1 };
96
+ //#endregion
97
+ //#region ../../shared/player-events/dist/index.js
98
+ var te = class e extends CustomEvent {
99
+ static {
100
+ this.TYPE = "model-set";
101
+ }
102
+ constructor(t, n, r) {
103
+ super(e.TYPE, {
104
+ bubbles: !0,
105
+ composed: !0,
106
+ detail: {
107
+ complete: n,
108
+ component: t,
109
+ hasModel: r
110
+ }
111
+ }), this.component = t, this.complete = n;
112
+ }
113
+ }, ne = class e extends CustomEvent {
114
+ static {
115
+ this.TYPE = "session-changed";
116
+ }
117
+ constructor(t, n) {
118
+ super(e.TYPE, {
119
+ bubbles: !0,
120
+ composed: !0,
121
+ detail: {
122
+ complete: n,
123
+ component: t
124
+ }
125
+ }), this.component = t, this.complete = n;
126
+ }
127
+ }, re = "height ease-in 300ms, opacity ease-in 300ms", ie = l("div")(() => ({
128
+ position: "relative",
129
+ height: 0,
130
+ overflow: "hidden",
131
+ display: "flex",
132
+ visibility: "hidden",
133
+ width: 0,
134
+ "&.enter": {
135
+ transition: re,
136
+ opacity: 1,
137
+ height: "auto",
138
+ width: "auto",
139
+ visibility: "visible",
140
+ minHeight: "25px"
141
+ },
142
+ "&.enter-done": {
143
+ height: "auto",
144
+ visibility: "visible",
145
+ width: "auto",
146
+ minHeight: "25px"
147
+ },
148
+ "&.exit": {
149
+ transition: re,
150
+ opacity: 0,
151
+ height: 0,
152
+ visibility: "visible",
153
+ width: 0
154
+ },
155
+ "&.exit-done": {
156
+ opacity: 0,
157
+ visibility: "hidden",
158
+ height: 0,
159
+ width: 0
160
+ }
161
+ })), ae = (e) => {
162
+ let { show: t, children: n, className: i } = e, a = C(null);
163
+ return /* @__PURE__ */ T(r, {
164
+ nodeRef: a,
165
+ in: t,
166
+ appear: !0,
167
+ mountOnEnter: !1,
168
+ timeout: 300,
169
+ classNames: {
170
+ enter: "enter",
171
+ enterDone: "enter-done",
172
+ exit: "exit",
173
+ exitDone: "exit-done"
174
+ },
175
+ children: /* @__PURE__ */ T(ie, {
176
+ ref: a,
177
+ className: i,
178
+ children: n
179
+ })
180
+ });
181
+ };
182
+ ae.propTypes = {
183
+ show: D.default.bool.isRequired,
184
+ className: D.default.string,
185
+ children: D.default.oneOfType([D.default.arrayOf(D.default.node), D.default.node]).isRequired
186
+ };
187
+ //#endregion
188
+ //#region ../../lib-react/translator/dist/en.js
189
+ var oe = {
190
+ translation: {
191
+ categorize: {
192
+ limitMaxChoicesPerCategory: "You've reached the limit of {{maxChoicesPerCategory}} responses per area. To add another response, one must first be removed.",
193
+ maxChoicesPerCategoryRestriction: "To change this value to {{maxChoicesPerCategory}}, each category must have {{maxChoicesPerCategory}} or fewer answer choice[s]."
194
+ },
195
+ ebsr: { part: "Part {{index}}" },
196
+ numberLine: {
197
+ addElementLimit_one: "You can only add {{count}} element",
198
+ addElementLimit_other: "You can only add {{count}} elements",
199
+ clearAll: "Clear all"
200
+ },
201
+ imageClozeAssociation: {
202
+ reachedLimit_one: "You’ve reached the limit of {{count}} response per area. To add another response, one must first be removed.",
203
+ reachedLimit_other: "Full"
204
+ },
205
+ drawingResponse: {
206
+ fillColor: "Fill color",
207
+ outlineColor: "Outline color",
208
+ noFill: "No fill",
209
+ lightblue: "Light blue",
210
+ lightyellow: "Light yellow",
211
+ red: "Red",
212
+ orange: "Orange",
213
+ yellow: "Yellow",
214
+ violet: "Violet",
215
+ blue: "Blue",
216
+ green: "Green",
217
+ white: "White",
218
+ black: "Black",
219
+ onDoubleClick: "Double click to edit this text. Press Enter to submit."
220
+ },
221
+ charting: {
222
+ addCategory: "Add category",
223
+ actions: "Actions",
224
+ add: "Add",
225
+ delete: "Delete",
226
+ newLabel: "New label",
227
+ reachedLimit_other: "There can't be more than {{count}} categories.",
228
+ keyLegend: {
229
+ incorrectAnswer: "Student incorrect answer",
230
+ correctAnswer: "Student correct answer",
231
+ correctKeyAnswer: "Answer key correct"
232
+ }
233
+ },
234
+ graphing: {
235
+ point: "Point",
236
+ circle: "Circle",
237
+ line: "Line",
238
+ parabola: "Parabola",
239
+ absolute: "Absolute Value",
240
+ exponential: "Exponential",
241
+ polygon: "Polygon",
242
+ ray: "Ray",
243
+ segment: "Segment",
244
+ sine: "Sine",
245
+ vector: "Vector",
246
+ label: "Label",
247
+ redo: "Redo",
248
+ reset: "Reset"
249
+ },
250
+ mathInline: { primaryCorrectWithAlternates: "Note: The answer shown above is the primary correct answer specified by the author for this item, but other answers may also be recognized as correct." },
251
+ multipleChoice: {
252
+ minSelections: "Select at least {{minSelections}}.",
253
+ maxSelections_one: "Only {{maxSelections}} answer is allowed.",
254
+ maxSelections_other: "Only {{maxSelections}} answers are allowed.",
255
+ minmaxSelections_equal: "Select {{minSelections}}.",
256
+ minmaxSelections_range: "Select between {{minSelections}} and {{maxSelections}}."
257
+ },
258
+ selectText: {
259
+ correctAnswerSelected: "Correct",
260
+ correctAnswerNotSelected: "Correct Answer Not Selected",
261
+ incorrectSelection: "Incorrect Selection",
262
+ key: "Key"
263
+ }
264
+ },
265
+ common: {
266
+ undo: "Undo",
267
+ clearAll: "Clear all",
268
+ correct: "Correct",
269
+ incorrect: "Incorrect",
270
+ showCorrectAnswer: "Show correct answer",
271
+ hideCorrectAnswer: "Hide correct answer",
272
+ commonCorrectAnswerWithAlternates: "Note: The answer shown above is the most common correct answer for this item. One or more additional correct answers are also defined, and will also be recognized as correct.",
273
+ warning: "Warning",
274
+ showNote: "Show Note",
275
+ hideNote: "Hide Note",
276
+ cancel: "Cancel"
277
+ }
278
+ }, se = {
279
+ translation: {
280
+ categorize: {
281
+ limitMaxChoicesPerCategory: "Has alcanzado el límite de {{maxChoicesPerCategory}} respuestas por área. Para agregar otra respuesta, primero se debe eliminar una respuesta.",
282
+ maxChoicesPerCategoryRestriction: "Para cambiar este valor a {{maxChoicesPerCategory}}, cada categoría debe tener {{maxChoicesPerCategory}} o menos opciones de respuesta"
283
+ },
284
+ ebsr: { part: "Parte {{index}}" },
285
+ numberLine: {
286
+ addElementLimit_one: "Solo puedes agregar {{count}} elemento",
287
+ addElementLimit_other: "Solo puedes agregar {{count}} elementos",
288
+ clearAll: "Borrar todo"
289
+ },
290
+ imageClozeAssociation: {
291
+ reachedLimit_one: "Has alcanzado el límite de {{count}} respuesta por área. Para agregar otra respuesta, primero se debe eliminar una respuesta.",
292
+ reachedLimit_other: "Lleno"
293
+ },
294
+ drawingResponse: {
295
+ fillColor: "Color de relleno",
296
+ outlineColor: "Color del contorno",
297
+ noFill: "Sin relleno",
298
+ lightblue: "Azul claro",
299
+ lightyellow: "Amarillo claro",
300
+ red: "Rojo",
301
+ orange: "Naranja",
302
+ yellow: "Amarillo",
303
+ violet: "Violeta",
304
+ blue: "Azul",
305
+ green: "Verde",
306
+ white: "Blanco",
307
+ black: "Negro",
308
+ onDoubleClick: "Haz doble clic para revisar este texto. Presiona el botón de ingreso para enviar"
309
+ },
310
+ charting: {
311
+ addCategory: "Añadir categoría",
312
+ actions: "Acciones",
313
+ add: "Añadir",
314
+ delete: "Eliminar",
315
+ newLabel: "Nueva etiqueta",
316
+ reachedLimit_other: "No puede haber más de {{count}} categorías.",
317
+ keyLegend: {
318
+ incorrectAnswer: "Respuesta incorrecta del estudiante",
319
+ correctAnswer: "Respuesta correcta del estudiante",
320
+ correctKeyAnswer: "Clave de respuesta correcta"
321
+ }
322
+ },
323
+ graphing: {
324
+ point: "Punto",
325
+ circle: "Circulo",
326
+ line: "Línea",
327
+ parabola: "Parábola",
328
+ absolute: "Valor absoluto",
329
+ exponential: "Exponencial",
330
+ polygon: "Polígono",
331
+ ray: "Semirrecta",
332
+ segment: "Segmento ",
333
+ sine: "Seno",
334
+ vector: "Vector",
335
+ label: "Etiqueta",
336
+ redo: "Rehacer",
337
+ reset: "Reiniciar"
338
+ },
339
+ mathInline: { primaryCorrectWithAlternates: "Nota: La respuesta que se muestra arriba es la respuesta correcta principal especificada por el autor para esta pregunta, pero también se pueden reconocer otras respuestas como correctas." },
340
+ multipleChoice: {
341
+ minSelections: "Seleccione al menos {{minSelections}}.",
342
+ maxSelections_one: "Sólo se permite {{maxSelections}} respuesta.",
343
+ maxSelections_other: "Sólo se permiten {{maxSelections}} respuestas.",
344
+ minmaxSelections_equal: "Seleccione {{minSelections}}.",
345
+ minmaxSelections_range: "Seleccione entre {{minSelections}} y {{maxSelections}}."
346
+ },
347
+ selectText: {
348
+ correctAnswerSelected: "Respuesta Correcta",
349
+ correctAnswerNotSelected: "Respuesta Correcta No Seleccionada",
350
+ incorrectSelection: "Selección Incorrecta",
351
+ key: "Clave"
352
+ }
353
+ },
354
+ common: {
355
+ undo: "Deshacer",
356
+ clearAll: "Borrar todo",
357
+ correct: "Correct",
358
+ incorrect: "Incorrect",
359
+ showCorrectAnswer: "Mostrar respuesta correcta",
360
+ hideCorrectAnswer: "Ocultar respuesta correcta",
361
+ commonCorrectAnswerWithAlternates: "Nota: La respuesta que se muestra arriba es la respuesta correcta más común para esta pregunta. También se definen una o más respuestas correctas adicionales, y también se reconocerán como correctas.",
362
+ warning: "Advertencia",
363
+ showNote: "Mostrar Nota",
364
+ hideNote: "Ocultar Nota",
365
+ cancel: "Cancelar"
366
+ }
367
+ }, j = (e) => typeof e == "string", M = () => {
368
+ let e, t, n = new Promise((n, r) => {
369
+ e = n, t = r;
370
+ });
371
+ return n.resolve = e, n.reject = t, n;
372
+ }, ce = (e) => e == null ? "" : "" + e, le = (e, t, n) => {
373
+ e.forEach((e) => {
374
+ t[e] && (n[e] = t[e]);
375
+ });
376
+ }, ue = /###/g, de = (e) => e && e.indexOf("###") > -1 ? e.replace(ue, ".") : e, fe = (e) => !e || j(e), N = (e, t, n) => {
377
+ let r = j(t) ? t.split(".") : t, i = 0;
378
+ for (; i < r.length - 1;) {
379
+ if (fe(e)) return {};
380
+ let t = de(r[i]);
381
+ !e[t] && n && (e[t] = new n()), e = Object.prototype.hasOwnProperty.call(e, t) ? e[t] : {}, ++i;
382
+ }
383
+ return fe(e) ? {} : {
384
+ obj: e,
385
+ k: de(r[i])
386
+ };
387
+ }, pe = (e, t, n) => {
388
+ let { obj: r, k: i } = N(e, t, Object);
389
+ if (r !== void 0 || t.length === 1) {
390
+ r[i] = n;
391
+ return;
392
+ }
393
+ let a = t[t.length - 1], o = t.slice(0, t.length - 1), s = N(e, o, Object);
394
+ for (; s.obj === void 0 && o.length;) a = `${o[o.length - 1]}.${a}`, o = o.slice(0, o.length - 1), s = N(e, o, Object), s?.obj && s.obj[`${s.k}.${a}`] !== void 0 && (s.obj = void 0);
395
+ s.obj[`${s.k}.${a}`] = n;
396
+ }, me = (e, t, n, r) => {
397
+ let { obj: i, k: a } = N(e, t, Object);
398
+ i[a] = i[a] || [], i[a].push(n);
399
+ }, P = (e, t) => {
400
+ let { obj: n, k: r } = N(e, t);
401
+ if (n && Object.prototype.hasOwnProperty.call(n, r)) return n[r];
402
+ }, he = (e, t, n) => {
403
+ let r = P(e, n);
404
+ return r === void 0 ? P(t, n) : r;
405
+ }, ge = (e, t, n) => {
406
+ for (let r in t) r !== "__proto__" && r !== "constructor" && (r in e ? j(e[r]) || e[r] instanceof String || j(t[r]) || t[r] instanceof String ? n && (e[r] = t[r]) : ge(e[r], t[r], n) : e[r] = t[r]);
407
+ return e;
408
+ }, F = (e) => e.replace(/[\-\[\]\/\{\}\(\)\*\+\?\.\\\^\$\|]/g, "\\$&"), _e = {
409
+ "&": "&amp;",
410
+ "<": "&lt;",
411
+ ">": "&gt;",
412
+ "\"": "&quot;",
413
+ "'": "&#39;",
414
+ "/": "&#x2F;"
415
+ }, ve = (e) => j(e) ? e.replace(/[&<>"'\/]/g, (e) => _e[e]) : e, ye = class {
416
+ constructor(e) {
417
+ this.capacity = e, this.regExpMap = /* @__PURE__ */ new Map(), this.regExpQueue = [];
418
+ }
419
+ getRegExp(e) {
420
+ let t = this.regExpMap.get(e);
421
+ if (t !== void 0) return t;
422
+ let n = new RegExp(e);
423
+ return this.regExpQueue.length === this.capacity && this.regExpMap.delete(this.regExpQueue.shift()), this.regExpMap.set(e, n), this.regExpQueue.push(e), n;
424
+ }
425
+ }, be = [
426
+ " ",
427
+ ",",
428
+ "?",
429
+ "!",
430
+ ";"
431
+ ], xe = new ye(20), Se = (e, t, n) => {
432
+ t ||= "", n ||= "";
433
+ let r = be.filter((e) => t.indexOf(e) < 0 && n.indexOf(e) < 0);
434
+ if (r.length === 0) return !0;
435
+ let i = xe.getRegExp(`(${r.map((e) => e === "?" ? "\\?" : e).join("|")})`), a = !i.test(e);
436
+ if (!a) {
437
+ let t = e.indexOf(n);
438
+ t > 0 && !i.test(e.substring(0, t)) && (a = !0);
439
+ }
440
+ return a;
441
+ }, Ce = (e, t, n = ".") => {
442
+ if (!e) return;
443
+ if (e[t]) return Object.prototype.hasOwnProperty.call(e, t) ? e[t] : void 0;
444
+ let r = t.split(n), i = e;
445
+ for (let e = 0; e < r.length;) {
446
+ if (!i || typeof i != "object") return;
447
+ let t, a = "";
448
+ for (let o = e; o < r.length; ++o) if (o !== e && (a += n), a += r[o], t = i[a], t !== void 0) {
449
+ if ([
450
+ "string",
451
+ "number",
452
+ "boolean"
453
+ ].indexOf(typeof t) > -1 && o < r.length - 1) continue;
454
+ e += o - e + 1;
455
+ break;
456
+ }
457
+ i = t;
458
+ }
459
+ return i;
460
+ }, I = (e) => e?.replace(/_/g, "-"), we = {
461
+ type: "logger",
462
+ log(e) {
463
+ this.output("log", e);
464
+ },
465
+ warn(e) {
466
+ this.output("warn", e);
467
+ },
468
+ error(e) {
469
+ this.output("error", e);
470
+ },
471
+ output(e, t) {
472
+ console?.[e]?.apply?.(console, t);
473
+ }
474
+ }, L = new class e {
475
+ constructor(e, t = {}) {
476
+ this.init(e, t);
477
+ }
478
+ init(e, t = {}) {
479
+ this.prefix = t.prefix || "i18next:", this.logger = e || we, this.options = t, this.debug = t.debug;
480
+ }
481
+ log(...e) {
482
+ return this.forward(e, "log", "", !0);
483
+ }
484
+ warn(...e) {
485
+ return this.forward(e, "warn", "", !0);
486
+ }
487
+ error(...e) {
488
+ return this.forward(e, "error", "");
489
+ }
490
+ deprecate(...e) {
491
+ return this.forward(e, "warn", "WARNING DEPRECATED: ", !0);
492
+ }
493
+ forward(e, t, n, r) {
494
+ return r && !this.debug ? null : (j(e[0]) && (e[0] = `${n}${this.prefix} ${e[0]}`), this.logger[t](e));
495
+ }
496
+ create(t) {
497
+ return new e(this.logger, {
498
+ prefix: `${this.prefix}:${t}:`,
499
+ ...this.options
500
+ });
501
+ }
502
+ clone(t) {
503
+ return t ||= this.options, t.prefix = t.prefix || this.prefix, new e(this.logger, t);
504
+ }
505
+ }(), Te = class {
506
+ constructor() {
507
+ this.observers = {};
508
+ }
509
+ on(e, t) {
510
+ return e.split(" ").forEach((e) => {
511
+ this.observers[e] || (this.observers[e] = /* @__PURE__ */ new Map());
512
+ let n = this.observers[e].get(t) || 0;
513
+ this.observers[e].set(t, n + 1);
514
+ }), this;
515
+ }
516
+ off(e, t) {
517
+ if (this.observers[e]) {
518
+ if (!t) {
519
+ delete this.observers[e];
520
+ return;
521
+ }
522
+ this.observers[e].delete(t);
523
+ }
524
+ }
525
+ emit(e, ...t) {
526
+ this.observers[e] && Array.from(this.observers[e].entries()).forEach(([e, n]) => {
527
+ for (let r = 0; r < n; r++) e(...t);
528
+ }), this.observers["*"] && Array.from(this.observers["*"].entries()).forEach(([n, r]) => {
529
+ for (let i = 0; i < r; i++) n.apply(n, [e, ...t]);
530
+ });
531
+ }
532
+ }, Ee = class extends Te {
533
+ constructor(e, t = {
534
+ ns: ["translation"],
535
+ defaultNS: "translation"
536
+ }) {
537
+ super(), this.data = e || {}, this.options = t, this.options.keySeparator === void 0 && (this.options.keySeparator = "."), this.options.ignoreJSONStructure === void 0 && (this.options.ignoreJSONStructure = !0);
538
+ }
539
+ addNamespaces(e) {
540
+ this.options.ns.indexOf(e) < 0 && this.options.ns.push(e);
541
+ }
542
+ removeNamespaces(e) {
543
+ let t = this.options.ns.indexOf(e);
544
+ t > -1 && this.options.ns.splice(t, 1);
545
+ }
546
+ getResource(e, t, n, r = {}) {
547
+ let i = r.keySeparator === void 0 ? this.options.keySeparator : r.keySeparator, a = r.ignoreJSONStructure === void 0 ? this.options.ignoreJSONStructure : r.ignoreJSONStructure, o;
548
+ e.indexOf(".") > -1 ? o = e.split(".") : (o = [e, t], n && (Array.isArray(n) ? o.push(...n) : j(n) && i ? o.push(...n.split(i)) : o.push(n)));
549
+ let s = P(this.data, o);
550
+ return !s && !t && !n && e.indexOf(".") > -1 && (e = o[0], t = o[1], n = o.slice(2).join(".")), s || !a || !j(n) ? s : Ce(this.data?.[e]?.[t], n, i);
551
+ }
552
+ addResource(e, t, n, r, i = { silent: !1 }) {
553
+ let a = i.keySeparator === void 0 ? this.options.keySeparator : i.keySeparator, o = [e, t];
554
+ n && (o = o.concat(a ? n.split(a) : n)), e.indexOf(".") > -1 && (o = e.split("."), r = t, t = o[1]), this.addNamespaces(t), pe(this.data, o, r), i.silent || this.emit("added", e, t, n, r);
555
+ }
556
+ addResources(e, t, n, r = { silent: !1 }) {
557
+ for (let r in n) (j(n[r]) || Array.isArray(n[r])) && this.addResource(e, t, r, n[r], { silent: !0 });
558
+ r.silent || this.emit("added", e, t, n);
559
+ }
560
+ addResourceBundle(e, t, n, r, i, a = {
561
+ silent: !1,
562
+ skipCopy: !1
563
+ }) {
564
+ let o = [e, t];
565
+ e.indexOf(".") > -1 && (o = e.split("."), r = n, n = t, t = o[1]), this.addNamespaces(t);
566
+ let s = P(this.data, o) || {};
567
+ a.skipCopy || (n = JSON.parse(JSON.stringify(n))), r ? ge(s, n, i) : s = {
568
+ ...s,
569
+ ...n
570
+ }, pe(this.data, o, s), a.silent || this.emit("added", e, t, n);
571
+ }
572
+ removeResourceBundle(e, t) {
573
+ this.hasResourceBundle(e, t) && delete this.data[e][t], this.removeNamespaces(t), this.emit("removed", e, t);
574
+ }
575
+ hasResourceBundle(e, t) {
576
+ return this.getResource(e, t) !== void 0;
577
+ }
578
+ getResourceBundle(e, t) {
579
+ return t ||= this.options.defaultNS, this.getResource(e, t);
580
+ }
581
+ getDataByLanguage(e) {
582
+ return this.data[e];
583
+ }
584
+ hasLanguageSomeTranslations(e) {
585
+ let t = this.getDataByLanguage(e);
586
+ return !!(t && Object.keys(t) || []).find((e) => t[e] && Object.keys(t[e]).length > 0);
587
+ }
588
+ toJSON() {
589
+ return this.data;
590
+ }
591
+ }, De = {
592
+ processors: {},
593
+ addPostProcessor(e) {
594
+ this.processors[e.name] = e;
595
+ },
596
+ handle(e, t, n, r, i) {
597
+ return e.forEach((e) => {
598
+ t = this.processors[e]?.process(t, n, r, i) ?? t;
599
+ }), t;
600
+ }
601
+ }, Oe = Symbol("i18next/PATH_KEY");
602
+ function ke() {
603
+ let e = [], t = Object.create(null), n;
604
+ return t.get = (r, i) => (n?.revoke?.(), i === Oe ? e : (e.push(i), n = Proxy.revocable(r, t), n.proxy)), Proxy.revocable(Object.create(null), t).proxy;
605
+ }
606
+ function R(e, t) {
607
+ let { [Oe]: n } = e(ke()), r = t?.keySeparator ?? ".", i = t?.nsSeparator ?? ":";
608
+ if (n.length > 1 && i) {
609
+ let e = t?.ns, a = Array.isArray(e) ? e : null;
610
+ if (a && a.length > 1 && a.slice(1).includes(n[0])) return `${n[0]}${i}${n.slice(1).join(r)}`;
611
+ }
612
+ return n.join(r);
613
+ }
614
+ var Ae = {}, je = (e) => !j(e) && typeof e != "boolean" && typeof e != "number", Me = class e extends Te {
615
+ constructor(e, t = {}) {
616
+ super(), le([
617
+ "resourceStore",
618
+ "languageUtils",
619
+ "pluralResolver",
620
+ "interpolator",
621
+ "backendConnector",
622
+ "i18nFormat",
623
+ "utils"
624
+ ], e, this), this.options = t, this.options.keySeparator === void 0 && (this.options.keySeparator = "."), this.logger = L.create("translator");
625
+ }
626
+ changeLanguage(e) {
627
+ e && (this.language = e);
628
+ }
629
+ exists(e, t = { interpolation: {} }) {
630
+ let n = { ...t };
631
+ if (e == null) return !1;
632
+ let r = this.resolve(e, n);
633
+ if (r?.res === void 0) return !1;
634
+ let i = je(r.res);
635
+ return !(n.returnObjects === !1 && i);
636
+ }
637
+ extractFromKey(e, t) {
638
+ let n = t.nsSeparator === void 0 ? this.options.nsSeparator : t.nsSeparator;
639
+ n === void 0 && (n = ":");
640
+ let r = t.keySeparator === void 0 ? this.options.keySeparator : t.keySeparator, i = t.ns || this.options.defaultNS || [], a = n && e.indexOf(n) > -1, o = !this.options.userDefinedKeySeparator && !t.keySeparator && !this.options.userDefinedNsSeparator && !t.nsSeparator && !Se(e, n, r);
641
+ if (a && !o) {
642
+ let t = e.match(this.interpolator.nestingRegexp);
643
+ if (t && t.length > 0) return {
644
+ key: e,
645
+ namespaces: j(i) ? [i] : i
646
+ };
647
+ let a = e.split(n);
648
+ (n !== r || n === r && this.options.ns.indexOf(a[0]) > -1) && (i = a.shift()), e = a.join(r);
649
+ }
650
+ return {
651
+ key: e,
652
+ namespaces: j(i) ? [i] : i
653
+ };
654
+ }
655
+ translate(t, n, r) {
656
+ let i = typeof n == "object" ? { ...n } : n;
657
+ if (typeof i != "object" && this.options.overloadTranslationOptionHandler && (i = this.options.overloadTranslationOptionHandler(arguments)), typeof i == "object" && (i = { ...i }), i ||= {}, t == null) return "";
658
+ typeof t == "function" && (t = R(t, {
659
+ ...this.options,
660
+ ...i
661
+ })), Array.isArray(t) || (t = [String(t)]), t = t.map((e) => typeof e == "function" ? R(e, {
662
+ ...this.options,
663
+ ...i
664
+ }) : String(e));
665
+ let a = i.returnDetails === void 0 ? this.options.returnDetails : i.returnDetails, o = i.keySeparator === void 0 ? this.options.keySeparator : i.keySeparator, { key: s, namespaces: c } = this.extractFromKey(t[t.length - 1], i), l = c[c.length - 1], u = i.nsSeparator === void 0 ? this.options.nsSeparator : i.nsSeparator;
666
+ u === void 0 && (u = ":");
667
+ let d = i.lng || this.language, f = i.appendNamespaceToCIMode || this.options.appendNamespaceToCIMode;
668
+ if (d?.toLowerCase() === "cimode") return f ? a ? {
669
+ res: `${l}${u}${s}`,
670
+ usedKey: s,
671
+ exactUsedKey: s,
672
+ usedLng: d,
673
+ usedNS: l,
674
+ usedParams: this.getUsedParamsDetails(i)
675
+ } : `${l}${u}${s}` : a ? {
676
+ res: s,
677
+ usedKey: s,
678
+ exactUsedKey: s,
679
+ usedLng: d,
680
+ usedNS: l,
681
+ usedParams: this.getUsedParamsDetails(i)
682
+ } : s;
683
+ let p = this.resolve(t, i), m = p?.res, h = p?.usedKey || s, g = p?.exactUsedKey || s, _ = [
684
+ "[object Number]",
685
+ "[object Function]",
686
+ "[object RegExp]"
687
+ ], v = i.joinArrays === void 0 ? this.options.joinArrays : i.joinArrays, y = !this.i18nFormat || this.i18nFormat.handleAsObject, b = i.count !== void 0 && !j(i.count), x = e.hasDefaultValue(i), S = b ? this.pluralResolver.getSuffix(d, i.count, i) : "", C = i.ordinal && b ? this.pluralResolver.getSuffix(d, i.count, { ordinal: !1 }) : "", w = b && !i.ordinal && i.count === 0, T = w && i[`defaultValue${this.options.pluralSeparator}zero`] || i[`defaultValue${S}`] || i[`defaultValue${C}`] || i.defaultValue, E = m;
688
+ y && !m && x && (E = T);
689
+ let D = je(E), O = Object.prototype.toString.apply(E);
690
+ if (y && E && D && _.indexOf(O) < 0 && !(j(v) && Array.isArray(E))) {
691
+ if (!i.returnObjects && !this.options.returnObjects) {
692
+ this.options.returnedObjectHandler || this.logger.warn("accessing an object - but returnObjects options is not enabled!");
693
+ let e = this.options.returnedObjectHandler ? this.options.returnedObjectHandler(h, E, {
694
+ ...i,
695
+ ns: c
696
+ }) : `key '${s} (${this.language})' returned an object instead of string.`;
697
+ return a ? (p.res = e, p.usedParams = this.getUsedParamsDetails(i), p) : e;
698
+ }
699
+ if (o) {
700
+ let e = Array.isArray(E), t = e ? [] : {}, n = e ? g : h;
701
+ for (let e in E) if (Object.prototype.hasOwnProperty.call(E, e)) {
702
+ let r = `${n}${o}${e}`;
703
+ x && !m ? t[e] = this.translate(r, {
704
+ ...i,
705
+ defaultValue: je(T) ? T[e] : void 0,
706
+ joinArrays: !1,
707
+ ns: c
708
+ }) : t[e] = this.translate(r, {
709
+ ...i,
710
+ joinArrays: !1,
711
+ ns: c
712
+ }), t[e] === r && (t[e] = E[e]);
713
+ }
714
+ m = t;
715
+ }
716
+ } else if (y && j(v) && Array.isArray(m)) m = m.join(v), m &&= this.extendTranslation(m, t, i, r);
717
+ else {
718
+ let e = !1, n = !1;
719
+ !this.isValidLookup(m) && x && (e = !0, m = T), this.isValidLookup(m) || (n = !0, m = s);
720
+ let a = (i.missingKeyNoValueFallbackToKey || this.options.missingKeyNoValueFallbackToKey) && n ? void 0 : m, c = x && T !== m && this.options.updateMissing;
721
+ if (n || e || c) {
722
+ if (this.logger.log(c ? "updateKey" : "missingKey", d, l, s, c ? T : m), o) {
723
+ let e = this.resolve(s, {
724
+ ...i,
725
+ keySeparator: !1
726
+ });
727
+ e && e.res && this.logger.warn("Seems the loaded translations were in flat JSON format instead of nested. Either set keySeparator: false on init or make sure your translations are published in nested format.");
728
+ }
729
+ let e = [], t = this.languageUtils.getFallbackCodes(this.options.fallbackLng, i.lng || this.language);
730
+ if (this.options.saveMissingTo === "fallback" && t && t[0]) for (let n = 0; n < t.length; n++) e.push(t[n]);
731
+ else this.options.saveMissingTo === "all" ? e = this.languageUtils.toResolveHierarchy(i.lng || this.language) : e.push(i.lng || this.language);
732
+ let n = (e, t, n) => {
733
+ let r = x && n !== m ? n : a;
734
+ this.options.missingKeyHandler ? this.options.missingKeyHandler(e, l, t, r, c, i) : this.backendConnector?.saveMissing && this.backendConnector.saveMissing(e, l, t, r, c, i), this.emit("missingKey", e, l, t, m);
735
+ };
736
+ this.options.saveMissing && (this.options.saveMissingPlurals && b ? e.forEach((e) => {
737
+ let t = this.pluralResolver.getSuffixes(e, i);
738
+ w && i[`defaultValue${this.options.pluralSeparator}zero`] && t.indexOf(`${this.options.pluralSeparator}zero`) < 0 && t.push(`${this.options.pluralSeparator}zero`), t.forEach((t) => {
739
+ n([e], s + t, i[`defaultValue${t}`] || T);
740
+ });
741
+ }) : n(e, s, T));
742
+ }
743
+ m = this.extendTranslation(m, t, i, p, r), n && m === s && this.options.appendNamespaceToMissingKey && (m = `${l}${u}${s}`), (n || e) && this.options.parseMissingKeyHandler && (m = this.options.parseMissingKeyHandler(this.options.appendNamespaceToMissingKey ? `${l}${u}${s}` : s, e ? m : void 0, i));
744
+ }
745
+ return a ? (p.res = m, p.usedParams = this.getUsedParamsDetails(i), p) : m;
746
+ }
747
+ extendTranslation(e, t, n, r, i) {
748
+ if (this.i18nFormat?.parse) e = this.i18nFormat.parse(e, {
749
+ ...this.options.interpolation.defaultVariables,
750
+ ...n
751
+ }, n.lng || this.language || r.usedLng, r.usedNS, r.usedKey, { resolved: r });
752
+ else if (!n.skipInterpolation) {
753
+ n.interpolation && this.interpolator.init({
754
+ ...n,
755
+ interpolation: {
756
+ ...this.options.interpolation,
757
+ ...n.interpolation
758
+ }
759
+ });
760
+ let a = j(e) && (n?.interpolation?.skipOnVariables === void 0 ? this.options.interpolation.skipOnVariables : n.interpolation.skipOnVariables), o;
761
+ if (a) {
762
+ let t = e.match(this.interpolator.nestingRegexp);
763
+ o = t && t.length;
764
+ }
765
+ let s = n.replace && !j(n.replace) ? n.replace : n;
766
+ if (this.options.interpolation.defaultVariables && (s = {
767
+ ...this.options.interpolation.defaultVariables,
768
+ ...s
769
+ }), e = this.interpolator.interpolate(e, s, n.lng || this.language || r.usedLng, n), a) {
770
+ let t = e.match(this.interpolator.nestingRegexp), r = t && t.length;
771
+ o < r && (n.nest = !1);
772
+ }
773
+ !n.lng && r && r.res && (n.lng = this.language || r.usedLng), n.nest !== !1 && (e = this.interpolator.nest(e, (...e) => i?.[0] === e[0] && !n.context ? (this.logger.warn(`It seems you are nesting recursively key: ${e[0]} in key: ${t[0]}`), null) : this.translate(...e, t), n)), n.interpolation && this.interpolator.reset();
774
+ }
775
+ let a = n.postProcess || this.options.postProcess, o = j(a) ? [a] : a;
776
+ return e != null && o?.length && n.applyPostProcessor !== !1 && (e = De.handle(o, e, t, this.options && this.options.postProcessPassResolved ? {
777
+ i18nResolved: {
778
+ ...r,
779
+ usedParams: this.getUsedParamsDetails(n)
780
+ },
781
+ ...n
782
+ } : n, this)), e;
783
+ }
784
+ resolve(e, t = {}) {
785
+ let n, r, i, a, o;
786
+ return j(e) && (e = [e]), Array.isArray(e) && (e = e.map((e) => typeof e == "function" ? R(e, {
787
+ ...this.options,
788
+ ...t
789
+ }) : e)), e.forEach((e) => {
790
+ if (this.isValidLookup(n)) return;
791
+ let s = this.extractFromKey(e, t), c = s.key;
792
+ r = c;
793
+ let l = s.namespaces;
794
+ this.options.fallbackNS && (l = l.concat(this.options.fallbackNS));
795
+ let u = t.count !== void 0 && !j(t.count), d = u && !t.ordinal && t.count === 0, f = t.context !== void 0 && (j(t.context) || typeof t.context == "number") && t.context !== "", p = t.lngs ? t.lngs : this.languageUtils.toResolveHierarchy(t.lng || this.language, t.fallbackLng);
796
+ l.forEach((e) => {
797
+ this.isValidLookup(n) || (o = e, !Ae[`${p[0]}-${e}`] && this.utils?.hasLoadedNamespace && !this.utils?.hasLoadedNamespace(o) && (Ae[`${p[0]}-${e}`] = !0, this.logger.warn(`key "${r}" for languages "${p.join(", ")}" won't get resolved as namespace "${o}" was not yet loaded`, "This means something IS WRONG in your setup. You access the t function before i18next.init / i18next.loadNamespace / i18next.changeLanguage was done. Wait for the callback or Promise to resolve before accessing it!!!")), p.forEach((r) => {
798
+ if (this.isValidLookup(n)) return;
799
+ a = r;
800
+ let o = [c];
801
+ if (this.i18nFormat?.addLookupKeys) this.i18nFormat.addLookupKeys(o, c, r, e, t);
802
+ else {
803
+ let e;
804
+ u && (e = this.pluralResolver.getSuffix(r, t.count, t));
805
+ let n = `${this.options.pluralSeparator}zero`, i = `${this.options.pluralSeparator}ordinal${this.options.pluralSeparator}`;
806
+ if (u && (t.ordinal && e.indexOf(i) === 0 && o.push(c + e.replace(i, this.options.pluralSeparator)), o.push(c + e), d && o.push(c + n)), f) {
807
+ let r = `${c}${this.options.contextSeparator || "_"}${t.context}`;
808
+ o.push(r), u && (t.ordinal && e.indexOf(i) === 0 && o.push(r + e.replace(i, this.options.pluralSeparator)), o.push(r + e), d && o.push(r + n));
809
+ }
810
+ }
811
+ let s;
812
+ for (; s = o.pop();) this.isValidLookup(n) || (i = s, n = this.getResource(r, e, s, t));
813
+ }));
814
+ });
815
+ }), {
816
+ res: n,
817
+ usedKey: r,
818
+ exactUsedKey: i,
819
+ usedLng: a,
820
+ usedNS: o
821
+ };
822
+ }
823
+ isValidLookup(e) {
824
+ return e !== void 0 && !(!this.options.returnNull && e === null) && !(!this.options.returnEmptyString && e === "");
825
+ }
826
+ getResource(e, t, n, r = {}) {
827
+ return this.i18nFormat?.getResource ? this.i18nFormat.getResource(e, t, n, r) : this.resourceStore.getResource(e, t, n, r);
828
+ }
829
+ getUsedParamsDetails(e = {}) {
830
+ let t = [
831
+ "defaultValue",
832
+ "ordinal",
833
+ "context",
834
+ "replace",
835
+ "lng",
836
+ "lngs",
837
+ "fallbackLng",
838
+ "ns",
839
+ "keySeparator",
840
+ "nsSeparator",
841
+ "returnObjects",
842
+ "returnDetails",
843
+ "joinArrays",
844
+ "postProcess",
845
+ "interpolation"
846
+ ], n = e.replace && !j(e.replace), r = n ? e.replace : e;
847
+ if (n && e.count !== void 0 && (r.count = e.count), this.options.interpolation.defaultVariables && (r = {
848
+ ...this.options.interpolation.defaultVariables,
849
+ ...r
850
+ }), !n) {
851
+ r = { ...r };
852
+ for (let e of t) delete r[e];
853
+ }
854
+ return r;
855
+ }
856
+ static hasDefaultValue(e) {
857
+ for (let t in e) if (Object.prototype.hasOwnProperty.call(e, t) && t.substring(0, 12) === "defaultValue" && e[t] !== void 0) return !0;
858
+ return !1;
859
+ }
860
+ }, Ne = class {
861
+ constructor(e) {
862
+ this.options = e, this.supportedLngs = this.options.supportedLngs || !1, this.logger = L.create("languageUtils");
863
+ }
864
+ getScriptPartFromCode(e) {
865
+ if (e = I(e), !e || e.indexOf("-") < 0) return null;
866
+ let t = e.split("-");
867
+ return t.length === 2 || (t.pop(), t[t.length - 1].toLowerCase() === "x") ? null : this.formatLanguageCode(t.join("-"));
868
+ }
869
+ getLanguagePartFromCode(e) {
870
+ if (e = I(e), !e || e.indexOf("-") < 0) return e;
871
+ let t = e.split("-");
872
+ return this.formatLanguageCode(t[0]);
873
+ }
874
+ formatLanguageCode(e) {
875
+ if (j(e) && e.indexOf("-") > -1) {
876
+ let t;
877
+ try {
878
+ t = Intl.getCanonicalLocales(e)[0];
879
+ } catch {}
880
+ return t && this.options.lowerCaseLng && (t = t.toLowerCase()), t || (this.options.lowerCaseLng ? e.toLowerCase() : e);
881
+ }
882
+ return this.options.cleanCode || this.options.lowerCaseLng ? e.toLowerCase() : e;
883
+ }
884
+ isSupportedCode(e) {
885
+ return (this.options.load === "languageOnly" || this.options.nonExplicitSupportedLngs) && (e = this.getLanguagePartFromCode(e)), !this.supportedLngs || !this.supportedLngs.length || this.supportedLngs.indexOf(e) > -1;
886
+ }
887
+ getBestMatchFromCodes(e) {
888
+ if (!e) return null;
889
+ let t;
890
+ return e.forEach((e) => {
891
+ if (t) return;
892
+ let n = this.formatLanguageCode(e);
893
+ (!this.options.supportedLngs || this.isSupportedCode(n)) && (t = n);
894
+ }), !t && this.options.supportedLngs && e.forEach((e) => {
895
+ if (t) return;
896
+ let n = this.getScriptPartFromCode(e);
897
+ if (this.isSupportedCode(n)) return t = n;
898
+ let r = this.getLanguagePartFromCode(e);
899
+ if (this.isSupportedCode(r)) return t = r;
900
+ t = this.options.supportedLngs.find((e) => {
901
+ if (e === r || !(e.indexOf("-") < 0 && r.indexOf("-") < 0) && (e.indexOf("-") > 0 && r.indexOf("-") < 0 && e.substring(0, e.indexOf("-")) === r || e.indexOf(r) === 0 && r.length > 1)) return e;
902
+ });
903
+ }), t ||= this.getFallbackCodes(this.options.fallbackLng)[0], t;
904
+ }
905
+ getFallbackCodes(e, t) {
906
+ if (!e) return [];
907
+ if (typeof e == "function" && (e = e(t)), j(e) && (e = [e]), Array.isArray(e)) return e;
908
+ if (!t) return e.default || [];
909
+ let n = e[t];
910
+ return n ||= e[this.getScriptPartFromCode(t)], n ||= e[this.formatLanguageCode(t)], n ||= e[this.getLanguagePartFromCode(t)], n ||= e.default, n || [];
911
+ }
912
+ toResolveHierarchy(e, t) {
913
+ let n = this.getFallbackCodes((t === !1 ? [] : t) || this.options.fallbackLng || [], e), r = [], i = (e) => {
914
+ e && (this.isSupportedCode(e) ? r.push(e) : this.logger.warn(`rejecting language code not found in supportedLngs: ${e}`));
915
+ };
916
+ return j(e) && (e.indexOf("-") > -1 || e.indexOf("_") > -1) ? (this.options.load !== "languageOnly" && i(this.formatLanguageCode(e)), this.options.load !== "languageOnly" && this.options.load !== "currentOnly" && i(this.getScriptPartFromCode(e)), this.options.load !== "currentOnly" && i(this.getLanguagePartFromCode(e))) : j(e) && i(this.formatLanguageCode(e)), n.forEach((e) => {
917
+ r.indexOf(e) < 0 && i(this.formatLanguageCode(e));
918
+ }), r;
919
+ }
920
+ }, Pe = {
921
+ zero: 0,
922
+ one: 1,
923
+ two: 2,
924
+ few: 3,
925
+ many: 4,
926
+ other: 5
927
+ }, Fe = {
928
+ select: (e) => e === 1 ? "one" : "other",
929
+ resolvedOptions: () => ({ pluralCategories: ["one", "other"] })
930
+ }, Ie = class {
931
+ constructor(e, t = {}) {
932
+ this.languageUtils = e, this.options = t, this.logger = L.create("pluralResolver"), this.pluralRulesCache = {};
933
+ }
934
+ clearCache() {
935
+ this.pluralRulesCache = {};
936
+ }
937
+ getRule(e, t = {}) {
938
+ let n = I(e === "dev" ? "en" : e), r = t.ordinal ? "ordinal" : "cardinal", i = JSON.stringify({
939
+ cleanedCode: n,
940
+ type: r
941
+ });
942
+ if (i in this.pluralRulesCache) return this.pluralRulesCache[i];
943
+ let a;
944
+ try {
945
+ a = new Intl.PluralRules(n, { type: r });
946
+ } catch {
947
+ if (typeof Intl > "u") return this.logger.error("No Intl support, please use an Intl polyfill!"), Fe;
948
+ if (!e.match(/-|_/)) return Fe;
949
+ let n = this.languageUtils.getLanguagePartFromCode(e);
950
+ a = this.getRule(n, t);
951
+ }
952
+ return this.pluralRulesCache[i] = a, a;
953
+ }
954
+ needsPlural(e, t = {}) {
955
+ let n = this.getRule(e, t);
956
+ return n ||= this.getRule("dev", t), n?.resolvedOptions().pluralCategories.length > 1;
957
+ }
958
+ getPluralFormsOfKey(e, t, n = {}) {
959
+ return this.getSuffixes(e, n).map((e) => `${t}${e}`);
960
+ }
961
+ getSuffixes(e, t = {}) {
962
+ let n = this.getRule(e, t);
963
+ return n ||= this.getRule("dev", t), n ? n.resolvedOptions().pluralCategories.sort((e, t) => Pe[e] - Pe[t]).map((e) => `${this.options.prepend}${t.ordinal ? `ordinal${this.options.prepend}` : ""}${e}`) : [];
964
+ }
965
+ getSuffix(e, t, n = {}) {
966
+ let r = this.getRule(e, n);
967
+ return r ? `${this.options.prepend}${n.ordinal ? `ordinal${this.options.prepend}` : ""}${r.select(t)}` : (this.logger.warn(`no plural rule found for: ${e}`), this.getSuffix("dev", t, n));
968
+ }
969
+ }, Le = (e, t, n, r = ".", i = !0) => {
970
+ let a = he(e, t, n);
971
+ return !a && i && j(n) && (a = Ce(e, n, r), a === void 0 && (a = Ce(t, n, r))), a;
972
+ }, Re = (e) => e.replace(/\$/g, "$$$$"), ze = class {
973
+ constructor(e = {}) {
974
+ this.logger = L.create("interpolator"), this.options = e, this.format = e?.interpolation?.format || ((e) => e), this.init(e);
975
+ }
976
+ init(e = {}) {
977
+ e.interpolation ||= { escapeValue: !0 };
978
+ let { escape: t, escapeValue: n, useRawValueToEscape: r, prefix: i, prefixEscaped: a, suffix: o, suffixEscaped: s, formatSeparator: c, unescapeSuffix: l, unescapePrefix: u, nestingPrefix: d, nestingPrefixEscaped: f, nestingSuffix: p, nestingSuffixEscaped: m, nestingOptionsSeparator: h, maxReplaces: g, alwaysFormat: _ } = e.interpolation;
979
+ this.escape = t === void 0 ? ve : t, this.escapeValue = n === void 0 ? !0 : n, this.useRawValueToEscape = r === void 0 ? !1 : r, this.prefix = i ? F(i) : a || "{{", this.suffix = o ? F(o) : s || "}}", this.formatSeparator = c || ",", this.unescapePrefix = l ? "" : u || "-", this.unescapeSuffix = this.unescapePrefix ? "" : l || "", this.nestingPrefix = d ? F(d) : f || F("$t("), this.nestingSuffix = p ? F(p) : m || F(")"), this.nestingOptionsSeparator = h || ",", this.maxReplaces = g || 1e3, this.alwaysFormat = _ === void 0 ? !1 : _, this.resetRegExp();
980
+ }
981
+ reset() {
982
+ this.options && this.init(this.options);
983
+ }
984
+ resetRegExp() {
985
+ let e = (e, t) => e?.source === t ? (e.lastIndex = 0, e) : new RegExp(t, "g");
986
+ this.regexp = e(this.regexp, `${this.prefix}(.+?)${this.suffix}`), this.regexpUnescape = e(this.regexpUnescape, `${this.prefix}${this.unescapePrefix}(.+?)${this.unescapeSuffix}${this.suffix}`), this.nestingRegexp = e(this.nestingRegexp, `${this.nestingPrefix}((?:[^()"']+|"[^"]*"|'[^']*'|\\((?:[^()]|"[^"]*"|'[^']*')*\\))*?)${this.nestingSuffix}`);
987
+ }
988
+ interpolate(e, t, n, r) {
989
+ let i, a, o, s = this.options && this.options.interpolation && this.options.interpolation.defaultVariables || {}, c = (e) => {
990
+ if (e.indexOf(this.formatSeparator) < 0) {
991
+ let i = Le(t, s, e, this.options.keySeparator, this.options.ignoreJSONStructure);
992
+ return this.alwaysFormat ? this.format(i, void 0, n, {
993
+ ...r,
994
+ ...t,
995
+ interpolationkey: e
996
+ }) : i;
997
+ }
998
+ let i = e.split(this.formatSeparator), a = i.shift().trim(), o = i.join(this.formatSeparator).trim();
999
+ return this.format(Le(t, s, a, this.options.keySeparator, this.options.ignoreJSONStructure), o, n, {
1000
+ ...r,
1001
+ ...t,
1002
+ interpolationkey: a
1003
+ });
1004
+ };
1005
+ this.resetRegExp();
1006
+ let l = r?.missingInterpolationHandler || this.options.missingInterpolationHandler, u = r?.interpolation?.skipOnVariables === void 0 ? this.options.interpolation.skipOnVariables : r.interpolation.skipOnVariables;
1007
+ return [{
1008
+ regex: this.regexpUnescape,
1009
+ safeValue: (e) => Re(e)
1010
+ }, {
1011
+ regex: this.regexp,
1012
+ safeValue: (e) => this.escapeValue ? Re(this.escape(e)) : Re(e)
1013
+ }].forEach((t) => {
1014
+ for (o = 0; i = t.regex.exec(e);) {
1015
+ let n = i[1].trim();
1016
+ if (a = c(n), a === void 0) if (typeof l == "function") {
1017
+ let t = l(e, i, r);
1018
+ a = j(t) ? t : "";
1019
+ } else if (r && Object.prototype.hasOwnProperty.call(r, n)) a = "";
1020
+ else if (u) {
1021
+ a = i[0];
1022
+ continue;
1023
+ } else this.logger.warn(`missed to pass in variable ${n} for interpolating ${e}`), a = "";
1024
+ else !j(a) && !this.useRawValueToEscape && (a = ce(a));
1025
+ let s = t.safeValue(a);
1026
+ if (e = e.replace(i[0], s), u ? (t.regex.lastIndex += a.length, t.regex.lastIndex -= i[0].length) : t.regex.lastIndex = 0, o++, o >= this.maxReplaces) break;
1027
+ }
1028
+ }), e;
1029
+ }
1030
+ nest(e, t, n = {}) {
1031
+ let r, i, a, o = (e, t) => {
1032
+ let n = this.nestingOptionsSeparator;
1033
+ if (e.indexOf(n) < 0) return e;
1034
+ let r = e.split(RegExp(`${F(n)}[ ]*{`)), i = `{${r[1]}`;
1035
+ e = r[0], i = this.interpolate(i, a);
1036
+ let o = i.match(/'/g), s = i.match(/"/g);
1037
+ ((o?.length ?? 0) % 2 == 0 && !s || (s?.length ?? 0) % 2 != 0) && (i = i.replace(/'/g, "\""));
1038
+ try {
1039
+ a = JSON.parse(i), t && (a = {
1040
+ ...t,
1041
+ ...a
1042
+ });
1043
+ } catch (t) {
1044
+ return this.logger.warn(`failed parsing options string in nesting for key ${e}`, t), `${e}${n}${i}`;
1045
+ }
1046
+ return a.defaultValue && a.defaultValue.indexOf(this.prefix) > -1 && delete a.defaultValue, e;
1047
+ };
1048
+ for (; r = this.nestingRegexp.exec(e);) {
1049
+ let s = [];
1050
+ a = { ...n }, a = a.replace && !j(a.replace) ? a.replace : a, a.applyPostProcessor = !1, delete a.defaultValue;
1051
+ let c = /{.*}/.test(r[1]) ? r[1].lastIndexOf("}") + 1 : r[1].indexOf(this.formatSeparator);
1052
+ if (c !== -1 && (s = r[1].slice(c).split(this.formatSeparator).map((e) => e.trim()).filter(Boolean), r[1] = r[1].slice(0, c)), i = t(o.call(this, r[1].trim(), a), a), i && r[0] === e && !j(i)) return i;
1053
+ j(i) || (i = ce(i)), i ||= (this.logger.warn(`missed to resolve ${r[1]} for nesting ${e}`), ""), s.length && (i = s.reduce((e, t) => this.format(e, t, n.lng, {
1054
+ ...n,
1055
+ interpolationkey: r[1].trim()
1056
+ }), i.trim())), e = e.replace(r[0], i), this.regexp.lastIndex = 0;
1057
+ }
1058
+ return e;
1059
+ }
1060
+ }, Be = (e) => {
1061
+ let t = e.toLowerCase().trim(), n = {};
1062
+ if (e.indexOf("(") > -1) {
1063
+ let r = e.split("(");
1064
+ t = r[0].toLowerCase().trim();
1065
+ let i = r[1].substring(0, r[1].length - 1);
1066
+ t === "currency" && i.indexOf(":") < 0 ? n.currency ||= i.trim() : t === "relativetime" && i.indexOf(":") < 0 ? n.range ||= i.trim() : i.split(";").forEach((e) => {
1067
+ if (e) {
1068
+ let [t, ...r] = e.split(":"), i = r.join(":").trim().replace(/^'+|'+$/g, ""), a = t.trim();
1069
+ n[a] || (n[a] = i), i === "false" && (n[a] = !1), i === "true" && (n[a] = !0), isNaN(i) || (n[a] = parseInt(i, 10));
1070
+ }
1071
+ });
1072
+ }
1073
+ return {
1074
+ formatName: t,
1075
+ formatOptions: n
1076
+ };
1077
+ }, Ve = (e) => {
1078
+ let t = {};
1079
+ return (n, r, i) => {
1080
+ let a = i;
1081
+ i && i.interpolationkey && i.formatParams && i.formatParams[i.interpolationkey] && i[i.interpolationkey] && (a = {
1082
+ ...a,
1083
+ [i.interpolationkey]: void 0
1084
+ });
1085
+ let o = r + JSON.stringify(a), s = t[o];
1086
+ return s || (s = e(I(r), i), t[o] = s), s(n);
1087
+ };
1088
+ }, He = (e) => (t, n, r) => e(I(n), r)(t), Ue = class {
1089
+ constructor(e = {}) {
1090
+ this.logger = L.create("formatter"), this.options = e, this.init(e);
1091
+ }
1092
+ init(e, t = { interpolation: {} }) {
1093
+ this.formatSeparator = t.interpolation.formatSeparator || ",";
1094
+ let n = t.cacheInBuiltFormats ? Ve : He;
1095
+ this.formats = {
1096
+ number: n((e, t) => {
1097
+ let n = new Intl.NumberFormat(e, { ...t });
1098
+ return (e) => n.format(e);
1099
+ }),
1100
+ currency: n((e, t) => {
1101
+ let n = new Intl.NumberFormat(e, {
1102
+ ...t,
1103
+ style: "currency"
1104
+ });
1105
+ return (e) => n.format(e);
1106
+ }),
1107
+ datetime: n((e, t) => {
1108
+ let n = new Intl.DateTimeFormat(e, { ...t });
1109
+ return (e) => n.format(e);
1110
+ }),
1111
+ relativetime: n((e, t) => {
1112
+ let n = new Intl.RelativeTimeFormat(e, { ...t });
1113
+ return (e) => n.format(e, t.range || "day");
1114
+ }),
1115
+ list: n((e, t) => {
1116
+ let n = new Intl.ListFormat(e, { ...t });
1117
+ return (e) => n.format(e);
1118
+ })
1119
+ };
1120
+ }
1121
+ add(e, t) {
1122
+ this.formats[e.toLowerCase().trim()] = t;
1123
+ }
1124
+ addCached(e, t) {
1125
+ this.formats[e.toLowerCase().trim()] = Ve(t);
1126
+ }
1127
+ format(e, t, n, r = {}) {
1128
+ let i = t.split(this.formatSeparator);
1129
+ if (i.length > 1 && i[0].indexOf("(") > 1 && i[0].indexOf(")") < 0 && i.find((e) => e.indexOf(")") > -1)) {
1130
+ let e = i.findIndex((e) => e.indexOf(")") > -1);
1131
+ i[0] = [i[0], ...i.splice(1, e)].join(this.formatSeparator);
1132
+ }
1133
+ return i.reduce((e, t) => {
1134
+ let { formatName: i, formatOptions: a } = Be(t);
1135
+ if (this.formats[i]) {
1136
+ let t = e;
1137
+ try {
1138
+ let o = r?.formatParams?.[r.interpolationkey] || {}, s = o.locale || o.lng || r.locale || r.lng || n;
1139
+ t = this.formats[i](e, s, {
1140
+ ...a,
1141
+ ...r,
1142
+ ...o
1143
+ });
1144
+ } catch (e) {
1145
+ this.logger.warn(e);
1146
+ }
1147
+ return t;
1148
+ } else this.logger.warn(`there was no format function for ${i}`);
1149
+ return e;
1150
+ }, e);
1151
+ }
1152
+ }, We = (e, t) => {
1153
+ e.pending[t] !== void 0 && (delete e.pending[t], e.pendingCount--);
1154
+ }, Ge = class extends Te {
1155
+ constructor(e, t, n, r = {}) {
1156
+ super(), this.backend = e, this.store = t, this.services = n, this.languageUtils = n.languageUtils, this.options = r, this.logger = L.create("backendConnector"), this.waitingReads = [], this.maxParallelReads = r.maxParallelReads || 10, this.readingCalls = 0, this.maxRetries = r.maxRetries >= 0 ? r.maxRetries : 5, this.retryTimeout = r.retryTimeout >= 1 ? r.retryTimeout : 350, this.state = {}, this.queue = [], this.backend?.init?.(n, r.backend, r);
1157
+ }
1158
+ queueLoad(e, t, n, r) {
1159
+ let i = {}, a = {}, o = {}, s = {};
1160
+ return e.forEach((e) => {
1161
+ let r = !0;
1162
+ t.forEach((t) => {
1163
+ let o = `${e}|${t}`;
1164
+ !n.reload && this.store.hasResourceBundle(e, t) ? this.state[o] = 2 : this.state[o] < 0 || (this.state[o] === 1 ? a[o] === void 0 && (a[o] = !0) : (this.state[o] = 1, r = !1, a[o] === void 0 && (a[o] = !0), i[o] === void 0 && (i[o] = !0), s[t] === void 0 && (s[t] = !0)));
1165
+ }), r || (o[e] = !0);
1166
+ }), (Object.keys(i).length || Object.keys(a).length) && this.queue.push({
1167
+ pending: a,
1168
+ pendingCount: Object.keys(a).length,
1169
+ loaded: {},
1170
+ errors: [],
1171
+ callback: r
1172
+ }), {
1173
+ toLoad: Object.keys(i),
1174
+ pending: Object.keys(a),
1175
+ toLoadLanguages: Object.keys(o),
1176
+ toLoadNamespaces: Object.keys(s)
1177
+ };
1178
+ }
1179
+ loaded(e, t, n) {
1180
+ let r = e.split("|"), i = r[0], a = r[1];
1181
+ t && this.emit("failedLoading", i, a, t), !t && n && this.store.addResourceBundle(i, a, n, void 0, void 0, { skipCopy: !0 }), this.state[e] = t ? -1 : 2, t && n && (this.state[e] = 0);
1182
+ let o = {};
1183
+ this.queue.forEach((n) => {
1184
+ me(n.loaded, [i], a), We(n, e), t && n.errors.push(t), n.pendingCount === 0 && !n.done && (Object.keys(n.loaded).forEach((e) => {
1185
+ o[e] || (o[e] = {});
1186
+ let t = n.loaded[e];
1187
+ t.length && t.forEach((t) => {
1188
+ o[e][t] === void 0 && (o[e][t] = !0);
1189
+ });
1190
+ }), n.done = !0, n.errors.length ? n.callback(n.errors) : n.callback());
1191
+ }), this.emit("loaded", o), this.queue = this.queue.filter((e) => !e.done);
1192
+ }
1193
+ read(e, t, n, r = 0, i = this.retryTimeout, a) {
1194
+ if (!e.length) return a(null, {});
1195
+ if (this.readingCalls >= this.maxParallelReads) {
1196
+ this.waitingReads.push({
1197
+ lng: e,
1198
+ ns: t,
1199
+ fcName: n,
1200
+ tried: r,
1201
+ wait: i,
1202
+ callback: a
1203
+ });
1204
+ return;
1205
+ }
1206
+ this.readingCalls++;
1207
+ let o = (o, s) => {
1208
+ if (this.readingCalls--, this.waitingReads.length > 0) {
1209
+ let e = this.waitingReads.shift();
1210
+ this.read(e.lng, e.ns, e.fcName, e.tried, e.wait, e.callback);
1211
+ }
1212
+ if (o && s && r < this.maxRetries) {
1213
+ setTimeout(() => {
1214
+ this.read.call(this, e, t, n, r + 1, i * 2, a);
1215
+ }, i);
1216
+ return;
1217
+ }
1218
+ a(o, s);
1219
+ }, s = this.backend[n].bind(this.backend);
1220
+ if (s.length === 2) {
1221
+ try {
1222
+ let n = s(e, t);
1223
+ n && typeof n.then == "function" ? n.then((e) => o(null, e)).catch(o) : o(null, n);
1224
+ } catch (e) {
1225
+ o(e);
1226
+ }
1227
+ return;
1228
+ }
1229
+ return s(e, t, o);
1230
+ }
1231
+ prepareLoading(e, t, n = {}, r) {
1232
+ if (!this.backend) return this.logger.warn("No backend was added via i18next.use. Will not load resources."), r && r();
1233
+ j(e) && (e = this.languageUtils.toResolveHierarchy(e)), j(t) && (t = [t]);
1234
+ let i = this.queueLoad(e, t, n, r);
1235
+ if (!i.toLoad.length) return i.pending.length || r(), null;
1236
+ i.toLoad.forEach((e) => {
1237
+ this.loadOne(e);
1238
+ });
1239
+ }
1240
+ load(e, t, n) {
1241
+ this.prepareLoading(e, t, {}, n);
1242
+ }
1243
+ reload(e, t, n) {
1244
+ this.prepareLoading(e, t, { reload: !0 }, n);
1245
+ }
1246
+ loadOne(e, t = "") {
1247
+ let n = e.split("|"), r = n[0], i = n[1];
1248
+ this.read(r, i, "read", void 0, void 0, (n, a) => {
1249
+ n && this.logger.warn(`${t}loading namespace ${i} for language ${r} failed`, n), !n && a && this.logger.log(`${t}loaded namespace ${i} for language ${r}`, a), this.loaded(e, n, a);
1250
+ });
1251
+ }
1252
+ saveMissing(e, t, n, r, i, a = {}, o = () => {}) {
1253
+ if (this.services?.utils?.hasLoadedNamespace && !this.services?.utils?.hasLoadedNamespace(t)) {
1254
+ this.logger.warn(`did not save key "${n}" as the namespace "${t}" was not yet loaded`, "This means something IS WRONG in your setup. You access the t function before i18next.init / i18next.loadNamespace / i18next.changeLanguage was done. Wait for the callback or Promise to resolve before accessing it!!!");
1255
+ return;
1256
+ }
1257
+ if (!(n == null || n === "")) {
1258
+ if (this.backend?.create) {
1259
+ let s = {
1260
+ ...a,
1261
+ isUpdate: i
1262
+ }, c = this.backend.create.bind(this.backend);
1263
+ if (c.length < 6) try {
1264
+ let i;
1265
+ i = c.length === 5 ? c(e, t, n, r, s) : c(e, t, n, r), i && typeof i.then == "function" ? i.then((e) => o(null, e)).catch(o) : o(null, i);
1266
+ } catch (e) {
1267
+ o(e);
1268
+ }
1269
+ else c(e, t, n, r, o, s);
1270
+ }
1271
+ !e || !e[0] || this.store.addResource(e[0], t, n, r);
1272
+ }
1273
+ }
1274
+ }, Ke = () => ({
1275
+ debug: !1,
1276
+ initAsync: !0,
1277
+ ns: ["translation"],
1278
+ defaultNS: ["translation"],
1279
+ fallbackLng: ["dev"],
1280
+ fallbackNS: !1,
1281
+ supportedLngs: !1,
1282
+ nonExplicitSupportedLngs: !1,
1283
+ load: "all",
1284
+ preload: !1,
1285
+ simplifyPluralSuffix: !0,
1286
+ keySeparator: ".",
1287
+ nsSeparator: ":",
1288
+ pluralSeparator: "_",
1289
+ contextSeparator: "_",
1290
+ partialBundledLanguages: !1,
1291
+ saveMissing: !1,
1292
+ updateMissing: !1,
1293
+ saveMissingTo: "fallback",
1294
+ saveMissingPlurals: !0,
1295
+ missingKeyHandler: !1,
1296
+ missingInterpolationHandler: !1,
1297
+ postProcess: !1,
1298
+ postProcessPassResolved: !1,
1299
+ returnNull: !1,
1300
+ returnEmptyString: !0,
1301
+ returnObjects: !1,
1302
+ joinArrays: !1,
1303
+ returnedObjectHandler: !1,
1304
+ parseMissingKeyHandler: !1,
1305
+ appendNamespaceToMissingKey: !1,
1306
+ appendNamespaceToCIMode: !1,
1307
+ overloadTranslationOptionHandler: (e) => {
1308
+ let t = {};
1309
+ if (typeof e[1] == "object" && (t = e[1]), j(e[1]) && (t.defaultValue = e[1]), j(e[2]) && (t.tDescription = e[2]), typeof e[2] == "object" || typeof e[3] == "object") {
1310
+ let n = e[3] || e[2];
1311
+ Object.keys(n).forEach((e) => {
1312
+ t[e] = n[e];
1313
+ });
1314
+ }
1315
+ return t;
1316
+ },
1317
+ interpolation: {
1318
+ escapeValue: !0,
1319
+ format: (e) => e,
1320
+ prefix: "{{",
1321
+ suffix: "}}",
1322
+ formatSeparator: ",",
1323
+ unescapePrefix: "-",
1324
+ nestingPrefix: "$t(",
1325
+ nestingSuffix: ")",
1326
+ nestingOptionsSeparator: ",",
1327
+ maxReplaces: 1e3,
1328
+ skipOnVariables: !0
1329
+ },
1330
+ cacheInBuiltFormats: !0
1331
+ }), qe = (e) => (j(e.ns) && (e.ns = [e.ns]), j(e.fallbackLng) && (e.fallbackLng = [e.fallbackLng]), j(e.fallbackNS) && (e.fallbackNS = [e.fallbackNS]), e.supportedLngs?.indexOf?.("cimode") < 0 && (e.supportedLngs = e.supportedLngs.concat(["cimode"])), typeof e.initImmediate == "boolean" && (e.initAsync = e.initImmediate), e), z = () => {}, Je = (e) => {
1332
+ Object.getOwnPropertyNames(Object.getPrototypeOf(e)).forEach((t) => {
1333
+ typeof e[t] == "function" && (e[t] = e[t].bind(e));
1334
+ });
1335
+ }, Ye = "__i18next_supportNoticeShown", Xe = () => !!(typeof globalThis < "u" && globalThis[Ye] || typeof process < "u" && process.env && process.env.I18NEXT_NO_SUPPORT_NOTICE || typeof process < "u" && process.env), Ze = () => {
1336
+ typeof globalThis < "u" && (globalThis[Ye] = !0);
1337
+ }, Qe = (e) => !!(e?.modules?.backend?.name?.indexOf("Locize") > 0 || e?.modules?.backend?.constructor?.name?.indexOf("Locize") > 0 || e?.options?.backend?.backends && e.options.backend.backends.some((e) => e?.name?.indexOf("Locize") > 0 || e?.constructor?.name?.indexOf("Locize") > 0) || e?.options?.backend?.projectId || e?.options?.backend?.backendOptions && e.options.backend.backendOptions.some((e) => e?.projectId)), B = class e extends Te {
1338
+ constructor(e = {}, t) {
1339
+ if (super(), this.options = qe(e), this.services = {}, this.logger = L, this.modules = { external: [] }, Je(this), t && !this.isInitialized && !e.isClone) {
1340
+ if (!this.options.initAsync) return this.init(e, t), this;
1341
+ setTimeout(() => {
1342
+ this.init(e, t);
1343
+ }, 0);
1344
+ }
1345
+ }
1346
+ init(e = {}, t) {
1347
+ this.isInitializing = !0, typeof e == "function" && (t = e, e = {}), e.defaultNS == null && e.ns && (j(e.ns) ? e.defaultNS = e.ns : e.ns.indexOf("translation") < 0 && (e.defaultNS = e.ns[0]));
1348
+ let n = Ke();
1349
+ this.options = {
1350
+ ...n,
1351
+ ...this.options,
1352
+ ...qe(e)
1353
+ }, this.options.interpolation = {
1354
+ ...n.interpolation,
1355
+ ...this.options.interpolation
1356
+ }, e.keySeparator !== void 0 && (this.options.userDefinedKeySeparator = e.keySeparator), e.nsSeparator !== void 0 && (this.options.userDefinedNsSeparator = e.nsSeparator), typeof this.options.overloadTranslationOptionHandler != "function" && (this.options.overloadTranslationOptionHandler = n.overloadTranslationOptionHandler), this.options.showSupportNotice !== !1 && !Qe(this) && !Xe() && (typeof console < "u" && console.info !== void 0 && console.info("🌐 i18next is made possible by our own product, Locize — consider powering your project with managed localization (AI, CDN, integrations): https://locize.com 💙"), Ze());
1357
+ let r = (e) => e ? typeof e == "function" ? new e() : e : null;
1358
+ if (!this.options.isClone) {
1359
+ this.modules.logger ? L.init(r(this.modules.logger), this.options) : L.init(null, this.options);
1360
+ let e;
1361
+ e = this.modules.formatter ? this.modules.formatter : Ue;
1362
+ let t = new Ne(this.options);
1363
+ this.store = new Ee(this.options.resources, this.options);
1364
+ let i = this.services;
1365
+ i.logger = L, i.resourceStore = this.store, i.languageUtils = t, i.pluralResolver = new Ie(t, {
1366
+ prepend: this.options.pluralSeparator,
1367
+ simplifyPluralSuffix: this.options.simplifyPluralSuffix
1368
+ }), this.options.interpolation.format && this.options.interpolation.format !== n.interpolation.format && this.logger.deprecate("init: you are still using the legacy format function, please use the new approach: https://www.i18next.com/translation-function/formatting"), e && (!this.options.interpolation.format || this.options.interpolation.format === n.interpolation.format) && (i.formatter = r(e), i.formatter.init && i.formatter.init(i, this.options), this.options.interpolation.format = i.formatter.format.bind(i.formatter)), i.interpolator = new ze(this.options), i.utils = { hasLoadedNamespace: this.hasLoadedNamespace.bind(this) }, i.backendConnector = new Ge(r(this.modules.backend), i.resourceStore, i, this.options), i.backendConnector.on("*", (e, ...t) => {
1369
+ this.emit(e, ...t);
1370
+ }), this.modules.languageDetector && (i.languageDetector = r(this.modules.languageDetector), i.languageDetector.init && i.languageDetector.init(i, this.options.detection, this.options)), this.modules.i18nFormat && (i.i18nFormat = r(this.modules.i18nFormat), i.i18nFormat.init && i.i18nFormat.init(this)), this.translator = new Me(this.services, this.options), this.translator.on("*", (e, ...t) => {
1371
+ this.emit(e, ...t);
1372
+ }), this.modules.external.forEach((e) => {
1373
+ e.init && e.init(this);
1374
+ });
1375
+ }
1376
+ if (this.format = this.options.interpolation.format, t ||= z, this.options.fallbackLng && !this.services.languageDetector && !this.options.lng) {
1377
+ let e = this.services.languageUtils.getFallbackCodes(this.options.fallbackLng);
1378
+ e.length > 0 && e[0] !== "dev" && (this.options.lng = e[0]);
1379
+ }
1380
+ !this.services.languageDetector && !this.options.lng && this.logger.warn("init: no languageDetector is used and no lng is defined"), [
1381
+ "getResource",
1382
+ "hasResourceBundle",
1383
+ "getResourceBundle",
1384
+ "getDataByLanguage"
1385
+ ].forEach((e) => {
1386
+ this[e] = (...t) => this.store[e](...t);
1387
+ }), [
1388
+ "addResource",
1389
+ "addResources",
1390
+ "addResourceBundle",
1391
+ "removeResourceBundle"
1392
+ ].forEach((e) => {
1393
+ this[e] = (...t) => (this.store[e](...t), this);
1394
+ });
1395
+ let i = M(), a = () => {
1396
+ let e = (e, n) => {
1397
+ this.isInitializing = !1, this.isInitialized && !this.initializedStoreOnce && this.logger.warn("init: i18next is already initialized. You should call init just once!"), this.isInitialized = !0, this.options.isClone || this.logger.log("initialized", this.options), this.emit("initialized", this.options), i.resolve(n), t(e, n);
1398
+ };
1399
+ if (this.languages && !this.isInitialized) return e(null, this.t.bind(this));
1400
+ this.changeLanguage(this.options.lng, e);
1401
+ };
1402
+ return this.options.resources || !this.options.initAsync ? a() : setTimeout(a, 0), i;
1403
+ }
1404
+ loadResources(e, t = z) {
1405
+ let n = t, r = j(e) ? e : this.language;
1406
+ if (typeof e == "function" && (n = e), !this.options.resources || this.options.partialBundledLanguages) {
1407
+ if (r?.toLowerCase() === "cimode" && (!this.options.preload || this.options.preload.length === 0)) return n();
1408
+ let e = [], t = (t) => {
1409
+ t && t !== "cimode" && this.services.languageUtils.toResolveHierarchy(t).forEach((t) => {
1410
+ t !== "cimode" && e.indexOf(t) < 0 && e.push(t);
1411
+ });
1412
+ };
1413
+ r ? t(r) : this.services.languageUtils.getFallbackCodes(this.options.fallbackLng).forEach((e) => t(e)), this.options.preload?.forEach?.((e) => t(e)), this.services.backendConnector.load(e, this.options.ns, (e) => {
1414
+ !e && !this.resolvedLanguage && this.language && this.setResolvedLanguage(this.language), n(e);
1415
+ });
1416
+ } else n(null);
1417
+ }
1418
+ reloadResources(e, t, n) {
1419
+ let r = M();
1420
+ return typeof e == "function" && (n = e, e = void 0), typeof t == "function" && (n = t, t = void 0), e ||= this.languages, t ||= this.options.ns, n ||= z, this.services.backendConnector.reload(e, t, (e) => {
1421
+ r.resolve(), n(e);
1422
+ }), r;
1423
+ }
1424
+ use(e) {
1425
+ if (!e) throw Error("You are passing an undefined module! Please check the object you are passing to i18next.use()");
1426
+ if (!e.type) throw Error("You are passing a wrong module! Please check the object you are passing to i18next.use()");
1427
+ return e.type === "backend" && (this.modules.backend = e), (e.type === "logger" || e.log && e.warn && e.error) && (this.modules.logger = e), e.type === "languageDetector" && (this.modules.languageDetector = e), e.type === "i18nFormat" && (this.modules.i18nFormat = e), e.type === "postProcessor" && De.addPostProcessor(e), e.type === "formatter" && (this.modules.formatter = e), e.type === "3rdParty" && this.modules.external.push(e), this;
1428
+ }
1429
+ setResolvedLanguage(e) {
1430
+ if (!(!e || !this.languages) && !(["cimode", "dev"].indexOf(e) > -1)) {
1431
+ for (let e = 0; e < this.languages.length; e++) {
1432
+ let t = this.languages[e];
1433
+ if (!(["cimode", "dev"].indexOf(t) > -1) && this.store.hasLanguageSomeTranslations(t)) {
1434
+ this.resolvedLanguage = t;
1435
+ break;
1436
+ }
1437
+ }
1438
+ !this.resolvedLanguage && this.languages.indexOf(e) < 0 && this.store.hasLanguageSomeTranslations(e) && (this.resolvedLanguage = e, this.languages.unshift(e));
1439
+ }
1440
+ }
1441
+ changeLanguage(e, t) {
1442
+ this.isLanguageChangingTo = e;
1443
+ let n = M();
1444
+ this.emit("languageChanging", e);
1445
+ let r = (e) => {
1446
+ this.language = e, this.languages = this.services.languageUtils.toResolveHierarchy(e), this.resolvedLanguage = void 0, this.setResolvedLanguage(e);
1447
+ }, i = (i, a) => {
1448
+ a ? this.isLanguageChangingTo === e && (r(a), this.translator.changeLanguage(a), this.isLanguageChangingTo = void 0, this.emit("languageChanged", a), this.logger.log("languageChanged", a)) : this.isLanguageChangingTo = void 0, n.resolve((...e) => this.t(...e)), t && t(i, (...e) => this.t(...e));
1449
+ }, a = (t) => {
1450
+ !e && !t && this.services.languageDetector && (t = []);
1451
+ let n = j(t) ? t : t && t[0], a = this.store.hasLanguageSomeTranslations(n) ? n : this.services.languageUtils.getBestMatchFromCodes(j(t) ? [t] : t);
1452
+ a && (this.language || r(a), this.translator.language || this.translator.changeLanguage(a), this.services.languageDetector?.cacheUserLanguage?.(a)), this.loadResources(a, (e) => {
1453
+ i(e, a);
1454
+ });
1455
+ };
1456
+ return !e && this.services.languageDetector && !this.services.languageDetector.async ? a(this.services.languageDetector.detect()) : !e && this.services.languageDetector && this.services.languageDetector.async ? this.services.languageDetector.detect.length === 0 ? this.services.languageDetector.detect().then(a) : this.services.languageDetector.detect(a) : a(e), n;
1457
+ }
1458
+ getFixedT(e, t, n) {
1459
+ let r = (e, t, ...i) => {
1460
+ let a;
1461
+ a = typeof t == "object" ? { ...t } : this.options.overloadTranslationOptionHandler([e, t].concat(i)), a.lng = a.lng || r.lng, a.lngs = a.lngs || r.lngs, a.ns = a.ns || r.ns, a.keyPrefix !== "" && (a.keyPrefix = a.keyPrefix || n || r.keyPrefix);
1462
+ let o = {
1463
+ ...this.options,
1464
+ ...a
1465
+ };
1466
+ typeof a.keyPrefix == "function" && (a.keyPrefix = R(a.keyPrefix, o));
1467
+ let s = this.options.keySeparator || ".", c;
1468
+ return a.keyPrefix && Array.isArray(e) ? c = e.map((e) => (typeof e == "function" && (e = R(e, o)), `${a.keyPrefix}${s}${e}`)) : (typeof e == "function" && (e = R(e, o)), c = a.keyPrefix ? `${a.keyPrefix}${s}${e}` : e), this.t(c, a);
1469
+ };
1470
+ return j(e) ? r.lng = e : r.lngs = e, r.ns = t, r.keyPrefix = n, r;
1471
+ }
1472
+ t(...e) {
1473
+ return this.translator?.translate(...e);
1474
+ }
1475
+ exists(...e) {
1476
+ return this.translator?.exists(...e);
1477
+ }
1478
+ setDefaultNamespace(e) {
1479
+ this.options.defaultNS = e;
1480
+ }
1481
+ hasLoadedNamespace(e, t = {}) {
1482
+ if (!this.isInitialized) return this.logger.warn("hasLoadedNamespace: i18next was not initialized", this.languages), !1;
1483
+ if (!this.languages || !this.languages.length) return this.logger.warn("hasLoadedNamespace: i18n.languages were undefined or empty", this.languages), !1;
1484
+ let n = t.lng || this.resolvedLanguage || this.languages[0], r = this.options ? this.options.fallbackLng : !1, i = this.languages[this.languages.length - 1];
1485
+ if (n.toLowerCase() === "cimode") return !0;
1486
+ let a = (e, t) => {
1487
+ let n = this.services.backendConnector.state[`${e}|${t}`];
1488
+ return n === -1 || n === 0 || n === 2;
1489
+ };
1490
+ if (t.precheck) {
1491
+ let e = t.precheck(this, a);
1492
+ if (e !== void 0) return e;
1493
+ }
1494
+ return !!(this.hasResourceBundle(n, e) || !this.services.backendConnector.backend || this.options.resources && !this.options.partialBundledLanguages || a(n, e) && (!r || a(i, e)));
1495
+ }
1496
+ loadNamespaces(e, t) {
1497
+ let n = M();
1498
+ return this.options.ns ? (j(e) && (e = [e]), e.forEach((e) => {
1499
+ this.options.ns.indexOf(e) < 0 && this.options.ns.push(e);
1500
+ }), this.loadResources((e) => {
1501
+ n.resolve(), t && t(e);
1502
+ }), n) : (t && t(), Promise.resolve());
1503
+ }
1504
+ loadLanguages(e, t) {
1505
+ let n = M();
1506
+ j(e) && (e = [e]);
1507
+ let r = this.options.preload || [], i = e.filter((e) => r.indexOf(e) < 0 && this.services.languageUtils.isSupportedCode(e));
1508
+ return i.length ? (this.options.preload = r.concat(i), this.loadResources((e) => {
1509
+ n.resolve(), t && t(e);
1510
+ }), n) : (t && t(), Promise.resolve());
1511
+ }
1512
+ dir(e) {
1513
+ if (e ||= this.resolvedLanguage || (this.languages?.length > 0 ? this.languages[0] : this.language), !e) return "rtl";
1514
+ try {
1515
+ let t = new Intl.Locale(e);
1516
+ if (t && t.getTextInfo) {
1517
+ let e = t.getTextInfo();
1518
+ if (e && e.direction) return e.direction;
1519
+ }
1520
+ } catch {}
1521
+ let t = /* @__PURE__ */ "ar.shu.sqr.ssh.xaa.yhd.yud.aao.abh.abv.acm.acq.acw.acx.acy.adf.ads.aeb.aec.afb.ajp.apc.apd.arb.arq.ars.ary.arz.auz.avl.ayh.ayl.ayn.ayp.bbz.pga.he.iw.ps.pbt.pbu.pst.prp.prd.ug.ur.ydd.yds.yih.ji.yi.hbo.men.xmn.fa.jpr.peo.pes.prs.dv.sam.ckb".split("."), n = this.services?.languageUtils || new Ne(Ke());
1522
+ return e.toLowerCase().indexOf("-latn") > 1 ? "ltr" : t.indexOf(n.getLanguagePartFromCode(e)) > -1 || e.toLowerCase().indexOf("-arab") > 1 ? "rtl" : "ltr";
1523
+ }
1524
+ static createInstance(t = {}, n) {
1525
+ let r = new e(t, n);
1526
+ return r.createInstance = e.createInstance, r;
1527
+ }
1528
+ cloneInstance(t = {}, n = z) {
1529
+ let r = t.forkResourceStore;
1530
+ r && delete t.forkResourceStore;
1531
+ let i = {
1532
+ ...this.options,
1533
+ ...t,
1534
+ isClone: !0
1535
+ }, a = new e(i);
1536
+ if ((t.debug !== void 0 || t.prefix !== void 0) && (a.logger = a.logger.clone(t)), [
1537
+ "store",
1538
+ "services",
1539
+ "language"
1540
+ ].forEach((e) => {
1541
+ a[e] = this[e];
1542
+ }), a.services = { ...this.services }, a.services.utils = { hasLoadedNamespace: a.hasLoadedNamespace.bind(a) }, r && (a.store = new Ee(Object.keys(this.store.data).reduce((e, t) => (e[t] = { ...this.store.data[t] }, e[t] = Object.keys(e[t]).reduce((n, r) => (n[r] = { ...e[t][r] }, n), e[t]), e), {}), i), a.services.resourceStore = a.store), t.interpolation) {
1543
+ let e = {
1544
+ ...Ke().interpolation,
1545
+ ...this.options.interpolation,
1546
+ ...t.interpolation
1547
+ }, n = {
1548
+ ...i,
1549
+ interpolation: e
1550
+ };
1551
+ a.services.interpolator = new ze(n);
1552
+ }
1553
+ return a.translator = new Me(a.services, i), a.translator.on("*", (e, ...t) => {
1554
+ a.emit(e, ...t);
1555
+ }), a.init(i, n), a.translator.options = i, a.translator.backendConnector.services.utils = { hasLoadedNamespace: a.hasLoadedNamespace.bind(a) }, a;
1556
+ }
1557
+ toJSON() {
1558
+ return {
1559
+ options: this.options,
1560
+ store: this.store,
1561
+ language: this.language,
1562
+ languages: this.languages,
1563
+ resolvedLanguage: this.resolvedLanguage
1564
+ };
1565
+ }
1566
+ }.createInstance();
1567
+ //#endregion
1568
+ //#region ../../lib-react/translator/dist/index.js
1569
+ B.createInstance, B.dir, B.init, B.loadResources, B.reloadResources, B.use, B.changeLanguage, B.getFixedT, B.t, B.exists, B.setDefaultNamespace, B.hasLoadedNamespace, B.loadNamespaces, B.loadLanguages, B.init({
1570
+ fallbackLng: "en",
1571
+ lng: "en",
1572
+ debug: !0,
1573
+ resources: {
1574
+ en: oe,
1575
+ es: se
1576
+ }
1577
+ });
1578
+ var $e = {
1579
+ translator: {
1580
+ ...B,
1581
+ t: (e, t) => {
1582
+ let { lng: n } = t;
1583
+ switch (n) {
1584
+ case "en_US":
1585
+ case "en-US":
1586
+ t.lng = "en";
1587
+ break;
1588
+ case "es_ES":
1589
+ case "es-ES":
1590
+ case "es_MX":
1591
+ case "es-MX":
1592
+ t.lng = "es";
1593
+ break;
1594
+ default: break;
1595
+ }
1596
+ return B.t(e, {
1597
+ lng: n,
1598
+ ...t
1599
+ });
1600
+ }
1601
+ },
1602
+ languageOptions: [{
1603
+ value: "en_US",
1604
+ label: "English (US)"
1605
+ }, {
1606
+ value: "es_ES",
1607
+ label: "Spanish"
1608
+ }]
1609
+ };
1610
+ //#endregion
1611
+ //#region ../../lib-react/correct-answer-toggle/dist/index.js
1612
+ function V(e) {
1613
+ return typeof e == "function" || typeof e == "object" && !!e && typeof e.$$typeof == "symbol";
1614
+ }
1615
+ function et(e, t) {
1616
+ return !e || V(e) ? e : V(e.default) ? e.default : t && V(e[t]) ? e[t] : t && V(e[t]?.default) ? e[t].default : e;
1617
+ }
1618
+ var tt = et(c, "Readable") || et(it.Readable, "Readable"), nt = f, rt = nt.default, it = rt && typeof rt == "object" ? rt : nt, { translator: H } = $e, at = {
1619
+ WebkitTouchCallout: "none",
1620
+ WebkitUserSelect: "none",
1621
+ KhtmlUserSelect: "none",
1622
+ MozUserSelect: "none",
1623
+ msUserSelect: "none",
1624
+ userSelect: "none"
1625
+ }, ot = l("div")(() => ({
1626
+ width: "100%",
1627
+ cursor: "pointer"
1628
+ })), st = l("div")(() => ({
1629
+ margin: "0 auto",
1630
+ textAlign: "center",
1631
+ display: "flex"
1632
+ })), ct = l("div")(() => ({
1633
+ width: "fit-content",
1634
+ minWidth: "140px",
1635
+ alignSelf: "center",
1636
+ verticalAlign: "middle",
1637
+ color: `var(--correct-answer-toggle-label-color, ${o.text()})`,
1638
+ fontWeight: "normal",
1639
+ ...at
1640
+ })), lt = l("div")(() => ({
1641
+ position: "absolute",
1642
+ width: "25px",
1643
+ "&.enter": { opacity: "0" },
1644
+ "&.enter-active": {
1645
+ opacity: "1",
1646
+ transition: "opacity 0.3s ease-in"
1647
+ },
1648
+ "&.exit": { opacity: "1" },
1649
+ "&.exit-active": {
1650
+ opacity: "0",
1651
+ transition: "opacity 0.3s ease-in"
1652
+ }
1653
+ })), ut = l("div")(() => ({
1654
+ width: "25px",
1655
+ marginRight: "5px",
1656
+ display: "flex",
1657
+ alignItems: "center"
1658
+ })), dt = class e extends S.Component {
1659
+ static propTypes = {
1660
+ onToggle: D.default.func,
1661
+ toggled: D.default.bool,
1662
+ show: D.default.bool,
1663
+ hideMessage: D.default.string,
1664
+ showMessage: D.default.string,
1665
+ className: D.default.string,
1666
+ language: D.default.string
1667
+ };
1668
+ static defaultProps = {
1669
+ showMessage: "Show correct answer",
1670
+ hideMessage: "Hide correct answer",
1671
+ show: !1,
1672
+ toggled: !1
1673
+ };
1674
+ constructor(t) {
1675
+ super(t), this.state = { show: t.show }, this.openIconRef = S.createRef(), this.closedIconRef = S.createRef(), e.defaultProps = {
1676
+ ...e.defaultProps,
1677
+ showMessage: H.t("common:showCorrectAnswer", { lng: t.language }),
1678
+ hideMessage: H.t("common:hideCorrectAnswer", { lng: t.language })
1679
+ };
1680
+ }
1681
+ onClick() {
1682
+ this.props.onToggle(!this.props.toggled);
1683
+ }
1684
+ onTouch(e) {
1685
+ e.preventDefault(), this.props.onToggle(!this.props.toggled);
1686
+ }
1687
+ UNSAFE_componentWillReceiveProps(t) {
1688
+ this.setState({ show: t.show }), t.language !== this.props?.language && (e.defaultProps = {
1689
+ ...e.defaultProps,
1690
+ showMessage: H.t("common:showCorrectAnswer", { lng: t.language }),
1691
+ hideMessage: H.t("common:hideCorrectAnswer", { lng: t.language })
1692
+ });
1693
+ }
1694
+ render() {
1695
+ let { className: e, toggled: t, hideMessage: n, showMessage: i } = this.props;
1696
+ return /* @__PURE__ */ T(ot, {
1697
+ className: e,
1698
+ children: /* @__PURE__ */ T(ae, {
1699
+ show: this.state.show,
1700
+ children: /* @__PURE__ */ E(st, {
1701
+ onClick: this.onClick.bind(this),
1702
+ onTouchEnd: this.onTouch.bind(this),
1703
+ children: [/* @__PURE__ */ E(ut, { children: [/* @__PURE__ */ T(r, {
1704
+ nodeRef: this.openIconRef,
1705
+ timeout: 400,
1706
+ in: t,
1707
+ exit: !t,
1708
+ classNames: {
1709
+ enter: "enter",
1710
+ enterActive: "enter-active",
1711
+ exit: "exit",
1712
+ exitActive: "exit-active"
1713
+ },
1714
+ children: /* @__PURE__ */ T(lt, {
1715
+ ref: this.openIconRef,
1716
+ children: /* @__PURE__ */ T(A, { open: t }, "correct-open")
1717
+ })
1718
+ }), /* @__PURE__ */ T(r, {
1719
+ nodeRef: this.closedIconRef,
1720
+ timeout: 5e3,
1721
+ in: !t,
1722
+ exit: t,
1723
+ classNames: {
1724
+ enter: "enter",
1725
+ enterActive: "enter-active",
1726
+ exit: "exit",
1727
+ exitActive: "exit-active"
1728
+ },
1729
+ children: /* @__PURE__ */ T(lt, {
1730
+ ref: this.closedIconRef,
1731
+ children: /* @__PURE__ */ T(A, { open: t }, "correct-closed")
1732
+ })
1733
+ })] }), /* @__PURE__ */ T(tt, {
1734
+ false: !0,
1735
+ children: /* @__PURE__ */ T(ct, {
1736
+ "aria-hidden": !this.state.show,
1737
+ children: t ? n : i
1738
+ })
1739
+ })]
1740
+ })
1741
+ })
1742
+ });
1743
+ }
1744
+ };
1745
+ //#endregion
1746
+ //#region src/delivery/hotspot/image-konva-tooltip.tsx
1747
+ function U(e) {
1748
+ return typeof e == "function" || typeof e == "object" && !!e && typeof e.$$typeof == "symbol";
1749
+ }
1750
+ function W(e, t) {
1751
+ 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;
1752
+ }
1753
+ var ft = W(m, "Label"), pt = W("Tag", "Tag"), mt = W(g, "Text"), ht = W(y, "Image"), gt = W(_, "Group"), G = class extends S.Component {
1754
+ constructor(e) {
1755
+ super(e), this.state = {
1756
+ image: null,
1757
+ showTooltip: !1
1758
+ };
1759
+ }
1760
+ componentDidMount() {
1761
+ this.loadImage();
1762
+ }
1763
+ componentDidUpdate(e) {
1764
+ e.src !== this.props.src && this.loadImage();
1765
+ }
1766
+ componentWillUnmount() {
1767
+ this.image.removeEventListener("load", this.handleLoad);
1768
+ }
1769
+ loadImage() {
1770
+ let { src: e } = this.props;
1771
+ this.image = new window.Image(), this.image.src = e, this.image.addEventListener("load", this.handleLoad);
1772
+ }
1773
+ handleLoad = () => {
1774
+ this.setState({ image: this.image });
1775
+ };
1776
+ render() {
1777
+ let { x: e, y: t, tooltip: n } = this.props, { image: r, showTooltip: i } = this.state;
1778
+ return /* @__PURE__ */ E(gt, { children: [/* @__PURE__ */ T(ht, {
1779
+ width: 20,
1780
+ height: 20,
1781
+ x: e,
1782
+ y: t,
1783
+ image: r,
1784
+ onMouseEnter: () => this.setState({ showTooltip: !0 }),
1785
+ onMouseLeave: () => this.setState({ showTooltip: !1 })
1786
+ }), i && n && /* @__PURE__ */ E(ft, {
1787
+ x: e - 30,
1788
+ y: t + 25,
1789
+ children: [/* @__PURE__ */ T(pt, {
1790
+ fill: "white",
1791
+ cornerRadius: 5,
1792
+ opacity: .9
1793
+ }), /* @__PURE__ */ T(mt, {
1794
+ text: n,
1795
+ padding: 5
1796
+ })]
1797
+ })] });
1798
+ }
1799
+ };
1800
+ G.propTypes = {
1801
+ src: D.default.string.isRequired,
1802
+ x: D.default.number.isRequired,
1803
+ y: D.default.number.isRequired,
1804
+ tooltip: D.default.string.isRequired
1805
+ };
1806
+ //#endregion
1807
+ //#region src/delivery/hotspot/icons.ts
1808
+ var K = "data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAgAAAAIACAYAAAD0eNT6AAAABGdBTUEAALGPC/xhBQAAACBjSFJNAAB6JgAAgIQAAPoAAACA6AAAdTAAAOpgAAA6mAAAF3CculE8AAAAhGVYSWZNTQAqAAAACAAFARIAAwAAAAEAAQAAARoABQAAAAEAAABKARsABQAAAAEAAABSASgAAwAAAAEAAgAAh2kABAAAAAEAAABaAAAAAAAAAEgAAAABAAAASAAAAAEAA6ABAAMAAAABAAEAAKACAAQAAAABAAACAKADAAQAAAABAAACAAAAAAD4wtiGAAAACXBIWXMAAAsTAAALEwEAmpwYAAABWWlUWHRYTUw6Y29tLmFkb2JlLnhtcAAAAAAAPHg6eG1wbWV0YSB4bWxuczp4PSJhZG9iZTpuczptZXRhLyIgeDp4bXB0az0iWE1QIENvcmUgNS40LjAiPgogICA8cmRmOlJERiB4bWxuczpyZGY9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkvMDIvMjItcmRmLXN5bnRheC1ucyMiPgogICAgICA8cmRmOkRlc2NyaXB0aW9uIHJkZjphYm91dD0iIgogICAgICAgICAgICB4bWxuczp0aWZmPSJodHRwOi8vbnMuYWRvYmUuY29tL3RpZmYvMS4wLyI+CiAgICAgICAgIDx0aWZmOk9yaWVudGF0aW9uPjE8L3RpZmY6T3JpZW50YXRpb24+CiAgICAgIDwvcmRmOkRlc2NyaXB0aW9uPgogICA8L3JkZjpSREY+CjwveDp4bXBtZXRhPgpMwidZAABAAElEQVR4Ae2dCZwcZZn/n7e6e45kZjJJCIFwDSThTCAQrnAOIORAIICEI+RiEXCVU0QOkQRFRV1h19UVrwABdEH/QZEcyDHguuq60SiKq4AGRZArmStzdXe9/+etnurpnumjuuvoOn7Fh3R1Vb3X96np5/feRDhAAARAAARAAARAAARAAARAAARAAARAAARAAARAAARAAARAAARAAARAAARAAARAAARAAARAAARAAARAAARAAARAAARAAARAAARAAARAAARAAAR8SkD4NF/IFgiAQGECgiTfeOwCjaa8I+hPPYIGd9WmtqbjqYa61sEBOTEe1ydLKXclKVqFEHtIIZuETnWSJP+vNRPJiXzeIEiLqySEkLpOQhdS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", q = "data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAgAAAAIACAYAAAD0eNT6AAAABGdBTUEAALGPC/xhBQAAACBjSFJNAAB6JgAAgIQAAPoAAACA6AAAdTAAAOpgAAA6mAAAF3CculE8AAAAhGVYSWZNTQAqAAAACAAFARIAAwAAAAEAAQAAARoABQAAAAEAAABKARsABQAAAAEAAABSASgAAwAAAAEAAgAAh2kABAAAAAEAAABaAAAAAAAAAEgAAAABAAAASAAAAAEAA6ABAAMAAAABAAEAAKACAAQAAAABAAACAKADAAQAAAABAAACAAAAAAD4wtiGAAAACXBIWXMAAAsTAAALEwEAmpwYAAABWWlUWHRYTUw6Y29tLmFkb2JlLnhtcAAAAAAAPHg6eG1wbWV0YSB4bWxuczp4PSJhZG9iZTpuczptZXRhLyIgeDp4bXB0az0iWE1QIENvcmUgNS40LjAiPgogICA8cmRmOlJERiB4bWxuczpyZGY9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkvMDIvMjItcmRmLXN5bnRheC1ucyMiPgogICAgICA8cmRmOkRlc2NyaXB0aW9uIHJkZjphYm91dD0iIgogICAgICAgICAgICB4bWxuczp0aWZmPSJodHRwOi8vbnMuYWRvYmUuY29tL3RpZmYvMS4wLyI+CiAgICAgICAgIDx0aWZmOk9yaWVudGF0aW9uPjE8L3RpZmY6T3JpZW50YXRpb24+CiAgICAgIDwvcmRmOkRlc2NyaXB0aW9uPgogICA8L3JkZjpSREY+CjwveDp4bXBtZXRhPgpMwidZAABAAElEQVR4AeydB5wV1fXHf++9bcAuLFWQtlZAFLAkJtZdUeyKvcQC9o5RozGJLbYUjUSj/mMSFbuowd7jgiUaK11UVEQRkLa9v/f+5w476+6y++qUOzO/+Xx2570p9577PffNOffcMgA3EiABEiABEiABEiABEiABEiABEiABEiABEiABEiABEiABEiABEiABEiABEiABEiABEiABEiABEiABEiABEiABEiABEiABEiABEiABEiABEiABEiABEiABEiABEiABXQiEdBGEcpAACXRPoLwYxWiQvxyUICR7oDgcQx/1OR6SYxs347jx8cdjxtd4fOM9rdcl21WEQqhod1EF4m3f1fGK0MbvxvFYGJVyfplxfQuWlTW0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";
1809
+ //#endregion
1810
+ //#region src/delivery/hotspot/rectangle.tsx
1811
+ function J(e) {
1812
+ return typeof e == "function" || typeof e == "object" && !!e && typeof e.$$typeof == "symbol";
1813
+ }
1814
+ function _t(e, t) {
1815
+ return !e || J(e) ? e : J(e.default) ? e.default : t && J(e[t]) ? e[t] : t && J(e[t]?.default) ? e[t].default : e;
1816
+ }
1817
+ var vt = _t(_, "Group"), yt = _t(b, "Rect"), bt = class extends S.Component {
1818
+ constructor(e) {
1819
+ super(e), this.state = { hovered: !1 };
1820
+ }
1821
+ handleClick = (e) => {
1822
+ let { onClick: t, id: n, selected: r, disabled: i } = this.props;
1823
+ i || (e.cancelBubble = !0, t({
1824
+ id: n,
1825
+ selected: !r,
1826
+ selector: "Mouse"
1827
+ }));
1828
+ };
1829
+ handleMouseEnter = () => {
1830
+ let { disabled: e } = this.props;
1831
+ e || (document.body.style.cursor = "pointer"), this.setState({ hovered: !0 });
1832
+ };
1833
+ handleMouseLeave = () => {
1834
+ document.body.style.cursor = "default", this.setState({ hovered: !1 });
1835
+ };
1836
+ getEvaluateOutlineColor = (e, t, n) => t ? "green" : e ? n : "red";
1837
+ getOutlineWidth = (e, t, n, r) => n || !n && !e && t ? r : 0;
1838
+ render() {
1839
+ let { height: e, hotspotColor: t, hoverOutlineColor: n, selectedHotspotColor: r, isCorrect: i, isEvaluateMode: a, outlineColor: o, selected: s, width: c, x: l, y: u, evaluateText: d, strokeWidth: f, scale: p, markAsCorrect: m, showCorrectEnabled: h } = this.props, g = a ? this.getEvaluateOutlineColor(i, m, o) : o, _ = this.getOutlineWidth(h, s, m, f), v = l + c / 2 - 10, y = u + e / 2 - 10, b;
1840
+ h ? (s && i || !s && !i) && (b = K) : s ? b = i ? K : q : i || (b = q);
1841
+ let { hovered: x } = this.state, S = x && n;
1842
+ return /* @__PURE__ */ E(vt, {
1843
+ scaleX: p,
1844
+ scaleY: p,
1845
+ children: [
1846
+ S && /* @__PURE__ */ T(yt, {
1847
+ x: l,
1848
+ y: u,
1849
+ width: c,
1850
+ height: e,
1851
+ stroke: s ? "transparent" : n,
1852
+ strokeWidth: f,
1853
+ listening: !1
1854
+ }),
1855
+ /* @__PURE__ */ T(yt, {
1856
+ x: l,
1857
+ y: u,
1858
+ width: c,
1859
+ height: e,
1860
+ fill: s && r ? r : t,
1861
+ onClick: this.handleClick,
1862
+ onTap: this.handleClick,
1863
+ draggable: !1,
1864
+ stroke: S && !s ? "transparent" : g,
1865
+ strokeWidth: S && !s ? 0 : _,
1866
+ onMouseLeave: this.handleMouseLeave,
1867
+ onMouseEnter: this.handleMouseEnter,
1868
+ cursor: "pointer"
1869
+ }),
1870
+ a && b ? /* @__PURE__ */ T(G, {
1871
+ src: b,
1872
+ x: v,
1873
+ y,
1874
+ tooltip: d
1875
+ }) : null
1876
+ ]
1877
+ });
1878
+ }
1879
+ };
1880
+ bt.propTypes = {
1881
+ height: D.default.number.isRequired,
1882
+ hotspotColor: D.default.string.isRequired,
1883
+ id: D.default.string.isRequired,
1884
+ isCorrect: D.default.oneOfType([D.default.bool, D.default.string]),
1885
+ isEvaluateMode: D.default.bool.isRequired,
1886
+ hoverOutlineColor: D.default.string,
1887
+ disabled: D.default.bool.isRequired,
1888
+ onClick: D.default.func.isRequired,
1889
+ outlineColor: D.default.string.isRequired,
1890
+ selected: D.default.bool.isRequired,
1891
+ width: D.default.number.isRequired,
1892
+ x: D.default.number.isRequired,
1893
+ y: D.default.number.isRequired,
1894
+ evaluateText: D.default.string,
1895
+ strokeWidth: D.default.number,
1896
+ scale: D.default.number,
1897
+ selectedHotspotColor: D.default.string,
1898
+ markAsCorrect: D.default.bool.isRequired,
1899
+ showCorrectEnabled: D.default.bool.isRequired
1900
+ }, bt.defaultProps = {
1901
+ isCorrect: !1,
1902
+ evaluateText: null,
1903
+ strokeWidth: 5,
1904
+ scale: 1
1905
+ };
1906
+ //#endregion
1907
+ //#region src/delivery/hotspot/polygon.tsx
1908
+ function Y(e) {
1909
+ return typeof e == "function" || typeof e == "object" && !!e && typeof e.$$typeof == "symbol";
1910
+ }
1911
+ function xt(e, t) {
1912
+ return !e || Y(e) ? e : Y(e.default) ? e.default : t && Y(e[t]) ? e[t] : t && Y(e[t]?.default) ? e[t].default : e;
1913
+ }
1914
+ var St = xt(b, "Rect"), Ct = xt(_, "Group"), wt = xt(v, "Line"), Tt = class extends S.Component {
1915
+ constructor(e) {
1916
+ super(e), this.state = { hovered: !1 };
1917
+ }
1918
+ getPolygonCenter = (e) => {
1919
+ let t = e.map(({ x: e }) => e), n = e.map(({ y: e }) => e), r = Math.min.apply(null, t), i = Math.max.apply(null, t), a = Math.min.apply(null, n), o = Math.max.apply(null, n);
1920
+ return [(r + i) / 2, (a + o) / 2];
1921
+ };
1922
+ parsePointsForKonva = (e) => {
1923
+ let t = [];
1924
+ return e.forEach(({ x: e, y: n }) => {
1925
+ t.push(e), t.push(n);
1926
+ }), t;
1927
+ };
1928
+ handleClick = (e) => {
1929
+ let { onClick: t, id: n, selected: r, disabled: i } = this.props;
1930
+ i || (e.cancelBubble = !0, t({
1931
+ id: n,
1932
+ selected: !r,
1933
+ selector: "Mouse"
1934
+ }));
1935
+ };
1936
+ handleMouseEnter = () => {
1937
+ let { disabled: e } = this.props;
1938
+ e || (document.body.style.cursor = "pointer"), this.setState({ hovered: !0 });
1939
+ };
1940
+ handleMouseLeave = () => {
1941
+ document.body.style.cursor = "default", this.setState({ hovered: !1 });
1942
+ };
1943
+ getEvaluateOutlineColor = (e, t, n) => t ? "green" : e ? n : "red";
1944
+ getOutlineWidth = (e, t, n, r) => n || !n && !e && t ? r : 0;
1945
+ render() {
1946
+ let { hotspotColor: e, isCorrect: t, isEvaluateMode: n, hoverOutlineColor: r, outlineColor: i, selected: a, points: o, evaluateText: s, strokeWidth: c, scale: l, markAsCorrect: u, selectedHotspotColor: d, showCorrectEnabled: f } = this.props, { hovered: p } = this.state, m = n ? this.getEvaluateOutlineColor(t, u, i) : i, h = this.getOutlineWidth(f, a, u, c), g = this.parsePointsForKonva(o), _ = this.getPolygonCenter(o), v = _[0], y = _[1], b;
1947
+ f ? (a && t || !a && !t) && (b = K) : a ? b = t ? K : q : t || (b = q);
1948
+ let x = p && r, S = g.filter((e, t) => t % 2 == 0), C = g.filter((e, t) => t % 2 != 0), w = Math.min(...S), D = Math.max(...S), O = Math.min(...C), k = Math.max(...C), ee = w, A = O, te = D - w, ne = k - O;
1949
+ return /* @__PURE__ */ E(Ct, {
1950
+ scaleX: l,
1951
+ scaleY: l,
1952
+ children: [
1953
+ x && /* @__PURE__ */ T(St, {
1954
+ x: ee,
1955
+ y: A,
1956
+ width: te,
1957
+ height: ne,
1958
+ stroke: a ? "transparent" : r,
1959
+ strokeWidth: c
1960
+ }),
1961
+ /* @__PURE__ */ T(wt, {
1962
+ points: g,
1963
+ closed: !0,
1964
+ fill: a && d ? d : e,
1965
+ onClick: this.handleClick,
1966
+ onTap: this.handleClick,
1967
+ draggable: !1,
1968
+ stroke: x && !a ? "transparent" : m,
1969
+ strokeWidth: x && !a ? 0 : h,
1970
+ onMouseLeave: this.handleMouseLeave,
1971
+ onMouseEnter: this.handleMouseEnter,
1972
+ cursor: "pointer",
1973
+ position: "relative"
1974
+ }),
1975
+ n && b ? /* @__PURE__ */ T(G, {
1976
+ src: b,
1977
+ x: v,
1978
+ y,
1979
+ tooltip: s
1980
+ }) : null
1981
+ ]
1982
+ });
1983
+ }
1984
+ };
1985
+ Tt.propTypes = {
1986
+ hotspotColor: D.default.string.isRequired,
1987
+ id: D.default.string.isRequired,
1988
+ isCorrect: D.default.bool.isRequired,
1989
+ isEvaluateMode: D.default.bool.isRequired,
1990
+ hoverOutlineColor: D.default.string,
1991
+ disabled: D.default.bool.isRequired,
1992
+ onClick: D.default.func.isRequired,
1993
+ outlineColor: D.default.string.isRequired,
1994
+ points: D.default.array.isRequired,
1995
+ selected: D.default.bool.isRequired,
1996
+ evaluateText: D.default.string,
1997
+ selectedHotspotColor: D.default.string,
1998
+ strokeWidth: D.default.number,
1999
+ scale: D.default.number,
2000
+ markAsCorrect: D.default.bool.isRequired,
2001
+ showCorrectEnabled: D.default.bool.isRequired
2002
+ }, Tt.defaultProps = {
2003
+ evaluateText: null,
2004
+ strokeWidth: 5,
2005
+ scale: 1
2006
+ };
2007
+ //#endregion
2008
+ //#region src/delivery/hotspot/circle.tsx
2009
+ function X(e) {
2010
+ return typeof e == "function" || typeof e == "object" && !!e && typeof e.$$typeof == "symbol";
2011
+ }
2012
+ function Et(e, t) {
2013
+ return !e || X(e) ? e : X(e.default) ? e.default : t && X(e[t]) ? e[t] : t && X(e[t]?.default) ? e[t].default : e;
2014
+ }
2015
+ var Dt = Et(b, "Rect"), Ot = Et(_, "Group"), kt = Et(x, "Circle"), At = class extends S.Component {
2016
+ constructor(e) {
2017
+ super(e), this.state = { hovered: !1 };
2018
+ }
2019
+ handleClick = (e) => {
2020
+ let { onClick: t, id: n, selected: r, disabled: i } = this.props;
2021
+ i || (e.cancelBubble = !0, t({
2022
+ id: n,
2023
+ selected: !r,
2024
+ selector: "Mouse"
2025
+ }));
2026
+ };
2027
+ handleMouseEnter = () => {
2028
+ let { disabled: e } = this.props;
2029
+ e || (document.body.style.cursor = "pointer"), this.setState({ hovered: !0 });
2030
+ };
2031
+ handleMouseLeave = () => {
2032
+ document.body.style.cursor = "default", this.setState({ hovered: !1 });
2033
+ };
2034
+ getEvaluateOutlineColor = (e, t, n) => t ? "green" : e ? n : "red";
2035
+ getOutlineWidth = (e, t, n, r) => n || !n && !e && t ? r : 0;
2036
+ render() {
2037
+ let { radius: e, hotspotColor: t, isCorrect: n, isEvaluateMode: r, hoverOutlineColor: i, outlineColor: a, selected: o, x: s, y: c, evaluateText: l, strokeWidth: u, scale: d, markAsCorrect: f, selectedHotspotColor: p, showCorrectEnabled: m } = this.props, { hovered: h } = this.state, g = r ? this.getEvaluateOutlineColor(n, f, a) : a, _ = this.getOutlineWidth(m, o, f, u), v = s - 10, y = c - 10, b;
2038
+ m ? (o && n || !o && !n) && (b = K) : o ? b = n ? K : q : n || (b = q);
2039
+ let x = h && i;
2040
+ return /* @__PURE__ */ E(Ot, {
2041
+ scaleX: d,
2042
+ scaleY: d,
2043
+ children: [
2044
+ x && /* @__PURE__ */ T(Dt, {
2045
+ x: s - e,
2046
+ y: c - e,
2047
+ width: e * 2,
2048
+ height: e * 2,
2049
+ stroke: o ? "transparent" : i,
2050
+ strokeWidth: u
2051
+ }),
2052
+ /* @__PURE__ */ T(kt, {
2053
+ radius: e,
2054
+ fill: o && p ? p : t,
2055
+ onClick: this.handleClick,
2056
+ onTap: this.handleClick,
2057
+ draggable: !1,
2058
+ stroke: x && !o ? "transparent" : g,
2059
+ strokeWidth: x && !o ? 0 : _,
2060
+ onMouseLeave: this.handleMouseLeave,
2061
+ onMouseEnter: this.handleMouseEnter,
2062
+ x: s,
2063
+ y: c
2064
+ }),
2065
+ r && b ? /* @__PURE__ */ T(G, {
2066
+ src: b,
2067
+ x: v,
2068
+ y,
2069
+ tooltip: l
2070
+ }) : null
2071
+ ]
2072
+ });
2073
+ }
2074
+ };
2075
+ At.propTypes = {
2076
+ radius: D.default.number.isRequired,
2077
+ hotspotColor: D.default.string.isRequired,
2078
+ id: D.default.string.isRequired,
2079
+ isCorrect: D.default.oneOfType([D.default.bool, D.default.string]),
2080
+ isEvaluateMode: D.default.bool.isRequired,
2081
+ disabled: D.default.bool.isRequired,
2082
+ hoverOutlineColor: D.default.string,
2083
+ onClick: D.default.func.isRequired,
2084
+ outlineColor: D.default.string.isRequired,
2085
+ selected: D.default.bool.isRequired,
2086
+ x: D.default.number.isRequired,
2087
+ y: D.default.number.isRequired,
2088
+ evaluateText: D.default.string,
2089
+ strokeWidth: D.default.number,
2090
+ scale: D.default.number,
2091
+ selectedHotspotColor: D.default.string,
2092
+ markAsCorrect: D.default.bool.isRequired,
2093
+ showCorrectEnabled: D.default.bool.isRequired
2094
+ }, At.defaultProps = {
2095
+ isCorrect: !1,
2096
+ evaluateText: null,
2097
+ strokeWidth: 5,
2098
+ scale: 1
2099
+ };
2100
+ //#endregion
2101
+ //#region src/delivery/hotspot/container.tsx
2102
+ function Z(e) {
2103
+ return typeof e == "function" || typeof e == "object" && !!e && typeof e.$$typeof == "symbol";
2104
+ }
2105
+ function jt(e, t) {
2106
+ return !e || Z(e) ? e : Z(e.default) ? e.default : t && Z(e[t]) ? e[t] : t && Z(e[t]?.default) ? e[t].default : e;
2107
+ }
2108
+ var Mt = jt(p, "Stage"), Nt = jt(d, "Layer"), Pt = l("div")(({ theme: e }) => ({
2109
+ marginTop: e.spacing(2),
2110
+ marginBottom: e.spacing(2),
2111
+ position: "relative",
2112
+ background: e.palette.common.white,
2113
+ border: `${e.spacing(1)} solid ${e.palette.common.white}`,
2114
+ width: "fit-content"
2115
+ })), Ft = l("div")({
2116
+ position: "relative",
2117
+ width: "fit-content"
2118
+ }), It = l("img")({
2119
+ alignItems: "center",
2120
+ display: "flex",
2121
+ justifyContent: "center"
2122
+ }), Lt = l(Mt)({
2123
+ left: 0,
2124
+ top: 0,
2125
+ position: "absolute"
2126
+ }), Rt = class extends S.Component {
2127
+ isSelected(e) {
2128
+ return !!this.props.session.answers.filter((t) => t.id === e.id)[0];
2129
+ }
2130
+ correctness = (e, t) => e ? t : !t;
2131
+ getEvaluateText = (e, t) => t && e ? "Correctly\nselected" : t && !e ? "Should not have\nbeen selected" : !t && e ? "Should have\nbeen selected" : null;
2132
+ render() {
2133
+ let { dimensions: { width: e, height: t }, disabled: n, hotspotColor: r, hoverOutlineColor: i, selectedHotspotColor: a, imageUrl: o, isEvaluateMode: s, outlineColor: c, onSelectChoice: l, shapes: { rectangles: u = [], polygons: d = [], circles: f = [] }, scale: p, strokeWidth: m, showCorrect: h } = this.props, g = e * p, _ = t * p;
2134
+ return /* @__PURE__ */ E(Pt, {
2135
+ style: { padding: m / 2 },
2136
+ children: [o ? /* @__PURE__ */ T(Ft, { children: /* @__PURE__ */ T(It, {
2137
+ alt: "hotspot-image",
2138
+ height: "auto",
2139
+ src: o,
2140
+ style: {
2141
+ width: g,
2142
+ height: _,
2143
+ maxWidth: g,
2144
+ maxHeight: _
2145
+ }
2146
+ }) }) : null, /* @__PURE__ */ T(Lt, {
2147
+ height: _ + m,
2148
+ width: g + m,
2149
+ x: m / 2,
2150
+ y: m / 2,
2151
+ children: /* @__PURE__ */ E(Nt, { children: [
2152
+ u.map((e) => {
2153
+ let t = this.isSelected(e), o = s ? this.correctness(e.correct, t) : void 0, u = s ? this.getEvaluateText(e.correct, t) : null, d = !!(s && h && e.correct);
2154
+ return /* @__PURE__ */ T(bt, {
2155
+ scale: p,
2156
+ isEvaluateMode: s,
2157
+ isCorrect: o,
2158
+ evaluateText: u,
2159
+ disabled: n,
2160
+ selected: t,
2161
+ height: e.height,
2162
+ hotspotColor: r,
2163
+ hoverOutlineColor: i,
2164
+ selectedHotspotColor: a,
2165
+ id: e.id,
2166
+ onClick: l,
2167
+ outlineColor: c,
2168
+ width: e.width,
2169
+ x: e.x,
2170
+ y: e.y,
2171
+ strokeWidth: m,
2172
+ markAsCorrect: d,
2173
+ showCorrectEnabled: h
2174
+ }, e.id);
2175
+ }),
2176
+ d.map((e) => {
2177
+ let t = this.isSelected(e), o = s ? this.correctness(e.correct, t) : void 0, u = s ? this.getEvaluateText(e.correct, t) : null, d = !!(s && h && e.correct);
2178
+ return /* @__PURE__ */ T(Tt, {
2179
+ scale: p,
2180
+ isEvaluateMode: s,
2181
+ isCorrect: !!o,
2182
+ evaluateText: u,
2183
+ disabled: n,
2184
+ selected: t,
2185
+ hotspotColor: r,
2186
+ id: e.id,
2187
+ onClick: l,
2188
+ outlineColor: c,
2189
+ points: e.points,
2190
+ strokeWidth: m,
2191
+ markAsCorrect: d,
2192
+ selectedHotspotColor: a,
2193
+ hoverOutlineColor: i,
2194
+ showCorrectEnabled: h
2195
+ }, e.id);
2196
+ }),
2197
+ f.map((e) => {
2198
+ let t = this.isSelected(e), o = s ? this.correctness(e.correct, t) : void 0, u = s ? this.getEvaluateText(e.correct, t) : null, d = !!(s && h && e.correct);
2199
+ return /* @__PURE__ */ T(At, {
2200
+ scale: p,
2201
+ isEvaluateMode: s,
2202
+ isCorrect: o,
2203
+ evaluateText: u,
2204
+ disabled: n,
2205
+ selected: t,
2206
+ radius: e.radius,
2207
+ hotspotColor: r,
2208
+ id: e.id,
2209
+ onClick: l,
2210
+ outlineColor: c,
2211
+ x: e.x,
2212
+ y: e.y,
2213
+ strokeWidth: m,
2214
+ markAsCorrect: d,
2215
+ selectedHotspotColor: a,
2216
+ hoverOutlineColor: i,
2217
+ showCorrectEnabled: h
2218
+ }, e.id);
2219
+ })
2220
+ ] })
2221
+ })]
2222
+ });
2223
+ }
2224
+ };
2225
+ Rt.propTypes = {
2226
+ dimensions: D.default.object.isRequired,
2227
+ disabled: D.default.bool.isRequired,
2228
+ hotspotColor: D.default.string.isRequired,
2229
+ hoverOutlineColor: D.default.string,
2230
+ imageUrl: D.default.string.isRequired,
2231
+ isEvaluateMode: D.default.bool.isRequired,
2232
+ onSelectChoice: D.default.func.isRequired,
2233
+ outlineColor: D.default.string.isRequired,
2234
+ selectedHotspotColor: D.default.string,
2235
+ session: D.default.object.isRequired,
2236
+ shapes: D.default.object.isRequired,
2237
+ strokeWidth: D.default.number,
2238
+ scale: D.default.number,
2239
+ showCorrect: D.default.bool
2240
+ }, Rt.defaultProps = { scale: 1 };
2241
+ //#endregion
2242
+ //#region src/delivery/hotspot/index.tsx
2243
+ function Q(e) {
2244
+ return typeof e == "function" || typeof e == "object" && !!e && typeof e.$$typeof == "symbol";
2245
+ }
2246
+ function $(e, t) {
2247
+ return !e || Q(e) ? e : Q(e.default) ? e.default : t && Q(e[t]) ? e[t] : t && Q(e[t]?.default) ? e[t].default : e;
2248
+ }
2249
+ var zt = $(s, "UiLayout") || $(Wt.UiLayout, "UiLayout"), Bt = $(h, "PreviewPrompt") || $(Wt.PreviewPrompt, "PreviewPrompt"), Vt = $(u, "Collapsible") || $(Wt.Collapsible, "Collapsible"), Ht = f, Ut = Ht.default, Wt = Ut && typeof Ut == "object" ? Ut : Ht, Gt = l(zt)({
2250
+ color: o.text(),
2251
+ backgroundColor: o.background(),
2252
+ position: "relative"
2253
+ }), Kt = l(Vt)(({ theme: e }) => ({ marginBottom: e.spacing(2) })), qt = class extends S.Component {
2254
+ constructor(e) {
2255
+ super(e), this.state = {
2256
+ showCorrect: !1,
2257
+ observer: null,
2258
+ scale: 1
2259
+ };
2260
+ }
2261
+ componentDidMount() {
2262
+ this.observer = new MutationObserver((e) => {
2263
+ e.forEach(() => {
2264
+ let e = document.getElementById("question-container")?.style?.cssText, t = (e?.substring(e.indexOf("--pie-zoom") + 11, e.lastIndexOf("%")))?.replace(/\s/g, "");
2265
+ t ? parseFloat(t) / 100 !== this.state.scale && this.setState({ scale: parseFloat(t) / 100 }) : !t && this.state.scale !== 1 && this.setState({ scale: 1 });
2266
+ });
2267
+ });
2268
+ let e = document.getElementById("question-container");
2269
+ e && this.observer.observe(e, {
2270
+ attributes: !0,
2271
+ attributeFilter: ["style"]
2272
+ });
2273
+ }
2274
+ componentWillUnmount() {
2275
+ this.observer?.disconnect();
2276
+ }
2277
+ onToggle = () => {
2278
+ let { showCorrect: e } = this.state;
2279
+ this.setState({ showCorrect: !e });
2280
+ };
2281
+ render() {
2282
+ let { session: e, model: { disabled: r, extraCSSRules: i, imageUrl: a, prompt: o, mode: s, multipleCorrect: c, shapes: l, outlineColor: u, hotspotColor: d, hoverOutlineColor: f, selectedHotspotColor: p, dimensions: m, rationale: h, teacherInstructions: g, strokeWidth: _, responseCorrect: v, language: y, fontSizeFactor: b, autoplayAudioEnabled: x, customAudioButton: S }, onSelectChoice: C } = this.props, { showCorrect: w } = this.state, D = s === "evaluate", O = s === "gather", k = D && !v, ee = h && (t(h) || n(h));
2283
+ return /* @__PURE__ */ E(Gt, {
2284
+ extraCSSRules: i,
2285
+ id: "main-container",
2286
+ fontSizeFactor: b,
2287
+ children: [
2288
+ g && (t(g) || n(g)) && /* @__PURE__ */ T(Kt, {
2289
+ labels: {
2290
+ hidden: "Show Teacher Instructions",
2291
+ visible: "Hide Teacher Instructions"
2292
+ },
2293
+ children: /* @__PURE__ */ T(Bt, {
2294
+ className: "prompt",
2295
+ prompt: g
2296
+ })
2297
+ }),
2298
+ o && /* @__PURE__ */ T(Bt, {
2299
+ className: "prompt",
2300
+ prompt: o,
2301
+ autoplayAudioEnabled: x,
2302
+ customAudioButton: S
2303
+ }),
2304
+ k && /* @__PURE__ */ T(dt, {
2305
+ show: k,
2306
+ toggled: w,
2307
+ onToggle: this.onToggle.bind(this),
2308
+ language: y
2309
+ }),
2310
+ a ? /* @__PURE__ */ T(Rt, {
2311
+ isEvaluateMode: D,
2312
+ session: e,
2313
+ dimensions: m,
2314
+ imageUrl: a,
2315
+ hotspotColor: d,
2316
+ hoverOutlineColor: O ? f : void 0,
2317
+ selectedHotspotColor: p,
2318
+ multipleCorrect: c,
2319
+ outlineColor: u,
2320
+ onSelectChoice: C,
2321
+ shapes: l,
2322
+ disabled: r,
2323
+ strokeWidth: _,
2324
+ scale: this.state.scale,
2325
+ showCorrect: w
2326
+ }) : null,
2327
+ ee && /* @__PURE__ */ T(Vt, {
2328
+ labels: {
2329
+ hidden: "Show Rationale",
2330
+ visible: "Hide Rationale"
2331
+ },
2332
+ children: /* @__PURE__ */ T(Bt, {
2333
+ className: "prompt",
2334
+ prompt: h
2335
+ })
2336
+ })
2337
+ ]
2338
+ });
2339
+ }
2340
+ };
2341
+ qt.propTypes = {
2342
+ model: D.default.object.isRequired,
2343
+ onSelectChoice: D.default.func.isRequired,
2344
+ session: D.default.object.isRequired
2345
+ };
2346
+ //#endregion
2347
+ //#region src/delivery/session-updater.ts
2348
+ function Jt(e, t, n) {
2349
+ let { id: r, selected: i } = n, { multipleCorrect: a } = t || {};
2350
+ if (e.answers = e.answers || [], !i) e.answers = e.answers.filter((e) => e.id !== r);
2351
+ else {
2352
+ let t = { id: r };
2353
+ a ? e.answers.push(t) : e.answers = [t], e.selector = n.selector;
2354
+ }
2355
+ }
2356
+ function Yt(e, t) {
2357
+ e.audioStartTime = e.audioStartTime || t.audioStartTime, e.audioEndTime = e.audioEndTime || t.audioEndTime, !e.waitTime && e.audioStartTime && e.audioEndTime && (e.waitTime = e.audioEndTime - e.audioStartTime);
2358
+ }
2359
+ //#endregion
2360
+ //#region src/delivery/index.ts
2361
+ function Xt(e) {
2362
+ return typeof e == "function" || typeof e == "object" && !!e && typeof e.$$typeof == "symbol";
2363
+ }
2364
+ function Zt(e, t) {
2365
+ return !e || Xt(e) ? e : Xt(e.default) ? e.default : t && Xt(e[t]) ? e[t] : t && Xt(e[t]?.default) ? e[t].default : e;
2366
+ }
2367
+ var Qt = Zt("data:image/jpeg;base64,/9j/4AAQSkZJRgABAQAAAQABAAD/2wBDAAMCAgICAgMCAgIDAwMDBAYEBAQEBAgGBgUGCQgKCgkICQkKDA8MCgsOCwkJDRENDg8QEBEQCgwSExIQEw8QEBD/2wBDAQMDAwQDBAgEBAgQCwkLEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBD/wAARCAJYAyADAREAAhEBAxEB/8QAHgABAQABBQEBAQAAAAAAAAAAAAEIAgMGBwkEBQr/xABiEAACAQIDBAMKCAYMCgYLAQAAAQIDEQQFIQYSMUEHCFETFRYiUmFxkdHhCRRjgaGisfAXMjRTcsEjJDY4QmJ1dpKztMQYMzdEVIKyw9PxQ1hmc3SWJzVFRlZXhJOUldJk/8QAGwEBAQADAQEBAAAAAAAAAAAAAAcEBQYCAQP/xABBEQEAAQIDAgkJBgUFAQEBAAAAAQIDBAYRBSESMUFEYXGCscITNDVRcoGRocEUIjJS0eEVI2KSsjNCU6LwFtLx/9oADAMBAAIRAxEAPwD1TAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA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", "EnableAudioAutoplayImage") || Zt(tn.EnableAudioAutoplayImage, "EnableAudioAutoplayImage"), $t = f, en = $t.default, tn = en && typeof en == "object" ? en : $t, nn = class extends HTMLElement {
2368
+ constructor() {
2369
+ super(), this._model = null, this._session = null, this._audioInitialized = !1, this.audioComplete = !1, this._root = null;
2370
+ }
2371
+ set model(e) {
2372
+ this._model = e, this.dispatchEvent(new te(this.tagName.toLowerCase(), this.isComplete(), !!this._model)), this._audioInitialized = !1, this._render();
2373
+ }
2374
+ isComplete() {
2375
+ if (!this._session || !this._session.answers) return !1;
2376
+ let { autoplayAudioEnabled: e, completeAudioEnabled: t } = this._model || {}, n = this;
2377
+ if (e && t && !this.audioComplete && n) {
2378
+ let e = n.querySelector("audio"), t = e && e.closest("#preview-prompt");
2379
+ if (e && t) return !1;
2380
+ }
2381
+ return Array.isArray(this._session.answers) ? this._session.answers.length > 0 : !1;
2382
+ }
2383
+ set session(e) {
2384
+ e && !e.answers && (e.answers = []), this._session = e, this._render();
2385
+ }
2386
+ get session() {
2387
+ return this._session;
2388
+ }
2389
+ onSelectChoice(e) {
2390
+ Jt(this._session, this._model, e), this.dispatchEvent(new ne(this.tagName.toLowerCase(), this.isComplete())), this._render();
2391
+ }
2392
+ _createAudioInfoToast() {
2393
+ let e = document.createElement("div");
2394
+ e.id = "play-audio-info", Object.assign(e.style, {
2395
+ position: "absolute",
2396
+ top: 0,
2397
+ width: "100%",
2398
+ height: "100%",
2399
+ display: "flex",
2400
+ justifyContent: "center",
2401
+ alignItems: "center",
2402
+ background: "white",
2403
+ zIndex: "1000",
2404
+ cursor: "pointer"
2405
+ });
2406
+ let t = document.createElement("img");
2407
+ return t.src = Qt, t.alt = "Click anywhere to enable audio autoplay", t.width = 500, t.height = 300, e.appendChild(t), e;
2408
+ }
2409
+ connectedCallback() {
2410
+ this._render(), new MutationObserver((e, t) => {
2411
+ e.forEach((e) => {
2412
+ if (e.type === "childList") {
2413
+ if (this._audioInitialized) return;
2414
+ let e = this.querySelector("audio"), n = e && e.closest("#preview-prompt");
2415
+ if (!this._model || !this._model.autoplayAudioEnabled || e && !n || !e) return;
2416
+ let r = this._createAudioInfoToast(), i = this.querySelector("#main-container"), a = () => {
2417
+ this.querySelector("#play-audio-info") && (e.play(), i.removeChild(r)), document.removeEventListener("click", a);
2418
+ };
2419
+ setTimeout(() => {
2420
+ e.paused && !this.querySelector("#play-audio-info") ? (i.appendChild(r), document.addEventListener("click", a)) : document.removeEventListener("click", a);
2421
+ }, 500);
2422
+ let o = () => {
2423
+ Yt(this._session, { audioStartTime: (/* @__PURE__ */ new Date()).getTime() });
2424
+ let t = this.querySelector("#play-audio-info");
2425
+ t && i.removeChild(t), e.removeEventListener("playing", o);
2426
+ };
2427
+ e.addEventListener("playing", o);
2428
+ let s = () => {
2429
+ Yt(this._session, { audioEndTime: (/* @__PURE__ */ new Date()).getTime() });
2430
+ let { audioStartTime: t, audioEndTime: n, waitTime: r } = this._session;
2431
+ !r && t && n && (this._session.waitTime = n - t), this.audioComplete = !0, this.dispatchEvent(new ne(this.tagName.toLowerCase(), this.isComplete())), e.removeEventListener("ended", s);
2432
+ };
2433
+ e.addEventListener("ended", s), this._audio = e, this._handlePlaying = o, this._handleEnded = s, this._enableAudio = a, this._audioInitialized = !0, t.disconnect();
2434
+ }
2435
+ });
2436
+ }).observe(this, {
2437
+ childList: !0,
2438
+ subtree: !0
2439
+ });
2440
+ }
2441
+ _render() {
2442
+ if (this._model && this._session) {
2443
+ let e = S.createElement(qt, {
2444
+ model: this._model,
2445
+ session: this._session,
2446
+ onSelectChoice: this.onSelectChoice.bind(this)
2447
+ });
2448
+ this._root ||= w(this), this._root.render(e), queueMicrotask(() => {
2449
+ a(this);
2450
+ });
2451
+ }
2452
+ }
2453
+ disconnectedCallback() {
2454
+ document.removeEventListener("click", this._enableAudio), this._audio &&= (this._audio.removeEventListener("playing", this._handlePlaying), this._audio.removeEventListener("ended", this._handleEnded), null), this._root && this._root.unmount();
2455
+ }
2456
+ };
2457
+ //#endregion
2458
+ export { nn as default };
2459
+
2460
+ //# sourceMappingURL=index.js.map