kritzel-stencil 0.0.130 → 0.0.132

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 (388) hide show
  1. package/dist/cjs/{index-CUSIflVf.js → index-nzUNdMPh.js} +47 -17
  2. package/dist/cjs/index-nzUNdMPh.js.map +1 -0
  3. package/dist/cjs/{index-CfXjPLHb.js → index-ouFX0OVi.js} +891 -802
  4. package/dist/cjs/index-ouFX0OVi.js.map +1 -0
  5. package/dist/cjs/index.cjs.js +2 -1
  6. package/dist/cjs/index.cjs.js.map +1 -1
  7. package/dist/cjs/kritzel-brush-style.cjs.entry.js +32 -0
  8. package/dist/cjs/kritzel-brush-style.entry.cjs.js.map +1 -0
  9. package/dist/cjs/{kritzel-brush-style_23.cjs.entry.js → kritzel-color_22.cjs.entry.js} +1539 -1325
  10. package/dist/cjs/loader.cjs.js +2 -2
  11. package/dist/cjs/stencil.cjs.js +3 -3
  12. package/dist/cjs/stencil.cjs.js.map +1 -1
  13. package/dist/collection/classes/commands/add-object.command.js +7 -7
  14. package/dist/collection/classes/commands/add-object.command.js.map +1 -1
  15. package/dist/collection/classes/commands/add-selection-group.command.js +10 -9
  16. package/dist/collection/classes/commands/add-selection-group.command.js.map +1 -1
  17. package/dist/collection/classes/commands/base.command.js +6 -4
  18. package/dist/collection/classes/commands/base.command.js.map +1 -1
  19. package/dist/collection/classes/commands/batch.command.js +3 -2
  20. package/dist/collection/classes/commands/batch.command.js.map +1 -1
  21. package/dist/collection/classes/commands/move-selection-group.command.js +13 -7
  22. package/dist/collection/classes/commands/move-selection-group.command.js.map +1 -1
  23. package/dist/collection/classes/commands/remove-object.command.js +9 -9
  24. package/dist/collection/classes/commands/remove-object.command.js.map +1 -1
  25. package/dist/collection/classes/commands/remove-selection-group.command.js +8 -7
  26. package/dist/collection/classes/commands/remove-selection-group.command.js.map +1 -1
  27. package/dist/collection/classes/commands/resize-selection-group.command.js +10 -7
  28. package/dist/collection/classes/commands/resize-selection-group.command.js.map +1 -1
  29. package/dist/collection/classes/commands/rotate-selection-group.command.js +15 -12
  30. package/dist/collection/classes/commands/rotate-selection-group.command.js.map +1 -1
  31. package/dist/collection/classes/commands/update-object.command.js +7 -5
  32. package/dist/collection/classes/commands/update-object.command.js.map +1 -1
  33. package/dist/collection/classes/commands/update-viewport.command.js +13 -11
  34. package/dist/collection/classes/commands/update-viewport.command.js.map +1 -1
  35. package/dist/collection/classes/{store.class.js → core/core.class.js} +123 -147
  36. package/dist/collection/classes/core/core.class.js.map +1 -0
  37. package/dist/collection/classes/{database.class.js → core/database.class.js} +34 -25
  38. package/dist/collection/classes/core/database.class.js.map +1 -0
  39. package/dist/collection/classes/core/history.class.js +88 -0
  40. package/dist/collection/classes/core/history.class.js.map +1 -0
  41. package/dist/collection/classes/{reviver.class.js → core/reviver.class.js} +27 -22
  42. package/dist/collection/classes/core/reviver.class.js.map +1 -0
  43. package/dist/collection/classes/core/store.class.js +51 -0
  44. package/dist/collection/classes/core/store.class.js.map +1 -0
  45. package/dist/collection/classes/core/viewport.class.js +165 -0
  46. package/dist/collection/classes/core/viewport.class.js.map +1 -0
  47. package/dist/collection/classes/core/workspace.class.js +42 -0
  48. package/dist/collection/classes/core/workspace.class.js.map +1 -0
  49. package/dist/collection/classes/handlers/base.handler.js +4 -3
  50. package/dist/collection/classes/handlers/base.handler.js.map +1 -1
  51. package/dist/collection/classes/handlers/context-menu.handler.js +26 -21
  52. package/dist/collection/classes/handlers/context-menu.handler.js.map +1 -1
  53. package/dist/collection/classes/handlers/hover.handler.js +5 -5
  54. package/dist/collection/classes/handlers/hover.handler.js.map +1 -1
  55. package/dist/collection/classes/handlers/key.handler.js +38 -44
  56. package/dist/collection/classes/handlers/key.handler.js.map +1 -1
  57. package/dist/collection/classes/handlers/move.handler.js +40 -35
  58. package/dist/collection/classes/handlers/move.handler.js.map +1 -1
  59. package/dist/collection/classes/handlers/resize.handler.js +57 -60
  60. package/dist/collection/classes/handlers/resize.handler.js.map +1 -1
  61. package/dist/collection/classes/handlers/rotation.handler.js +55 -57
  62. package/dist/collection/classes/handlers/rotation.handler.js.map +1 -1
  63. package/dist/collection/classes/handlers/selection.handler.js +78 -75
  64. package/dist/collection/classes/handlers/selection.handler.js.map +1 -1
  65. package/dist/collection/classes/objects/base-object.class.js +49 -31
  66. package/dist/collection/classes/objects/base-object.class.js.map +1 -1
  67. package/dist/collection/classes/objects/custom-element.class.js +6 -5
  68. package/dist/collection/classes/objects/custom-element.class.js.map +1 -1
  69. package/dist/collection/classes/objects/image.class.js +17 -17
  70. package/dist/collection/classes/objects/image.class.js.map +1 -1
  71. package/dist/collection/classes/objects/path.class.js +36 -34
  72. package/dist/collection/classes/objects/path.class.js.map +1 -1
  73. package/dist/collection/classes/objects/selection-box.class.js +6 -9
  74. package/dist/collection/classes/objects/selection-box.class.js.map +1 -1
  75. package/dist/collection/classes/objects/selection-group.class.js +23 -22
  76. package/dist/collection/classes/objects/selection-group.class.js.map +1 -1
  77. package/dist/collection/classes/objects/text.class.js +23 -23
  78. package/dist/collection/classes/objects/text.class.js.map +1 -1
  79. package/dist/collection/classes/registries/icon-registry.class.js +1 -1
  80. package/dist/collection/classes/registries/icon-registry.class.js.map +1 -1
  81. package/dist/collection/classes/registries/tool.registry.js +3 -3
  82. package/dist/collection/classes/registries/tool.registry.js.map +1 -1
  83. package/dist/collection/classes/structures/circular-buffer.structure.js +5 -3
  84. package/dist/collection/classes/structures/circular-buffer.structure.js.map +1 -1
  85. package/dist/collection/classes/structures/object-map.structure.js +1 -0
  86. package/dist/collection/classes/structures/object-map.structure.js.map +1 -1
  87. package/dist/collection/classes/tools/base-tool.class.js +13 -6
  88. package/dist/collection/classes/tools/base-tool.class.js.map +1 -1
  89. package/dist/collection/classes/tools/brush-tool.class.js +64 -60
  90. package/dist/collection/classes/tools/brush-tool.class.js.map +1 -1
  91. package/dist/collection/classes/tools/eraser-tool.class.js +27 -28
  92. package/dist/collection/classes/tools/eraser-tool.class.js.map +1 -1
  93. package/dist/collection/classes/tools/image-tool.class.js +14 -15
  94. package/dist/collection/classes/tools/image-tool.class.js.map +1 -1
  95. package/dist/collection/classes/tools/selection-tool.class.js +48 -43
  96. package/dist/collection/classes/tools/selection-tool.class.js.map +1 -1
  97. package/dist/collection/classes/tools/text-tool.class.js +57 -58
  98. package/dist/collection/classes/tools/text-tool.class.js.map +1 -1
  99. package/dist/collection/collection-manifest.json +1 -1
  100. package/dist/collection/components/core/kritzel-cursor-trail/kritzel-cursor-trail.js +30 -30
  101. package/dist/collection/components/core/kritzel-cursor-trail/kritzel-cursor-trail.js.map +1 -1
  102. package/dist/collection/components/core/kritzel-editor/kritzel-editor.css +7 -9
  103. package/dist/collection/components/core/kritzel-editor/kritzel-editor.js +267 -93
  104. package/dist/collection/components/core/kritzel-editor/kritzel-editor.js.map +1 -1
  105. package/dist/collection/components/core/kritzel-engine/kritzel-engine.js +319 -327
  106. package/dist/collection/components/core/kritzel-engine/kritzel-engine.js.map +1 -1
  107. package/dist/collection/components/shared/kritzel-brush-style/kritzel-brush-style.js +7 -8
  108. package/dist/collection/components/shared/kritzel-brush-style/kritzel-brush-style.js.map +1 -1
  109. package/dist/collection/components/shared/kritzel-color/kritzel-color.js +4 -5
  110. package/dist/collection/components/shared/kritzel-color/kritzel-color.js.map +1 -1
  111. package/dist/collection/components/shared/kritzel-color-palette/kritzel-color-palette.css +5 -0
  112. package/dist/collection/components/shared/kritzel-color-palette/kritzel-color-palette.js +8 -9
  113. package/dist/collection/components/shared/kritzel-color-palette/kritzel-color-palette.js.map +1 -1
  114. package/dist/collection/components/shared/kritzel-dropdown/kritzel-dropdown.js +53 -49
  115. package/dist/collection/components/shared/kritzel-dropdown/kritzel-dropdown.js.map +1 -1
  116. package/dist/collection/components/shared/kritzel-font/kritzel-font.js +4 -6
  117. package/dist/collection/components/shared/kritzel-font/kritzel-font.js.map +1 -1
  118. package/dist/collection/components/shared/kritzel-font-family/kritzel-font-family.js +18 -18
  119. package/dist/collection/components/shared/kritzel-font-family/kritzel-font-family.js.map +1 -1
  120. package/dist/collection/components/shared/kritzel-font-size/kritzel-font-size.js +5 -6
  121. package/dist/collection/components/shared/kritzel-font-size/kritzel-font-size.js.map +1 -1
  122. package/dist/collection/components/shared/kritzel-icon/kritzel-icon.css +1 -0
  123. package/dist/collection/components/shared/kritzel-icon/kritzel-icon.js +3 -3
  124. package/dist/collection/components/shared/kritzel-icon/kritzel-icon.js.map +1 -1
  125. package/dist/collection/components/shared/kritzel-menu/kritzel-menu.css +6 -2
  126. package/dist/collection/components/shared/kritzel-menu/kritzel-menu.js +36 -30
  127. package/dist/collection/components/shared/kritzel-menu/kritzel-menu.js.map +1 -1
  128. package/dist/collection/components/shared/kritzel-menu-item/kritzel-menu-item.css +25 -7
  129. package/dist/collection/components/shared/kritzel-menu-item/kritzel-menu-item.js +61 -40
  130. package/dist/collection/components/shared/kritzel-menu-item/kritzel-menu-item.js.map +1 -1
  131. package/dist/collection/components/shared/kritzel-portal/kritzel-portal.js +22 -61
  132. package/dist/collection/components/shared/kritzel-portal/kritzel-portal.js.map +1 -1
  133. package/dist/collection/components/shared/kritzel-split-button/kritzel-split-button.css +16 -20
  134. package/dist/collection/components/shared/kritzel-split-button/kritzel-split-button.js +104 -53
  135. package/dist/collection/components/shared/kritzel-split-button/kritzel-split-button.js.map +1 -1
  136. package/dist/collection/components/shared/kritzel-stroke-size/kritzel-stroke-size.css +4 -0
  137. package/dist/collection/components/shared/kritzel-stroke-size/kritzel-stroke-size.js +4 -5
  138. package/dist/collection/components/shared/kritzel-stroke-size/kritzel-stroke-size.js.map +1 -1
  139. package/dist/collection/components/shared/kritzel-tooltip/kritzel-tooltip.js +85 -14
  140. package/dist/collection/components/shared/kritzel-tooltip/kritzel-tooltip.js.map +1 -1
  141. package/dist/collection/components/ui/kritzel-context-menu/kritzel-context-menu.js +50 -16
  142. package/dist/collection/components/ui/kritzel-context-menu/kritzel-context-menu.js.map +1 -1
  143. package/dist/collection/components/ui/kritzel-control-brush-config/kritzel-control-brush-config.css +4 -0
  144. package/dist/collection/components/ui/kritzel-control-brush-config/kritzel-control-brush-config.js +7 -7
  145. package/dist/collection/components/ui/kritzel-control-brush-config/kritzel-control-brush-config.js.map +1 -1
  146. package/dist/collection/components/ui/kritzel-control-text-config/kritzel-control-text-config.js +5 -5
  147. package/dist/collection/components/ui/kritzel-control-text-config/kritzel-control-text-config.js.map +1 -1
  148. package/dist/collection/components/ui/kritzel-controls/kritzel-controls.css +12 -1
  149. package/dist/collection/components/ui/kritzel-controls/kritzel-controls.js +41 -32
  150. package/dist/collection/components/ui/kritzel-controls/kritzel-controls.js.map +1 -1
  151. package/dist/collection/components/ui/kritzel-utility-panel/kritzel-utility-panel.css +5 -0
  152. package/dist/collection/components/ui/kritzel-utility-panel/kritzel-utility-panel.js +4 -1
  153. package/dist/collection/components/ui/kritzel-utility-panel/kritzel-utility-panel.js.map +1 -1
  154. package/dist/collection/components/ui/kritzel-workspace-manager/kritzel-workspace-manager.js +40 -28
  155. package/dist/collection/components/ui/kritzel-workspace-manager/kritzel-workspace-manager.js.map +1 -1
  156. package/dist/collection/configs/default-engine-state.js +0 -1
  157. package/dist/collection/configs/default-engine-state.js.map +1 -1
  158. package/dist/collection/helpers/devices.helper.js +20 -0
  159. package/dist/collection/helpers/devices.helper.js.map +1 -1
  160. package/dist/collection/helpers/event.helper.js +2 -6
  161. package/dist/collection/helpers/event.helper.js.map +1 -1
  162. package/dist/collection/helpers/html.helper.js +30 -2
  163. package/dist/collection/helpers/html.helper.js.map +1 -1
  164. package/dist/collection/helpers/object.helper.js +2 -14
  165. package/dist/collection/helpers/object.helper.js.map +1 -1
  166. package/dist/collection/index.js +1 -0
  167. package/dist/collection/index.js.map +1 -1
  168. package/dist/collection/interfaces/engine-state.interface.js.map +1 -1
  169. package/dist/collection/interfaces/serializable.interface.js.map +1 -1
  170. package/dist/collection/types/deep-readonly.type.js +2 -0
  171. package/dist/collection/types/deep-readonly.type.js.map +1 -0
  172. package/dist/components/index.js +4 -3
  173. package/dist/components/index.js.map +1 -1
  174. package/dist/components/kritzel-brush-style.js +59 -1
  175. package/dist/components/kritzel-brush-style.js.map +1 -1
  176. package/dist/components/kritzel-color-palette.js +1 -1
  177. package/dist/components/kritzel-color.js +1 -1
  178. package/dist/components/kritzel-context-menu.js +1 -1
  179. package/dist/components/kritzel-control-brush-config.js +1 -1
  180. package/dist/components/kritzel-control-text-config.js +1 -1
  181. package/dist/components/kritzel-controls.js +1 -1
  182. package/dist/components/kritzel-cursor-trail.js +1 -1
  183. package/dist/components/kritzel-dropdown.js +1 -1
  184. package/dist/components/kritzel-editor.js +172 -124
  185. package/dist/components/kritzel-editor.js.map +1 -1
  186. package/dist/components/kritzel-engine.js +1 -1
  187. package/dist/components/kritzel-font-family.js +1 -1
  188. package/dist/components/kritzel-font-size.js +1 -1
  189. package/dist/components/kritzel-font.js +1 -1
  190. package/dist/components/kritzel-icon.js +1 -1
  191. package/dist/components/kritzel-menu-item.js +1 -1
  192. package/dist/components/kritzel-menu.js +1 -1
  193. package/dist/components/kritzel-portal.js +1 -1
  194. package/dist/components/kritzel-split-button.js +1 -1
  195. package/dist/components/kritzel-stroke-size.js +1 -1
  196. package/dist/components/kritzel-tooltip.js +1 -1
  197. package/dist/components/kritzel-utility-panel.js +1 -1
  198. package/dist/components/kritzel-workspace-manager.js +1 -1
  199. package/dist/components/{p-BGccckxP.js → p-0iJh9Z6m.js} +9 -8
  200. package/dist/components/p-0iJh9Z6m.js.map +1 -0
  201. package/dist/components/{p-C9-70hiF.js → p-B3VQubt_.js} +268 -236
  202. package/dist/components/p-B3VQubt_.js.map +1 -0
  203. package/dist/components/{p-5CJxFNEE.js → p-B7kZ1_RH.js} +7 -6
  204. package/dist/components/p-B7kZ1_RH.js.map +1 -0
  205. package/dist/components/{p-Cb1IUD_g.js → p-B7w19kIk.js} +17 -27
  206. package/dist/components/p-B7w19kIk.js.map +1 -0
  207. package/dist/components/{p-BU2q3PRS.js → p-BGdsAz54.js} +31 -19
  208. package/dist/components/p-BGdsAz54.js.map +1 -0
  209. package/dist/components/{p-BZ-j_4CK.js → p-BM9IjvnD.js} +7 -7
  210. package/dist/components/p-BM9IjvnD.js.map +1 -0
  211. package/dist/components/{p-26poIWa_.js → p-BPsQrpzN.js} +47 -18
  212. package/dist/components/p-BPsQrpzN.js.map +1 -0
  213. package/dist/components/{p-BqrTPNyu.js → p-BYanlgdq.js} +41 -15
  214. package/dist/components/p-BYanlgdq.js.map +1 -0
  215. package/dist/components/{p-D_Uh-xv_.js → p-BiCgeOiJ.js} +60 -56
  216. package/dist/components/p-BiCgeOiJ.js.map +1 -0
  217. package/dist/components/{p-BcQWRzsB.js → p-C1-nvBx9.js} +42 -29
  218. package/dist/components/p-C1-nvBx9.js.map +1 -0
  219. package/dist/components/p-C6qB08BS.js +68 -0
  220. package/dist/components/p-C6qB08BS.js.map +1 -0
  221. package/dist/components/{p-jpGLgpoq.js → p-CTvJDYFQ.js} +26 -64
  222. package/dist/components/p-CTvJDYFQ.js.map +1 -0
  223. package/dist/components/{p-BAPUTr3K.js → p-CsyM5q2M.js} +13 -12
  224. package/dist/components/p-CsyM5q2M.js.map +1 -0
  225. package/dist/components/p-CvmWmUK9.js +149 -0
  226. package/dist/components/p-CvmWmUK9.js.map +1 -0
  227. package/dist/components/{p-fyfT6A5K.js → p-DCx3703u.js} +9 -6
  228. package/dist/components/p-DCx3703u.js.map +1 -0
  229. package/dist/components/{p-BvlGgLAQ.js → p-DFO-6kuA.js} +57 -51
  230. package/dist/components/p-DFO-6kuA.js.map +1 -0
  231. package/dist/components/p-D_907-Wd.js +267 -0
  232. package/dist/components/p-D_907-Wd.js.map +1 -0
  233. package/dist/components/{p-jGaWxggY.js → p-Davd1R_4.js} +1278 -1227
  234. package/dist/components/p-Davd1R_4.js.map +1 -0
  235. package/dist/components/{p-DtmZW6eP.js → p-Db3kxVe2.js} +27 -25
  236. package/dist/components/p-Db3kxVe2.js.map +1 -0
  237. package/dist/components/{p-_ntxNi8v.js → p-Ddlbt3Bj.js} +22 -20
  238. package/dist/components/p-Ddlbt3Bj.js.map +1 -0
  239. package/dist/components/{p-Crni2OI4.js → p-DjU7p3od.js} +15 -13
  240. package/dist/components/p-DjU7p3od.js.map +1 -0
  241. package/dist/components/p-EXPChOF6.js +30 -0
  242. package/dist/components/p-EXPChOF6.js.map +1 -0
  243. package/dist/components/p-YqK8ch2R.js +46 -0
  244. package/dist/components/p-YqK8ch2R.js.map +1 -0
  245. package/dist/components/p-l10It7Nm.js +30 -0
  246. package/dist/components/p-l10It7Nm.js.map +1 -0
  247. package/dist/components/{p-BLmFBe2a.js → p-sq9jgfX0.js} +8 -6
  248. package/dist/components/p-sq9jgfX0.js.map +1 -0
  249. package/dist/components/{p-BcQTDgzV.js → p-sreNwi0N.js} +9 -8
  250. package/dist/components/p-sreNwi0N.js.map +1 -0
  251. package/dist/esm/{index-DqqxAoZI.js → index-C_uHp-ur.js} +891 -803
  252. package/dist/esm/index-C_uHp-ur.js.map +1 -0
  253. package/dist/esm/{index-NiIEUDzj.js → index-oCOlsFCN.js} +47 -17
  254. package/dist/esm/index-oCOlsFCN.js.map +1 -0
  255. package/dist/esm/index.js +1 -1
  256. package/dist/esm/kritzel-brush-style.entry.js +30 -0
  257. package/dist/esm/kritzel-brush-style.entry.js.map +1 -0
  258. package/dist/esm/{kritzel-brush-style_23.entry.js → kritzel-color_22.entry.js} +1538 -1323
  259. package/dist/esm/loader.js +3 -3
  260. package/dist/esm/stencil.js +4 -4
  261. package/dist/esm/stencil.js.map +1 -1
  262. package/dist/stencil/index.esm.js +1 -1
  263. package/dist/stencil/kritzel-brush-style.entry.esm.js.map +1 -0
  264. package/dist/stencil/p-25d1e040.entry.js +2 -0
  265. package/dist/stencil/p-25d1e040.entry.js.map +1 -0
  266. package/dist/stencil/p-C_uHp-ur.js +2 -0
  267. package/dist/stencil/p-C_uHp-ur.js.map +1 -0
  268. package/dist/stencil/p-a6f8283e.entry.js +2 -0
  269. package/dist/stencil/p-a6f8283e.entry.js.map +1 -0
  270. package/dist/stencil/p-oCOlsFCN.js +3 -0
  271. package/dist/stencil/p-oCOlsFCN.js.map +1 -0
  272. package/dist/stencil/stencil.esm.js +1 -1
  273. package/dist/stencil/stencil.esm.js.map +1 -1
  274. package/dist/types/classes/commands/add-object.command.d.ts +2 -2
  275. package/dist/types/classes/commands/add-selection-group.command.d.ts +2 -1
  276. package/dist/types/classes/commands/base.command.d.ts +3 -3
  277. package/dist/types/classes/commands/batch.command.d.ts +2 -1
  278. package/dist/types/classes/commands/move-selection-group.command.d.ts +2 -1
  279. package/dist/types/classes/commands/remove-object.command.d.ts +2 -2
  280. package/dist/types/classes/commands/remove-selection-group.command.d.ts +2 -2
  281. package/dist/types/classes/commands/resize-selection-group.command.d.ts +2 -1
  282. package/dist/types/classes/commands/rotate-selection-group.command.d.ts +2 -1
  283. package/dist/types/classes/commands/update-object.command.d.ts +2 -2
  284. package/dist/types/classes/commands/update-viewport.command.d.ts +2 -1
  285. package/dist/types/classes/{store.class.d.ts → core/core.class.d.ts} +9 -19
  286. package/dist/types/classes/{database.class.d.ts → core/database.class.d.ts} +3 -2
  287. package/dist/types/classes/{history.class.d.ts → core/history.class.d.ts} +5 -5
  288. package/dist/types/classes/core/reviver.class.d.ts +6 -0
  289. package/dist/types/classes/core/store.class.d.ts +17 -0
  290. package/dist/types/classes/{viewport.class.d.ts → core/viewport.class.d.ts} +3 -3
  291. package/dist/types/classes/core/workspace.class.d.ts +24 -0
  292. package/dist/types/classes/handlers/base.handler.d.ts +3 -3
  293. package/dist/types/classes/handlers/context-menu.handler.d.ts +2 -2
  294. package/dist/types/classes/handlers/hover.handler.d.ts +2 -2
  295. package/dist/types/classes/handlers/key.handler.d.ts +2 -2
  296. package/dist/types/classes/handlers/move.handler.d.ts +2 -2
  297. package/dist/types/classes/handlers/resize.handler.d.ts +2 -2
  298. package/dist/types/classes/handlers/rotation.handler.d.ts +2 -2
  299. package/dist/types/classes/handlers/selection.handler.d.ts +2 -2
  300. package/dist/types/classes/objects/base-object.class.d.ts +5 -4
  301. package/dist/types/classes/objects/custom-element.class.d.ts +2 -2
  302. package/dist/types/classes/objects/image.class.d.ts +2 -2
  303. package/dist/types/classes/objects/path.class.d.ts +2 -4
  304. package/dist/types/classes/objects/selection-box.class.d.ts +2 -2
  305. package/dist/types/classes/objects/selection-group.class.d.ts +2 -2
  306. package/dist/types/classes/objects/text.class.d.ts +2 -2
  307. package/dist/types/classes/registries/tool.registry.d.ts +2 -2
  308. package/dist/types/classes/tools/base-tool.class.d.ts +8 -4
  309. package/dist/types/classes/tools/brush-tool.class.d.ts +2 -2
  310. package/dist/types/classes/tools/eraser-tool.class.d.ts +2 -2
  311. package/dist/types/classes/tools/image-tool.class.d.ts +2 -2
  312. package/dist/types/classes/tools/selection-tool.class.d.ts +2 -2
  313. package/dist/types/classes/tools/text-tool.class.d.ts +2 -2
  314. package/dist/types/components/core/kritzel-cursor-trail/kritzel-cursor-trail.d.ts +5 -5
  315. package/dist/types/components/core/kritzel-editor/kritzel-editor.d.ts +13 -3
  316. package/dist/types/components/core/kritzel-engine/kritzel-engine.d.ts +21 -22
  317. package/dist/types/components/shared/kritzel-dropdown/kritzel-dropdown.d.ts +2 -2
  318. package/dist/types/components/shared/kritzel-menu-item/kritzel-menu-item.d.ts +2 -0
  319. package/dist/types/components/shared/kritzel-portal/kritzel-portal.d.ts +0 -1
  320. package/dist/types/components/shared/kritzel-split-button/kritzel-split-button.d.ts +4 -2
  321. package/dist/types/components/shared/kritzel-tooltip/kritzel-tooltip.d.ts +8 -2
  322. package/dist/types/components/ui/kritzel-context-menu/kritzel-context-menu.d.ts +5 -3
  323. package/dist/types/components/ui/kritzel-control-brush-config/kritzel-control-brush-config.d.ts +1 -1
  324. package/dist/types/components/ui/kritzel-controls/kritzel-controls.d.ts +3 -1
  325. package/dist/types/components/ui/kritzel-workspace-manager/kritzel-workspace-manager.d.ts +3 -2
  326. package/dist/types/components.d.ts +41 -12
  327. package/dist/types/helpers/devices.helper.d.ts +4 -0
  328. package/dist/types/helpers/event.helper.d.ts +1 -1
  329. package/dist/types/helpers/html.helper.d.ts +1 -0
  330. package/dist/types/index.d.ts +1 -0
  331. package/dist/types/interfaces/engine-state.interface.d.ts +1 -2
  332. package/dist/types/interfaces/serializable.interface.d.ts +2 -1
  333. package/dist/types/stencil-public-runtime.d.ts +6 -4
  334. package/dist/types/types/deep-readonly.type.d.ts +7 -0
  335. package/package.json +64 -63
  336. package/dist/cjs/index-CUSIflVf.js.map +0 -1
  337. package/dist/cjs/index-CfXjPLHb.js.map +0 -1
  338. package/dist/collection/classes/database.class.js.map +0 -1
  339. package/dist/collection/classes/history.class.js +0 -84
  340. package/dist/collection/classes/history.class.js.map +0 -1
  341. package/dist/collection/classes/reviver.class.js.map +0 -1
  342. package/dist/collection/classes/store.class.js.map +0 -1
  343. package/dist/collection/classes/viewport.class.js +0 -152
  344. package/dist/collection/classes/viewport.class.js.map +0 -1
  345. package/dist/collection/classes/workspace.class.js +0 -10
  346. package/dist/collection/classes/workspace.class.js.map +0 -1
  347. package/dist/components/p-26poIWa_.js.map +0 -1
  348. package/dist/components/p-5CJxFNEE.js.map +0 -1
  349. package/dist/components/p-BAPUTr3K.js.map +0 -1
  350. package/dist/components/p-BGccckxP.js.map +0 -1
  351. package/dist/components/p-BLmFBe2a.js.map +0 -1
  352. package/dist/components/p-BU2q3PRS.js.map +0 -1
  353. package/dist/components/p-BZ-j_4CK.js.map +0 -1
  354. package/dist/components/p-Bb6od8He.js +0 -42
  355. package/dist/components/p-Bb6od8He.js.map +0 -1
  356. package/dist/components/p-BcQTDgzV.js.map +0 -1
  357. package/dist/components/p-BcQWRzsB.js.map +0 -1
  358. package/dist/components/p-BeVv4o5c.js +0 -14
  359. package/dist/components/p-BeVv4o5c.js.map +0 -1
  360. package/dist/components/p-BqrTPNyu.js.map +0 -1
  361. package/dist/components/p-BvlGgLAQ.js.map +0 -1
  362. package/dist/components/p-C-DqsDXz.js +0 -238
  363. package/dist/components/p-C-DqsDXz.js.map +0 -1
  364. package/dist/components/p-C9-70hiF.js.map +0 -1
  365. package/dist/components/p-CJKA5zIE.js +0 -10
  366. package/dist/components/p-CJKA5zIE.js.map +0 -1
  367. package/dist/components/p-CaPdvVd4.js +0 -127
  368. package/dist/components/p-CaPdvVd4.js.map +0 -1
  369. package/dist/components/p-Cb1IUD_g.js.map +0 -1
  370. package/dist/components/p-Crni2OI4.js.map +0 -1
  371. package/dist/components/p-D_Uh-xv_.js.map +0 -1
  372. package/dist/components/p-DtmZW6eP.js.map +0 -1
  373. package/dist/components/p-V4ui5aWj.js +0 -63
  374. package/dist/components/p-V4ui5aWj.js.map +0 -1
  375. package/dist/components/p-_ntxNi8v.js.map +0 -1
  376. package/dist/components/p-fyfT6A5K.js.map +0 -1
  377. package/dist/components/p-jGaWxggY.js.map +0 -1
  378. package/dist/components/p-jpGLgpoq.js.map +0 -1
  379. package/dist/esm/index-DqqxAoZI.js.map +0 -1
  380. package/dist/esm/index-NiIEUDzj.js.map +0 -1
  381. package/dist/stencil/p-DqqxAoZI.js +0 -2
  382. package/dist/stencil/p-DqqxAoZI.js.map +0 -1
  383. package/dist/stencil/p-NiIEUDzj.js +0 -3
  384. package/dist/stencil/p-NiIEUDzj.js.map +0 -1
  385. package/dist/stencil/p-eebdbf65.entry.js +0 -2
  386. package/dist/stencil/p-eebdbf65.entry.js.map +0 -1
  387. package/dist/types/classes/reviver.class.d.ts +0 -6
  388. package/dist/types/classes/workspace.class.d.ts +0 -16
