@dbcdk/react-components 0.0.1 → 0.0.3

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 (281) hide show
  1. package/dist/assets/logo.cjs +87 -0
  2. package/dist/assets/logo.d.ts +2 -0
  3. package/dist/assets/logo.js +85 -0
  4. package/dist/components/app-header/AppHeader.cjs +14 -0
  5. package/dist/components/app-header/AppHeader.d.ts +5 -0
  6. package/dist/components/app-header/AppHeader.js +8 -0
  7. package/dist/components/app-header/AppHeader.module.css +73 -0
  8. package/dist/components/avatar/Avatar.cjs +67 -0
  9. package/dist/components/avatar/Avatar.d.ts +15 -0
  10. package/dist/components/avatar/Avatar.js +42 -0
  11. package/dist/components/avatar/Avatar.module.css +43 -0
  12. package/dist/components/breadcrumbs/Breadcrumbs.cjs +23 -0
  13. package/dist/components/breadcrumbs/Breadcrumbs.d.ts +12 -0
  14. package/dist/components/breadcrumbs/Breadcrumbs.js +16 -0
  15. package/dist/components/breadcrumbs/Breadcrumbs.module.css +84 -0
  16. package/dist/components/button/Button.cjs +79 -0
  17. package/dist/components/button/Button.d.ts +13 -0
  18. package/dist/components/button/Button.js +54 -0
  19. package/dist/components/button/Button.module.css +156 -0
  20. package/dist/components/card/Card.cjs +29 -0
  21. package/dist/components/card/Card.d.ts +11 -0
  22. package/dist/components/card/Card.js +23 -0
  23. package/dist/components/card/Card.module.css +69 -0
  24. package/dist/components/card-container/CardContainer.cjs +23 -0
  25. package/dist/components/card-container/CardContainer.d.ts +8 -0
  26. package/dist/components/card-container/CardContainer.js +17 -0
  27. package/dist/components/card-container/CardContainer.module.css +18 -0
  28. package/dist/components/checkbox/Checkbox.cjs +43 -0
  29. package/dist/components/checkbox/Checkbox.d.ts +12 -0
  30. package/dist/components/checkbox/Checkbox.js +37 -0
  31. package/dist/components/checkbox/Checkbox.module.css +63 -0
  32. package/dist/components/chip/Chip.cjs +49 -0
  33. package/dist/components/chip/Chip.d.ts +13 -0
  34. package/dist/components/chip/Chip.js +43 -0
  35. package/dist/components/chip/Chip.module.css +97 -0
  36. package/dist/components/circle/Circle.cjs +18 -0
  37. package/dist/components/circle/Circle.d.ts +8 -0
  38. package/dist/components/circle/Circle.js +12 -0
  39. package/dist/components/circle/Circle.module.css +62 -0
  40. package/dist/components/clear-button/ClearButton.cjs +26 -0
  41. package/dist/components/clear-button/ClearButton.d.ts +6 -0
  42. package/dist/components/clear-button/ClearButton.js +20 -0
  43. package/dist/components/clear-button/ClearButton.module.css +16 -0
  44. package/dist/components/data-summary/DataSummary.cjs +49 -0
  45. package/dist/components/data-summary/DataSummary.d.ts +19 -0
  46. package/dist/components/data-summary/DataSummary.js +43 -0
  47. package/dist/components/data-summary/DataSummary.module.css +51 -0
  48. package/dist/components/filter-field/FilterField.cjs +174 -0
  49. package/dist/components/filter-field/FilterField.d.ts +28 -0
  50. package/dist/components/filter-field/FilterField.js +167 -0
  51. package/dist/components/filter-field/FilterField.module.css +109 -0
  52. package/dist/components/headline/Headline.cjs +47 -0
  53. package/dist/components/headline/Headline.d.ts +14 -0
  54. package/dist/components/headline/Headline.js +41 -0
  55. package/dist/components/headline/Headline.module.css +35 -0
  56. package/dist/components/icon/Icon.cjs +27 -0
  57. package/dist/components/icon/Icon.d.ts +9 -0
  58. package/dist/components/icon/Icon.js +20 -0
  59. package/dist/components/icon/Icon.module.css +34 -0
  60. package/dist/components/input/Input.cjs +48 -0
  61. package/dist/components/input/Input.d.ts +13 -0
  62. package/dist/components/input/Input.js +42 -0
  63. package/dist/components/input/Input.module.css +112 -0
  64. package/dist/components/menu/Menu.cjs +96 -0
  65. package/dist/components/menu/Menu.d.ts +12 -0
  66. package/dist/components/menu/Menu.js +71 -0
  67. package/dist/components/menu/Menu.module.css +95 -0
  68. package/dist/components/multi-select/MultiSelect.cjs +48 -0
  69. package/dist/components/multi-select/MultiSelect.d.ts +18 -0
  70. package/dist/components/multi-select/MultiSelect.js +46 -0
  71. package/dist/components/nav-bar/NavBar.cjs +55 -0
  72. package/dist/components/nav-bar/NavBar.d.ts +20 -0
  73. package/dist/components/nav-bar/NavBar.js +49 -0
  74. package/dist/components/nav-bar/NavBar.module.css +101 -0
  75. package/dist/components/page/Page.cjs +30 -0
  76. package/dist/components/page/Page.d.ts +13 -0
  77. package/dist/components/page/Page.js +24 -0
  78. package/dist/components/page/Page.module.css +26 -0
  79. package/dist/components/page-layout/PageLayout.cjs +101 -0
  80. package/dist/components/page-layout/PageLayout.d.ts +35 -0
  81. package/dist/components/page-layout/PageLayout.js +95 -0
  82. package/dist/components/page-layout/PageLayout.module.css +142 -0
  83. package/dist/components/pagination/Pagination.cjs +117 -0
  84. package/dist/components/pagination/Pagination.d.ts +17 -0
  85. package/dist/components/pagination/Pagination.js +111 -0
  86. package/dist/components/pagination/Pagination.module.css +17 -0
  87. package/dist/components/panel/Panel.cjs +18 -0
  88. package/dist/components/panel/Panel.d.ts +10 -0
  89. package/dist/components/panel/Panel.js +12 -0
  90. package/dist/components/panel/Panel.module.css +29 -0
  91. package/dist/components/popover/Popover.cjs +132 -0
  92. package/dist/components/popover/Popover.d.ts +15 -0
  93. package/dist/components/popover/Popover.js +126 -0
  94. package/dist/components/popover/Popover.module.css +25 -0
  95. package/dist/components/search-box/SearchBox.cjs +162 -0
  96. package/dist/components/search-box/SearchBox.d.ts +22 -0
  97. package/dist/components/search-box/SearchBox.js +156 -0
  98. package/dist/components/search-box/SearchBox.module.css +20 -0
  99. package/dist/components/segmented-progress-bar/SegmentedProgressBar.cjs +97 -0
  100. package/dist/components/segmented-progress-bar/SegmentedProgressBar.d.ts +24 -0
  101. package/dist/components/segmented-progress-bar/SegmentedProgressBar.js +91 -0
  102. package/dist/components/segmented-progress-bar/SegmentedProgressBar.module.css +55 -0
  103. package/dist/components/select/Select.cjs +52 -0
  104. package/dist/components/select/Select.d.ts +11 -0
  105. package/dist/components/select/Select.js +50 -0
  106. package/dist/components/sidebar/Sidebar.cjs +38 -0
  107. package/dist/components/sidebar/Sidebar.d.ts +12 -0
  108. package/dist/components/sidebar/Sidebar.js +31 -0
  109. package/dist/components/sidebar/Sidebar.module.css +66 -0
  110. package/dist/components/sidebar/components/SidebarItem.cjs +16 -0
  111. package/dist/components/sidebar/components/SidebarItem.d.ts +9 -0
  112. package/dist/components/sidebar/components/SidebarItem.js +14 -0
  113. package/dist/components/sidebar/components/SidebarItem.module.css +0 -0
  114. package/dist/components/sidebar/components/expandable-sidebar-item/ExpandableSidebarItem.cjs +74 -0
  115. package/dist/components/sidebar/components/expandable-sidebar-item/ExpandableSidebarItem.d.ts +9 -0
  116. package/dist/components/sidebar/components/expandable-sidebar-item/ExpandableSidebarItem.js +68 -0
  117. package/dist/components/sidebar/components/expandable-sidebar-item/ExpandableSidebarItem.module.css +61 -0
  118. package/dist/components/sidebar/components/sidebar-item-content/SidebarItemContent.cjs +27 -0
  119. package/dist/components/sidebar/components/sidebar-item-content/SidebarItemContent.d.ts +8 -0
  120. package/dist/components/sidebar/components/sidebar-item-content/SidebarItemContent.js +21 -0
  121. package/dist/components/sidebar/components/sidebar-item-content/SidebarItemContent.module.css +62 -0
  122. package/dist/components/sidebar/components/sidebar-items/SidebarItems.cjs +28 -0
  123. package/dist/components/sidebar/components/sidebar-items/SidebarItems.d.ts +4 -0
  124. package/dist/components/sidebar/components/sidebar-items/SidebarItems.js +26 -0
  125. package/dist/components/sidebar/components/sidenav-filteirng/SidenavFiltering.cjs +25 -0
  126. package/dist/components/sidebar/components/sidenav-filteirng/SidenavFiltering.d.ts +3 -0
  127. package/dist/components/sidebar/components/sidenav-filteirng/SidenavFiltering.js +23 -0
  128. package/dist/components/sidebar/providers/SidebarProvider.cjs +81 -0
  129. package/dist/components/sidebar/providers/SidebarProvider.d.ts +24 -0
  130. package/dist/components/sidebar/providers/SidebarProvider.js +78 -0
  131. package/dist/components/skeleton-loader/SkeletonLoader.cjs +270 -0
  132. package/dist/components/skeleton-loader/SkeletonLoader.d.ts +9 -0
  133. package/dist/components/skeleton-loader/SkeletonLoader.js +268 -0
  134. package/dist/components/skeleton-loader/skeleton-loader-item/SkeletonLoaderItem.cjs +42 -0
  135. package/dist/components/skeleton-loader/skeleton-loader-item/SkeletonLoaderItem.d.ts +11 -0
  136. package/dist/components/skeleton-loader/skeleton-loader-item/SkeletonLoaderItem.js +36 -0
  137. package/dist/components/skeleton-loader/skeleton-loader-item/SkeletonLoaderItem.module.css +63 -0
  138. package/dist/components/split-button/SplitButton.cjs +37 -0
  139. package/dist/components/split-button/SplitButton.d.ts +14 -0
  140. package/dist/components/split-button/SplitButton.js +31 -0
  141. package/dist/components/split-button/SplitButton.module.css +32 -0
  142. package/dist/components/table/Table.cjs +181 -0
  143. package/dist/components/table/Table.d.ts +45 -0
  144. package/dist/components/table/Table.js +175 -0
  145. package/dist/components/table/Table.module.css +143 -0
  146. package/dist/components/table/components/column-resizer/ColumnResizer.cjs +22 -0
  147. package/dist/components/table/components/column-resizer/ColumnResizer.d.ts +7 -0
  148. package/dist/components/table/components/column-resizer/ColumnResizer.js +16 -0
  149. package/dist/components/table/components/column-resizer/ColumnResizer.module.css +13 -0
  150. package/dist/components/tabs/Tabs.cjs +74 -0
  151. package/dist/components/tabs/Tabs.d.ts +18 -0
  152. package/dist/components/tabs/Tabs.js +68 -0
  153. package/dist/components/tabs/Tabs.module.css +113 -0
  154. package/dist/components/text-area/Textarea.cjs +62 -0
  155. package/dist/components/text-area/Textarea.d.ts +14 -0
  156. package/dist/components/text-area/Textarea.js +56 -0
  157. package/dist/components/text-area/Textarea.module.css +3 -0
  158. package/dist/components/tooltip/Tooltip.cjs +78 -0
  159. package/dist/components/tooltip/Tooltip.d.ts +11 -0
  160. package/dist/components/tooltip/Tooltip.js +72 -0
  161. package/dist/components/tooltip/Tooltip.module.css +84 -0
  162. package/dist/components/user-display/UserDisplay.cjs +28 -0
  163. package/dist/components/user-display/UserDisplay.d.ts +9 -0
  164. package/dist/components/user-display/UserDisplay.js +22 -0
  165. package/dist/components/user-display/UserDisplay.module.css +25 -0
  166. package/dist/constants/severity.cjs +21 -0
  167. package/dist/constants/severity.d.ts +3 -0
  168. package/dist/constants/severity.js +18 -0
  169. package/dist/constants/severity.types.cjs +2 -0
  170. package/dist/constants/severity.types.d.ts +1 -0
  171. package/dist/constants/severity.types.js +1 -0
  172. package/dist/constants/sizes.cjs +10 -0
  173. package/dist/constants/sizes.d.ts +2 -0
  174. package/dist/constants/sizes.js +8 -0
  175. package/dist/hooks/useTheme.cjs +58 -0
  176. package/dist/hooks/useTheme.d.ts +9 -0
  177. package/dist/hooks/useTheme.js +55 -0
  178. package/dist/hooks/useViewportFill.cjs +52 -0
  179. package/dist/hooks/useViewportFill.d.ts +15 -0
  180. package/dist/hooks/useViewportFill.js +50 -0
  181. package/dist/index.cjs +264 -2
  182. package/dist/index.d.ts +37 -12
  183. package/dist/index.js +37 -2
  184. package/dist/src/styles/styles.css +124 -0
  185. package/dist/styles/css-helper-classes/spacing.css +291 -0
  186. package/dist/styles/fonts/Roboto/OFL.txt +93 -0
  187. package/dist/styles/fonts/Roboto/README.txt +118 -0
  188. package/dist/styles/fonts/Roboto/Roboto-Black.ttf +0 -0
  189. package/dist/styles/fonts/Roboto/Roboto-BlackItalic.ttf +0 -0
  190. package/dist/styles/fonts/Roboto/Roboto-Bold.ttf +0 -0
  191. package/dist/styles/fonts/Roboto/Roboto-BoldItalic.ttf +0 -0
  192. package/dist/styles/fonts/Roboto/Roboto-ExtraBold.ttf +0 -0
  193. package/dist/styles/fonts/Roboto/Roboto-ExtraBoldItalic.ttf +0 -0
  194. package/dist/styles/fonts/Roboto/Roboto-ExtraLight.ttf +0 -0
  195. package/dist/styles/fonts/Roboto/Roboto-ExtraLightItalic.ttf +0 -0
  196. package/dist/styles/fonts/Roboto/Roboto-Italic.ttf +0 -0
  197. package/dist/styles/fonts/Roboto/Roboto-Light.ttf +0 -0
  198. package/dist/styles/fonts/Roboto/Roboto-LightItalic.ttf +0 -0
  199. package/dist/styles/fonts/Roboto/Roboto-Medium.ttf +0 -0
  200. package/dist/styles/fonts/Roboto/Roboto-MediumItalic.ttf +0 -0
  201. package/dist/styles/fonts/Roboto/Roboto-Regular.ttf +0 -0
  202. package/dist/styles/fonts/Roboto/Roboto-SemiBold.ttf +0 -0
  203. package/dist/styles/fonts/Roboto/Roboto-SemiBoldItalic.ttf +0 -0
  204. package/dist/styles/fonts/Roboto/Roboto-Thin.ttf +0 -0
  205. package/dist/styles/fonts/Roboto/Roboto-ThinItalic.ttf +0 -0
  206. package/dist/styles/fonts/Roboto/Roboto_Condensed-Black.ttf +0 -0
  207. package/dist/styles/fonts/Roboto/Roboto_Condensed-BlackItalic.ttf +0 -0
  208. package/dist/styles/fonts/Roboto/Roboto_Condensed-Bold.ttf +0 -0
  209. package/dist/styles/fonts/Roboto/Roboto_Condensed-BoldItalic.ttf +0 -0
  210. package/dist/styles/fonts/Roboto/Roboto_Condensed-ExtraBold.ttf +0 -0
  211. package/dist/styles/fonts/Roboto/Roboto_Condensed-ExtraBoldItalic.ttf +0 -0
  212. package/dist/styles/fonts/Roboto/Roboto_Condensed-ExtraLight.ttf +0 -0
  213. package/dist/styles/fonts/Roboto/Roboto_Condensed-ExtraLightItalic.ttf +0 -0
  214. package/dist/styles/fonts/Roboto/Roboto_Condensed-Italic.ttf +0 -0
  215. package/dist/styles/fonts/Roboto/Roboto_Condensed-Light.ttf +0 -0
  216. package/dist/styles/fonts/Roboto/Roboto_Condensed-LightItalic.ttf +0 -0
  217. package/dist/styles/fonts/Roboto/Roboto_Condensed-Medium.ttf +0 -0
  218. package/dist/styles/fonts/Roboto/Roboto_Condensed-MediumItalic.ttf +0 -0
  219. package/dist/styles/fonts/Roboto/Roboto_Condensed-Regular.ttf +0 -0
  220. package/dist/styles/fonts/Roboto/Roboto_Condensed-SemiBold.ttf +0 -0
  221. package/dist/styles/fonts/Roboto/Roboto_Condensed-SemiBoldItalic.ttf +0 -0
  222. package/dist/styles/fonts/Roboto/Roboto_Condensed-Thin.ttf +0 -0
  223. package/dist/styles/fonts/Roboto/Roboto_Condensed-ThinItalic.ttf +0 -0
  224. package/dist/styles/fonts/Roboto/Roboto_SemiCondensed-Black.ttf +0 -0
  225. package/dist/styles/fonts/Roboto/Roboto_SemiCondensed-BlackItalic.ttf +0 -0
  226. package/dist/styles/fonts/Roboto/Roboto_SemiCondensed-Bold.ttf +0 -0
  227. package/dist/styles/fonts/Roboto/Roboto_SemiCondensed-BoldItalic.ttf +0 -0
  228. package/dist/styles/fonts/Roboto/Roboto_SemiCondensed-ExtraBold.ttf +0 -0
  229. package/dist/styles/fonts/Roboto/Roboto_SemiCondensed-ExtraBoldItalic.ttf +0 -0
  230. package/dist/styles/fonts/Roboto/Roboto_SemiCondensed-ExtraLight.ttf +0 -0
  231. package/dist/styles/fonts/Roboto/Roboto_SemiCondensed-ExtraLightItalic.ttf +0 -0
  232. package/dist/styles/fonts/Roboto/Roboto_SemiCondensed-Italic.ttf +0 -0
  233. package/dist/styles/fonts/Roboto/Roboto_SemiCondensed-Light.ttf +0 -0
  234. package/dist/styles/fonts/Roboto/Roboto_SemiCondensed-LightItalic.ttf +0 -0
  235. package/dist/styles/fonts/Roboto/Roboto_SemiCondensed-Medium.ttf +0 -0
  236. package/dist/styles/fonts/Roboto/Roboto_SemiCondensed-MediumItalic.ttf +0 -0
  237. package/dist/styles/fonts/Roboto/Roboto_SemiCondensed-Regular.ttf +0 -0
  238. package/dist/styles/fonts/Roboto/Roboto_SemiCondensed-SemiBold.ttf +0 -0
  239. package/dist/styles/fonts/Roboto/Roboto_SemiCondensed-SemiBoldItalic.ttf +0 -0
  240. package/dist/styles/fonts/Roboto/Roboto_SemiCondensed-Thin.ttf +0 -0
  241. package/dist/styles/fonts/Roboto/Roboto_SemiCondensed-ThinItalic.ttf +0 -0
  242. package/dist/styles/fonts/Tajawal/OFL.txt +93 -0
  243. package/dist/styles/fonts/Tajawal/Tajawal-Black.ttf +0 -0
  244. package/dist/styles/fonts/Tajawal/Tajawal-Bold.ttf +0 -0
  245. package/dist/styles/fonts/Tajawal/Tajawal-ExtraBold.ttf +0 -0
  246. package/dist/styles/fonts/Tajawal/Tajawal-ExtraLight.ttf +0 -0
  247. package/dist/styles/fonts/Tajawal/Tajawal-Light.ttf +0 -0
  248. package/dist/styles/fonts/Tajawal/Tajawal-Medium.ttf +0 -0
  249. package/dist/styles/fonts/Tajawal/Tajawal-Regular.ttf +0 -0
  250. package/dist/styles/styles.css +124 -0
  251. package/dist/styles/themes/dbc/dark.css +240 -0
  252. package/dist/styles/themes/dbc/light.css +245 -0
  253. package/dist/styles/themes/forfatterweb/light.css +104 -0
  254. package/dist/styles/themes/types.cjs +2 -0
  255. package/dist/styles/themes/types.d.ts +16 -0
  256. package/dist/styles/themes/types.js +1 -0
  257. package/dist/tanstack.cjs +231 -0
  258. package/dist/tanstack.d.ts +25 -0
  259. package/dist/tanstack.js +206 -0
  260. package/dist/types/a11y-props.types.cjs +2 -0
  261. package/dist/types/a11y-props.types.d.ts +8 -0
  262. package/dist/types/a11y-props.types.js +1 -0
  263. package/dist/types/assets.d.cjs +2 -0
  264. package/dist/types/assets.d.js +1 -0
  265. package/dist/types/css.d.cjs +2 -0
  266. package/dist/types/css.d.js +1 -0
  267. package/dist/types/sizes.types.cjs +2 -0
  268. package/dist/types/sizes.types.d.ts +2 -0
  269. package/dist/types/sizes.types.js +1 -0
  270. package/dist/utils/arrays/nested-filtering.cjs +40 -0
  271. package/dist/utils/arrays/nested-filtering.d.ts +9 -0
  272. package/dist/utils/arrays/nested-filtering.js +38 -0
  273. package/dist/utils/date/formatDate.cjs +19 -0
  274. package/dist/utils/date/formatDate.d.ts +12 -0
  275. package/dist/utils/date/formatDate.js +17 -0
  276. package/package.json +67 -20
  277. package/dist/index.cjs.map +0 -1
  278. package/dist/index.css +0 -2
  279. package/dist/index.css.map +0 -1
  280. package/dist/index.d.cts +0 -12
  281. package/dist/index.js.map +0 -1
