@navikt/ds-react 7.2.1 → 7.3.1

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 (222) hide show
  1. package/cjs/accordion/AccordionHeader.js +1 -1
  2. package/cjs/accordion/AccordionHeader.js.map +1 -1
  3. package/cjs/alert/Alert.d.ts +0 -3
  4. package/cjs/alert/Alert.js +11 -17
  5. package/cjs/alert/Alert.js.map +1 -1
  6. package/cjs/chips/Removable.d.ts +5 -5
  7. package/cjs/chips/Removable.js +4 -2
  8. package/cjs/chips/Removable.js.map +1 -1
  9. package/cjs/collapsible/Collapsible.context.d.ts +1 -1
  10. package/cjs/date/datepicker/DatePicker.d.ts +2 -2
  11. package/cjs/date/monthpicker/MonthPicker.d.ts +2 -2
  12. package/cjs/form/combobox/Input/Input.js +1 -1
  13. package/cjs/form/combobox/Input/Input.js.map +1 -1
  14. package/cjs/form/combobox/types.d.ts +3 -1
  15. package/cjs/form/file-upload/FileUpload.context.d.ts +1 -1
  16. package/cjs/index.d.ts +1 -0
  17. package/cjs/index.js +4 -2
  18. package/cjs/index.js.map +1 -1
  19. package/cjs/layout/base/BasePrimitive.d.ts +3 -0
  20. package/cjs/layout/base/BasePrimitive.js.map +1 -1
  21. package/cjs/layout/box/Box.d.ts +2 -2
  22. package/cjs/layout/box/Box.js.map +1 -1
  23. package/cjs/layout/grid/HGrid.d.ts +2 -2
  24. package/cjs/layout/grid/HGrid.js.map +1 -1
  25. package/cjs/layout/stack/Stack.d.ts +2 -2
  26. package/cjs/layout/stack/Stack.js.map +1 -1
  27. package/cjs/modal/ModalHeader.js +6 -1
  28. package/cjs/modal/ModalHeader.js.map +1 -1
  29. package/cjs/modal/dialog-polyfill.js +2 -2
  30. package/cjs/modal/dialog-polyfill.js.map +1 -1
  31. package/cjs/overlays/action-menu/ActionMenu.d.ts +310 -0
  32. package/cjs/overlays/action-menu/ActionMenu.js +227 -0
  33. package/cjs/overlays/action-menu/ActionMenu.js.map +1 -0
  34. package/cjs/overlays/action-menu/index.d.ts +1 -0
  35. package/cjs/overlays/action-menu/index.js +19 -0
  36. package/cjs/overlays/action-menu/index.js.map +1 -0
  37. package/cjs/overlays/floating/Floating.js +9 -10
  38. package/cjs/overlays/floating/Floating.js.map +1 -1
  39. package/cjs/overlays/floating/Floating.utils.d.ts +3 -5
  40. package/cjs/overlays/floating/Floating.utils.js +0 -2
  41. package/cjs/overlays/floating/Floating.utils.js.map +1 -1
  42. package/cjs/overlays/floating-menu/Menu.d.ts +15 -21
  43. package/cjs/overlays/floating-menu/Menu.js +119 -230
  44. package/cjs/overlays/floating-menu/Menu.js.map +1 -1
  45. package/cjs/overlays/floating-menu/parts/RovingFocus.d.ts +1 -1
  46. package/cjs/overlays/floating-menu/parts/RovingFocus.js.map +1 -1
  47. package/cjs/pagination/Pagination.d.ts +1 -6
  48. package/cjs/pagination/Pagination.js.map +1 -1
  49. package/cjs/provider/i18n/LanguageProvider.d.ts +3 -3
  50. package/cjs/stepper/context.d.ts +1 -1
  51. package/cjs/table/Body.d.ts +2 -4
  52. package/cjs/table/Body.js.map +1 -1
  53. package/cjs/table/ColumnHeader.d.ts +1 -2
  54. package/cjs/table/ColumnHeader.js.map +1 -1
  55. package/cjs/table/ExpandableRow.d.ts +1 -2
  56. package/cjs/table/ExpandableRow.js.map +1 -1
  57. package/cjs/table/Header.d.ts +2 -4
  58. package/cjs/table/Header.js.map +1 -1
  59. package/cjs/table/HeaderCell.d.ts +1 -2
  60. package/cjs/table/HeaderCell.js.map +1 -1
  61. package/cjs/table/Row.d.ts +1 -2
  62. package/cjs/table/Row.js.map +1 -1
  63. package/cjs/tabs/Tabs.context.d.ts +1 -1
  64. package/cjs/toggle-group/ToggleGroup.context.d.ts +1 -1
  65. package/cjs/util/hooks/descendants/useDescendant.js +4 -4
  66. package/cjs/util/hooks/descendants/useDescendant.js.map +1 -1
  67. package/cjs/util/i18n/get.d.ts +2 -2
  68. package/cjs/util/i18n/get.js.map +1 -1
  69. package/cjs/util/i18n/i18n.context.d.ts +2 -3
  70. package/cjs/util/i18n/i18n.context.js.map +1 -1
  71. package/cjs/util/i18n/i18n.types.d.ts +5 -9
  72. package/cjs/util/i18n/locales/en.d.ts +39 -0
  73. package/cjs/util/i18n/locales/en.js +41 -0
  74. package/cjs/util/i18n/locales/en.js.map +1 -0
  75. package/cjs/util/i18n/locales/nb.d.ts +14 -0
  76. package/cjs/util/i18n/locales/nb.js +14 -0
  77. package/cjs/util/i18n/locales/nb.js.map +1 -1
  78. package/cjs/util/i18n/locales/nn.d.ts +39 -0
  79. package/cjs/util/i18n/locales/nn.js +41 -0
  80. package/cjs/util/i18n/locales/nn.js.map +1 -0
  81. package/cjs/util/requireReactElement.d.ts +2 -0
  82. package/cjs/util/requireReactElement.js +22 -0
  83. package/cjs/util/requireReactElement.js.map +1 -0
  84. package/cjs/util/virtualfocus/Context.d.ts +1 -1
  85. package/cjs/util/virtualfocus/parts/VirtualFocusContent.d.ts +1 -2
  86. package/cjs/util/virtualfocus/parts/VirtualFocusContent.js.map +1 -1
  87. package/esm/accordion/AccordionHeader.js +1 -1
  88. package/esm/accordion/AccordionHeader.js.map +1 -1
  89. package/esm/alert/Alert.d.ts +0 -3
  90. package/esm/alert/Alert.js +11 -17
  91. package/esm/alert/Alert.js.map +1 -1
  92. package/esm/chips/Removable.d.ts +5 -5
  93. package/esm/chips/Removable.js +4 -2
  94. package/esm/chips/Removable.js.map +1 -1
  95. package/esm/collapsible/Collapsible.context.d.ts +1 -1
  96. package/esm/date/datepicker/DatePicker.d.ts +2 -2
  97. package/esm/date/monthpicker/MonthPicker.d.ts +2 -2
  98. package/esm/form/combobox/Input/Input.js +1 -1
  99. package/esm/form/combobox/Input/Input.js.map +1 -1
  100. package/esm/form/combobox/types.d.ts +3 -1
  101. package/esm/form/file-upload/FileUpload.context.d.ts +1 -1
  102. package/esm/index.d.ts +1 -0
  103. package/esm/index.js +1 -0
  104. package/esm/index.js.map +1 -1
  105. package/esm/layout/base/BasePrimitive.d.ts +3 -0
  106. package/esm/layout/base/BasePrimitive.js.map +1 -1
  107. package/esm/layout/box/Box.d.ts +2 -2
  108. package/esm/layout/box/Box.js.map +1 -1
  109. package/esm/layout/grid/HGrid.d.ts +2 -2
  110. package/esm/layout/grid/HGrid.js.map +1 -1
  111. package/esm/layout/stack/Stack.d.ts +2 -2
  112. package/esm/layout/stack/Stack.js.map +1 -1
  113. package/esm/modal/ModalHeader.js +6 -1
  114. package/esm/modal/ModalHeader.js.map +1 -1
  115. package/esm/modal/dialog-polyfill.js +2 -2
  116. package/esm/modal/dialog-polyfill.js.map +1 -1
  117. package/esm/overlays/action-menu/ActionMenu.d.ts +310 -0
  118. package/esm/overlays/action-menu/ActionMenu.js +197 -0
  119. package/esm/overlays/action-menu/ActionMenu.js.map +1 -0
  120. package/esm/overlays/action-menu/index.d.ts +1 -0
  121. package/esm/overlays/action-menu/index.js +3 -0
  122. package/esm/overlays/action-menu/index.js.map +1 -0
  123. package/esm/overlays/floating/Floating.js +9 -10
  124. package/esm/overlays/floating/Floating.js.map +1 -1
  125. package/esm/overlays/floating/Floating.utils.d.ts +3 -5
  126. package/esm/overlays/floating/Floating.utils.js +0 -2
  127. package/esm/overlays/floating/Floating.utils.js.map +1 -1
  128. package/esm/overlays/floating-menu/Menu.d.ts +15 -21
  129. package/esm/overlays/floating-menu/Menu.js +119 -230
  130. package/esm/overlays/floating-menu/Menu.js.map +1 -1
  131. package/esm/overlays/floating-menu/parts/RovingFocus.d.ts +1 -1
  132. package/esm/overlays/floating-menu/parts/RovingFocus.js.map +1 -1
  133. package/esm/pagination/Pagination.d.ts +1 -6
  134. package/esm/pagination/Pagination.js.map +1 -1
  135. package/esm/provider/i18n/LanguageProvider.d.ts +3 -3
  136. package/esm/stepper/context.d.ts +1 -1
  137. package/esm/table/Body.d.ts +2 -4
  138. package/esm/table/Body.js.map +1 -1
  139. package/esm/table/ColumnHeader.d.ts +1 -2
  140. package/esm/table/ColumnHeader.js.map +1 -1
  141. package/esm/table/ExpandableRow.d.ts +1 -2
  142. package/esm/table/ExpandableRow.js.map +1 -1
  143. package/esm/table/Header.d.ts +2 -4
  144. package/esm/table/Header.js.map +1 -1
  145. package/esm/table/HeaderCell.d.ts +1 -2
  146. package/esm/table/HeaderCell.js.map +1 -1
  147. package/esm/table/Row.d.ts +1 -2
  148. package/esm/table/Row.js.map +1 -1
  149. package/esm/tabs/Tabs.context.d.ts +1 -1
  150. package/esm/toggle-group/ToggleGroup.context.d.ts +1 -1
  151. package/esm/util/hooks/descendants/useDescendant.js +4 -4
  152. package/esm/util/hooks/descendants/useDescendant.js.map +1 -1
  153. package/esm/util/i18n/get.d.ts +2 -2
  154. package/esm/util/i18n/get.js.map +1 -1
  155. package/esm/util/i18n/i18n.context.d.ts +2 -3
  156. package/esm/util/i18n/i18n.context.js.map +1 -1
  157. package/esm/util/i18n/i18n.types.d.ts +5 -9
  158. package/esm/util/i18n/locales/en.d.ts +39 -0
  159. package/esm/util/i18n/locales/en.js +39 -0
  160. package/esm/util/i18n/locales/en.js.map +1 -0
  161. package/esm/util/i18n/locales/nb.d.ts +14 -0
  162. package/esm/util/i18n/locales/nb.js +14 -0
  163. package/esm/util/i18n/locales/nb.js.map +1 -1
  164. package/esm/util/i18n/locales/nn.d.ts +39 -0
  165. package/esm/util/i18n/locales/nn.js +39 -0
  166. package/esm/util/i18n/locales/nn.js.map +1 -0
  167. package/esm/util/requireReactElement.d.ts +2 -0
  168. package/esm/util/requireReactElement.js +15 -0
  169. package/esm/util/requireReactElement.js.map +1 -0
  170. package/esm/util/virtualfocus/Context.d.ts +1 -1
  171. package/esm/util/virtualfocus/parts/VirtualFocusContent.d.ts +1 -2
  172. package/esm/util/virtualfocus/parts/VirtualFocusContent.js.map +1 -1
  173. package/package.json +15 -7
  174. package/src/accordion/AccordionHeader.tsx +0 -1
  175. package/src/alert/Alert.tsx +11 -20
  176. package/src/chips/Removable.tsx +13 -9
  177. package/src/date/datepicker/DatePicker.tsx +2 -2
  178. package/src/date/monthpicker/MonthPicker.tsx +2 -2
  179. package/src/form/checkbox/Checkbox.test.tsx +2 -3
  180. package/src/form/combobox/Input/Input.tsx +1 -1
  181. package/src/form/combobox/types.ts +3 -1
  182. package/src/form/confirmation-panel/ConfirmationPanel.test.tsx +1 -2
  183. package/src/form/radio/Radio.test.tsx +4 -5
  184. package/src/index.ts +1 -0
  185. package/src/layout/base/BasePrimitive.tsx +3 -0
  186. package/src/layout/box/Box.tsx +35 -36
  187. package/src/layout/grid/HGrid.tsx +26 -27
  188. package/src/layout/stack/Stack.tsx +53 -54
  189. package/src/modal/ModalHeader.tsx +6 -0
  190. package/src/modal/dialog-polyfill.ts +2 -2
  191. package/src/overlays/action-menu/ActionMenu.tsx +971 -0
  192. package/src/overlays/action-menu/index.ts +29 -0
  193. package/src/overlays/floating/Floating.tsx +6 -12
  194. package/src/overlays/floating/Floating.utils.ts +2 -5
  195. package/src/overlays/floating-menu/Menu.tsx +183 -332
  196. package/src/overlays/floating-menu/parts/RovingFocus.tsx +3 -3
  197. package/src/pagination/Pagination.tsx +4 -1
  198. package/src/pagination/steps.test.ts +15 -16
  199. package/src/provider/i18n/LanguageProvider.tsx +3 -3
  200. package/src/table/Body.tsx +4 -6
  201. package/src/table/ColumnHeader.tsx +3 -4
  202. package/src/table/ExpandableRow.tsx +3 -4
  203. package/src/table/Header.tsx +4 -6
  204. package/src/table/HeaderCell.tsx +3 -4
  205. package/src/table/Row.tsx +3 -4
  206. package/src/util/hooks/descendants/useDescendant.tsx +5 -5
  207. package/src/util/i18n/get.ts +3 -3
  208. package/src/util/i18n/i18n.context.ts +2 -3
  209. package/src/util/i18n/i18n.types.ts +7 -11
  210. package/src/util/i18n/locales/en.ts +40 -0
  211. package/src/util/i18n/locales/nb.ts +23 -1
  212. package/src/util/i18n/locales/nn.ts +40 -0
  213. package/src/util/i18n/locales.test.tsx +23 -0
  214. package/src/util/requireReactElement.ts +25 -0
  215. package/src/util/virtualfocus/parts/VirtualFocusContent.tsx +4 -2
  216. package/cjs/util/i18n/merge.d.ts +0 -2
  217. package/cjs/util/i18n/merge.js +0 -28
  218. package/cjs/util/i18n/merge.js.map +0 -1
  219. package/esm/util/i18n/merge.d.ts +0 -2
  220. package/esm/util/i18n/merge.js +0 -25
  221. package/esm/util/i18n/merge.js.map +0 -1
  222. package/src/util/i18n/merge.ts +0 -35
