kritzel-stencil 0.0.126 → 0.0.127

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 (378) hide show
  1. package/dist/cjs/app-globals-V2Kpy_OQ.js +8 -0
  2. package/dist/cjs/app-globals-V2Kpy_OQ.js.map +1 -0
  3. package/dist/cjs/index-BacMQbNR.js +2555 -0
  4. package/dist/cjs/index-BacMQbNR.js.map +1 -0
  5. package/dist/cjs/index-C05uAr89.js +1591 -0
  6. package/dist/cjs/index-C05uAr89.js.map +1 -0
  7. package/dist/cjs/index.cjs.js +19 -0
  8. package/dist/cjs/index.cjs.js.map +1 -0
  9. package/dist/cjs/kritzel-brush-style_18.cjs.entry.js +2365 -0
  10. package/dist/cjs/kritzel-brush-style_18.cjs.entry.js.map +1 -0
  11. package/dist/cjs/loader.cjs.js +16 -0
  12. package/dist/cjs/loader.cjs.js.map +1 -0
  13. package/dist/cjs/stencil.cjs.js +28 -0
  14. package/dist/cjs/stencil.cjs.js.map +1 -0
  15. package/dist/collection/classes/commands/add-object.command.js +14 -0
  16. package/dist/collection/classes/commands/add-object.command.js.map +1 -0
  17. package/dist/collection/classes/commands/add-selection-group.command.js +20 -0
  18. package/dist/collection/classes/commands/add-selection-group.command.js.map +1 -0
  19. package/dist/collection/classes/commands/base.command.js +15 -0
  20. package/dist/collection/classes/commands/base.command.js.map +1 -0
  21. package/dist/collection/classes/commands/batch.command.js +14 -0
  22. package/dist/collection/classes/commands/batch.command.js.map +1 -0
  23. package/dist/collection/classes/commands/move-selection-group.command.js +25 -0
  24. package/dist/collection/classes/commands/move-selection-group.command.js.map +1 -0
  25. package/dist/collection/classes/commands/remove-object.command.js +17 -0
  26. package/dist/collection/classes/commands/remove-object.command.js.map +1 -0
  27. package/dist/collection/classes/commands/remove-selection-group.command.js +18 -0
  28. package/dist/collection/classes/commands/remove-selection-group.command.js.map +1 -0
  29. package/dist/collection/classes/commands/resize-selection-group.command.js +18 -0
  30. package/dist/collection/classes/commands/resize-selection-group.command.js.map +1 -0
  31. package/dist/collection/classes/commands/rotate-selection-group.command.js +24 -0
  32. package/dist/collection/classes/commands/rotate-selection-group.command.js.map +1 -0
  33. package/dist/collection/classes/commands/update-object.command.js +29 -0
  34. package/dist/collection/classes/commands/update-object.command.js.map +1 -0
  35. package/dist/collection/classes/commands/update-viewport.command.js +23 -0
  36. package/dist/collection/classes/commands/update-viewport.command.js.map +1 -0
  37. package/dist/collection/classes/handlers/base.handler.js +7 -0
  38. package/dist/collection/classes/handlers/base.handler.js.map +1 -0
  39. package/dist/collection/classes/handlers/context-menu.handler.js +47 -0
  40. package/dist/collection/classes/handlers/context-menu.handler.js.map +1 -0
  41. package/dist/collection/classes/handlers/hover.handler.js +19 -0
  42. package/dist/collection/classes/handlers/hover.handler.js.map +1 -0
  43. package/dist/collection/classes/handlers/key.handler.js +81 -0
  44. package/dist/collection/classes/handlers/key.handler.js.map +1 -0
  45. package/dist/collection/classes/handlers/move.handler.js +84 -0
  46. package/dist/collection/classes/handlers/move.handler.js.map +1 -0
  47. package/dist/collection/classes/handlers/resize.handler.js +150 -0
  48. package/dist/collection/classes/handlers/resize.handler.js.map +1 -0
  49. package/dist/collection/classes/handlers/rotation.handler.js +102 -0
  50. package/dist/collection/classes/handlers/rotation.handler.js.map +1 -0
  51. package/dist/collection/classes/handlers/selection.handler.js +200 -0
  52. package/dist/collection/classes/handlers/selection.handler.js.map +1 -0
  53. package/dist/collection/classes/history.class.js +71 -0
  54. package/dist/collection/classes/history.class.js.map +1 -0
  55. package/dist/collection/classes/objects/base-object.class.js +204 -0
  56. package/dist/collection/classes/objects/base-object.class.js.map +1 -0
  57. package/dist/collection/classes/objects/custom-element.class.js +52 -0
  58. package/dist/collection/classes/objects/custom-element.class.js.map +1 -0
  59. package/dist/collection/classes/objects/image.class.js +53 -0
  60. package/dist/collection/classes/objects/image.class.js.map +1 -0
  61. package/dist/collection/classes/objects/path.class.js +268 -0
  62. package/dist/collection/classes/objects/path.class.js.map +1 -0
  63. package/dist/collection/classes/objects/selection-box.class.js +22 -0
  64. package/dist/collection/classes/objects/selection-box.class.js.map +1 -0
  65. package/dist/collection/classes/objects/selection-group.class.js +157 -0
  66. package/dist/collection/classes/objects/selection-group.class.js.map +1 -0
  67. package/dist/collection/classes/objects/text.class.js +141 -0
  68. package/dist/collection/classes/objects/text.class.js.map +1 -0
  69. package/dist/{stencil/icon-registry.class-Bw5YkOTi.js → collection/classes/registries/icon-registry.class.js} +2 -6
  70. package/dist/collection/classes/registries/icon-registry.class.js.map +1 -0
  71. package/dist/collection/classes/registries/tool.registry.js +18 -0
  72. package/dist/collection/classes/registries/tool.registry.js.map +1 -0
  73. package/dist/collection/classes/reviver.class.js +66 -0
  74. package/dist/collection/classes/reviver.class.js.map +1 -0
  75. package/dist/collection/classes/store.class.js +287 -0
  76. package/dist/collection/classes/store.class.js.map +1 -0
  77. package/dist/collection/classes/structures/circular-buffer.structure.js +46 -0
  78. package/dist/collection/classes/structures/circular-buffer.structure.js.map +1 -0
  79. package/dist/collection/classes/structures/octree.structure.js +111 -0
  80. package/dist/collection/classes/structures/octree.structure.js.map +1 -0
  81. package/dist/collection/classes/tools/base-tool.class.js +31 -0
  82. package/dist/collection/classes/tools/base-tool.class.js.map +1 -0
  83. package/dist/collection/classes/tools/brush-tool.class.js +116 -0
  84. package/dist/collection/classes/tools/brush-tool.class.js.map +1 -0
  85. package/dist/collection/classes/tools/eraser-tool.class.js +86 -0
  86. package/dist/collection/classes/tools/eraser-tool.class.js.map +1 -0
  87. package/dist/collection/classes/tools/image-tool.class.js +88 -0
  88. package/dist/collection/classes/tools/image-tool.class.js.map +1 -0
  89. package/dist/collection/classes/tools/selection-tool.class.js +156 -0
  90. package/dist/collection/classes/tools/selection-tool.class.js.map +1 -0
  91. package/dist/collection/classes/tools/text-tool.class.js +116 -0
  92. package/dist/collection/classes/tools/text-tool.class.js.map +1 -0
  93. package/dist/collection/classes/viewport.class.js +148 -0
  94. package/dist/collection/classes/viewport.class.js.map +1 -0
  95. package/dist/collection/collection-manifest.json +29 -0
  96. package/dist/collection/components/core/kritzel-cursor-trail/kritzel-cursor-trail.css +10 -0
  97. package/dist/collection/components/core/kritzel-cursor-trail/kritzel-cursor-trail.js +154 -0
  98. package/dist/collection/components/core/kritzel-cursor-trail/kritzel-cursor-trail.js.map +1 -0
  99. package/dist/collection/components/core/kritzel-editor/kritzel-editor.css +24 -0
  100. package/dist/collection/components/core/kritzel-editor/kritzel-editor.js +672 -0
  101. package/dist/collection/components/core/kritzel-editor/kritzel-editor.js.map +1 -0
  102. package/dist/collection/components/core/kritzel-engine/kritzel-engine.css +60 -0
  103. package/dist/collection/components/core/kritzel-engine/kritzel-engine.js +1287 -0
  104. package/dist/collection/components/core/kritzel-engine/kritzel-engine.js.map +1 -0
  105. package/dist/collection/components/shared/kritzel-brush-style/kritzel-brush-style.css +44 -0
  106. package/dist/collection/components/shared/kritzel-brush-style/kritzel-brush-style.js +100 -0
  107. package/dist/collection/components/shared/kritzel-brush-style/kritzel-brush-style.js.map +1 -0
  108. package/dist/collection/components/shared/kritzel-color/kritzel-color.css +21 -0
  109. package/dist/collection/components/shared/kritzel-color/kritzel-color.js +108 -0
  110. package/dist/collection/components/shared/kritzel-color/kritzel-color.js.map +1 -0
  111. package/dist/collection/components/shared/kritzel-color-palette/kritzel-color-palette.css +46 -0
  112. package/dist/collection/components/shared/kritzel-color-palette/kritzel-color-palette.js +147 -0
  113. package/dist/collection/components/shared/kritzel-color-palette/kritzel-color-palette.js.map +1 -0
  114. package/dist/collection/components/shared/kritzel-dropdown/kritzel-dropdown.css +53 -0
  115. package/dist/collection/components/shared/kritzel-dropdown/kritzel-dropdown.js +215 -0
  116. package/dist/collection/components/shared/kritzel-dropdown/kritzel-dropdown.js.map +1 -0
  117. package/dist/collection/components/shared/kritzel-font/kritzel-font.css +10 -0
  118. package/dist/collection/components/shared/kritzel-font/kritzel-font.js +92 -0
  119. package/dist/collection/components/shared/kritzel-font/kritzel-font.js.map +1 -0
  120. package/dist/collection/components/shared/kritzel-font-family/kritzel-font-family.css +48 -0
  121. package/dist/collection/components/shared/kritzel-font-family/kritzel-font-family.js +115 -0
  122. package/dist/collection/components/shared/kritzel-font-family/kritzel-font-family.js.map +1 -0
  123. package/dist/collection/components/shared/kritzel-font-size/kritzel-font-size.css +30 -0
  124. package/dist/collection/components/shared/kritzel-font-size/kritzel-font-size.js +112 -0
  125. package/dist/collection/components/shared/kritzel-font-size/kritzel-font-size.js.map +1 -0
  126. package/dist/collection/components/shared/kritzel-icon/kritzel-icon.css +17 -0
  127. package/dist/collection/components/shared/kritzel-icon/kritzel-icon.js +94 -0
  128. package/dist/collection/components/shared/kritzel-icon/kritzel-icon.js.map +1 -0
  129. package/dist/collection/components/shared/kritzel-stroke-size/kritzel-stroke-size.css +28 -0
  130. package/dist/collection/components/shared/kritzel-stroke-size/kritzel-stroke-size.js +91 -0
  131. package/dist/collection/components/shared/kritzel-stroke-size/kritzel-stroke-size.js.map +1 -0
  132. package/dist/collection/components/shared/kritzel-tooltip/kritzel-tooltip.css +17 -0
  133. package/dist/collection/components/shared/kritzel-tooltip/kritzel-tooltip.js +181 -0
  134. package/dist/collection/components/shared/kritzel-tooltip/kritzel-tooltip.js.map +1 -0
  135. package/dist/collection/components/ui/kritzel-context-menu/kritzel-context-menu.css +55 -0
  136. package/dist/collection/components/ui/kritzel-context-menu/kritzel-context-menu.js +178 -0
  137. package/dist/collection/components/ui/kritzel-context-menu/kritzel-context-menu.js.map +1 -0
  138. package/dist/collection/components/ui/kritzel-control-brush-config/kritzel-control-brush-config.css +19 -0
  139. package/dist/collection/components/ui/kritzel-control-brush-config/kritzel-control-brush-config.js +136 -0
  140. package/dist/collection/components/ui/kritzel-control-brush-config/kritzel-control-brush-config.js.map +1 -0
  141. package/dist/collection/components/ui/kritzel-control-text-config/kritzel-control-text-config.css +19 -0
  142. package/dist/collection/components/ui/kritzel-control-text-config/kritzel-control-text-config.js +116 -0
  143. package/dist/collection/components/ui/kritzel-control-text-config/kritzel-control-text-config.js.map +1 -0
  144. package/dist/collection/components/ui/kritzel-controls/kritzel-controls.css +124 -0
  145. package/dist/collection/components/ui/kritzel-controls/kritzel-controls.js +268 -0
  146. package/dist/collection/components/ui/kritzel-controls/kritzel-controls.js.map +1 -0
  147. package/dist/collection/components/ui/kritzel-utility-panel/kritzel-utility-panel.css +33 -0
  148. package/dist/collection/components/ui/kritzel-utility-panel/kritzel-utility-panel.js +79 -0
  149. package/dist/collection/components/ui/kritzel-utility-panel/kritzel-utility-panel.js.map +1 -0
  150. package/dist/{stencil/default-text-tool.config-DvOZmpuR.js → collection/configs/default-brush-tool.config.js} +2 -38
  151. package/dist/collection/configs/default-brush-tool.config.js.map +1 -0
  152. package/dist/collection/configs/default-engine-state.js +58 -0
  153. package/dist/collection/configs/default-engine-state.js.map +1 -0
  154. package/dist/collection/configs/default-text-tool.config.js +32 -0
  155. package/dist/collection/configs/default-text-tool.config.js.map +1 -0
  156. package/dist/collection/constants/engine.constants.js +3 -0
  157. package/dist/collection/constants/engine.constants.js.map +1 -0
  158. package/dist/collection/enums/event-button.enum.js +7 -0
  159. package/dist/collection/enums/event-button.enum.js.map +1 -0
  160. package/dist/collection/enums/handle-type.enum.js +8 -0
  161. package/dist/collection/enums/handle-type.enum.js.map +1 -0
  162. package/dist/collection/helpers/class.helper.js +6 -0
  163. package/dist/collection/helpers/class.helper.js.map +1 -0
  164. package/dist/collection/helpers/devices.helper.js +6 -0
  165. package/dist/collection/helpers/devices.helper.js.map +1 -0
  166. package/dist/collection/helpers/event.helper.js +58 -0
  167. package/dist/collection/helpers/event.helper.js.map +1 -0
  168. package/dist/collection/helpers/geometry.helper.js +53 -0
  169. package/dist/collection/helpers/geometry.helper.js.map +1 -0
  170. package/dist/collection/helpers/html.helper.js +7 -0
  171. package/dist/collection/helpers/html.helper.js.map +1 -0
  172. package/dist/collection/helpers/keyboard.helper.js +31 -0
  173. package/dist/collection/helpers/keyboard.helper.js.map +1 -0
  174. package/dist/collection/helpers/math.helper.js +6 -0
  175. package/dist/collection/helpers/math.helper.js.map +1 -0
  176. package/dist/collection/helpers/object.helper.js +38 -0
  177. package/dist/collection/helpers/object.helper.js.map +1 -0
  178. package/dist/collection/index.js +21 -0
  179. package/dist/collection/index.js.map +1 -0
  180. package/dist/collection/interfaces/bounding-box.interface.js +2 -0
  181. package/dist/collection/interfaces/bounding-box.interface.js.map +1 -0
  182. package/dist/collection/interfaces/command.interface.js +2 -0
  183. package/dist/collection/interfaces/command.interface.js.map +1 -0
  184. package/dist/collection/interfaces/context-menu-item.interface.js +2 -0
  185. package/dist/collection/interfaces/context-menu-item.interface.js.map +1 -0
  186. package/dist/collection/interfaces/debug-info.interface.js +2 -0
  187. package/dist/collection/interfaces/debug-info.interface.js.map +1 -0
  188. package/dist/collection/interfaces/engine-state.interface.js +2 -0
  189. package/dist/collection/interfaces/engine-state.interface.js.map +1 -0
  190. package/dist/collection/interfaces/object.interface.js +2 -0
  191. package/dist/collection/interfaces/object.interface.js.map +1 -0
  192. package/dist/collection/interfaces/path-options.interface.js +2 -0
  193. package/dist/collection/interfaces/path-options.interface.js.map +1 -0
  194. package/dist/collection/interfaces/point.interface.js +2 -0
  195. package/dist/collection/interfaces/point.interface.js.map +1 -0
  196. package/dist/collection/interfaces/polygon.interface.js +2 -0
  197. package/dist/collection/interfaces/polygon.interface.js.map +1 -0
  198. package/dist/collection/interfaces/selection-state.interface.js +2 -0
  199. package/dist/collection/interfaces/selection-state.interface.js.map +1 -0
  200. package/dist/collection/interfaces/serializable.interface.js +2 -0
  201. package/dist/collection/interfaces/serializable.interface.js.map +1 -0
  202. package/dist/collection/interfaces/tool.interface.js +2 -0
  203. package/dist/collection/interfaces/tool.interface.js.map +1 -0
  204. package/dist/collection/interfaces/toolbar-control.interface.js +2 -0
  205. package/dist/collection/interfaces/toolbar-control.interface.js.map +1 -0
  206. package/dist/collection/types/state.types.js +2 -0
  207. package/dist/collection/types/state.types.js.map +1 -0
  208. package/dist/components/index.js +24 -0
  209. package/dist/components/index.js.map +1 -0
  210. package/dist/components/kritzel-brush-style.js +9 -0
  211. package/dist/components/kritzel-brush-style.js.map +1 -0
  212. package/dist/components/kritzel-color-palette.js +9 -0
  213. package/dist/components/kritzel-color-palette.js.map +1 -0
  214. package/dist/components/kritzel-color.js +9 -0
  215. package/dist/components/kritzel-color.js.map +1 -0
  216. package/dist/components/kritzel-context-menu.js +9 -0
  217. package/dist/components/kritzel-context-menu.js.map +1 -0
  218. package/dist/components/kritzel-control-brush-config.js +9 -0
  219. package/dist/components/kritzel-control-brush-config.js.map +1 -0
  220. package/dist/components/kritzel-control-text-config.js +9 -0
  221. package/dist/components/kritzel-control-text-config.js.map +1 -0
  222. package/dist/components/kritzel-controls.js +9 -0
  223. package/dist/components/kritzel-controls.js.map +1 -0
  224. package/dist/components/kritzel-cursor-trail.js +9 -0
  225. package/dist/components/kritzel-cursor-trail.js.map +1 -0
  226. package/dist/components/kritzel-dropdown.js +9 -0
  227. package/dist/components/kritzel-dropdown.js.map +1 -0
  228. package/dist/components/kritzel-editor.js +409 -0
  229. package/dist/components/kritzel-editor.js.map +1 -0
  230. package/dist/components/kritzel-engine.js +9 -0
  231. package/dist/components/kritzel-engine.js.map +1 -0
  232. package/dist/components/kritzel-font-family.js +9 -0
  233. package/dist/components/kritzel-font-family.js.map +1 -0
  234. package/dist/components/kritzel-font-size.js +9 -0
  235. package/dist/components/kritzel-font-size.js.map +1 -0
  236. package/dist/components/kritzel-font.js +9 -0
  237. package/dist/components/kritzel-font.js.map +1 -0
  238. package/dist/components/kritzel-icon.js +9 -0
  239. package/dist/components/kritzel-icon.js.map +1 -0
  240. package/dist/components/kritzel-stroke-size.js +9 -0
  241. package/dist/components/kritzel-stroke-size.js.map +1 -0
  242. package/dist/components/kritzel-tooltip.js +9 -0
  243. package/dist/components/kritzel-tooltip.js.map +1 -0
  244. package/dist/components/kritzel-utility-panel.js +9 -0
  245. package/dist/components/kritzel-utility-panel.js.map +1 -0
  246. package/dist/{stencil/kritzel-context-menu-B2p1_Ffh.js → components/p-2gNwfcSP.js} +39 -11
  247. package/dist/components/p-2gNwfcSP.js.map +1 -0
  248. package/dist/components/p-BOUCnklW.js +54 -0
  249. package/dist/components/p-BOUCnklW.js.map +1 -0
  250. package/dist/components/p-BhC-Et5I.js +102 -0
  251. package/dist/components/p-BhC-Et5I.js.map +1 -0
  252. package/dist/components/p-BkFzf8vg.js +111 -0
  253. package/dist/components/p-BkFzf8vg.js.map +1 -0
  254. package/dist/{stencil/kritzel-font-family.entry.js → components/p-BubFkS0u.js} +35 -11
  255. package/dist/components/p-BubFkS0u.js.map +1 -0
  256. package/dist/components/p-C9usqwb5.js +61 -0
  257. package/dist/components/p-C9usqwb5.js.map +1 -0
  258. package/dist/{stencil/kritzel-tooltip.entry.js → components/p-CmlcJ8Kw.js} +37 -14
  259. package/dist/components/p-CmlcJ8Kw.js.map +1 -0
  260. package/dist/components/p-CtiROna-.js +90 -0
  261. package/dist/components/p-CtiROna-.js.map +1 -0
  262. package/dist/components/p-CudOuOAW.js +2716 -0
  263. package/dist/components/p-CudOuOAW.js.map +1 -0
  264. package/dist/components/p-D5a8vnRF.js +52 -0
  265. package/dist/components/p-D5a8vnRF.js.map +1 -0
  266. package/dist/{stencil/event-button.enum-D8W6LE-c.js → components/p-D8W6LE-c.js} +2 -2
  267. package/dist/components/p-D8W6LE-c.js.map +1 -0
  268. package/dist/components/p-DJN0U8pI.js +1327 -0
  269. package/dist/components/p-DJN0U8pI.js.map +1 -0
  270. package/dist/{stencil/kritzel-color-palette.entry.js → components/p-DJc6_PyL.js} +37 -11
  271. package/dist/components/p-DJc6_PyL.js.map +1 -0
  272. package/dist/{stencil/kritzel-controls.entry.js → components/p-DSWoCkxm.js} +116 -16
  273. package/dist/components/p-DSWoCkxm.js.map +1 -0
  274. package/dist/components/p-DcvujuV_.js +54 -0
  275. package/dist/components/p-DcvujuV_.js.map +1 -0
  276. package/dist/{stencil/kritzel-color.entry.js → components/p-DfJEh7HZ.js} +29 -11
  277. package/dist/components/p-DfJEh7HZ.js.map +1 -0
  278. package/dist/components/p-Dp8hrISj.js +44 -0
  279. package/dist/components/p-Dp8hrISj.js.map +1 -0
  280. package/dist/{stencil/kritzel-cursor-trail.entry.js → components/p-EQo4-DJT.js} +30 -11
  281. package/dist/components/p-EQo4-DJT.js.map +1 -0
  282. package/dist/{stencil/kritzel-dropdown.entry.js → components/p-NZJPrwJV.js} +37 -11
  283. package/dist/components/p-NZJPrwJV.js.map +1 -0
  284. package/dist/{stencil/brush-tool.class-D1U3x9_Y.js → components/p-ljdIU3DL.js} +18 -51
  285. package/dist/components/p-ljdIU3DL.js.map +1 -0
  286. package/dist/esm/app-globals-DQuL1Twl.js +6 -0
  287. package/dist/esm/app-globals-DQuL1Twl.js.map +1 -0
  288. package/dist/esm/index-BGl8znzE.js +1564 -0
  289. package/dist/esm/index-BGl8znzE.js.map +1 -0
  290. package/dist/esm/index-D37FADaF.js +2531 -0
  291. package/dist/esm/index-D37FADaF.js.map +1 -0
  292. package/dist/esm/index.js +4 -0
  293. package/dist/esm/index.js.map +1 -0
  294. package/dist/esm/kritzel-brush-style_18.entry.js +2346 -0
  295. package/dist/esm/kritzel-brush-style_18.entry.js.map +1 -0
  296. package/dist/esm/loader.js +14 -0
  297. package/dist/esm/loader.js.map +1 -0
  298. package/dist/esm/stencil.js +24 -0
  299. package/dist/esm/stencil.js.map +1 -0
  300. package/dist/index.cjs.js +1 -0
  301. package/dist/index.js +1 -0
  302. package/dist/stencil/index.esm.js +1 -16
  303. package/dist/stencil/index.esm.js.map +1 -1
  304. package/dist/stencil/loader.esm.js.map +1 -1
  305. package/dist/stencil/p-BGl8znzE.js +3 -0
  306. package/dist/stencil/p-BGl8znzE.js.map +1 -0
  307. package/dist/stencil/p-D37FADaF.js +2 -0
  308. package/dist/stencil/p-D37FADaF.js.map +1 -0
  309. package/dist/stencil/p-DQuL1Twl.js +2 -0
  310. package/dist/stencil/p-DQuL1Twl.js.map +1 -0
  311. package/dist/stencil/p-e6ac7fc6.entry.js +2 -0
  312. package/dist/stencil/p-e6ac7fc6.entry.js.map +1 -0
  313. package/dist/stencil/stencil.esm.js +1 -49
  314. package/dist/stencil/stencil.esm.js.map +1 -1
  315. package/dist/types/classes/objects/base-object.class.d.ts +1 -0
  316. package/dist/types/classes/objects/path.class.d.ts +1 -0
  317. package/dist/types/interfaces/object.interface.d.ts +1 -0
  318. package/package.json +62 -62
  319. package/dist/stencil/brush-tool.class-D1U3x9_Y.js.map +0 -1
  320. package/dist/stencil/default-text-tool.config-DvOZmpuR.js.map +0 -1
  321. package/dist/stencil/engine.constants-DsjjAmnl.js +0 -7
  322. package/dist/stencil/engine.constants-DsjjAmnl.js.map +0 -1
  323. package/dist/stencil/event-button.enum-D8W6LE-c.js.map +0 -1
  324. package/dist/stencil/icon-registry.class-Bw5YkOTi.js.map +0 -1
  325. package/dist/stencil/image-tool.class-uKAmXFSl.js +0 -1341
  326. package/dist/stencil/image-tool.class-uKAmXFSl.js.map +0 -1
  327. package/dist/stencil/index-Df69oUcb.js +0 -4334
  328. package/dist/stencil/index-Df69oUcb.js.map +0 -1
  329. package/dist/stencil/kritzel-brush-style.entry.esm.js.map +0 -1
  330. package/dist/stencil/kritzel-brush-style.entry.js +0 -31
  331. package/dist/stencil/kritzel-brush-style.entry.js.map +0 -1
  332. package/dist/stencil/kritzel-color-palette.entry.esm.js.map +0 -1
  333. package/dist/stencil/kritzel-color-palette.entry.js.map +0 -1
  334. package/dist/stencil/kritzel-color.entry.esm.js.map +0 -1
  335. package/dist/stencil/kritzel-color.entry.js.map +0 -1
  336. package/dist/stencil/kritzel-context-menu-B2p1_Ffh.js.map +0 -1
  337. package/dist/stencil/kritzel-context-menu-DPHV6MRm.js +0 -91
  338. package/dist/stencil/kritzel-context-menu-DPHV6MRm.js.map +0 -1
  339. package/dist/stencil/kritzel-context-menu.entry.esm.js.map +0 -1
  340. package/dist/stencil/kritzel-context-menu.entry.js +0 -5
  341. package/dist/stencil/kritzel-context-menu.entry.js.map +0 -1
  342. package/dist/stencil/kritzel-control-brush-config.entry.esm.js.map +0 -1
  343. package/dist/stencil/kritzel-control-brush-config.entry.js +0 -54
  344. package/dist/stencil/kritzel-control-brush-config.entry.js.map +0 -1
  345. package/dist/stencil/kritzel-control-text-config.entry.esm.js.map +0 -1
  346. package/dist/stencil/kritzel-control-text-config.entry.js +0 -42
  347. package/dist/stencil/kritzel-control-text-config.entry.js.map +0 -1
  348. package/dist/stencil/kritzel-controls.entry.esm.js.map +0 -1
  349. package/dist/stencil/kritzel-controls.entry.js.map +0 -1
  350. package/dist/stencil/kritzel-cursor-trail.entry.esm.js.map +0 -1
  351. package/dist/stencil/kritzel-cursor-trail.entry.js.map +0 -1
  352. package/dist/stencil/kritzel-dropdown.entry.esm.js.map +0 -1
  353. package/dist/stencil/kritzel-dropdown.entry.js.map +0 -1
  354. package/dist/stencil/kritzel-editor.entry.esm.js.map +0 -1
  355. package/dist/stencil/kritzel-editor.entry.js +0 -180
  356. package/dist/stencil/kritzel-editor.entry.js.map +0 -1
  357. package/dist/stencil/kritzel-engine.entry.esm.js.map +0 -1
  358. package/dist/stencil/kritzel-engine.entry.js +0 -1318
  359. package/dist/stencil/kritzel-engine.entry.js.map +0 -1
  360. package/dist/stencil/kritzel-font-family.entry.esm.js.map +0 -1
  361. package/dist/stencil/kritzel-font-family.entry.js.map +0 -1
  362. package/dist/stencil/kritzel-font-size.entry.esm.js.map +0 -1
  363. package/dist/stencil/kritzel-font-size.entry.js +0 -29
  364. package/dist/stencil/kritzel-font-size.entry.js.map +0 -1
  365. package/dist/stencil/kritzel-font.entry.esm.js.map +0 -1
  366. package/dist/stencil/kritzel-font.entry.js +0 -25
  367. package/dist/stencil/kritzel-font.entry.js.map +0 -1
  368. package/dist/stencil/kritzel-icon.entry.esm.js.map +0 -1
  369. package/dist/stencil/kritzel-icon.entry.js +0 -29
  370. package/dist/stencil/kritzel-icon.entry.js.map +0 -1
  371. package/dist/stencil/kritzel-stroke-size.entry.esm.js.map +0 -1
  372. package/dist/stencil/kritzel-stroke-size.entry.js +0 -28
  373. package/dist/stencil/kritzel-stroke-size.entry.js.map +0 -1
  374. package/dist/stencil/kritzel-tooltip.entry.esm.js.map +0 -1
  375. package/dist/stencil/kritzel-tooltip.entry.js.map +0 -1
  376. package/dist/stencil/kritzel-utility-panel.entry.esm.js.map +0 -1
  377. package/dist/stencil/kritzel-utility-panel.entry.js +0 -33
  378. package/dist/stencil/kritzel-utility-panel.entry.js.map +0 -1
