@helpwave/hightide 0.0.18 → 0.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (655) hide show
  1. package/README.md +21 -2
  2. package/dist/coloring/shading.cjs +556 -0
  3. package/dist/coloring/shading.cjs.map +1 -0
  4. package/dist/coloring/{shading.d.mts → shading.d.cts} +1 -1
  5. package/dist/coloring/shading.js +476 -37
  6. package/dist/coloring/shading.js.map +1 -1
  7. package/dist/coloring/types.cjs +31 -0
  8. package/dist/coloring/{types.mjs.map → types.cjs.map} +1 -1
  9. package/dist/coloring/types.js +2 -27
  10. package/dist/coloring/types.js.map +1 -1
  11. package/dist/components/{HelpwaveBadge.js → branding/HelpwaveBadge.cjs} +65 -33
  12. package/dist/components/branding/HelpwaveBadge.cjs.map +1 -0
  13. package/dist/components/branding/HelpwaveBadge.js +123 -0
  14. package/dist/components/branding/HelpwaveBadge.js.map +1 -0
  15. package/dist/components/date/{DatePicker.mjs → DatePicker.cjs} +158 -94
  16. package/dist/components/date/DatePicker.cjs.map +1 -0
  17. package/dist/components/date/{DatePicker.d.mts → DatePicker.d.cts} +7 -8
  18. package/dist/components/date/DatePicker.d.ts +4 -5
  19. package/dist/components/date/DatePicker.js +121 -129
  20. package/dist/components/date/DatePicker.js.map +1 -1
  21. package/dist/components/date/{DayPicker.mjs → DayPicker.cjs} +77 -24
  22. package/dist/components/date/DayPicker.cjs.map +1 -0
  23. package/dist/components/date/{DayPicker.d.mts → DayPicker.d.cts} +3 -3
  24. package/dist/components/date/DayPicker.d.ts +2 -2
  25. package/dist/components/date/DayPicker.js +38 -61
  26. package/dist/components/date/DayPicker.js.map +1 -1
  27. package/dist/components/{TimeDisplay.js → date/TimeDisplay.cjs} +24 -9
  28. package/dist/components/date/TimeDisplay.cjs.map +1 -0
  29. package/dist/components/{TimeDisplay.d.mts → date/TimeDisplay.d.cts} +2 -3
  30. package/dist/components/{TimeDisplay.d.ts → date/TimeDisplay.d.ts} +2 -3
  31. package/dist/components/{TimeDisplay.mjs → date/TimeDisplay.js} +23 -8
  32. package/dist/components/date/TimeDisplay.js.map +1 -0
  33. package/dist/components/date/{TimePicker.mjs → TimePicker.cjs} +62 -26
  34. package/dist/components/date/TimePicker.cjs.map +1 -0
  35. package/dist/components/date/{TimePicker.d.mts → TimePicker.d.cts} +2 -2
  36. package/dist/components/date/TimePicker.d.ts +2 -2
  37. package/dist/components/date/TimePicker.js +25 -61
  38. package/dist/components/date/TimePicker.js.map +1 -1
  39. package/dist/components/date/{YearMonthPicker.mjs → YearMonthPicker.cjs} +93 -42
  40. package/dist/components/date/YearMonthPicker.cjs.map +1 -0
  41. package/dist/components/date/{YearMonthPicker.d.mts → YearMonthPicker.d.cts} +2 -2
  42. package/dist/components/date/YearMonthPicker.d.ts +2 -2
  43. package/dist/components/date/YearMonthPicker.js +56 -77
  44. package/dist/components/date/YearMonthPicker.js.map +1 -1
  45. package/dist/components/{AvatarGroup.js → icons-and-geometry/Avatar.cjs} +23 -19
  46. package/dist/components/icons-and-geometry/Avatar.cjs.map +1 -0
  47. package/dist/components/icons-and-geometry/Avatar.d.cts +30 -0
  48. package/dist/components/icons-and-geometry/Avatar.d.ts +30 -0
  49. package/dist/components/{AvatarGroup.mjs → icons-and-geometry/Avatar.js} +13 -10
  50. package/dist/components/icons-and-geometry/Avatar.js.map +1 -0
  51. package/dist/components/{Circle.js → icons-and-geometry/Circle.cjs} +3 -3
  52. package/dist/components/icons-and-geometry/Circle.cjs.map +1 -0
  53. package/dist/components/{Circle.mjs → icons-and-geometry/Circle.js} +2 -2
  54. package/dist/components/icons-and-geometry/Circle.js.map +1 -0
  55. package/dist/components/{icons/Helpwave.js → icons-and-geometry/Helpwave.cjs} +38 -6
  56. package/dist/components/icons-and-geometry/Helpwave.cjs.map +1 -0
  57. package/dist/components/icons-and-geometry/Helpwave.js +75 -0
  58. package/dist/components/icons-and-geometry/Helpwave.js.map +1 -0
  59. package/dist/components/{Ring.js → icons-and-geometry/Ring.cjs} +6 -6
  60. package/dist/components/icons-and-geometry/Ring.cjs.map +1 -0
  61. package/dist/components/{Ring.mjs → icons-and-geometry/Ring.js} +4 -4
  62. package/dist/components/icons-and-geometry/Ring.js.map +1 -0
  63. package/dist/components/{icons/Tag.js → icons-and-geometry/Tag.cjs} +3 -3
  64. package/dist/components/icons-and-geometry/Tag.cjs.map +1 -0
  65. package/dist/components/{icons/Tag.mjs → icons-and-geometry/Tag.js} +2 -2
  66. package/dist/components/icons-and-geometry/Tag.js.map +1 -0
  67. package/dist/components/{BreadCrumb.js → layout-and-navigation/BreadCrumb.cjs} +12 -5
  68. package/dist/components/layout-and-navigation/BreadCrumb.cjs.map +1 -0
  69. package/dist/components/{BreadCrumb.mjs → layout-and-navigation/BreadCrumb.js} +10 -3
  70. package/dist/components/layout-and-navigation/BreadCrumb.js.map +1 -0
  71. package/dist/components/{layout/Carousel.js → layout-and-navigation/Carousel.cjs} +4 -4
  72. package/dist/components/layout-and-navigation/Carousel.cjs.map +1 -0
  73. package/dist/components/{layout/Carousel.mjs → layout-and-navigation/Carousel.js} +4 -4
  74. package/dist/components/layout-and-navigation/Carousel.js.map +1 -0
  75. package/dist/components/{ChipList.js → layout-and-navigation/Chip.cjs} +6 -6
  76. package/dist/components/layout-and-navigation/Chip.cjs.map +1 -0
  77. package/dist/components/{ChipList.mjs → layout-and-navigation/Chip.js} +2 -2
  78. package/dist/components/layout-and-navigation/Chip.js.map +1 -0
  79. package/dist/components/{layout/DividerInserter.js → layout-and-navigation/DividerInserter.cjs} +3 -3
  80. package/dist/components/layout-and-navigation/DividerInserter.cjs.map +1 -0
  81. package/dist/components/{layout/DividerInserter.mjs → layout-and-navigation/DividerInserter.js} +2 -2
  82. package/dist/components/layout-and-navigation/DividerInserter.js.map +1 -0
  83. package/dist/components/{Expandable.js → layout-and-navigation/Expandable.cjs} +3 -3
  84. package/dist/components/layout-and-navigation/Expandable.cjs.map +1 -0
  85. package/dist/components/{Expandable.mjs → layout-and-navigation/Expandable.js} +2 -2
  86. package/dist/components/layout-and-navigation/Expandable.js.map +1 -0
  87. package/dist/components/{layout/FAQSection.js → layout-and-navigation/FAQSection.cjs} +7 -7
  88. package/dist/components/layout-and-navigation/FAQSection.cjs.map +1 -0
  89. package/dist/components/{layout/FAQSection.d.mts → layout-and-navigation/FAQSection.d.cts} +1 -1
  90. package/dist/components/{layout → layout-and-navigation}/FAQSection.d.ts +1 -1
  91. package/dist/components/{layout/FAQSection.mjs → layout-and-navigation/FAQSection.js} +5 -5
  92. package/dist/components/layout-and-navigation/FAQSection.js.map +1 -0
  93. package/dist/components/{MarkdownInterpreter.js → layout-and-navigation/MarkdownInterpreter.cjs} +2 -2
  94. package/dist/components/layout-and-navigation/MarkdownInterpreter.cjs.map +1 -0
  95. package/dist/components/{MarkdownInterpreter.mjs → layout-and-navigation/MarkdownInterpreter.js} +2 -2
  96. package/dist/components/layout-and-navigation/MarkdownInterpreter.js.map +1 -0
  97. package/dist/components/layout-and-navigation/Overlay.cjs +467 -0
  98. package/dist/components/layout-and-navigation/Overlay.cjs.map +1 -0
  99. package/dist/components/layout-and-navigation/Overlay.d.cts +63 -0
  100. package/dist/components/layout-and-navigation/Overlay.d.ts +63 -0
  101. package/dist/components/layout-and-navigation/Overlay.js +429 -0
  102. package/dist/components/layout-and-navigation/Overlay.js.map +1 -0
  103. package/dist/components/{Pagination.js → layout-and-navigation/Pagination.cjs} +25 -10
  104. package/dist/components/layout-and-navigation/Pagination.cjs.map +1 -0
  105. package/dist/components/{Pagination.d.mts → layout-and-navigation/Pagination.d.cts} +2 -3
  106. package/dist/components/{Pagination.d.ts → layout-and-navigation/Pagination.d.ts} +2 -3
  107. package/dist/components/{Pagination.mjs → layout-and-navigation/Pagination.js} +25 -10
  108. package/dist/components/layout-and-navigation/Pagination.js.map +1 -0
  109. package/dist/components/{SearchableList.js → layout-and-navigation/SearchableList.cjs} +51 -34
  110. package/dist/components/layout-and-navigation/SearchableList.cjs.map +1 -0
  111. package/dist/components/{SearchableList.d.mts → layout-and-navigation/SearchableList.d.cts} +2 -2
  112. package/dist/components/{SearchableList.d.ts → layout-and-navigation/SearchableList.d.ts} +2 -2
  113. package/dist/components/{SearchableList.mjs → layout-and-navigation/SearchableList.js} +52 -40
  114. package/dist/components/layout-and-navigation/SearchableList.js.map +1 -0
  115. package/dist/components/{StepperBar.js → layout-and-navigation/StepperBar.cjs} +42 -16
  116. package/dist/components/layout-and-navigation/StepperBar.cjs.map +1 -0
  117. package/dist/components/{StepperBar.d.mts → layout-and-navigation/StepperBar.d.cts} +2 -3
  118. package/dist/components/{StepperBar.d.ts → layout-and-navigation/StepperBar.d.ts} +2 -3
  119. package/dist/components/{StepperBar.mjs → layout-and-navigation/StepperBar.js} +40 -14
  120. package/dist/components/layout-and-navigation/StepperBar.js.map +1 -0
  121. package/dist/components/{Table.js → layout-and-navigation/Table.cjs} +176 -40
  122. package/dist/components/layout-and-navigation/Table.cjs.map +1 -0
  123. package/dist/components/{Table.d.mts → layout-and-navigation/Table.d.cts} +10 -1
  124. package/dist/components/{Table.d.ts → layout-and-navigation/Table.d.ts} +10 -1
  125. package/dist/components/{Table.mjs → layout-and-navigation/Table.js} +175 -40
  126. package/dist/components/layout-and-navigation/Table.js.map +1 -0
  127. package/dist/components/{TextImage.js → layout-and-navigation/TextImage.cjs} +25 -10
  128. package/dist/components/layout-and-navigation/TextImage.cjs.map +1 -0
  129. package/dist/components/{TextImage.d.mts → layout-and-navigation/TextImage.d.cts} +2 -3
  130. package/dist/components/{TextImage.d.ts → layout-and-navigation/TextImage.d.ts} +2 -3
  131. package/dist/components/{TextImage.mjs → layout-and-navigation/TextImage.js} +23 -8
  132. package/dist/components/layout-and-navigation/TextImage.js.map +1 -0
  133. package/dist/components/{layout/Tile.js → layout-and-navigation/Tile.cjs} +4 -4
  134. package/dist/components/layout-and-navigation/Tile.cjs.map +1 -0
  135. package/dist/components/{layout/Tile.mjs → layout-and-navigation/Tile.js} +2 -2
  136. package/dist/components/layout-and-navigation/Tile.js.map +1 -0
  137. package/dist/components/{VerticalDivider.js → layout-and-navigation/VerticalDivider.cjs} +2 -2
  138. package/dist/components/layout-and-navigation/VerticalDivider.cjs.map +1 -0
  139. package/dist/components/{VerticalDivider.mjs → layout-and-navigation/VerticalDivider.js} +2 -2
  140. package/dist/components/layout-and-navigation/VerticalDivider.js.map +1 -0
  141. package/dist/components/{ErrorComponent.js → loading-states/ErrorComponent.cjs} +25 -10
  142. package/dist/components/loading-states/ErrorComponent.cjs.map +1 -0
  143. package/dist/components/{ErrorComponent.d.mts → loading-states/ErrorComponent.d.cts} +2 -3
  144. package/dist/components/{ErrorComponent.d.ts → loading-states/ErrorComponent.d.ts} +2 -3
  145. package/dist/components/{ErrorComponent.mjs → loading-states/ErrorComponent.js} +24 -9
  146. package/dist/components/loading-states/ErrorComponent.js.map +1 -0
  147. package/dist/components/{LoadingAndErrorComponent.js → loading-states/LoadingAndErrorComponent.cjs} +67 -18
  148. package/dist/components/loading-states/LoadingAndErrorComponent.cjs.map +1 -0
  149. package/dist/components/{LoadingAndErrorComponent.d.mts → loading-states/LoadingAndErrorComponent.d.cts} +6 -6
  150. package/dist/components/{LoadingAndErrorComponent.d.ts → loading-states/LoadingAndErrorComponent.d.ts} +4 -4
  151. package/dist/components/{LoadingAndErrorComponent.mjs → loading-states/LoadingAndErrorComponent.js} +66 -17
  152. package/dist/components/loading-states/LoadingAndErrorComponent.js.map +1 -0
  153. package/dist/components/{LoadingAnimation.js → loading-states/LoadingAnimation.cjs} +64 -15
  154. package/dist/components/loading-states/LoadingAnimation.cjs.map +1 -0
  155. package/dist/components/{LoadingAnimation.d.mts → loading-states/LoadingAnimation.d.cts} +2 -3
  156. package/dist/components/{LoadingAnimation.d.ts → loading-states/LoadingAnimation.d.ts} +2 -3
  157. package/dist/components/{LoadingAnimation.mjs → loading-states/LoadingAnimation.js} +63 -14
  158. package/dist/components/loading-states/LoadingAnimation.js.map +1 -0
  159. package/dist/components/{LoadingButton.js → loading-states/LoadingButton.cjs} +101 -58
  160. package/dist/components/loading-states/LoadingButton.cjs.map +1 -0
  161. package/dist/components/{LoadingButton.d.mts → loading-states/LoadingButton.d.cts} +1 -1
  162. package/dist/components/{LoadingButton.d.ts → loading-states/LoadingButton.d.ts} +1 -1
  163. package/dist/components/{LoadingButton.mjs → loading-states/LoadingButton.js} +100 -57
  164. package/dist/components/loading-states/LoadingButton.js.map +1 -0
  165. package/dist/components/{ProgressIndicator.js → loading-states/ProgressIndicator.cjs} +2 -2
  166. package/dist/components/loading-states/ProgressIndicator.cjs.map +1 -0
  167. package/dist/components/{ProgressIndicator.mjs → loading-states/ProgressIndicator.js} +2 -2
  168. package/dist/components/loading-states/ProgressIndicator.js.map +1 -0
  169. package/dist/components/modals/ConfirmDialog.cjs +353 -0
  170. package/dist/components/modals/ConfirmDialog.cjs.map +1 -0
  171. package/dist/components/modals/{ConfirmDialog.d.mts → ConfirmDialog.d.cts} +6 -6
  172. package/dist/components/modals/ConfirmDialog.d.ts +6 -6
  173. package/dist/components/modals/ConfirmDialog.js +157 -266
  174. package/dist/components/modals/ConfirmDialog.js.map +1 -1
  175. package/dist/components/modals/{DiscardChangesDialog.js → DiscardChangesModal.cjs} +213 -117
  176. package/dist/components/modals/DiscardChangesModal.cjs.map +1 -0
  177. package/dist/components/modals/DiscardChangesModal.d.cts +23 -0
  178. package/dist/components/modals/DiscardChangesModal.d.ts +23 -0
  179. package/dist/components/modals/{DiscardChangesDialog.mjs → DiscardChangesModal.js} +202 -106
  180. package/dist/components/modals/DiscardChangesModal.js.map +1 -0
  181. package/dist/components/modals/InputModal.cjs +533 -0
  182. package/dist/components/modals/InputModal.cjs.map +1 -0
  183. package/dist/components/modals/{InputModal.d.mts → InputModal.d.cts} +7 -7
  184. package/dist/components/modals/InputModal.d.ts +6 -6
  185. package/dist/components/modals/InputModal.js +197 -299
  186. package/dist/components/modals/InputModal.js.map +1 -1
  187. package/dist/components/modals/LanguageModal.cjs +667 -0
  188. package/dist/components/modals/LanguageModal.cjs.map +1 -0
  189. package/dist/components/modals/LanguageModal.d.cts +20 -0
  190. package/dist/components/modals/LanguageModal.d.ts +7 -8
  191. package/dist/components/modals/LanguageModal.js +308 -204
  192. package/dist/components/modals/LanguageModal.js.map +1 -1
  193. package/dist/components/modals/ThemeModal.cjs +694 -0
  194. package/dist/components/modals/ThemeModal.cjs.map +1 -0
  195. package/dist/components/modals/ThemeModal.d.cts +21 -0
  196. package/dist/components/modals/ThemeModal.d.ts +21 -0
  197. package/dist/components/modals/ThemeModal.js +657 -0
  198. package/dist/components/modals/ThemeModal.js.map +1 -0
  199. package/dist/components/properties/CheckboxProperty.cjs +362 -0
  200. package/dist/components/properties/CheckboxProperty.cjs.map +1 -0
  201. package/dist/components/properties/{CheckboxProperty.d.mts → CheckboxProperty.d.cts} +3 -3
  202. package/dist/components/properties/CheckboxProperty.d.ts +2 -2
  203. package/dist/components/properties/CheckboxProperty.js +94 -93
  204. package/dist/components/properties/CheckboxProperty.js.map +1 -1
  205. package/dist/components/properties/DateProperty.cjs +451 -0
  206. package/dist/components/properties/DateProperty.cjs.map +1 -0
  207. package/dist/components/properties/{DateProperty.d.mts → DateProperty.d.cts} +3 -3
  208. package/dist/components/properties/DateProperty.d.ts +2 -2
  209. package/dist/components/properties/DateProperty.js +110 -116
  210. package/dist/components/properties/DateProperty.js.map +1 -1
  211. package/dist/components/properties/{MultiSelectProperty.mjs → MultiSelectProperty.cjs} +216 -155
  212. package/dist/components/properties/MultiSelectProperty.cjs.map +1 -0
  213. package/dist/components/properties/{MultiSelectProperty.d.mts → MultiSelectProperty.d.cts} +5 -5
  214. package/dist/components/properties/MultiSelectProperty.d.ts +4 -4
  215. package/dist/components/properties/MultiSelectProperty.js +180 -184
  216. package/dist/components/properties/MultiSelectProperty.js.map +1 -1
  217. package/dist/components/properties/NumberProperty.cjs +459 -0
  218. package/dist/components/properties/NumberProperty.cjs.map +1 -0
  219. package/dist/components/properties/{NumberProperty.d.mts → NumberProperty.d.cts} +3 -3
  220. package/dist/components/properties/NumberProperty.d.ts +2 -2
  221. package/dist/components/properties/NumberProperty.js +109 -116
  222. package/dist/components/properties/NumberProperty.js.map +1 -1
  223. package/dist/components/properties/PropertyBase.cjs +223 -0
  224. package/dist/components/properties/PropertyBase.cjs.map +1 -0
  225. package/dist/components/properties/{PropertyBase.d.mts → PropertyBase.d.cts} +2 -2
  226. package/dist/components/properties/PropertyBase.d.ts +2 -2
  227. package/dist/components/properties/PropertyBase.js +60 -69
  228. package/dist/components/properties/PropertyBase.js.map +1 -1
  229. package/dist/components/properties/{SelectProperty.mjs → SelectProperty.cjs} +251 -199
  230. package/dist/components/properties/SelectProperty.cjs.map +1 -0
  231. package/dist/components/properties/{SelectProperty.d.mts → SelectProperty.d.cts} +5 -6
  232. package/dist/components/properties/SelectProperty.d.ts +4 -5
  233. package/dist/components/properties/SelectProperty.js +215 -228
  234. package/dist/components/properties/SelectProperty.js.map +1 -1
  235. package/dist/components/properties/TextProperty.cjs +428 -0
  236. package/dist/components/properties/TextProperty.cjs.map +1 -0
  237. package/dist/components/properties/{TextProperty.d.mts → TextProperty.d.cts} +3 -3
  238. package/dist/components/properties/TextProperty.d.ts +2 -2
  239. package/dist/components/properties/TextProperty.js +134 -121
  240. package/dist/components/properties/TextProperty.js.map +1 -1
  241. package/dist/components/{Button.js → user-action/Button.cjs} +70 -12
  242. package/dist/components/user-action/Button.cjs.map +1 -0
  243. package/dist/components/{Button.d.mts → user-action/Button.d.cts} +32 -5
  244. package/dist/components/{Button.d.ts → user-action/Button.d.ts} +32 -5
  245. package/dist/components/{Button.mjs → user-action/Button.js} +66 -10
  246. package/dist/components/user-action/Button.js.map +1 -0
  247. package/dist/components/{user-input/Checkbox.js → user-action/Checkbox.cjs} +26 -16
  248. package/dist/components/user-action/Checkbox.cjs.map +1 -0
  249. package/dist/components/{user-input/Checkbox.d.mts → user-action/Checkbox.d.cts} +5 -5
  250. package/dist/components/{user-input → user-action}/Checkbox.d.ts +4 -4
  251. package/dist/components/{user-input/Checkbox.mjs → user-action/Checkbox.js} +24 -14
  252. package/dist/components/user-action/Checkbox.js.map +1 -0
  253. package/dist/components/{user-input/DateAndTimePicker.js → user-action/DateAndTimePicker.cjs} +51 -23
  254. package/dist/components/user-action/DateAndTimePicker.cjs.map +1 -0
  255. package/dist/components/{user-input/DateAndTimePicker.d.mts → user-action/DateAndTimePicker.d.cts} +7 -8
  256. package/dist/components/{user-input → user-action}/DateAndTimePicker.d.ts +2 -3
  257. package/dist/components/{user-input/DateAndTimePicker.mjs → user-action/DateAndTimePicker.js} +44 -16
  258. package/dist/components/user-action/DateAndTimePicker.js.map +1 -0
  259. package/dist/components/{user-input/Input.js → user-action/Input.cjs} +35 -34
  260. package/dist/components/user-action/Input.cjs.map +1 -0
  261. package/dist/components/{user-input/Input.d.mts → user-action/Input.d.cts} +9 -16
  262. package/dist/components/{user-input → user-action}/Input.d.ts +8 -15
  263. package/dist/components/{user-input/Input.mjs → user-action/Input.js} +35 -39
  264. package/dist/components/user-action/Input.js.map +1 -0
  265. package/dist/components/{user-input/Label.js → user-action/Label.cjs} +15 -3
  266. package/dist/components/user-action/Label.cjs.map +1 -0
  267. package/dist/components/{user-input/Label.d.mts → user-action/Label.d.cts} +1 -1
  268. package/dist/components/{user-input → user-action}/Label.d.ts +1 -1
  269. package/dist/components/{user-input/Label.mjs → user-action/Label.js} +5 -3
  270. package/dist/components/user-action/Label.js.map +1 -0
  271. package/dist/components/{user-input/Menu.js → user-action/Menu.cjs} +4 -4
  272. package/dist/components/user-action/Menu.cjs.map +1 -0
  273. package/dist/components/{user-input/Menu.mjs → user-action/Menu.js} +3 -3
  274. package/dist/components/user-action/Menu.js.map +1 -0
  275. package/dist/components/{user-input/MultiSelect.js → user-action/MultiSelect.cjs} +76 -51
  276. package/dist/components/user-action/MultiSelect.cjs.map +1 -0
  277. package/dist/components/{user-input/MultiSelect.d.mts → user-action/MultiSelect.d.cts} +3 -3
  278. package/dist/components/{user-input → user-action}/MultiSelect.d.ts +2 -2
  279. package/dist/components/{user-input/MultiSelect.mjs → user-action/MultiSelect.js} +75 -55
  280. package/dist/components/user-action/MultiSelect.js.map +1 -0
  281. package/dist/components/{user-input/ScrollPicker.js → user-action/ScrollPicker.cjs} +4 -4
  282. package/dist/components/user-action/ScrollPicker.cjs.map +1 -0
  283. package/dist/components/{user-input/ScrollPicker.mjs → user-action/ScrollPicker.js} +3 -3
  284. package/dist/components/user-action/ScrollPicker.js.map +1 -0
  285. package/dist/components/{user-input/SearchableSelect.js → user-action/Select.cjs} +181 -152
  286. package/dist/components/user-action/Select.cjs.map +1 -0
  287. package/dist/components/user-action/Select.d.cts +49 -0
  288. package/dist/components/user-action/Select.d.ts +49 -0
  289. package/dist/components/{user-input/SearchableSelect.mjs → user-action/Select.js} +167 -145
  290. package/dist/components/user-action/Select.js.map +1 -0
  291. package/dist/components/{user-input/Textarea.js → user-action/Textarea.cjs} +80 -35
  292. package/dist/components/user-action/Textarea.cjs.map +1 -0
  293. package/dist/components/user-action/Textarea.d.cts +28 -0
  294. package/dist/components/{user-input → user-action}/Textarea.d.ts +9 -5
  295. package/dist/components/user-action/Textarea.js +163 -0
  296. package/dist/components/user-action/Textarea.js.map +1 -0
  297. package/dist/components/{user-input/ToggleableInput.js → user-action/ToggleableInput.cjs} +9 -15
  298. package/dist/components/user-action/ToggleableInput.cjs.map +1 -0
  299. package/dist/components/{user-input/ToggleableInput.mjs → user-action/ToggleableInput.js} +8 -14
  300. package/dist/components/user-action/ToggleableInput.js.map +1 -0
  301. package/dist/components/{Tooltip.js → user-action/Tooltip.cjs} +13 -9
  302. package/dist/components/user-action/Tooltip.cjs.map +1 -0
  303. package/dist/components/{Tooltip.d.mts → user-action/Tooltip.d.cts} +1 -1
  304. package/dist/components/{Tooltip.d.ts → user-action/Tooltip.d.ts} +1 -1
  305. package/dist/components/{Tooltip.mjs → user-action/Tooltip.js} +12 -8
  306. package/dist/components/user-action/Tooltip.js.map +1 -0
  307. package/dist/css/globals.css +178 -126
  308. package/dist/css/uncompiled/globals.css +65 -29
  309. package/dist/hooks/useHoverState.cjs +72 -0
  310. package/dist/hooks/{useHoverState.mjs.map → useHoverState.cjs.map} +1 -1
  311. package/dist/hooks/useHoverState.js +7 -32
  312. package/dist/hooks/useHoverState.js.map +1 -1
  313. package/dist/hooks/useLocalStorage.cjs +83 -0
  314. package/dist/hooks/useLocalStorage.cjs.map +1 -0
  315. package/dist/hooks/useLocalStorage.js +9 -34
  316. package/dist/hooks/useLocalStorage.js.map +1 -1
  317. package/dist/hooks/useOutsideClick.cjs +48 -0
  318. package/dist/hooks/{useOutsideClick.mjs.map → useOutsideClick.cjs.map} +1 -1
  319. package/dist/hooks/useOutsideClick.js +4 -29
  320. package/dist/hooks/useOutsideClick.js.map +1 -1
  321. package/dist/hooks/useSaveDelay.cjs +68 -0
  322. package/dist/hooks/{useSaveDelay.mjs.map → useSaveDelay.cjs.map} +1 -1
  323. package/dist/hooks/useSaveDelay.js +6 -31
  324. package/dist/hooks/useSaveDelay.js.map +1 -1
  325. package/dist/{index.mjs → index.cjs} +4008 -3882
  326. package/dist/index.cjs.map +1 -0
  327. package/dist/index.d.cts +82 -0
  328. package/dist/index.d.ts +49 -55
  329. package/dist/index.js +3825 -4056
  330. package/dist/index.js.map +1 -1
  331. package/dist/{hooks/useLanguage.js → localization/LanguageProvider.cjs} +30 -26
  332. package/dist/localization/LanguageProvider.cjs.map +1 -0
  333. package/dist/localization/LanguageProvider.d.cts +18 -0
  334. package/dist/localization/LanguageProvider.d.ts +18 -0
  335. package/dist/{hooks/useLanguage.mjs → localization/LanguageProvider.js} +26 -19
  336. package/dist/localization/LanguageProvider.js.map +1 -0
  337. package/dist/{hooks/useTranslation.js → localization/useTranslation.cjs} +23 -8
  338. package/dist/localization/useTranslation.cjs.map +1 -0
  339. package/dist/{hooks/useTranslation.d.mts → localization/useTranslation.d.cts} +5 -7
  340. package/dist/{hooks → localization}/useTranslation.d.ts +5 -7
  341. package/dist/{hooks/useTranslation.mjs → localization/useTranslation.js} +22 -7
  342. package/dist/localization/useTranslation.js.map +1 -0
  343. package/dist/localization/util.cjs +41 -0
  344. package/dist/localization/util.cjs.map +1 -0
  345. package/dist/localization/util.d.cts +18 -0
  346. package/dist/localization/util.d.ts +18 -0
  347. package/dist/localization/util.js +16 -0
  348. package/dist/localization/util.js.map +1 -0
  349. package/dist/{hooks/useTheme.js → theming/useTheme.cjs} +19 -11
  350. package/dist/theming/useTheme.cjs.map +1 -0
  351. package/dist/{hooks/useTheme.d.mts → theming/useTheme.d.cts} +9 -5
  352. package/dist/{hooks → theming}/useTheme.d.ts +9 -5
  353. package/dist/{hooks/useTheme.mjs → theming/useTheme.js} +15 -7
  354. package/dist/theming/useTheme.js.map +1 -0
  355. package/dist/util/{array.mjs → array.cjs} +34 -3
  356. package/dist/util/array.cjs.map +1 -0
  357. package/dist/util/array.js +2 -33
  358. package/dist/util/array.js.map +1 -1
  359. package/dist/util/builder.cjs +34 -0
  360. package/dist/util/{builder.mjs.map → builder.cjs.map} +1 -1
  361. package/dist/util/builder.js +2 -27
  362. package/dist/util/builder.js.map +1 -1
  363. package/dist/util/{date.mjs → date.cjs} +41 -3
  364. package/dist/util/date.cjs.map +1 -0
  365. package/dist/util/date.js +2 -40
  366. package/dist/util/date.js.map +1 -1
  367. package/dist/util/easeFunctions.cjs +63 -0
  368. package/dist/util/easeFunctions.cjs.map +1 -0
  369. package/dist/util/easeFunctions.js +2 -29
  370. package/dist/util/easeFunctions.js.map +1 -1
  371. package/dist/util/emailValidation.cjs +33 -0
  372. package/dist/util/{emailValidation.mjs.map → emailValidation.cjs.map} +1 -1
  373. package/dist/util/emailValidation.js +2 -27
  374. package/dist/util/emailValidation.js.map +1 -1
  375. package/dist/util/{loopingArray.mjs → loopingArray.cjs} +28 -3
  376. package/dist/util/{loopingArray.mjs.map → loopingArray.cjs.map} +1 -1
  377. package/dist/util/loopingArray.js +2 -27
  378. package/dist/util/loopingArray.js.map +1 -1
  379. package/dist/util/math.cjs +33 -0
  380. package/dist/util/{math.mjs.map → math.cjs.map} +1 -1
  381. package/dist/util/math.js +2 -27
  382. package/dist/util/math.js.map +1 -1
  383. package/dist/util/news.cjs +77 -0
  384. package/dist/util/news.cjs.map +1 -0
  385. package/dist/util/{news.d.mts → news.d.cts} +11 -13
  386. package/dist/util/news.d.ts +11 -13
  387. package/dist/util/news.js +22 -49
  388. package/dist/util/news.js.map +1 -1
  389. package/dist/util/noop.cjs +31 -0
  390. package/dist/util/noop.cjs.map +1 -0
  391. package/dist/util/noop.js +2 -27
  392. package/dist/util/noop.js.map +1 -1
  393. package/dist/util/simpleSearch.cjs +54 -0
  394. package/dist/util/simpleSearch.cjs.map +1 -0
  395. package/dist/util/simpleSearch.js +2 -30
  396. package/dist/util/simpleSearch.js.map +1 -1
  397. package/dist/util/storage.cjs +64 -0
  398. package/dist/util/storage.cjs.map +1 -0
  399. package/dist/util/storage.js +2 -28
  400. package/dist/util/storage.js.map +1 -1
  401. package/dist/util/types.cjs +19 -0
  402. package/dist/util/types.cjs.map +1 -0
  403. package/dist/util/types.js +0 -18
  404. package/dist/util/types.js.map +1 -1
  405. package/package.json +9 -12
  406. package/dist/coloring/shading.mjs +0 -47
  407. package/dist/coloring/shading.mjs.map +0 -1
  408. package/dist/coloring/types.mjs +0 -6
  409. package/dist/components/Avatar.d.mts +0 -17
  410. package/dist/components/Avatar.d.ts +0 -17
  411. package/dist/components/Avatar.js +0 -85
  412. package/dist/components/Avatar.js.map +0 -1
  413. package/dist/components/Avatar.mjs +0 -48
  414. package/dist/components/Avatar.mjs.map +0 -1
  415. package/dist/components/AvatarGroup.d.mts +0 -14
  416. package/dist/components/AvatarGroup.d.ts +0 -14
  417. package/dist/components/AvatarGroup.js.map +0 -1
  418. package/dist/components/AvatarGroup.mjs.map +0 -1
  419. package/dist/components/BreadCrumb.js.map +0 -1
  420. package/dist/components/BreadCrumb.mjs.map +0 -1
  421. package/dist/components/Button.js.map +0 -1
  422. package/dist/components/Button.mjs.map +0 -1
  423. package/dist/components/ChipList.js.map +0 -1
  424. package/dist/components/ChipList.mjs.map +0 -1
  425. package/dist/components/Circle.js.map +0 -1
  426. package/dist/components/Circle.mjs.map +0 -1
  427. package/dist/components/ErrorComponent.js.map +0 -1
  428. package/dist/components/ErrorComponent.mjs.map +0 -1
  429. package/dist/components/Expandable.js.map +0 -1
  430. package/dist/components/Expandable.mjs.map +0 -1
  431. package/dist/components/HelpwaveBadge.js.map +0 -1
  432. package/dist/components/HelpwaveBadge.mjs +0 -91
  433. package/dist/components/HelpwaveBadge.mjs.map +0 -1
  434. package/dist/components/HideableContentSection.d.mts +0 -14
  435. package/dist/components/HideableContentSection.d.ts +0 -14
  436. package/dist/components/HideableContentSection.js +0 -70
  437. package/dist/components/HideableContentSection.js.map +0 -1
  438. package/dist/components/HideableContentSection.mjs +0 -35
  439. package/dist/components/HideableContentSection.mjs.map +0 -1
  440. package/dist/components/InputGroup.d.mts +0 -17
  441. package/dist/components/InputGroup.d.ts +0 -17
  442. package/dist/components/InputGroup.js +0 -97
  443. package/dist/components/InputGroup.js.map +0 -1
  444. package/dist/components/InputGroup.mjs +0 -62
  445. package/dist/components/InputGroup.mjs.map +0 -1
  446. package/dist/components/LoadingAndErrorComponent.js.map +0 -1
  447. package/dist/components/LoadingAndErrorComponent.mjs.map +0 -1
  448. package/dist/components/LoadingAnimation.js.map +0 -1
  449. package/dist/components/LoadingAnimation.mjs.map +0 -1
  450. package/dist/components/LoadingButton.js.map +0 -1
  451. package/dist/components/LoadingButton.mjs.map +0 -1
  452. package/dist/components/MarkdownInterpreter.js.map +0 -1
  453. package/dist/components/MarkdownInterpreter.mjs.map +0 -1
  454. package/dist/components/Pagination.js.map +0 -1
  455. package/dist/components/Pagination.mjs.map +0 -1
  456. package/dist/components/Profile.d.mts +0 -31
  457. package/dist/components/Profile.d.ts +0 -31
  458. package/dist/components/Profile.js +0 -197
  459. package/dist/components/Profile.js.map +0 -1
  460. package/dist/components/Profile.mjs +0 -162
  461. package/dist/components/Profile.mjs.map +0 -1
  462. package/dist/components/ProgressIndicator.js.map +0 -1
  463. package/dist/components/ProgressIndicator.mjs.map +0 -1
  464. package/dist/components/Ring.js.map +0 -1
  465. package/dist/components/Ring.mjs.map +0 -1
  466. package/dist/components/SearchableList.js.map +0 -1
  467. package/dist/components/SearchableList.mjs.map +0 -1
  468. package/dist/components/SortButton.d.mts +0 -15
  469. package/dist/components/SortButton.d.ts +0 -15
  470. package/dist/components/SortButton.js +0 -132
  471. package/dist/components/SortButton.js.map +0 -1
  472. package/dist/components/SortButton.mjs +0 -97
  473. package/dist/components/SortButton.mjs.map +0 -1
  474. package/dist/components/StepperBar.js.map +0 -1
  475. package/dist/components/StepperBar.mjs.map +0 -1
  476. package/dist/components/Table.js.map +0 -1
  477. package/dist/components/Table.mjs.map +0 -1
  478. package/dist/components/TechRadar.d.mts +0 -39
  479. package/dist/components/TechRadar.d.ts +0 -39
  480. package/dist/components/TechRadar.js +0 -243
  481. package/dist/components/TechRadar.js.map +0 -1
  482. package/dist/components/TechRadar.mjs +0 -208
  483. package/dist/components/TechRadar.mjs.map +0 -1
  484. package/dist/components/TextImage.js.map +0 -1
  485. package/dist/components/TextImage.mjs.map +0 -1
  486. package/dist/components/TimeDisplay.js.map +0 -1
  487. package/dist/components/TimeDisplay.mjs.map +0 -1
  488. package/dist/components/Tooltip.js.map +0 -1
  489. package/dist/components/Tooltip.mjs.map +0 -1
  490. package/dist/components/VerticalDivider.js.map +0 -1
  491. package/dist/components/VerticalDivider.mjs.map +0 -1
  492. package/dist/components/date/DatePicker.mjs.map +0 -1
  493. package/dist/components/date/DayPicker.mjs.map +0 -1
  494. package/dist/components/date/TimePicker.mjs.map +0 -1
  495. package/dist/components/date/YearMonthPicker.mjs.map +0 -1
  496. package/dist/components/icons/Helpwave.js.map +0 -1
  497. package/dist/components/icons/Helpwave.mjs +0 -43
  498. package/dist/components/icons/Helpwave.mjs.map +0 -1
  499. package/dist/components/icons/Tag.js.map +0 -1
  500. package/dist/components/icons/Tag.mjs.map +0 -1
  501. package/dist/components/layout/Carousel.js.map +0 -1
  502. package/dist/components/layout/Carousel.mjs.map +0 -1
  503. package/dist/components/layout/DividerInserter.js.map +0 -1
  504. package/dist/components/layout/DividerInserter.mjs.map +0 -1
  505. package/dist/components/layout/FAQSection.js.map +0 -1
  506. package/dist/components/layout/FAQSection.mjs.map +0 -1
  507. package/dist/components/layout/Tile.js.map +0 -1
  508. package/dist/components/layout/Tile.mjs.map +0 -1
  509. package/dist/components/modals/ConfirmDialog.mjs +0 -388
  510. package/dist/components/modals/ConfirmDialog.mjs.map +0 -1
  511. package/dist/components/modals/DiscardChangesDialog.d.mts +0 -23
  512. package/dist/components/modals/DiscardChangesDialog.d.ts +0 -23
  513. package/dist/components/modals/DiscardChangesDialog.js.map +0 -1
  514. package/dist/components/modals/DiscardChangesDialog.mjs.map +0 -1
  515. package/dist/components/modals/InputModal.mjs +0 -566
  516. package/dist/components/modals/InputModal.mjs.map +0 -1
  517. package/dist/components/modals/LanguageModal.d.mts +0 -21
  518. package/dist/components/modals/LanguageModal.mjs +0 -489
  519. package/dist/components/modals/LanguageModal.mjs.map +0 -1
  520. package/dist/components/modals/Modal.d.mts +0 -43
  521. package/dist/components/modals/Modal.d.ts +0 -43
  522. package/dist/components/modals/Modal.js +0 -286
  523. package/dist/components/modals/Modal.js.map +0 -1
  524. package/dist/components/modals/Modal.mjs +0 -249
  525. package/dist/components/modals/Modal.mjs.map +0 -1
  526. package/dist/components/modals/ModalRegister.d.mts +0 -16
  527. package/dist/components/modals/ModalRegister.d.ts +0 -16
  528. package/dist/components/modals/ModalRegister.js +0 -63
  529. package/dist/components/modals/ModalRegister.js.map +0 -1
  530. package/dist/components/modals/ModalRegister.mjs +0 -37
  531. package/dist/components/modals/ModalRegister.mjs.map +0 -1
  532. package/dist/components/properties/CheckboxProperty.mjs +0 -291
  533. package/dist/components/properties/CheckboxProperty.mjs.map +0 -1
  534. package/dist/components/properties/DateProperty.mjs +0 -392
  535. package/dist/components/properties/DateProperty.mjs.map +0 -1
  536. package/dist/components/properties/MultiSelectProperty.mjs.map +0 -1
  537. package/dist/components/properties/NumberProperty.mjs +0 -401
  538. package/dist/components/properties/NumberProperty.mjs.map +0 -1
  539. package/dist/components/properties/PropertyBase.mjs +0 -162
  540. package/dist/components/properties/PropertyBase.mjs.map +0 -1
  541. package/dist/components/properties/SelectProperty.mjs.map +0 -1
  542. package/dist/components/properties/TextProperty.mjs +0 -345
  543. package/dist/components/properties/TextProperty.mjs.map +0 -1
  544. package/dist/components/user-input/Checkbox.js.map +0 -1
  545. package/dist/components/user-input/Checkbox.mjs.map +0 -1
  546. package/dist/components/user-input/DateAndTimePicker.js.map +0 -1
  547. package/dist/components/user-input/DateAndTimePicker.mjs.map +0 -1
  548. package/dist/components/user-input/Input.js.map +0 -1
  549. package/dist/components/user-input/Input.mjs.map +0 -1
  550. package/dist/components/user-input/Label.js.map +0 -1
  551. package/dist/components/user-input/Label.mjs.map +0 -1
  552. package/dist/components/user-input/Menu.js.map +0 -1
  553. package/dist/components/user-input/Menu.mjs.map +0 -1
  554. package/dist/components/user-input/MultiSelect.js.map +0 -1
  555. package/dist/components/user-input/MultiSelect.mjs.map +0 -1
  556. package/dist/components/user-input/ScrollPicker.js.map +0 -1
  557. package/dist/components/user-input/ScrollPicker.mjs.map +0 -1
  558. package/dist/components/user-input/SearchableSelect.d.mts +0 -14
  559. package/dist/components/user-input/SearchableSelect.d.ts +0 -14
  560. package/dist/components/user-input/SearchableSelect.js.map +0 -1
  561. package/dist/components/user-input/SearchableSelect.mjs.map +0 -1
  562. package/dist/components/user-input/Select.d.mts +0 -36
  563. package/dist/components/user-input/Select.d.ts +0 -36
  564. package/dist/components/user-input/Select.js +0 -153
  565. package/dist/components/user-input/Select.js.map +0 -1
  566. package/dist/components/user-input/Select.mjs +0 -118
  567. package/dist/components/user-input/Select.mjs.map +0 -1
  568. package/dist/components/user-input/Textarea.d.mts +0 -24
  569. package/dist/components/user-input/Textarea.js.map +0 -1
  570. package/dist/components/user-input/Textarea.mjs +0 -119
  571. package/dist/components/user-input/Textarea.mjs.map +0 -1
  572. package/dist/components/user-input/ToggleableInput.js.map +0 -1
  573. package/dist/components/user-input/ToggleableInput.mjs.map +0 -1
  574. package/dist/hooks/useHoverState.mjs +0 -47
  575. package/dist/hooks/useLanguage.d.mts +0 -21
  576. package/dist/hooks/useLanguage.d.ts +0 -21
  577. package/dist/hooks/useLanguage.js.map +0 -1
  578. package/dist/hooks/useLanguage.mjs.map +0 -1
  579. package/dist/hooks/useLocalStorage.mjs +0 -58
  580. package/dist/hooks/useLocalStorage.mjs.map +0 -1
  581. package/dist/hooks/useOutsideClick.mjs +0 -23
  582. package/dist/hooks/useSaveDelay.mjs +0 -43
  583. package/dist/hooks/useTheme.js.map +0 -1
  584. package/dist/hooks/useTheme.mjs.map +0 -1
  585. package/dist/hooks/useTranslation.js.map +0 -1
  586. package/dist/hooks/useTranslation.mjs.map +0 -1
  587. package/dist/index.d.mts +0 -88
  588. package/dist/index.mjs.map +0 -1
  589. package/dist/util/array.mjs.map +0 -1
  590. package/dist/util/builder.mjs +0 -9
  591. package/dist/util/date.mjs.map +0 -1
  592. package/dist/util/easeFunctions.mjs +0 -36
  593. package/dist/util/easeFunctions.mjs.map +0 -1
  594. package/dist/util/emailValidation.mjs +0 -8
  595. package/dist/util/math.mjs +0 -8
  596. package/dist/util/news.mjs +0 -48
  597. package/dist/util/news.mjs.map +0 -1
  598. package/dist/util/noop.mjs +0 -6
  599. package/dist/util/noop.mjs.map +0 -1
  600. package/dist/util/simpleSearch.mjs +0 -26
  601. package/dist/util/simpleSearch.mjs.map +0 -1
  602. package/dist/util/storage.mjs +0 -38
  603. package/dist/util/storage.mjs.map +0 -1
  604. package/dist/util/types.mjs +0 -1
  605. package/dist/util/types.mjs.map +0 -1
  606. /package/dist/coloring/{types.d.mts → types.d.cts} +0 -0
  607. /package/dist/components/{HelpwaveBadge.d.mts → branding/HelpwaveBadge.d.cts} +0 -0
  608. /package/dist/components/{HelpwaveBadge.d.ts → branding/HelpwaveBadge.d.ts} +0 -0
  609. /package/dist/components/{Circle.d.mts → icons-and-geometry/Circle.d.cts} +0 -0
  610. /package/dist/components/{Circle.d.ts → icons-and-geometry/Circle.d.ts} +0 -0
  611. /package/dist/components/{icons/Helpwave.d.mts → icons-and-geometry/Helpwave.d.cts} +0 -0
  612. /package/dist/components/{icons → icons-and-geometry}/Helpwave.d.ts +0 -0
  613. /package/dist/components/{Ring.d.mts → icons-and-geometry/Ring.d.cts} +0 -0
  614. /package/dist/components/{Ring.d.ts → icons-and-geometry/Ring.d.ts} +0 -0
  615. /package/dist/components/{icons/Tag.d.mts → icons-and-geometry/Tag.d.cts} +0 -0
  616. /package/dist/components/{icons → icons-and-geometry}/Tag.d.ts +0 -0
  617. /package/dist/components/{BreadCrumb.d.mts → layout-and-navigation/BreadCrumb.d.cts} +0 -0
  618. /package/dist/components/{BreadCrumb.d.ts → layout-and-navigation/BreadCrumb.d.ts} +0 -0
  619. /package/dist/components/{layout/Carousel.d.mts → layout-and-navigation/Carousel.d.cts} +0 -0
  620. /package/dist/components/{layout → layout-and-navigation}/Carousel.d.ts +0 -0
  621. /package/dist/components/{ChipList.d.mts → layout-and-navigation/Chip.d.cts} +0 -0
  622. /package/dist/components/{ChipList.d.ts → layout-and-navigation/Chip.d.ts} +0 -0
  623. /package/dist/components/{layout/DividerInserter.d.mts → layout-and-navigation/DividerInserter.d.cts} +0 -0
  624. /package/dist/components/{layout → layout-and-navigation}/DividerInserter.d.ts +0 -0
  625. /package/dist/components/{Expandable.d.mts → layout-and-navigation/Expandable.d.cts} +0 -0
  626. /package/dist/components/{Expandable.d.ts → layout-and-navigation/Expandable.d.ts} +0 -0
  627. /package/dist/components/{MarkdownInterpreter.d.mts → layout-and-navigation/MarkdownInterpreter.d.cts} +0 -0
  628. /package/dist/components/{MarkdownInterpreter.d.ts → layout-and-navigation/MarkdownInterpreter.d.ts} +0 -0
  629. /package/dist/components/{layout/Tile.d.mts → layout-and-navigation/Tile.d.cts} +0 -0
  630. /package/dist/components/{layout → layout-and-navigation}/Tile.d.ts +0 -0
  631. /package/dist/components/{VerticalDivider.d.mts → layout-and-navigation/VerticalDivider.d.cts} +0 -0
  632. /package/dist/components/{VerticalDivider.d.ts → layout-and-navigation/VerticalDivider.d.ts} +0 -0
  633. /package/dist/components/{ProgressIndicator.d.mts → loading-states/ProgressIndicator.d.cts} +0 -0
  634. /package/dist/components/{ProgressIndicator.d.ts → loading-states/ProgressIndicator.d.ts} +0 -0
  635. /package/dist/components/{user-input/Menu.d.mts → user-action/Menu.d.cts} +0 -0
  636. /package/dist/components/{user-input → user-action}/Menu.d.ts +0 -0
  637. /package/dist/components/{user-input/ScrollPicker.d.mts → user-action/ScrollPicker.d.cts} +0 -0
  638. /package/dist/components/{user-input → user-action}/ScrollPicker.d.ts +0 -0
  639. /package/dist/components/{user-input/ToggleableInput.d.mts → user-action/ToggleableInput.d.cts} +0 -0
  640. /package/dist/components/{user-input → user-action}/ToggleableInput.d.ts +0 -0
  641. /package/dist/hooks/{useHoverState.d.mts → useHoverState.d.cts} +0 -0
  642. /package/dist/hooks/{useLocalStorage.d.mts → useLocalStorage.d.cts} +0 -0
  643. /package/dist/hooks/{useOutsideClick.d.mts → useOutsideClick.d.cts} +0 -0
  644. /package/dist/hooks/{useSaveDelay.d.mts → useSaveDelay.d.cts} +0 -0
  645. /package/dist/util/{array.d.mts → array.d.cts} +0 -0
  646. /package/dist/util/{builder.d.mts → builder.d.cts} +0 -0
  647. /package/dist/util/{date.d.mts → date.d.cts} +0 -0
  648. /package/dist/util/{easeFunctions.d.mts → easeFunctions.d.cts} +0 -0
  649. /package/dist/util/{emailValidation.d.mts → emailValidation.d.cts} +0 -0
  650. /package/dist/util/{loopingArray.d.mts → loopingArray.d.cts} +0 -0
  651. /package/dist/util/{math.d.mts → math.d.cts} +0 -0
  652. /package/dist/util/{noop.d.mts → noop.d.cts} +0 -0
  653. /package/dist/util/{simpleSearch.d.mts → simpleSearch.d.cts} +0 -0
  654. /package/dist/util/{storage.d.mts → storage.d.cts} +0 -0
  655. /package/dist/util/{types.d.mts → types.d.cts} +0 -0