@@ -1,4 +1,5 @@
1
- import { p as proxyCustomElement, H, h, d as Host } from './p-BqrTPNyu.js';
1
+ import { p as proxyCustomElement, H, c as createEvent, h, d as Host } from './p-BYanlgdq.js';
2
+ import { K as KritzelHTMLHelper } from './p-C6qB08BS.js';
2
3
 
3
4
  const kritzelTooltipCss = ":host{width:auto}.tooltip-content{position:relative;padding:8px 12px;border-radius:4px;width:fit-content;background-color:var(--kritzel-controls-tooltip-background-color, #ffffff);color:var(--kritzel-controls-tooltip-color, #000000);padding:var(--kritzel-controls-tooltip-padding, 8px);border-radius:var(--kritzel-controls-tooltip-border-radius, 16px);white-space:nowrap;box-shadow:var(--kritzel-controls-tooltip-box-shadow, 0 1px 6px rgba(0, 0, 0, 0.12))}";
4
5
 
@@ -10,17 +11,38 @@ const KritzelTooltip = /*@__PURE__*/ proxyCustomElement(class KritzelTooltip ext
10
11
  this.__registerHost();
11
12
  }
12
13
  this.__attachShadow();
13
- this.isVisible = false;
14
- this.arrowSize = 8;
15
- this.offsetY = 24;
16
- this.positionX = 0;
17
- this.arrowOffset = '0px';
18
- this.isMobileView = window.innerWidth < MOBILE_BREAKPOINT;
14
+ this.tooltipClosed = createEvent(this, "tooltipClosed");
15
+ }
16
+ get host() { return this; }
17
+ isVisible = false;
18
+ anchorElement;
19
+ arrowSize = 8;
20
+ offsetY = 24;
21
+ tooltipClosed;
22
+ positionX = 0;
23
+ arrowOffset = '0px';
24
+ isMobileView = window.innerWidth < MOBILE_BREAKPOINT;
25
+ handleOutsideClick(event) {
26
+ if (!this.isVisible)
27
+ return;
28
+ const target = event.target;
29
+ if (!this.host.contains(target)) {
30
+ this.tooltipClosed.emit();
31
+ }
19
32
  }