@@ -0,0 +1,268 @@
1
+ import { h, Host } from "@stencil/core";
2
+ import { KritzelBrushTool } from "../../../classes/tools/brush-tool.class";
3
+ import { KritzelTextTool } from "../../../classes/tools/text-tool.class";
4
+ import { KritzelDevicesHelper } from "../../../helpers/devices.helper";
5
+ export class KritzelControls {
6
+ constructor() {
7
+ this.controls = [];
8
+ this.activeControl = null;
9
+ this.isUtilityPanelVisible = true;
10
+ this.firstConfig = null;
11
+ this.isTooltipVisible = false;
12
+ this.isTouchDevice = KritzelDevicesHelper.isTouchDevice();
13
+ this.kritzelEngine = null;
14
+ }
15
+ async handleActiveToolChange(event) {
16
+ var _a;
17
+ this.activeControl = this.controls.find(control => control.tool === event.detail) || null;
18
+ await ((_a = this.kritzelEngine) === null || _a === void 0 ? void 0 : _a.setFocus());
19
+ }
20
+ handleClick(event) {
21
+ const element = event.target;
22
+ if (!this.kritzelEngine || element.closest('.kritzel-tooltip')) {
23
+ return;
24
+ }
25
+ this.isTooltipVisible = false;
26
+ this.kritzelEngine.enable();
27
+ }
28
+ async closeTooltip() {
29
+ var _a;
30
+ this.isTooltipVisible = false;
31
+ (_a = this.kritzelEngine) === null || _a === void 0 ? void 0 : _a.enable();
32
+ }
33
+ get activeToolAsTextTool() {
34
+ var _a;
35
+ return (_a = this.activeControl) === null || _a === void 0 ? void 0 : _a.tool;
36
+ }
37
+ get activeToolAsBrushTool() {
38
+ var _a;
39
+ return (_a = this.activeControl) === null || _a === void 0 ? void 0 : _a.tool;
40
+ }
41
+ async componentWillLoad() {
42
+ await this.initializeEngine();
43
+ await this.initializeTools();
44
+ this.isControlsReady.emit();
45
+ }
46
+ async initializeEngine() {
47
+ await customElements.whenDefined('kritzel-engine');
48
+ this.kritzelEngine = this.host.parentElement.querySelector('kritzel-engine');
49
+ if (!this.kritzelEngine) {
50
+ throw new Error('kritzel-engine not found in parent element.');
51
+ }
52
+ }
53
+ async initializeTools() {
54
+ for (const c of this.controls) {
55
+ if (c.type === 'tool' && c.tool) {
56
+ c.tool = await this.kritzelEngine.registerTool(c.name, c.tool, c.config);
57
+ }
58
+ if (c.type === 'tool' && c.isDefault && c.tool) {
59
+ await this.kritzelEngine.changeActiveTool(c.tool);
60
+ this.activeControl = c;
61
+ }
62
+ if (c.type === 'config') {
63
+ if (this.firstConfig === null) {
64
+ this.firstConfig = c;
65
+ }
66
+ else {
67
+ console.warn('Only one config control is allowed. The first one will be used.');
68
+ }
69
+ }
70
+ }
71
+ }
72
+ async handleControlClick(control) {
73
+ this.activeControl = control;
74
+ if (this.activeControl.type === 'tool') {
75
+ await this.kritzelEngine.changeActiveTool(this.activeControl.tool);
76
+ }
77
+ }
78
+ handleConfigClick(event) {
79
+ event.stopPropagation();
80
+ this.isTooltipVisible = !this.isTooltipVisible;
81
+ this.kritzelEngine.disable();
82
+ }
83
+ async handleToolChange(event) {
84
+ this.activeControl = Object.assign(Object.assign({}, this.activeControl), { tool: event.detail });
85
+ await this.kritzelEngine.changeActiveTool(this.activeControl.tool);
86
+ }
87
+ render() {
88
+ var _a, _b;
89
+ const hasNoConfig = ((_a = this.activeControl) === null || _a === void 0 ? void 0 : _a.config) === undefined || ((_b = this.activeControl) === null || _b === void 0 ? void 0 : _b.config) === null;
90
+ return (h(Host, { key: 'dfb17219cf1d27d86148bc918b8303d74244700c', class: {
91
+ mobile: this.isTouchDevice,
92
+ } }, this.isUtilityPanelVisible && (h("kritzel-utility-panel", { key: 'a5eb7c6b59a193ba0bdde53812882c355a7658d4', style: {
93
+ position: 'absolute',
94
+ bottom: '56px',
95
+ left: '12px',
96
+ }, onUndo: () => { var _a; return (_a = this.kritzelEngine) === null || _a === void 0 ? void 0 : _a.undo(); }, onRedo: () => { var _a; return (_a = this.kritzelEngine) === null || _a === void 0 ? void 0 : _a.redo(); }, onDelete: () => { var _a; return (_a = this.kritzelEngine) === null || _a === void 0 ? void 0 : _a.delete(); } })), h("div", { key: 'b51e49664bf6330f22fb07ef64116459ec3832b3', class: "kritzel-controls" }, this.controls.map(control => {
97
+ var _a, _b, _c, _d, _e, _f, _g, _h;
98
+ if (control.type === 'tool') {
99
+ return (h("button", { class: {
100
+ 'kritzel-control': true,
101
+ 'selected': ((_a = this.activeControl) === null || _a === void 0 ? void 0 : _a.name) === (control === null || control === void 0 ? void 0 : control.name),
102
+ }, key: control.name, onClick: _event => { var _a; return (_a = this.handleControlClick) === null || _a === void 0 ? void 0 : _a.call(this, control); } }, h("kritzel-icon", { name: control.icon })));
103
+ }
104
+ if (control.type === 'divider') {
105
+ return h("div", { class: "kritzel-divider", key: control.name });
106
+ }
107
+ if (control.type === 'config' && control.name === ((_b = this.firstConfig) === null || _b === void 0 ? void 0 : _b.name) && this.activeControl) {
108
+ return (h("div", { class: "kritzel-config-container", key: control.name }, h("kritzel-tooltip", { isVisible: this.isTooltipVisible, anchorElement: (_c = this.host.shadowRoot) === null || _c === void 0 ? void 0 : _c.querySelector('.kritzel-config-container') }, h("div", { style: { width: '294px', height: '100%' } }, this.activeControl.name === 'brush' && (h("kritzel-control-brush-config", { tool: this.activeToolAsBrushTool, onToolChange: event => { var _a; return (_a = this.handleToolChange) === null || _a === void 0 ? void 0 : _a.call(this, event); } })), this.activeControl.name === 'text' && (h("kritzel-control-text-config", { tool: this.activeToolAsTextTool, onToolChange: event => { var _a; return (_a = this.handleToolChange) === null || _a === void 0 ? void 0 : _a.call(this, event); } })))), h("div", { class: "kritzel-config", onClick: event => { var _a; return (_a = this.handleConfigClick) === null || _a === void 0 ? void 0 : _a.call(this, event); }, style: {
109
+ cursor: this.activeControl.config ? 'pointer' : 'default',
110
+ pointerEvents: hasNoConfig ? 'none' : 'auto',
111
+ } }, this.activeControl.tool instanceof KritzelBrushTool && (h("div", { class: "color-container" }, h("kritzel-color", { value: (_d = this.activeToolAsBrushTool) === null || _d === void 0 ? void 0 : _d.color, size: (_e = this.activeToolAsBrushTool) === null || _e === void 0 ? void 0 : _e.size, style: {
112
+ borderRadius: '50%',
113
+ border: 'none',
114
+ } }))), this.activeControl.tool instanceof KritzelTextTool && (h("div", { class: "font-container" }, h("kritzel-font", { fontFamily: (_f = this.activeToolAsTextTool) === null || _f === void 0 ? void 0 : _f.fontFamily, size: (_g = this.activeToolAsTextTool) === null || _g === void 0 ? void 0 : _g.fontSize, color: (_h = this.activeToolAsTextTool) === null || _h === void 0 ? void 0 : _h.fontColor }))), hasNoConfig && h("div", { class: "no-config" }))));
115
+ }
116
+ }))));
117
+ }
118
+ static get is() { return "kritzel-controls"; }
119
+ static get encapsulation() { return "shadow"; }
120
+ static get originalStyleUrls() {
121
+ return {
122
+ "$": ["kritzel-controls.css"]
123
+ };
124
+ }
125
+ static get styleUrls() {
126
+ return {
127
+ "$": ["kritzel-controls.css"]
128
+ };
129
+ }
130
+ static get assetsDirs() { return ["../assets"]; }
131
+ static get properties() {
132
+ return {
133
+ "controls": {
134
+ "type": "unknown",
135
+ "attribute": "controls",
136
+ "mutable": false,
137
+ "complexType": {
138
+ "original": "KritzelToolbarControl[]",
139
+ "resolved": "KritzelToolbarControl[]",
140
+ "references": {
141
+ "KritzelToolbarControl": {
142
+ "location": "import",
143
+ "path": "../../../interfaces/toolbar-control.interface",
144
+ "id": "src/interfaces/toolbar-control.interface.ts::KritzelToolbarControl"
145
+ }
146
+ }
147
+ },
148
+ "required": false,
149
+ "optional": false,
150
+ "docs": {
151
+ "tags": [],
152
+ "text": ""
153
+ },
154
+ "getter": false,
155
+ "setter": false,
156
+ "defaultValue": "[]"
157
+ },
158
+ "activeControl": {
159
+ "type": "unknown",
160
+ "attribute": "active-control",
161
+ "mutable": true,
162
+ "complexType": {
163
+ "original": "KritzelToolbarControl | null",
164
+ "resolved": "KritzelToolbarControl",
165
+ "references": {
166
+ "KritzelToolbarControl": {
167
+ "location": "import",
168
+ "path": "../../../interfaces/toolbar-control.interface",
169
+ "id": "src/interfaces/toolbar-control.interface.ts::KritzelToolbarControl"
170
+ }
171
+ }
172
+ },
173
+ "required": false,
174
+ "optional": false,
175
+ "docs": {
176
+ "tags": [],
177
+ "text": ""
178
+ },
179
+ "getter": false,
180
+ "setter": false,
181
+ "defaultValue": "null"
182
+ },
183
+ "isUtilityPanelVisible": {
184
+ "type": "boolean",
185
+ "attribute": "is-utility-panel-visible",
186
+ "mutable": false,
187
+ "complexType": {
188
+ "original": "boolean",
189
+ "resolved": "boolean",
190
+ "references": {}
191
+ },
192
+ "required": false,
193
+ "optional": false,
194
+ "docs": {
195
+ "tags": [],
196
+ "text": ""
197
+ },
198
+ "getter": false,
199
+ "setter": false,
200
+ "reflect": false,
201
+ "defaultValue": "true"
202
+ }
203
+ };
204
+ }
205
+ static get states() {
206
+ return {
207
+ "firstConfig": {},
208
+ "isTooltipVisible": {},
209
+ "isTouchDevice": {}
210
+ };
211
+ }
212
+ static get events() {
213
+ return [{
214
+ "method": "isControlsReady",
215
+ "name": "isControlsReady",
216
+ "bubbles": true,
217
+ "cancelable": true,
218
+ "composed": true,
219
+ "docs": {
220
+ "tags": [],
221
+ "text": ""
222
+ },
223
+ "complexType": {
224
+ "original": "void",
225
+ "resolved": "void",
226
+ "references": {}
227
+ }
228
+ }];
229
+ }
230
+ static get methods() {
231
+ return {
232
+ "closeTooltip": {
233
+ "complexType": {
234
+ "signature": "() => Promise<void>",
235
+ "parameters": [],
236
+ "references": {
237
+ "Promise": {
238
+ "location": "global",
239
+ "id": "global::Promise"
240
+ }
241
+ },
242
+ "return": "Promise<void>"
243
+ },
244
+ "docs": {
245
+ "text": "",
246
+ "tags": []
247
+ }
248
+ }
249
+ };
250
+ }
251
+ static get elementRef() { return "host"; }
252
+ static get listeners() {
253
+ return [{
254
+ "name": "activeToolChange",
255
+ "method": "handleActiveToolChange",
256
+ "target": "document",
257
+ "capture": false,
258
+ "passive": false
259
+ }, {
260
+ "name": "click",
261
+ "method": "handleClick",
262
+ "target": "document",
263
+ "capture": false,
264
+ "passive": false
265
+ }];
266
+ }
267
+ }
268
+ //# sourceMappingURL=kritzel-controls.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"kritzel-controls.js","sourceRoot":"","sources":["../../../../src/components/ui/kritzel-controls/kritzel-controls.tsx"],"names":[],"mappings":"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","sourcesContent":["import { Component, h, Prop, State, Element, Host, Listen, Event, EventEmitter, Method } from '@stencil/core';\r\nimport { KritzelBrushTool } from '../../../classes/tools/brush-tool.class';\r\nimport { KritzelTextTool } from '../../../classes/tools/text-tool.class';\r\nimport { KritzelToolbarControl } from '../../../interfaces/toolbar-control.interface';\r\nimport { KritzelBaseTool } from '../../../classes/tools/base-tool.class';\r\nimport { KritzelDevicesHelper } from '../../../helpers/devices.helper';\r\n\r\ntype ToolConfig = Record<string, any>;\r\n\r\n@Component({\r\n tag: 'kritzel-controls',\r\n styleUrl: 'kritzel-controls.css',\r\n shadow: true,\r\n assetsDirs: ['../assets'],\r\n})\r\nexport class KritzelControls {\r\n @Prop()\r\n controls: KritzelToolbarControl[] = [];\r\n\r\n @Prop({ mutable: true })\r\n activeControl: KritzelToolbarControl | null = null;\r\n\r\n @Prop()\r\n isUtilityPanelVisible: boolean = true;\r\n\r\n @Event()\r\n isControlsReady: EventEmitter<void>;\r\n\r\n @State()\r\n firstConfig: ToolConfig | null = null;\r\n\r\n @State()\r\n isTooltipVisible: boolean = false;\r\n\r\n @State()\r\n isTouchDevice: boolean = KritzelDevicesHelper.isTouchDevice();\r\n\r\n @Element()\r\n host!: HTMLElement;\r\n\r\n @Listen('activeToolChange', { target: 'document' })\r\n async handleActiveToolChange(event: CustomEvent) {\r\n this.activeControl = this.controls.find(control => control.tool === event.detail) || null;\r\n await this.kritzelEngine?.setFocus();\r\n }\r\n\r\n @Listen('click', { target: 'document' })\r\n handleClick(event: MouseEvent) {\r\n const element = event.target as HTMLElement;\r\n\r\n if (!this.kritzelEngine || element.closest('.kritzel-tooltip')) {\r\n return;\r\n }\r\n\r\n this.isTooltipVisible = false;\r\n this.kritzelEngine.enable();\r\n }\r\n\r\n @Method()\r\n async closeTooltip() {\r\n this.isTooltipVisible = false;\r\n this.kritzelEngine?.enable();\r\n }\r\n\r\n kritzelEngine: HTMLKritzelEngineElement | null = null;\r\n\r\n get activeToolAsTextTool() {\r\n return this.activeControl?.tool as KritzelTextTool;\r\n }\r\n\r\n get activeToolAsBrushTool() {\r\n return this.activeControl?.tool as KritzelBrushTool;\r\n }\r\n\r\n async componentWillLoad() {\r\n await this.initializeEngine();\r\n await this.initializeTools();\r\n this.isControlsReady.emit();\r\n }\r\n\r\n private async initializeEngine() {\r\n await customElements.whenDefined('kritzel-engine');\r\n this.kritzelEngine = this.host.parentElement.querySelector('kritzel-engine');\r\n\r\n if (!this.kritzelEngine) {\r\n throw new Error('kritzel-engine not found in parent element.');\r\n }\r\n }\r\n\r\n private async initializeTools() {\r\n for (const c of this.controls) {\r\n if (c.type === 'tool' && c.tool) {\r\n c.tool = await this.kritzelEngine.registerTool(c.name, c.tool, c.config);\r\n }\r\n\r\n if (c.type === 'tool' && c.isDefault && c.tool) {\r\n await this.kritzelEngine.changeActiveTool(c.tool as KritzelBaseTool);\r\n this.activeControl = c;\r\n }\r\n\r\n if (c.type === 'config') {\r\n if (this.firstConfig === null) {\r\n this.firstConfig = c;\r\n } else {\r\n console.warn('Only one config control is allowed. The first one will be used.');\r\n }\r\n }\r\n }\r\n }\r\n\r\n private async handleControlClick(control: KritzelToolbarControl) {\r\n this.activeControl = control;\r\n\r\n if (this.activeControl.type === 'tool') {\r\n await this.kritzelEngine.changeActiveTool(this.activeControl.tool as KritzelBaseTool);\r\n }\r\n }\r\n\r\n private handleConfigClick(event: MouseEvent) {\r\n event.stopPropagation();\r\n this.isTooltipVisible = !this.isTooltipVisible;\r\n this.kritzelEngine.disable();\r\n }\r\n\r\n private async handleToolChange(event: CustomEvent) {\r\n this.activeControl = { ...this.activeControl, tool: event.detail };\r\n await this.kritzelEngine.changeActiveTool((this.activeControl as any).tool);\r\n }\r\n\r\n render() {\r\n const hasNoConfig = this.activeControl?.config === undefined || this.activeControl?.config === null;\r\n\r\n return (\r\n <Host\r\n class={{\r\n mobile: this.isTouchDevice,\r\n }}\r\n >\r\n {this.isUtilityPanelVisible && (\r\n <kritzel-utility-panel\r\n style={{\r\n position: 'absolute',\r\n bottom: '56px',\r\n left: '12px',\r\n }}\r\n onUndo={() => this.kritzelEngine?.undo()}\r\n onRedo={() => this.kritzelEngine?.redo()}\r\n onDelete={() => this.kritzelEngine?.delete()}\r\n ></kritzel-utility-panel>\r\n )}\r\n\r\n <div class=\"kritzel-controls\">\r\n {this.controls.map(control => {\r\n if (control.type === 'tool') {\r\n return (\r\n <button\r\n class={{\r\n 'kritzel-control': true,\r\n 'selected': this.activeControl?.name === control?.name,\r\n }}\r\n key={control.name}\r\n onClick={_event => this.handleControlClick?.(control)}\r\n >\r\n <kritzel-icon name={control.icon}></kritzel-icon>\r\n </button>\r\n );\r\n }\r\n\r\n if (control.type === 'divider') {\r\n return <div class=\"kritzel-divider\" key={control.name}></div>;\r\n }\r\n\r\n if (control.type === 'config' && control.name === this.firstConfig?.name && this.activeControl) {\r\n return (\r\n <div class=\"kritzel-config-container\" key={control.name}>\r\n <kritzel-tooltip isVisible={this.isTooltipVisible} anchorElement={this.host.shadowRoot?.querySelector('.kritzel-config-container') as HTMLElement}>\r\n <div style={{ width: '294px', height: '100%' }}>\r\n {this.activeControl.name === 'brush' && (\r\n <kritzel-control-brush-config tool={this.activeToolAsBrushTool} onToolChange={event => this.handleToolChange?.(event)}></kritzel-control-brush-config>\r\n )}\r\n\r\n {this.activeControl.name === 'text' && (\r\n <kritzel-control-text-config tool={this.activeToolAsTextTool} onToolChange={event => this.handleToolChange?.(event)}></kritzel-control-text-config>\r\n )}\r\n </div>\r\n </kritzel-tooltip>\r\n\r\n <div\r\n class=\"kritzel-config\"\r\n onClick={event => this.handleConfigClick?.(event)}\r\n style={{\r\n cursor: this.activeControl.config ? 'pointer' : 'default',\r\n pointerEvents: hasNoConfig ? 'none' : 'auto',\r\n }}\r\n >\r\n {this.activeControl.tool instanceof KritzelBrushTool && (\r\n <div class=\"color-container\">\r\n <kritzel-color\r\n value={this.activeToolAsBrushTool?.color}\r\n size={this.activeToolAsBrushTool?.size}\r\n style={{\r\n borderRadius: '50%',\r\n border: 'none',\r\n }}\r\n ></kritzel-color>\r\n </div>\r\n )}\r\n\r\n {this.activeControl.tool instanceof KritzelTextTool && (\r\n <div class=\"font-container\">\r\n <kritzel-font\r\n fontFamily={this.activeToolAsTextTool?.fontFamily}\r\n size={this.activeToolAsTextTool?.fontSize}\r\n color={this.activeToolAsTextTool?.fontColor}\r\n ></kritzel-font>\r\n </div>\r\n )}\r\n\r\n {hasNoConfig && <div class=\"no-config\"></div>}\r\n </div>\r\n </div>\r\n );\r\n }\r\n })}\r\n </div>\r\n </Host>\r\n );\r\n }\r\n}\r\n"]}
@@ -0,0 +1,33 @@
1
+ :host {
2
+ display: flex;
3
+ flex-direction: row;
4
+ align-items: center;
5
+ padding: 4px;
6
+ gap: 8px;
7
+ border-top-left-radius: 12px;
8
+ border-top-right-radius: 12px;
9
+ background-color: rgb(226, 226, 226);
10
+ width: fit-content;
11
+ user-select: none;
12
+ }
13
+
14
+ .utility-button {
15
+ display: flex;
16
+ justify-content: center;
17
+ align-items: center;
18
+ width: 28px;
19
+ height: 28px;
20
+ padding: 8px 4px;
21
+ border: none;
22
+ outline: none;
23
+ background: none;
24
+ cursor: pointer;
25
+ color: #333333;
26
+ -webkit-tap-highlight-color: transparent;
27
+ }
28
+
29
+ .utility-separator {
30
+ width: 1px;
31
+ height: 16px;
32
+ background-color: hsl(0, 0%, 0%, 4.3%);
33
+ }
@@ -0,0 +1,79 @@
1
+ import { Host, h } from "@stencil/core";
2
+ export class KritzelUtilityPanel {
3
+ handleUndo(event) {
4
+ if (event.cancelable) {
5
+ event.preventDefault();
6
+ event.stopPropagation();
7
+ this.undo.emit();
8
+ }
9
+ }
10
+ handleRedo(event) {
11
+ event.preventDefault();
12
+ event.stopPropagation();
13
+ this.redo.emit();
14
+ }
15
+ render() {
16
+ return (h(Host, { key: 'f381fac2cb032ca19c6945ef4f39673ea0bd0cc5' }, h("button", { key: '1f7200672970baf1d0cfcaa116fa3f8f9a39832a', class: "utility-button", onClick: event => this.handleUndo(event) }, h("kritzel-icon", { key: '755d9201d80d8db086f07b38e90a01a06e980b50', name: "undo" })), h("button", { key: '06e4d5c2956f23245c3d48f21c15d54e8bef8119', class: "utility-button", onClick: event => this.handleRedo(event) }, h("kritzel-icon", { key: '13eb6b31c45b67ac399fc7c84b941ddce04c5c86', name: "redo" })), h("div", { key: '7f03a576a37649db679b93604c2654d29cc81da4', class: "utility-separator" }), h("button", { key: '0c40613e9f6a049cec872d71e9f948d685ec1dbe', class: "utility-button" }, h("kritzel-icon", { key: '8cba73bcb02ef8b7c182ba2fd16d98d6855f1c1b', name: "delete", onClick: () => this.delete.emit() }))));
17
+ }
18
+ static get is() { return "kritzel-utility-panel"; }
19
+ static get encapsulation() { return "shadow"; }
20
+ static get originalStyleUrls() {
21
+ return {
22
+ "$": ["kritzel-utility-panel.css"]
23
+ };
24
+ }
25
+ static get styleUrls() {
26
+ return {
27
+ "$": ["kritzel-utility-panel.css"]
28
+ };
29
+ }
30
+ static get events() {
31
+ return [{
32
+ "method": "undo",
33
+ "name": "undo",
34
+ "bubbles": true,
35
+ "cancelable": true,
36
+ "composed": true,
37
+ "docs": {
38
+ "tags": [],
39
+ "text": ""
40
+ },
41
+ "complexType": {
42
+ "original": "void",
43
+ "resolved": "void",
44
+ "references": {}
45
+ }
46
+ }, {
47
+ "method": "redo",
48
+ "name": "redo",
49
+ "bubbles": true,
50
+ "cancelable": true,
51
+ "composed": true,
52
+ "docs": {
53
+ "tags": [],
54
+ "text": ""
55
+ },
56
+ "complexType": {
57
+ "original": "void",
58
+ "resolved": "void",
59
+ "references": {}
60
+ }
61
+ }, {
62
+ "method": "delete",
63
+ "name": "delete",
64
+ "bubbles": true,
65
+ "cancelable": true,
66
+ "composed": true,
67
+ "docs": {
68
+ "tags": [],
69
+ "text": ""
70
+ },
71
+ "complexType": {
72
+ "original": "void",
73
+ "resolved": "void",
74
+ "references": {}
75
+ }
76
+ }];
77
+ }
78
+ }
79
+ //# sourceMappingURL=kritzel-utility-panel.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"kritzel-utility-panel.js","sourceRoot":"","sources":["../../../../src/components/ui/kritzel-utility-panel/kritzel-utility-panel.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC,EAAE,KAAK,EAAgB,MAAM,eAAe,CAAC;AAOxE,MAAM,OAAO,mBAAmB;IAU9B,UAAU,CAAC,KAAY;QACrB,IAAI,KAAK,CAAC,UAAU,EAAE,CAAC;YACrB,KAAK,CAAC,cAAc,EAAE,CAAC;YACvB,KAAK,CAAC,eAAe,EAAE,CAAC;YACxB,IAAI,CAAC,IAAI,CAAC,IAAI,EAAE,CAAC;QACnB,CAAC;IACH,CAAC;IAED,UAAU,CAAC,KAAY;QACrB,KAAK,CAAC,cAAc,EAAE,CAAC;QACvB,KAAK,CAAC,eAAe,EAAE,CAAC;QACxB,IAAI,CAAC,IAAI,CAAC,IAAI,EAAE,CAAC;IACnB,CAAC;IAED,MAAM;QACJ,OAAO,CACL,EAAC,IAAI;YACH,+DAAQ,KAAK,EAAC,gBAAgB,EAAC,OAAO,EAAE,KAAK,CAAC,EAAE,CAAC,IAAI,CAAC,UAAU,CAAC,KAAK,CAAC;gBACrE,qEAAc,IAAI,EAAC,MAAM,GAAgB,CAClC;YACT,+DAAQ,KAAK,EAAC,gBAAgB,EAAC,OAAO,EAAE,KAAK,CAAC,EAAE,CAAC,IAAI,CAAC,UAAU,CAAC,KAAK,CAAC;gBACrE,qEAAc,IAAI,EAAC,MAAM,GAAgB,CAClC;YAET,4DAAK,KAAK,EAAC,mBAAmB,GAAO;YAErC,+DAAQ,KAAK,EAAC,gBAAgB;gBAC5B,qEAAc,IAAI,EAAC,QAAQ,EAAC,OAAO,EAAE,GAAG,EAAE,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,EAAE,GAAiB,CACvE,CACJ,CACR,CAAC;IACJ,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CACF","sourcesContent":["import { Component, Host, h, Event, EventEmitter } from '@stencil/core';\r\n\r\n@Component({\r\n tag: 'kritzel-utility-panel',\r\n styleUrl: 'kritzel-utility-panel.css',\r\n shadow: true,\r\n})\r\nexport class KritzelUtilityPanel {\r\n @Event()\r\n undo: EventEmitter<void>;\r\n\r\n @Event()\r\n redo: EventEmitter<void>;\r\n\r\n @Event()\r\n delete: EventEmitter<void>;\r\n\r\n handleUndo(event: Event) {\r\n if (event.cancelable) {\r\n event.preventDefault();\r\n event.stopPropagation();\r\n this.undo.emit();\r\n }\r\n }\r\n\r\n handleRedo(event: Event) {\r\n event.preventDefault();\r\n event.stopPropagation();\r\n this.redo.emit();\r\n }\r\n\r\n render() {\r\n return (\r\n <Host>\r\n <button class=\"utility-button\" onClick={event => this.handleUndo(event)}>\r\n <kritzel-icon name=\"undo\"></kritzel-icon>\r\n </button>\r\n <button class=\"utility-button\" onClick={event => this.handleRedo(event)}>\r\n <kritzel-icon name=\"redo\"></kritzel-icon>\r\n </button>\r\n\r\n <div class=\"utility-separator\"></div>\r\n\r\n <button class=\"utility-button\">\r\n <kritzel-icon name=\"delete\" onClick={() => this.delete.emit()}></kritzel-icon>\r\n </button>\r\n </Host>\r\n );\r\n }\r\n}\r\n"]}
@@ -1,4 +1,4 @@
1
- const DEFAULT_BRUSH_CONFIG = {
1
+ export const DEFAULT_BRUSH_CONFIG = {
2
2
  type: 'pen',
3
3
  color: '#000000',
4
4
  size: 16,
@@ -57,40 +57,4 @@ const DEFAULT_BRUSH_CONFIG = {
57
57
  ],
58
58
  },
59
59
  };
