@helpwave/hightide 0.0.19 → 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 -268
  174. package/dist/components/modals/ConfirmDialog.js.map +1 -1
  175. package/dist/components/modals/{DiscardChangesDialog.js → DiscardChangesModal.cjs} +210 -116
  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} +198 -104
  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 -301
  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 +305 -203
  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} +4005 -3881
  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 +3822 -4055
  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 -390
  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 -568
  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 -491
  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 -288
  523. package/dist/components/modals/Modal.js.map +0 -1
  524. package/dist/components/modals/Modal.mjs +0 -251
  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,51 +1,18 @@
1
- "use strict";
2
- var __create = Object.create;
3
- var __defProp = Object.defineProperty;
4
- var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
5
- var __getOwnPropNames = Object.getOwnPropertyNames;
6
- var __getProtoOf = Object.getPrototypeOf;
7
- var __hasOwnProp = Object.prototype.hasOwnProperty;
8
- var __export = (target, all) => {
9
- for (var name in all)
10
- __defProp(target, name, { get: all[name], enumerable: true });
11
- };
12
- var __copyProps = (to, from, except, desc) => {
13
- if (from && typeof from === "object" || typeof from === "function") {
14
- for (let key of __getOwnPropNames(from))
15
- if (!__hasOwnProp.call(to, key) && key !== except)
16
- __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
17
- }
18
- return to;
19
- };
20
- var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
21
- // If the importer is in node compatibility mode or this is not an ESM
22
- // file that has been converted to a CommonJS file using a Babel-
23
- // compatible transform (i.e. "__esModule" has not been set), then set
24
- // "default" to the CommonJS "module.exports" for node compatibility.
25
- isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
26
- mod
27
- ));
28
- var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
29
-
30
1
  // src/components/properties/CheckboxProperty.tsx
31
- var CheckboxProperty_exports = {};
32
- __export(CheckboxProperty_exports, {
33
- CheckboxProperty: () => CheckboxProperty
34
- });
35
- module.exports = __toCommonJS(CheckboxProperty_exports);
36
- var import_lucide_react3 = require("lucide-react");
2
+ import { Check as Check2 } from "lucide-react";
37
3
 
38
4
  // src/util/noop.ts
39
5
  var noop = () => void 0;
40
6
 
41
- // src/components/user-input/Checkbox.tsx
42
- var import_react = require("react");
43
- var CheckboxPrimitive = __toESM(require("@radix-ui/react-checkbox"));
44
- var import_lucide_react = require("lucide-react");
45
- var import_clsx = __toESM(require("clsx"));
7
+ // src/components/user-action/Checkbox.tsx
8
+ import { useState } from "react";
9
+ import * as CheckboxPrimitive from "@radix-ui/react-checkbox";
10
+ import { Check, Minus } from "lucide-react";
11
+ import clsx2 from "clsx";
46
12
 