@@ -11,60 +11,59 @@ import { PrimitiveAsChildProps } from "../base/PrimitiveAsChildProps";
11
11
  import { getResponsiveProps, getResponsiveValue } from "../utilities/css";
12
12
  import { ResponsiveProp, SpacingScale } from "../utilities/types";
13
13
 
14
- export type StackProps = PrimitiveProps &
15
- PrimitiveAsChildProps &
16
- HTMLAttributes<HTMLDivElement> & {
17
- /**
18
- * CSS `justify-content` property.
19
- *
20
- * @example
21
- * justify='center'
22
- * justify={{xs: 'start', sm: 'center', md: 'end', lg: 'space-around', xl: 'space-between'}}
23
- */
24
- justify?: ResponsiveProp<
25
- | "start"
26
- | "center"
27
- | "end"
28
- | "space-around"
29
- | "space-between"
30
- | "space-evenly"
31
- >;
32
- /**
33
- * CSS `align-items` property.
34
- * @default "stretch"
35
- *
36
- * @example
37
- * align='center'
38
- * align={{xs: 'start', sm: 'center', md: 'end', lg: 'baseline', xl: 'stretch'}}
39
- */
40
- align?: ResponsiveProp<"start" | "center" | "end" | "baseline" | "stretch">;
41
- /**
42
- * Sets the CSS `flex-wrap` property.
43
- */
44
- wrap?: boolean;
45
- /**
46
- * CSS `gap` property.
47
- * Accepts a [spacing token](https://aksel.nav.no/grunnleggende/styling/design-tokens#0cc9fb32f213)
48
- * or an object of spacing tokens for different breakpoints.
49
- *
50
- * @example
51
- * gap='4'
52
- * gap='8 4'
53
- * gap={{xs: '2', sm: '3', md: '4', lg: '5', xl: '6'}}
54
- */
55
- gap?: ResponsiveProp<SpacingScale | `${SpacingScale} ${SpacingScale}`>;
56
- /**
57
- * CSS `flex-direction` property.
58
- * @default "row"
59
- *
60
- * @example
61
- * direction='row'
62
- * direction={{xs: 'row', sm: 'column'}}
63
- */
64
- direction?: ResponsiveProp<
65
- "row" | "column" | "row-reverse" | "column-reverse"
66
- >;
67
- };
14
+ export type StackProps = HTMLAttributes<HTMLDivElement> & {
15
+ /**
16
+ * CSS `justify-content` property.
17
+ *
18
+ * @example
19
+ * justify='center'
20
+ * justify={{xs: 'start', sm: 'center', md: 'end', lg: 'space-around', xl: 'space-between'}}
21
+ */
22
+ justify?: ResponsiveProp<
23
+ | "start"
24
+ | "center"
25
+ | "end"
26
+ | "space-around"
27
+ | "space-between"
28
+ | "space-evenly"
29
+ >;
30
+ /**
31
+ * CSS `align-items` property.
32
+ * @default "stretch"
33
+ *
34
+ * @example
35
+ * align='center'
36
+ * align={{xs: 'start', sm: 'center', md: 'end', lg: 'baseline', xl: 'stretch'}}
37
+ */
38
+ align?: ResponsiveProp<"start" | "center" | "end" | "baseline" | "stretch">;
39
+ /**
40
+ * Sets the CSS `flex-wrap` property.
41
+ */
42
+ wrap?: boolean;
43
+ /**
44
+ * CSS `gap` property.
45
+ * Accepts a [spacing token](https://aksel.nav.no/grunnleggende/styling/design-tokens#0cc9fb32f213)
46
+ * or an object of spacing tokens for different breakpoints.
47
+ *
48
+ * @example
49
+ * gap='4'
50
+ * gap='8 4'
51
+ * gap={{xs: '2', sm: '3', md: '4', lg: '5', xl: '6'}}
52
+ */
53
+ gap?: ResponsiveProp<SpacingScale | `${SpacingScale} ${SpacingScale}`>;
54
+ /**
55
+ * CSS `flex-direction` property.
56
+ * @default "row"
57
+ *
58
+ * @example
59
+ * direction='row'
60
+ * direction={{xs: 'row', sm: 'column'}}
61
+ */
62
+ direction?: ResponsiveProp<
63
+ "row" | "column" | "row-reverse" | "column-reverse"
64
+ >;
65
+ } & PrimitiveProps &
66
+ PrimitiveAsChildProps;
68
67
 
