kritzel-stencil 0.0.129 → 0.0.131

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 (310) hide show
  1. package/dist/cjs/{index-C7Read21.js → index-BwINBV6L.js} +259 -191
  2. package/dist/cjs/index-BwINBV6L.js.map +1 -0
  3. package/dist/cjs/{index-CUSIflVf.js → index-nzUNdMPh.js} +43 -17
  4. package/dist/cjs/index-nzUNdMPh.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_22.cjs.entry.js → kritzel-brush-style_23.cjs.entry.js} +930 -841
  8. package/dist/cjs/loader.cjs.js +2 -2
  9. package/dist/cjs/stencil.cjs.js +3 -3
  10. package/dist/cjs/stencil.cjs.js.map +1 -1
  11. package/dist/collection/classes/commands/add-object.command.js +3 -2
  12. package/dist/collection/classes/commands/add-object.command.js.map +1 -1
  13. package/dist/collection/classes/commands/add-selection-group.command.js +4 -3
  14. package/dist/collection/classes/commands/add-selection-group.command.js.map +1 -1
  15. package/dist/collection/classes/commands/base.command.js +4 -2
  16. package/dist/collection/classes/commands/base.command.js.map +1 -1
  17. package/dist/collection/classes/commands/batch.command.js +1 -0
  18. package/dist/collection/classes/commands/batch.command.js.map +1 -1
  19. package/dist/collection/classes/commands/move-selection-group.command.js +6 -0
  20. package/dist/collection/classes/commands/move-selection-group.command.js.map +1 -1
  21. package/dist/collection/classes/commands/remove-object.command.js +5 -4
  22. package/dist/collection/classes/commands/remove-object.command.js.map +1 -1
  23. package/dist/collection/classes/commands/remove-selection-group.command.js +3 -2
  24. package/dist/collection/classes/commands/remove-selection-group.command.js.map +1 -1
  25. package/dist/collection/classes/commands/resize-selection-group.command.js +3 -0
  26. package/dist/collection/classes/commands/resize-selection-group.command.js.map +1 -1
  27. package/dist/collection/classes/commands/rotate-selection-group.command.js +5 -2
  28. package/dist/collection/classes/commands/rotate-selection-group.command.js.map +1 -1
  29. package/dist/collection/classes/commands/update-object.command.js +3 -0
  30. package/dist/collection/classes/commands/update-object.command.js.map +1 -1
  31. package/dist/collection/classes/commands/update-viewport.command.js +2 -0
  32. package/dist/collection/classes/commands/update-viewport.command.js.map +1 -1
  33. package/dist/collection/classes/database.class.js +6 -5
  34. package/dist/collection/classes/database.class.js.map +1 -1
  35. package/dist/collection/classes/handlers/base.handler.js +1 -0
  36. package/dist/collection/classes/handlers/base.handler.js.map +1 -1
  37. package/dist/collection/classes/handlers/context-menu.handler.js +2 -2
  38. package/dist/collection/classes/handlers/context-menu.handler.js.map +1 -1
  39. package/dist/collection/classes/handlers/move.handler.js +8 -3
  40. package/dist/collection/classes/handlers/move.handler.js.map +1 -1
  41. package/dist/collection/classes/handlers/resize.handler.js +6 -6
  42. package/dist/collection/classes/handlers/resize.handler.js.map +1 -1
  43. package/dist/collection/classes/handlers/rotation.handler.js +2 -2
  44. package/dist/collection/classes/handlers/rotation.handler.js.map +1 -1
  45. package/dist/collection/classes/handlers/selection.handler.js +10 -8
  46. package/dist/collection/classes/handlers/selection.handler.js.map +1 -1
  47. package/dist/collection/classes/history.class.js +4 -0
  48. package/dist/collection/classes/history.class.js.map +1 -1
  49. package/dist/collection/classes/objects/base-object.class.js +29 -16
  50. package/dist/collection/classes/objects/base-object.class.js.map +1 -1
  51. package/dist/collection/classes/objects/custom-element.class.js +3 -2
  52. package/dist/collection/classes/objects/custom-element.class.js.map +1 -1
  53. package/dist/collection/classes/objects/image.class.js +12 -12
  54. package/dist/collection/classes/objects/image.class.js.map +1 -1
  55. package/dist/collection/classes/objects/path.class.js +30 -28
  56. package/dist/collection/classes/objects/path.class.js.map +1 -1
  57. package/dist/collection/classes/objects/selection-box.class.js +2 -5
  58. package/dist/collection/classes/objects/selection-box.class.js.map +1 -1
  59. package/dist/collection/classes/objects/selection-group.class.js +13 -12
  60. package/dist/collection/classes/objects/selection-group.class.js.map +1 -1
  61. package/dist/collection/classes/objects/text.class.js +11 -11
  62. package/dist/collection/classes/objects/text.class.js.map +1 -1
  63. package/dist/collection/classes/registries/icon-registry.class.js +1 -1
  64. package/dist/collection/classes/registries/icon-registry.class.js.map +1 -1
  65. package/dist/collection/classes/registries/tool.registry.js +1 -1
  66. package/dist/collection/classes/registries/tool.registry.js.map +1 -1
  67. package/dist/collection/classes/reviver.class.js +1 -0
  68. package/dist/collection/classes/reviver.class.js.map +1 -1
  69. package/dist/collection/classes/store.class.js +18 -30
  70. package/dist/collection/classes/store.class.js.map +1 -1
  71. package/dist/collection/classes/structures/circular-buffer.structure.js +5 -3
  72. package/dist/collection/classes/structures/circular-buffer.structure.js.map +1 -1
  73. package/dist/collection/classes/structures/object-map.structure.js +43 -0
  74. package/dist/collection/classes/structures/object-map.structure.js.map +1 -0
  75. package/dist/collection/classes/tools/base-tool.class.js +3 -2
  76. package/dist/collection/classes/tools/base-tool.class.js.map +1 -1
  77. package/dist/collection/classes/tools/brush-tool.class.js +7 -7
  78. package/dist/collection/classes/tools/brush-tool.class.js.map +1 -1
  79. package/dist/collection/classes/tools/eraser-tool.class.js +2 -3
  80. package/dist/collection/classes/tools/eraser-tool.class.js.map +1 -1
  81. package/dist/collection/classes/tools/image-tool.class.js +3 -4
  82. package/dist/collection/classes/tools/image-tool.class.js.map +1 -1
  83. package/dist/collection/classes/tools/selection-tool.class.js +12 -9
  84. package/dist/collection/classes/tools/selection-tool.class.js.map +1 -1
  85. package/dist/collection/classes/tools/text-tool.class.js +26 -27
  86. package/dist/collection/classes/tools/text-tool.class.js.map +1 -1
  87. package/dist/collection/classes/viewport.class.js +4 -3
  88. package/dist/collection/classes/viewport.class.js.map +1 -1
  89. package/dist/collection/classes/workspace.class.js +5 -0
  90. package/dist/collection/classes/workspace.class.js.map +1 -1
  91. package/dist/collection/collection-manifest.json +2 -1
  92. package/dist/collection/components/core/kritzel-cursor-trail/kritzel-cursor-trail.js +6 -6
  93. package/dist/collection/components/core/kritzel-cursor-trail/kritzel-cursor-trail.js.map +1 -1
  94. package/dist/collection/components/core/kritzel-editor/kritzel-editor.css +7 -0
  95. package/dist/collection/components/core/kritzel-editor/kritzel-editor.js +102 -88
  96. package/dist/collection/components/core/kritzel-editor/kritzel-editor.js.map +1 -1
  97. package/dist/collection/components/core/kritzel-engine/kritzel-engine.js +137 -148
  98. package/dist/collection/components/core/kritzel-engine/kritzel-engine.js.map +1 -1
  99. package/dist/collection/components/shared/kritzel-brush-style/kritzel-brush-style.js +6 -7
  100. package/dist/collection/components/shared/kritzel-brush-style/kritzel-brush-style.js.map +1 -1
  101. package/dist/collection/components/shared/kritzel-color/kritzel-color.js +2 -3
  102. package/dist/collection/components/shared/kritzel-color/kritzel-color.js.map +1 -1
  103. package/dist/collection/components/shared/kritzel-color-palette/kritzel-color-palette.js +5 -6
  104. package/dist/collection/components/shared/kritzel-color-palette/kritzel-color-palette.js.map +1 -1
  105. package/dist/collection/components/shared/kritzel-dropdown/kritzel-dropdown.js +44 -40
  106. package/dist/collection/components/shared/kritzel-dropdown/kritzel-dropdown.js.map +1 -1
  107. package/dist/collection/components/shared/kritzel-font/kritzel-font.js +3 -5
  108. package/dist/collection/components/shared/kritzel-font/kritzel-font.js.map +1 -1
  109. package/dist/collection/components/shared/kritzel-font-family/kritzel-font-family.js +17 -17
  110. package/dist/collection/components/shared/kritzel-font-family/kritzel-font-family.js.map +1 -1
  111. package/dist/collection/components/shared/kritzel-font-size/kritzel-font-size.js +4 -5
  112. package/dist/collection/components/shared/kritzel-font-size/kritzel-font-size.js.map +1 -1
  113. package/dist/collection/components/shared/kritzel-icon/kritzel-icon.js +3 -3
  114. package/dist/collection/components/shared/kritzel-icon/kritzel-icon.js.map +1 -1
  115. package/dist/collection/components/shared/kritzel-menu/kritzel-menu.css +16 -169
  116. package/dist/collection/components/shared/kritzel-menu/kritzel-menu.js +176 -196
  117. package/dist/collection/components/shared/kritzel-menu/kritzel-menu.js.map +1 -1
  118. package/dist/collection/components/shared/kritzel-menu-item/kritzel-menu-item.css +136 -0
  119. package/dist/collection/components/shared/kritzel-menu-item/kritzel-menu-item.js +267 -0
  120. package/dist/collection/components/shared/kritzel-menu-item/kritzel-menu-item.js.map +1 -0
  121. package/dist/collection/components/shared/kritzel-portal/kritzel-portal.js +164 -48
  122. package/dist/collection/components/shared/kritzel-portal/kritzel-portal.js.map +1 -1
  123. package/dist/collection/components/shared/kritzel-split-button/kritzel-split-button.css +83 -78
  124. package/dist/collection/components/shared/kritzel-split-button/kritzel-split-button.js +160 -130
  125. package/dist/collection/components/shared/kritzel-split-button/kritzel-split-button.js.map +1 -1
  126. package/dist/collection/components/shared/kritzel-stroke-size/kritzel-stroke-size.js +4 -5
  127. package/dist/collection/components/shared/kritzel-stroke-size/kritzel-stroke-size.js.map +1 -1
  128. package/dist/collection/components/shared/kritzel-tooltip/kritzel-tooltip.js +13 -14
  129. package/dist/collection/components/shared/kritzel-tooltip/kritzel-tooltip.js.map +1 -1
  130. package/dist/collection/components/ui/kritzel-context-menu/kritzel-context-menu.js +5 -3
  131. package/dist/collection/components/ui/kritzel-context-menu/kritzel-context-menu.js.map +1 -1
  132. package/dist/collection/components/ui/kritzel-control-brush-config/kritzel-control-brush-config.js +6 -6
  133. package/dist/collection/components/ui/kritzel-control-brush-config/kritzel-control-brush-config.js.map +1 -1
  134. package/dist/collection/components/ui/kritzel-control-text-config/kritzel-control-text-config.js +5 -5
  135. package/dist/collection/components/ui/kritzel-control-text-config/kritzel-control-text-config.js.map +1 -1
  136. package/dist/collection/components/ui/kritzel-controls/kritzel-controls.js +25 -32
  137. package/dist/collection/components/ui/kritzel-controls/kritzel-controls.js.map +1 -1
  138. package/dist/collection/components/ui/kritzel-utility-panel/kritzel-utility-panel.js +4 -1
  139. package/dist/collection/components/ui/kritzel-utility-panel/kritzel-utility-panel.js.map +1 -1
  140. package/dist/collection/components/ui/kritzel-workspace-manager/kritzel-workspace-manager.js +116 -95
  141. package/dist/collection/components/ui/kritzel-workspace-manager/kritzel-workspace-manager.js.map +1 -1
  142. package/dist/collection/configs/default-engine-state.js +1 -1
  143. package/dist/collection/configs/default-engine-state.js.map +1 -1
  144. package/dist/collection/helpers/event.helper.js +2 -2
  145. package/dist/collection/helpers/event.helper.js.map +1 -1
  146. package/dist/collection/helpers/html.helper.js +1 -2
  147. package/dist/collection/helpers/html.helper.js.map +1 -1
  148. package/dist/collection/helpers/keyboard.helper.js +18 -0
  149. package/dist/collection/helpers/keyboard.helper.js.map +1 -1
  150. package/dist/collection/helpers/object.helper.js +2 -14
  151. package/dist/collection/helpers/object.helper.js.map +1 -1
  152. package/dist/collection/index.js +2 -0
  153. package/dist/collection/index.js.map +1 -1
  154. package/dist/collection/interfaces/engine-state.interface.js.map +1 -1
  155. package/dist/collection/interfaces/menu-item.interface.js.map +1 -1
  156. package/dist/components/index.d.ts +2 -0
  157. package/dist/components/index.js +5 -3
  158. package/dist/components/index.js.map +1 -1
  159. package/dist/components/kritzel-brush-style.js +1 -1
  160. package/dist/components/kritzel-color-palette.js +1 -1
  161. package/dist/components/kritzel-color.js +1 -1
  162. package/dist/components/kritzel-context-menu.js +1 -1
  163. package/dist/components/kritzel-control-brush-config.js +1 -1
  164. package/dist/components/kritzel-control-text-config.js +1 -1
  165. package/dist/components/kritzel-controls.js +1 -1
  166. package/dist/components/kritzel-cursor-trail.js +1 -1
  167. package/dist/components/kritzel-dropdown.js +1 -1
  168. package/dist/components/kritzel-editor.js +145 -126
  169. package/dist/components/kritzel-editor.js.map +1 -1
  170. package/dist/components/kritzel-engine.js +1 -1
  171. package/dist/components/kritzel-font-family.js +1 -1
  172. package/dist/components/kritzel-font-size.js +1 -1
  173. package/dist/components/kritzel-font.js +1 -1
  174. package/dist/components/kritzel-icon.js +1 -1
  175. package/dist/components/kritzel-menu-item.d.ts +11 -0
  176. package/dist/components/kritzel-menu-item.js +9 -0
  177. package/dist/components/kritzel-menu-item.js.map +1 -0
  178. package/dist/components/kritzel-menu.js +1 -1
  179. package/dist/components/kritzel-portal.js +1 -1
  180. package/dist/components/kritzel-split-button.js +1 -1
  181. package/dist/components/kritzel-stroke-size.js +1 -1
  182. package/dist/components/kritzel-tooltip.js +1 -1
  183. package/dist/components/kritzel-utility-panel.js +1 -1
  184. package/dist/components/kritzel-workspace-manager.js +1 -1
  185. package/dist/components/{p-BU2q3PRS.js → p-B1BLgWL1.js} +9 -6
  186. package/dist/components/p-B1BLgWL1.js.map +1 -0
  187. package/dist/components/{p-5CJxFNEE.js → p-BB0_-X42.js} +5 -4
  188. package/dist/components/p-BB0_-X42.js.map +1 -0
  189. package/dist/components/{p-yZFrTtMQ.js → p-BB5R2k1o.js} +42 -48
  190. package/dist/components/p-BB5R2k1o.js.map +1 -0
  191. package/dist/components/p-BPz_H-EG.js +137 -0
  192. package/dist/components/p-BPz_H-EG.js.map +1 -0
  193. package/dist/components/{p-BqrTPNyu.js → p-BYanlgdq.js} +41 -15
  194. package/dist/components/p-BYanlgdq.js.map +1 -0
  195. package/dist/components/{p-BeVv4o5c.js → p-B_lb1FGi.js} +7 -2
  196. package/dist/components/p-B_lb1FGi.js.map +1 -0
  197. package/dist/components/p-BeljsQ-8.js +252 -0
  198. package/dist/components/p-BeljsQ-8.js.map +1 -0
  199. package/dist/components/{p-_ntxNi8v.js → p-BexTdWaX.js} +21 -19
  200. package/dist/components/p-BexTdWaX.js.map +1 -0
  201. package/dist/components/{p-BzSz74Ci.js → p-BgmKrd5Z.js} +8 -5
  202. package/dist/components/p-BgmKrd5Z.js.map +1 -0
  203. package/dist/components/{p-BZ-j_4CK.js → p-BhiYvSBc.js} +6 -6
  204. package/dist/components/p-BhiYvSBc.js.map +1 -0
  205. package/dist/components/{p-jG1e48OE.js → p-BrBQUN0Q.js} +16 -16
  206. package/dist/components/p-BrBQUN0Q.js.map +1 -0
  207. package/dist/components/{p-DtmZW6eP.js → p-BubxwvMA.js} +9 -7
  208. package/dist/components/p-BubxwvMA.js.map +1 -0
  209. package/dist/components/{p-D-zg05gA.js → p-BuewJQNl.js} +332 -393
  210. package/dist/components/p-BuewJQNl.js.map +1 -0
  211. package/dist/components/p-CGmS8wnN.js +186 -0
  212. package/dist/components/p-CGmS8wnN.js.map +1 -0
  213. package/dist/components/{p-BaKb8ZLg.js → p-CHxPWeZd.js} +15 -13
  214. package/dist/components/p-CHxPWeZd.js.map +1 -0
  215. package/dist/components/{p-rQeWFfPG.js → p-CMJ3P0Vw.js} +8 -7
  216. package/dist/components/p-CMJ3P0Vw.js.map +1 -0
  217. package/dist/components/{p-B7VrEdgP.js → p-DHSEK3rF.js} +141 -102
  218. package/dist/components/p-DHSEK3rF.js.map +1 -0
  219. package/dist/components/{p-BAPUTr3K.js → p-DMrtdhBD.js} +9 -8
  220. package/dist/components/p-DMrtdhBD.js.map +1 -0
  221. package/dist/components/p-DnUKql15.js +30 -0
  222. package/dist/components/p-DnUKql15.js.map +1 -0
  223. package/dist/components/p-DxTu1aoJ.js +237 -0
  224. package/dist/components/p-DxTu1aoJ.js.map +1 -0
  225. package/dist/components/{p-BLmFBe2a.js → p-p1Jkec_q.js} +7 -5
  226. package/dist/components/p-p1Jkec_q.js.map +1 -0
  227. package/dist/components/{p-V4ui5aWj.js → p-rIRXQdie.js} +11 -10
  228. package/dist/components/p-rIRXQdie.js.map +1 -0
  229. package/dist/components/{p-a7KmQzo4.js → p-t4NIsuX9.js} +15 -13
  230. package/dist/components/p-t4NIsuX9.js.map +1 -0
  231. package/dist/components/{p-BvlGgLAQ.js → p-trncBp_6.js} +47 -41
  232. package/dist/components/p-trncBp_6.js.map +1 -0
  233. package/dist/components/{p-BcQTDgzV.js → p-yZ48g7-u.js} +8 -7
  234. package/dist/components/p-yZ48g7-u.js.map +1 -0
  235. package/dist/esm/{index-J4NpPimy.js → index-B-oSk-v8.js} +259 -192
  236. package/dist/esm/index-B-oSk-v8.js.map +1 -0
  237. package/dist/esm/{index-NiIEUDzj.js → index-oCOlsFCN.js} +43 -17
  238. package/dist/esm/index-oCOlsFCN.js.map +1 -0
  239. package/dist/esm/index.js +1 -1
  240. package/dist/esm/{kritzel-brush-style_22.entry.js → kritzel-brush-style_23.entry.js} +929 -841
  241. package/dist/esm/loader.js +3 -3
  242. package/dist/esm/stencil.js +4 -4
  243. package/dist/esm/stencil.js.map +1 -1
  244. package/dist/stencil/index.esm.js +1 -1
  245. package/dist/stencil/p-3bb80782.entry.js +2 -0
  246. package/dist/stencil/p-3bb80782.entry.js.map +1 -0
  247. package/dist/stencil/p-B-oSk-v8.js +2 -0
  248. package/dist/stencil/p-B-oSk-v8.js.map +1 -0
  249. package/dist/stencil/p-oCOlsFCN.js +3 -0
  250. package/dist/stencil/p-oCOlsFCN.js.map +1 -0
  251. package/dist/stencil/stencil.esm.js +1 -1
  252. package/dist/stencil/stencil.esm.js.map +1 -1
  253. package/dist/types/classes/objects/path.class.d.ts +0 -2
  254. package/dist/types/classes/structures/object-map.structure.d.ts +11 -0
  255. package/dist/types/components/core/kritzel-editor/kritzel-editor.d.ts +3 -0
  256. package/dist/types/components/shared/kritzel-menu/kritzel-menu.d.ts +18 -20
  257. package/dist/types/components/shared/kritzel-menu-item/kritzel-menu-item.d.ts +26 -0
  258. package/dist/types/components/shared/kritzel-portal/kritzel-portal.d.ts +15 -10
  259. package/dist/types/components/shared/kritzel-split-button/kritzel-split-button.d.ts +23 -15
  260. package/dist/types/components/ui/kritzel-workspace-manager/kritzel-workspace-manager.d.ts +18 -14
  261. package/dist/types/components.d.ts +90 -61
  262. package/dist/types/helpers/keyboard.helper.d.ts +1 -0
  263. package/dist/types/index.d.ts +2 -0
  264. package/dist/types/interfaces/engine-state.interface.d.ts +2 -2
  265. package/dist/types/interfaces/menu-item.interface.d.ts +21 -7
  266. package/dist/types/stencil-public-runtime.d.ts +6 -4
  267. package/package.json +1 -1
  268. package/dist/cjs/index-C7Read21.js.map +0 -1
  269. package/dist/cjs/index-CUSIflVf.js.map +0 -1
  270. package/dist/collection/classes/structures/octree.structure.js +0 -115
  271. package/dist/collection/classes/structures/octree.structure.js.map +0 -1
  272. package/dist/components/p-5CJxFNEE.js.map +0 -1
  273. package/dist/components/p-B7VrEdgP.js.map +0 -1
  274. package/dist/components/p-BAPUTr3K.js.map +0 -1
  275. package/dist/components/p-BLmFBe2a.js.map +0 -1
  276. package/dist/components/p-BU2q3PRS.js.map +0 -1
  277. package/dist/components/p-BZ-j_4CK.js.map +0 -1
  278. package/dist/components/p-BaKb8ZLg.js.map +0 -1
  279. package/dist/components/p-Bb6od8He.js +0 -42
  280. package/dist/components/p-Bb6od8He.js.map +0 -1
  281. package/dist/components/p-BcQTDgzV.js.map +0 -1
  282. package/dist/components/p-BeVv4o5c.js.map +0 -1
  283. package/dist/components/p-BmJbJwkH.js +0 -167
  284. package/dist/components/p-BmJbJwkH.js.map +0 -1
  285. package/dist/components/p-BqrTPNyu.js.map +0 -1
  286. package/dist/components/p-BvlGgLAQ.js.map +0 -1
  287. package/dist/components/p-BzSz74Ci.js.map +0 -1
  288. package/dist/components/p-C6OxvITm.js +0 -168
  289. package/dist/components/p-C6OxvITm.js.map +0 -1
  290. package/dist/components/p-D-zg05gA.js.map +0 -1
  291. package/dist/components/p-Dozs0Zfn.js +0 -115
  292. package/dist/components/p-Dozs0Zfn.js.map +0 -1
  293. package/dist/components/p-DtmZW6eP.js.map +0 -1
  294. package/dist/components/p-V4ui5aWj.js.map +0 -1
  295. package/dist/components/p-_ntxNi8v.js.map +0 -1
  296. package/dist/components/p-a7KmQzo4.js.map +0 -1
  297. package/dist/components/p-aaxf-h5S.js +0 -159
  298. package/dist/components/p-aaxf-h5S.js.map +0 -1
  299. package/dist/components/p-jG1e48OE.js.map +0 -1
  300. package/dist/components/p-rQeWFfPG.js.map +0 -1
  301. package/dist/components/p-yZFrTtMQ.js.map +0 -1
  302. package/dist/esm/index-J4NpPimy.js.map +0 -1
  303. package/dist/esm/index-NiIEUDzj.js.map +0 -1
  304. package/dist/stencil/p-43202395.entry.js +0 -2
  305. package/dist/stencil/p-43202395.entry.js.map +0 -1
  306. package/dist/stencil/p-J4NpPimy.js +0 -2
  307. package/dist/stencil/p-J4NpPimy.js.map +0 -1
  308. package/dist/stencil/p-NiIEUDzj.js +0 -3
  309. package/dist/stencil/p-NiIEUDzj.js.map +0 -1
  310. package/dist/types/classes/structures/octree.structure.d.ts +0 -18