47
- // src/components/user-input/Label.tsx
48
- var import_jsx_runtime = require("react/jsx-runtime");
13
+ // src/components/user-action/Label.tsx
14
+ import clsx from "clsx";
15
+ import { jsx } from "react/jsx-runtime";
49
16
  var styleMapping = {
50
17
  labelSmall: "textstyle-label-sm",
51
18
  labelMedium: "textstyle-label-md",
@@ -55,13 +22,14 @@ var Label = ({
55
22
  children,
56
23
  name,
57
24
  labelType = "labelSmall",
25
+ className,
58
26
  ...props
59
27
  }) => {
60
- return /* @__PURE__ */ (0, import_jsx_runtime.jsx)("label", { ...props, children: children ? children : /* @__PURE__ */ (0, import_jsx_runtime.jsx)("span", { className: styleMapping[labelType], children: name }) });
28
+ return /* @__PURE__ */ jsx("label", { ...props, className: clsx(styleMapping[labelType], className), children: children ? children : name });
61
29
  };
62
30
 
63
- // src/components/user-input/Checkbox.tsx
64
- var import_jsx_runtime2 = require("react/jsx-runtime");
31
+ // src/components/user-action/Checkbox.tsx
32
+ import { jsx as jsx2, jsxs } from "react/jsx-runtime";
65
33
  var checkboxSizeMapping = {
66
34
  small: "size-4",
67
35
  medium: "size-6",
@@ -72,7 +40,7 @@ var checkboxIconSizeMapping = {
72
40
  medium: "size-5",
73
41
  large: "size-7"
74
42
  };
75
- var ControlledCheckbox = ({
43
+ var Checkbox = ({
76
44
  id,
77
45
  label,
78
46
  checked,
@@ -97,43 +65,66 @@ var ControlledCheckbox = ({
97
65
  const newValue = checked === "indeterminate" ? false : !checked;
98
66
  propagateChange(newValue);
99
67
  };
100
- return /* @__PURE__ */ (0, import_jsx_runtime2.jsxs)("div", { className: (0, import_clsx.default)("row justify-center items-center", containerClassName), children: [
101
- /* @__PURE__ */ (0, import_jsx_runtime2.jsx)(
68
+ return /* @__PURE__ */ jsxs("div", { className: clsx2("row justify-center items-center", containerClassName), children: [
69
+ /* @__PURE__ */ jsx2(
102
70
  CheckboxPrimitive.Root,
103
71
  {
104
72
  onCheckedChange: propagateChange,
105
73
  checked,
106
74
  disabled,
107
75
  id,
108
- className: (0, import_clsx.default)(usedSizeClass, `items-center border-2 rounded outline-none focus:border-primary`, {
76
+ className: clsx2(usedSizeClass, `items-center border-2 rounded outline-none focus:border-primary`, {
109
77
  "text-disabled-text border-disabled-text": disabled,
110
78
  "border-on-background": !disabled,
111
79
  "bg-primary/30 border-primary text-primary": checked === true || checked === "indeterminate",
112
80
  "hover:border-gray-400 focus:hover:border-primary": !checked
113
81
  }, className),
114
- children: /* @__PURE__ */ (0, import_jsx_runtime2.jsxs)(CheckboxPrimitive.Indicator, { children: [
115
- checked === true && /* @__PURE__ */ (0, import_jsx_runtime2.jsx)(import_lucide_react.Check, { className: innerIconSize }),
116
- checked === "indeterminate" && /* @__PURE__ */ (0, import_jsx_runtime2.jsx)(import_lucide_react.Minus, { className: innerIconSize })
82
+ children: /* @__PURE__ */ jsxs(CheckboxPrimitive.Indicator, { children: [
83
+ checked === true && /* @__PURE__ */ jsx2(Check, { className: innerIconSize }),
84
+ checked === "indeterminate" && /* @__PURE__ */ jsx2(Minus, { className: innerIconSize })
117
85
  ] })
118
86
  }
119
87
  ),
120
- label && /* @__PURE__ */ (0, import_jsx_runtime2.jsx)(Label, { ...label, className: (0, import_clsx.default)("cursor-pointer", label.className), htmlFor: id, onClick: changeValue })
88
+ label && /* @__PURE__ */ jsx2(
89
+ Label,
90
+ {
91
+ ...label,
92
+ className: clsx2("cursor-pointer", label.className),
93
+ htmlFor: id,
94
+ onClick: changeValue
95
+ }
96
+ )
121
97
  ] });
122
98
  };
123
99
 
124
- // src/hooks/useLanguage.tsx
125
- var import_react3 = require("react");
100
+ // src/localization/LanguageProvider.tsx
101
+ import { createContext, useContext, useEffect as useEffect2, useState as useState3 } from "react";
126
102
 
127
- // src/hooks/useLocalStorage.tsx
128
- var import_react2 = require("react");
103
+ // src/hooks/useLocalStorage.ts
104
+ import { useCallback, useEffect, useState as useState2 } from "react";
129
105
 
130
- // src/hooks/useLanguage.tsx
131
- var import_jsx_runtime3 = require("react/jsx-runtime");
106
+ // src/localization/util.ts
107
+ var languages = ["en", "de"];
108
+ var languagesLocalNames = {
109
+ en: "English",
110
+ de: "Deutsch"
111
+ };
132
112
  var DEFAULT_LANGUAGE = "en";
133
- var LanguageContext = (0, import_react3.createContext)({ language: DEFAULT_LANGUAGE, setLanguage: (v) => v });
134
- var useLanguage = () => (0, import_react3.useContext)(LanguageContext);
113
+ var LanguageUtil = {
114
+ languages,
115
+ DEFAULT_LANGUAGE,
116
+ languagesLocalNames
117
+ };
118
+
119
+ // src/localization/LanguageProvider.tsx
120
+ import { jsx as jsx3 } from "react/jsx-runtime";
121
+ var LanguageContext = createContext({
122
+ language: LanguageUtil.DEFAULT_LANGUAGE,
123
+ setLanguage: (v) => v
124
+ });
125
+ var useLanguage = () => useContext(LanguageContext);
135
126
 
136
- // src/hooks/useTranslation.ts
127
+ // src/localization/useTranslation.ts
137
128
  var useTranslation = (defaults, translationOverwrite = {}) => {
138
129
  const { language: languageProp, translation: overwrite } = translationOverwrite;
139
130
  const { language: inferredLanguage } = useLanguage();
@@ -146,17 +137,26 @@ var useTranslation = (defaults, translationOverwrite = {}) => {
146
137
  };
147
138
 
148
139
  // src/components/properties/PropertyBase.tsx
149
- var import_lucide_react2 = require("lucide-react");
150
- var import_clsx3 = __toESM(require("clsx"));
140
+ import { AlertTriangle } from "lucide-react";
141
+ import clsx4 from "clsx";
151
142
 
152
- // src/components/Button.tsx
153
- var import_clsx2 = __toESM(require("clsx"));
154
- var import_jsx_runtime4 = require("react/jsx-runtime");
155
- var ButtonSizePaddings = {
143
+ // src/components/user-action/Button.tsx
144
+ import clsx3 from "clsx";
145
+ import { jsx as jsx4, jsxs as jsxs2 } from "react/jsx-runtime";
146
+ var paddingMapping = {
156
147
  small: "btn-sm",
157
148
  medium: "btn-md",
158
149
  large: "btn-lg"
159
150
  };
151
+ var iconPaddingMapping = {
152
+ small: "icon-btn-sm",
153
+ medium: "icon-btn-md",
154
+ large: "icon-btn-lg"
155
+ };
156
+ var ButtonUtil = {
157
+ paddingMapping,
158
+ iconPaddingMapping
159
+ };
160
160
  var TextButton = ({
161
161
  children,
162
162
  disabled = false,
@@ -169,32 +169,34 @@ var TextButton = ({
169
169
  ...restProps
170
170
  }) => {
171
171
  const colorClasses = {
172
+ primary: "bg-transparent text-button-text-primary-text",
172
173
  negative: "bg-transparent text-button-text-negative-text",
173
174
  neutral: "bg-transparent text-button-text-neutral-text"
174
175
  }[color];
175
176
  const iconColorClasses = {
177
+ primary: "text-button-text-primary-icon",
176
178
  negative: "text-button-text-negative-icon",
177
179
  neutral: "text-button-text-neutral-icon"
178
180
  }[color];
179
- return /* @__PURE__ */ (0, import_jsx_runtime4.jsxs)(
181
+ return /* @__PURE__ */ jsxs2(
180
182
  "button",
181
183
  {
182
184
  onClick: disabled ? void 0 : onClick,
183
185
  disabled: disabled || onClick === void 0,
184
- className: (0, import_clsx2.default)(
186
+ className: clsx3(
185
187
  className,
186
188
  {
187
189
  "text-disabled-text": disabled,
188
- [(0, import_clsx2.default)(colorClasses, "hover:bg-button-text-hover-background rounded-full")]: !disabled
190
+ [clsx3(colorClasses, "hover:bg-button-text-hover-background rounded-full")]: !disabled
189
191
  },
190
- ButtonSizePaddings[size]
192
+ ButtonUtil.paddingMapping[size]
191
193
  ),
192
194
  ...restProps,
193
195
  children: [
194
- startIcon && /* @__PURE__ */ (0, import_jsx_runtime4.jsx)(
196
+ startIcon && /* @__PURE__ */ jsx4(
195
197
  "span",
196
198
  {
197
- className: (0, import_clsx2.default)({
199
+ className: clsx3({
198
200
  [iconColorClasses]: !disabled,
199
201
  [`text-disabled-icon`]: disabled
200
202
  }),
@@ -202,10 +204,10 @@ var TextButton = ({
202
204
  }
203
205
  ),
204
206
  children,
205
- endIcon && /* @__PURE__ */ (0, import_jsx_runtime4.jsx)(
207
+ endIcon && /* @__PURE__ */ jsx4(
206
208
  "span",
207
209
  {
208
- className: (0, import_clsx2.default)({
210
+ className: clsx3({
209
211
  [iconColorClasses]: !disabled,
210
212
  [`text-disabled-icon`]: disabled
211
213
  }),
@@ -218,7 +220,7 @@ var TextButton = ({
218
220
  };
219
221
 
220
222
  // src/components/properties/PropertyBase.tsx
221
- var import_jsx_runtime5 = require("react/jsx-runtime");
223
+ import { jsx as jsx5, jsxs as jsxs3 } from "react/jsx-runtime";
222
224
  var defaultPropertyBaseTranslation = {
223
225
  en: {
224
226
  remove: "Remove"
@@ -240,11 +242,11 @@ var PropertyBase = ({
240
242
  }) => {
241
243
  const translation = useTranslation(defaultPropertyBaseTranslation, overwriteTranslation);
242
244
  const requiredAndNoValue = softRequired && !hasValue;
243
- return /* @__PURE__ */ (0, import_jsx_runtime5.jsxs)("div", { className: (0, import_clsx3.default)("row gap-x-0 group", className), children: [
244
- /* @__PURE__ */ (0, import_jsx_runtime5.jsxs)(
245
+ return /* @__PURE__ */ jsxs3("div", { className: clsx4("row gap-x-0 group", className), children: [
246
+ /* @__PURE__ */ jsxs3(
245
247
  "div",
246
248
  {
247
- className: (0, import_clsx3.default)("row gap-x-2 !w-[200px] px-4 py-2 items-center rounded-l-xl border-2 border-r-0", {
249
+ className: clsx4("row gap-x-2 !w-[200px] px-4 py-2 items-center rounded-l-xl border-2 border-r-0", {
248
250
  "bg-gray-100 text-black group-hover:border-primary border-gray-400": !requiredAndNoValue,
249
251
  "bg-warning text-surface-warning group-hover:border-warning border-warning/90": requiredAndNoValue
250
252
  }, className),
@@ -254,22 +256,22 @@ var PropertyBase = ({
254
256
  ]
255
257
  }
256
258
  ),
257
- /* @__PURE__ */ (0, import_jsx_runtime5.jsxs)(
259
+ /* @__PURE__ */ jsxs3(
258
260
  "div",
259
261
  {
260
- className: (0, import_clsx3.default)("row grow justify-between items-center rounded-r-xl border-2 border-l-0", {
262
+ className: clsx4("row grow justify-between items-center rounded-r-xl border-2 border-l-0", {
261
263
  "bg-white group-hover:border-primary border-gray-400": !requiredAndNoValue,
262
264
  "bg-surface-warning group-hover:border-warning border-warning/90": requiredAndNoValue
263
265
  }, className),
264
266
  children: [
265
267
  input({ softRequired, hasValue }),
266
- requiredAndNoValue && /* @__PURE__ */ (0, import_jsx_runtime5.jsx)("div", { className: "text-warning pr-4", children: /* @__PURE__ */ (0, import_jsx_runtime5.jsx)(import_lucide_react2.AlertTriangle, { size: 24 }) }),
267
- onRemove && /* @__PURE__ */ (0, import_jsx_runtime5.jsx)(
268
+ requiredAndNoValue && /* @__PURE__ */ jsx5("div", { className: "text-warning pr-4", children: /* @__PURE__ */ jsx5(AlertTriangle, { size: 24 }) }),
269
+ onRemove && /* @__PURE__ */ jsx5(
268
270
  TextButton,
269
271
  {
270
272
  onClick: onRemove,
271
273
  color: "negative",
272
- className: (0, import_clsx3.default)("pr-4 items-center", { "!text-transparent": !hasValue || readOnly }),
274
+ className: clsx4("pr-4 items-center", { "!text-transparent": !hasValue || readOnly }),
273
275
  disabled: !hasValue || readOnly,
274
276
  children: translation.remove
275
277
  }
@@ -281,7 +283,7 @@ var PropertyBase = ({
281
283
  };
282
284
 
283
285
  // src/components/properties/CheckboxProperty.tsx
284
- var import_jsx_runtime6 = require("react/jsx-runtime");
286
+ import { jsx as jsx6 } from "react/jsx-runtime";
285
287
  var defaultCheckboxPropertyTranslation = {
286
288
  en: {
287
289
  yes: "Yes",
@@ -300,15 +302,15 @@ var CheckboxProperty = ({
300
302
  ...baseProps
301
303
  }) => {
302
304
  const translation = useTranslation(defaultCheckboxPropertyTranslation, overwriteTranslation);
303
- return /* @__PURE__ */ (0, import_jsx_runtime6.jsx)(
305
+ return /* @__PURE__ */ jsx6(
304
306
  PropertyBase,
305
307
  {
306
308
  ...baseProps,
307
309
  hasValue: true,
308
310
  readOnly,
309
- icon: /* @__PURE__ */ (0, import_jsx_runtime6.jsx)(import_lucide_react3.Check, { size: 16 }),
310
- input: () => /* @__PURE__ */ (0, import_jsx_runtime6.jsx)("div", { className: "row py-2 px-4 items-center", children: /* @__PURE__ */ (0, import_jsx_runtime6.jsx)(
311
- ControlledCheckbox,
311
+ icon: /* @__PURE__ */ jsx6(Check2, { size: 16 }),
312
+ input: () => /* @__PURE__ */ jsx6("div", { className: "row py-2 px-4 items-center", children: /* @__PURE__ */ jsx6(
313
+ Checkbox,
312
314
  {
313
315
  checked: value ?? true,
314
316
  disabled: readOnly,
@@ -319,8 +321,7 @@ var CheckboxProperty = ({
319
321
  }
320
322
  );
321
323
  };
322
- // Annotate the CommonJS export names for ESM import in node:
323
- 0 && (module.exports = {
324
+ export {
324
325
  CheckboxProperty
325
- });
326
+ };
326
327
  //# sourceMappingURL=CheckboxProperty.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/components/properties/CheckboxProperty.tsx","../../../src/util/noop.ts","../../../src/components/user-input/Checkbox.tsx","../../../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 { Check } from 'lucide-react'\nimport { noop } from '../../util/noop'\nimport { Checkbox } from '../user-input/Checkbox'\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 CheckboxPropertyTranslation = {\n yes: string,\n no: string,\n}\n\nconst defaultCheckboxPropertyTranslation: Record<Languages, CheckboxPropertyTranslation> = {\n en: {\n yes: 'Yes',\n no: 'No'\n },\n de: {\n yes: 'Ja',\n no: 'Nein'\n }\n}\n\nexport type CheckboxPropertyProps = Omit<PropertyBaseProps, 'icon' | 'input' | 'hasValue' | 'onRemove'> & {\n value?: boolean,\n onChange?: (value: boolean) => void,\n}\n\n/**\n * An Input for a boolen properties\n */\nexport const CheckboxProperty = ({\n overwriteTranslation,\n value,\n onChange = noop,\n readOnly,\n ...baseProps\n }: PropsForTranslation<CheckboxPropertyTranslation, CheckboxPropertyProps>) => {\n const translation = useTranslation(defaultCheckboxPropertyTranslation, overwriteTranslation)\n\n return (\n <PropertyBase\n {...baseProps}\n hasValue={true}\n readOnly={readOnly}\n icon={<Check size={16}/>}\n input={() => (\n <div className=\"row py-2 px-4 items-center\">\n <Checkbox\n // TODO make bigger as in #904\n checked={value ?? true}\n disabled={readOnly}\n onChange={onChange}\n label={{ name: `${translation.yes}/${translation.no}`, labelType: 'labelMedium' }}\n />\n </div>\n )}\n />\n )\n}\n","export const noop = () => undefined\n","import { useState } from 'react'\nimport * as CheckboxPrimitive from '@radix-ui/react-checkbox'\nimport type { CheckedState } from '@radix-ui/react-checkbox'\nimport { Check, Minus } from 'lucide-react'\nimport clsx from 'clsx'\nimport type { LabelProps } from './Label'\nimport { Label } from './Label'\n\ntype CheckBoxSize = 'small' | 'medium' | 'large'\n\nconst checkboxSizeMapping: Record<CheckBoxSize, string> = {\n small: 'size-4',\n medium: 'size-6',\n large: 'size-8',\n}\n\nconst checkboxIconSizeMapping: Record<CheckBoxSize, string> = {\n small: 'size-3',\n medium: 'size-5',\n large: 'size-7',\n}\n\ntype CheckboxProps = {\n /** used for the label's `for` attribute */\n id?: string,\n label?: Omit<LabelProps, 'id'>,\n /**\n * @default false\n */\n checked: CheckedState,\n disabled?: boolean,\n onChange?: (checked: boolean) => void,\n onChangeTristate?: (checked: CheckedState) => void,\n size?: CheckBoxSize,\n className?: string,\n containerClassName?: string,\n}\n\n/**\n * A Tristate checkbox\n *\n * The state is managed by the parent\n */\nconst ControlledCheckbox = ({\n id,\n label,\n checked,\n disabled,\n onChange,\n onChangeTristate,\n size = 'medium',\n className = '',\n containerClassName\n }: CheckboxProps) => {\n const usedSizeClass = checkboxSizeMapping[size]\n const innerIconSize = checkboxIconSizeMapping[size]\n\n const propagateChange = (checked: CheckedState) => {\n if (onChangeTristate) {\n onChangeTristate(checked)\n }\n if (onChange) {\n onChange(checked === 'indeterminate' ? false : checked)\n }\n }\n\n const changeValue = () => {\n const newValue = checked === 'indeterminate' ? false : !checked\n propagateChange(newValue)\n }\n\n return (\n <div className={clsx('row justify-center items-center', containerClassName)}>\n <CheckboxPrimitive.Root\n onCheckedChange={propagateChange}\n checked={checked}\n disabled={disabled}\n id={id}\n className={clsx(usedSizeClass, `items-center border-2 rounded outline-none focus:border-primary`, {\n 'text-disabled-text border-disabled-text': disabled,\n 'border-on-background': !disabled,\n 'bg-primary/30 border-primary text-primary': checked === true || checked === 'indeterminate',\n 'hover:border-gray-400 focus:hover:border-primary': !checked\n }, className)}\n >\n <CheckboxPrimitive.Indicator>\n {checked === true && <Check className={innerIconSize}/>}\n {checked === 'indeterminate' && <Minus className={innerIconSize}/>}\n </CheckboxPrimitive.Indicator>\n </CheckboxPrimitive.Root>\n {label &&\n <Label {...label} className={clsx('cursor-pointer', label.className)} htmlFor={id} onClick={changeValue}/>}\n </div>\n )\n}\n\ntype UncontrolledCheckboxProps = Omit<CheckboxProps, 'value' | 'checked'> & {\n /**\n * @default false\n */\n defaultValue?: CheckedState,\n}\n\n/**\n * A Tristate checkbox\n *\n * The state is managed by this component\n */\nconst UncontrolledCheckbox = ({\n onChange,\n onChangeTristate,\n defaultValue = false,\n ...props\n }: UncontrolledCheckboxProps) => {\n const [checked, setChecked] = useState(defaultValue)\n\n const handleChange = (checked: CheckedState) => {\n if (onChangeTristate) {\n onChangeTristate(checked)\n }\n if (onChange) {\n onChange(checked === 'indeterminate' ? false : checked)\n }\n setChecked(checked)\n }\n\n return (\n <ControlledCheckbox\n {...props}\n checked={checked}\n onChangeTristate={handleChange}\n />\n )\n}\n\nexport {\n UncontrolledCheckbox,\n ControlledCheckbox as Checkbox\n}\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":["import_lucide_react","import_jsx_runtime","checked","clsx","import_react","import_react","import_jsx_runtime","import_lucide_react","import_clsx","import_clsx","import_jsx_runtime","clsx","import_jsx_runtime","clsx","import_jsx_runtime"]}
1
+ {"version":3,"sources":["../../../src/components/properties/CheckboxProperty.tsx","../../../src/util/noop.ts","../../../src/components/user-action/Checkbox.tsx","../../../src/components/user-action/Label.tsx","../../../src/localization/LanguageProvider.tsx","../../../src/hooks/useLocalStorage.ts","../../../src/localization/util.ts","../../../src/localization/useTranslation.ts","../../../src/components/properties/PropertyBase.tsx","../../../src/components/user-action/Button.tsx"],"sourcesContent":["import { Check } from 'lucide-react'\nimport { noop } from '../../util/noop'\nimport { Checkbox } from '../user-action/Checkbox'\nimport type { Language } from '../../localization/util'\nimport type { PropsForTranslation } from '../../localization/useTranslation'\nimport { useTranslation } from '../../localization/useTranslation'\nimport type { PropertyBaseProps } from './PropertyBase'\nimport { PropertyBase } from './PropertyBase'\n\ntype CheckboxPropertyTranslation = {\n yes: string,\n no: string,\n}\n\nconst defaultCheckboxPropertyTranslation: Record<Language, CheckboxPropertyTranslation> = {\n en: {\n yes: 'Yes',\n no: 'No'\n },\n de: {\n yes: 'Ja',\n no: 'Nein'\n }\n}\n\nexport type CheckboxPropertyProps = Omit<PropertyBaseProps, 'icon' | 'input' | 'hasValue' | 'onRemove'> & {\n value?: boolean,\n onChange?: (value: boolean) => void,\n}\n\n/**\n * An Input for a boolen properties\n */\nexport const CheckboxProperty = ({\n overwriteTranslation,\n value,\n onChange = noop,\n readOnly,\n ...baseProps\n }: PropsForTranslation<CheckboxPropertyTranslation, CheckboxPropertyProps>) => {\n const translation = useTranslation(defaultCheckboxPropertyTranslation, overwriteTranslation)\n\n return (\n <PropertyBase\n {...baseProps}\n hasValue={true}\n readOnly={readOnly}\n icon={<Check size={16}/>}\n input={() => (\n <div className=\"row py-2 px-4 items-center\">\n <Checkbox\n // TODO make bigger as in #904\n checked={value ?? true}\n disabled={readOnly}\n onChange={onChange}\n label={{ name: `${translation.yes}/${translation.no}`, labelType: 'labelMedium' }}\n />\n </div>\n )}\n />\n )\n}\n","export const noop = () => undefined\n","import { useState } from 'react'\nimport type { CheckedState } from '@radix-ui/react-checkbox'\nimport * as CheckboxPrimitive from '@radix-ui/react-checkbox'\nimport { Check, Minus } from 'lucide-react'\nimport clsx from 'clsx'\nimport type { LabelProps } from './Label'\nimport { Label } from './Label'\n\ntype CheckBoxSize = 'small' | 'medium' | 'large'\n\nconst checkboxSizeMapping: Record<CheckBoxSize, string> = {\n small: 'size-4',\n medium: 'size-6',\n large: 'size-8',\n}\n\nconst checkboxIconSizeMapping: Record<CheckBoxSize, string> = {\n small: 'size-3',\n medium: 'size-5',\n large: 'size-7',\n}\n\ntype CheckboxProps = {\n /** used for the label's `for` attribute */\n id?: string,\n label?: Omit<LabelProps, 'id'>,\n /**\n * @default false\n */\n checked: CheckedState,\n disabled?: boolean,\n onChange?: (checked: boolean) => void,\n onChangeTristate?: (checked: CheckedState) => void,\n size?: CheckBoxSize,\n className?: string,\n containerClassName?: string,\n}\n\n/**\n * A Tristate checkbox\n *\n * The state is managed by the parent\n */\nconst Checkbox = ({\n id,\n label,\n checked,\n disabled,\n onChange,\n onChangeTristate,\n size = 'medium',\n className = '',\n containerClassName\n }: CheckboxProps) => {\n const usedSizeClass = checkboxSizeMapping[size]\n const innerIconSize = checkboxIconSizeMapping[size]\n\n const propagateChange = (checked: CheckedState) => {\n if (onChangeTristate) {\n onChangeTristate(checked)\n }\n if (onChange) {\n onChange(checked === 'indeterminate' ? false : checked)\n }\n }\n\n const changeValue = () => {\n const newValue = checked === 'indeterminate' ? false : !checked\n propagateChange(newValue)\n }\n\n return (\n <div className={clsx('row justify-center items-center', containerClassName)}>\n <CheckboxPrimitive.Root\n onCheckedChange={propagateChange}\n checked={checked}\n disabled={disabled}\n id={id}\n className={clsx(usedSizeClass, `items-center border-2 rounded outline-none focus:border-primary`, {\n 'text-disabled-text border-disabled-text': disabled,\n 'border-on-background': !disabled,\n 'bg-primary/30 border-primary text-primary': checked === true || checked === 'indeterminate',\n 'hover:border-gray-400 focus:hover:border-primary': !checked\n }, className)}\n >\n <CheckboxPrimitive.Indicator>\n {checked === true && <Check className={innerIconSize}/>}\n {checked === 'indeterminate' && <Minus className={innerIconSize}/>}\n </CheckboxPrimitive.Indicator>\n </CheckboxPrimitive.Root>\n {label && (\n <Label {...label} className={clsx('cursor-pointer', label.className)} htmlFor={id}\n onClick={changeValue}/>\n )}\n </div>\n )\n}\n\ntype CheckboxUncontrolledProps = Omit<CheckboxProps, 'value' | 'checked'> & {\n /**\n * @default false\n */\n defaultValue?: CheckedState,\n}\n\n/**\n * A Tristate checkbox\n *\n * The state is managed by this component\n */\nconst CheckboxUncontrolled = ({\n onChange,\n onChangeTristate,\n defaultValue = false,\n ...props\n }: CheckboxUncontrolledProps) => {\n const [checked, setChecked] = useState(defaultValue)\n\n const handleChange = (checked: CheckedState) => {\n if (onChangeTristate) {\n onChangeTristate(checked)\n }\n if (onChange) {\n onChange(checked === 'indeterminate' ? false : checked)\n }\n setChecked(checked)\n }\n\n return (\n <Checkbox\n {...props}\n checked={checked}\n onChangeTristate={handleChange}\n />\n )\n}\n\nexport {\n CheckboxProps,\n CheckboxUncontrolled,\n Checkbox,\n}\n","import type { LabelHTMLAttributes } from 'react'\nimport clsx from 'clsx'\n\nexport type LabelType = 'labelSmall' | 'labelMedium' | 'labelBig'\n\nconst styleMapping: Record<LabelType, string> = {\n labelSmall: 'textstyle-label-sm',\n labelMedium: 'textstyle-label-md',\n labelBig: 'textstyle-label-lg',\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 className,\n ...props\n }: LabelProps) => {\n return (\n <label {...props} className={clsx(styleMapping[labelType], className)}>\n {children ? children : name}\n </label>\n )\n}\n","import type { Dispatch, PropsWithChildren, SetStateAction } from 'react'\nimport { createContext, useContext, useEffect, useState } from 'react'\nimport { useLocalStorage } from '@/hooks/useLocalStorage'\nimport type { Language } from './util'\nimport { LanguageUtil } from './util'\n\nexport type LanguageContextValue = {\n language: Language,\n setLanguage: Dispatch<SetStateAction<Language>>,\n}\n\nexport const LanguageContext = createContext<LanguageContextValue>({\n language: LanguageUtil.DEFAULT_LANGUAGE,\n setLanguage: (v) => v\n})\n\nexport const useLanguage = () => useContext(LanguageContext)\n\nexport const useLocale = (overWriteLanguage?: Language) => {\n const { language } = useLanguage()\n const mapping: Record<Language, string> = {\n en: 'en-US',\n de: 'de-DE'\n }\n return mapping[overWriteLanguage ?? language]\n}\n\ntype LanguageProviderProps = {\n initialLanguage?: Language,\n}\n\nexport const LanguageProvider = ({ initialLanguage, children }: PropsWithChildren<LanguageProviderProps>) => {\n const [language, setLanguage] = useState<Language>(initialLanguage ?? LanguageUtil.DEFAULT_LANGUAGE)\n const [storedLanguage, setStoredLanguage] = useLocalStorage<Language>('language', initialLanguage ?? LanguageUtil.DEFAULT_LANGUAGE)\n\n useEffect(() => {\n if (language !== initialLanguage && initialLanguage) {\n console.warn('LanguageProvider initial state changed: Prefer using languageProvider\\'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 LanguageToTestAgainst = Object.values(LanguageUtil.languages)\n\n const matchingBrowserLanguage = window.navigator.languages\n .map(language => LanguageToTestAgainst.find((test) => language === test || language.split('-')[0] === test))\n .filter(entry => entry !== undefined)\n\n if (matchingBrowserLanguage.length === 0) return\n\n const firstMatch = matchingBrowserLanguage[0] as Language\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}","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}","/**\n * The supported languages\n */\nconst languages = ['en', 'de'] as const\n\n/**\n * The supported languages\n */\nexport type Language = typeof languages[number]\n\n/**\n * The supported languages' names in their respective language\n */\nconst languagesLocalNames: Record<Language, string> = {\n en: 'English',\n de: 'Deutsch',\n}\n\n/**\n * The default language\n */\nconst DEFAULT_LANGUAGE: Language = 'en'\n\n/**\n * A constant definition for holding data regarding languages\n */\nexport const LanguageUtil = {\n languages,\n DEFAULT_LANGUAGE,\n languagesLocalNames,\n}","import { useLanguage } from './LanguageProvider'\nimport type { Language } from './util'\n\nexport type Translation<T> = Record<Language, T>\n\ntype OverwriteTranslationType<Translation extends Record<string, unknown>> = {\n language?: Language,\n translation?: Partial<Record<Language, 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<Language, 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 { Language } from '../../localization/util'\nimport { TextButton } from '../user-action/Button'\nimport type { PropsForTranslation } from '../../localization/useTranslation'\nimport { useTranslation } from '../../localization/useTranslation'\n\ntype PropertyBaseTranslation = {\n remove: string,\n}\n\nconst defaultPropertyBaseTranslation: Record<Language, 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 { ButtonHTMLAttributes, PropsWithChildren, ReactNode } from 'react'\nimport clsx from 'clsx'\n\n\nexport const ButtonColorUtil = {\n solid: ['primary', 'secondary', 'tertiary', 'positive', 'warning', 'negative', 'neutral'] as const,\n text: ['primary', 'negative', 'neutral'] as const,\n outline: ['primary'] as const,\n}\n\n\n/**\n * The allowed colors for the SolidButton and IconButton\n */\nexport type SolidButtonColor = typeof ButtonColorUtil.solid[number]\n/**\n * The allowed colors for the OutlineButton\n */\nexport type OutlineButtonColor = typeof ButtonColorUtil.outline[number]\n/**\n * The allowed colors for the TextButton\n */\nexport type TextButtonColor = typeof ButtonColorUtil.text[number]\n\n/**\n * The different sizes for a button\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\nconst paddingMapping: Record<ButtonSizes, string> = {\n small: 'btn-sm',\n medium: 'btn-md',\n large: 'btn-lg'\n}\n\nconst iconPaddingMapping: Record<ButtonSizes, string> = {\n small: 'icon-btn-sm',\n medium: 'icon-btn-md',\n large: 'icon-btn-lg'\n}\n\nexport const ButtonUtil = {\n paddingMapping,\n iconPaddingMapping\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\nexport type IconButtonProps = ButtonProps & {\n color?: SolidButtonColor,\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 neutral: 'bg-button-solid-neutral-background text-button-solid-neutral-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 neutral: 'text-button-solid-neutral-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 ButtonUtil.paddingMapping[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 ButtonUtil.paddingMapping[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 primary: 'bg-transparent text-button-text-primary-text',\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 primary: 'text-button-text-primary-icon',\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 ButtonUtil.paddingMapping[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/**\n * A button for icons with a solid background and different sizes\n */\nconst IconButton = ({\n children,\n disabled = false,\n color = 'primary',\n size = 'medium',\n onClick,\n className,\n ...restProps\n }: IconButtonProps) => {\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 neutral: 'bg-button-solid-neutral-background text-button-solid-neutral-text',\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 ButtonUtil.iconPaddingMapping[size]\n )}\n {...restProps}\n >\n {children}\n </button>\n )\n}\n\nexport { SolidButton, OutlineButton, TextButton, IconButton }\n"],"mappings":"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","names":["Check","clsx","jsx","checked","clsx","useEffect","useState","useState","jsx","clsx","clsx","jsx","jsxs","jsxs","clsx","jsx","jsx","jsxs","clsx","jsx","Check"]}