@dbcdk/react-components 0.0.102 → 0.0.104

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 (355) hide show
  1. package/dist/assets/logo.cjs +87 -0
  2. package/dist/assets/logo.js +85 -0
  3. package/dist/client.cjs +587 -0
  4. package/dist/client.d.ts +83 -0
  5. package/dist/client.js +84 -0
  6. package/dist/components/accordion/Accordion.cjs +103 -0
  7. package/dist/components/accordion/Accordion.js +97 -0
  8. package/dist/components/accordion/Accordion.module.css +41 -0
  9. package/dist/components/accordion/components/AccordionRow.cjs +115 -0
  10. package/dist/components/accordion/components/AccordionRow.js +109 -0
  11. package/dist/components/accordion/components/AccordionRow.module.css +99 -0
  12. package/dist/components/alert/Alert.cjs +52 -0
  13. package/dist/components/alert/Alert.d.ts +2 -1
  14. package/dist/components/alert/Alert.js +46 -0
  15. package/dist/components/alert/Alert.module.css +97 -0
  16. package/dist/components/app-header/AppHeader.cjs +14 -0
  17. package/dist/components/app-header/AppHeader.js +8 -0
  18. package/dist/components/app-header/AppHeader.module.css +74 -0
  19. package/dist/components/attribute-chip/AttributeChip.cjs +22 -0
  20. package/dist/components/attribute-chip/AttributeChip.js +16 -0
  21. package/dist/components/attribute-chip/AttributeChip.module.css +65 -0
  22. package/dist/components/avatar/Avatar.cjs +111 -0
  23. package/dist/components/avatar/Avatar.js +86 -0
  24. package/dist/components/avatar/Avatar.module.css +91 -0
  25. package/dist/components/breadcrumbs/Breadcrumbs.cjs +24 -0
  26. package/dist/components/breadcrumbs/Breadcrumbs.js +18 -0
  27. package/dist/components/breadcrumbs/Breadcrumbs.module.css +80 -0
  28. package/dist/components/button/Button.cjs +149 -0
  29. package/dist/components/button/Button.js +124 -0
  30. package/dist/components/button/Button.module.css +260 -0
  31. package/dist/components/button-select/ButtonSelect.cjs +35 -0
  32. package/dist/components/button-select/ButtonSelect.js +29 -0
  33. package/dist/components/button-select/ButtonSelect.module.css +40 -0
  34. package/dist/components/card/Card.cjs +112 -0
  35. package/dist/components/card/Card.d.ts +2 -1
  36. package/dist/components/card/Card.js +106 -0
  37. package/dist/components/card/Card.module.css +187 -0
  38. package/dist/components/card/components/CardMeta.cjs +62 -0
  39. package/dist/components/card/components/CardMeta.js +55 -0
  40. package/dist/components/card/components/CardMeta.module.css +55 -0
  41. package/dist/components/card-container/CardContainer.cjs +34 -0
  42. package/dist/components/card-container/CardContainer.js +28 -0
  43. package/dist/components/card-container/CardContainer.module.css +63 -0
  44. package/dist/components/chip/Chip.cjs +65 -0
  45. package/dist/components/chip/Chip.js +59 -0
  46. package/dist/components/chip/Chip.module.css +236 -0
  47. package/dist/components/circle/Circle.cjs +33 -0
  48. package/dist/components/circle/Circle.js +27 -0
  49. package/dist/components/circle/Circle.module.css +128 -0
  50. package/dist/components/clear-button/ClearButton.cjs +33 -0
  51. package/dist/components/clear-button/ClearButton.d.ts +2 -1
  52. package/dist/components/clear-button/ClearButton.js +27 -0
  53. package/dist/components/clear-button/ClearButton.module.css +26 -0
  54. package/dist/components/code-block/CodeBlock.cjs +97 -0
  55. package/dist/components/code-block/CodeBlock.js +91 -0
  56. package/dist/components/code-block/CodeBlock.module.css +124 -0
  57. package/dist/components/copy-button/CopyButton.cjs +139 -0
  58. package/dist/components/copy-button/CopyButton.js +133 -0
  59. package/dist/components/copy-button/CopyButton.module.css +22 -0
  60. package/dist/components/datetime-picker/DateTimePicker.cjs +559 -0
  61. package/dist/components/datetime-picker/DateTimePicker.js +553 -0
  62. package/dist/components/datetime-picker/DateTimePicker.module.css +155 -0
  63. package/dist/components/datetime-picker/dateTimeHelpers.cjs +179 -0
  64. package/dist/components/datetime-picker/dateTimeHelpers.js +160 -0
  65. package/dist/components/divider/Divider.cjs +22 -0
  66. package/dist/components/divider/Divider.js +20 -0
  67. package/dist/components/filter-field/FilterField.cjs +296 -0
  68. package/dist/components/filter-field/FilterField.js +289 -0
  69. package/dist/components/filter-field/FilterField.module.css +379 -0
  70. package/dist/components/filtering/chip-multi-toggle/ChipMultiToggle.cjs +115 -0
  71. package/dist/components/filtering/chip-multi-toggle/ChipMultiToggle.js +108 -0
  72. package/dist/components/filtering/chip-multi-toggle/ChipMultiToggle.module.css +59 -0
  73. package/dist/components/forms/checkbox/Checkbox.cjs +88 -0
  74. package/dist/components/forms/checkbox/Checkbox.js +82 -0
  75. package/dist/components/forms/checkbox/Checkbox.module.css +104 -0
  76. package/dist/components/forms/checkbox-group/CheckboxGroup.cjs +121 -0
  77. package/dist/components/forms/checkbox-group/CheckboxGroup.js +115 -0
  78. package/dist/components/forms/checkbox-group/CheckboxGroup.module.css +115 -0
  79. package/dist/components/forms/form-select/FormSelect.cjs +191 -0
  80. package/dist/components/forms/form-select/FormSelect.js +166 -0
  81. package/dist/components/forms/form-select/FormSelect.module.css +236 -0
  82. package/dist/components/forms/input/Input.cjs +188 -0
  83. package/dist/components/forms/input/Input.d.ts +1 -0
  84. package/dist/components/forms/input/Input.js +182 -0
  85. package/dist/components/forms/input/Input.module.css +468 -0
  86. package/dist/components/forms/input-container/InputContainer.cjs +72 -0
  87. package/dist/components/forms/input-container/InputContainer.js +66 -0
  88. package/dist/components/forms/input-container/InputContainer.module.css +59 -0
  89. package/dist/components/forms/multi-select/MultiSelect.cjs +227 -0
  90. package/dist/components/forms/multi-select/MultiSelect.js +225 -0
  91. package/dist/components/forms/radio-buttons/RadioButton.cjs +91 -0
  92. package/dist/components/forms/radio-buttons/RadioButton.js +85 -0
  93. package/dist/components/forms/radio-buttons/RadioButtonGroup.cjs +74 -0
  94. package/dist/components/forms/radio-buttons/RadioButtonGroup.js +72 -0
  95. package/dist/components/forms/radio-buttons/RadioButtons.module.css +118 -0
  96. package/dist/components/forms/select/Select.cjs +286 -0
  97. package/dist/components/forms/select/Select.js +280 -0
  98. package/dist/components/forms/select/Select.module.css +32 -0
  99. package/dist/components/forms/text-area/Textarea.cjs +116 -0
  100. package/dist/components/forms/text-area/Textarea.js +110 -0
  101. package/dist/components/forms/text-area/Textarea.module.css +70 -0
  102. package/dist/components/forms/typeahead/Typeahead.cjs +792 -0
  103. package/dist/components/forms/typeahead/Typeahead.js +768 -0
  104. package/dist/components/forms/typeahead/Typeahead.module.css +38 -0
  105. package/dist/components/grid/Grid.cjs +45 -0
  106. package/dist/components/grid/Grid.js +38 -0
  107. package/dist/components/grid/Grid.module.css +35 -0
  108. package/dist/components/headline/CollapsibleHeadline.cjs +80 -0
  109. package/dist/components/headline/CollapsibleHeadline.js +74 -0
  110. package/dist/components/headline/Headline.cjs +59 -0
  111. package/dist/components/headline/Headline.js +53 -0
  112. package/dist/components/headline/Headline.module.css +185 -0
  113. package/dist/components/hyperlink/Hyperlink.cjs +107 -0
  114. package/dist/components/hyperlink/Hyperlink.d.ts +1 -0
  115. package/dist/components/hyperlink/Hyperlink.js +82 -0
  116. package/dist/components/hyperlink/Hyperlink.module.css +121 -0
  117. package/dist/components/icon/Icon.cjs +27 -0
  118. package/dist/components/icon/Icon.js +20 -0
  119. package/dist/components/icon/Icon.module.css +36 -0
  120. package/dist/components/inline-status/InlineStatus.cjs +39 -0
  121. package/dist/components/inline-status/InlineStatus.js +33 -0
  122. package/dist/components/inline-status/InlineStatus.module.css +92 -0
  123. package/dist/components/interval-select/IntervalSelect.cjs +203 -0
  124. package/dist/components/interval-select/IntervalSelect.js +201 -0
  125. package/dist/components/json-viewer/HighlightedText.cjs +13 -0
  126. package/dist/components/json-viewer/HighlightedText.js +11 -0
  127. package/dist/components/json-viewer/JsonNode.cjs +124 -0
  128. package/dist/components/json-viewer/JsonNode.js +118 -0
  129. package/dist/components/json-viewer/JsonViewer.cjs +164 -0
  130. package/dist/components/json-viewer/JsonViewer.js +158 -0
  131. package/dist/components/json-viewer/JsonViewer.module.css +346 -0
  132. package/dist/components/json-viewer/types.cjs +2 -0
  133. package/dist/components/json-viewer/types.js +1 -0
  134. package/dist/components/json-viewer/useClipboardStatus.cjs +15 -0
  135. package/dist/components/json-viewer/useClipboardStatus.js +13 -0
  136. package/dist/components/json-viewer/utils.cjs +126 -0
  137. package/dist/components/json-viewer/utils.js +111 -0
  138. package/dist/components/media-card/MediaCard.cjs +60 -0
  139. package/dist/components/media-card/MediaCard.d.ts +19 -0
  140. package/dist/components/media-card/MediaCard.js +54 -0
  141. package/dist/components/media-card/MediaCard.module.css +92 -0
  142. package/dist/components/menu/Menu.cjs +287 -0
  143. package/dist/components/menu/Menu.js +262 -0
  144. package/dist/components/menu/Menu.module.css +220 -0
  145. package/dist/components/meta-bar/MetaBar.cjs +28 -0
  146. package/dist/components/meta-bar/MetaBar.js +22 -0
  147. package/dist/components/meta-bar/MetaBar.module.css +27 -0
  148. package/dist/components/nav-bar/NavBar.cjs +95 -0
  149. package/dist/components/nav-bar/NavBar.d.ts +1 -1
  150. package/dist/components/nav-bar/NavBar.js +89 -0
  151. package/dist/components/nav-bar/NavBar.module.css +225 -0
  152. package/dist/components/overlay/fade-overlay/FadeOverlay.cjs +30 -0
  153. package/dist/components/overlay/fade-overlay/FadeOverlay.js +24 -0
  154. package/dist/components/overlay/fade-overlay/FadeOverlay.module.css +54 -0
  155. package/dist/components/overlay/modal/Modal.cjs +189 -0
  156. package/dist/components/overlay/modal/Modal.d.ts +2 -1
  157. package/dist/components/overlay/modal/Modal.js +183 -0
  158. package/dist/components/overlay/modal/Modal.module.css +112 -0
  159. package/dist/components/overlay/modal/provider/ModalProvider.cjs +98 -0
  160. package/dist/components/overlay/modal/provider/ModalProvider.js +95 -0
  161. package/dist/components/overlay/side-panel/SidePanel.cjs +173 -0
  162. package/dist/components/overlay/side-panel/SidePanel.js +167 -0
  163. package/dist/components/overlay/side-panel/SidePanel.module.css +177 -0
  164. package/dist/components/overlay/side-panel/useSidePanel.cjs +16 -0
  165. package/dist/components/overlay/side-panel/useSidePanel.js +14 -0
  166. package/dist/components/overlay/tooltip/Tooltip.cjs +34 -0
  167. package/dist/components/overlay/tooltip/Tooltip.js +32 -0
  168. package/dist/components/overlay/tooltip/Tooltip.module.css +104 -0
  169. package/dist/components/overlay/tooltip/TooltipProvider.cjs +238 -0
  170. package/dist/components/overlay/tooltip/TooltipProvider.js +231 -0
  171. package/dist/components/overlay/tooltip/useTooltipTrigger.cjs +117 -0
  172. package/dist/components/overlay/tooltip/useTooltipTrigger.js +115 -0
  173. package/dist/components/page/Page.cjs +63 -0
  174. package/dist/components/page/Page.js +57 -0
  175. package/dist/components/page/Page.module.css +95 -0
  176. package/dist/components/page-layout/PageLayout.cjs +97 -0
  177. package/dist/components/page-layout/PageLayout.d.ts +0 -5
  178. package/dist/components/page-layout/PageLayout.js +91 -0
  179. package/dist/components/page-layout/PageLayout.module.css +236 -0
  180. package/dist/components/page-layout/components/footer/Footer.cjs +53 -0
  181. package/dist/components/page-layout/components/footer/Footer.js +47 -0
  182. package/dist/components/page-layout/components/footer/Footer.module.css +89 -0
  183. package/dist/components/pagination/Pagination.cjs +160 -0
  184. package/dist/components/pagination/Pagination.js +154 -0
  185. package/dist/components/pagination/Pagination.module.css +25 -0
  186. package/dist/components/panel/Panel.cjs +38 -0
  187. package/dist/components/panel/Panel.js +32 -0
  188. package/dist/components/panel/Panel.module.css +30 -0
  189. package/dist/components/popover/Popover.cjs +331 -0
  190. package/dist/components/popover/Popover.js +307 -0
  191. package/dist/components/popover/Popover.module.css +52 -0
  192. package/dist/components/search-box/SearchBox.cjs +274 -0
  193. package/dist/components/search-box/SearchBox.js +268 -0
  194. package/dist/components/search-box/SearchBox.module.css +27 -0
  195. package/dist/components/segmented-progress-bar/SegmentedProgressBar.cjs +127 -0
  196. package/dist/components/segmented-progress-bar/SegmentedProgressBar.js +121 -0
  197. package/dist/components/segmented-progress-bar/SegmentedProgressBar.module.css +174 -0
  198. package/dist/components/sidebar/Sidebar.cjs +39 -0
  199. package/dist/components/sidebar/Sidebar.js +37 -0
  200. package/dist/components/sidebar/components/SidebarItem.cjs +29 -0
  201. package/dist/components/sidebar/components/SidebarItem.js +27 -0
  202. package/dist/components/sidebar/components/SidebarItem.module.css +0 -0
  203. package/dist/components/sidebar/components/expandable-sidebar-item/ExpandableSidebarItem.cjs +133 -0
  204. package/dist/components/sidebar/components/expandable-sidebar-item/ExpandableSidebarItem.js +127 -0
  205. package/dist/components/sidebar/components/expandable-sidebar-item/ExpandableSidebarItem.module.css +29 -0
  206. package/dist/components/sidebar/components/sidebar-container/SidebarContainer.cjs +214 -0
  207. package/dist/components/sidebar/components/sidebar-container/SidebarContainer.js +207 -0
  208. package/dist/components/sidebar/components/sidebar-container/SidebarContainer.module.css +260 -0
  209. package/dist/components/sidebar/components/sidebar-item-content/SidebarItemContent.cjs +54 -0
  210. package/dist/components/sidebar/components/sidebar-item-content/SidebarItemContent.js +47 -0
  211. package/dist/components/sidebar/components/sidebar-item-content/SidebarItemContent.module.css +106 -0
  212. package/dist/components/sidebar/components/sidebar-items/SidebarItems.cjs +61 -0
  213. package/dist/components/sidebar/components/sidebar-items/SidebarItems.js +55 -0
  214. package/dist/components/sidebar/components/sidebar-items/SidebarItems.module.css +20 -0
  215. package/dist/components/sidebar/components/sidenav-filteirng/SidenavFiltering.cjs +97 -0
  216. package/dist/components/sidebar/components/sidenav-filteirng/SidenavFiltering.js +91 -0
  217. package/dist/components/sidebar/providers/SidebarProvider.cjs +223 -0
  218. package/dist/components/sidebar/providers/SidebarProvider.js +220 -0
  219. package/dist/components/skeleton-loader/SkeletonLoader.cjs +442 -0
  220. package/dist/components/skeleton-loader/SkeletonLoader.js +440 -0
  221. package/dist/components/skeleton-loader/skeleton-loader-item/SkeletonLoaderItem.cjs +42 -0
  222. package/dist/components/skeleton-loader/skeleton-loader-item/SkeletonLoaderItem.js +36 -0
  223. package/dist/components/skeleton-loader/skeleton-loader-item/SkeletonLoaderItem.module.css +51 -0
  224. package/dist/components/split-button/SplitButton.cjs +46 -0
  225. package/dist/components/split-button/SplitButton.js +40 -0
  226. package/dist/components/split-button/SplitButton.module.css +32 -0
  227. package/dist/components/split-pane/SplitPane.cjs +177 -0
  228. package/dist/components/split-pane/SplitPane.js +168 -0
  229. package/dist/components/split-pane/SplitPane.module.css +111 -0
  230. package/dist/components/split-pane/provider/SplitPaneContext.cjs +129 -0
  231. package/dist/components/split-pane/provider/SplitPaneContext.js +121 -0
  232. package/dist/components/stack/Stack.cjs +47 -0
  233. package/dist/components/stack/Stack.d.ts +1 -1
  234. package/dist/components/stack/Stack.js +41 -0
  235. package/dist/components/stack/Stack.module.css +61 -0
  236. package/dist/components/state-page/StatePage.cjs +48 -0
  237. package/dist/components/state-page/StatePage.js +42 -0
  238. package/dist/components/state-page/StatePage.module.css +9 -0
  239. package/dist/components/state-page/empty.cjs +664 -0
  240. package/dist/components/state-page/empty.js +662 -0
  241. package/dist/components/state-page/error.cjs +310 -0
  242. package/dist/components/state-page/error.js +308 -0
  243. package/dist/components/state-page/notFound.cjs +243 -0
  244. package/dist/components/state-page/notFound.js +241 -0
  245. package/dist/components/sticky-footer-layout/StickyFooterLayout.cjs +98 -0
  246. package/dist/components/sticky-footer-layout/StickyFooterLayout.js +96 -0
  247. package/dist/components/table/Table.cjs +216 -0
  248. package/dist/components/table/Table.js +210 -0
  249. package/dist/components/table/Table.module.css +534 -0
  250. package/dist/components/table/Table.types.cjs +2 -0
  251. package/dist/components/table/Table.types.js +1 -0
  252. package/dist/components/table/TanstackTable.cjs +172 -0
  253. package/dist/components/table/TanstackTable.js +147 -0
  254. package/dist/components/table/components/TableBody.cjs +50 -0
  255. package/dist/components/table/components/TableBody.js +44 -0
  256. package/dist/components/table/components/TableHeader.cjs +56 -0
  257. package/dist/components/table/components/TableHeader.js +50 -0
  258. package/dist/components/table/components/TableHeaderCell.cjs +69 -0
  259. package/dist/components/table/components/TableHeaderCell.js +63 -0
  260. package/dist/components/table/components/TableLoadingBody.cjs +35 -0
  261. package/dist/components/table/components/TableLoadingBody.js +29 -0
  262. package/dist/components/table/components/TablePagination.cjs +2 -0
  263. package/dist/components/table/components/TablePagination.js +1 -0
  264. package/dist/components/table/components/TableRow.cjs +151 -0
  265. package/dist/components/table/components/TableRow.js +145 -0
  266. package/dist/components/table/components/TableSelectionCell.cjs +41 -0
  267. package/dist/components/table/components/TableSelectionCell.js +35 -0
  268. package/dist/components/table/components/column-resizer/ColumnResizer.cjs +25 -0
  269. package/dist/components/table/components/column-resizer/ColumnResizer.js +19 -0
  270. package/dist/components/table/components/column-resizer/ColumnResizer.module.css +22 -0
  271. package/dist/components/table/components/empty-state/EmptyState.cjs +33 -0
  272. package/dist/components/table/components/empty-state/EmptyState.js +31 -0
  273. package/dist/components/table/components/empty-state/EmptyState.module.css +4 -0
  274. package/dist/components/table/components/table-settings/TableSettings.cjs +139 -0
  275. package/dist/components/table/components/table-settings/TableSettings.js +137 -0
  276. package/dist/components/table/hooks/useTableRowInteractions.cjs +46 -0
  277. package/dist/components/table/hooks/useTableRowInteractions.js +44 -0
  278. package/dist/components/table/table.classes.cjs +49 -0
  279. package/dist/components/table/table.classes.js +40 -0
  280. package/dist/components/table/table.utils.cjs +57 -0
  281. package/dist/components/table/table.utils.js +45 -0
  282. package/dist/components/table/tanstackTable.utils.cjs +166 -0
  283. package/dist/components/table/tanstackTable.utils.js +159 -0
  284. package/dist/components/tabs/Tabs.cjs +172 -0
  285. package/dist/components/tabs/Tabs.js +166 -0
  286. package/dist/components/tabs/Tabs.module.css +261 -0
  287. package/dist/components/theme-button/ThemeButton.cjs +78 -0
  288. package/dist/components/theme-button/ThemeButton.js +75 -0
  289. package/dist/components/toast/Toast.cjs +68 -0
  290. package/dist/components/toast/Toast.js +62 -0
  291. package/dist/components/toast/Toast.module.css +161 -0
  292. package/dist/components/toast/provider/ToastProvider.cjs +105 -0
  293. package/dist/components/toast/provider/ToastProvider.js +97 -0
  294. package/dist/components/user-display/UserDisplay.cjs +22 -0
  295. package/dist/components/user-display/UserDisplay.js +16 -0
  296. package/dist/components/user-display/UserDisplay.module.css +25 -0
  297. package/dist/constants/chart-colors.cjs +10 -0
  298. package/dist/constants/chart-colors.js +8 -0
  299. package/dist/constants/chart-colors.types.cjs +2 -0
  300. package/dist/constants/chart-colors.types.js +1 -0
  301. package/dist/constants/severity.cjs +30 -0
  302. package/dist/constants/severity.js +26 -0
  303. package/dist/constants/severity.types.cjs +2 -0
  304. package/dist/constants/severity.types.js +1 -0
  305. package/dist/constants/sizes.cjs +11 -0
  306. package/dist/constants/sizes.js +9 -0
  307. package/dist/hooks/useDeviceSize.cjs +35 -0
  308. package/dist/hooks/useDeviceSize.js +33 -0
  309. package/dist/hooks/useListNavigation.cjs +237 -0
  310. package/dist/hooks/useListNavigation.js +235 -0
  311. package/dist/hooks/usePagination.cjs +144 -0
  312. package/dist/hooks/usePagination.js +142 -0
  313. package/dist/hooks/useSorting.cjs +119 -0
  314. package/dist/hooks/useSorting.js +117 -0
  315. package/dist/hooks/useTableData.cjs +53 -0
  316. package/dist/hooks/useTableData.js +51 -0
  317. package/dist/hooks/useTableSelection.cjs +172 -0
  318. package/dist/hooks/useTableSelection.js +170 -0
  319. package/dist/hooks/useTableSettings.cjs +90 -0
  320. package/dist/hooks/useTableSettings.js +87 -0
  321. package/dist/hooks/useTheme.cjs +64 -0
  322. package/dist/hooks/useTheme.js +62 -0
  323. package/dist/hooks/useTimeDuration.cjs +72 -0
  324. package/dist/hooks/useTimeDuration.js +70 -0
  325. package/dist/hooks/useViewportFill.cjs +82 -0
  326. package/dist/hooks/useViewportFill.js +80 -0
  327. package/dist/index.cjs +161 -12901
  328. package/dist/index.css +67 -7228
  329. package/dist/index.d.ts +0 -58
  330. package/dist/index.js +24 -12802
  331. package/dist/styles/animation.cjs +9 -0
  332. package/dist/styles/animation.js +7 -0
  333. package/dist/styles/themes/dbc/colors.css +5 -0
  334. package/dist/styles/themes/types.cjs +2 -0
  335. package/dist/styles/themes/types.js +1 -0
  336. package/dist/tanstack.cjs +18 -2652
  337. package/dist/tanstack.js +3 -2636
  338. package/dist/types/a11y-props.types.cjs +2 -0
  339. package/dist/types/a11y-props.types.js +1 -0
  340. package/dist/types/assets.d.cjs +2 -0
  341. package/dist/types/assets.d.js +1 -0
  342. package/dist/types/css.d.cjs +2 -0
  343. package/dist/types/css.d.js +1 -0
  344. package/dist/types/sizes.types.cjs +2 -0
  345. package/dist/types/sizes.types.js +1 -0
  346. package/dist/utils/arrays/nested-filtering.cjs +40 -0
  347. package/dist/utils/arrays/nested-filtering.js +38 -0
  348. package/dist/utils/date/formatDate.cjs +35 -0
  349. package/dist/utils/date/formatDate.js +33 -0
  350. package/dist/utils/localStorage.utils.cjs +53 -0
  351. package/dist/utils/localStorage.utils.js +49 -0
  352. package/dist/utils/text/get-highlighted-segments.cjs +49 -0
  353. package/dist/utils/text/get-highlighted-segments.js +47 -0
  354. package/package.json +8 -3
  355. package/dist/tanstack.css +0 -1271