69
68
  export const Stack: OverridableComponent<StackProps, HTMLDivElement> =
70
69
  forwardRef(
@@ -25,6 +25,12 @@ const ModalHeader = forwardRef<HTMLDivElement, ModalHeaderProps>(
25
25
  className="navds-modal__button"
26
26
  size="small"
27
27
  variant="tertiary-neutral"
28
+ onKeyDown={(event) => {
29
+ /* Prevents autofocus used in combination with holding down keys from closing modal */
30
+ if (["Enter", " "].includes(event.key) && event.repeat) {
31
+ event.preventDefault();
32
+ }
33
+ }}
28
34
  onClick={context.closeHandler}
29
35
  icon={<XMarkIcon title="Lukk" />}
30
36
  />
@@ -518,7 +518,7 @@ dialogPolyfill.isInlinePositionSetByStylesheet = function (element) {
518
518
  // Some browsers throw on cssRules.
519
519
  try {
520
520
  cssRules = styleSheet.cssRules;
521
- } catch (e) {
521
+ } catch {
522
522
  /* empty */
523
523
  }
524
524
  if (!cssRules) {
@@ -530,7 +530,7 @@ dialogPolyfill.isInlinePositionSetByStylesheet = function (element) {
530
530
  // Ignore errors on invalid selector texts.
531
531
  try {
532
532
  selectedNodes = document.querySelectorAll(rule.selectorText);
533
- } catch (e) {
533
+ } catch {
534
534
  /* empty */
535
535
  }
536
536
  if (!selectedNodes || !inNodeList(selectedNodes, element)) {