@@ -0,0 +1,267 @@
1
+ import { Host, h } from "@stencil/core";
2
+ export class KritzelMenuItem {
3
+ host;
4
+ item;
5
+ onItemChange(newValue, oldValue) {
6
+ if (newValue !== oldValue) {
7
+ this.isDirty = false;
8
+ }
9
+ }
10
+ parent = null;
11
+ itemSelect;
12
+ itemSave;
13
+ itemCancel;
14
+ itemToggleChildMenu;
15
+ itemCloseChildMenu;
16
+ isDirty = false;
17
+ inputRef;
18
+ componentDidLoad() {
19
+ if (this.item.isEditing && this.inputRef && !this.isDirty) {
20
+ this.inputRef.focus();
21
+ this.inputRef.select();
22
+ }
23
+ }
24
+ componentDidUpdate() {
25
+ if (this.item.isEditing && this.inputRef && !this.isDirty) {
26
+ this.inputRef.focus();
27
+ this.inputRef.select();
28
+ }
29
+ }
30
+ handleItemSelect = (event) => {
31
+ event.stopPropagation();
32
+ this.itemSelect.emit({ item: this.item, parent: this.parent });
33
+ };
34
+ handleInputChange = (event) => {
35
+ event.stopPropagation();
36
+ const target = event.target;
37
+ this.item.label = target.value;
38
+ this.isDirty = true;
39
+ };
40
+ handleSave = (event) => {
41
+ event.stopPropagation();
42
+ this.host.focus();
43
+ this.itemSave.emit(this.item);
44
+ };
45
+ handleCancel = (event) => {
46
+ event.stopPropagation();
47
+ this.host.focus();
48
+ this.itemCancel.emit(this.item);
49
+ };
50
+ handleMenuToggle = (event) => {
51
+ event.stopPropagation();
52
+ this.itemToggleChildMenu.emit({ item: this.item, childMenuAnchor: event.target });
53
+ };
54
+ handleMenuClose = () => {
55
+ this.itemCloseChildMenu.emit(this.item);
56
+ };
57
+ renderViewMode() {
58
+ return [
59
+ h("div", { class: "menu-item-content left" }, h("div", null, this.item.label)),
60
+ h("div", { class: "menu-item-content right" }, this.item.children &&
61
+ this.item.children.length > 0 && [
62
+ h("button", { id: "child-menu-toggle", class: "action-button", onClick: this.handleMenuToggle, disabled: this.item.isDisabled }, h("kritzel-icon", { name: "ellipsis-vertical", size: 16 })),
63
+ h("kritzel-portal", { anchor: this.item.childMenuAnchor, offsetY: 4, onClose: this.handleMenuClose }, h("kritzel-menu", { items: this.item.children, parent: this.item, onItemSelect: event => this.itemSelect.emit(event.detail), onItemSave: event => this.itemSave.emit(event.detail), onItemCancel: event => this.itemCancel.emit(event.detail), onClose: this.handleMenuClose })),
64
+ ]),
65
+ ];
66
+ }
67
+ renderEditMode() {
68
+ return [
69
+ h("div", { class: "menu-item-content left" }, h("input", { ref: el => (this.inputRef = el), type: "text", class: "edit-input", value: this.item.label, onInput: this.handleInputChange })),
70
+ h("div", { class: "menu-item-content right" }, h("div", { tabIndex: !this.isDirty && !this.item.isNewItem ? -1 : 0, class: { 'action-button': true, 'disabled': !this.isDirty && !this.item.isNewItem }, onClick: this.handleSave }, h("kritzel-icon", { name: "check", size: 16 })), h("div", { tabIndex: 0, class: "action-button", onClick: this.handleCancel }, h("kritzel-icon", { name: "x", size: 16 }))),
71
+ ];
72
+ }
73
+ render() {
74
+ return (h(Host, { key: '5440ed43726d00ab65e7f423f065c1a3fa74e39e', tabIndex: 0, class: {
75
+ 'selected': this.item.isSelected,
76
+ 'editing': this.item.isEditing,
77
+ 'disabled': this.item.isDisabled,
78
+ 'child-open': this.item.isChildMenuOpen,
79
+ }, onClick: this.handleItemSelect }, h("div", { key: '69542710179216a1df47bde5d474a72e4a07aa5b', class: "menu-item-overlay" }), this.item.isEditing ? this.renderEditMode() : this.renderViewMode()));
80
+ }
81
+ static get is() { return "kritzel-menu-item"; }
82
+ static get encapsulation() { return "shadow"; }
83
+ static get originalStyleUrls() {
84
+ return {
85
+ "$": ["kritzel-menu-item.css"]
86
+ };
87
+ }
88
+ static get styleUrls() {
89
+ return {
90
+ "$": ["kritzel-menu-item.css"]
91
+ };
92
+ }
93
+ static get properties() {
94
+ return {
95
+ "item": {
96
+ "type": "unknown",
97
+ "attribute": "item",
98
+ "mutable": false,
99
+ "complexType": {
100
+ "original": "IKritzelMenuItem",
101
+ "resolved": "IKritzelMenuItem<any>",
102
+ "references": {
103
+ "IKritzelMenuItem": {
104
+ "location": "import",
105
+ "path": "../../../interfaces/menu-item.interface",
106
+ "id": "src/interfaces/menu-item.interface.ts::IKritzelMenuItem"
107
+ }
108
+ }
109
+ },
110
+ "required": false,
111
+ "optional": false,
112
+ "docs": {
113
+ "tags": [],
114
+ "text": ""
115
+ },
116
+ "getter": false,
117
+ "setter": false
118
+ },
119
+ "parent": {
120
+ "type": "unknown",
121
+ "attribute": "parent",
122
+ "mutable": false,
123
+ "complexType": {
124
+ "original": "IKritzelMenuItem",
125
+ "resolved": "IKritzelMenuItem<any>",
126
+ "references": {
127
+ "IKritzelMenuItem": {
128
+ "location": "import",
129
+ "path": "../../../interfaces/menu-item.interface",
130
+ "id": "src/interfaces/menu-item.interface.ts::IKritzelMenuItem"
131
+ }
132
+ }
133
+ },
134
+ "required": false,
135
+ "optional": false,
136
+ "docs": {
137
+ "tags": [],
138
+ "text": ""
139
+ },
140
+ "getter": false,
141
+ "setter": false,
142
+ "defaultValue": "null"
143
+ }
144
+ };
145
+ }
146
+ static get states() {
147
+ return {
148
+ "isDirty": {}
149
+ };
150
+ }
151
+ static get events() {
152
+ return [{
153
+ "method": "itemSelect",
154
+ "name": "itemSelect",
155
+ "bubbles": true,
156
+ "cancelable": true,
157
+ "composed": true,
158
+ "docs": {
159
+ "tags": [],
160
+ "text": ""
161
+ },
162
+ "complexType": {
163
+ "original": "IKritzelMenuItemSelectEvent",
164
+ "resolved": "IKritzelMenuItemSelectEvent",
165
+ "references": {
166
+ "IKritzelMenuItemSelectEvent": {
167
+ "location": "import",
168
+ "path": "../../../interfaces/menu-item.interface",
169
+ "id": "src/interfaces/menu-item.interface.ts::IKritzelMenuItemSelectEvent"
170
+ }
171
+ }
172
+ }
173
+ }, {
174
+ "method": "itemSave",
175
+ "name": "itemSave",
176
+ "bubbles": true,
177
+ "cancelable": true,
178
+ "composed": true,
179
+ "docs": {
180
+ "tags": [],
181
+ "text": ""
182
+ },
183
+ "complexType": {
184
+ "original": "IKritzelMenuItem",
185
+ "resolved": "IKritzelMenuItem<any>",
186
+ "references": {
187
+ "IKritzelMenuItem": {
188
+ "location": "import",
189
+ "path": "../../../interfaces/menu-item.interface",
190
+ "id": "src/interfaces/menu-item.interface.ts::IKritzelMenuItem"
191
+ }
192
+ }
193
+ }
194
+ }, {
195
+ "method": "itemCancel",
196
+ "name": "itemCancel",
197
+ "bubbles": true,
198
+ "cancelable": true,
199
+ "composed": true,
200
+ "docs": {
201
+ "tags": [],
202
+ "text": ""
203
+ },
204
+ "complexType": {
205
+ "original": "IKritzelMenuItem",
206
+ "resolved": "IKritzelMenuItem<any>",
207
+ "references": {
208
+ "IKritzelMenuItem": {
209
+ "location": "import",
210
+ "path": "../../../interfaces/menu-item.interface",
211
+ "id": "src/interfaces/menu-item.interface.ts::IKritzelMenuItem"
212
+ }
213
+ }
214
+ }
215
+ }, {
216
+ "method": "itemToggleChildMenu",
217
+ "name": "itemToggleChildMenu",
218
+ "bubbles": true,
219
+ "cancelable": true,
220
+ "composed": true,
221
+ "docs": {
222
+ "tags": [],
223
+ "text": ""
224
+ },
225
+ "complexType": {
226
+ "original": "IKritzelMenuItemToggleChildMenuEvent",
227
+ "resolved": "IKritzelMenuItemToggleChildMenuEvent",
228
+ "references": {
229
+ "IKritzelMenuItemToggleChildMenuEvent": {
230
+ "location": "import",
231
+ "path": "../../../interfaces/menu-item.interface",
232
+ "id": "src/interfaces/menu-item.interface.ts::IKritzelMenuItemToggleChildMenuEvent"
233
+ }
234
+ }
235
+ }
236
+ }, {
237
+ "method": "itemCloseChildMenu",
238
+ "name": "itemCloseChildMenu",
239
+ "bubbles": true,
240
+ "cancelable": true,
241
+ "composed": true,
242
+ "docs": {
243
+ "tags": [],
244
+ "text": ""
245
+ },
246
+ "complexType": {
247
+ "original": "IKritzelMenuItem",
248
+ "resolved": "IKritzelMenuItem<any>",
249
+ "references": {
250
+ "IKritzelMenuItem": {
251
+ "location": "import",
252
+ "path": "../../../interfaces/menu-item.interface",
253
+ "id": "src/interfaces/menu-item.interface.ts::IKritzelMenuItem"
254
+ }
255
+ }
256
+ }
257
+ }];
258
+ }
259
+ static get elementRef() { return "host"; }
260
+ static get watchers() {
261
+ return [{
262
+ "propName": "item",
263
+ "methodName": "onItemChange"
264
+ }];
265
+ }
266
+ }
267
+ //# sourceMappingURL=kritzel-menu-item.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"kritzel-menu-item.js","sourceRoot":"","sources":["../../../../src/components/shared/kritzel-menu-item/kritzel-menu-item.tsx"],"names":[],"mappings":"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","sourcesContent":["import { Component, Host, Prop, h, Element, State, Watch, Event, EventEmitter } from '@stencil/core';\r\nimport { IKritzelMenuItem, IKritzelMenuItemSelectEvent, IKritzelMenuItemToggleChildMenuEvent } from '../../../interfaces/menu-item.interface';\r\n\r\n@Component({\r\n tag: 'kritzel-menu-item',\r\n styleUrl: 'kritzel-menu-item.css',\r\n shadow: true,\r\n})\r\nexport class KritzelMenuItem {\r\n @Element() host: HTMLElement;\r\n\r\n @Prop() item: IKritzelMenuItem;\r\n @Watch('item')\r\n onItemChange(newValue: IKritzelMenuItem, oldValue: IKritzelMenuItem) {\r\n if (newValue !== oldValue) {\r\n this.isDirty = false;\r\n }\r\n }\r\n @Prop() parent: IKritzelMenuItem = null;\r\n\r\n @Event() itemSelect: EventEmitter<IKritzelMenuItemSelectEvent>;\r\n @Event() itemSave: EventEmitter<IKritzelMenuItem>;\r\n @Event() itemCancel: EventEmitter<IKritzelMenuItem>;\r\n @Event() itemToggleChildMenu: EventEmitter<IKritzelMenuItemToggleChildMenuEvent>;\r\n @Event() itemCloseChildMenu: EventEmitter<IKritzelMenuItem>;\r\n\r\n @State()\r\n isDirty: boolean = false;\r\n\r\n private inputRef: HTMLInputElement;\r\n\r\n componentDidLoad() {\r\n if (this.item.isEditing && this.inputRef && !this.isDirty) {\r\n this.inputRef.focus();\r\n this.inputRef.select();\r\n }\r\n }\r\n\r\n componentDidUpdate() {\r\n if (this.item.isEditing && this.inputRef && !this.isDirty) {\r\n this.inputRef.focus();\r\n this.inputRef.select();\r\n }\r\n }\r\n\r\n private handleItemSelect = (event: MouseEvent) => {\r\n event.stopPropagation();\r\n this.itemSelect.emit({ item: this.item, parent: this.parent });\r\n };\r\n\r\n private handleInputChange = (event: Event) => {\r\n event.stopPropagation();\r\n const target = event.target as HTMLInputElement;\r\n this.item.label = target.value;\r\n this.isDirty = true;\r\n };\r\n\r\n private handleSave = (event: MouseEvent) => {\r\n event.stopPropagation();\r\n this.host.focus();\r\n this.itemSave.emit(this.item);\r\n };\r\n\r\n private handleCancel = (event: MouseEvent) => {\r\n event.stopPropagation();\r\n this.host.focus();\r\n this.itemCancel.emit(this.item);\r\n };\r\n\r\n private handleMenuToggle = (event: MouseEvent) => {\r\n event.stopPropagation();\r\n this.itemToggleChildMenu.emit({ item: this.item, childMenuAnchor: event.target as HTMLElement });\r\n };\r\n\r\n private handleMenuClose = () => {\r\n this.itemCloseChildMenu.emit(this.item);\r\n };\r\n\r\n private renderViewMode() {\r\n return [\r\n <div class=\"menu-item-content left\">\r\n <div>{this.item.label}</div>\r\n </div>,\r\n <div class=\"menu-item-content right\">\r\n {this.item.children &&\r\n this.item.children.length > 0 && [\r\n <button id=\"child-menu-toggle\" class=\"action-button\" onClick={this.handleMenuToggle} disabled={this.item.isDisabled}>\r\n <kritzel-icon name=\"ellipsis-vertical\" size={16}></kritzel-icon>\r\n </button>,\r\n <kritzel-portal anchor={this.item.childMenuAnchor} offsetY={4} onClose={this.handleMenuClose}>\r\n <kritzel-menu\r\n items={this.item.children}\r\n parent={this.item}\r\n onItemSelect={event => this.itemSelect.emit(event.detail)}\r\n onItemSave={event => this.itemSave.emit(event.detail)}\r\n onItemCancel={event => this.itemCancel.emit(event.detail)}\r\n onClose={this.handleMenuClose}\r\n ></kritzel-menu>\r\n </kritzel-portal>,\r\n ]}\r\n </div>,\r\n ];\r\n }\r\n\r\n private renderEditMode() {\r\n return [\r\n <div class=\"menu-item-content left\">\r\n <input ref={el => (this.inputRef = el)} type=\"text\" class=\"edit-input\" value={this.item.label} onInput={this.handleInputChange} />\r\n </div>,\r\n <div class=\"menu-item-content right\">\r\n <div tabIndex={!this.isDirty && !this.item.isNewItem ? -1 : 0} class={{ 'action-button': true, 'disabled': !this.isDirty && !this.item.isNewItem }} onClick={this.handleSave}>\r\n <kritzel-icon name=\"check\" size={16}></kritzel-icon>\r\n </div>\r\n <div tabIndex={0} class=\"action-button\" onClick={this.handleCancel}>\r\n <kritzel-icon name=\"x\" size={16}></kritzel-icon>\r\n </div>\r\n </div>,\r\n ];\r\n }\r\n\r\n render() {\r\n return (\r\n <Host\r\n tabIndex={0}\r\n class={{\r\n 'selected': this.item.isSelected,\r\n 'editing': this.item.isEditing,\r\n 'disabled': this.item.isDisabled,\r\n 'child-open': this.item.isChildMenuOpen,\r\n }}\r\n onClick={this.handleItemSelect}\r\n >\r\n <div class=\"menu-item-overlay\"></div>\r\n {this.item.isEditing ? this.renderEditMode() : this.renderViewMode()}\r\n </Host>\r\n );\r\n }\r\n}\r\n"]}
@@ -1,70 +1,190 @@
1
1
  import { Host, h } from "@stencil/core";