@@ -0,0 +1,79 @@
1
+ 'use strict';
2
+
3
+ var jsxRuntime = require('react/jsx-runtime');
4
+ var React = require('react');
5
+ var styles = require('./Button.module.css');
6
+ var lucideReact = require('lucide-react');
7
+ var Tooltip = require('../tooltip/Tooltip');
8
+
9
+ function _interopDefault (e) { return e && e.__esModule ? e : { default: e }; }
10
+
11
+ function _interopNamespace(e) {
12
+ if (e && e.__esModule) return e;
13
+ var n = Object.create(null);
14
+ if (e) {
15
+ Object.keys(e).forEach(function (k) {
16
+ if (k !== 'default') {
17
+ var d = Object.getOwnPropertyDescriptor(e, k);
18
+ Object.defineProperty(n, k, d.get ? d : {
19
+ enumerable: true,
20
+ get: function () { return e[k]; }
21
+ });
22
+ }
23
+ });
24
+ }
25
+ n.default = e;
26
+ return Object.freeze(n);
27
+ }
28
+
29
+ var React__namespace = /*#__PURE__*/_interopNamespace(React);
30
+ var styles__default = /*#__PURE__*/_interopDefault(styles);
31
+
32
+ const Button = React__namespace.forwardRef(function Button2({
33
+ variant = "outlined",
34
+ size = "md",
35
+ icon,
36
+ children,
37
+ loading,
38
+ active,
39
+ spinIcon,
40
+ tooltip,
41
+ isLink,
42
+ ...rest
43
+ }, ref) {
44
+ let buttonEl;
45
+ const className = [
46
+ styles__default.default.button,
47
+ styles__default.default[variant],
48
+ styles__default.default[size],
49
+ active ? styles__default.default.active : "",
50
+ loading ? styles__default.default.loading : "",
51
+ isLink ? styles__default.default.link : "",
52
+ rest.className || ""
53
+ ].filter(Boolean).join(" ");
54
+ if (isLink && React__namespace.isValidElement(children)) {
55
+ buttonEl = React__namespace.cloneElement(children, {
56
+ className,
57
+ ...rest,
58
+ ref,
59
+ children: /* @__PURE__ */ jsxRuntime.jsxs(jsxRuntime.Fragment, { children: [
60
+ icon && /* @__PURE__ */ jsxRuntime.jsx("span", { className: `${styles__default.default.icon} ${spinIcon ? "spin" : ""}`, children: icon }),
61
+ children.props.children,
62
+ loading && /* @__PURE__ */ jsxRuntime.jsx("span", { style: { display: "flex", opacity: 0.5 }, className: "spin", children: /* @__PURE__ */ jsxRuntime.jsx(lucideReact.LoaderCircle, {}) })
63
+ ] })
64
+ });
65
+ } else {
66
+ buttonEl = /* @__PURE__ */ jsxRuntime.jsxs("button", { ref, className, ...rest, children: [
67
+ icon && /* @__PURE__ */ jsxRuntime.jsx("span", { className: `${styles__default.default.icon} ${spinIcon ? "spin" : ""}`, children: icon }),
68
+ children,
69
+ loading && /* @__PURE__ */ jsxRuntime.jsx("span", { style: { display: "flex", opacity: 0.5 }, className: "spin", children: /* @__PURE__ */ jsxRuntime.jsx(lucideReact.LoaderCircle, {}) })
70
+ ] });
71
+ }
72
+ if (tooltip) {
73
+ return /* @__PURE__ */ jsxRuntime.jsx(Tooltip.Tooltip, { content: tooltip, children: buttonEl });
74
+ }
75
+ return buttonEl;
76
+ });
77
+ Button.displayName = "Button";
78
+
79
+ exports.Button = Button;
@@ -0,0 +1,13 @@
1
+ import * as React from 'react';
2
+ export type ButtonVariant = 'primary' | 'secondary' | 'outlined' | 'default' | 'inline' | 'success' | 'danger';
3
+ export interface ButtonProps extends React.ButtonHTMLAttributes<HTMLButtonElement> {
4
+ variant?: ButtonVariant;
5
+ size?: 'sm' | 'md' | 'lg';
6
+ icon?: React.ReactNode;
7
+ loading?: boolean;
8
+ active?: boolean;
9
+ spinIcon?: boolean;
10
+ tooltip?: string;
11
+ isLink?: boolean;
12
+ }
13
+ export declare const Button: React.ForwardRefExoticComponent<ButtonProps & React.RefAttributes<HTMLButtonElement>>;
@@ -0,0 +1,54 @@
1
+ import { jsxs, Fragment, jsx } from 'react/jsx-runtime';
2
+ import * as React from 'react';
3
+ import styles from './Button.module.css';
4
+ import { LoaderCircle } from 'lucide-react';
5
+ import { Tooltip } from '../tooltip/Tooltip';
6
+
7
+ const Button = React.forwardRef(function Button2({
8
+ variant = "outlined",
9
+ size = "md",
10
+ icon,
11
+ children,
12
+ loading,
13
+ active,
14
+ spinIcon,
15
+ tooltip,
16
+ isLink,
17
+ ...rest
18
+ }, ref) {
19
+ let buttonEl;
20
+ const className = [
21
+ styles.button,
22
+ styles[variant],
23
+ styles[size],
24
+ active ? styles.active : "",
25
+ loading ? styles.loading : "",
26
+ isLink ? styles.link : "",
27
+ rest.className || ""
28
+ ].filter(Boolean).join(" ");
29
+ if (isLink && React.isValidElement(children)) {
30
+ buttonEl = React.cloneElement(children, {
31
+ className,
32
+ ...rest,
33
+ ref,
34
+ children: /* @__PURE__ */ jsxs(Fragment, { children: [
35
+ icon && /* @__PURE__ */ jsx("span", { className: `${styles.icon} ${spinIcon ? "spin" : ""}`, children: icon }),
36
+ children.props.children,
37
+ loading && /* @__PURE__ */ jsx("span", { style: { display: "flex", opacity: 0.5 }, className: "spin", children: /* @__PURE__ */ jsx(LoaderCircle, {}) })
38
+ ] })
39
+ });
40
+ } else {
41
+ buttonEl = /* @__PURE__ */ jsxs("button", { ref, className, ...rest, children: [
42
+ icon && /* @__PURE__ */ jsx("span", { className: `${styles.icon} ${spinIcon ? "spin" : ""}`, children: icon }),
43
+ children,
44
+ loading && /* @__PURE__ */ jsx("span", { style: { display: "flex", opacity: 0.5 }, className: "spin", children: /* @__PURE__ */ jsx(LoaderCircle, {}) })
45
+ ] });
46
+ }
47
+ if (tooltip) {
48
+ return /* @__PURE__ */ jsx(Tooltip, { content: tooltip, children: buttonEl });
49
+ }
50
+ return buttonEl;
51
+ });
52
+ Button.displayName = "Button";
53
+
54
+ export { Button };
@@ -0,0 +1,156 @@
1
+ .link {
2
+ text-decoration: none;
3
+ font-size: var(--font-size-sm);
4
+ color: var(--color-link);
5
+ transition:
6
+ color var(--transition-fast) var(--ease-standard),
7
+ text-decoration-color var(--transition-fast) var(--ease-standard);
8
+ text-underline-offset: 0.15em;
9
+ }
10
+ .link:hover {
11
+ color: var(--color-link-hover);
12
+ text-decoration: underline;
13
+ }
14
+ .link:focus-visible {
15
+ outline: none;
16
+ box-shadow: var(--focus-ring);
17
+ }
18
+
19
+ .button {
20
+ display: inline-flex;
21
+ align-items: center;
22
+ justify-content: center;
23
+ gap: var(--space-inline-sm);
24
+
25
+ font-family: var(--font-family);
26
+ font-size: var(--font-size-sm);
27
+ line-height: 1;
28
+
29
+ border: var(--border-width-thin) solid transparent;
30
+ border-radius: var(--border-radius-default);
31
+
32
+ padding-inline: var(--control-padding-x);
33
+ padding-block: calc(var(--control-padding-y) + var(--density));
34
+ min-block-size: calc(var(--component-size-md) + var(--density));
35
+
36
+ cursor: pointer;
37
+ user-select: none;
38
+ white-space: nowrap;
39
+
40
+ transition:
41
+ background-color var(--transition-fast) var(--ease-standard),
42
+ color var(--transition-fast) var(--ease-standard),
43
+ border-color var(--transition-fast) var(--ease-standard),
44
+ box-shadow var(--transition-fast) var(--ease-standard);
45
+ }
46
+
47
+ .button:focus-visible {
48
+ outline: none;
49
+ box-shadow: var(--focus-ring);
50
+ }
51
+
52
+ .button:disabled,
53
+ .button[aria-disabled='true'] {
54
+ cursor: not-allowed;
55
+ pointer-events: none;
56
+ color: var(--color-disabled-text);
57
+ background-color: var(--color-disabled-bg);
58
+ border-color: var(--color-disabled-border);
59
+ }
60
+
61
+ .button svg,
62
+ .icon svg {
63
+ inline-size: var(--icon-size);
64
+ block-size: var(--icon-size);
65
+ }
66
+ .icon {
67
+ display: inline-flex;
68
+ }
69
+
70
+ .button.sm {
71
+ padding-inline: var(--spacing-sm);
72
+ min-block-size: calc(var(--component-size-sm) + var(--density));
73
+ }
74
+ .button.lg {
75
+ padding-inline: var(--spacing-lg);
76
+ min-block-size: calc(var(--component-size-lg) + var(--density));
77
+ }
78
+
79
+ .primary {
80
+ background-color: var(--color-primary);
81
+ color: var(--color-text-on-primary);
82
+ border-color: transparent;
83
+ }
84
+ .primary:hover {
85
+ background-color: var(--color-primary-hover);
86
+ }
87
+
88
+ .secondary {
89
+ background-color: var(--color-secondary);
90
+ color: var(--color-text-on-secondary);
91
+ border-color: transparent;
92
+ }
93
+ .secondary:hover {
94
+ background-color: var(--color-secondary-hover);
95
+ }
96
+
97
+ .default {
98
+ background-color: var(--color-surface);
99
+ color: var(--color-text);
100
+ border-color: var(--color-border);
101
+ }
102
+ .default:hover {
103
+ background-color: var(--color-surface-hover);
104
+ border-color: var(--color-border-strong);
105
+ }
106
+
107
+ .outlined {
108
+ background-color: transparent;
109
+ color: var(--color-text);
110
+ border-color: var(--color-border);
111
+ }
112
+ .outlined:hover {
113
+ border-color: var(--color-border-strong);
114
+ }
115
+
116
+ .success {
117
+ background-color: transparent;
118
+ color: var(--color-text-success);
119
+ border-color: var(--color-border-success);
120
+ }
121
+ .success .icon {
122
+ color: var(--color-success);
123
+ }
124
+ .success:hover {
125
+ border-color: var(--color-text);
126
+ }
127
+
128
+ .danger {
129
+ background-color: transparent;
130
+ color: var(--color-text-error);
131
+ border-color: var(--color-border-error);
132
+ }
133
+ .danger .icon {
134
+ color: var(--color-error);
135
+ }
136
+ .danger:hover {
137
+ border-color: var(--color-text);
138
+ }
139
+
140
+ .button.inline {
141
+ padding: var(--spacing-xxs);
142
+ min-block-size: unset;
143
+ background-color: transparent;
144
+ color: var(--color-text);
145
+ border-color: transparent;
146
+ }
147
+
148
+ .button.inline:hover {
149
+ background-color: var(--color-surface-hover);
150
+ }
151
+
152
+ .active {
153
+ background-color: var(--color-primary);
154
+ color: var(--color-text-on-primary);
155
+ border-color: var(--color-border-selected);
156
+ }
@@ -0,0 +1,29 @@
1
+ 'use strict';
2
+
3
+ var jsxRuntime = require('react/jsx-runtime');
4
+ var Headline = require('../headline/Headline');
5
+ var styles = require('./Card.module.css');
6
+
7
+ function _interopDefault (e) { return e && e.__esModule ? e : { default: e }; }
8
+
9
+ var styles__default = /*#__PURE__*/_interopDefault(styles);
10
+
11
+ function Card({ header, content, image, link: Link, width }) {
12
+ const cardContent = /* @__PURE__ */ jsxRuntime.jsxs(jsxRuntime.Fragment, { children: [
13
+ /* @__PURE__ */ jsxRuntime.jsx("div", { className: styles__default.default.imageContainer, children: image }),
14
+ /* @__PURE__ */ jsxRuntime.jsxs("div", { className: styles__default.default.content, children: [
15
+ /* @__PURE__ */ jsxRuntime.jsx(Headline.Headline, { marker: true, severity: "brand", size: 2, weight: 500, children: header }),
16
+ /* @__PURE__ */ jsxRuntime.jsx("div", { children: content })
17
+ ] })
18
+ ] });
19
+ return /* @__PURE__ */ jsxRuntime.jsx(
20
+ "div",
21
+ {
22
+ className: styles__default.default.container,
23
+ style: width ? { ["--width"]: `${width}%` } : void 0,
24
+ children: Link ? /* @__PURE__ */ jsxRuntime.jsx(Link, { children: cardContent }) : cardContent
25
+ }
26
+ );
27
+ }
28
+
29
+ exports.Card = Card;
@@ -0,0 +1,11 @@
1
+ interface CardProps {
2
+ header: string;
3
+ content: React.ReactNode | string;
4
+ image?: React.ReactNode;
5
+ link?: React.ComponentType<{
6
+ children: React.ReactNode;
7
+ }>;
8
+ width?: 25 | 33 | 50 | 66 | 75 | 100;
9
+ }
10
+ export declare function Card({ header, content, image, link: Link, width }: CardProps): JSX.Element;
11
+ export {};
@@ -0,0 +1,23 @@
1
+ import { jsxs, Fragment, jsx } from 'react/jsx-runtime';
2
+ import { Headline } from '../headline/Headline';
3
+ import styles from './Card.module.css';
4
+
5
+ function Card({ header, content, image, link: Link, width }) {
6
+ const cardContent = /* @__PURE__ */ jsxs(Fragment, { children: [
7
+ /* @__PURE__ */ jsx("div", { className: styles.imageContainer, children: image }),
8
+ /* @__PURE__ */ jsxs("div", { className: styles.content, children: [
9
+ /* @__PURE__ */ jsx(Headline, { marker: true, severity: "brand", size: 2, weight: 500, children: header }),
10
+ /* @__PURE__ */ jsx("div", { children: content })
11
+ ] })
12
+ ] });
13
+ return /* @__PURE__ */ jsx(
14
+ "div",
15
+ {
16
+ className: styles.container,
17
+ style: width ? { ["--width"]: `${width}%` } : void 0,
18
+ children: Link ? /* @__PURE__ */ jsx(Link, { children: cardContent }) : cardContent
19
+ }
20
+ );
21
+ }
22
+
23
+ export { Card };
@@ -0,0 +1,69 @@
1
+ /* Card container */
2
+ .container {
3
+ inline-size: 100%;
4
+ color: var(--color-text);
5
+ background: var(--color-surface);
6
+ border: var(--border-width-thin) solid var(--color-border);
7
+ border-radius: var(--border-radius-lg);
8
+
9
+ /* elevation */
10
+ box-shadow: var(--shadow-sm);
11
+ padding: var(--spacing-md);
12
+
13
+ transition:
14
+ color var(--transition-fast) var(--ease-standard),
15
+ box-shadow var(--transition-fast) var(--ease-standard),
16
+ transform var(--transition-fast) var(--ease-standard);
17
+ }
18
+
19
+ .container:hover {
20
+ color: var(--color-highlight);
21
+ cursor: pointer;
22
+ box-shadow: var(--shadow-lg);
23
+ transform: translateY(-2px);
24
+ }
25
+
26
+ /* Responsive width (uses your width var if provided) */
27
+ @media screen and (min-width: 768px) {
28
+ .container {
29
+ inline-size: calc(var(--width, 100%) - var(--spacing-md));
30
+ }
31
+ }
32
+
33
+ /* Media note: if you use custom media, define:
34
+ @custom-media --dbc-bp-md (min-width: 768px);
35
+ then swap the query above to: @media (--dbc-bp-md) { ... } */
36
+
37
+ /* Image wrapper */
38
+ .imageContainer {
39
+ overflow: hidden;
40
+ border-start-start-radius: var(--border-radius-lg);
41
+ border-start-end-radius: var(--border-radius-lg);
42
+ }
43
+
44
+ /* Media */
45
+ .container img {
46
+ inline-size: 100%;
47
+ block-size: auto;
48
+ border-block-end: var(--border-width-thin) solid var(--color-border);
49
+ transform: scale(1);
50
+ }
51
+
52
+ /* Headings & text */
53
+ .container h3 {
54
+ margin: var(--spacing-sm) 0;
55
+ color: inherit;
56
+ }
57
+
58
+ .container p {
59
+ margin: var(--spacing-sm) 0;
60
+ line-height: var(--line-height-tight);
61
+ }
62
+
63
+ /* Optional: image hover zoom (tokenized) */
64
+ /*
65
+ .container:hover img {
66
+ transition: transform var(--transition-normal) var(--ease-standard);
67
+ transform: scale(1.02);
68
+ }
69
+ */
@@ -0,0 +1,23 @@
1
+ 'use strict';
2
+
3
+ var jsxRuntime = require('react/jsx-runtime');
4
+ var Headline = require('../headline/Headline');
5
+ var styles = require('./CardContainer.module.css');
6
+
7
+ function _interopDefault (e) { return e && e.__esModule ? e : { default: e }; }
8
+
9
+ var styles__default = /*#__PURE__*/_interopDefault(styles);
10
+
11
+ function CardContainer({
12
+ children,
13
+ headline,
14
+ subHeadline,
15
+ expand
16
+ }) {
17
+ return /* @__PURE__ */ jsxRuntime.jsxs("div", { children: [
18
+ /* @__PURE__ */ jsxRuntime.jsx(Headline.Headline, { marker: true, severity: "brand", subHeadline, children: headline }),
19
+ /* @__PURE__ */ jsxRuntime.jsx("div", { className: styles__default.default.container, style: { ["--expand"]: expand ? "1" : "0" }, children })
20
+ ] });
21
+ }
22
+
23
+ exports.CardContainer = CardContainer;
@@ -0,0 +1,8 @@
1
+ interface CardContainerProps {
2
+ headline?: string;
3
+ subHeadline?: string;
4
+ children?: React.ReactNode[];
5
+ expand?: boolean;
6
+ }
7
+ export declare function CardContainer({ children, headline, subHeadline, expand, }: CardContainerProps): JSX.Element;
8
+ export {};
@@ -0,0 +1,17 @@
1
+ import { jsxs, jsx } from 'react/jsx-runtime';
2
+ import { Headline } from '../headline/Headline';
3
+ import styles from './CardContainer.module.css';
4
+
5
+ function CardContainer({
6
+ children,
7
+ headline,
8
+ subHeadline,
9
+ expand
10
+ }) {
11
+ return /* @__PURE__ */ jsxs("div", { children: [
12
+ /* @__PURE__ */ jsx(Headline, { marker: true, severity: "brand", subHeadline, children: headline }),
13
+ /* @__PURE__ */ jsx("div", { className: styles.container, style: { ["--expand"]: expand ? "1" : "0" }, children })
14
+ ] });
15
+ }
16
+
17
+ export { CardContainer };
@@ -0,0 +1,18 @@
1
+ .container {
2
+ display: flex;
3
+ flex-wrap: wrap;
4
+ gap: var(--spacing-md);
5
+ --width: 100%;
6
+ }
7
+
8
+ @media screen and (min-width: 768px) {
9
+ .container {
10
+ --width: 33.333%;
11
+ }
12
+ }
13
+
14
+ .container > * {
15
+ flex-grow: var(--expand);
16
+ flex-shrink: 1;
17
+ box-sizing: border-box;
18
+ }
@@ -0,0 +1,43 @@
1
+ 'use strict';
2
+
3
+ var jsxRuntime = require('react/jsx-runtime');
4
+ var react = require('react');
5
+ var lucideReact = require('lucide-react');
6
+ var styles = require('./Checkbox.module.css');
7
+
8
+ function _interopDefault (e) { return e && e.__esModule ? e : { default: e }; }
9
+
10
+ var styles__default = /*#__PURE__*/_interopDefault(styles);
11
+
12
+ function Checkbox({
13
+ checked: controlled,
14
+ onChange,
15
+ variant = "outlined",
16
+ disabled,
17
+ label,
18
+ size = "md"
19
+ }) {
20
+ const [internal, setInternal] = react.useState(false);
21
+ const isChecked = controlled != null ? controlled : internal;
22
+ const toggle = () => {
23
+ const value = !isChecked;
24
+ setInternal(value);
25
+ onChange == null ? void 0 : onChange(value);
26
+ };
27
+ return /* @__PURE__ */ jsxRuntime.jsxs("span", { className: styles__default.default.container, children: [
28
+ /* @__PURE__ */ jsxRuntime.jsx(
29
+ "button",
30
+ {
31
+ disabled,
32
+ type: "button",
33
+ onClick: toggle,
34
+ "aria-pressed": isChecked,
35
+ className: `${styles__default.default.checkbox} ${isChecked ? styles__default.default.checked : ""} ${styles__default.default[variant]} ${styles__default.default[size]}`,
36
+ children: isChecked && /* @__PURE__ */ jsxRuntime.jsx(lucideReact.Check, { className: styles__default.default.icon })
37
+ }
38
+ ),
39
+ label && /* @__PURE__ */ jsxRuntime.jsx("span", { className: styles__default.default.label, children: label })
40
+ ] });
41
+ }
42
+
43
+ exports.Checkbox = Checkbox;
@@ -0,0 +1,12 @@
1
+ type Variant = 'default' | 'primary' | 'outlined';
2
+ type Size = 'sm' | 'md' | 'lg';
3
+ interface CheckboxProps {
4
+ checked?: boolean;
5
+ onChange?: (checked: boolean) => void;
6
+ variant?: Variant;
7
+ disabled?: boolean;
8
+ label?: string;
9
+ size?: Size;
10
+ }
11
+ export declare function Checkbox({ checked: controlled, onChange, variant, disabled, label, size, }: CheckboxProps): JSX.Element;
12
+ export {};
@@ -0,0 +1,37 @@
1
+ import { jsxs, jsx } from 'react/jsx-runtime';
2
+ import { useState } from 'react';
3
+ import { Check } from 'lucide-react';
4
+ import styles from './Checkbox.module.css';
5
+
6
+ function Checkbox({
7
+ checked: controlled,
8
+ onChange,
9
+ variant = "outlined",
10
+ disabled,
11
+ label,
12
+ size = "md"
13
+ }) {
14
+ const [internal, setInternal] = useState(false);
15
+ const isChecked = controlled != null ? controlled : internal;
16
+ const toggle = () => {
17
+ const value = !isChecked;
18
+ setInternal(value);
19
+ onChange == null ? void 0 : onChange(value);
20
+ };
21
+ return /* @__PURE__ */ jsxs("span", { className: styles.container, children: [
22
+ /* @__PURE__ */ jsx(
23
+ "button",
24
+ {
25
+ disabled,
26
+ type: "button",
27
+ onClick: toggle,
28
+ "aria-pressed": isChecked,
29
+ className: `${styles.checkbox} ${isChecked ? styles.checked : ""} ${styles[variant]} ${styles[size]}`,
30
+ children: isChecked && /* @__PURE__ */ jsx(Check, { className: styles.icon })
31
+ }
32
+ ),
33
+ label && /* @__PURE__ */ jsx("span", { className: styles.label, children: label })
34
+ ] });
35
+ }
36
+
37
+ export { Checkbox };
@@ -0,0 +1,63 @@
1
+ .container {
2
+ display: inline-flex;
3
+ align-items: center;
4
+ justify-content: center;
5
+ gap: var(--spacing-sm);
6
+ vertical-align: middle;
7
+ line-height: 0;
8
+ }
9
+
10
+ .checkbox {
11
+ width: var(--component-size-sm);
12
+ height: var(--component-size-sm);
13
+ padding: 0;
14
+ display: flex;
15
+ align-items: center;
16
+ justify-content: center;
17
+ border: var(--border-width-thin) solid var(--color-border-strong);
18
+ border-radius: var(--border-radius-sm);
19
+ background-color: var(--color-surface);
20
+ cursor: pointer;
21
+ transition:
22
+ background-color var(--transition-fast) var(--ease-standard),
23
+ border-color var(--transition-fast) var(--ease-standard),
24
+ box-shadow var(--transition-fast) var(--ease-standard);
25
+ }
26
+
27
+ .checkbox.sm {
28
+ width: var(--component-size-xs);
29
+ height: var(--component-size-xs);
30
+ }
31
+
32
+ .label {
33
+ display: block;
34
+ font-size: var(--font-size-sm);
35
+ }
36
+
37
+ .checkbox:hover {
38
+ border-color: var(--color-text);
39
+ }
40
+
41
+ .checked {
42
+ background-color: var(--color-primary);
43
+ border-color: var(--color-primary);
44
+ }
45
+
46
+ .icon {
47
+ width: var(--icon-size);
48
+ height: var(--icon-size);
49
+ color: var(--color-text-on-primary);
50
+ stroke-width: 3;
51
+ pointer-events: none;
52
+ }
53
+
54
+ .outlined.checked {
55
+ background-color: var(--opac-bg-default);
56
+ &:not(:hover) {
57
+ border-color: transparent;
58
+ }
59
+
60
+ .icon {
61
+ color: var(--color-text);
62
+ }
63
+ }