@@ -1,401 +0,0 @@
1
- // src/components/properties/NumberProperty.tsx
2
- import { Binary } from "lucide-react";
3
- import clsx4 from "clsx";
4
-
5
- // src/util/noop.ts
6
- var noop = () => void 0;
7
-
8
- // src/components/user-input/Input.tsx
9
- import {
10
- useEffect as useEffect2,
11
- useRef,
12
- useState as useState2,
13
- forwardRef
14
- } from "react";
15
- import clsx from "clsx";
16
-
17
- // src/hooks/useSaveDelay.ts
18
- import { useEffect, useState } from "react";
19
- function useSaveDelay(setNotificationStatus, delay) {
20
- const [updateTimer, setUpdateTimer] = useState(void 0);
21
- const [notificationTimer, setNotificationTimer] = useState(void 0);
22
- const restartTimer = (onSave) => {
23
- clearTimeout(updateTimer);
24
- setUpdateTimer(setTimeout(() => {
25
- onSave();
26
- setNotificationStatus(true);
27
- clearTimeout(notificationTimer);
28
- setNotificationTimer(setTimeout(() => {
29
- setNotificationStatus(false);
30
- clearTimeout(notificationTimer);
31
- }, delay));
32
- clearTimeout(updateTimer);
33
- }, delay));
34
- };
35
- const clearUpdateTimer = (hasSaved = true) => {
36
- clearTimeout(updateTimer);
37
- if (hasSaved) {
38
- setNotificationStatus(true);
39
- clearTimeout(notificationTimer);
40
- setNotificationTimer(setTimeout(() => {
41
- setNotificationStatus(false);
42
- clearTimeout(notificationTimer);
43
- }, delay));
44
- } else {
45
- setNotificationStatus(false);
46
- }
47
- };
48
- useEffect(() => {
49
- return () => {
50
- clearTimeout(updateTimer);
51
- clearTimeout(notificationTimer);
52
- };
53
- }, []);
54
- return { restartTimer, clearUpdateTimer };
55
- }
56
-
57
- // src/components/user-input/Label.tsx
58
- import { jsx } from "react/jsx-runtime";
59
- var styleMapping = {
60
- labelSmall: "textstyle-label-sm",
61
- labelMedium: "textstyle-label-md",
62
- labelBig: "textstyle-label-lg"
63
- };
64
- var Label = ({
65
- children,
66
- name,
67
- labelType = "labelSmall",
68
- ...props
69
- }) => {
70
- return /* @__PURE__ */ jsx("label", { ...props, children: children ? children : /* @__PURE__ */ jsx("span", { className: styleMapping[labelType], children: name }) });
71
- };
72
-
73
- // src/components/user-input/Input.tsx
74
- import { jsx as jsx2, jsxs } from "react/jsx-runtime";
75
- var ControlledInput = ({
76
- id,
77
- type = "text",
78
- value,
79
- label,
80
- onChange = noop,
81
- onChangeEvent = noop,
82
- className = "",
83
- onEditCompleted,
84
- expanded = true,
85
- onBlur,
86
- containerClassName,
87
- ...restProps
88
- }) => {
89
- const {
90
- restartTimer,
91
- clearUpdateTimer
92
- } = useSaveDelay(() => void 0, 3e3);
93
- const ref = useRef(null);
94
- useEffect2(() => {
95
- if (restProps.autoFocus) {
96
- ref.current?.focus();
97
- }
98
- }, [restProps.autoFocus]);
99
- return /* @__PURE__ */ jsxs("div", { className: clsx({ "w-full": expanded }, containerClassName), children: [
100
- label && /* @__PURE__ */ jsx2(Label, { ...label, htmlFor: id, className: clsx("mb-1", label.className) }),
101
- /* @__PURE__ */ jsx2(
102
- "input",
103
- {
104
- ref,
105
- value,
106
- id,
107
- type,
108
- className: clsx("block bg-surface text-on-surface px-3 py-2 rounded-md w-full border-2 border-gray-200 hover:border-primary focus:outline-none focus:border-primary focus:ring-primary", className),
109
- onBlur: (event) => {
110
- if (onBlur) {
111
- onBlur(event);
112
- }
113
- if (onEditCompleted) {
114
- onEditCompleted(event.target.value, event);
115
- clearUpdateTimer();
116
- }
117
- },
118
- onChange: (e) => {
119
- const value2 = e.target.value;
120
- if (onEditCompleted) {
121
- restartTimer(() => {
122
- onEditCompleted(value2, e);
123
- clearUpdateTimer();
124
- });
125
- }
126
- onChange(value2, e);
127
- onChangeEvent(e);
128
- },
129
- ...restProps
130
- }
131
- )
132
- ] });
133
- };
134
- var FormInput = forwardRef(function FormInput2({
135
- id,
136
- labelText,
137
- errorText,
138
- className,
139
- labelClassName,
140
- errorClassName,
141
- containerClassName,
142
- required,
143
- ...restProps
144
- }, ref) {
145
- const input = /* @__PURE__ */ jsx2(
146
- "input",
147
- {
148
- ref,
149
- id,
150
- ...restProps,
151
- className: clsx(
152
- "block bg-surface text-on-surface px-3 py-2 rounded-md w-full border-2 border-gray-200 hover:border-primary focus:outline-none focus:border-primary focus:ring-primary",
153
- {
154
- "focus:border-primary focus:ring-primary": !errorText,
155
- "focus:border-negative focus:ring-negative text-negative": !!errorText
156
- },
157
- className
158
- )
159
- }
160
- );
161
- return /* @__PURE__ */ jsxs("div", { className: clsx("flex flex-col gap-y-1", containerClassName), children: [
162
- labelText && /* @__PURE__ */ jsxs("label", { htmlFor: id, className: clsx("textstyle-label-md", labelClassName), children: [
163
- labelText,
164
- required && /* @__PURE__ */ jsx2("span", { className: "text-primary font-bold", children: "*" })
165
- ] }),
166
- input,
167
- errorText && /* @__PURE__ */ jsx2("label", { htmlFor: id, className: clsx("text-negative", errorClassName), children: errorText })
168
- ] });
169
- });
170
-
171
- // src/hooks/useLanguage.tsx
172
- import { createContext, useContext, useEffect as useEffect4, useState as useState4 } from "react";
173
-
174
- // src/hooks/useLocalStorage.tsx
175
- import { useCallback, useEffect as useEffect3, useState as useState3 } from "react";
176
-
177
- // src/hooks/useLanguage.tsx
178
- import { jsx as jsx3 } from "react/jsx-runtime";
179
- var DEFAULT_LANGUAGE = "en";
180
- var LanguageContext = createContext({ language: DEFAULT_LANGUAGE, setLanguage: (v) => v });
181
- var useLanguage = () => useContext(LanguageContext);
182
-
183
- // src/hooks/useTranslation.ts
184
- var useTranslation = (defaults, translationOverwrite = {}) => {
185
- const { language: languageProp, translation: overwrite } = translationOverwrite;
186
- const { language: inferredLanguage } = useLanguage();
187
- const usedLanguage = languageProp ?? inferredLanguage;
188
- let defaultValues = defaults[usedLanguage];
189
- if (overwrite && overwrite[usedLanguage]) {
190
- defaultValues = { ...defaultValues, ...overwrite[usedLanguage] };
191
- }
192
- return defaultValues;
193
- };
194
-
195
- // src/components/properties/PropertyBase.tsx
196
- import { AlertTriangle } from "lucide-react";
197
- import clsx3 from "clsx";
198
-
199
- // src/components/Button.tsx
200
- import clsx2 from "clsx";
201
- import { jsx as jsx4, jsxs as jsxs2 } from "react/jsx-runtime";
202
- var ButtonSizePaddings = {
203
- small: "btn-sm",
204
- medium: "btn-md",
205
- large: "btn-lg"
206
- };
207
- var TextButton = ({
208
- children,
209
- disabled = false,
210
- color = "neutral",
211
- size = "medium",
212
- startIcon,
213
- endIcon,
214
- onClick,
215
- className,
216
- ...restProps
217
- }) => {
218
- const colorClasses = {
219
- negative: "bg-transparent text-button-text-negative-text",
220
- neutral: "bg-transparent text-button-text-neutral-text"
221
- }[color];
222
- const iconColorClasses = {
223
- negative: "text-button-text-negative-icon",
224
- neutral: "text-button-text-neutral-icon"
225
- }[color];
226
- return /* @__PURE__ */ jsxs2(
227
- "button",
228
- {
229
- onClick: disabled ? void 0 : onClick,
230
- disabled: disabled || onClick === void 0,
231
- className: clsx2(
232
- className,
233
- {
234
- "text-disabled-text": disabled,
235
- [clsx2(colorClasses, "hover:bg-button-text-hover-background rounded-full")]: !disabled
236
- },
237
- ButtonSizePaddings[size]
238
- ),
239
- ...restProps,
240
- children: [
241
- startIcon && /* @__PURE__ */ jsx4(
242
- "span",
243
- {
244
- className: clsx2({
245
- [iconColorClasses]: !disabled,
246
- [`text-disabled-icon`]: disabled
247
- }),
248
- children: startIcon
249
- }
250
- ),
251
- children,
252
- endIcon && /* @__PURE__ */ jsx4(
253
- "span",
254
- {
255
- className: clsx2({
256
- [iconColorClasses]: !disabled,
257
- [`text-disabled-icon`]: disabled
258
- }),
259
- children: endIcon
260
- }
261
- )
262
- ]
263
- }
264
- );
265
- };
266
-
267
- // src/components/properties/PropertyBase.tsx
268
- import { jsx as jsx5, jsxs as jsxs3 } from "react/jsx-runtime";
269
- var defaultPropertyBaseTranslation = {
270
- en: {
271
- remove: "Remove"
272
- },
273
- de: {
274
- remove: "Entfernen"
275
- }
276
- };
277
- var PropertyBase = ({
278
- overwriteTranslation,
279
- name,
280
- input,
281
- softRequired = false,
282
- hasValue,
283
- icon,
284
- readOnly,
285
- onRemove,
286
- className = ""
287
- }) => {
288
- const translation = useTranslation(defaultPropertyBaseTranslation, overwriteTranslation);
289
- const requiredAndNoValue = softRequired && !hasValue;
290
- return /* @__PURE__ */ jsxs3("div", { className: clsx3("row gap-x-0 group", className), children: [
291
- /* @__PURE__ */ jsxs3(
292
- "div",
293
- {
294
- className: clsx3("row gap-x-2 !w-[200px] px-4 py-2 items-center rounded-l-xl border-2 border-r-0", {
295
- "bg-gray-100 text-black group-hover:border-primary border-gray-400": !requiredAndNoValue,
296
- "bg-warning text-surface-warning group-hover:border-warning border-warning/90": requiredAndNoValue
297
- }, className),
298
- children: [
299
- icon,
300
- name
301
- ]
302
- }
303
- ),
304
- /* @__PURE__ */ jsxs3(
305
- "div",
306
- {
307
- className: clsx3("row grow justify-between items-center rounded-r-xl border-2 border-l-0", {
308
- "bg-white group-hover:border-primary border-gray-400": !requiredAndNoValue,
309
- "bg-surface-warning group-hover:border-warning border-warning/90": requiredAndNoValue
310
- }, className),
311
- children: [
312
- input({ softRequired, hasValue }),
313
- requiredAndNoValue && /* @__PURE__ */ jsx5("div", { className: "text-warning pr-4", children: /* @__PURE__ */ jsx5(AlertTriangle, { size: 24 }) }),
314
- onRemove && /* @__PURE__ */ jsx5(
315
- TextButton,
316
- {
317
- onClick: onRemove,
318
- color: "negative",
319
- className: clsx3("pr-4 items-center", { "!text-transparent": !hasValue || readOnly }),
320
- disabled: !hasValue || readOnly,
321
- children: translation.remove
322
- }
323
- )
324
- ]
325
- }
326
- )
327
- ] });
328
- };
329
-
330
- // src/components/properties/NumberProperty.tsx
331
- import { jsx as jsx6, jsxs as jsxs4 } from "react/jsx-runtime";
332
- var defaultNumberPropertyTranslation = {
333
- en: {
334
- value: "Value"
335
- },
336
- de: {
337
- value: "Wert"
338
- }
339
- };
340
- var NumberProperty = ({
341
- overwriteTranslation,
342
- value,
343
- onChange = noop,
344
- onRemove = noop,
345
- onEditComplete = noop,
346
- readOnly,
347
- suffix,
348
- ...baseProps
349
- }) => {
350
- const translation = useTranslation(defaultNumberPropertyTranslation, overwriteTranslation);
351
- const hasValue = value !== void 0;
352
- return /* @__PURE__ */ jsx6(
353
- PropertyBase,
354
- {
355
- ...baseProps,
356
- onRemove,
357
- hasValue,
358
- icon: /* @__PURE__ */ jsx6(Binary, { size: 16 }),
359
- input: ({ softRequired }) => /* @__PURE__ */ jsxs4(
360
- "div",
361
- {
362
- className: clsx4("row grow py-2 px-4 cursor-pointer", { "text-warning": softRequired && !hasValue }),
363
- children: [
364
- /* @__PURE__ */ jsx6(
365
- ControlledInput,
366
- {
367
- expanded: false,
368
- className: clsx4("!ring-0 !border-0 !outline-0 !p-0 !m-0 !w-fit !shadow-none !rounded-none", { "bg-surface-warning placeholder-warning": softRequired && !hasValue }),
369
- value: value?.toString() ?? "",
370
- type: "number",
371
- readOnly,
372
- placeholder: `${translation.value}...`,
373
- onChange: (value2) => {
374
- const numberValue = parseFloat(value2);
375
- if (isNaN(numberValue)) {
376
- onRemove();
377
- } else {
378
- onChange(numberValue);
379
- }
380
- },
381
- onEditCompleted: (value2) => {
382
- const numberValue = parseFloat(value2);
383
- if (isNaN(numberValue)) {
384
- onRemove();
385
- } else {
386
- onEditComplete(numberValue);
387
- }
388
- }
389
- }
390
- ),
391
- suffix && /* @__PURE__ */ jsx6("span", { className: clsx4("ml-1", { "bg-surface-warning": softRequired && !hasValue }), children: suffix })
392
- ]
393
- }
394
- )
395
- }
396
- );
397
- };
398
- export {
399
- NumberProperty
400
- };
401
- //# sourceMappingURL=NumberProperty.mjs.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../../../src/components/properties/NumberProperty.tsx","../../../src/util/noop.ts","../../../src/components/user-input/Input.tsx","../../../src/hooks/useSaveDelay.ts","../../../src/components/user-input/Label.tsx","../../../src/hooks/useLanguage.tsx","../../../src/hooks/useLocalStorage.tsx","../../../src/hooks/useTranslation.ts","../../../src/components/properties/PropertyBase.tsx","../../../src/components/Button.tsx"],"sourcesContent":["import { Binary } from 'lucide-react'\nimport clsx from 'clsx'\nimport { noop } from '../../util/noop'\nimport { Input } from '../user-input/Input'\nimport type { Languages } from '../../hooks/useLanguage'\nimport type { PropsForTranslation } from '../../hooks/useTranslation'\nimport { useTranslation } from '../../hooks/useTranslation'\nimport type { PropertyBaseProps } from './PropertyBase'\nimport { PropertyBase } from './PropertyBase'\n\ntype NumberPropertyTranslation = {\n value: string,\n}\n\nconst defaultNumberPropertyTranslation: Record<Languages, NumberPropertyTranslation> = {\n en: {\n value: 'Value'\n },\n de: {\n value: 'Wert'\n }\n}\n\nexport type NumberPropertyProps = Omit<PropertyBaseProps, 'icon' | 'input' | 'hasValue'> & {\n value?: number,\n suffix?: string,\n onChange?: (value: number) => void,\n onEditComplete?: (value: number) => void,\n}\n\n/**\n * An Input for number properties\n */\nexport const NumberProperty = ({\n overwriteTranslation,\n value,\n onChange = noop,\n onRemove = noop,\n onEditComplete = noop,\n readOnly,\n suffix,\n ...baseProps\n}: PropsForTranslation<NumberPropertyTranslation, NumberPropertyProps>) => {\n const translation = useTranslation(defaultNumberPropertyTranslation, overwriteTranslation)\n const hasValue = value !== undefined\n\n return (\n <PropertyBase\n {...baseProps}\n onRemove={onRemove}\n hasValue={hasValue}\n icon={<Binary size={16}/>}\n input={({ softRequired }) => (\n <div\n className={clsx('row grow py-2 px-4 cursor-pointer', { 'text-warning': softRequired && !hasValue })}\n >\n <Input\n expanded={false}\n className={clsx('!ring-0 !border-0 !outline-0 !p-0 !m-0 !w-fit !shadow-none !rounded-none', { 'bg-surface-warning placeholder-warning': softRequired && !hasValue })}\n value={value?.toString() ?? ''}\n type=\"number\"\n readOnly={readOnly}\n placeholder={`${translation.value}...`}\n onChange={(value) => {\n const numberValue = parseFloat(value)\n if (isNaN(numberValue)) {\n onRemove()\n } else {\n onChange(numberValue)\n }\n }}\n onEditCompleted={(value) => {\n const numberValue = parseFloat(value)\n if (isNaN(numberValue)) {\n onRemove()\n } else {\n onEditComplete(numberValue)\n }\n }}\n />\n {suffix && <span className={clsx('ml-1', { 'bg-surface-warning': softRequired && !hasValue })}>{suffix}</span>}\n </div>\n )}\n />\n )\n}\n","export const noop = () => undefined\n","import React, {\n useEffect,\n useRef,\n useState,\n type ChangeEvent,\n type HTMLInputTypeAttribute,\n type InputHTMLAttributes, forwardRef\n} from 'react'\nimport clsx from 'clsx'\nimport { useSaveDelay } from '../../hooks/useSaveDelay'\nimport { noop } from '../../util/noop'\nimport type { LabelProps } from './Label'\nimport { Label } from './Label'\n\nexport type InputProps = {\n /**\n * used for the label's `for` attribute\n */\n id?: string,\n value: string,\n label?: Omit<LabelProps, 'id'>,\n /**\n * @default 'text'\n */\n type?: HTMLInputTypeAttribute,\n /**\n * Callback for when the input's value changes\n * This is pretty much required but made optional for the rare cases where it actually isn't need such as when used with disabled\n * That could be enforced through a union type but that seems a bit overkill\n * @default noop\n */\n onChange?: (text: string, event: ChangeEvent<HTMLInputElement>) => void,\n onChangeEvent?: (event: ChangeEvent<HTMLInputElement>) => void,\n className?: string,\n onEditCompleted?: (text: string, event: ChangeEvent<HTMLInputElement>) => void,\n expanded?: boolean,\n containerClassName?: string,\n} & Omit<InputHTMLAttributes<HTMLInputElement>, 'id' | 'value' | 'label' | 'type' | 'onChange' | 'crossOrigin'>\n\n/**\n * A Component for inputting text or other information\n *\n * Its state is managed must be managed by the parent\n */\nconst ControlledInput = ({\n id,\n type = 'text',\n value,\n label,\n onChange = noop,\n onChangeEvent = noop,\n className = '',\n onEditCompleted,\n expanded = true,\n onBlur,\n containerClassName,\n ...restProps\n }: InputProps) => {\n const {\n restartTimer,\n clearUpdateTimer\n } = useSaveDelay(() => undefined, 3000)\n const ref = useRef<HTMLInputElement>(null)\n\n useEffect(() => {\n if (restProps.autoFocus) {\n ref.current?.focus()\n }\n }, [restProps.autoFocus])\n return (\n <div className={clsx({ 'w-full': expanded }, containerClassName)}>\n {label && <Label {...label} htmlFor={id} className={clsx('mb-1', label.className)}/>}\n <input\n ref={ref}\n value={value}\n id={id}\n type={type}\n className={clsx('block bg-surface text-on-surface px-3 py-2 rounded-md w-full border-2 border-gray-200 hover:border-primary focus:outline-none focus:border-primary focus:ring-primary', className)}\n onBlur={event => {\n if (onBlur) {\n onBlur(event)\n }\n if (onEditCompleted) {\n onEditCompleted(event.target.value, event)\n clearUpdateTimer()\n }\n }}\n onChange={e => {\n const value = e.target.value\n if (onEditCompleted) {\n restartTimer(() => {\n onEditCompleted(value, e)\n clearUpdateTimer()\n })\n }\n onChange(value, e)\n onChangeEvent(e)\n }}\n {...restProps}\n />\n </div>\n )\n}\n\ntype UncontrolledInputProps = Omit<InputProps, 'value'> & {\n /**\n * @default ''\n */\n defaultValue?: string,\n}\n\n/**\n * A Component for inputting text or other information\n *\n * Its state is managed by the component itself\n */\nconst UncontrolledInput = ({\n defaultValue = '',\n onChange = noop,\n ...props\n }: UncontrolledInputProps) => {\n const [value, setValue] = useState(defaultValue)\n\n const handleChange = (text: string, event: ChangeEvent<HTMLInputElement>) => {\n setValue(text)\n onChange(text, event)\n }\n\n return (\n <ControlledInput\n {...props}\n value={value}\n onChange={handleChange}\n />\n )\n}\n\nexport type FormInputProps = InputHTMLAttributes<HTMLInputElement> & {\n id: string,\n labelText?: string,\n errorText?: string,\n labelClassName?: string,\n errorClassName?: string,\n containerClassName?: string,\n}\n\nconst FormInput = forwardRef<HTMLInputElement, FormInputProps>(function FormInput({\n id,\n labelText,\n errorText,\n className,\n labelClassName,\n errorClassName,\n containerClassName,\n required,\n ...restProps\n }, ref) {\n const input = (\n <input\n ref={ref}\n id={id}\n {...restProps}\n className={clsx(\n 'block bg-surface text-on-surface px-3 py-2 rounded-md w-full border-2 border-gray-200 hover:border-primary focus:outline-none focus:border-primary focus:ring-primary',\n {\n 'focus:border-primary focus:ring-primary': !errorText,\n 'focus:border-negative focus:ring-negative text-negative': !!errorText,\n },\n className\n )}\n />\n )\n\n return (\n <div className={clsx('flex flex-col gap-y-1', containerClassName)}>\n {labelText && (\n <label htmlFor={id} className={clsx('textstyle-label-md', labelClassName)}>\n {labelText}\n {required && <span className=\"text-primary font-bold\">*</span>}\n </label>\n )}\n {input}\n {errorText && <label htmlFor={id} className={clsx('text-negative', errorClassName)}>{errorText}</label>}\n </div>\n )\n})\n\nexport {\n UncontrolledInput,\n ControlledInput as Input,\n FormInput\n}\n","import { useEffect, useState } from 'react'\n\nexport function useSaveDelay(setNotificationStatus: (isShowing: boolean) => void, delay: number) {\n const [updateTimer, setUpdateTimer] = useState<NodeJS.Timeout | undefined>(undefined)\n const [notificationTimer, setNotificationTimer] = useState<NodeJS.Timeout | undefined>(undefined)\n\n const restartTimer = (onSave: () => void) => {\n clearTimeout(updateTimer)\n setUpdateTimer(setTimeout(() => {\n onSave()\n setNotificationStatus(true)\n // Show Saved Notification for fade animation duration\n clearTimeout(notificationTimer)\n setNotificationTimer(setTimeout(() => {\n setNotificationStatus(false)\n clearTimeout(notificationTimer)\n }, delay))\n clearTimeout(updateTimer)\n }, delay))\n }\n\n const clearUpdateTimer = (hasSaved = true) => {\n clearTimeout(updateTimer)\n if (hasSaved) {\n setNotificationStatus(true)\n clearTimeout(notificationTimer)\n setNotificationTimer(setTimeout(() => {\n setNotificationStatus(false)\n clearTimeout(notificationTimer)\n }, delay))\n } else {\n setNotificationStatus(false)\n }\n }\n\n useEffect(() => {\n return () => {\n clearTimeout(updateTimer)\n clearTimeout(notificationTimer)\n }\n }, []) // eslint-disable-line react-hooks/exhaustive-deps\n\n return { restartTimer, clearUpdateTimer }\n}","import type { LabelHTMLAttributes } from 'react'\n\nexport type LabelType = 'labelSmall' | 'labelMedium' | 'labelBig'\nconst styleMapping: Record<LabelType, string> = {\n labelSmall: 'textstyle-label-sm',\n labelMedium: 'textstyle-label-md',\n labelBig: 'textstyle-label-lg',\n}\n\n\nexport type LabelProps = {\n /** The text for the label */\n name?: string,\n /** The styling for the label */\n labelType?: LabelType,\n} & LabelHTMLAttributes<HTMLLabelElement>\n\n/**\n * A Label component\n */\nexport const Label = ({\n children,\n name,\n labelType = 'labelSmall',\n ...props\n}: LabelProps) => {\n return (\n <label {...props}>\n {children ? children : (<span className={styleMapping[labelType]}>{name}</span>)}\n </label>\n )\n}\n","import type { Dispatch, PropsWithChildren, SetStateAction } from 'react'\nimport { createContext, useContext, useEffect, useState } from 'react'\nimport { useLocalStorage } from './useLocalStorage'\n\nexport const languages = ['en', 'de'] as const\nexport type Languages = typeof languages[number]\nexport const languagesLocalNames: Record<Languages, string> = {\n en: 'English',\n de: 'Deutsch',\n}\n\nexport const DEFAULT_LANGUAGE = 'en'\n\nexport type LanguageContextValue = {\n language: Languages,\n setLanguage: Dispatch<SetStateAction<Languages>>,\n}\n\nexport const LanguageContext = createContext<LanguageContextValue>({ language: DEFAULT_LANGUAGE, setLanguage: (v) => v })\n\nexport const useLanguage = () => useContext(LanguageContext)\n\nexport const useLocale = (overWriteLanguage?: Languages) => {\n const { language } = useLanguage()\n const mapping: Record<Languages, string> = {\n en: 'en-US',\n de: 'de-DE'\n }\n return mapping[overWriteLanguage ?? language]\n}\n\ntype ProvideLanguageProps = {\n initialLanguage?: Languages,\n}\n\nexport const ProvideLanguage = ({ initialLanguage, children }: PropsWithChildren<ProvideLanguageProps>) => {\n const [language, setLanguage] = useState<Languages>(initialLanguage ?? DEFAULT_LANGUAGE)\n const [storedLanguage, setStoredLanguage] = useLocalStorage<Languages>('language', initialLanguage ?? DEFAULT_LANGUAGE)\n\n useEffect(() => {\n if(language !== initialLanguage && initialLanguage){\n console.warn('LanguageProvider initial state changed: Prefer using useLanguages\\'s setLanguage instead')\n setLanguage(initialLanguage)\n }\n }, [initialLanguage]) // eslint-disable-line react-hooks/exhaustive-deps\n\n useEffect(() => {\n // TODO set locale of html tag here as well\n setStoredLanguage(language)\n }, [language, setStoredLanguage])\n\n useEffect(() => {\n if (storedLanguage !== null) {\n setLanguage(storedLanguage)\n return\n }\n\n const languagesToTestAgainst = Object.values(languages)\n\n const matchingBrowserLanguages = window.navigator.languages\n .map(language => languagesToTestAgainst.find((test) => language === test || language.split('-')[0] === test))\n .filter(entry => entry !== undefined)\n\n if (matchingBrowserLanguages.length === 0) return\n\n const firstMatch = matchingBrowserLanguages[0] as Languages\n setLanguage(firstMatch)\n }, []) // eslint-disable-line react-hooks/exhaustive-deps\n\n return (\n <LanguageContext.Provider value={{\n language,\n setLanguage\n }}>\n {children}\n </LanguageContext.Provider>\n )\n}\n","import type { Dispatch, SetStateAction } from 'react'\nimport { useCallback, useEffect, useState } from 'react'\nimport { LocalStorageService } from '../util/storage'\n\ntype SetValue<T> = Dispatch<SetStateAction<T>>\nexport const useLocalStorage = <T, >(key: string, initValue: T): [T, SetValue<T>] => {\n const get = useCallback((): T => {\n if (typeof window === 'undefined') {\n return initValue\n }\n const storageService = new LocalStorageService()\n const value = storageService.get<T>(key)\n return value || initValue\n }, [initValue, key])\n\n const [storedValue, setStoredValue] = useState<T>(get)\n\n const setValue: SetValue<T> = useCallback(value => {\n const newValue = value instanceof Function ? value(storedValue) : value\n const storageService = new LocalStorageService()\n storageService.set(key, value)\n\n setStoredValue(newValue)\n }, [storedValue, setStoredValue, key])\n\n useEffect(() => {\n setStoredValue(get())\n }, []) // eslint-disable-line react-hooks/exhaustive-deps\n\n return [storedValue, setValue]\n}","import type { Languages } from './useLanguage'\nimport { useLanguage } from './useLanguage'\n\nexport type Translation<T> = Record<Languages, T>\n\ntype OverwriteTranslationType<Translation extends Record<string, unknown>> = {\n language?: Languages,\n translation?: Partial<Record<Languages, Partial<Translation>>>,\n}\n\n/**\n * Adds the `language` prop to the component props.\n *\n * @param Translation the type of the translation object\n *\n * @param Props the type of the component props, defaults to `Record<string, never>`,\n * if you don't expect any other props other than `language` and get an\n * error when using your component (because it uses `forwardRef` etc.)\n * you can try out `Record<string, unknown>`, this might resolve your\n * problem as `SomeType & never` is still `never` but `SomeType & unknown`\n * is `SomeType` which means that adding back props (like `ref` etc.)\n * works properly\n */\nexport type PropsForTranslation<\n Translation extends Record<string, unknown>,\n Props = Record<string, never>\n> = Props & {\n overwriteTranslation?: OverwriteTranslationType<Translation>,\n};\n\nexport const useTranslation = <Translation extends Record<string, unknown>>(\n defaults: Record<Languages, Translation>,\n translationOverwrite: OverwriteTranslationType<Translation> = {}\n) : Translation => {\n const { language: languageProp, translation: overwrite } = translationOverwrite\n const { language: inferredLanguage } = useLanguage()\n const usedLanguage = languageProp ?? inferredLanguage\n let defaultValues: Translation = defaults[usedLanguage]\n if (overwrite && overwrite[usedLanguage]) {\n defaultValues = { ...defaultValues, ...overwrite[usedLanguage] }\n }\n return defaultValues\n}\n","import type { ReactNode } from 'react'\nimport { AlertTriangle } from 'lucide-react'\nimport clsx from 'clsx'\nimport type { Languages } from '../../hooks/useLanguage'\nimport { TextButton } from '../Button'\nimport type { PropsForTranslation } from '../../hooks/useTranslation'\nimport { useTranslation } from '../../hooks/useTranslation'\n\ntype PropertyBaseTranslation = {\n remove: string,\n}\n\nconst defaultPropertyBaseTranslation: Record<Languages, PropertyBaseTranslation> = {\n en: {\n remove: 'Remove'\n },\n de: {\n remove: 'Entfernen'\n }\n}\n\nexport type PropertyBaseProps = {\n name: string,\n input: (props: { softRequired: boolean, hasValue: boolean }) => ReactNode,\n onRemove?: () => void,\n hasValue: boolean,\n softRequired?: boolean,\n readOnly?: boolean,\n icon?: ReactNode,\n className?: string,\n}\n\n/**\n * A component for showing a properties with uniform styling\n */\nexport const PropertyBase = ({\n overwriteTranslation,\n name,\n input,\n softRequired = false,\n hasValue,\n icon,\n readOnly,\n onRemove,\n className = '',\n}: PropsForTranslation<PropertyBaseTranslation, PropertyBaseProps>) => {\n const translation = useTranslation(defaultPropertyBaseTranslation, overwriteTranslation)\n const requiredAndNoValue = softRequired && !hasValue\n return (\n <div className={clsx('row gap-x-0 group', className)}>\n <div\n className={\n clsx('row gap-x-2 !w-[200px] px-4 py-2 items-center rounded-l-xl border-2 border-r-0', {\n 'bg-gray-100 text-black group-hover:border-primary border-gray-400': !requiredAndNoValue,\n 'bg-warning text-surface-warning group-hover:border-warning border-warning/90': requiredAndNoValue,\n }, className)}\n >\n {icon}\n {name}\n </div>\n <div className={\n clsx('row grow justify-between items-center rounded-r-xl border-2 border-l-0', {\n 'bg-white group-hover:border-primary border-gray-400': !requiredAndNoValue,\n 'bg-surface-warning group-hover:border-warning border-warning/90': requiredAndNoValue,\n }, className)}\n >\n {input({ softRequired, hasValue })}\n {requiredAndNoValue && (\n <div className=\"text-warning pr-4\"><AlertTriangle size={24}/></div>\n )}\n {onRemove && (\n <TextButton\n onClick={onRemove}\n color=\"negative\"\n className={clsx('pr-4 items-center', { '!text-transparent': !hasValue || readOnly })}\n disabled={!hasValue || readOnly}\n >\n {translation.remove}\n </TextButton>\n )}\n </div>\n </div>\n )\n}\n","import type { PropsWithChildren, ButtonHTMLAttributes, ReactNode } from 'react'\nimport clsx from 'clsx'\n\nexport type SolidButtonColor = 'primary' | 'secondary' | 'tertiary' | 'positive' | 'warning'| 'negative'\nexport type OutlineButtonColor = 'primary'\nexport type TextButtonColor = 'negative' | 'neutral'\n\ntype ButtonSizes = 'small' | 'medium' | 'large'\n\n/**\n * The shard properties between all button types\n */\nexport type ButtonProps = PropsWithChildren<{\n /**\n * @default 'medium'\n */\n size?: ButtonSizes,\n}> & ButtonHTMLAttributes<Element>\n\nexport const ButtonSizePaddings: Record<ButtonSizes, string> = {\n small: 'btn-sm',\n medium: 'btn-md',\n large: 'btn-lg'\n}\n\ntype ButtonWithIconsProps = ButtonProps & {\n startIcon?: ReactNode,\n endIcon?: ReactNode,\n}\n\nexport type SolidButtonProps = ButtonWithIconsProps & {\n color?: SolidButtonColor,\n}\n\nexport type OutlineButtonProps = ButtonWithIconsProps & {\n color?: OutlineButtonColor,\n}\n\nexport type TextButtonProps = ButtonWithIconsProps & {\n color?: TextButtonColor,\n}\n\n/**\n * A button with a solid background and different sizes\n */\nconst SolidButton = ({\n children,\n disabled = false,\n color = 'primary',\n size = 'medium',\n startIcon,\n endIcon,\n onClick,\n className,\n ...restProps\n }: SolidButtonProps) => {\n const colorClasses = {\n primary: 'bg-button-solid-primary-background text-button-solid-primary-text',\n secondary: 'bg-button-solid-secondary-background text-button-solid-secondary-text',\n tertiary: 'bg-button-solid-tertiary-background text-button-solid-tertiary-text',\n positive: 'bg-button-solid-positive-background text-button-solid-positive-text',\n warning: 'bg-button-solid-warning-background text-button-solid-warning-text',\n negative: 'bg-button-solid-negative-background text-button-solid-negative-text',\n }[color]\n\n const iconColorClasses = {\n primary: 'text-button-solid-primary-icon',\n secondary: 'text-button-solid-secondary-icon',\n tertiary: 'text-button-solid-tertiary-icon',\n positive: 'text-button-solid-positive-icon',\n warning: 'text-button-solid-warning-icon',\n negative: 'text-button-solid-negative-icon',\n }[color]\n\n return (\n <button\n onClick={disabled ? undefined : onClick}\n disabled={disabled || onClick === undefined}\n className={clsx(\n className,\n {\n 'text-disabled-text bg-disabled-background': disabled,\n [clsx(colorClasses, 'hover:brightness-90')]: !disabled\n },\n ButtonSizePaddings[size]\n )}\n {...restProps}\n >\n {startIcon && (\n <span\n className={clsx({\n [iconColorClasses]: !disabled,\n [`text-disabled-icon`]: disabled\n })}\n >\n {startIcon}\n </span>\n )}\n {children}\n {endIcon && (\n <span\n className={clsx({\n [iconColorClasses]: !disabled,\n [`text-disabled-icon`]: disabled\n })}\n >\n {endIcon}\n </span>\n )}\n </button>\n )\n}\n\n/**\n * A button with an outline border and different sizes\n */\nconst OutlineButton = ({\n children,\n disabled = false,\n color = 'primary',\n size = 'medium',\n startIcon,\n endIcon,\n onClick,\n className,\n ...restProps\n }: OutlineButtonProps) => {\n const colorClasses = {\n primary: 'bg-transparent border-2 border-button-outline-primary-text text-button-outline-primary-text',\n }[color]\n\n const iconColorClasses = {\n primary: 'text-button-outline-primary-icon',\n }[color]\n return (\n <button\n onClick={disabled ? undefined : onClick}\n disabled={disabled || onClick === undefined}\n className={clsx(\n className, {\n 'text-disabled-text border-disabled-outline)': disabled,\n [clsx(colorClasses, 'hover:brightness-80')]: !disabled,\n },\n ButtonSizePaddings[size]\n )}\n {...restProps}\n >\n {startIcon && (\n <span\n className={clsx({\n [iconColorClasses]: !disabled,\n [`text-disabled-icon`]: disabled\n })}\n >\n {startIcon}\n </span>\n )}\n {children}\n {endIcon && (\n <span\n className={clsx({\n [iconColorClasses]: !disabled,\n [`text-disabled-icon`]: disabled\n })}\n >\n {endIcon}\n </span>\n )}\n </button>\n )\n}\n\n/**\n * A text that is a button that can have different sizes\n */\nconst TextButton = ({\n children,\n disabled = false,\n color = 'neutral',\n size = 'medium',\n startIcon,\n endIcon,\n onClick,\n className,\n ...restProps\n }: TextButtonProps) => {\n const colorClasses = {\n negative: 'bg-transparent text-button-text-negative-text',\n neutral: 'bg-transparent text-button-text-neutral-text',\n }[color]\n\n const iconColorClasses = {\n negative: 'text-button-text-negative-icon',\n neutral: 'text-button-text-neutral-icon',\n }[color]\n return (\n <button\n onClick={disabled ? undefined : onClick}\n disabled={disabled || onClick === undefined}\n className={clsx(\n className, {\n 'text-disabled-text': disabled,\n [clsx(colorClasses, 'hover:bg-button-text-hover-background rounded-full')]: !disabled,\n },\n ButtonSizePaddings[size]\n )}\n {...restProps}\n >\n {startIcon && (\n <span\n className={clsx({\n [iconColorClasses]: !disabled,\n [`text-disabled-icon`]: disabled\n })}\n >\n {startIcon}\n </span>\n )}\n {children}\n {endIcon && (\n <span\n className={clsx({\n [iconColorClasses]: !disabled,\n [`text-disabled-icon`]: disabled\n })}\n >\n {endIcon}\n </span>\n )}\n </button>\n )\n}\n\n// TODO Icon button\n\nexport { SolidButton, OutlineButton, TextButton }\n"],"mappings":"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","names":["clsx","useEffect","useState","jsx","useEffect","value","FormInput","jsx","useEffect","useState","useEffect","useState","jsx","clsx","clsx","jsx","jsxs","jsxs","clsx","jsx","jsx","jsxs","clsx","jsx","jsxs","clsx","value"]}
@@ -1,162 +0,0 @@
1
- // src/components/properties/PropertyBase.tsx
2
- import { AlertTriangle } from "lucide-react";
3
- import clsx2 from "clsx";
4
-
5
- // src/components/Button.tsx
6
- import clsx from "clsx";
7
- import { jsx, jsxs } from "react/jsx-runtime";
8
- var ButtonSizePaddings = {
9
- small: "btn-sm",
10
- medium: "btn-md",
11
- large: "btn-lg"
12
- };
13
- var TextButton = ({
14
- children,
15
- disabled = false,
16
- color = "neutral",
17
- size = "medium",
18
- startIcon,
19
- endIcon,
20
- onClick,
21
- className,
22
- ...restProps
23
- }) => {
24
- const colorClasses = {
25
- negative: "bg-transparent text-button-text-negative-text",
26
- neutral: "bg-transparent text-button-text-neutral-text"
27
- }[color];
28
- const iconColorClasses = {
29
- negative: "text-button-text-negative-icon",
30
- neutral: "text-button-text-neutral-icon"
31
- }[color];
32
- return /* @__PURE__ */ jsxs(
33
- "button",
34
- {
35
- onClick: disabled ? void 0 : onClick,
36
- disabled: disabled || onClick === void 0,
37
- className: clsx(
38
- className,
39
- {
40
- "text-disabled-text": disabled,
41
- [clsx(colorClasses, "hover:bg-button-text-hover-background rounded-full")]: !disabled
42
- },
43
- ButtonSizePaddings[size]
44
- ),
45
- ...restProps,
46
- children: [
47
- startIcon && /* @__PURE__ */ jsx(
48
- "span",
49
- {
50
- className: clsx({
51
- [iconColorClasses]: !disabled,
52
- [`text-disabled-icon`]: disabled
53
- }),
54
- children: startIcon
55
- }
56
- ),
57
- children,
58
- endIcon && /* @__PURE__ */ jsx(
59
- "span",
60
- {
61
- className: clsx({
62
- [iconColorClasses]: !disabled,
63
- [`text-disabled-icon`]: disabled
64
- }),
65
- children: endIcon
66
- }
67
- )
68
- ]
69
- }
70
- );
71
- };
72
-
73
- // src/hooks/useLanguage.tsx
74
- import { createContext, useContext, useEffect as useEffect2, useState as useState2 } from "react";
75
-
76
- // src/hooks/useLocalStorage.tsx
77
- import { useCallback, useEffect, useState } from "react";
78
-
79
- // src/hooks/useLanguage.tsx
80
- import { jsx as jsx2 } from "react/jsx-runtime";
81
- var DEFAULT_LANGUAGE = "en";
82
- var LanguageContext = createContext({ language: DEFAULT_LANGUAGE, setLanguage: (v) => v });
83
- var useLanguage = () => useContext(LanguageContext);
84
-
85
- // src/hooks/useTranslation.ts
86
- var useTranslation = (defaults, translationOverwrite = {}) => {
87
- const { language: languageProp, translation: overwrite } = translationOverwrite;
88
- const { language: inferredLanguage } = useLanguage();
89
- const usedLanguage = languageProp ?? inferredLanguage;
90
- let defaultValues = defaults[usedLanguage];
91
- if (overwrite && overwrite[usedLanguage]) {
92
- defaultValues = { ...defaultValues, ...overwrite[usedLanguage] };
93
- }
94
- return defaultValues;
95
- };
96
-
97
- // src/components/properties/PropertyBase.tsx
98
- import { jsx as jsx3, jsxs as jsxs2 } from "react/jsx-runtime";
99
- var defaultPropertyBaseTranslation = {
100
- en: {
101
- remove: "Remove"
102
- },
103
- de: {
104
- remove: "Entfernen"
105
- }
106
- };
107
- var PropertyBase = ({
108
- overwriteTranslation,
109
- name,
110
- input,
111
- softRequired = false,
112
- hasValue,
113
- icon,
114
- readOnly,
115
- onRemove,
116
- className = ""
117
- }) => {
118
- const translation = useTranslation(defaultPropertyBaseTranslation, overwriteTranslation);
119
- const requiredAndNoValue = softRequired && !hasValue;
120
- return /* @__PURE__ */ jsxs2("div", { className: clsx2("row gap-x-0 group", className), children: [
121
- /* @__PURE__ */ jsxs2(
122
- "div",
123
- {
124
- className: clsx2("row gap-x-2 !w-[200px] px-4 py-2 items-center rounded-l-xl border-2 border-r-0", {
125
- "bg-gray-100 text-black group-hover:border-primary border-gray-400": !requiredAndNoValue,
126
- "bg-warning text-surface-warning group-hover:border-warning border-warning/90": requiredAndNoValue
127
- }, className),
128
- children: [
129
- icon,
130
- name
131
- ]
132
- }
133
- ),
134
- /* @__PURE__ */ jsxs2(
135
- "div",
136
- {
137
- className: clsx2("row grow justify-between items-center rounded-r-xl border-2 border-l-0", {
138
- "bg-white group-hover:border-primary border-gray-400": !requiredAndNoValue,
139
- "bg-surface-warning group-hover:border-warning border-warning/90": requiredAndNoValue
140
- }, className),
141
- children: [
142
- input({ softRequired, hasValue }),
143
- requiredAndNoValue && /* @__PURE__ */ jsx3("div", { className: "text-warning pr-4", children: /* @__PURE__ */ jsx3(AlertTriangle, { size: 24 }) }),
144
- onRemove && /* @__PURE__ */ jsx3(
145
- TextButton,
146
- {
147
- onClick: onRemove,
148
- color: "negative",
149
- className: clsx2("pr-4 items-center", { "!text-transparent": !hasValue || readOnly }),
150
- disabled: !hasValue || readOnly,
151
- children: translation.remove
152
- }
153
- )
154
- ]
155
- }
156
- )
157
- ] });
158
- };
159
- export {
160
- PropertyBase
161
- };
162
- //# sourceMappingURL=PropertyBase.mjs.map