2
- import { KritzelHTMLHelper } from "../../../helpers/html.helper";
3
- const DEFAULT_OFFSET = 0;
4
- const MIN_LEFT_POSITION = 0;
5
- const Z_INDEX = '9005';
6
- const ID_PORTAL = 'portal';
2
+ import { ObjectHelper } from "../../../helpers/object.helper";
7
3
  export class KritzelPortal {
8
- constructor() {
9
- this.autoFocus = true;
10
- this.moved = false;
11
- this.handleScroll = () => {
12
- const isAnchorInViewport = KritzelHTMLHelper.isElementInViewport(this.anchor);
13
- if (!isAnchorInViewport) {
14
- this.close.emit();
15
- return;
16
- }
17
- this.calculatePosition();
18
- };
19
- }
4
+ host;
5
+ anchor;
20
6
  anchorChanged(newValue) {
21
7
  if (newValue) {
8
+ this.openPortal();
22
9
  this.calculatePosition();
10
+ if (this.autoFocus) {
11
+ this.focusFirstElement();
12
+ }
13
+ }
14
+ else {
15
+ this.closePortal();
16
+ }
17
+ }
18
+ offsetX;
19
+ offsetY;
20
+ autoFocus = true;
21
+ close;
22
+ handleOutsideClick(event) {
23
+ event.stopPropagation();
24
+ const isLastPortal = this.lastAddedPortal === this.portal;
25
+ if (!isLastPortal)
26
+ return;
27
+ const target = event.target;
28
+ if (!this.host.contains(target)) {
29
+ this.close.emit();
30
+ this.closePortal();
31
+ }
32
+ }
33
+ handleKeyDown(event) {
34
+ event.stopPropagation();
35
+ const isLastPortal = this.lastAddedPortal === this.portal;
36
+ if (!isLastPortal)
37
+ return;
38
+ if (event.key === 'Escape') {
39
+ this.anchor.focus();
40
+ this.close.emit();
41
+ this.closePortal();
42
+ }
43
+ if (event.key === 'Tab') {
44
+ this.trapFocus(event);
45
+ }
46
+ if (event.key === 'Enter') {
47
+ const activeElement = this.getDeepActiveElement();
48
+ if (activeElement?.click) {
49
+ event.preventDefault();
50
+ activeElement.click();
51
+ }
23
52
  }
24
53
  }
25
54
  handleResize() {
26
55
  this.calculatePosition();
27
56
  }
57
+ portal;
58
+ id = `portal-${ObjectHelper.generateUUID()}`;
59
+ defaultOffset = 0;
60
+ minLeft = 0;
61
+ focusFirstElement() {
62
+ requestAnimationFrame(() => {
63
+ this.firstFocusableElement?.focus?.();
64
+ });
65
+ }
66
+ getDeepActiveElement() {
67
+ let activeEl = document.activeElement;
68
+ while (activeEl?.shadowRoot?.activeElement) {
69
+ activeEl = activeEl.shadowRoot.activeElement;
70
+ }
71
+ return activeEl;
72
+ }
73
+ trapFocus(event) {
74
+ const focusableElements = this.getFocusableElements(this.host);
75
+ if (focusableElements.length === 0)
76
+ return;
77
+ const firstFocusable = focusableElements[0];
78
+ const lastFocusable = focusableElements[focusableElements.length - 1];
79
+ const activeElement = this.getDeepActiveElement();
80
+ if (event.shiftKey) {
81
+ /* shift + tab */
82
+ if (activeElement === firstFocusable) {
83
+ lastFocusable.focus();
84
+ event.preventDefault();
85
+ }
86
+ }
87
+ else {
88
+ /* tab */
89
+ if (activeElement === lastFocusable) {
90
+ firstFocusable.focus();
91
+ event.preventDefault();
92
+ }
93
+ }
94
+ }
95
+ getFocusableElements(root) {
96
+ if (!root)
97
+ return [];
98
+ const focusableElements = [];
99
+ const focusableSelector = 'a[href], button:not([disabled]), input:not([disabled]), textarea:not([disabled]), select:not([disabled]), details, [tabindex]:not([tabindex="-1"])';
100
+ const isVisible = (el) => {
101
+ return el.offsetParent !== null;
102
+ };
103
+ // Check if the root element itself is focusable
104
+ if (root.matches(focusableSelector) && !root.hasAttribute('disabled') && isVisible(root)) {
105
+ focusableElements.push(root);
106
+ }
107
+ // Function to recursively find focusable elements
108
+ const findFocusable = (element) => {
109
+ // Search in shadow root
110
+ if (element.shadowRoot) {
111
+ Array.from(element.shadowRoot.querySelectorAll(focusableSelector)).forEach(el => {
112
+ if (isVisible(el)) {
113
+ focusableElements.push(el);
114
+ }
115
+ });
116
+ Array.from(element.shadowRoot.children).forEach(findFocusable);
117
+ }
118
+ // Search in light DOM
119
+ Array.from(element.querySelectorAll(focusableSelector)).forEach(el => {
120
+ if (!focusableElements.includes(el) && isVisible(el)) {
121
+ focusableElements.push(el);
122
+ }
123
+ });
124
+ // Handle slotted content
125
+ if (element.tagName === 'SLOT') {
126
+ element.assignedElements({ flatten: true }).forEach(el => findFocusable(el));
127
+ }
128
+ Array.from(element.children).forEach(findFocusable);
129
+ };
130
+ findFocusable(root);
131
+ // Return unique elements in document order
132
+ return [...new Set(focusableElements)];
133
+ }
134
+ get firstFocusableElement() {
135
+ const slotEl = this.host.shadowRoot?.querySelector('slot');
136
+ const firstAssigned = slotEl?.assignedElements({ flatten: true })[0];
137
+ if (!firstAssigned)
138
+ return null;
139
+ const focusable = this.getFocusableElements(firstAssigned);
140
+ return focusable[0] ?? firstAssigned;
141
+ }
142
+ get lastAddedPortal() {
143
+ const portals = Array.from(document.querySelectorAll('[id^="portal-"]'));
144
+ return portals.length ? portals[portals.length - 1] : null;
145
+ }
28
146
  calculateLeft() {
29
- var _a;
30
147
  if (!this.anchor || !this.portal)
31
148
  return 0;
32
149
  const refRect = this.anchor.getBoundingClientRect();
33
150
  const portalRect = this.portal.getBoundingClientRect();
34
- const offset = (_a = this.offsetX) !== null && _a !== void 0 ? _a : DEFAULT_OFFSET;
151
+ const offset = this.offsetX ?? this.defaultOffset;
35
152
  let left = refRect.left + offset;
36
- const maxLeft = window.innerWidth - portalRect.width - MIN_LEFT_POSITION;
37
- if (left < MIN_LEFT_POSITION)
38
- left = MIN_LEFT_POSITION;
153
+ const maxLeft = window.innerWidth - portalRect.width - this.minLeft;
154
+ if (left < this.minLeft)
155
+ left = this.minLeft;
39
156
  if (left > maxLeft)
40
157
  left = maxLeft;
41
158
  return Math.round(left + window.scrollX);
42
159
  }
43
160
  calculateTop() {
44
- var _a;
45
161
  if (!this.anchor || !this.portal)
46
162
  return 0;
47
163
  const refRect = this.anchor.getBoundingClientRect();
48
164
  const portalRect = this.portal.getBoundingClientRect();
49
- const offset = (_a = this.offsetY) !== null && _a !== void 0 ? _a : DEFAULT_OFFSET;
165
+ const offset = this.offsetY ?? this.defaultOffset;
50
166
  let top = refRect.bottom + offset;
51
167
  if (top + portalRect.height > window.innerHeight) {
52
168
  top = refRect.top - portalRect.height - offset;
53
169
  }
54
170
  return Math.round(top + window.scrollY);
55
171
  }
56
- createPortal() {
172
+ openPortal() {
57
173
  this.portal = document.createElement('div');
58
- this.portal.setAttribute('id', ID_PORTAL);
59
- this.portal.style.zIndex = Z_INDEX;
174
+ this.portal.setAttribute('id', this.id);
175
+ this.portal.style.zIndex = '1';
60
176
  this.portal.style.position = 'absolute';
61
177
  this.portal.style.top = '0px';
62
178
  this.portal.style.left = '0px';
179
+ this.portal.appendChild(this.host);
63
180
  document.body.append(this.portal);
64
181
  }
65
- moveElementToPortal() {
66
- this.portal.appendChild(this.element);
67
- this.moved = true;
182
+ closePortal() {
183
+ const portal = document.getElementById(this.id);
184
+ if (!portal)
185
+ return;
186
+ document.body.removeChild(portal);
187
+ this.host.remove();
68
188
  }
69
189
  calculatePosition() {
70
190
  if (!this.anchor || !this.portal)
@@ -74,25 +194,8 @@ export class KritzelPortal {
74
194
  this.portal.style.top = `${top}px`;
75
195
  this.portal.style.left = `${left}px`;
76
196
  }
77
- componentWillLoad() {
78
- this.createPortal();
79
- }
80
- componentDidLoad() {
81
- var _a;
82
- this.moveElementToPortal();
83
- if (this.anchor) {
84
- this.calculatePosition();
85
- this.scrollableParent = KritzelHTMLHelper.getScrollableParent(this.anchor);
86
- (_a = this.scrollableParent) === null || _a === void 0 ? void 0 : _a.addEventListener('scroll', this.handleScroll);
87
- }
88
- }
89
- disconnectedCallback() {
90
- var _a;
91
- this.moved ? this.portal.remove() : (this.moved = true);
92
- (_a = this.scrollableParent) === null || _a === void 0 ? void 0 : _a.removeEventListener('scroll', this.handleScroll);
93
- }
94
197
  render() {
95
- return (h(Host, { key: 'e39525c3e9ddbf738b63ac0c08d8c1e2264783b1', ref: el => (this.element = el) }, h("slot", { key: '95202c5bea32c77dc1dde0a12a58ac9bcebd8812' })));
198
+ return (h(Host, { key: '968f0360b9396da16f5b970293ba20f8a1dcc09a', style: { display: this.anchor ? 'block' : 'none' } }, h("slot", { key: '0fe1569bde60a834e9226d7c838d113a64151164' })));
96
199
  }
97
200
  static get is() { return "kritzel-portal"; }
98
201
  static get encapsulation() { return "shadow"; }
@@ -199,6 +302,7 @@ export class KritzelPortal {
199
302
  }
200
303
  }];
201
304
  }
305
+ static get elementRef() { return "host"; }
202
306
  static get watchers() {
203
307
  return [{
204
308
  "propName": "anchor",
@@ -207,6 +311,18 @@ export class KritzelPortal {
207
311
  }
208
312
  static get listeners() {
209
313
  return [{
314
+ "name": "click",
315
+ "method": "handleOutsideClick",
316
+ "target": "window",
317
+ "capture": false,
318
+ "passive": false
319
+ }, {
320
+ "name": "keydown",
321
+ "method": "handleKeyDown",
322
+ "target": "window",
323
+ "capture": false,
324
+ "passive": false
325
+ }, {
210
326
  "name": "resize",
211
327
  "method": "handleResize",
212
328
  "target": "window",
@@ -1 +1 @@
1
- {"version":3,"file":"kritzel-portal.js","sourceRoot":"","sources":["../../../../src/components/shared/kritzel-portal/kritzel-portal.tsx"],"names":[],"mappings":"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","sourcesContent":["import { Component, Host, Listen, Prop, Watch, h, Event, EventEmitter } from '@stencil/core';\r\nimport { KritzelHTMLHelper } from '../../../helpers/html.helper';\r\n\r\nconst DEFAULT_OFFSET = 0;\r\nconst MIN_LEFT_POSITION = 0;\r\nconst Z_INDEX = '9005';\r\nconst ID_PORTAL = 'portal';\r\n\r\n@Component({\r\n tag: 'kritzel-portal',\r\n shadow: true,\r\n})\r\nexport class KritzelPortal {\r\n @Prop()\r\n anchor: HTMLElement;\r\n\r\n @Watch('anchor')\r\n anchorChanged(newValue: HTMLElement) {\r\n if (newValue) {\r\n this.calculatePosition();\r\n }\r\n }\r\n\r\n @Prop()\r\n offsetX: number;\r\n\r\n @Prop()\r\n offsetY: number;\r\n\r\n @Prop()\r\n autoFocus: boolean = true;\r\n\r\n @Event()\r\n close: EventEmitter<void>;\r\n\r\n private portal: HTMLElement;\r\n\r\n private element: HTMLElement;\r\n\r\n private moved: boolean = false;\r\n\r\n private scrollableParent: HTMLElement | Window;\r\n\r\n @Listen('resize', { target: 'window', capture: true })\r\n handleResize() {\r\n this.calculatePosition();\r\n }\r\n\r\n private handleScroll = () => {\r\n const isAnchorInViewport = KritzelHTMLHelper.isElementInViewport(this.anchor);\r\n\r\n if (!isAnchorInViewport) {\r\n this.close.emit();\r\n return;\r\n }\r\n\r\n this.calculatePosition();\r\n };\r\n\r\n private calculateLeft() {\r\n if (!this.anchor || !this.portal) return 0;\r\n const refRect = this.anchor.getBoundingClientRect();\r\n const portalRect = this.portal.getBoundingClientRect();\r\n\r\n const offset = this.offsetX ?? DEFAULT_OFFSET;\r\n let left = refRect.left + offset;\r\n\r\n const maxLeft = window.innerWidth - portalRect.width - MIN_LEFT_POSITION;\r\n if (left < MIN_LEFT_POSITION) left = MIN_LEFT_POSITION;\r\n if (left > maxLeft) left = maxLeft;\r\n\r\n return Math.round(left + window.scrollX);\r\n }\r\n\r\n private calculateTop() {\r\n if (!this.anchor || !this.portal) return 0;\r\n const refRect = this.anchor.getBoundingClientRect();\r\n const portalRect = this.portal.getBoundingClientRect();\r\n const offset = this.offsetY ?? DEFAULT_OFFSET;\r\n\r\n let top = refRect.bottom + offset;\r\n\r\n if (top + portalRect.height > window.innerHeight) {\r\n top = refRect.top - portalRect.height - offset;\r\n }\r\n\r\n return Math.round(top + window.scrollY);\r\n }\r\n\r\n private createPortal() {\r\n this.portal = document.createElement('div');\r\n this.portal.setAttribute('id', ID_PORTAL);\r\n this.portal.style.zIndex = Z_INDEX;\r\n this.portal.style.position = 'absolute';\r\n this.portal.style.top = '0px';\r\n this.portal.style.left = '0px';\r\n document.body.append(this.portal);\r\n }\r\n\r\n private moveElementToPortal() {\r\n this.portal.appendChild(this.element);\r\n this.moved = true;\r\n }\r\n\r\n private calculatePosition() {\r\n if (!this.anchor || !this.portal) return;\r\n const top = this.calculateTop();\r\n const left = this.calculateLeft();\r\n this.portal.style.top = `${top}px`;\r\n this.portal.style.left = `${left}px`;\r\n }\r\n\r\n componentWillLoad() {\r\n this.createPortal();\r\n }\r\n\r\n componentDidLoad() {\r\n this.moveElementToPortal();\r\n if (this.anchor) {\r\n this.calculatePosition();\r\n this.scrollableParent = KritzelHTMLHelper.getScrollableParent(this.anchor);\r\n this.scrollableParent?.addEventListener('scroll', this.handleScroll);\r\n }\r\n }\r\n\r\n disconnectedCallback() {\r\n this.moved ? this.portal.remove() : (this.moved = true);\r\n this.scrollableParent?.removeEventListener('scroll', this.handleScroll);\r\n }\r\n\r\n render() {\r\n return (\r\n <Host ref={el => (this.element = el)}>\r\n <slot />\r\n </Host>\r\n );\r\n }\r\n}"]}
1
+ {"version":3,"file":"kritzel-portal.js","sourceRoot":"","sources":["../../../../src/components/shared/kritzel-portal/kritzel-portal.tsx"],"names":[],"mappings":"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","sourcesContent":["import { Component, Host, Listen, Prop, Watch, h, Event, EventEmitter, Element } from '@stencil/core';\r\nimport { ObjectHelper } from '../../../helpers/object.helper';\r\n\r\n@Component({\r\n tag: 'kritzel-portal',\r\n shadow: true,\r\n})\r\nexport class KritzelPortal {\r\n @Element() host: HTMLElement;\r\n\r\n @Prop() anchor: HTMLElement;\r\n @Watch('anchor')\r\n anchorChanged(newValue: HTMLElement) {\r\n if (newValue) {\r\n this.openPortal();\r\n this.calculatePosition();\r\n if (this.autoFocus) {\r\n this.focusFirstElement();\r\n }\r\n } else {\r\n this.closePortal();\r\n }\r\n }\r\n\r\n @Prop() offsetX: number;\r\n @Prop() offsetY: number;\r\n @Prop() autoFocus: boolean = true;\r\n\r\n @Event() close: EventEmitter<void>;\r\n\r\n @Listen('click', { target: 'window' })\r\n handleOutsideClick(event: MouseEvent) {\r\n event.stopPropagation();\r\n\r\n const isLastPortal = this.lastAddedPortal === this.portal;\r\n if (!isLastPortal) return;\r\n\r\n const target = event.target as HTMLElement;\r\n if (!this.host.contains(target)) {\r\n this.close.emit();\r\n this.closePortal();\r\n }\r\n }\r\n\r\n @Listen('keydown', { target: 'window' })\r\n handleKeyDown(event: KeyboardEvent) {\r\n event.stopPropagation();\r\n\r\n const isLastPortal = this.lastAddedPortal === this.portal;\r\n if (!isLastPortal) return;\r\n\r\n if (event.key === 'Escape') {\r\n this.anchor.focus();\r\n this.close.emit();\r\n this.closePortal();\r\n }\r\n\r\n if (event.key === 'Tab') {\r\n this.trapFocus(event);\r\n }\r\n\r\n if (event.key === 'Enter') {\r\n const activeElement = this.getDeepActiveElement() as HTMLElement;\r\n if (activeElement?.click) {\r\n event.preventDefault();\r\n activeElement.click();\r\n }\r\n }\r\n }\r\n\r\n @Listen('resize', { target: 'window', capture: true })\r\n handleResize() {\r\n this.calculatePosition();\r\n }\r\n\r\n private portal: HTMLElement;\r\n private id: string = `portal-${ObjectHelper.generateUUID()}`;\r\n private defaultOffset = 0;\r\n private minLeft = 0;\r\n\r\n private focusFirstElement() {\r\n requestAnimationFrame(() => {\r\n this.firstFocusableElement?.focus?.();\r\n });\r\n }\r\n\r\n private getDeepActiveElement(): Element {\r\n let activeEl = document.activeElement;\r\n while (activeEl?.shadowRoot?.activeElement) {\r\n activeEl = activeEl.shadowRoot.activeElement;\r\n }\r\n return activeEl;\r\n }\r\n\r\n private trapFocus(event: KeyboardEvent) {\r\n const focusableElements = this.getFocusableElements(this.host);\r\n if (focusableElements.length === 0) return;\r\n\r\n const firstFocusable = focusableElements[0];\r\n const lastFocusable = focusableElements[focusableElements.length - 1];\r\n const activeElement = this.getDeepActiveElement();\r\n\r\n if (event.shiftKey) {\r\n /* shift + tab */\r\n if (activeElement === firstFocusable) {\r\n lastFocusable.focus();\r\n event.preventDefault();\r\n }\r\n } else {\r\n /* tab */\r\n if (activeElement === lastFocusable) {\r\n firstFocusable.focus();\r\n event.preventDefault();\r\n }\r\n }\r\n }\r\n\r\n private getFocusableElements(root: HTMLElement): HTMLElement[] {\r\n if (!root) return [];\r\n\r\n const focusableElements: HTMLElement[] = [];\r\n const focusableSelector = 'a[href], button:not([disabled]), input:not([disabled]), textarea:not([disabled]), select:not([disabled]), details, [tabindex]:not([tabindex=\"-1\"])';\r\n\r\n const isVisible = (el: HTMLElement) => {\r\n return el.offsetParent !== null;\r\n };\r\n\r\n // Check if the root element itself is focusable\r\n if (root.matches(focusableSelector) && !root.hasAttribute('disabled') && isVisible(root)) {\r\n focusableElements.push(root);\r\n }\r\n\r\n // Function to recursively find focusable elements\r\n const findFocusable = (element: Element) => {\r\n // Search in shadow root\r\n if (element.shadowRoot) {\r\n Array.from(element.shadowRoot.querySelectorAll<HTMLElement>(focusableSelector)).forEach(el => {\r\n if (isVisible(el)) {\r\n focusableElements.push(el);\r\n }\r\n });\r\n Array.from(element.shadowRoot.children).forEach(findFocusable);\r\n }\r\n\r\n // Search in light DOM\r\n Array.from(element.querySelectorAll<HTMLElement>(focusableSelector)).forEach(el => {\r\n if (!focusableElements.includes(el) && isVisible(el)) {\r\n focusableElements.push(el);\r\n }\r\n });\r\n\r\n // Handle slotted content\r\n if (element.tagName === 'SLOT') {\r\n (element as HTMLSlotElement).assignedElements({ flatten: true }).forEach(el => findFocusable(el));\r\n }\r\n\r\n Array.from(element.children).forEach(findFocusable);\r\n };\r\n\r\n findFocusable(root);\r\n\r\n // Return unique elements in document order\r\n return [...new Set(focusableElements)];\r\n }\r\n\r\n private get firstFocusableElement(): HTMLElement | null {\r\n const slotEl = this.host.shadowRoot?.querySelector('slot') as HTMLSlotElement | null;\r\n const firstAssigned = slotEl?.assignedElements({ flatten: true })[0] as HTMLElement | undefined;\r\n if (!firstAssigned) return null;\r\n\r\n const focusable = this.getFocusableElements(firstAssigned);\r\n return focusable[0] ?? firstAssigned;\r\n }\r\n\r\n private get lastAddedPortal(): HTMLElement | null {\r\n const portals = Array.from(document.querySelectorAll<HTMLElement>('[id^=\"portal-\"]'));\r\n return portals.length ? portals[portals.length - 1] : null;\r\n }\r\n\r\n private calculateLeft() {\r\n if (!this.anchor || !this.portal) return 0;\r\n const refRect = this.anchor.getBoundingClientRect();\r\n const portalRect = this.portal.getBoundingClientRect();\r\n\r\n const offset = this.offsetX ?? this.defaultOffset;\r\n let left = refRect.left + offset;\r\n\r\n const maxLeft = window.innerWidth - portalRect.width - this.minLeft;\r\n if (left < this.minLeft) left = this.minLeft;\r\n if (left > maxLeft) left = maxLeft;\r\n\r\n return Math.round(left + window.scrollX);\r\n }\r\n\r\n private calculateTop() {\r\n if (!this.anchor || !this.portal) return 0;\r\n const refRect = this.anchor.getBoundingClientRect();\r\n const portalRect = this.portal.getBoundingClientRect();\r\n const offset = this.offsetY ?? this.defaultOffset;\r\n\r\n let top = refRect.bottom + offset;\r\n\r\n if (top + portalRect.height > window.innerHeight) {\r\n top = refRect.top - portalRect.height - offset;\r\n }\r\n\r\n return Math.round(top + window.scrollY);\r\n }\r\n\r\n private openPortal() {\r\n this.portal = document.createElement('div');\r\n this.portal.setAttribute('id', this.id);\r\n this.portal.style.zIndex = '1';\r\n this.portal.style.position = 'absolute';\r\n this.portal.style.top = '0px';\r\n this.portal.style.left = '0px';\r\n this.portal.appendChild(this.host);\r\n document.body.append(this.portal);\r\n }\r\n\r\n private closePortal() {\r\n const portal = document.getElementById(this.id);\r\n if (!portal) return;\r\n document.body.removeChild(portal);\r\n this.host.remove();\r\n }\r\n\r\n private calculatePosition() {\r\n if (!this.anchor || !this.portal) return;\r\n const top = this.calculateTop();\r\n const left = this.calculateLeft();\r\n this.portal.style.top = `${top}px`;\r\n this.portal.style.left = `${left}px`;\r\n }\r\n\r\n render() {\r\n return (\r\n <Host style={{ display: this.anchor ? 'block' : 'none' }}>\r\n <slot />\r\n </Host>\r\n );\r\n }\r\n}\r\n"]}