kritzel-stencil 0.0.155 → 0.0.156

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 (412) hide show
  1. package/dist/stencil/default-text-tool.config-DKpRP4XR.js +1441 -0
  2. package/dist/stencil/default-text-tool.config-DKpRP4XR.js.map +1 -0
  3. package/dist/{components/p-l10It7Nm.js → stencil/devices.helper-l10It7Nm.js} +2 -2
  4. package/dist/stencil/devices.helper-l10It7Nm.js.map +1 -0
  5. package/dist/stencil/engine.constants-DsjjAmnl.js +7 -0
  6. package/dist/stencil/engine.constants-DsjjAmnl.js.map +1 -0
  7. package/dist/{components/p-D8W6LE-c.js → stencil/event-button.enum-D8W6LE-c.js} +2 -2
  8. package/dist/stencil/event-button.enum-D8W6LE-c.js.map +1 -0
  9. package/dist/{components/p-C6qB08BS.js → stencil/html.helper-C6qB08BS.js} +2 -2
  10. package/dist/{collection/helpers/html.helper.js.map → stencil/html.helper-C6qB08BS.js.map} +1 -1
  11. package/dist/{collection/classes/registries/icon-registry.class.js → stencil/icon-registry.class-BtT8riKh.js} +6 -2
  12. package/dist/stencil/icon-registry.class-BtT8riKh.js.map +1 -0
  13. package/dist/stencil/index-DniO_INI.js +4395 -0
  14. package/dist/stencil/index-DniO_INI.js.map +1 -0
  15. package/dist/stencil/index.esm.js +18 -2
  16. package/dist/stencil/index.esm.js.map +1 -1
  17. package/dist/{esm → stencil}/kritzel-brush-style.entry.js +3 -3
  18. package/dist/stencil/kritzel-color-palette.entry.esm.js.map +1 -0
  19. package/dist/{components/p-D1uj4A4F.js → stencil/kritzel-color-palette.entry.js} +9 -39
  20. package/dist/stencil/kritzel-color.entry.esm.js.map +1 -0
  21. package/dist/{components/p-D4yvhd1d.js → stencil/kritzel-color.entry.js} +8 -30
  22. package/dist/stencil/kritzel-context-menu-BYgOEy-i.js +66 -0
  23. package/dist/stencil/kritzel-context-menu-BYgOEy-i.js.map +1 -0
  24. package/dist/{components/p-C2sWlNsJ.js → stencil/kritzel-context-menu-GdU9xEKC.js} +12 -41
  25. package/dist/stencil/kritzel-context-menu-GdU9xEKC.js.map +1 -0
  26. package/dist/stencil/kritzel-context-menu.entry.esm.js.map +1 -0
  27. package/dist/stencil/kritzel-context-menu.entry.js +3 -0
  28. package/dist/stencil/kritzel-control-brush-config.entry.esm.js.map +1 -0
  29. package/dist/stencil/kritzel-control-brush-config.entry.js +54 -0
  30. package/dist/stencil/kritzel-control-text-config.entry.esm.js.map +1 -0
  31. package/dist/stencil/kritzel-control-text-config.entry.js +42 -0
  32. package/dist/stencil/kritzel-controls.entry.esm.js.map +1 -0
  33. package/dist/{components/p-1lIHoOlH.js → stencil/kritzel-controls.entry.js} +17 -115
  34. package/dist/stencil/kritzel-cursor-trail.entry.esm.js.map +1 -0
  35. package/dist/{components/p-CLt3HMl6.js → stencil/kritzel-cursor-trail.entry.js} +10 -33
  36. package/dist/stencil/kritzel-dropdown.entry.esm.js.map +1 -0
  37. package/dist/{components/p-CIXPLjCu.js → stencil/kritzel-dropdown.entry.js} +9 -39
  38. package/dist/stencil/kritzel-editor.entry.esm.js.map +1 -0
  39. package/dist/stencil/kritzel-editor.entry.js +248 -0
  40. package/dist/stencil/kritzel-engine.entry.esm.js.map +1 -0
  41. package/dist/{esm/kritzel-color_22.entry.js → stencil/kritzel-engine.entry.js} +265 -1835
  42. package/dist/stencil/kritzel-font-family.entry.esm.js.map +1 -0
  43. package/dist/{components/p-BgznZoBH.js → stencil/kritzel-font-family.entry.js} +9 -37
  44. package/dist/{components/p-DDmSxM5f.js.map → stencil/kritzel-font-size.entry.esm.js.map} +1 -1
  45. package/dist/stencil/kritzel-font-size.entry.js +28 -0
  46. package/dist/stencil/kritzel-font.entry.esm.js.map +1 -0
  47. package/dist/stencil/kritzel-font.entry.js +23 -0
  48. package/dist/stencil/kritzel-icon.entry.esm.js.map +1 -0
  49. package/dist/stencil/kritzel-icon.entry.js +29 -0
  50. package/dist/stencil/kritzel-menu-item.entry.esm.js.map +1 -0
  51. package/dist/{components/p-CsA9M6me.js → stencil/kritzel-menu-item.entry.js} +16 -174
  52. package/dist/stencil/kritzel-menu.entry.esm.js.map +1 -0
  53. package/dist/stencil/kritzel-menu.entry.js +72 -0
  54. package/dist/stencil/kritzel-portal.entry.esm.js.map +1 -0
  55. package/dist/{components/p-D5Wq4x4r.js → stencil/kritzel-portal.entry.js} +11 -37
  56. package/dist/stencil/kritzel-split-button.entry.esm.js.map +1 -0
  57. package/dist/{components/p-TdCTkEu0.js → stencil/kritzel-split-button.entry.js} +18 -72
  58. package/dist/stencil/kritzel-stroke-size.entry.esm.js.map +1 -0
  59. package/dist/stencil/kritzel-stroke-size.entry.js +27 -0
  60. package/dist/stencil/kritzel-tooltip.entry.esm.js.map +1 -0
  61. package/dist/{components/p-CTP479Lf.js → stencil/kritzel-tooltip.entry.js} +11 -39
  62. package/dist/stencil/kritzel-utility-panel.entry.esm.js.map +1 -0
  63. package/dist/{components/p-DAfkuR8U.js → stencil/kritzel-utility-panel.entry.js} +11 -38
  64. package/dist/stencil/kritzel-workspace-manager.entry.esm.js.map +1 -0
  65. package/dist/{components/p-CK6no3mi.js → stencil/kritzel-workspace-manager.entry.js} +13 -68
  66. package/dist/stencil/loader.esm.js.map +1 -1
  67. package/dist/{components/p-B0kd2rUI.js → stencil/object.helper-B0kd2rUI.js} +2 -2
  68. package/dist/stencil/object.helper-B0kd2rUI.js.map +1 -0
  69. package/dist/stencil/stencil.esm.js +48 -2
  70. package/dist/stencil/stencil.esm.js.map +1 -1
  71. package/dist/stencil/sync-config.interface-lKfyG1EN.js +19839 -0
  72. package/dist/stencil/sync-config.interface-lKfyG1EN.js.map +1 -0
  73. package/dist/{components/p-CBYBurdY.js → stencil/text-tool.class-C0GbC5zQ.js} +729 -25
  74. package/dist/stencil/text-tool.class-C0GbC5zQ.js.map +1 -0
  75. package/dist/{components/p-n789Y3S-.js → stencil/workspace.class-n789Y3S-.js} +2 -2
  76. package/dist/stencil/workspace.class-n789Y3S-.js.map +1 -0
  77. package/dist/types/classes/structures/object-map.structure.d.ts +9 -1
  78. package/dist/types/classes/structures/quadtree.structure.d.ts +18 -0
  79. package/dist/types/components/core/kritzel-engine/kritzel-engine.d.ts +1 -0
  80. package/dist/types/interfaces/bounding-box.interface.d.ts +1 -0
  81. package/package.json +1 -1
  82. package/dist/cjs/app-globals-V2Kpy_OQ.js +0 -8
  83. package/dist/cjs/app-globals-V2Kpy_OQ.js.map +0 -1
  84. package/dist/cjs/default-text-tool.config-BySzvIox.js +0 -31267
  85. package/dist/cjs/default-text-tool.config-BySzvIox.js.map +0 -1
  86. package/dist/cjs/index-Cj__YTlG.js +0 -1650
  87. package/dist/cjs/index-Cj__YTlG.js.map +0 -1
  88. package/dist/cjs/index.cjs.js +0 -1465
  89. package/dist/cjs/index.cjs.js.map +0 -1
  90. package/dist/cjs/kritzel-brush-style.cjs.entry.js +0 -32
  91. package/dist/cjs/kritzel-brush-style.entry.cjs.js.map +0 -1
  92. package/dist/cjs/kritzel-color_22.cjs.entry.js +0 -20811
  93. package/dist/cjs/loader.cjs.js +0 -14
  94. package/dist/cjs/loader.cjs.js.map +0 -1
  95. package/dist/cjs/stencil.cjs.js +0 -26
  96. package/dist/cjs/stencil.cjs.js.map +0 -1
  97. package/dist/collection/classes/core/core.class.js +0 -461
  98. package/dist/collection/classes/core/core.class.js.map +0 -1
  99. package/dist/collection/classes/core/reviver.class.js +0 -71
  100. package/dist/collection/classes/core/reviver.class.js.map +0 -1
  101. package/dist/collection/classes/core/store.class.js +0 -72
  102. package/dist/collection/classes/core/store.class.js.map +0 -1
  103. package/dist/collection/classes/core/viewport.class.js +0 -190
  104. package/dist/collection/classes/core/viewport.class.js.map +0 -1
  105. package/dist/collection/classes/core/workspace.class.js +0 -41
  106. package/dist/collection/classes/core/workspace.class.js.map +0 -1
  107. package/dist/collection/classes/handlers/base.handler.js +0 -8
  108. package/dist/collection/classes/handlers/base.handler.js.map +0 -1
  109. package/dist/collection/classes/handlers/context-menu.handler.js +0 -62
  110. package/dist/collection/classes/handlers/context-menu.handler.js.map +0 -1
  111. package/dist/collection/classes/handlers/hover.handler.js +0 -19
  112. package/dist/collection/classes/handlers/hover.handler.js.map +0 -1
  113. package/dist/collection/classes/handlers/key.handler.js +0 -58
  114. package/dist/collection/classes/handlers/key.handler.js.map +0 -1
  115. package/dist/collection/classes/handlers/move.handler.js +0 -149
  116. package/dist/collection/classes/handlers/move.handler.js.map +0 -1
  117. package/dist/collection/classes/handlers/resize.handler.js +0 -184
  118. package/dist/collection/classes/handlers/resize.handler.js.map +0 -1
  119. package/dist/collection/classes/handlers/rotation.handler.js +0 -116
  120. package/dist/collection/classes/handlers/rotation.handler.js.map +0 -1
  121. package/dist/collection/classes/handlers/selection.handler.js +0 -246
  122. package/dist/collection/classes/handlers/selection.handler.js.map +0 -1
  123. package/dist/collection/classes/objects/base-object.class.js +0 -232
  124. package/dist/collection/classes/objects/base-object.class.js.map +0 -1
  125. package/dist/collection/classes/objects/custom-element.class.js +0 -62
  126. package/dist/collection/classes/objects/custom-element.class.js.map +0 -1
  127. package/dist/collection/classes/objects/image.class.js +0 -56
  128. package/dist/collection/classes/objects/image.class.js.map +0 -1
  129. package/dist/collection/classes/objects/path.class.js +0 -284
  130. package/dist/collection/classes/objects/path.class.js.map +0 -1
  131. package/dist/collection/classes/objects/selection-box.class.js +0 -19
  132. package/dist/collection/classes/objects/selection-box.class.js.map +0 -1
  133. package/dist/collection/classes/objects/selection-group.class.js +0 -226
  134. package/dist/collection/classes/objects/selection-group.class.js.map +0 -1
  135. package/dist/collection/classes/objects/text.class.js +0 -261
  136. package/dist/collection/classes/objects/text.class.js.map +0 -1
  137. package/dist/collection/classes/providers/broadcast-sync-provider.class.js +0 -93
  138. package/dist/collection/classes/providers/broadcast-sync-provider.class.js.map +0 -1
  139. package/dist/collection/classes/providers/hocuspocus-sync-provider.class.js +0 -232
  140. package/dist/collection/classes/providers/hocuspocus-sync-provider.class.js.map +0 -1
  141. package/dist/collection/classes/providers/indexeddb-sync-provider.class.js +0 -35
  142. package/dist/collection/classes/providers/indexeddb-sync-provider.class.js.map +0 -1
  143. package/dist/collection/classes/providers/websocket-sync-provider.class.js +0 -89
  144. package/dist/collection/classes/providers/websocket-sync-provider.class.js.map +0 -1
  145. package/dist/collection/classes/registries/icon-registry.class.js.map +0 -1
  146. package/dist/collection/classes/registries/tool.registry.js +0 -18
  147. package/dist/collection/classes/registries/tool.registry.js.map +0 -1
  148. package/dist/collection/classes/structures/app-state-map.structure.js +0 -189
  149. package/dist/collection/classes/structures/app-state-map.structure.js.map +0 -1
  150. package/dist/collection/classes/structures/object-map.structure.js +0 -310
  151. package/dist/collection/classes/structures/object-map.structure.js.map +0 -1
  152. package/dist/collection/classes/tools/base-tool.class.js +0 -38
  153. package/dist/collection/classes/tools/base-tool.class.js.map +0 -1
  154. package/dist/collection/classes/tools/brush-tool.class.js +0 -133
  155. package/dist/collection/classes/tools/brush-tool.class.js.map +0 -1
  156. package/dist/collection/classes/tools/eraser-tool.class.js +0 -85
  157. package/dist/collection/classes/tools/eraser-tool.class.js.map +0 -1
  158. package/dist/collection/classes/tools/image-tool.class.js +0 -83
  159. package/dist/collection/classes/tools/image-tool.class.js.map +0 -1
  160. package/dist/collection/classes/tools/selection-tool.class.js +0 -164
  161. package/dist/collection/classes/tools/selection-tool.class.js.map +0 -1
  162. package/dist/collection/classes/tools/text-tool.class.js +0 -108
  163. package/dist/collection/classes/tools/text-tool.class.js.map +0 -1
  164. package/dist/collection/collection-manifest.json +0 -34
  165. package/dist/collection/components/core/kritzel-cursor-trail/kritzel-cursor-trail.css +0 -10
  166. package/dist/collection/components/core/kritzel-cursor-trail/kritzel-cursor-trail.js +0 -153
  167. package/dist/collection/components/core/kritzel-cursor-trail/kritzel-cursor-trail.js.map +0 -1
  168. package/dist/collection/components/core/kritzel-editor/kritzel-editor.css +0 -34
  169. package/dist/collection/components/core/kritzel-editor/kritzel-editor.js +0 -928
  170. package/dist/collection/components/core/kritzel-editor/kritzel-editor.js.map +0 -1
  171. package/dist/collection/components/core/kritzel-engine/kritzel-engine.css +0 -73
  172. package/dist/collection/components/core/kritzel-engine/kritzel-engine.js +0 -1606
  173. package/dist/collection/components/core/kritzel-engine/kritzel-engine.js.map +0 -1
  174. package/dist/collection/components/shared/kritzel-brush-style/kritzel-brush-style.css +0 -44
  175. package/dist/collection/components/shared/kritzel-brush-style/kritzel-brush-style.js +0 -98
  176. package/dist/collection/components/shared/kritzel-brush-style/kritzel-brush-style.js.map +0 -1
  177. package/dist/collection/components/shared/kritzel-color/kritzel-color.css +0 -21
  178. package/dist/collection/components/shared/kritzel-color/kritzel-color.js +0 -107
  179. package/dist/collection/components/shared/kritzel-color/kritzel-color.js.map +0 -1
  180. package/dist/collection/components/shared/kritzel-color-palette/kritzel-color-palette.css +0 -46
  181. package/dist/collection/components/shared/kritzel-color-palette/kritzel-color-palette.js +0 -145
  182. package/dist/collection/components/shared/kritzel-color-palette/kritzel-color-palette.js.map +0 -1
  183. package/dist/collection/components/shared/kritzel-dropdown/kritzel-dropdown.css +0 -53
  184. package/dist/collection/components/shared/kritzel-dropdown/kritzel-dropdown.js +0 -218
  185. package/dist/collection/components/shared/kritzel-dropdown/kritzel-dropdown.js.map +0 -1
  186. package/dist/collection/components/shared/kritzel-font/kritzel-font.css +0 -10
  187. package/dist/collection/components/shared/kritzel-font/kritzel-font.js +0 -90
  188. package/dist/collection/components/shared/kritzel-font/kritzel-font.js.map +0 -1
  189. package/dist/collection/components/shared/kritzel-font-family/kritzel-font-family.css +0 -48
  190. package/dist/collection/components/shared/kritzel-font-family/kritzel-font-family.js +0 -114
  191. package/dist/collection/components/shared/kritzel-font-family/kritzel-font-family.js.map +0 -1
  192. package/dist/collection/components/shared/kritzel-font-size/kritzel-font-size.css +0 -30
  193. package/dist/collection/components/shared/kritzel-font-size/kritzel-font-size.js +0 -110
  194. package/dist/collection/components/shared/kritzel-font-size/kritzel-font-size.js.map +0 -1
  195. package/dist/collection/components/shared/kritzel-icon/kritzel-icon.css +0 -18
  196. package/dist/collection/components/shared/kritzel-icon/kritzel-icon.js +0 -94
  197. package/dist/collection/components/shared/kritzel-icon/kritzel-icon.js.map +0 -1
  198. package/dist/collection/components/shared/kritzel-menu/kritzel-menu.css +0 -27
  199. package/dist/collection/components/shared/kritzel-menu/kritzel-menu.js +0 -291
  200. package/dist/collection/components/shared/kritzel-menu/kritzel-menu.js.map +0 -1
  201. package/dist/collection/components/shared/kritzel-menu-item/kritzel-menu-item.css +0 -145
  202. package/dist/collection/components/shared/kritzel-menu-item/kritzel-menu-item.js +0 -280
  203. package/dist/collection/components/shared/kritzel-menu-item/kritzel-menu-item.js.map +0 -1
  204. package/dist/collection/components/shared/kritzel-portal/kritzel-portal.js +0 -310
  205. package/dist/collection/components/shared/kritzel-portal/kritzel-portal.js.map +0 -1
  206. package/dist/collection/components/shared/kritzel-split-button/kritzel-split-button.css +0 -78
  207. package/dist/collection/components/shared/kritzel-split-button/kritzel-split-button.js +0 -406
  208. package/dist/collection/components/shared/kritzel-split-button/kritzel-split-button.js.map +0 -1
  209. package/dist/collection/components/shared/kritzel-stroke-size/kritzel-stroke-size.css +0 -28
  210. package/dist/collection/components/shared/kritzel-stroke-size/kritzel-stroke-size.js +0 -89
  211. package/dist/collection/components/shared/kritzel-stroke-size/kritzel-stroke-size.js.map +0 -1
  212. package/dist/collection/components/shared/kritzel-tooltip/kritzel-tooltip.css +0 -17
  213. package/dist/collection/components/shared/kritzel-tooltip/kritzel-tooltip.js +0 -251
  214. package/dist/collection/components/shared/kritzel-tooltip/kritzel-tooltip.js.map +0 -1
  215. package/dist/collection/components/ui/kritzel-context-menu/kritzel-context-menu.css +0 -55
  216. package/dist/collection/components/ui/kritzel-context-menu/kritzel-context-menu.js +0 -172
  217. package/dist/collection/components/ui/kritzel-context-menu/kritzel-context-menu.js.map +0 -1
  218. package/dist/collection/components/ui/kritzel-control-brush-config/kritzel-control-brush-config.css +0 -19
  219. package/dist/collection/components/ui/kritzel-control-brush-config/kritzel-control-brush-config.js +0 -135
  220. package/dist/collection/components/ui/kritzel-control-brush-config/kritzel-control-brush-config.js.map +0 -1
  221. package/dist/collection/components/ui/kritzel-control-text-config/kritzel-control-text-config.css +0 -19
  222. package/dist/collection/components/ui/kritzel-control-text-config/kritzel-control-text-config.js +0 -115
  223. package/dist/collection/components/ui/kritzel-control-text-config/kritzel-control-text-config.js.map +0 -1
  224. package/dist/collection/components/ui/kritzel-controls/kritzel-controls.css +0 -127
  225. package/dist/collection/components/ui/kritzel-controls/kritzel-controls.js +0 -312
  226. package/dist/collection/components/ui/kritzel-controls/kritzel-controls.js.map +0 -1
  227. package/dist/collection/components/ui/kritzel-utility-panel/kritzel-utility-panel.css +0 -44
  228. package/dist/collection/components/ui/kritzel-utility-panel/kritzel-utility-panel.js +0 -111
  229. package/dist/collection/components/ui/kritzel-utility-panel/kritzel-utility-panel.js.map +0 -1
  230. package/dist/collection/components/ui/kritzel-workspace-manager/kritzel-workspace-manager.css +0 -5
  231. package/dist/collection/components/ui/kritzel-workspace-manager/kritzel-workspace-manager.js +0 -255
  232. package/dist/collection/components/ui/kritzel-workspace-manager/kritzel-workspace-manager.js.map +0 -1
  233. package/dist/collection/configs/default-brush-tool.config.js +0 -60
  234. package/dist/collection/configs/default-brush-tool.config.js.map +0 -1
  235. package/dist/collection/configs/default-engine-config.js +0 -53
  236. package/dist/collection/configs/default-engine-config.js.map +0 -1
  237. package/dist/collection/configs/default-sync.config.js +0 -10
  238. package/dist/collection/configs/default-sync.config.js.map +0 -1
  239. package/dist/collection/configs/default-text-tool.config.js +0 -32
  240. package/dist/collection/configs/default-text-tool.config.js.map +0 -1
  241. package/dist/collection/constants/core.constants.js +0 -2
  242. package/dist/collection/constants/core.constants.js.map +0 -1
  243. package/dist/collection/constants/engine.constants.js +0 -3
  244. package/dist/collection/constants/engine.constants.js.map +0 -1
  245. package/dist/collection/enums/event-button.enum.js +0 -7
  246. package/dist/collection/enums/event-button.enum.js.map +0 -1
  247. package/dist/collection/enums/handle-type.enum.js +0 -8
  248. package/dist/collection/enums/handle-type.enum.js.map +0 -1
  249. package/dist/collection/helpers/class.helper.js +0 -6
  250. package/dist/collection/helpers/class.helper.js.map +0 -1
  251. package/dist/collection/helpers/devices.helper.js +0 -26
  252. package/dist/collection/helpers/devices.helper.js.map +0 -1
  253. package/dist/collection/helpers/event.helper.js +0 -51
  254. package/dist/collection/helpers/event.helper.js.map +0 -1
  255. package/dist/collection/helpers/geometry.helper.js +0 -53
  256. package/dist/collection/helpers/geometry.helper.js.map +0 -1
  257. package/dist/collection/helpers/html.helper.js +0 -64
  258. package/dist/collection/helpers/keyboard.helper.js +0 -49
  259. package/dist/collection/helpers/keyboard.helper.js.map +0 -1
  260. package/dist/collection/helpers/math.helper.js +0 -6
  261. package/dist/collection/helpers/math.helper.js.map +0 -1
  262. package/dist/collection/helpers/object.helper.js +0 -12
  263. package/dist/collection/helpers/object.helper.js.map +0 -1
  264. package/dist/collection/index.js +0 -30
  265. package/dist/collection/index.js.map +0 -1
  266. package/dist/collection/interfaces/bounding-box.interface.js +0 -2
  267. package/dist/collection/interfaces/bounding-box.interface.js.map +0 -1
  268. package/dist/collection/interfaces/clonable.interface.js +0 -2
  269. package/dist/collection/interfaces/clonable.interface.js.map +0 -1
  270. package/dist/collection/interfaces/context-menu-item.interface.js +0 -2
  271. package/dist/collection/interfaces/context-menu-item.interface.js.map +0 -1
  272. package/dist/collection/interfaces/debug-info.interface.js +0 -2
  273. package/dist/collection/interfaces/debug-info.interface.js.map +0 -1
  274. package/dist/collection/interfaces/engine-state.interface.js +0 -2
  275. package/dist/collection/interfaces/engine-state.interface.js.map +0 -1
  276. package/dist/collection/interfaces/menu-item.interface.js +0 -2
  277. package/dist/collection/interfaces/menu-item.interface.js.map +0 -1
  278. package/dist/collection/interfaces/object.interface.js +0 -2
  279. package/dist/collection/interfaces/object.interface.js.map +0 -1
  280. package/dist/collection/interfaces/path-options.interface.js +0 -2
  281. package/dist/collection/interfaces/path-options.interface.js.map +0 -1
  282. package/dist/collection/interfaces/point.interface.js +0 -2
  283. package/dist/collection/interfaces/point.interface.js.map +0 -1
  284. package/dist/collection/interfaces/polygon.interface.js +0 -2
  285. package/dist/collection/interfaces/polygon.interface.js.map +0 -1
  286. package/dist/collection/interfaces/selection-state.interface.js +0 -2
  287. package/dist/collection/interfaces/selection-state.interface.js.map +0 -1
  288. package/dist/collection/interfaces/serializable.interface.js +0 -2
  289. package/dist/collection/interfaces/serializable.interface.js.map +0 -1
  290. package/dist/collection/interfaces/shortcut.interface.js +0 -2
  291. package/dist/collection/interfaces/shortcut.interface.js.map +0 -1
  292. package/dist/collection/interfaces/sync-config.interface.js +0 -2
  293. package/dist/collection/interfaces/sync-config.interface.js.map +0 -1
  294. package/dist/collection/interfaces/sync-provider.interface.js +0 -2
  295. package/dist/collection/interfaces/sync-provider.interface.js.map +0 -1
  296. package/dist/collection/interfaces/tool.interface.js +0 -2
  297. package/dist/collection/interfaces/tool.interface.js.map +0 -1
  298. package/dist/collection/interfaces/toolbar-control.interface.js +0 -2
  299. package/dist/collection/interfaces/toolbar-control.interface.js.map +0 -1
  300. package/dist/collection/interfaces/undo-state.interface.js +0 -2
  301. package/dist/collection/interfaces/undo-state.interface.js.map +0 -1
  302. package/dist/collection/types/deep-readonly.type.js +0 -2
  303. package/dist/collection/types/deep-readonly.type.js.map +0 -1
  304. package/dist/collection/types/state.types.js +0 -2
  305. package/dist/collection/types/state.types.js.map +0 -1
  306. package/dist/components/index.js +0 -1477
  307. package/dist/components/index.js.map +0 -1
  308. package/dist/components/kritzel-brush-style.js +0 -67
  309. package/dist/components/kritzel-brush-style.js.map +0 -1
  310. package/dist/components/kritzel-color-palette.js +0 -9
  311. package/dist/components/kritzel-color-palette.js.map +0 -1
  312. package/dist/components/kritzel-color.js +0 -9
  313. package/dist/components/kritzel-color.js.map +0 -1
  314. package/dist/components/kritzel-context-menu.js +0 -9
  315. package/dist/components/kritzel-context-menu.js.map +0 -1
  316. package/dist/components/kritzel-control-brush-config.js +0 -9
  317. package/dist/components/kritzel-control-brush-config.js.map +0 -1
  318. package/dist/components/kritzel-control-text-config.js +0 -9
  319. package/dist/components/kritzel-control-text-config.js.map +0 -1
  320. package/dist/components/kritzel-controls.js +0 -9
  321. package/dist/components/kritzel-controls.js.map +0 -1
  322. package/dist/components/kritzel-cursor-trail.js +0 -9
  323. package/dist/components/kritzel-cursor-trail.js.map +0 -1
  324. package/dist/components/kritzel-dropdown.js +0 -9
  325. package/dist/components/kritzel-dropdown.js.map +0 -1
  326. package/dist/components/kritzel-editor.js +0 -516
  327. package/dist/components/kritzel-editor.js.map +0 -1
  328. package/dist/components/kritzel-engine.js +0 -9
  329. package/dist/components/kritzel-engine.js.map +0 -1
  330. package/dist/components/kritzel-font-family.js +0 -9
  331. package/dist/components/kritzel-font-family.js.map +0 -1
  332. package/dist/components/kritzel-font-size.js +0 -9
  333. package/dist/components/kritzel-font-size.js.map +0 -1
  334. package/dist/components/kritzel-font.js +0 -9
  335. package/dist/components/kritzel-font.js.map +0 -1
  336. package/dist/components/kritzel-icon.js +0 -9
  337. package/dist/components/kritzel-icon.js.map +0 -1
  338. package/dist/components/kritzel-menu-item.js +0 -9
  339. package/dist/components/kritzel-menu-item.js.map +0 -1
  340. package/dist/components/kritzel-menu.js +0 -9
  341. package/dist/components/kritzel-menu.js.map +0 -1
  342. package/dist/components/kritzel-portal.js +0 -9
  343. package/dist/components/kritzel-portal.js.map +0 -1
  344. package/dist/components/kritzel-split-button.js +0 -9
  345. package/dist/components/kritzel-split-button.js.map +0 -1
  346. package/dist/components/kritzel-stroke-size.js +0 -9
  347. package/dist/components/kritzel-stroke-size.js.map +0 -1
  348. package/dist/components/kritzel-tooltip.js +0 -9
  349. package/dist/components/kritzel-tooltip.js.map +0 -1
  350. package/dist/components/kritzel-utility-panel.js +0 -9
  351. package/dist/components/kritzel-utility-panel.js.map +0 -1
  352. package/dist/components/kritzel-workspace-manager.js +0 -9
  353. package/dist/components/kritzel-workspace-manager.js.map +0 -1
  354. package/dist/components/p-1lIHoOlH.js.map +0 -1
  355. package/dist/components/p-B0kd2rUI.js.map +0 -1
  356. package/dist/components/p-B4kxkVe-.js +0 -55
  357. package/dist/components/p-B4kxkVe-.js.map +0 -1
  358. package/dist/components/p-BQg4YML7.js +0 -106
  359. package/dist/components/p-BQg4YML7.js.map +0 -1
  360. package/dist/components/p-BgznZoBH.js.map +0 -1
  361. package/dist/components/p-Bhtn9qay.js +0 -98
  362. package/dist/components/p-Bhtn9qay.js.map +0 -1
  363. package/dist/components/p-C2sWlNsJ.js.map +0 -1
  364. package/dist/components/p-C6qB08BS.js.map +0 -1
  365. package/dist/components/p-CBYBurdY.js.map +0 -1
  366. package/dist/components/p-CIXPLjCu.js.map +0 -1
  367. package/dist/components/p-CK6no3mi.js.map +0 -1
  368. package/dist/components/p-CLt3HMl6.js.map +0 -1
  369. package/dist/components/p-CTP479Lf.js.map +0 -1
  370. package/dist/components/p-CsA9M6me.js.map +0 -1
  371. package/dist/components/p-CwkUrTy1.js +0 -1367
  372. package/dist/components/p-CwkUrTy1.js.map +0 -1
  373. package/dist/components/p-D1uj4A4F.js.map +0 -1
  374. package/dist/components/p-D4yvhd1d.js.map +0 -1
  375. package/dist/components/p-D5Wq4x4r.js.map +0 -1
  376. package/dist/components/p-D8W6LE-c.js.map +0 -1
  377. package/dist/components/p-DAfkuR8U.js.map +0 -1
  378. package/dist/components/p-DDmSxM5f.js +0 -57
  379. package/dist/components/p-Ddh40W3x.js +0 -103
  380. package/dist/components/p-Ddh40W3x.js.map +0 -1
  381. package/dist/components/p-TdCTkEu0.js.map +0 -1
  382. package/dist/components/p-l10It7Nm.js.map +0 -1
  383. package/dist/components/p-n789Y3S-.js.map +0 -1
  384. package/dist/components/p-q5u4CVFi.js +0 -35447
  385. package/dist/components/p-q5u4CVFi.js.map +0 -1
  386. package/dist/components/p-uuRJU2R1.js +0 -46
  387. package/dist/components/p-uuRJU2R1.js.map +0 -1
  388. package/dist/esm/app-globals-DQuL1Twl.js +0 -6
  389. package/dist/esm/app-globals-DQuL1Twl.js.map +0 -1
  390. package/dist/esm/default-text-tool.config-2YFQA3SF.js +0 -31208
  391. package/dist/esm/default-text-tool.config-2YFQA3SF.js.map +0 -1
  392. package/dist/esm/index-SGde3HXB.js +0 -1623
  393. package/dist/esm/index-SGde3HXB.js.map +0 -1
  394. package/dist/esm/index.js +0 -1449
  395. package/dist/esm/index.js.map +0 -1
  396. package/dist/esm/kritzel-brush-style.entry.js.map +0 -1
  397. package/dist/esm/loader.js +0 -12
  398. package/dist/esm/loader.js.map +0 -1
  399. package/dist/esm/stencil.js +0 -22
  400. package/dist/esm/stencil.js.map +0 -1
  401. package/dist/index.cjs.js +0 -1
  402. package/dist/index.js +0 -1
  403. package/dist/stencil/p-2YFQA3SF.js +0 -2
  404. package/dist/stencil/p-2YFQA3SF.js.map +0 -1
  405. package/dist/stencil/p-77fa3987.entry.js +0 -10
  406. package/dist/stencil/p-77fa3987.entry.js.map +0 -1
  407. package/dist/stencil/p-DQuL1Twl.js +0 -2
  408. package/dist/stencil/p-DQuL1Twl.js.map +0 -1
  409. package/dist/stencil/p-SGde3HXB.js +0 -3
  410. package/dist/stencil/p-SGde3HXB.js.map +0 -1
  411. package/dist/stencil/p-d702c5af.entry.js +0 -2
  412. package/dist/stencil/p-d702c5af.entry.js.map +0 -1