20
33
  handleWindowResize() {
21
34
  this.isMobileView = window.innerWidth < MOBILE_BREAKPOINT;
22
35
  this.calculateAdjustedPosition();
23
36
  }
37
+ async focusContent() {
38
+ const focusableElements = KritzelHTMLHelper.getFocusableElements(this.host);
39
+ if (focusableElements.length > 0) {
40
+ focusableElements[0].focus();
41
+ }
42
+ }
43
+ componentDidLoad() {
44
+ this.focusSlottedContent();
45
+ }
24
46
  componentWillLoad() {
25
47
  this.isMobileView = window.innerWidth < MOBILE_BREAKPOINT;
26
48
  this.calculateAdjustedPosition();
@@ -28,11 +50,18 @@ const KritzelTooltip = /*@__PURE__*/ proxyCustomElement(class KritzelTooltip ext
28
50
  componentWillUpdate() {
29
51
  this.calculateAdjustedPosition();
30
52
  }
53
+ focusSlottedContent() {
54
+ const slot = this.host.shadowRoot?.querySelector('slot');
55
+ const assignedElements = slot?.assignedElements() || [];
56
+ if (assignedElements.length > 0) {
57
+ const firstElement = assignedElements[0];
58
+ firstElement.focus();
59
+ }
60
+ }
31
61
  calculateAdjustedPosition() {
32
- var _a;
33
62
  if (this.isVisible && this.anchorElement) {
34
63
  const anchorRect = this.anchorElement.getBoundingClientRect();
35
- const tooltipContent = (_a = this.el.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector('.tooltip-content');
64
+ const tooltipContent = this.host.shadowRoot?.querySelector('.tooltip-content');
36
65
  if (!this.isMobileView) {
37
66
  this.positionX = anchorRect.left + anchorRect.width / 2;
38
67
  this.arrowOffset = `calc(${50}% - ${this.arrowSize}px)`;
@@ -45,23 +74,23 @@ const KritzelTooltip = /*@__PURE__*/ proxyCustomElement(class KritzelTooltip ext
45
74
  }
46
75
  }
47
76
  render() {
48
- return (h(Host, { key: '6eb67bcfd08234affe3724dff4d94ddf7907a1a7', style: {
77
+ return (h(Host, { key: '8c3aeff60625f43f129afa70367cdb7a68a4b271', style: {
49
78
  position: 'fixed',
50
79
  zIndex: '9999',
51
80
  transition: 'opacity 0.3s ease-in-out, transform 0.3s ease-in-out',
52
81
  visibility: this.isVisible ? 'visible' : 'hidden',
53
82
  left: !this.isMobileView ? `${this.positionX}px` : '50%',
54
83
  marginBottom: `${this.offsetY + this.arrowSize}px`,
55
- } }, h("div", { key: '9314b30b71200776e3728027b2ac7332cf4ab669', class: "tooltip-content", onClick: event => event.stopPropagation() }, h("slot", { key: '80cb8d0a8a91d9c816580cedc02fc9382fb07f8c' }), h("div", { key: '87fb2399463a0eb7beb1ca0f2c2867d8ff033f3a', class: "tooltip-arrow-wrapper", style: {
84
+ } }, h("div", { key: 'b22b606c2a836c2c9bbe21c6b470754753ccb309', class: "tooltip-content", onClick: event => event.stopPropagation() }, h("slot", { key: '783403f4b5560012c9f6bd184a8c5eb26428e148' }), h("div", { key: 'bb98400edc5c6e05fd4ed2a476a5821f93964b8e', class: "tooltip-arrow-wrapper", style: {
56
85
  position: 'fixed',
57
86
  left: this.arrowOffset,
58
87
  bottom: `-${this.arrowSize * 2}px`,
59
- } }, h("div", { key: 'fc3953ad9b6aa5a4b2228653573fc3a7e37c0487', class: "tooltip-arrow", style: {
88
+ } }, h("div", { key: '850a058d635113a7870f25fa288a6447394c53ed', class: "tooltip-arrow", style: {
60
89
  borderLeft: `${this.arrowSize}px solid transparent`,
61
90
  borderRight: `${this.arrowSize}px solid transparent`,
62
91
  borderTop: `${this.arrowSize}px solid var(--kritzel-controls-tooltip-background-color, #ffffff)`,
63
92
  filter: 'drop-shadow(0 2px 4px rgba(0, 0, 0, 0.2))',
64
- } }), h("div", { key: '5b8e4e3eb90c4c47c47fa47dc96e4149794e1732', class: "tooltip-arrow-rect", style: {
93
+ } }), h("div", { key: 'bbb3dc2673e2dfe4443ad80540dfc9e5a25c6c06', class: "tooltip-arrow-rect", style: {
65
94
  position: 'relative',
66
95
  width: `${this.arrowSize * 2}px`,
67
96
  height: `${this.arrowSize}px`,
@@ -69,7 +98,6 @@ const KritzelTooltip = /*@__PURE__*/ proxyCustomElement(class KritzelTooltip ext
69
98
  bottom: `${this.arrowSize * 2}px`,
70
99
  } })))));
71
100
  }
72
- get el() { return this; }
73
101
  static get style() { return kritzelTooltipCss; }
74
102
  }, [257, "kritzel-tooltip", {
75
103
  "isVisible": [4, "is-visible"],
@@ -78,8 +106,9 @@ const KritzelTooltip = /*@__PURE__*/ proxyCustomElement(class KritzelTooltip ext
78
106
  "offsetY": [2, "offset-y"],
79
107
  "positionX": [32],
80
108
  "arrowOffset": [32],
81
- "isMobileView": [32]
82
- }, [[9, "resize", "handleWindowResize"]]]);
109
+ "isMobileView": [32],
110
+ "focusContent": [64]
111
+ }, [[4, "click", "handleOutsideClick"], [9, "resize", "handleWindowResize"]]]);
83
112
  function defineCustomElement() {
84
113
  if (typeof customElements === "undefined") {
85
114
  return;
@@ -95,6 +124,6 @@ function defineCustomElement() {
95
124
  }
96
125
 
97
126
  export { KritzelTooltip as K, defineCustomElement as d };
98
- //# sourceMappingURL=p-26poIWa_.js.map
127
+ //# sourceMappingURL=p-BPsQrpzN.js.map
99
128
 
100
- //# sourceMappingURL=p-26poIWa_.js.map
129
+ //# sourceMappingURL=p-BPsQrpzN.js.map
@@ -0,0 +1 @@
1
+ {"file":"p-BPsQrpzN.js","mappings":"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","names":["__stencil_proxyCustomElement","HTMLElement"],"sources":["src/components/shared/kritzel-tooltip/kritzel-tooltip.css?tag=kritzel-tooltip&encapsulation=shadow","src/components/shared/kritzel-tooltip/kritzel-tooltip.tsx"],"sourcesContent":[":host {\r\n width: auto;\r\n}\r\n\r\n.tooltip-content {\r\n position: relative;\r\n padding: 8px 12px;\r\n border-radius: 4px;\r\n width: fit-content;\r\n background-color: var(--kritzel-controls-tooltip-background-color, #ffffff);\r\n color: var(--kritzel-controls-tooltip-color, #000000);\r\n padding: var(--kritzel-controls-tooltip-padding, 8px);\r\n border-radius: var(--kritzel-controls-tooltip-border-radius, 16px);\r\n white-space: nowrap;\r\n box-shadow: var(--kritzel-controls-tooltip-box-shadow, 0 1px 6px rgba(0, 0, 0, 0.12));\r\n}\r\n\r\n","import { Component, Host, Prop, h, Element, State, Listen, Method, Event, EventEmitter } from '@stencil/core';\r\nimport { KritzelHTMLHelper } from '../../../helpers/html.helper';\r\n\r\nconst MOBILE_BREAKPOINT = 768;\r\n\r\n@Component({\r\n tag: 'kritzel-tooltip',\r\n styleUrl: 'kritzel-tooltip.css',\r\n shadow: true,\r\n})\r\nexport class KritzelTooltip {\r\n @Element() host: HTMLElement;\r\n\r\n @Prop() isVisible: boolean = false;\r\n @Prop() anchorElement: HTMLElement;\r\n @Prop() arrowSize: number = 8;\r\n @Prop() offsetY: number = 24;\r\n\r\n @Event() tooltipClosed: EventEmitter<void>;\r\n\r\n @State() positionX: number = 0;\r\n @State() arrowOffset: string = '0px';\r\n @State() isMobileView: boolean = window.innerWidth < MOBILE_BREAKPOINT;\r\n\r\n @Listen('click', { target: 'document' })\r\n handleOutsideClick(event: MouseEvent) {\r\n if( !this.isVisible ) return;\r\n const target = event.target as HTMLElement;\r\n if (!this.host.contains(target)) {\r\n this.tooltipClosed.emit();\r\n }\r\n }\r\n\r\n @Listen('resize', { target: 'window' })\r\n handleWindowResize() {\r\n this.isMobileView = window.innerWidth < MOBILE_BREAKPOINT;\r\n this.calculateAdjustedPosition();\r\n }\r\n\r\n @Method()\r\n async focusContent() {\r\n const focusableElements = KritzelHTMLHelper.getFocusableElements(this.host);\r\n if (focusableElements.length > 0) {\r\n focusableElements[0].focus();\r\n }\r\n }\r\n\r\n componentDidLoad() {\r\n this.focusSlottedContent();\r\n }\r\n\r\n componentWillLoad() {\r\n this.isMobileView = window.innerWidth < MOBILE_BREAKPOINT;\r\n this.calculateAdjustedPosition();\r\n }\r\n\r\n componentWillUpdate() {\r\n this.calculateAdjustedPosition();\r\n }\r\n\r\n private focusSlottedContent() {\r\n const slot = this.host.shadowRoot?.querySelector('slot');\r\n const assignedElements = slot?.assignedElements() || [];\r\n if (assignedElements.length > 0) {\r\n const firstElement = assignedElements[0] as HTMLElement;\r\n firstElement.focus();\r\n }\r\n }\r\n\r\n private calculateAdjustedPosition() {\r\n if (this.isVisible && this.anchorElement) {\r\n const anchorRect = this.anchorElement.getBoundingClientRect();\r\n const tooltipContent = this.host.shadowRoot?.querySelector('.tooltip-content') as HTMLElement;\r\n\r\n if (!this.isMobileView) {\r\n this.positionX = anchorRect.left + anchorRect.width / 2;\r\n this.arrowOffset = `calc(${50}% - ${this.arrowSize}px)`; \r\n } else {\r\n const tooltipRect = tooltipContent.getBoundingClientRect();\r\n this.positionX = anchorRect.left + anchorRect.width / 2 - tooltipRect.width / 2;\r\n this.arrowOffset = `${anchorRect.left + anchorRect.width / 2 - tooltipRect.left - this.arrowSize}px`;\r\n }\r\n }\r\n }\r\n\r\n render() {\r\n return (\r\n <Host\r\n style={{\r\n position: 'fixed',\r\n zIndex: '9999',\r\n transition: 'opacity 0.3s ease-in-out, transform 0.3s ease-in-out',\r\n visibility: this.isVisible ? 'visible' : 'hidden',\r\n left: !this.isMobileView ? `${this.positionX}px` : '50%',\r\n marginBottom: `${this.offsetY + this.arrowSize}px`,\r\n }}\r\n >\r\n <div class=\"tooltip-content\" onClick={event => event.stopPropagation()}>\r\n <slot></slot>\r\n <div\r\n class=\"tooltip-arrow-wrapper\"\r\n style={{\r\n position: 'fixed',\r\n left: this.arrowOffset,\r\n bottom: `-${this.arrowSize * 2}px`,\r\n }}\r\n >\r\n <div\r\n class=\"tooltip-arrow\"\r\n style={{\r\n borderLeft: `${this.arrowSize}px solid transparent`,\r\n borderRight: `${this.arrowSize}px solid transparent`,\r\n borderTop: `${this.arrowSize}px solid var(--kritzel-controls-tooltip-background-color, #ffffff)`,\r\n filter: 'drop-shadow(0 2px 4px rgba(0, 0, 0, 0.2))',\r\n }}\r\n ></div>\r\n <div\r\n class=\"tooltip-arrow-rect\"\r\n style={{\r\n position: 'relative',\r\n width: `${this.arrowSize * 2}px`,\r\n height: `${this.arrowSize}px`,\r\n backgroundColor: 'var(--kritzel-controls-tooltip-background-color, #ffffff)',\r\n bottom: `${this.arrowSize * 2}px`,\r\n }}\r\n ></div>\r\n </div>\r\n </div>\r\n </Host>\r\n );\r\n }\r\n}\r\n"],"version":3}
@@ -2,7 +2,7 @@ const NAMESPACE = 'stencil';
2
2
  const BUILD = /* stencil */ { hydratedSelectorName: "hydrated", lazyLoad: false, updatable: true};
3
3
 
4
4
  /*
5
- Stencil Client Platform v4.37.0 | MIT Licensed | https://stenciljs.com
5
+ Stencil Client Platform v4.37.1 | MIT Licensed | https://stenciljs.com
6
6
  */
7
7
  var __defProp = Object.defineProperty;
8
8
  var __export = (target, all) => {
@@ -14,6 +14,40 @@ var __export = (target, all) => {
14
14
  var SVG_NS = "http://www.w3.org/2000/svg";
15
15
  var HTML_NS = "http://www.w3.org/1999/xhtml";
16
16
 
17
+ // src/utils/es2022-rewire-class-members.ts
18
+ var reWireGetterSetter = (instance, hostRef) => {
19
+ var _a;
20
+ const cmpMeta = hostRef.$cmpMeta$;
21
+ const members = Object.entries((_a = cmpMeta.$members$) != null ? _a : {});
22
+ members.map(([memberName, [memberFlags]]) => {
23
+ if ((memberFlags & 31 /* Prop */ || memberFlags & 32 /* State */)) {
24
+ const ogValue = instance[memberName];
25
+ const ogDescriptor = getPropertyDescriptor(Object.getPrototypeOf(instance), memberName) || Object.getOwnPropertyDescriptor(instance, memberName);
26
+ if (ogDescriptor) {
27
+ Object.defineProperty(instance, memberName, {
28
+ get() {
29
+ return ogDescriptor.get.call(this);
30
+ },
31
+ set(newValue) {
32
+ ogDescriptor.set.call(this, newValue);
33
+ },
34
+ configurable: true,
35
+ enumerable: true
36
+ });
37
+ }
38
+ instance[memberName] = hostRef.$instanceValues$.has(memberName) ? hostRef.$instanceValues$.get(memberName) : ogValue;
39
+ }
40
+ });
41
+ };
42
+ function getPropertyDescriptor(obj, memberName) {
43
+ while (obj) {
44
+ const desc = Object.getOwnPropertyDescriptor(obj, memberName);
45
+ if (desc == null ? void 0 : desc.get) return desc;
46
+ obj = Object.getPrototypeOf(obj);
47
+ }
48
+ return void 0;
49
+ }
50
+
17
51
  // src/client/client-host-ref.ts
18
52
  var getHostRef = (ref) => {
19
53
  if (ref.__stencil__getHostRef) {
@@ -35,6 +69,9 @@ var registerHost = (hostElement, cmpMeta) => {
35
69
  }
36
70
  const ref = hostRef;
37
71
  hostElement.__stencil__getHostRef = () => ref;
72
+ {
73
+ reWireGetterSetter(hostElement, hostRef);
74
+ }
38
75
  return ref;
39
76
  };
40
77
  var isMemberInElement = (elm, memberName) => memberName in elm;
@@ -396,12 +433,6 @@ createSupportsRuleRe("::slotted");
396
433
  createSupportsRuleRe(":host");
397
434
  createSupportsRuleRe(":host-context");
398
435
  var parsePropertyValue = (propValue, propType, isFormAssociated) => {
399
- if (typeof propValue === "string" && (propType & 16 /* Unknown */ || propType & 8 /* Any */) && (propValue.startsWith("{") && propValue.endsWith("}") || propValue.startsWith("[") && propValue.endsWith("]"))) {
400
- try {
401
- return JSON.parse(propValue);
402
- } catch (e) {
403
- }
404
- }
405
436
  if (propValue != null && !isComplexType(propValue)) {
406
437
  if (propType & 4 /* Boolean */) {
407
438
  {
@@ -1129,12 +1160,7 @@ var initializeComponent = async (elm, hostRef, cmpMeta, hmrVersionId) => {
1129
1160
  {
1130
1161
  Cstr = elm.constructor;
1131
1162
  const cmpTag = elm.localName;
1132
- const setWatchIsReady = () => hostRef.$flags$ |= 128 /* isWatchReady */;
1133
- if (!!customElements.get(cmpTag)) {
1134
- setWatchIsReady();
1135
- } else {
1136
- customElements.whenDefined(cmpTag).then(setWatchIsReady);
1137
- }
1163
+ customElements.whenDefined(cmpTag).then(() => hostRef.$flags$ |= 128 /* isWatchReady */);
1138
1164
  }
1139
1165
  if (Cstr && Cstr.style) {
1140
1166
  let style;
@@ -1325,6 +1351,6 @@ function render(vnode, container) {
1325
1351
  }
1326
1352
 
1327
1353
  export { H, setNonce as a, setPlatformOptions as b, createEvent as c, Host as d, getAssetPath as g, h, proxyCustomElement as p, render as r, setAssetPath as s };
1328
- //# sourceMappingURL=p-BqrTPNyu.js.map
1354
+ //# sourceMappingURL=p-BYanlgdq.js.map
1329
1355
 
1330
- //# sourceMappingURL=p-BqrTPNyu.js.map
1356
+ //# sourceMappingURL=p-BYanlgdq.js.map