@navikt/ds-react 6.4.0 → 6.5.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 (203) hide show
  1. package/cjs/date/datepicker/parts/DayButton.js +1 -1
  2. package/cjs/date/datepicker/parts/DayButton.js.map +1 -1
  3. package/cjs/date/hooks/useDatepicker.js +4 -1
  4. package/cjs/date/hooks/useDatepicker.js.map +1 -1
  5. package/cjs/date/hooks/useMonthPicker.js +4 -1
  6. package/cjs/date/hooks/useMonthPicker.js.map +1 -1
  7. package/cjs/date/monthpicker/MonthButton.js +1 -1
  8. package/cjs/date/monthpicker/MonthButton.js.map +1 -1
  9. package/cjs/tabs/Tabs.context.d.ts +30 -0
  10. package/cjs/tabs/Tabs.context.js +14 -0
  11. package/cjs/tabs/Tabs.context.js.map +1 -0
  12. package/cjs/tabs/Tabs.d.ts +8 -43
  13. package/cjs/tabs/Tabs.js +19 -12
  14. package/cjs/tabs/Tabs.js.map +1 -1
  15. package/cjs/tabs/Tabs.types.d.ts +41 -0
  16. package/cjs/tabs/Tabs.types.js +3 -0
  17. package/cjs/tabs/Tabs.types.js.map +1 -0
  18. package/cjs/tabs/index.d.ts +5 -4
  19. package/cjs/tabs/index.js +6 -6
  20. package/cjs/tabs/index.js.map +1 -1
  21. package/cjs/tabs/parts/tab/Tab.d.ts +25 -0
  22. package/cjs/tabs/{Tab.js → parts/tab/Tab.js} +15 -14
  23. package/cjs/tabs/parts/tab/Tab.js.map +1 -0
  24. package/cjs/tabs/parts/tab/useTab.d.ts +20 -0
  25. package/cjs/tabs/parts/tab/useTab.js +29 -0
  26. package/cjs/tabs/parts/tab/useTab.js.map +1 -0
  27. package/cjs/tabs/parts/tablist/ScrollButtons.d.ts +8 -0
  28. package/cjs/tabs/parts/tablist/ScrollButtons.js +15 -0
  29. package/cjs/tabs/parts/tablist/ScrollButtons.js.map +1 -0
  30. package/{esm/tabs → cjs/tabs/parts/tablist}/TabList.d.ts +1 -1
  31. package/cjs/tabs/parts/tablist/TabList.js +61 -0
  32. package/cjs/tabs/parts/tablist/TabList.js.map +1 -0
  33. package/cjs/tabs/parts/tablist/useScrollButtons.d.ts +12 -0
  34. package/cjs/tabs/parts/tablist/useScrollButtons.js +61 -0
  35. package/cjs/tabs/parts/tablist/useScrollButtons.js.map +1 -0
  36. package/cjs/tabs/parts/tablist/useTabList.d.ts +7 -0
  37. package/cjs/tabs/parts/tablist/useTabList.js +66 -0
  38. package/cjs/tabs/parts/tablist/useTabList.js.map +1 -0
  39. package/cjs/tabs/parts/tabpanel/TabPanel.d.ts +25 -0
  40. package/cjs/tabs/{TabPanel.js → parts/tabpanel/TabPanel.js} +5 -3
  41. package/cjs/tabs/parts/tabpanel/TabPanel.js.map +1 -0
  42. package/cjs/tabs/parts/tabpanel/useTabPanel.d.ts +12 -0
  43. package/cjs/tabs/parts/tabpanel/useTabPanel.js +17 -0
  44. package/cjs/tabs/parts/tabpanel/useTabPanel.js.map +1 -0
  45. package/cjs/tabs/useTabs.d.ts +14 -0
  46. package/cjs/tabs/useTabs.js +43 -0
  47. package/cjs/tabs/useTabs.js.map +1 -0
  48. package/cjs/toggle-group/ToggleGroup.context.d.ts +31 -0
  49. package/cjs/toggle-group/ToggleGroup.context.js +16 -0
  50. package/cjs/toggle-group/ToggleGroup.context.js.map +1 -0
  51. package/cjs/toggle-group/ToggleGroup.d.ts +5 -36
  52. package/cjs/toggle-group/ToggleGroup.js +24 -24
  53. package/cjs/toggle-group/ToggleGroup.js.map +1 -1
  54. package/cjs/toggle-group/ToggleGroup.types.d.ts +38 -0
  55. package/cjs/toggle-group/ToggleGroup.types.js +3 -0
  56. package/cjs/toggle-group/ToggleGroup.types.js.map +1 -0
  57. package/cjs/toggle-group/index.d.ts +3 -2
  58. package/cjs/toggle-group/index.js +1 -1
  59. package/cjs/toggle-group/index.js.map +1 -1
  60. package/cjs/toggle-group/{ToggleItem.d.ts → parts/ToggleItem.d.ts} +2 -2
  61. package/cjs/toggle-group/{ToggleItem.js → parts/ToggleItem.js} +9 -8
  62. package/cjs/toggle-group/parts/ToggleItem.js.map +1 -0
  63. package/cjs/toggle-group/parts/useToggleItem.d.ts +20 -0
  64. package/cjs/toggle-group/parts/useToggleItem.js +76 -0
  65. package/cjs/toggle-group/parts/useToggleItem.js.map +1 -0
  66. package/cjs/toggle-group/useToggleGroup.d.ts +8 -0
  67. package/cjs/toggle-group/useToggleGroup.js +29 -0
  68. package/cjs/toggle-group/useToggleGroup.js.map +1 -0
  69. package/esm/date/datepicker/parts/DayButton.js +1 -1
  70. package/esm/date/datepicker/parts/DayButton.js.map +1 -1
  71. package/esm/date/hooks/useDatepicker.js +4 -1
  72. package/esm/date/hooks/useDatepicker.js.map +1 -1
  73. package/esm/date/hooks/useMonthPicker.js +4 -1
  74. package/esm/date/hooks/useMonthPicker.js.map +1 -1
  75. package/esm/date/monthpicker/MonthButton.js +1 -1
  76. package/esm/date/monthpicker/MonthButton.js.map +1 -1
  77. package/esm/tabs/Tabs.context.d.ts +30 -0
  78. package/esm/tabs/Tabs.context.js +10 -0
  79. package/esm/tabs/Tabs.context.js.map +1 -0
  80. package/esm/tabs/Tabs.d.ts +8 -43
  81. package/esm/tabs/Tabs.js +19 -12
  82. package/esm/tabs/Tabs.js.map +1 -1
  83. package/esm/tabs/Tabs.types.d.ts +41 -0
  84. package/esm/tabs/Tabs.types.js +2 -0
  85. package/esm/tabs/Tabs.types.js.map +1 -0
  86. package/esm/tabs/index.d.ts +5 -4
  87. package/esm/tabs/index.js +3 -3
  88. package/esm/tabs/index.js.map +1 -1
  89. package/esm/tabs/parts/tab/Tab.d.ts +25 -0
  90. package/esm/tabs/parts/tab/Tab.js +35 -0
  91. package/esm/tabs/parts/tab/Tab.js.map +1 -0
  92. package/esm/tabs/parts/tab/useTab.d.ts +20 -0
  93. package/esm/tabs/parts/tab/useTab.js +25 -0
  94. package/esm/tabs/parts/tab/useTab.js.map +1 -0
  95. package/esm/tabs/parts/tablist/ScrollButtons.d.ts +8 -0
  96. package/esm/tabs/parts/tablist/ScrollButtons.js +10 -0
  97. package/esm/tabs/parts/tablist/ScrollButtons.js.map +1 -0
  98. package/{cjs/tabs → esm/tabs/parts/tablist}/TabList.d.ts +1 -1
  99. package/esm/tabs/parts/tablist/TabList.js +32 -0
  100. package/esm/tabs/parts/tablist/TabList.js.map +1 -0
  101. package/esm/tabs/parts/tablist/useScrollButtons.d.ts +12 -0
  102. package/esm/tabs/parts/tablist/useScrollButtons.js +57 -0
  103. package/esm/tabs/parts/tablist/useScrollButtons.js.map +1 -0
  104. package/esm/tabs/parts/tablist/useTabList.d.ts +7 -0
  105. package/esm/tabs/parts/tablist/useTabList.js +62 -0
  106. package/esm/tabs/parts/tablist/useTabList.js.map +1 -0
  107. package/esm/tabs/parts/tabpanel/TabPanel.d.ts +25 -0
  108. package/esm/tabs/parts/tabpanel/TabPanel.js +22 -0
  109. package/esm/tabs/parts/tabpanel/TabPanel.js.map +1 -0
  110. package/esm/tabs/parts/tabpanel/useTabPanel.d.ts +12 -0
  111. package/esm/tabs/parts/tabpanel/useTabPanel.js +13 -0
  112. package/esm/tabs/parts/tabpanel/useTabPanel.js.map +1 -0
  113. package/esm/tabs/useTabs.d.ts +14 -0
  114. package/esm/tabs/useTabs.js +39 -0
  115. package/esm/tabs/useTabs.js.map +1 -0
  116. package/esm/toggle-group/ToggleGroup.context.d.ts +31 -0
  117. package/esm/toggle-group/ToggleGroup.context.js +12 -0
  118. package/esm/toggle-group/ToggleGroup.context.js.map +1 -0
  119. package/esm/toggle-group/ToggleGroup.d.ts +5 -36
  120. package/esm/toggle-group/ToggleGroup.js +24 -24
  121. package/esm/toggle-group/ToggleGroup.js.map +1 -1
  122. package/esm/toggle-group/ToggleGroup.types.d.ts +38 -0
  123. package/esm/toggle-group/ToggleGroup.types.js +2 -0
  124. package/esm/toggle-group/ToggleGroup.types.js.map +1 -0
  125. package/esm/toggle-group/index.d.ts +3 -2
  126. package/esm/toggle-group/index.js +1 -1
  127. package/esm/toggle-group/index.js.map +1 -1
  128. package/esm/toggle-group/{ToggleItem.d.ts → parts/ToggleItem.d.ts} +2 -2
  129. package/esm/toggle-group/parts/ToggleItem.js +25 -0
  130. package/esm/toggle-group/parts/ToggleItem.js.map +1 -0
  131. package/esm/toggle-group/parts/useToggleItem.d.ts +20 -0
  132. package/esm/toggle-group/parts/useToggleItem.js +72 -0
  133. package/esm/toggle-group/parts/useToggleItem.js.map +1 -0
  134. package/esm/toggle-group/useToggleGroup.d.ts +8 -0
  135. package/esm/toggle-group/useToggleGroup.js +25 -0
  136. package/esm/toggle-group/useToggleGroup.js.map +1 -0
  137. package/package.json +3 -5
  138. package/src/date/datepicker/datepicker.stories.tsx +39 -0
  139. package/src/date/datepicker/parts/DayButton.tsx +2 -0
  140. package/src/date/hooks/useDatepicker.tsx +5 -1
  141. package/src/date/hooks/useMonthPicker.tsx +5 -1
  142. package/src/date/monthpicker/MonthButton.tsx +1 -0
  143. package/src/date/monthpicker/monthpicker.stories.tsx +36 -19
  144. package/src/modal/modal.stories.tsx +2 -6
  145. package/src/tabs/Tabs.context.ts +24 -0
  146. package/src/tabs/Tabs.stories.tsx +233 -113
  147. package/src/tabs/Tabs.test.tsx +99 -37
  148. package/src/tabs/Tabs.tsx +48 -70
  149. package/src/tabs/Tabs.types.ts +43 -0
  150. package/src/tabs/index.ts +11 -4
  151. package/src/tabs/parts/tab/Tab.tsx +93 -0
  152. package/src/tabs/parts/tab/useTab.ts +52 -0
  153. package/src/tabs/parts/tablist/ScrollButtons.tsx +29 -0
  154. package/src/tabs/parts/tablist/TabList.tsx +56 -0
  155. package/src/tabs/parts/tablist/useScrollButtons.ts +69 -0
  156. package/src/tabs/parts/tablist/useTabList.ts +68 -0
  157. package/src/tabs/parts/tabpanel/TabPanel.tsx +50 -0
  158. package/src/tabs/parts/tabpanel/useTabPanel.ts +18 -0
  159. package/src/tabs/useTabs.ts +51 -0
  160. package/src/toggle-group/ToggleGroup.context.ts +31 -0
  161. package/src/toggle-group/ToggleGroup.stories.tsx +67 -6
  162. package/src/toggle-group/ToggleGroup.test.tsx +57 -16
  163. package/src/toggle-group/ToggleGroup.tsx +63 -90
  164. package/src/toggle-group/ToggleGroup.types.ts +40 -0
  165. package/src/toggle-group/index.ts +3 -2
  166. package/src/toggle-group/parts/ToggleItem.tsx +55 -0
  167. package/src/toggle-group/parts/useToggleItem.ts +104 -0
  168. package/src/toggle-group/useToggleGroup.ts +33 -0
  169. package/cjs/tabs/Tab.d.ts +0 -18
  170. package/cjs/tabs/Tab.js.map +0 -1
  171. package/cjs/tabs/TabList.js +0 -111
  172. package/cjs/tabs/TabList.js.map +0 -1
  173. package/cjs/tabs/TabPanel.d.ts +0 -13
  174. package/cjs/tabs/TabPanel.js.map +0 -1
  175. package/cjs/tabs/context.d.ts +0 -8
  176. package/cjs/tabs/context.js +0 -6
  177. package/cjs/tabs/context.js.map +0 -1
  178. package/cjs/toggle-group/ToggleItem.js.map +0 -1
  179. package/cjs/toggle-group/context.d.ts +0 -6
  180. package/cjs/toggle-group/context.js +0 -6
  181. package/cjs/toggle-group/context.js.map +0 -1
  182. package/esm/tabs/Tab.d.ts +0 -18
  183. package/esm/tabs/Tab.js +0 -34
  184. package/esm/tabs/Tab.js.map +0 -1
  185. package/esm/tabs/TabList.js +0 -82
  186. package/esm/tabs/TabList.js.map +0 -1
  187. package/esm/tabs/TabPanel.d.ts +0 -13
  188. package/esm/tabs/TabPanel.js +0 -20
  189. package/esm/tabs/TabPanel.js.map +0 -1
  190. package/esm/tabs/context.d.ts +0 -8
  191. package/esm/tabs/context.js +0 -3
  192. package/esm/tabs/context.js.map +0 -1
  193. package/esm/toggle-group/ToggleItem.js +0 -24
  194. package/esm/toggle-group/ToggleItem.js.map +0 -1
  195. package/esm/toggle-group/context.d.ts +0 -6
  196. package/esm/toggle-group/context.js +0 -3
  197. package/esm/toggle-group/context.js.map +0 -1
  198. package/src/tabs/Tab.tsx +0 -66
  199. package/src/tabs/TabList.tsx +0 -128
  200. package/src/tabs/TabPanel.tsx +0 -26
  201. package/src/tabs/context.ts +0 -9
  202. package/src/toggle-group/ToggleItem.tsx +0 -41
  203. package/src/toggle-group/context.ts +0 -9