60
-
61
- const DEFAULT_TEXT_CONFIG = {
62
- color: '#000000',
63
- size: 8,
64
- fontFamily: 'Arial',
65
- palette: [
66
- '#000000',
67
- '#ff5252',
68
- '#ffbc00',
69
- '#00c853',
70
- '#0000FF',
71
- '#d500f9',
72
- '#fafafa',
73
- '#a52714',
74
- '#ee8100',
75
- '#558b2f',
76
- '#01579b',
77
- '#8e24aa',
78
- '#90a4ae',
79
- '#ff4081',
80
- '#ff6e40',
81
- '#aeea00',
82
- '#304ffe',
83
- '#7c4dff',
84
- '#cfd8dc',
85
- '#f8bbd0',
86
- '#ffccbc',
87
- '#f0f4c3',
88
- '#9fa8da',
89
- '#d1c4e9',
90
- ],
91
- };
92
-
93
- export { DEFAULT_BRUSH_CONFIG as D, DEFAULT_TEXT_CONFIG as a };
94
- //# sourceMappingURL=default-text-tool.config-DvOZmpuR.js.map
95
-
96
- //# sourceMappingURL=default-text-tool.config-DvOZmpuR.js.map
60
+ //# sourceMappingURL=default-brush-tool.config.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"default-brush-tool.config.js","sourceRoot":"","sources":["../../src/configs/default-brush-tool.config.ts"],"names":[],"mappings":"AAEA,MAAM,CAAC,MAAM,oBAAoB,GAA2B;IAC1D,IAAI,EAAE,KAAK;IACX,KAAK,EAAE,SAAS;IAChB,IAAI,EAAE,EAAE;IACR,QAAQ,EAAE;QACR,GAAG,EAAE;YACH,SAAS;YACT,SAAS;YACT,SAAS;YACT,SAAS;YACT,SAAS;YACT,SAAS;YACT,SAAS;YACT,SAAS;YACT,SAAS;YACT,SAAS;YACT,SAAS;YACT,SAAS;YACT,SAAS;YACT,SAAS;YACT,SAAS;YACT,SAAS;YACT,SAAS;YACT,SAAS;YACT,SAAS;YACT,SAAS;YACT,SAAS;YACT,SAAS;YACT,SAAS;YACT,SAAS;SACV;QACD,WAAW,EAAE;YACX,WAAW;YACX,WAAW;YACX,WAAW;YACX,WAAW;YACX,WAAW;YACX,WAAW;YACX,WAAW;YACX,WAAW;YACX,WAAW;YACX,WAAW;YACX,WAAW;YACX,WAAW;YACX,WAAW;YACX,WAAW;YACX,WAAW;YACX,WAAW;YACX,WAAW;YACX,WAAW;YACX,WAAW;YACX,WAAW;YACX,WAAW;YACX,WAAW;YACX,WAAW;YACX,WAAW;SACZ;KACF;CACF,CAAC","sourcesContent":["import { KritzelBrushToolConfig } from '../interfaces/toolbar-control.interface';\r\n\r\nexport const DEFAULT_BRUSH_CONFIG: KritzelBrushToolConfig = {\r\n type: 'pen',\r\n color: '#000000',\r\n size: 16,\r\n palettes: {\r\n pen: [\r\n '#000000',\r\n '#ff5252',\r\n '#ffbc00',\r\n '#00c853',\r\n '#0000FF',\r\n '#d500f9',\r\n '#fafafa',\r\n '#a52714',\r\n '#ee8100',\r\n '#558b2f',\r\n '#01579b',\r\n '#8e24aa',\r\n '#90a4ae',\r\n '#ff4081',\r\n '#ff6e40',\r\n '#aeea00',\r\n '#304ffe',\r\n '#7c4dff',\r\n '#cfd8dc',\r\n '#f8bbd0',\r\n '#ffccbc',\r\n '#f0f4c3',\r\n '#9fa8da',\r\n '#d1c4e9',\r\n ],\r\n highlighter: [\r\n '#0000006e',\r\n '#ff52526e',\r\n '#ffbb006e',\r\n '#00c8536e',\r\n '#0000FF6e',\r\n '#d500f96e',\r\n '#fafafa6e',\r\n '#a527146e',\r\n '#ee81006e',\r\n '#558b2f6e',\r\n '#01579b6e',\r\n '#8e24aa6e',\r\n '#90a4ae6e',\r\n '#ff40816e',\r\n '#ff6e406e',\r\n '#aeea006e',\r\n '#304ffe6e',\r\n '#7c4dff6e',\r\n '#cfd8dc6e',\r\n '#f8bbd06e',\r\n '#ffccbc6e',\r\n '#f0f4c36e',\r\n '#9fa8da6e',\r\n '#d1c4e96e',\r\n ],\r\n },\r\n};\r\n\r\n\r\n"]}
@@ -0,0 +1,58 @@
1
+ export const DEFAULT_ENGINE_STATE = {
2
+ activeTool: null,
3
+ activeText: null,
4
+ currentPath: null,
5
+ copiedObjects: null,
6
+ objectsOctree: null,
7
+ selectionBox: null,
8
+ selectionGroup: null,
9
+ resizeHandleType: null,
10
+ hasViewportChanged: false,
11
+ isReady: false,
12
+ isEnabled: true,
13
+ isScaling: false,
14
+ isPanning: false,
15
+ isFocused: false,
16
+ isSelecting: false,
17
+ isResizing: false,
18
+ isResizeHandleSelected: false,
19
+ isRotating: false,
20
+ isRotationHandleSelected: false,
21
+ isDragging: false,
22
+ isDrawing: false,
23
+ isErasing: false,
24
+ isWriting: false,
25
+ isCtrlKeyPressed: false,
26
+ isContextMenuVisible: false,
27
+ contextMenuItems: [],
28
+ contextMenuX: 0,
29
+ contextMenuY: 0,
30
+ skipContextMenu: false,
31
+ debugInfo: {
32
+ showObjectInfo: false,
33
+ showViewportInfo: false,
34
+ logCommands: false,
35
+ },
36
+ host: null,
37
+ pointerX: 0,
38
+ pointerY: 0,
39
+ scale: 1,
40
+ scaleMax: 1,
41
+ scaleMin: 1,
42
+ scaleStep: 0.05,
43
+ startX: 0,
44
+ startY: 0,
45
+ translateX: 0,
46
+ translateXMax: 400,
47
+ translateXMin: 0,
48
+ translateY: 0,
49
+ translateYMax: 400,
50
+ translateYMin: 0,
51
+ viewportWidth: 0,
52
+ viewportHeight: 0,
53
+ historyBufferSize: 1000,
54
+ longTouchTimeout: null,
55
+ longTouchDelay: 300,
56
+ pointers: new Map()
57
+ };
58
+ //# sourceMappingURL=default-engine-state.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"default-engine-state.js","sourceRoot":"","sources":["../../src/configs/default-engine-state.ts"],"names":[],"mappings":"AAEA,MAAM,CAAC,MAAM,oBAAoB,GAAuB;IACtD,UAAU,EAAE,IAAI;IAChB,UAAU,EAAE,IAAI;IAChB,WAAW,EAAE,IAAI;IACjB,aAAa,EAAE,IAAI;IACnB,aAAa,EAAE,IAAI;IACnB,YAAY,EAAE,IAAI;IAClB,cAAc,EAAE,IAAI;IACpB,gBAAgB,EAAE,IAAI;IACtB,kBAAkB,EAAE,KAAK;IACzB,OAAO,EAAE,KAAK;IACd,SAAS,EAAE,IAAI;IACf,SAAS,EAAE,KAAK;IAChB,SAAS,EAAE,KAAK;IAChB,SAAS,EAAE,KAAK;IAChB,WAAW,EAAE,KAAK;IAClB,UAAU,EAAE,KAAK;IACjB,sBAAsB,EAAE,KAAK;IAC7B,UAAU,EAAE,KAAK;IACjB,wBAAwB,EAAE,KAAK;IAC/B,UAAU,EAAE,KAAK;IACjB,SAAS,EAAE,KAAK;IAChB,SAAS,EAAE,KAAK;IAChB,SAAS,EAAE,KAAK;IAChB,gBAAgB,EAAE,KAAK;IACvB,oBAAoB,EAAE,KAAK;IAC3B,gBAAgB,EAAE,EAAE;IACpB,YAAY,EAAE,CAAC;IACf,YAAY,EAAE,CAAC;IACf,eAAe,EAAE,KAAK;IACtB,SAAS,EAAE;QACT,cAAc,EAAE,KAAK;QACrB,gBAAgB,EAAE,KAAK;QACvB,WAAW,EAAE,KAAK;KACnB;IACD,IAAI,EAAE,IAAI;IACV,QAAQ,EAAE,CAAC;IACX,QAAQ,EAAE,CAAC;IACX,KAAK,EAAE,CAAC;IACR,QAAQ,EAAE,CAAC;IACX,QAAQ,EAAE,CAAC;IACX,SAAS,EAAE,IAAI;IACf,MAAM,EAAE,CAAC;IACT,MAAM,EAAE,CAAC;IACT,UAAU,EAAE,CAAC;IACb,aAAa,EAAE,GAAG;IAClB,aAAa,EAAE,CAAC;IAChB,UAAU,EAAE,CAAC;IACb,aAAa,EAAE,GAAG;IAClB,aAAa,EAAE,CAAC;IAChB,aAAa,EAAE,CAAC;IAChB,cAAc,EAAE,CAAC;IACjB,iBAAiB,EAAE,IAAI;IACvB,gBAAgB,EAAE,IAAI;IACtB,cAAc,EAAE,GAAG;IACnB,QAAQ,EAAE,IAAI,GAAG,EAAwB;CAC1C,CAAC","sourcesContent":["import { KritzelEngineState } from \"../interfaces/engine-state.interface\";\r\n\r\nexport const DEFAULT_ENGINE_STATE: KritzelEngineState = {\r\n activeTool: null,\r\n activeText: null,\r\n currentPath: null,\r\n copiedObjects: null,\r\n objectsOctree: null,\r\n selectionBox: null,\r\n selectionGroup: null,\r\n resizeHandleType: null,\r\n hasViewportChanged: false,\r\n isReady: false,\r\n isEnabled: true,\r\n isScaling: false,\r\n isPanning: false,\r\n isFocused: false,\r\n isSelecting: false,\r\n isResizing: false,\r\n isResizeHandleSelected: false,\r\n isRotating: false,\r\n isRotationHandleSelected: false,\r\n isDragging: false,\r\n isDrawing: false,\r\n isErasing: false,\r\n isWriting: false,\r\n isCtrlKeyPressed: false,\r\n isContextMenuVisible: false,\r\n contextMenuItems: [],\r\n contextMenuX: 0,\r\n contextMenuY: 0,\r\n skipContextMenu: false,\r\n debugInfo: {\r\n showObjectInfo: false,\r\n showViewportInfo: false,\r\n logCommands: false,\r\n },\r\n host: null,\r\n pointerX: 0,\r\n pointerY: 0,\r\n scale: 1,\r\n scaleMax: 1,\r\n scaleMin: 1,\r\n scaleStep: 0.05,\r\n startX: 0,\r\n startY: 0,\r\n translateX: 0,\r\n translateXMax: 400,\r\n translateXMin: 0,\r\n translateY: 0,\r\n translateYMax: 400,\r\n translateYMin: 0,\r\n viewportWidth: 0,\r\n viewportHeight: 0,\r\n historyBufferSize: 1000,\r\n longTouchTimeout: null,\r\n longTouchDelay: 300,\r\n pointers: new Map<number, PointerEvent>()\r\n};"]}
@@ -0,0 +1,32 @@
1
+ export const DEFAULT_TEXT_CONFIG = {
2
+ color: '#000000',
3
+ size: 8,
4
+ fontFamily: 'Arial',
5
+ palette: [
6
+ '#000000',
7
+ '#ff5252',
8
+ '#ffbc00',
9
+ '#00c853',
10
+ '#0000FF',
11
+ '#d500f9',
12
+ '#fafafa',
13
+ '#a52714',
14
+ '#ee8100',
15
+ '#558b2f',
16
+ '#01579b',
17
+ '#8e24aa',
18
+ '#90a4ae',
19
+ '#ff4081',
20
+ '#ff6e40',
21
+ '#aeea00',
22
+ '#304ffe',
23
+ '#7c4dff',
24
+ '#cfd8dc',
25
+ '#f8bbd0',
26
+ '#ffccbc',
27
+ '#f0f4c3',
28
+ '#9fa8da',
29
+ '#d1c4e9',
30
+ ],
31
+ };
32
+ //# sourceMappingURL=default-text-tool.config.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"default-text-tool.config.js","sourceRoot":"","sources":["../../src/configs/default-text-tool.config.ts"],"names":[],"mappings":"AAEA,MAAM,CAAC,MAAM,mBAAmB,GAA0B;IACxD,KAAK,EAAE,SAAS;IAChB,IAAI,EAAE,CAAC;IACP,UAAU,EAAE,OAAO;IACnB,OAAO,EAAE;QACP,SAAS;QACT,SAAS;QACT,SAAS;QACT,SAAS;QACT,SAAS;QACT,SAAS;QACT,SAAS;QACT,SAAS;QACT,SAAS;QACT,SAAS;QACT,SAAS;QACT,SAAS;QACT,SAAS;QACT,SAAS;QACT,SAAS;QACT,SAAS;QACT,SAAS;QACT,SAAS;QACT,SAAS;QACT,SAAS;QACT,SAAS;QACT,SAAS;QACT,SAAS;QACT,SAAS;KACV;CACF,CAAC","sourcesContent":["import { KritzelTextToolConfig } from \"../interfaces/toolbar-control.interface\";\r\n\r\nexport const DEFAULT_TEXT_CONFIG: KritzelTextToolConfig = {\r\n color: '#000000',\r\n size: 8,\r\n fontFamily: 'Arial',\r\n palette: [\r\n '#000000',\r\n '#ff5252',\r\n '#ffbc00',\r\n '#00c853',\r\n '#0000FF',\r\n '#d500f9',\r\n '#fafafa',\r\n '#a52714',\r\n '#ee8100',\r\n '#558b2f',\r\n '#01579b',\r\n '#8e24aa',\r\n '#90a4ae',\r\n '#ff4081',\r\n '#ff6e40',\r\n '#aeea00',\r\n '#304ffe',\r\n '#7c4dff',\r\n '#cfd8dc',\r\n '#f8bbd0',\r\n '#ffccbc',\r\n '#f0f4c3',\r\n '#9fa8da',\r\n '#d1c4e9',\r\n ],\r\n};"]}
@@ -0,0 +1,3 @@
1
+ export const ABSOLUTE_SCALE_MAX = 1000;
2
+ export const ABSOLUTE_SCALE_MIN = 0.0001;
3
+ //# sourceMappingURL=engine.constants.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"engine.constants.js","sourceRoot":"","sources":["../../src/constants/engine.constants.ts"],"names":[],"mappings":"AAAA,MAAM,CAAC,MAAM,kBAAkB,GAAG,IAAI,CAAC;AACvC,MAAM,CAAC,MAAM,kBAAkB,GAAG,MAAM,CAAC","sourcesContent":["export const ABSOLUTE_SCALE_MAX = 1000;\r\nexport const ABSOLUTE_SCALE_MIN = 0.0001;"]}
@@ -0,0 +1,7 @@
1
+ export var KritzelMouseButton;
2
+ (function (KritzelMouseButton) {
3
+ KritzelMouseButton[KritzelMouseButton["Left"] = 0] = "Left";
4
+ KritzelMouseButton[KritzelMouseButton["Middle"] = 1] = "Middle";
5
+ KritzelMouseButton[KritzelMouseButton["Right"] = 2] = "Right";
6
+ })(KritzelMouseButton || (KritzelMouseButton = {}));
7
+ //# sourceMappingURL=event-button.enum.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"event-button.enum.js","sourceRoot":"","sources":["../../src/enums/event-button.enum.ts"],"names":[],"mappings":"AAAA,MAAM,CAAN,IAAY,kBAIX;AAJD,WAAY,kBAAkB;IAC5B,2DAAQ,CAAA;IACR,+DAAU,CAAA;IACV,6DAAS,CAAA;AACX,CAAC,EAJW,kBAAkB,KAAlB,kBAAkB,QAI7B","sourcesContent":["export enum KritzelMouseButton {\r\n Left = 0,\r\n Middle = 1,\r\n Right = 2\r\n}\r\n"]}
@@ -0,0 +1,8 @@
1
+ export var KritzelHandleType;
2
+ (function (KritzelHandleType) {
3
+ KritzelHandleType["TopLeft"] = "top-left";
4
+ KritzelHandleType["TopRight"] = "top-right";
5
+ KritzelHandleType["BottomLeft"] = "bottom-left";
6
+ KritzelHandleType["BottomRight"] = "bottom-right";
7
+ })(KritzelHandleType || (KritzelHandleType = {}));
8
+ //# sourceMappingURL=handle-type.enum.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"handle-type.enum.js","sourceRoot":"","sources":["../../src/enums/handle-type.enum.ts"],"names":[],"mappings":"AAAA,MAAM,CAAN,IAAY,iBAKX;AALD,WAAY,iBAAiB;IACzB,yCAAoB,CAAA;IACpB,2CAAsB,CAAA;IACtB,+CAA0B,CAAA;IAC1B,iDAA4B,CAAA;AAChC,CAAC,EALW,iBAAiB,KAAjB,iBAAiB,QAK5B","sourcesContent":["export enum KritzelHandleType {\r\n TopLeft = \"top-left\",\r\n TopRight = \"top-right\",\r\n BottomLeft = \"bottom-left\",\r\n BottomRight = \"bottom-right\"\r\n}"]}
@@ -0,0 +1,6 @@
1
+ export class KritzelClassHelper {
2
+ static isInstanceOf(object, className) {
3
+ return object.__class__ === className;
4
+ }
5
+ }
6
+ //# sourceMappingURL=class.helper.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"class.helper.js","sourceRoot":"","sources":["../../src/helpers/class.helper.ts"],"names":[],"mappings":"AAAA,MAAM,OAAO,kBAAkB;IAC7B,MAAM,CAAC,YAAY,CAAI,MAAW,EAAE,SAAiB;QACnD,OAAO,MAAM,CAAC,SAAS,KAAK,SAAS,CAAC;IACxC,CAAC;CACF","sourcesContent":["export class KritzelClassHelper {\r\n static isInstanceOf<T>(object: any, className: string): object is T {\r\n return object.__class__ === className;\r\n }\r\n}"]}
@@ -0,0 +1,6 @@
1
+ export class KritzelDevicesHelper {
2
+ static isTouchDevice() {
3
+ return window.matchMedia('(any-pointer: coarse)').matches;
4
+ }
5
+ }
6
+ //# sourceMappingURL=devices.helper.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"devices.helper.js","sourceRoot":"","sources":["../../src/helpers/devices.helper.ts"],"names":[],"mappings":"AAAA,MAAM,OAAO,oBAAoB;IAC7B,MAAM,CAAC,aAAa;QAChB,OAAO,MAAM,CAAC,UAAU,CAAC,uBAAuB,CAAC,CAAC,OAAO,CAAC;IAC9D,CAAC;CACJ","sourcesContent":["export class KritzelDevicesHelper {\r\n static isTouchDevice(): boolean {\r\n return window.matchMedia('(any-pointer: coarse)').matches;\r\n }\r\n}"]}