@@ -0,0 +1,170 @@
1
+ 'use client';
2
+ import { useState, useRef, useMemo, useEffect, useCallback } from 'react';
3
+
4
+ const EMPTY_IDS = /* @__PURE__ */ new Set();
5
+ function safeParseIds(raw) {
6
+ if (!raw) return null;
7
+ try {
8
+ const parsed = JSON.parse(raw);
9
+ if (!Array.isArray(parsed)) return null;
10
+ return parsed.filter((v) => typeof v === "string" || typeof v === "number");
11
+ } catch {
12
+ return null;
13
+ }
14
+ }
15
+ function serializeIds(ids) {
16
+ return JSON.stringify(Array.from(ids));
17
+ }
18
+ function areSetsEqual(a, b) {
19
+ if (a.size !== b.size) return false;
20
+ for (const value of a) {
21
+ if (!b.has(value)) return false;
22
+ }
23
+ return true;
24
+ }
25
+ function useTableSelection({
26
+ storageKey,
27
+ items,
28
+ getId,
29
+ initialSelectedIds,
30
+ onSelectionChange,
31
+ selectionMode = "single",
32
+ pruneToItems = false,
33
+ storage = "session"
34
+ }) {
35
+ const resolvedInitialSelectedIds = initialSelectedIds != null ? initialSelectedIds : EMPTY_IDS;
36
+ const [selectedIds, setSelectedIds] = useState(resolvedInitialSelectedIds);
37
+ const [hydrated, setHydrated] = useState(false);
38
+ const lastWrittenRef = useRef(null);
39
+ const itemsById = useMemo(() => {
40
+ const map = /* @__PURE__ */ new Map();
41
+ for (const item of items) {
42
+ map.set(getId(item), item);
43
+ }
44
+ return map;
45
+ }, [items, getId]);
46
+ useEffect(() => {
47
+ if (typeof window === "undefined") return;
48
+ const storageApi = storage === "local" ? window.localStorage : window.sessionStorage;
49
+ if (!storageKey) {
50
+ setSelectedIds(
51
+ (prev) => areSetsEqual(prev, resolvedInitialSelectedIds) ? prev : new Set(resolvedInitialSelectedIds)
52
+ );
53
+ setHydrated(true);
54
+ lastWrittenRef.current = null;
55
+ return;
56
+ }
57
+ const parsed = safeParseIds(storageApi.getItem(storageKey));
58
+ const next = new Set(parsed != null ? parsed : Array.from(resolvedInitialSelectedIds));
59
+ setSelectedIds((prev) => areSetsEqual(prev, next) ? prev : next);
60
+ lastWrittenRef.current = serializeIds(next);
61
+ setHydrated(true);
62
+ }, [storage, storageKey, resolvedInitialSelectedIds]);
63
+ useEffect(() => {
64
+ if (!pruneToItems) return;
65
+ const visibleIds = new Set(Array.from(itemsById.keys()));
66
+ setSelectedIds((prev) => {
67
+ if (prev.size === 0) return prev;
68
+ if (visibleIds.size === 0) return prev;
69
+ const next = /* @__PURE__ */ new Set();
70
+ for (const id of prev) {
71
+ if (visibleIds.has(id)) next.add(id);
72
+ }
73
+ return areSetsEqual(prev, next) ? prev : next;
74
+ });
75
+ }, [pruneToItems, itemsById]);
76
+ const selectedItemMap = useMemo(() => {
77
+ const map = /* @__PURE__ */ new Map();
78
+ for (const id of selectedIds) {
79
+ const item = itemsById.get(id);
80
+ if (item !== void 0) map.set(id, item);
81
+ }
82
+ return map;
83
+ }, [selectedIds, itemsById]);
84
+ const selectedItems = useMemo(() => Array.from(selectedItemMap.values()), [selectedItemMap]);
85
+ const allSelected = useMemo(() => {
86
+ if (items.length === 0) return false;
87
+ return items.every((item) => selectedIds.has(getId(item)));
88
+ }, [items, selectedIds, getId]);
89
+ const anySelected = useMemo(() => selectedIds.size > 0, [selectedIds]);
90
+ useEffect(() => {
91
+ if (!hydrated) return;
92
+ if (typeof window === "undefined") return;
93
+ if (storageKey) {
94
+ const storageApi = storage === "local" ? window.localStorage : window.sessionStorage;
95
+ const nextStr = serializeIds(selectedIds);
96
+ if (lastWrittenRef.current !== nextStr) {
97
+ storageApi.setItem(storageKey, nextStr);
98
+ lastWrittenRef.current = nextStr;
99
+ }
100
+ }
101
+ onSelectionChange == null ? void 0 : onSelectionChange({ selectedIds, selectedItems });
102
+ }, [hydrated, onSelectionChange, selectedIds, selectedItems, storage, storageKey]);
103
+ const toggleId = useCallback(
104
+ (id, selected) => {
105
+ setSelectedIds((prev) => {
106
+ const next = new Set(prev);
107
+ const isSelected = next.has(id);
108
+ const shouldSelect = selected === void 0 ? !isSelected : selected;
109
+ if (selectionMode === "single") {
110
+ next.clear();
111
+ if (shouldSelect) next.add(id);
112
+ return areSetsEqual(prev, next) ? prev : next;
113
+ }
114
+ if (shouldSelect) next.add(id);
115
+ else next.delete(id);
116
+ return areSetsEqual(prev, next) ? prev : next;
117
+ });
118
+ },
119
+ [selectionMode]
120
+ );
121
+ const toggleItem = useCallback(
122
+ (item) => {
123
+ toggleId(getId(item));
124
+ },
125
+ [toggleId, getId]
126
+ );
127
+ const selectOnly = useCallback((id) => {
128
+ setSelectedIds((prev) => {
129
+ const next = /* @__PURE__ */ new Set([id]);
130
+ return areSetsEqual(prev, next) ? prev : next;
131
+ });
132
+ }, []);
133
+ const clearSelection = useCallback(() => {
134
+ setSelectedIds((prev) => prev.size === 0 ? prev : /* @__PURE__ */ new Set());
135
+ }, []);
136
+ const toggleAll = useCallback(
137
+ (selected) => {
138
+ if (!selected) {
139
+ clearSelection();
140
+ return;
141
+ }
142
+ if (selectionMode === "single") {
143
+ const first = items[0];
144
+ const next2 = first ? /* @__PURE__ */ new Set([getId(first)]) : /* @__PURE__ */ new Set();
145
+ setSelectedIds((prev) => areSetsEqual(prev, next2) ? prev : next2);
146
+ return;
147
+ }
148
+ const next = /* @__PURE__ */ new Set();
149
+ for (const item of items) {
150
+ next.add(getId(item));
151
+ }
152
+ setSelectedIds((prev) => areSetsEqual(prev, next) ? prev : next);
153
+ },
154
+ [clearSelection, getId, items, selectionMode]
155
+ );
156
+ return {
157
+ selectedIds,
158
+ selectedItems,
159
+ selectedItemMap,
160
+ toggleItem,
161
+ toggleId,
162
+ selectOnly,
163
+ clearSelection,
164
+ allSelected,
165
+ anySelected,
166
+ toggleAll
167
+ };
168
+ }
169
+
170
+ export { useTableSelection };
@@ -0,0 +1,90 @@
1
+ 'use client';
2
+ 'use strict';
3
+
4
+ var react = require('react');
5
+ var localStorage_utils = require('../utils/localStorage.utils');
6
+
7
+ function getDefaultVisibleIds(tableColumns) {
8
+ var _a;
9
+ return (_a = tableColumns == null ? void 0 : tableColumns.filter((c) => {
10
+ var _a2;
11
+ return !((_a2 = c.meta) == null ? void 0 : _a2.hidden);
12
+ }).map((c) => c.id).filter(Boolean)) != null ? _a : [];
13
+ }
14
+ function mergeDefaults(stored, defaults) {
15
+ const viewMode = (stored == null ? void 0 : stored.viewMode) === "compact" || (stored == null ? void 0 : stored.viewMode) === "wrapped" ? stored.viewMode : defaults.viewMode;
16
+ const visibleColumnIds = Array.isArray(stored == null ? void 0 : stored.visibleColumnIds) && stored.visibleColumnIds.length > 0 ? stored.visibleColumnIds : defaults.visibleColumnIds;
17
+ return { viewMode, visibleColumnIds };
18
+ }
19
+ const localStorageTableSettingsStorage = {
20
+ get: (key) => {
21
+ const v = localStorage_utils.readLocalStorage(key);
22
+ return v && typeof v === "object" ? v : void 0;
23
+ },
24
+ set: (key, next) => {
25
+ localStorage_utils.writeLocalStorage(key, next);
26
+ }
27
+ };
28
+ function useTableSettings({
29
+ storageKey,
30
+ tableColumns,
31
+ defaultViewMode = "compact",
32
+ defaultVisibleColumnIds,
33
+ storage = localStorageTableSettingsStorage
34
+ }) {
35
+ const defaults = react.useMemo(() => {
36
+ return {
37
+ viewMode: defaultViewMode,
38
+ visibleColumnIds: defaultVisibleColumnIds != null ? defaultVisibleColumnIds : getDefaultVisibleIds(tableColumns)
39
+ };
40
+ }, [defaultViewMode, defaultVisibleColumnIds, tableColumns]);
41
+ const [state, setState] = react.useState(defaults);
42
+ react.useEffect(() => {
43
+ const stored = storage.get(storageKey);
44
+ const next = mergeDefaults(stored, defaults);
45
+ setState(next);
46
+ }, [storageKey, storage, defaults]);
47
+ const persist = react.useCallback(
48
+ (next) => storage.set(storageKey, next),
49
+ [storage, storageKey]
50
+ );
51
+ const setViewMode = react.useCallback(
52
+ (mode) => {
53
+ setState((prev) => {
54
+ if (prev.viewMode === mode) return prev;
55
+ const next = { ...prev, viewMode: mode };
56
+ persist(next);
57
+ return next;
58
+ });
59
+ },
60
+ [persist]
61
+ );
62
+ const toggleViewMode = react.useCallback(() => {
63
+ setState((prev) => {
64
+ const nextMode = prev.viewMode === "wrapped" ? "compact" : "wrapped";
65
+ const next = { ...prev, viewMode: nextMode };
66
+ persist(next);
67
+ return next;
68
+ });
69
+ }, [persist]);
70
+ const setVisibleColumnIds = react.useCallback(
71
+ (ids) => {
72
+ setState((prev) => {
73
+ const next = { ...prev, visibleColumnIds: ids };
74
+ persist(next);
75
+ return next;
76
+ });
77
+ },
78
+ [persist]
79
+ );
80
+ return {
81
+ viewMode: state.viewMode,
82
+ toggleViewMode,
83
+ setViewMode,
84
+ visibleColumnIds: state.visibleColumnIds,
85
+ setVisibleColumnIds
86
+ };
87
+ }
88
+
89
+ exports.localStorageTableSettingsStorage = localStorageTableSettingsStorage;
90
+ exports.useTableSettings = useTableSettings;
@@ -0,0 +1,87 @@
1
+ 'use client';
2
+ import { useMemo, useState, useEffect, useCallback } from 'react';
3
+ import { writeLocalStorage, readLocalStorage } from '../utils/localStorage.utils';
4
+
5
+ function getDefaultVisibleIds(tableColumns) {
6
+ var _a;
7
+ return (_a = tableColumns == null ? void 0 : tableColumns.filter((c) => {
8
+ var _a2;
9
+ return !((_a2 = c.meta) == null ? void 0 : _a2.hidden);
10
+ }).map((c) => c.id).filter(Boolean)) != null ? _a : [];
11
+ }
12
+ function mergeDefaults(stored, defaults) {
13
+ const viewMode = (stored == null ? void 0 : stored.viewMode) === "compact" || (stored == null ? void 0 : stored.viewMode) === "wrapped" ? stored.viewMode : defaults.viewMode;
14
+ const visibleColumnIds = Array.isArray(stored == null ? void 0 : stored.visibleColumnIds) && stored.visibleColumnIds.length > 0 ? stored.visibleColumnIds : defaults.visibleColumnIds;
15
+ return { viewMode, visibleColumnIds };
16
+ }
17
+ const localStorageTableSettingsStorage = {
18
+ get: (key) => {
19
+ const v = readLocalStorage(key);
20
+ return v && typeof v === "object" ? v : void 0;
21
+ },
22
+ set: (key, next) => {
23
+ writeLocalStorage(key, next);
24
+ }
25
+ };
26
+ function useTableSettings({
27
+ storageKey,
28
+ tableColumns,
29
+ defaultViewMode = "compact",
30
+ defaultVisibleColumnIds,
31
+ storage = localStorageTableSettingsStorage
32
+ }) {
33
+ const defaults = useMemo(() => {
34
+ return {
35
+ viewMode: defaultViewMode,
36
+ visibleColumnIds: defaultVisibleColumnIds != null ? defaultVisibleColumnIds : getDefaultVisibleIds(tableColumns)
37
+ };
38
+ }, [defaultViewMode, defaultVisibleColumnIds, tableColumns]);
39
+ const [state, setState] = useState(defaults);
40
+ useEffect(() => {
41
+ const stored = storage.get(storageKey);
42
+ const next = mergeDefaults(stored, defaults);
43
+ setState(next);
44
+ }, [storageKey, storage, defaults]);
45
+ const persist = useCallback(
46
+ (next) => storage.set(storageKey, next),
47
+ [storage, storageKey]
48
+ );
49
+ const setViewMode = useCallback(
50
+ (mode) => {
51
+ setState((prev) => {
52
+ if (prev.viewMode === mode) return prev;
53
+ const next = { ...prev, viewMode: mode };
54
+ persist(next);
55
+ return next;
56
+ });
57
+ },
58
+ [persist]
59
+ );
60
+ const toggleViewMode = useCallback(() => {
61
+ setState((prev) => {
62
+ const nextMode = prev.viewMode === "wrapped" ? "compact" : "wrapped";
63
+ const next = { ...prev, viewMode: nextMode };
64
+ persist(next);
65
+ return next;
66
+ });
67
+ }, [persist]);
68
+ const setVisibleColumnIds = useCallback(
69
+ (ids) => {
70
+ setState((prev) => {
71
+ const next = { ...prev, visibleColumnIds: ids };
72
+ persist(next);
73
+ return next;
74
+ });
75
+ },
76
+ [persist]
77
+ );
78
+ return {
79
+ viewMode: state.viewMode,
80
+ toggleViewMode,
81
+ setViewMode,
82
+ visibleColumnIds: state.visibleColumnIds,
83
+ setVisibleColumnIds
84
+ };
85
+ }
86
+
87
+ export { localStorageTableSettingsStorage, useTableSettings };
@@ -0,0 +1,64 @@
1
+ 'use client';
2
+ 'use strict';
3
+
4
+ var react = require('react');
5
+
6
+ const THEME_VARIANTS = ["light", "dark", "system"];
7
+ const STORAGE_KEY = "dbc_theme";
8
+ function isThemeVariant(x) {
9
+ return !!x && THEME_VARIANTS.includes(x);
10
+ }
11
+ function getCookie(name) {
12
+ const match = document.cookie.match(new RegExp(`(?:^|; )${name}=([^;]*)`));
13
+ return match ? decodeURIComponent(match[1]) : null;
14
+ }
15
+ function persistTheme(id) {
16
+ try {
17
+ localStorage.setItem(STORAGE_KEY, id);
18
+ } catch {
19
+ console.error("Failed to access localStorage");
20
+ }
21
+ try {
22
+ document.cookie = `${STORAGE_KEY}=${encodeURIComponent(
23
+ id
24
+ )}; Path=/; Max-Age=${60 * 60 * 24 * 365}`;
25
+ } catch {
26
+ console.error("Failed to set theme cookie");
27
+ }
28
+ }
29
+ function getTheme() {
30
+ return document.documentElement.dataset.theme;
31
+ }
32
+ function applyTheme(id) {
33
+ document.documentElement.dataset.theme = id;
34
+ }
35
+ function useTheme(initialTheme = "system") {
36
+ const [theme, setTheme] = react.useState(null);
37
+ react.useEffect(() => {
38
+ const themeFromDataAttributes = getTheme();
39
+ let resolved = isThemeVariant(themeFromDataAttributes) ? themeFromDataAttributes : initialTheme;
40
+ const fromCookie = getCookie(STORAGE_KEY);
41
+ if (isThemeVariant(fromCookie)) {
42
+ resolved = fromCookie;
43
+ } else {
44
+ try {
45
+ const fromStorage = localStorage.getItem(STORAGE_KEY);
46
+ if (isThemeVariant(fromStorage)) resolved = fromStorage;
47
+ } catch {
48
+ console.error("Failed to access localStorage");
49
+ }
50
+ }
51
+ applyTheme(resolved);
52
+ setTheme(resolved);
53
+ persistTheme(resolved);
54
+ }, [initialTheme]);
55
+ const switchTheme = react.useCallback((id) => {
56
+ applyTheme(id);
57
+ setTheme(id);
58
+ persistTheme(id);
59
+ return id;
60
+ }, []);
61
+ return { theme, switchTheme };
62
+ }
63
+
64
+ exports.useTheme = useTheme;
@@ -0,0 +1,62 @@
1
+ 'use client';
2
+ import { useState, useEffect, useCallback } from 'react';
3
+
4
+ const THEME_VARIANTS = ["light", "dark", "system"];
5
+ const STORAGE_KEY = "dbc_theme";
6
+ function isThemeVariant(x) {
7
+ return !!x && THEME_VARIANTS.includes(x);
8
+ }
9
+ function getCookie(name) {
10
+ const match = document.cookie.match(new RegExp(`(?:^|; )${name}=([^;]*)`));
11
+ return match ? decodeURIComponent(match[1]) : null;
12
+ }
13
+ function persistTheme(id) {
14
+ try {
15
+ localStorage.setItem(STORAGE_KEY, id);
16
+ } catch {
17
+ console.error("Failed to access localStorage");
18
+ }
19
+ try {
20
+ document.cookie = `${STORAGE_KEY}=${encodeURIComponent(
21
+ id
22
+ )}; Path=/; Max-Age=${60 * 60 * 24 * 365}`;
23
+ } catch {
24
+ console.error("Failed to set theme cookie");
25
+ }
26
+ }
27
+ function getTheme() {
28
+ return document.documentElement.dataset.theme;
29
+ }
30
+ function applyTheme(id) {
31
+ document.documentElement.dataset.theme = id;
32
+ }
33
+ function useTheme(initialTheme = "system") {
34
+ const [theme, setTheme] = useState(null);
35
+ useEffect(() => {
36
+ const themeFromDataAttributes = getTheme();
37
+ let resolved = isThemeVariant(themeFromDataAttributes) ? themeFromDataAttributes : initialTheme;
38
+ const fromCookie = getCookie(STORAGE_KEY);
39
+ if (isThemeVariant(fromCookie)) {
40
+ resolved = fromCookie;
41
+ } else {
42
+ try {
43
+ const fromStorage = localStorage.getItem(STORAGE_KEY);
44
+ if (isThemeVariant(fromStorage)) resolved = fromStorage;
45
+ } catch {
46
+ console.error("Failed to access localStorage");
47
+ }
48
+ }
49
+ applyTheme(resolved);
50
+ setTheme(resolved);
51
+ persistTheme(resolved);
52
+ }, [initialTheme]);
53
+ const switchTheme = useCallback((id) => {
54
+ applyTheme(id);
55
+ setTheme(id);
56
+ persistTheme(id);
57
+ return id;
58
+ }, []);
59
+ return { theme, switchTheme };
60
+ }
61
+
62
+ export { useTheme };
@@ -0,0 +1,72 @@
1
+ 'use client';
2
+ 'use strict';
3
+
4
+ var react = require('react');
5
+
6
+ function defaultDuration(ms) {
7
+ if (!Number.isFinite(ms) || ms < 0) return "\u2014";
8
+ const sec = Math.floor(ms / 1e3) % 60;
9
+ const min = Math.floor(ms / (1e3 * 60)) % 60;
10
+ const hr = Math.floor(ms / (1e3 * 60 * 60));
11
+ if (hr > 0) {
12
+ return `${hr}t ${min}m ${sec}s`;
13
+ }
14
+ if (min > 0) {
15
+ return `${min}m ${sec}s`;
16
+ }
17
+ return `${sec}s`;
18
+ }
19
+ function useTimeDuration({
20
+ start,
21
+ end,
22
+ dateFormat = {
23
+ year: "2-digit",
24
+ month: "2-digit",
25
+ day: "2-digit",
26
+ hour: "2-digit",
27
+ minute: "2-digit",
28
+ second: "2-digit"
29
+ },
30
+ fallback = "\u2014",
31
+ liveUpdate = false,
32
+ formatDuration = defaultDuration
33
+ }) {
34
+ const [hydrated, setHydrated] = react.useState(false);
35
+ const [tick, setTick] = react.useState(0);
36
+ react.useEffect(() => setHydrated(true), []);
37
+ react.useEffect(() => {
38
+ if (!liveUpdate) return;
39
+ if (end && end.getTime() <= Date.now()) return;
40
+ const timer = setInterval(() => {
41
+ if (end && end.getTime() <= Date.now()) {
42
+ clearInterval(timer);
43
+ }
44
+ setTick((tick2) => tick2 + 1);
45
+ }, 1e3);
46
+ return () => clearInterval(timer);
47
+ }, [liveUpdate, end]);
48
+ const started = react.useMemo(() => {
49
+ if (!start) return fallback;
50
+ if (!hydrated) return fallback;
51
+ return new Intl.DateTimeFormat("da-DK", dateFormat).format(start);
52
+ }, [start, hydrated, fallback, dateFormat]);
53
+ const ended = react.useMemo(() => {
54
+ if (!end) return fallback;
55
+ if (!hydrated) return fallback;
56
+ return new Intl.DateTimeFormat("da-DK", dateFormat).format(end);
57
+ }, [end, hydrated, fallback, dateFormat]);
58
+ const duration = react.useMemo(() => {
59
+ if (!start || !hydrated) return fallback;
60
+ const now = Date.now();
61
+ if (!end) {
62
+ return formatDuration(now - start.getTime());
63
+ }
64
+ if (end.getTime() > now) {
65
+ return formatDuration(end.getTime() - now);
66
+ }
67
+ return formatDuration(end.getTime() - start.getTime());
68
+ }, [start, end, fallback, hydrated, formatDuration, tick]);
69
+ return { started, ended, isFinished: !!start && !!end, duration, hydrated };
70
+ }
71
+
72
+ exports.useTimeDuration = useTimeDuration;
@@ -0,0 +1,70 @@
1
+ 'use client';
2
+ import { useState, useEffect, useMemo } from 'react';
3
+
4
+ function defaultDuration(ms) {
5
+ if (!Number.isFinite(ms) || ms < 0) return "\u2014";
6
+ const sec = Math.floor(ms / 1e3) % 60;
7
+ const min = Math.floor(ms / (1e3 * 60)) % 60;
8
+ const hr = Math.floor(ms / (1e3 * 60 * 60));
9
+ if (hr > 0) {
10
+ return `${hr}t ${min}m ${sec}s`;
11
+ }
12
+ if (min > 0) {
13
+ return `${min}m ${sec}s`;
14
+ }
15
+ return `${sec}s`;
16
+ }
17
+ function useTimeDuration({
18
+ start,
19
+ end,
20
+ dateFormat = {
21
+ year: "2-digit",
22
+ month: "2-digit",
23
+ day: "2-digit",
24
+ hour: "2-digit",
25
+ minute: "2-digit",
26
+ second: "2-digit"
27
+ },
28
+ fallback = "\u2014",
29
+ liveUpdate = false,
30
+ formatDuration = defaultDuration
31
+ }) {
32
+ const [hydrated, setHydrated] = useState(false);
33
+ const [tick, setTick] = useState(0);
34
+ useEffect(() => setHydrated(true), []);
35
+ useEffect(() => {
36
+ if (!liveUpdate) return;
37
+ if (end && end.getTime() <= Date.now()) return;
38
+ const timer = setInterval(() => {
39
+ if (end && end.getTime() <= Date.now()) {
40
+ clearInterval(timer);
41
+ }
42
+ setTick((tick2) => tick2 + 1);
43
+ }, 1e3);
44
+ return () => clearInterval(timer);
45
+ }, [liveUpdate, end]);
46
+ const started = useMemo(() => {
47
+ if (!start) return fallback;
48
+ if (!hydrated) return fallback;
49
+ return new Intl.DateTimeFormat("da-DK", dateFormat).format(start);
50
+ }, [start, hydrated, fallback, dateFormat]);
51
+ const ended = useMemo(() => {
52
+ if (!end) return fallback;
53
+ if (!hydrated) return fallback;
54
+ return new Intl.DateTimeFormat("da-DK", dateFormat).format(end);
55
+ }, [end, hydrated, fallback, dateFormat]);
56
+ const duration = useMemo(() => {
57
+ if (!start || !hydrated) return fallback;
58
+ const now = Date.now();
59
+ if (!end) {
60
+ return formatDuration(now - start.getTime());
61
+ }
62
+ if (end.getTime() > now) {
63
+ return formatDuration(end.getTime() - now);
64
+ }
65
+ return formatDuration(end.getTime() - start.getTime());
66
+ }, [start, end, fallback, hydrated, formatDuration, tick]);
67
+ return { started, ended, isFinished: !!start && !!end, duration, hydrated };
68
+ }
69
+
70
+ export { useTimeDuration };
@@ -0,0 +1,82 @@
1
+ 'use client';
2
+ 'use strict';
3
+
4
+ var react = require('react');
5
+
6
+ const useIsomorphicLayoutEffect = typeof window !== "undefined" ? react.useLayoutEffect : react.useEffect;
7
+ function useViewportFill(ref, { bottomOffset = 0, min = 120, includeMarginTop = false, watchRef } = {}) {
8
+ const [maxHeight, setMaxHeight] = react.useState(min);
9
+ const raf = react.useRef(null);
10
+ const measure = react.useCallback(() => {
11
+ if (typeof window === "undefined" || !ref.current) return;
12
+ const el = ref.current;
13
+ const rect = el.getBoundingClientRect();
14
+ let top = rect.top;
15
+ if (includeMarginTop) {
16
+ const marginTop = parseFloat(window.getComputedStyle(el).marginTop || "0") || 0;
17
+ top -= marginTop;
18
+ }
19
+ const next = Math.max(min, Math.floor(window.innerHeight - bottomOffset - top));
20
+ setMaxHeight((prev) => prev === next ? prev : next);
21
+ }, [ref, bottomOffset, min, includeMarginTop]);
22
+ const scheduleMeasure = react.useCallback(() => {
23
+ if (typeof window === "undefined") return;
24
+ if (raf.current != null) {
25
+ cancelAnimationFrame(raf.current);
26
+ }
27
+ raf.current = window.requestAnimationFrame(() => {
28
+ raf.current = null;
29
+ measure();
30
+ });
31
+ }, [measure]);
32
+ useIsomorphicLayoutEffect(() => {
33
+ measure();
34
+ }, [measure]);
35
+ react.useEffect(() => {
36
+ var _a;
37
+ if (typeof window === "undefined" || !ref.current) return;
38
+ const target = ref.current;
39
+ const extra = (_a = watchRef == null ? void 0 : watchRef.current) != null ? _a : null;
40
+ const parent = target.parentElement;
41
+ const onResize = () => scheduleMeasure();
42
+ const onTransitionOrAnimationEnd = () => scheduleMeasure();
43
+ window.addEventListener("resize", onResize);
44
+ document.addEventListener("transitionend", onTransitionOrAnimationEnd, true);
45
+ document.addEventListener("animationend", onTransitionOrAnimationEnd, true);
46
+ let resizeObserver = null;
47
+ if ("ResizeObserver" in window) {
48
+ resizeObserver = new ResizeObserver(() => scheduleMeasure());
49
+ resizeObserver.observe(target);
50
+ if (parent && parent !== target) {
51
+ resizeObserver.observe(parent);
52
+ }
53
+ if (extra && extra !== target && extra !== parent) {
54
+ resizeObserver.observe(extra);
55
+ }
56
+ }
57
+ return () => {
58
+ window.removeEventListener("resize", onResize);
59
+ document.removeEventListener("transitionend", onTransitionOrAnimationEnd, true);
60
+ document.removeEventListener("animationend", onTransitionOrAnimationEnd, true);
61
+ resizeObserver == null ? void 0 : resizeObserver.disconnect();
62
+ if (raf.current != null) {
63
+ cancelAnimationFrame(raf.current);
64
+ raf.current = null;
65
+ }
66
+ };
67
+ }, [ref, watchRef, scheduleMeasure]);
68
+ const style = react.useMemo(
69
+ () => ({
70
+ maxHeight,
71
+ overflow: "auto"
72
+ }),
73
+ [maxHeight]
74
+ );
75
+ return {
76
+ maxHeight,
77
+ style,
78
+ recompute: measure
79
+ };
80
+ }
81
+
82
+ exports.useViewportFill = useViewportFill;