package/src/tabs/Tab.tsx DELETED
@@ -1,66 +0,0 @@
1
- import * as RadixTabs from "@radix-ui/react-tabs";
2
- import cl from "clsx";
3
- import React, { forwardRef, useContext } from "react";
4
- import { BodyShort } from "../typography";
5
- import { OverridableComponent } from "../util/types";
6
- import { TabsContext } from "./context";
7
-
8
- export interface TabProps
9
- extends Omit<React.HTMLAttributes<HTMLButtonElement>, "children"> {
10
- /**
11
- * Tab label
12
- */
13
- label?: React.ReactNode;
14
- /**
15
- * Tab Icon
16
- */
17
- icon?: React.ReactNode;
18
- /**
19
- * Value for state-handling
20
- */
21
- value: string;
22
- }
23
-
24
- export const Tab: OverridableComponent<TabProps, HTMLButtonElement> =
25
- forwardRef(
26
- (
27
- { className, as: Component = "button", label, icon, value, ...rest },
28
- ref,
29
- ) => {
30
- const context = useContext(TabsContext);
31
-
32
- if (!label && !icon) {
33
- console.error("<Tabs.Tab/> needs label/icon");
34
- return null;
35
- }
36
-
37
- return (
38
- <RadixTabs.Trigger value={value} asChild>
39
- <Component
40
- ref={ref}
41
- className={cl(
42
- "navds-tabs__tab",
43
- `navds-tabs__tab--${context?.size ?? "medium"}`,
44
- `navds-tabs__tab-icon--${context?.iconPosition}`,
45
- className,
46
- {
47
- "navds-tabs__tab--icon-only": icon && !label,
48
- },
49
- )}
50
- {...rest}
51
- >
52
- <BodyShort
53
- as="span"
54
- className="navds-tabs__tab-inner"
55
- size={context?.size}
56
- >
57
- {icon}
58
- {label}
59
- </BodyShort>
60
- </Component>
61
- </RadixTabs.Trigger>
62
- );
63
- },
64
- );
65
-
66
- export default Tab;
@@ -1,128 +0,0 @@
1
- import * as RadixTabs from "@radix-ui/react-tabs";
2
- import cl from "clsx";
3
- import React, {
4
- forwardRef,
5
- useContext,
6
- useEffect,
7
- useMemo,
8
- useRef,
9
- useState,
10
- } from "react";
11
- import { ChevronLeftIcon, ChevronRightIcon } from "@navikt/aksel-icons";
12
- import { debounce } from "../util";
13
- import { useMergeRefs } from "../util/hooks/useMergeRefs";
14
- import { TabsContext } from "./context";
15
-
16
- export interface TabListProps extends React.HTMLAttributes<HTMLDivElement> {
17
- /**
18
- * `<Tabs.Tab />` elements
19
- */
20
- children: React.ReactNode;
21
- }
22
-
23
- export const TabList = forwardRef<HTMLDivElement, TabListProps>(
24
- ({ className, ...rest }, ref) => {
25
- const context = useContext(TabsContext);
26
- const listRef = useRef<HTMLDivElement | null>(null);
27
- const mergedRef = useMergeRefs(listRef, ref);
28
-
29
- const [displayScroll, setDisplayScroll] = useState({
30
- start: false,
31
- end: false,
32
- });
33
-
34
- const updateScrollButtonState = useMemo(
35
- () =>
36
- debounce(() => {
37
- if (!listRef?.current) return;
38
- const { scrollWidth, clientWidth } = listRef.current;
39
- const scrollLeft = listRef.current.scrollLeft;
40
- // use 1 for the potential rounding error with browser zooms.
41
- const showStartScroll = scrollLeft > 1;
42
- const showEndScroll = scrollLeft < scrollWidth - clientWidth - 1;
43
-
44
- setDisplayScroll((oldDisplayScroll) =>
45
- showStartScroll === oldDisplayScroll.start &&
46
- showEndScroll === oldDisplayScroll.end
47
- ? oldDisplayScroll
48
- : { start: showStartScroll, end: showEndScroll },
49
- );
50
- }),
51
- [],
52
- );
53
-
54
- useEffect(() => {
55
- const handleResize = () => updateScrollButtonState();
56
- const win = listRef.current?.ownerDocument ?? document ?? window;
57
- win.addEventListener("resize", handleResize);
58
-
59
- let resizeObserver;
60
-
61
- if (typeof ResizeObserver !== "undefined") {
62
- resizeObserver = new ResizeObserver(handleResize);
63
- resizeObserver.observe(listRef.current);
64
- }
65
-
66
- return () => {
67
- win.removeEventListener("resize", handleResize);
68
- if (resizeObserver) {
69
- resizeObserver.disconnect();
70
- }
71
- };
72
- }, [updateScrollButtonState]);
73
-
74
- useEffect(() => {
75
- updateScrollButtonState();
76
- });
77
-
78
- useEffect(() => {
79
- return () => {
80
- updateScrollButtonState.clear();
81
- };
82
- }, [updateScrollButtonState]);
83
-
84
- const ScrollButton = ({
85
- dir,
86
- hidden,
87
- }: {
88
- dir: 1 | -1;
89
- hidden: boolean;
90
- }) => (
91
- // eslint-disable-next-line jsx-a11y/click-events-have-key-events, jsx-a11y/no-static-element-interactions
92
- <div
93
- className={cl("navds-tabs__scroll-button", {
94
- "navds-tabs__scroll-button--hidden": hidden,
95
- })}
96
- onClick={() => {
97
- if (!listRef.current) return;
98
- listRef.current.scrollLeft += dir * 100;
99
- }}
100
- >
101
- {dir === -1 ? (
102
- <ChevronLeftIcon title="scroll tilbake" />
103
- ) : (
104
- <ChevronRightIcon title="scroll neste" />
105
- )}
106
- </div>
107
- );
108
-
109
- const showSteppers = displayScroll.end || displayScroll.start;
110
- return (
111
- <div className="navds-tabs__tablist-wrapper">
112
- {showSteppers && (
113
- <ScrollButton dir={-1} hidden={!displayScroll.start} />
114
- )}
115
- <RadixTabs.TabsList
116
- {...rest}
117
- ref={mergedRef}
118
- onScroll={updateScrollButtonState}
119
- loop={context?.loop}
120
- className={cl("navds-tabs__tablist", className)}
121
- />
122
- {showSteppers && <ScrollButton dir={1} hidden={!displayScroll.end} />}
123
- </div>
124
- );
125
- },
126
- );
127
-
128
- export default TabList;
@@ -1,26 +0,0 @@
1
- import * as RadixTabs from "@radix-ui/react-tabs";
2
- import cl from "clsx";
3
- import React, { forwardRef } from "react";
4
-
5
- export interface TabPanelProps extends React.HTMLAttributes<HTMLDivElement> {
6
- /**
7
- * Tab panel content
8
- */
9
- children: React.ReactNode;
10
- /**
11
- * Value for state-handling
12
- */
13
- value: string;
14
- }
15
-
16
- const TabPanel = forwardRef<HTMLDivElement, TabPanelProps>(
17
- ({ className, ...rest }, ref) => (
18
- <RadixTabs.TabsContent
19
- {...rest}
20
- ref={ref}
21
- className={cl("navds-tabs__tabpanel", className)}
22
- />
23
- ),
24
- );
25
-
26
- export default TabPanel;
@@ -1,9 +0,0 @@
1
- import { createContext } from "react";
2
-
3
- interface TabsContextProps {
4
- size: "medium" | "small";
5
- loop: boolean;
6
- iconPosition: "left" | "top";
7
- }
8
-
9
- export const TabsContext = createContext<TabsContextProps | null>(null);
@@ -1,41 +0,0 @@
1
- import * as RadixToggleGroup from "@radix-ui/react-toggle-group";
2
- import cl from "clsx";
3
- import React, { forwardRef, useContext } from "react";
4
- import { BodyShort } from "../typography/BodyShort";
5
- import { ToggleGroupContext } from "./context";
6
-
7
- export interface ToggleGroupItemProps
8
- extends React.HTMLAttributes<HTMLButtonElement> {
9
- /**
10
- * Content
11
- */
12
- children: React.ReactNode;
13
- /**
14
- * Value for state-handling
15
- */
16
- value: string;
17
- }
18
-
19
- const ToggleItem = forwardRef<HTMLButtonElement, ToggleGroupItemProps>(
20
- ({ className, children, ...rest }, ref) => {
21
- const context = useContext(ToggleGroupContext);
22
-
23
- return (
24
- <RadixToggleGroup.Item
25
- {...rest}
26
- ref={ref}
27
- className={cl("navds-toggle-group__button", className)}
28
- >
29
- <BodyShort
30
- as="span"
31
- className="navds-toggle-group__button-inner"
32
- size={context?.size}
33
- >
34
- {children}
35
- </BodyShort>
36
- </RadixToggleGroup.Item>
37
- );
38
- },
39
- );
40
-
41
- export default ToggleItem;
@@ -1,9 +0,0 @@
1
- import { createContext } from "react";
2
-
3
- interface ToggleContextProps {
4
- size: "medium" | "small";
5
- }
6
-
7
- export const ToggleGroupContext = createContext<ToggleContextProps | null>(
8
- null,
9
- );