@@ -1,310 +0,0 @@
1
- import { Host, h } from "@stencil/core";
2
- import { ObjectHelper } from "../../../helpers/object.helper";
3
- import { KritzelHTMLHelper } from "../../../helpers/html.helper";
4
- export class KritzelPortal {
5
- host;
6
- anchor;
7
- anchorChanged(newValue) {
8
- if (newValue) {
9
- this.openPortal();
10
- this.calculatePosition();
11
- if (this.autoFocus) {
12
- this.focusFirstElement();
13
- }
14
- }
15
- else {
16
- this.closePortal();
17
- }
18
- }
19
- offsetX;
20
- offsetY;
21
- autoFocus = true;
22
- close;
23
- handleOutsideClick(event) {
24
- event.stopPropagation();
25
- const isLastPortal = this.lastAddedPortal === this.portal;
26
- if (!isLastPortal)
27
- return;
28
- const target = event.target;
29
- if (!this.host.contains(target)) {
30
- this.close.emit();
31
- this.closePortal();
32
- }
33
- }
34
- handleKeyDown(event) {
35
- event.stopPropagation();
36
- const isLastPortal = this.lastAddedPortal === this.portal;
37
- if (!isLastPortal)
38
- return;
39
- if (event.key === 'Escape') {
40
- this.anchor.focus();
41
- this.close.emit();
42
- this.closePortal();
43
- }
44
- if (event.key === 'Tab') {
45
- this.trapFocus(event);
46
- }
47
- if (event.key === 'Enter') {
48
- const activeElement = this.getDeepActiveElement();
49
- if (activeElement?.click) {
50
- event.preventDefault();
51
- activeElement.click();
52
- }
53
- }
54
- }
55
- handleResize() {
56
- this.calculatePosition();
57
- }
58
- handleWindowScroll() {
59
- const isInViewport = KritzelHTMLHelper.isElementInViewport(this.anchor);
60
- if (!isInViewport) {
61
- this.anchor?.blur();
62
- this.closePortal();
63
- return;
64
- }
65
- this.calculatePosition();
66
- }
67
- portal;
68
- id = `portal-${ObjectHelper.generateUUID()}`;
69
- defaultOffset = 0;
70
- minLeft = 0;
71
- focusFirstElement() {
72
- requestAnimationFrame(() => {
73
- this.firstFocusableElement?.focus?.();
74
- });
75
- }
76
- getDeepActiveElement() {
77
- let activeEl = document.activeElement;
78
- while (activeEl?.shadowRoot?.activeElement) {
79
- activeEl = activeEl.shadowRoot.activeElement;
80
- }
81
- return activeEl;
82
- }
83
- trapFocus(event) {
84
- const focusableElements = KritzelHTMLHelper.getFocusableElements(this.host);
85
- if (focusableElements.length === 0)
86
- return;
87
- const firstFocusable = focusableElements[0];
88
- const lastFocusable = focusableElements[focusableElements.length - 1];
89
- const activeElement = this.getDeepActiveElement();
90
- if (event.shiftKey) {
91
- /* shift + tab */
92
- if (activeElement === firstFocusable) {
93
- lastFocusable.focus();
94
- event.preventDefault();
95
- }
96
- }
97
- else {
98
- /* tab */
99
- if (activeElement === lastFocusable) {
100
- firstFocusable.focus();
101
- event.preventDefault();
102
- }
103
- }
104
- }
105
- get firstFocusableElement() {
106
- const slotEl = this.host.shadowRoot?.querySelector('slot');
107
- const firstAssigned = slotEl?.assignedElements({ flatten: true })[0];
108
- if (!firstAssigned)
109
- return null;
110
- const focusable = KritzelHTMLHelper.getFocusableElements(firstAssigned);
111
- return focusable[0] ?? firstAssigned;
112
- }
113
- get lastAddedPortal() {
114
- const portals = Array.from(document.querySelectorAll('[id^="portal-"]'));
115
- return portals.length ? portals[portals.length - 1] : null;
116
- }
117
- calculateLeft() {
118
- if (!this.anchor || !this.portal)
119
- return 0;
120
- const refRect = this.anchor.getBoundingClientRect();
121
- const portalRect = this.portal.getBoundingClientRect();
122
- const offset = this.offsetX ?? this.defaultOffset;
123
- let left = refRect.left + offset;
124
- const maxLeft = window.innerWidth - portalRect.width - this.minLeft;
125
- if (left < this.minLeft)
126
- left = this.minLeft;
127
- if (left > maxLeft)
128
- left = maxLeft;
129
- return Math.round(left + window.scrollX);
130
- }
131
- calculateTop() {
132
- if (!this.anchor || !this.portal)
133
- return 0;
134
- const refRect = this.anchor.getBoundingClientRect();
135
- const portalRect = this.portal.getBoundingClientRect();
136
- const offset = this.offsetY ?? this.defaultOffset;
137
- let top = refRect.bottom + offset;
138
- if (top + portalRect.height > window.innerHeight) {
139
- top = refRect.top - portalRect.height - offset;
140
- }
141
- return Math.round(top + window.scrollY);
142
- }
143
- openPortal() {
144
- this.portal = document.createElement('div');
145
- this.portal.setAttribute('id', this.id);
146
- this.portal.style.zIndex = '1';
147
- this.portal.style.position = 'absolute';
148
- this.portal.style.top = '0px';
149
- this.portal.style.left = '0px';
150
- this.portal.appendChild(this.host);
151
- document.body.append(this.portal);
152
- }
153
- closePortal() {
154
- const portal = document.getElementById(this.id);
155
- if (!portal)
156
- return;
157
- document.body.removeChild(portal);
158
- this.host.remove();
159
- }
160
- calculatePosition() {
161
- if (!this.anchor || !this.portal)
162
- return;
163
- const top = this.calculateTop();
164
- const left = this.calculateLeft();
165
- this.portal.style.top = `${top}px`;
166
- this.portal.style.left = `${left}px`;
167
- }
168
- render() {
169
- return (h(Host, { key: '9c5cdf7126ff1148dd2364cce9d2524862e27d13', style: { display: this.anchor ? 'block' : 'none' } }, h("slot", { key: '209a77246fedcea0c24882605487452ff5cc62ce' })));
170
- }
171
- static get is() { return "kritzel-portal"; }
172
- static get encapsulation() { return "shadow"; }
173
- static get properties() {
174
- return {
175
- "anchor": {
176
- "type": "unknown",
177
- "mutable": false,
178
- "complexType": {
179
- "original": "HTMLElement",
180
- "resolved": "HTMLElement",
181
- "references": {
182
- "HTMLElement": {
183
- "location": "global",
184
- "id": "global::HTMLElement"
185
- }
186
- }
187
- },
188
- "required": false,
189
- "optional": false,
190
- "docs": {
191
- "tags": [],
192
- "text": ""
193
- },
194
- "getter": false,
195
- "setter": false
196
- },
197
- "offsetX": {
198
- "type": "number",
199
- "mutable": false,
200
- "complexType": {
201
- "original": "number",
202
- "resolved": "number",
203
- "references": {}
204
- },
205
- "required": false,
206
- "optional": false,
207
- "docs": {
208
- "tags": [],
209
- "text": ""
210
- },
211
- "getter": false,
212
- "setter": false,
213
- "reflect": false,
214
- "attribute": "offset-x"
215
- },
216
- "offsetY": {
217
- "type": "number",
218
- "mutable": false,
219
- "complexType": {
220
- "original": "number",
221
- "resolved": "number",
222
- "references": {}
223
- },
224
- "required": false,
225
- "optional": false,
226
- "docs": {
227
- "tags": [],
228
- "text": ""
229
- },
230
- "getter": false,
231
- "setter": false,
232
- "reflect": false,
233
- "attribute": "offset-y"
234
- },
235
- "autoFocus": {
236
- "type": "boolean",
237
- "mutable": false,
238
- "complexType": {
239
- "original": "boolean",
240
- "resolved": "boolean",
241
- "references": {}
242
- },
243
- "required": false,
244
- "optional": false,
245
- "docs": {
246
- "tags": [],
247
- "text": ""
248
- },
249
- "getter": false,
250
- "setter": false,
251
- "reflect": false,
252
- "attribute": "auto-focus",
253
- "defaultValue": "true"
254
- }
255
- };
256
- }
257
- static get events() {
258
- return [{
259
- "method": "close",
260
- "name": "close",
261
- "bubbles": true,
262
- "cancelable": true,
263
- "composed": true,
264
- "docs": {
265
- "tags": [],
266
- "text": ""
267
- },
268
- "complexType": {
269
- "original": "void",
270
- "resolved": "void",
271
- "references": {}
272
- }
273
- }];
274
- }
275
- static get elementRef() { return "host"; }
276
- static get watchers() {
277
- return [{
278
- "propName": "anchor",
279
- "methodName": "anchorChanged"
280
- }];
281
- }
282
- static get listeners() {
283
- return [{
284
- "name": "click",
285
- "method": "handleOutsideClick",
286
- "target": "window",
287
- "capture": false,
288
- "passive": false
289
- }, {
290
- "name": "keydown",
291
- "method": "handleKeyDown",
292
- "target": "window",
293
- "capture": false,
294
- "passive": false
295
- }, {
296
- "name": "resize",
297
- "method": "handleResize",
298
- "target": "window",
299
- "capture": true,
300
- "passive": true
301
- }, {
302
- "name": "scroll",
303
- "method": "handleWindowScroll",
304
- "target": "window",
305
- "capture": true,
306
- "passive": true
307
- }];
308
- }
309
- }
310
- //# sourceMappingURL=kritzel-portal.js.map
@@ -1 +0,0 @@
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\nimport { KritzelHTMLHelper } from '../../../helpers/html.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 @Listen('scroll', { target: 'window', capture: true })\r\n handleWindowScroll() {\r\n const isInViewport = KritzelHTMLHelper.isElementInViewport(this.anchor);\r\n\r\n if (!isInViewport) {\r\n this.anchor?.blur();\r\n this.closePortal();\r\n return;\r\n }\r\n\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 = KritzelHTMLHelper.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 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 = KritzelHTMLHelper.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"]}
@@ -1,78 +0,0 @@
1
- :host {
2
- position: relative;
3
- display: flex;
4
- align-items: center;
5
- font-family: sans-serif;
6
- z-index: 1;
7
- padding: var(--kritzel-split-button-padding, 4px);
8
- background-color: var(--kritzel-split-button-background-color, #ffffff);
9
- border-radius: var(--kritzel-split-button-border-radius, 12px);
10
- box-shadow: var(--kritzel-split-button-box-shadow, 0 0 3px rgba(0, 0, 0, 0.08));
11
- border: var(--kritzel-split-button-border, 1px solid #ebebeb);
12
- gap: var(--kritzel-split-button-gap, 4px);
13
- }
14
-
15
- :host(.mobile){
16
- --kritzel-split-button-hover-background-color: transparent;
17
- }
18
-
19
- button {
20
- border: none;
21
- background-color: transparent;
22
- padding: 0;
23
- margin: 0;
24
- font-family: inherit;
25
- font-size: inherit;
26
- color: inherit;
27
- -webkit-appearance: none;
28
- -moz-appearance: none;
29
- appearance: none;
30
- cursor: pointer;
31
- text-align: center;
32
- display: flex;
33
- align-items: center;
34
- justify-content: center;
35
- pointer-events: all;
36
- -webkit-tap-highlight-color: transparent;
37
- }
38
-
39
- .split-main-button,
40
- .split-menu-button {
41
- height: auto;
42
- display: flex;
43
- align-items: center;
44
- padding: var(--kritzel-split-button-padding, 8px);
45
- background-color: var(--kritzel-split-button-background-color, #ffffff);
46
- border-radius: var(--kritzel-split-button-border-radius, 12px);
47
- font-size: var(--kritzel-split-button-font-size, 14px);
48
- }
49
-
50
- .split-main-button:hover,
51
- .split-menu-button:hover {
52
- background-color: var(--kritzel-split-button-hover-background-color, hsl(0, 0%, 0%, 4.3%));
53
- }
54
-
55
- .split-main-button:focus,
56
- .split-menu-button:focus {
57
- background-color: var(--kritzel-split-button-hover-background-color, hsl(0, 0%, 0%, 4.3%));
58
- }
59
-
60
- .split-main-button {
61
- gap: var(--kritzel-split-button-gap, 4px);
62
- }
63
-
64
- .split-menu-button {
65
- border-left: none;
66
- justify-content: center;
67
- }
68
-
69
- .split-divider {
70
- width: var(--kritzel-split-button-divider-width, 1px);
71
- height: 24px;
72
- background-color: var(--kritzel-split-button-divider-background-color, hsl(0, 0%, 0%, 4.3%));
73
- }
74
-
75
- :disabled {
76
- pointer-events: none;
77
- opacity: 0.5;
78
- }