@onewelcome/react-lib-components 0.2.0 → 0.2.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 (282) hide show
  1. package/dist/Breadcrumbs/Breadcrumbs.d.ts +4 -4
  2. package/dist/Button/BaseButton.d.ts +4 -4
  3. package/dist/Button/Button.d.ts +3 -3
  4. package/dist/Button/IconButton.d.ts +4 -4
  5. package/dist/ContextMenu/ContextMenu.d.ts +5 -5
  6. package/dist/ContextMenu/ContextMenuItem.d.ts +2 -2
  7. package/dist/DataGrid/DataGrid.d.ts +6 -6
  8. package/dist/DataGrid/DataGridActions/DataGridActions.d.ts +4 -4
  9. package/dist/DataGrid/DataGridActions/DataGridColumnsToggle.d.ts +3 -3
  10. package/dist/DataGrid/DataGridBody/DataGridBody.d.ts +3 -3
  11. package/dist/DataGrid/DataGridBody/DataGridCell.d.ts +2 -2
  12. package/dist/DataGrid/DataGridBody/DataGridRow.d.ts +3 -3
  13. package/dist/DataGrid/DataGridHeader/DataGridHeader.d.ts +3 -3
  14. package/dist/DataGrid/DataGridHeader/DataGridHeaderCell.d.ts +3 -3
  15. package/dist/DataGrid/datagrid.interfaces.d.ts +1 -1
  16. package/dist/Form/Checkbox/Checkbox.d.ts +5 -5
  17. package/dist/Form/Fieldset/Fieldset.d.ts +3 -3
  18. package/dist/Form/Form.d.ts +1 -1
  19. package/dist/Form/FormControl/FormControl.d.ts +3 -3
  20. package/dist/Form/FormGroup/FormGroup.d.ts +5 -5
  21. package/dist/Form/FormHelperText/FormHelperText.d.ts +3 -3
  22. package/dist/Form/FormSelectorWrapper/FormSelectorWrapper.d.ts +6 -6
  23. package/dist/Form/Input/Input.d.ts +5 -5
  24. package/dist/Form/Label/Label.d.ts +2 -2
  25. package/dist/Form/Radio/Radio.d.ts +5 -5
  26. package/dist/Form/Select/Option.d.ts +2 -2
  27. package/dist/Form/Select/Select.d.ts +5 -5
  28. package/dist/Form/Textarea/Textarea.d.ts +6 -6
  29. package/dist/Form/Toggle/Toggle.d.ts +3 -3
  30. package/dist/Form/Wrapper/CheckboxWrapper/CheckboxWrapper.d.ts +4 -4
  31. package/dist/Form/Wrapper/InputWrapper/InputWrapper.d.ts +4 -4
  32. package/dist/Form/Wrapper/RadioWrapper/RadioWrapper.d.ts +4 -4
  33. package/dist/Form/Wrapper/SelectWrapper/SelectWrapper.d.ts +4 -4
  34. package/dist/Form/Wrapper/TextareaWrapper/TextareaWrapper.d.ts +4 -4
  35. package/dist/Form/Wrapper/Wrapper/Wrapper.d.ts +6 -6
  36. package/dist/Form/form.interfaces.d.ts +1 -1
  37. package/dist/Icon/Icon.d.ts +3 -3
  38. package/dist/Link/Link.d.ts +7 -7
  39. package/dist/Notifications/BaseModal/BaseModal.d.ts +4 -4
  40. package/dist/Notifications/BaseModal/BaseModalActions/BaseModalActions.d.ts +2 -2
  41. package/dist/Notifications/BaseModal/BaseModalContent/BaseModalContent.d.ts +2 -2
  42. package/dist/Notifications/BaseModal/BaseModalHeader/BaseModalHeader.d.ts +2 -2
  43. package/dist/Notifications/Dialog/Dialog.d.ts +5 -5
  44. package/dist/Notifications/Dialog/DialogActions/DialogActions.d.ts +3 -3
  45. package/dist/Notifications/Dialog/DialogTitle/DialogTitle.d.ts +2 -2
  46. package/dist/Notifications/DiscardChangesModal/DiscardChangesDialog/DiscardChangesDialog.d.ts +3 -3
  47. package/dist/Notifications/DiscardChangesModal/DiscardChangesModal.d.ts +7 -7
  48. package/dist/Notifications/Modal/Modal.d.ts +1 -1
  49. package/dist/Notifications/Modal/ModalActions/ModalActions.d.ts +1 -1
  50. package/dist/Notifications/Modal/ModalContent/ModalContent.d.ts +1 -1
  51. package/dist/Notifications/Modal/ModalHeader/ModalHeader.d.ts +1 -1
  52. package/dist/Notifications/SlideInModal/SlideInModal.d.ts +3 -3
  53. package/dist/Notifications/Snackbar/SnackbarContainer/SnackbarContainer.d.ts +3 -3
  54. package/dist/Notifications/Snackbar/SnackbarItem/SnackbarItem.d.ts +2 -2
  55. package/dist/Notifications/Snackbar/SnackbarProvider/SnackbarProvider.d.ts +3 -3
  56. package/dist/Notifications/Snackbar/SnackbarProvider/SnackbarStateProvider.d.ts +2 -2
  57. package/dist/Notifications/Snackbar/interfaces.d.ts +2 -2
  58. package/dist/Pagination/Pagination.d.ts +3 -3
  59. package/dist/Popover/Popover.d.ts +3 -3
  60. package/dist/Skeleton/Skeleton.d.ts +3 -3
  61. package/dist/StatusIndicator/StatusIndicator.d.ts +5 -5
  62. package/dist/Tabs/Tab.d.ts +1 -1
  63. package/dist/Tabs/TabButton.d.ts +2 -2
  64. package/dist/Tabs/TabPanel.d.ts +2 -2
  65. package/dist/Tabs/Tabs.d.ts +4 -4
  66. package/dist/TextEllipsis/TextEllipsis.d.ts +2 -2
  67. package/dist/Tiles/Tile.d.ts +5 -5
  68. package/dist/Tiles/Tiles.d.ts +2 -2
  69. package/dist/Tooltip/Tooltip.d.ts +3 -3
  70. package/dist/Typography/Typography.d.ts +3 -3
  71. package/dist/Wizard/BaseWizardSteps/BaseWizardSteps.d.ts +2 -2
  72. package/dist/Wizard/Wizard.d.ts +3 -3
  73. package/dist/Wizard/WizardActions/WizardActions.d.ts +2 -2
  74. package/dist/Wizard/WizardStateProvider.d.ts +2 -2
  75. package/dist/Wizard/WizardSteps/WizardSteps.d.ts +2 -2
  76. package/dist/Wizard/wizardStateReducer.d.ts +5 -5
  77. package/dist/_BaseStyling_/BaseStyling.d.ts +1 -1
  78. package/dist/hooks/usePosition.d.ts +4 -4
  79. package/dist/hooks/useRepeater.d.ts +1 -1
  80. package/dist/hooks/useScroll.d.ts +1 -1
  81. package/dist/hooks/useSpacing.d.ts +1 -1
  82. package/dist/hooks/useWrapper.d.ts +1 -1
  83. package/dist/index.d.ts +55 -55
  84. package/dist/react-lib-components.cjs.development.js +676 -578
  85. package/dist/react-lib-components.cjs.development.js.map +1 -1
  86. package/dist/react-lib-components.cjs.production.min.js +1 -1
  87. package/dist/react-lib-components.cjs.production.min.js.map +1 -1
  88. package/dist/react-lib-components.esm.js +676 -578
  89. package/dist/react-lib-components.esm.js.map +1 -1
  90. package/package.json +27 -16
  91. package/src/Breadcrumbs/Breadcrumbs.test.tsx +15 -15
  92. package/src/Breadcrumbs/Breadcrumbs.tsx +11 -11
  93. package/src/Button/BaseButton.module.scss +1 -1
  94. package/src/Button/BaseButton.test.tsx +27 -27
  95. package/src/Button/BaseButton.tsx +8 -8
  96. package/src/Button/Button.module.scss +5 -5
  97. package/src/Button/Button.test.tsx +39 -39
  98. package/src/Button/Button.tsx +10 -10
  99. package/src/Button/IconButton.module.scss +5 -5
  100. package/src/Button/IconButton.test.tsx +29 -29
  101. package/src/Button/IconButton.tsx +11 -11
  102. package/src/ContextMenu/ContextMenu.test.tsx +97 -76
  103. package/src/ContextMenu/ContextMenu.tsx +48 -42
  104. package/src/ContextMenu/ContextMenuItem.module.scss +1 -1
  105. package/src/ContextMenu/ContextMenuItem.tsx +7 -5
  106. package/src/DataGrid/DataGrid.test.tsx +193 -193
  107. package/src/DataGrid/DataGrid.tsx +26 -26
  108. package/src/DataGrid/DataGridActions/DataGridActions.test.tsx +63 -63
  109. package/src/DataGrid/DataGridActions/DataGridActions.tsx +15 -15
  110. package/src/DataGrid/DataGridActions/DataGridColumnsToggle.module.scss +1 -1
  111. package/src/DataGrid/DataGridActions/DataGridColumnsToggle.test.tsx +21 -21
  112. package/src/DataGrid/DataGridActions/DataGridColumnsToggle.tsx +20 -20
  113. package/src/DataGrid/DataGridBody/DataGridBody.test.tsx +40 -40
  114. package/src/DataGrid/DataGridBody/DataGridBody.tsx +10 -10
  115. package/src/DataGrid/DataGridBody/DataGridCell.module.scss +1 -1
  116. package/src/DataGrid/DataGridBody/DataGridCell.test.tsx +25 -25
  117. package/src/DataGrid/DataGridBody/DataGridCell.tsx +6 -6
  118. package/src/DataGrid/DataGridBody/DataGridRow.test.tsx +38 -38
  119. package/src/DataGrid/DataGridBody/DataGridRow.tsx +8 -8
  120. package/src/DataGrid/DataGridHeader/DataGridHeader.module.scss +1 -2
  121. package/src/DataGrid/DataGridHeader/DataGridHeader.test.tsx +119 -119
  122. package/src/DataGrid/DataGridHeader/DataGridHeader.tsx +13 -13
  123. package/src/DataGrid/DataGridHeader/DataGridHeaderCell.module.scss +2 -0
  124. package/src/DataGrid/DataGridHeader/DataGridHeaderCell.test.tsx +51 -51
  125. package/src/DataGrid/DataGridHeader/DataGridHeaderCell.tsx +14 -14
  126. package/src/DataGrid/datagrid.interfaces.ts +1 -1
  127. package/src/Form/Checkbox/Checkbox.test.tsx +74 -74
  128. package/src/Form/Checkbox/Checkbox.tsx +27 -27
  129. package/src/Form/Fieldset/Fieldset.module.scss +1 -1
  130. package/src/Form/Fieldset/Fieldset.test.tsx +35 -35
  131. package/src/Form/Fieldset/Fieldset.tsx +27 -27
  132. package/src/Form/Form.test.tsx +18 -18
  133. package/src/Form/Form.tsx +3 -3
  134. package/src/Form/FormControl/FormControl.test.tsx +22 -22
  135. package/src/Form/FormControl/FormControl.tsx +10 -10
  136. package/src/Form/FormGroup/FormGroup.test.tsx +37 -37
  137. package/src/Form/FormGroup/FormGroup.tsx +16 -16
  138. package/src/Form/FormHelperText/FormHelperText.test.tsx +18 -18
  139. package/src/Form/FormHelperText/FormHelperText.tsx +7 -7
  140. package/src/Form/FormSelectorWrapper/FormSelectorWrapper.test.tsx +15 -15
  141. package/src/Form/FormSelectorWrapper/FormSelectorWrapper.tsx +14 -14
  142. package/src/Form/Input/Input.module.scss +20 -44
  143. package/src/Form/Input/Input.test.tsx +121 -73
  144. package/src/Form/Input/Input.tsx +96 -35
  145. package/src/Form/Label/Label.test.tsx +13 -13
  146. package/src/Form/Label/Label.tsx +6 -6
  147. package/src/Form/Radio/Radio.test.tsx +35 -35
  148. package/src/Form/Radio/Radio.tsx +17 -17
  149. package/src/Form/Select/Option.test.tsx +10 -10
  150. package/src/Form/Select/Option.tsx +8 -8
  151. package/src/Form/Select/Select.module.scss +7 -9
  152. package/src/Form/Select/Select.test.tsx +144 -141
  153. package/src/Form/Select/Select.tsx +79 -78
  154. package/src/Form/Textarea/Textarea.module.scss +8 -18
  155. package/src/Form/Textarea/Textarea.test.tsx +27 -27
  156. package/src/Form/Textarea/Textarea.tsx +33 -13
  157. package/src/Form/Toggle/Toggle.module.scss +1 -1
  158. package/src/Form/Toggle/Toggle.test.tsx +22 -22
  159. package/src/Form/Toggle/Toggle.tsx +10 -10
  160. package/src/Form/Wrapper/CheckboxWrapper/CheckboxWrapper.test.tsx +39 -39
  161. package/src/Form/Wrapper/CheckboxWrapper/CheckboxWrapper.tsx +12 -12
  162. package/src/Form/Wrapper/InputWrapper/InputWrapper.module.scss +2 -8
  163. package/src/Form/Wrapper/InputWrapper/InputWrapper.test.tsx +55 -55
  164. package/src/Form/Wrapper/InputWrapper/InputWrapper.tsx +30 -35
  165. package/src/Form/Wrapper/RadioWrapper/RadioWrapper.test.tsx +35 -35
  166. package/src/Form/Wrapper/RadioWrapper/RadioWrapper.tsx +12 -12
  167. package/src/Form/Wrapper/SelectWrapper/SelectWrapper.test.tsx +55 -55
  168. package/src/Form/Wrapper/SelectWrapper/SelectWrapper.tsx +12 -12
  169. package/src/Form/Wrapper/TextareaWrapper/TextareaWrapper.module.scss +2 -11
  170. package/src/Form/Wrapper/TextareaWrapper/TextareaWrapper.test.tsx +50 -50
  171. package/src/Form/Wrapper/TextareaWrapper/TextareaWrapper.tsx +22 -22
  172. package/src/Form/Wrapper/Wrapper/Wrapper.module.scss +2 -2
  173. package/src/Form/Wrapper/Wrapper/Wrapper.test.tsx +11 -11
  174. package/src/Form/Wrapper/Wrapper/Wrapper.tsx +17 -17
  175. package/src/Form/form.interfaces.ts +1 -1
  176. package/src/Icon/Icon.module.scss +71 -71
  177. package/src/Icon/Icon.test.tsx +18 -18
  178. package/src/Icon/Icon.tsx +70 -70
  179. package/src/Link/Link.module.scss +5 -5
  180. package/src/Link/Link.test.tsx +76 -76
  181. package/src/Link/Link.tsx +27 -27
  182. package/src/Link/types.d.ts +1 -1
  183. package/src/Notifications/BaseModal/BaseModal.module.scss +1 -1
  184. package/src/Notifications/BaseModal/BaseModal.test.tsx +53 -53
  185. package/src/Notifications/BaseModal/BaseModal.tsx +16 -16
  186. package/src/Notifications/BaseModal/BaseModalActions/BaseModalActions.test.tsx +13 -13
  187. package/src/Notifications/BaseModal/BaseModalActions/BaseModalActions.tsx +5 -5
  188. package/src/Notifications/BaseModal/BaseModalContent/BaseModalContent.test.tsx +16 -16
  189. package/src/Notifications/BaseModal/BaseModalContent/BaseModalContent.tsx +5 -5
  190. package/src/Notifications/BaseModal/BaseModalHeader/BaseModalHeader.test.tsx +19 -19
  191. package/src/Notifications/BaseModal/BaseModalHeader/BaseModalHeader.tsx +10 -10
  192. package/src/Notifications/Dialog/Dialog.test.tsx +35 -35
  193. package/src/Notifications/Dialog/Dialog.tsx +19 -19
  194. package/src/Notifications/Dialog/DialogActions/DialogActions.test.tsx +14 -14
  195. package/src/Notifications/Dialog/DialogActions/DialogActions.tsx +6 -6
  196. package/src/Notifications/Dialog/DialogTitle/DialogTitle.test.tsx +12 -12
  197. package/src/Notifications/Dialog/DialogTitle/DialogTitle.tsx +6 -6
  198. package/src/Notifications/DiscardChangesModal/DiscardChangesDialog/DiscardChangesDialog.test.tsx +20 -20
  199. package/src/Notifications/DiscardChangesModal/DiscardChangesDialog/DiscardChangesDialog.tsx +7 -7
  200. package/src/Notifications/DiscardChangesModal/DiscardChangesModal.test.tsx +36 -36
  201. package/src/Notifications/DiscardChangesModal/DiscardChangesModal.tsx +8 -8
  202. package/src/Notifications/Modal/Modal.test.tsx +6 -6
  203. package/src/Notifications/Modal/Modal.tsx +1 -1
  204. package/src/Notifications/Modal/ModalActions/ModalActions.tsx +2 -2
  205. package/src/Notifications/Modal/ModalContent/ModalContent.tsx +2 -2
  206. package/src/Notifications/Modal/ModalHeader/ModalHeader.tsx +2 -2
  207. package/src/Notifications/SlideInModal/SlideInModal.test.tsx +16 -16
  208. package/src/Notifications/SlideInModal/SlideInModal.tsx +16 -11
  209. package/src/Notifications/Snackbar/SnackbarContainer/SnackbarContainer.test.tsx +16 -16
  210. package/src/Notifications/Snackbar/SnackbarContainer/SnackbarContainer.tsx +6 -6
  211. package/src/Notifications/Snackbar/SnackbarItem/SnackbarItem.module.scss +2 -2
  212. package/src/Notifications/Snackbar/SnackbarItem/SnackbarItem.test.tsx +17 -17
  213. package/src/Notifications/Snackbar/SnackbarItem/SnackbarItem.tsx +23 -23
  214. package/src/Notifications/Snackbar/SnackbarProvider/SnackbarProvider.test.tsx +32 -32
  215. package/src/Notifications/Snackbar/SnackbarProvider/SnackbarProvider.tsx +18 -18
  216. package/src/Notifications/Snackbar/SnackbarProvider/SnackbarStateProvider.tsx +3 -3
  217. package/src/Notifications/Snackbar/interfaces.ts +2 -2
  218. package/src/Notifications/Snackbar/useSnackbar.ts +2 -2
  219. package/src/Pagination/Pagination.module.scss +2 -0
  220. package/src/Pagination/Pagination.test.tsx +47 -47
  221. package/src/Pagination/Pagination.tsx +35 -35
  222. package/src/Popover/Popover.test.tsx +19 -19
  223. package/src/Popover/Popover.tsx +7 -7
  224. package/src/Skeleton/Skeleton.module.scss +2 -2
  225. package/src/Skeleton/Skeleton.test.tsx +29 -29
  226. package/src/Skeleton/Skeleton.tsx +10 -10
  227. package/src/StatusIndicator/StatusIndicator.test.tsx +38 -38
  228. package/src/StatusIndicator/StatusIndicator.tsx +9 -9
  229. package/src/Tabs/Tab.test.tsx +13 -13
  230. package/src/Tabs/Tab.tsx +1 -1
  231. package/src/Tabs/TabButton.test.tsx +28 -28
  232. package/src/Tabs/TabButton.tsx +7 -7
  233. package/src/Tabs/TabPanel.test.tsx +30 -30
  234. package/src/Tabs/TabPanel.tsx +4 -4
  235. package/src/Tabs/Tabs.test.tsx +93 -93
  236. package/src/Tabs/Tabs.tsx +25 -25
  237. package/src/TextEllipsis/TextEllipsis.test.tsx +22 -22
  238. package/src/TextEllipsis/TextEllipsis.tsx +6 -6
  239. package/src/Tiles/Tile.module.scss +1 -1
  240. package/src/Tiles/Tile.test.tsx +42 -42
  241. package/src/Tiles/Tile.tsx +22 -22
  242. package/src/Tiles/Tiles.test.tsx +30 -30
  243. package/src/Tiles/Tiles.tsx +9 -9
  244. package/src/Tooltip/Tooltip.test.tsx +35 -35
  245. package/src/Tooltip/Tooltip.tsx +21 -21
  246. package/src/Typography/Typography.module.scss +1 -1
  247. package/src/Typography/Typography.test.tsx +49 -49
  248. package/src/Typography/Typography.tsx +42 -42
  249. package/src/Wizard/BaseWizardSteps/BaseWizardSteps.module.scss +1 -1
  250. package/src/Wizard/BaseWizardSteps/BaseWizardSteps.test.tsx +26 -26
  251. package/src/Wizard/BaseWizardSteps/BaseWizardSteps.tsx +24 -24
  252. package/src/Wizard/Wizard.test.tsx +56 -56
  253. package/src/Wizard/Wizard.tsx +6 -6
  254. package/src/Wizard/WizardActions/WizardActions.test.tsx +34 -34
  255. package/src/Wizard/WizardActions/WizardActions.tsx +14 -14
  256. package/src/Wizard/WizardStateProvider.tsx +3 -3
  257. package/src/Wizard/WizardSteps/WizardSteps.test.tsx +27 -27
  258. package/src/Wizard/WizardSteps/WizardSteps.tsx +7 -7
  259. package/src/Wizard/wizardStateReducer.ts +9 -9
  260. package/src/_BaseStyling_/BaseStyling.test.tsx +14 -14
  261. package/src/_BaseStyling_/BaseStyling.tsx +50 -50
  262. package/src/hooks/useAnimation.test.tsx +12 -12
  263. package/src/hooks/useAnimation.ts +4 -4
  264. package/src/hooks/useBodyClick.test.tsx +8 -8
  265. package/src/hooks/useBodyClick.ts +3 -3
  266. package/src/hooks/useFormSelector.test.ts +17 -17
  267. package/src/hooks/useFormSelector.ts +4 -4
  268. package/src/hooks/usePosition.test.tsx +215 -215
  269. package/src/hooks/usePosition.ts +68 -68
  270. package/src/hooks/useRepeater.test.tsx +26 -26
  271. package/src/hooks/useRepeater.ts +5 -5
  272. package/src/hooks/useScroll.test.tsx +5 -5
  273. package/src/hooks/useScroll.ts +3 -3
  274. package/src/hooks/useSpacing.test.ts +40 -40
  275. package/src/hooks/useSpacing.ts +3 -3
  276. package/src/hooks/useWrapper.test.ts +12 -12
  277. package/src/hooks/useWrapper.ts +14 -7
  278. package/src/index.ts +67 -67
  279. package/src/mixins.module.scss +76 -27
  280. package/src/types.d.ts +1 -1
  281. package/src/util/helper.test.tsx +25 -25
  282. package/src/util/helper.tsx +64 -64
@@ -1,12 +1,12 @@
1
- import React, { ComponentPropsWithRef, Fragment, useState } from 'react';
2
- import classes from './Pagination.module.scss';
3
- import readyclasses from '../readyclasses.module.scss';
4
- import { IconButton } from '../Button/IconButton';
5
- import { Icons, Icon } from '../Icon/Icon';
6
- import { Input } from '../Form/Input/Input';
7
- import { Select } from '../Form/Select/Select';
8
- import { Option } from '../Form/Select/Option';
9
- import { Label } from '../Form/Label/Label';
1
+ import React, { ComponentPropsWithRef, Fragment, useState } from "react";
2
+ import classes from "./Pagination.module.scss";
3
+ import readyclasses from "../readyclasses.module.scss";
4
+ import { IconButton } from "../Button/IconButton";
5
+ import { Icons, Icon } from "../Icon/Icon";
6
+ import { Input } from "../Form/Input/Input";
7
+ import { Select } from "../Form/Select/Select";
8
+ import { Option } from "../Form/Select/Option";
9
+ import { Label } from "../Form/Label/Label";
10
10
 
11
11
  export type PaginationTranslations = {
12
12
  totalItems: string;
@@ -16,19 +16,19 @@ export type PaginationTranslations = {
16
16
  currentPageLabel: string;
17
17
  };
18
18
 
19
- export type PageChangeLabels = 'next' | 'previous' | 'first' | 'last';
19
+ export type PageChangeLabels = "next" | "previous" | "first" | "last";
20
20
 
21
21
  enum DefaultTranslations {
22
- totalItems = 'Total items',
23
- itemsPerPage = 'Items per page',
24
- currentPage = 'Page %1 of %2',
25
- itemsPerPageLabel = 'Select how many items per page you want to see.',
26
- currentPageLabel = 'What page you are currently on.',
22
+ totalItems = "Total items",
23
+ itemsPerPage = "Items per page",
24
+ currentPage = "Page %1 of %2",
25
+ itemsPerPageLabel = "Select how many items per page you want to see.",
26
+ currentPageLabel = "What page you are currently on."
27
27
  }
28
28
 
29
29
  export type PageSize = 10 | 25 | 50;
30
30
 
31
- export interface Props extends Omit<ComponentPropsWithRef<'div'>, 'translate'> {
31
+ export interface Props extends Omit<ComponentPropsWithRef<"div">, "translate"> {
32
32
  currentPage?: number;
33
33
  totalElements?: number;
34
34
  pageSize?: PageSize;
@@ -52,7 +52,7 @@ export const Pagination = React.forwardRef<HTMLDivElement, Props>(
52
52
  ref
53
53
  ) => {
54
54
  /** We use an internal state variable, because we don't want to fire onCurrentPageChange whenever onChange fires on the input. Rather, only when the Enter key is pressed. */
55
- const [internalCurrentPage, setInternalCurrentPage] = useState(currentPage?.toString() || '1');
55
+ const [internalCurrentPage, setInternalCurrentPage] = useState(currentPage?.toString() || "1");
56
56
  const calculateAmountOfPages = () => {
57
57
  if (!totalElements) return 1;
58
58
 
@@ -64,7 +64,7 @@ export const Pagination = React.forwardRef<HTMLDivElement, Props>(
64
64
  };
65
65
 
66
66
  const onEnterListener = (event: React.KeyboardEvent<HTMLInputElement>) => {
67
- if (event.code === 'Enter') {
67
+ if (event.code === "Enter") {
68
68
  onPageChange(Number(internalCurrentPage));
69
69
  }
70
70
  };
@@ -73,16 +73,16 @@ export const Pagination = React.forwardRef<HTMLDivElement, Props>(
73
73
  const amountOfPages = calculateAmountOfPages();
74
74
 
75
75
  if (amountOfPages) {
76
- const splitCurrentPageTranslation = translate.currentPage.split(' ');
76
+ const splitCurrentPageTranslation = translate.currentPage.split(" ");
77
77
 
78
- return splitCurrentPageTranslation.map((string) => {
79
- if (string.includes('%1')) {
78
+ return splitCurrentPageTranslation.map(string => {
79
+ if (string.includes("%1")) {
80
80
  return (
81
81
  <Fragment key={string}>
82
82
  <Label
83
83
  id="current-value-input-label"
84
84
  htmlFor="current-value-input"
85
- className={`${readyclasses['sr-only']} ${classes['current-value-input-label']}`}
85
+ className={`${readyclasses["sr-only"]} ${classes["current-value-input-label"]}`}
86
86
  >
87
87
  {translate.currentPageLabel}
88
88
  </Label>
@@ -93,7 +93,7 @@ export const Pagination = React.forwardRef<HTMLDivElement, Props>(
93
93
  type="text"
94
94
  size={currentPage?.toString().length}
95
95
  max={calculateAmountOfPages()}
96
- wrapperProps={{ className: classes['current-value-input'] }}
96
+ wrapperProps={{ className: classes["current-value-input"] }}
97
97
  onKeyUp={onEnterListener}
98
98
  onBlur={(event: React.ChangeEvent<HTMLInputElement>) =>
99
99
  onPageChange(Number(event.target.value))
@@ -103,16 +103,16 @@ export const Pagination = React.forwardRef<HTMLDivElement, Props>(
103
103
  }
104
104
  name="current-value-input"
105
105
  value={internalCurrentPage}
106
- className={`${classes['form-element']} ${classes['current-page-input']}`}
106
+ className={`${classes["form-element"]} ${classes["current-page-input"]}`}
107
107
  />
108
108
  </Fragment>
109
109
  );
110
110
  }
111
111
 
112
- if (string.includes('%2')) {
112
+ if (string.includes("%2")) {
113
113
  return (
114
114
  <div key={string}>
115
- <strong>{string.replace('%2', amountOfPages.toString())}</strong>&nbsp;
115
+ <strong>{string.replace("%2", amountOfPages.toString())}</strong>&nbsp;
116
116
  </div>
117
117
  );
118
118
  }
@@ -137,22 +137,22 @@ export const Pagination = React.forwardRef<HTMLDivElement, Props>(
137
137
  <div
138
138
  {...rest}
139
139
  ref={ref}
140
- className={`${classes['pagination-wrapper']} ${className ? className : ''}`}
140
+ className={`${classes["pagination-wrapper"]} ${className ? className : ""}`}
141
141
  >
142
142
  {totalElements && (
143
- <div className={classes['total']}>
143
+ <div className={classes["total"]}>
144
144
  <span tabIndex={0}>
145
145
  {translate.totalItems}: <span>{totalElements}</span>
146
146
  </span>
147
147
  </div>
148
148
  )}
149
- <div className={classes['pagination']}>
149
+ <div className={classes["pagination"]}>
150
150
  {pageSize && (
151
- <div className={classes['per-page']}>
151
+ <div className={classes["per-page"]}>
152
152
  <Label id="page-size-select-label">{translate.itemsPerPage}</Label>
153
153
  <Select
154
154
  labeledBy="page-size-select-label"
155
- className={`${classes['form-element']} ${classes['page-size-select']}`}
155
+ className={`${classes["form-element"]} ${classes["page-size-select"]}`}
156
156
  value={pageSize.toString()}
157
157
  onChange={onPageSizeChangeHandler}
158
158
  >
@@ -164,7 +164,7 @@ export const Pagination = React.forwardRef<HTMLDivElement, Props>(
164
164
  )}
165
165
  <Fragment>
166
166
  {!!((currentPage && currentPage > 2) || (currentPage && currentPage > 1)) && (
167
- <div className={classes['previous']}>
167
+ <div className={classes["previous"]}>
168
168
  {currentPage > 2 && (
169
169
  <IconButton
170
170
  title="first"
@@ -185,10 +185,10 @@ export const Pagination = React.forwardRef<HTMLDivElement, Props>(
185
185
  )}
186
186
  </div>
187
187
  )}
188
- {totalElements && calculateAmountOfPages() && (
189
- <div className={classes['page']}>{renderCurrentPageTranslation()}</div>
188
+ {totalElements && !!calculateAmountOfPages() && (
189
+ <div className={classes["page"]}>{renderCurrentPageTranslation()}</div>
190
190
  )}
191
- <div className={classes['next']}>
191
+ <div className={classes["next"]}>
192
192
  {!!(
193
193
  (currentPage !== undefined && currentPage < calculateAmountOfPages()!) ||
194
194
  (currentPage !== undefined && !totalElements)
@@ -1,7 +1,7 @@
1
- import React, { Fragment, useRef } from 'react';
2
- import { Popover, Props } from './Popover';
3
- import { render } from '@testing-library/react';
4
- import { usePosition } from '../hooks/usePosition';
1
+ import React, { Fragment, useRef } from "react";
2
+ import { Popover, Props } from "./Popover";
3
+ import { render } from "@testing-library/react";
4
+ import { usePosition } from "../hooks/usePosition";
5
5
 
6
6
  const createPopover = (params?: (defaultParams: Props) => Props) => {
7
7
  const Component = () => {
@@ -17,7 +17,7 @@ const createPopover = (params?: (defaultParams: Props) => Props) => {
17
17
  </ul>
18
18
  ),
19
19
  show: false,
20
- placement: { vertical: 'top', horizontal: 'left' },
20
+ placement: { vertical: "top", horizontal: "left" }
21
21
  };
22
22
  let parameters: Props = defaultParams;
23
23
 
@@ -28,7 +28,7 @@ const createPopover = (params?: (defaultParams: Props) => Props) => {
28
28
  const { top, left, bottom, right, calculatePosition } = usePosition({
29
29
  elementToBePositioned: elementToBePositioned,
30
30
  relativeElement: relativeElement,
31
- ...parameters,
31
+ ...parameters
32
32
  });
33
33
 
34
34
  return (
@@ -49,34 +49,34 @@ const createPopover = (params?: (defaultParams: Props) => Props) => {
49
49
  };
50
50
 
51
51
  const queries = render(<Component />);
52
- const button = queries.getByTestId('button');
53
- const popover = queries.getByTestId('popover');
52
+ const button = queries.getByTestId("button");
53
+ const popover = queries.getByTestId("popover");
54
54
 
55
55
  /** Let the hacking begin */
56
- Object.defineProperty(button, 'offsetHeight', { configurable: true, value: 500 });
57
- Object.defineProperty(button, 'offsetWidth', { configurable: true, value: 500 });
56
+ Object.defineProperty(button, "offsetHeight", { configurable: true, value: 500 });
57
+ Object.defineProperty(button, "offsetWidth", { configurable: true, value: 500 });
58
58
 
59
- Object.defineProperty(window, 'innerHeight', {
59
+ Object.defineProperty(window, "innerHeight", {
60
60
  configurable: true,
61
- value: 1000,
61
+ value: 1000
62
62
  });
63
- Object.defineProperty(window, 'innerWidth', {
63
+ Object.defineProperty(window, "innerWidth", {
64
64
  configurable: true,
65
- value: 1000,
65
+ value: 1000
66
66
  });
67
67
 
68
- Object.defineProperty(popover, 'offsetHeight', { configurable: true, value: 100 });
69
- Object.defineProperty(popover, 'offsetWidth', { configurable: true, value: 100 });
68
+ Object.defineProperty(popover, "offsetHeight", { configurable: true, value: 100 });
69
+ Object.defineProperty(popover, "offsetWidth", { configurable: true, value: 100 });
70
70
 
71
71
  return {
72
72
  ...queries,
73
73
  popover,
74
- button,
74
+ button
75
75
  };
76
76
  };
77
77
 
78
- describe('Popover should render', () => {
79
- it('renders without crashing and has default left and top attributes', () => {
78
+ describe("Popover should render", () => {
79
+ it("renders without crashing and has default left and top attributes", () => {
80
80
  const { popover } = createPopover();
81
81
 
82
82
  expect(popover).toBeTruthy();
@@ -1,11 +1,11 @@
1
- import React, { ComponentPropsWithRef, ReactNode, RefObject, useEffect, useRef } from 'react';
2
- import { Offset, Placement, usePosition } from '../hooks/usePosition';
3
- import classes from './Popover.module.scss';
1
+ import React, { ComponentPropsWithRef, ReactNode, RefObject, useEffect, useRef } from "react";
2
+ import { Offset, Placement, usePosition } from "../hooks/usePosition";
3
+ import classes from "./Popover.module.scss";
4
4
 
5
- export interface Props extends ComponentPropsWithRef<'div'> {
5
+ export interface Props extends ComponentPropsWithRef<"div"> {
6
6
  children?: ReactNode;
7
7
  show?: boolean;
8
- anchorEl?: RefObject<HTMLOrSVGElement>;
8
+ anchorEl?: RefObject<HTMLOrSVGElement>; //eslint-disable-line no-undef
9
9
  placement?: Placement;
10
10
  offset?: Offset;
11
11
  transformOrigin?: Placement;
@@ -24,7 +24,7 @@ export const Popover = React.forwardRef<HTMLDivElement, Props>(
24
24
  relativeElement: anchorEl,
25
25
  offset: offset,
26
26
  placement: placement,
27
- transformOrigin: transformOrigin,
27
+ transformOrigin: transformOrigin
28
28
  });
29
29
 
30
30
  useEffect(() => {
@@ -35,7 +35,7 @@ export const Popover = React.forwardRef<HTMLDivElement, Props>(
35
35
  <div ref={ref} {...rest}>
36
36
  <div
37
37
  ref={elToBePositioned}
38
- className={`${classes.popover} ${className ?? ''} ${show ? classes.show : ''}`}
38
+ className={`${classes.popover} ${className ?? ""} ${show ? classes.show : ""}`}
39
39
  style={{ top: top, left: left, right: right, bottom: bottom }}
40
40
  >
41
41
  {children}
@@ -1,4 +1,4 @@
1
- @import '../mixins.module.scss';
1
+ @import "../mixins.module.scss";
2
2
 
3
3
  .skeleton {
4
4
  display: block;
@@ -7,7 +7,7 @@
7
7
  }
8
8
 
9
9
  .no-height::before {
10
- content: ' ';
10
+ content: " ";
11
11
  white-space: pre-wrap;
12
12
  }
13
13
 
@@ -1,6 +1,6 @@
1
- import React, { useEffect, useRef } from 'react';
2
- import { Skeleton, Props } from './Skeleton';
3
- import { render } from '@testing-library/react';
1
+ import React, { useEffect, useRef } from "react";
2
+ import { Skeleton, Props } from "./Skeleton";
3
+ import { render } from "@testing-library/react";
4
4
 
5
5
  const defaultParams: Props = {};
6
6
 
@@ -10,70 +10,70 @@ const createSkeleton = (params?: (defaultParams: Props) => Props) => {
10
10
  parameters = params(defaultParams);
11
11
  }
12
12
  const queries = render(<Skeleton {...parameters} data-testid="skeleton" />);
13
- const skeleton = queries.getByTestId('skeleton');
13
+ const skeleton = queries.getByTestId("skeleton");
14
14
 
15
15
  return {
16
16
  ...queries,
17
- skeleton,
17
+ skeleton
18
18
  };
19
19
  };
20
20
 
21
- describe('Skeleton should render', () => {
22
- it('renders without crashing', () => {
21
+ describe("Skeleton should render", () => {
22
+ it("renders without crashing", () => {
23
23
  const { skeleton } = createSkeleton();
24
24
 
25
- expect(skeleton).toHaveClass('skeleton text no-height', { exact: true });
25
+ expect(skeleton).toHaveClass("skeleton text no-height", { exact: true });
26
26
 
27
27
  expect(skeleton).toBeDefined();
28
28
  });
29
29
 
30
- it('renders with properties passed', () => {
31
- const testClass = 'testclass';
32
- const { skeleton } = createSkeleton((defaultParams) => ({
30
+ it("renders with properties passed", () => {
31
+ const testClass = "testclass";
32
+ const { skeleton } = createSkeleton(defaultParams => ({
33
33
  ...defaultParams,
34
- className: testClass,
34
+ className: testClass
35
35
  }));
36
36
 
37
37
  expect(skeleton).toHaveClass(`skeleton text no-height ${testClass}`, { exact: true });
38
38
  });
39
39
 
40
- it('renders text variant with width and height', () => {
41
- const width = '10rem';
40
+ it("renders text variant with width and height", () => {
41
+ const width = "10rem";
42
42
  const height = 10;
43
- const { skeleton } = createSkeleton((defaultParams) => ({
43
+ const { skeleton } = createSkeleton(defaultParams => ({
44
44
  ...defaultParams,
45
- variant: 'text',
45
+ variant: "text",
46
46
  width,
47
- height,
47
+ height
48
48
  }));
49
49
 
50
50
  expect(skeleton).toHaveClass(`skeleton text`, { exact: true });
51
- expect(skeleton).toHaveStyle({ width, height: '10px' });
51
+ expect(skeleton).toHaveStyle({ width, height: "10px" });
52
52
  });
53
53
 
54
- it('renders rectangle variant', () => {
55
- const { skeleton } = createSkeleton((defaultParams) => ({
54
+ it("renders rectangle variant", () => {
55
+ const { skeleton } = createSkeleton(defaultParams => ({
56
56
  ...defaultParams,
57
- variant: 'rectangle',
57
+ variant: "rectangle"
58
58
  }));
59
59
 
60
60
  expect(skeleton).toHaveClass(`skeleton no-height`, { exact: true });
61
61
  });
62
62
 
63
- it('renders circular variant', () => {
64
- const { skeleton } = createSkeleton((defaultParams) => ({
63
+ it("renders circular variant", () => {
64
+ const { skeleton } = createSkeleton(defaultParams => ({
65
65
  ...defaultParams,
66
- variant: 'circular',
66
+ variant: "circular"
67
67
  }));
68
68
 
69
69
  expect(skeleton).toHaveClass(`skeleton no-height circular`, { exact: true });
70
70
  });
71
71
  });
72
72
 
73
- describe('ref should work', () => {
74
- it('should give back the proper data prop, this also checks if the component propagates ...rest properly', () => {
73
+ describe("ref should work", () => {
74
+ it("should give back the proper data prop, this also checks if the component propagates ...rest properly", () => {
75
75
  const ExampleComponent = ({
76
- propagateRef,
76
+ propagateRef
77
77
  }: {
78
78
  propagateRef: (ref: React.RefObject<HTMLElement>) => void;
79
79
  }) => {
@@ -87,10 +87,10 @@ describe('ref should work', () => {
87
87
  };
88
88
 
89
89
  const refCheck = (ref: React.RefObject<HTMLElement>) => {
90
- expect(ref.current).toHaveAttribute('data-ref', 'testing');
90
+ expect(ref.current).toHaveAttribute("data-ref", "testing");
91
91
  };
92
92
 
93
- const container = document.createElement('tbody');
93
+ const container = document.createElement("tbody");
94
94
  render(<ExampleComponent propagateRef={refCheck} />, { container });
95
95
  });
96
96
  });
@@ -1,18 +1,18 @@
1
- import React, { ComponentPropsWithRef } from 'react';
2
- import classes from './Skeleton.module.scss';
1
+ import React, { ComponentPropsWithRef } from "react";
2
+ import classes from "./Skeleton.module.scss";
3
3
 
4
- export interface Props extends Omit<ComponentPropsWithRef<'div'>, 'children'> {
5
- variant?: 'circular' | 'rectangle' | 'text';
4
+ export interface Props extends Omit<ComponentPropsWithRef<"div">, "children"> {
5
+ variant?: "circular" | "rectangle" | "text";
6
6
  height?: number | string;
7
7
  width?: number | string;
8
8
  }
9
9
 
10
10
  export const Skeleton = React.forwardRef<HTMLDivElement, Props>(
11
- ({ variant = 'text', height, width, className, style, ...rest }: Props, ref) => {
12
- const classNames = [classes['skeleton']];
13
- !height && classNames.push(classes['no-height']);
14
- variant === 'text' && classNames.push(classes['text']);
15
- variant === 'circular' && classNames.push(classes['circular']);
11
+ ({ variant = "text", height, width, className, style, ...rest }: Props, ref) => {
12
+ const classNames = [classes["skeleton"]];
13
+ !height && classNames.push(classes["no-height"]);
14
+ variant === "text" && classNames.push(classes["text"]);
15
+ variant === "circular" && classNames.push(classes["circular"]);
16
16
  className && classNames.push(className);
17
17
 
18
18
  return (
@@ -22,7 +22,7 @@ export const Skeleton = React.forwardRef<HTMLDivElement, Props>(
22
22
  aria-hidden="true"
23
23
  ref={ref}
24
24
  style={{ ...style, width, height }}
25
- className={classNames.join(' ')}
25
+ className={classNames.join(" ")}
26
26
  ></span>
27
27
  );
28
28
  }
@@ -1,9 +1,9 @@
1
- import React, { useEffect, useRef } from 'react';
2
- import { StatusIndicator, Props } from './StatusIndicator';
3
- import { render } from '@testing-library/react';
1
+ import React, { useEffect, useRef } from "react";
2
+ import { StatusIndicator, Props } from "./StatusIndicator";
3
+ import { render } from "@testing-library/react";
4
4
 
5
5
  const defaultParams: Props = {
6
- status: 'active',
6
+ status: "active"
7
7
  };
8
8
 
9
9
  const createStatusIndicator = (params?: (defaultParams: Props) => Props) => {
@@ -16,92 +16,92 @@ const createStatusIndicator = (params?: (defaultParams: Props) => Props) => {
16
16
  content
17
17
  </StatusIndicator>
18
18
  );
19
- const statusIndicator = queries.getByTestId('StatusIndicator');
19
+ const statusIndicator = queries.getByTestId("StatusIndicator");
20
20
 
21
21
  return {
22
22
  ...queries,
23
- statusIndicator,
23
+ statusIndicator
24
24
  };
25
25
  };
26
26
 
27
- describe('StatusIndicator should render', () => {
28
- it('renders without crashing', () => {
27
+ describe("StatusIndicator should render", () => {
28
+ it("renders without crashing", () => {
29
29
  const { statusIndicator, getByText } = createStatusIndicator();
30
30
 
31
31
  expect(statusIndicator).toBeDefined();
32
- expect(getByText('content')).toBeInTheDocument();
32
+ expect(getByText("content")).toBeInTheDocument();
33
33
  });
34
34
 
35
- it('passes through custom typography props', () => {
36
- const { statusIndicator, getByText } = createStatusIndicator((params) => ({
35
+ it("passes through custom typography props", () => {
36
+ const { statusIndicator, getByText } = createStatusIndicator(params => ({
37
37
  ...params,
38
38
  typographyProps: {
39
- variant: 'body',
40
- children: <strong>custom children</strong>,
41
- },
39
+ variant: "body",
40
+ children: <strong>custom children</strong>
41
+ }
42
42
  }));
43
43
 
44
44
  expect(statusIndicator).toBeDefined();
45
- expect(getByText('custom children')).toBeInTheDocument();
45
+ expect(getByText("custom children")).toBeInTheDocument();
46
46
  });
47
47
 
48
- it('passes through custom props', () => {
49
- const { statusIndicator } = createStatusIndicator((params) => ({
48
+ it("passes through custom props", () => {
49
+ const { statusIndicator } = createStatusIndicator(params => ({
50
50
  ...params,
51
- 'aria-label': 'status indicator',
51
+ "aria-label": "status indicator"
52
52
  }));
53
53
 
54
54
  expect(statusIndicator).toBeDefined();
55
- expect(statusIndicator).toHaveAttribute('aria-label', 'status indicator');
55
+ expect(statusIndicator).toHaveAttribute("aria-label", "status indicator");
56
56
  });
57
57
 
58
58
  it('should set "active" class on status badge', () => {
59
- const { statusIndicator } = createStatusIndicator((params) => ({
59
+ const { statusIndicator } = createStatusIndicator(params => ({
60
60
  ...params,
61
- status: 'active',
61
+ status: "active"
62
62
  }));
63
63
 
64
- expect(statusIndicator.firstChild).toHaveClass('active');
64
+ expect(statusIndicator.firstChild).toHaveClass("active");
65
65
  });
66
66
 
67
67
  it('should set "error" class on status badge', () => {
68
- const { statusIndicator } = createStatusIndicator((params) => ({ ...params, status: 'error' }));
68
+ const { statusIndicator } = createStatusIndicator(params => ({ ...params, status: "error" }));
69
69
 
70
- expect(statusIndicator.firstChild).toHaveClass('error');
70
+ expect(statusIndicator.firstChild).toHaveClass("error");
71
71
  });
72
72
 
73
73
  it('should set "neutral" class on status badge', () => {
74
- const { statusIndicator } = createStatusIndicator((params) => ({
74
+ const { statusIndicator } = createStatusIndicator(params => ({
75
75
  ...params,
76
- status: 'neutral',
76
+ status: "neutral"
77
77
  }));
78
78
 
79
- expect(statusIndicator.firstChild).toHaveClass('neutral');
79
+ expect(statusIndicator.firstChild).toHaveClass("neutral");
80
80
  });
81
81
 
82
82
  it('should pass "warning" class to status badge', () => {
83
- const { statusIndicator } = createStatusIndicator((params) => ({
83
+ const { statusIndicator } = createStatusIndicator(params => ({
84
84
  ...params,
85
- status: 'warning',
85
+ status: "warning"
86
86
  }));
87
87
 
88
- expect(statusIndicator.firstChild).toHaveClass('warning');
88
+ expect(statusIndicator.firstChild).toHaveClass("warning");
89
89
  });
90
90
 
91
- it('should pass custom class to status badge', () => {
92
- const { statusIndicator } = createStatusIndicator((params) => ({
91
+ it("should pass custom class to status badge", () => {
92
+ const { statusIndicator } = createStatusIndicator(params => ({
93
93
  ...params,
94
- badgeProps: { className: 'custom' },
94
+ badgeProps: { className: "custom" }
95
95
  }));
96
96
 
97
- expect(statusIndicator.firstChild).toHaveClass('custom');
97
+ expect(statusIndicator.firstChild).toHaveClass("custom");
98
98
  });
99
99
  });
100
100
 
101
- describe('ref should work', () => {
102
- it('should give back the proper data prop, this also checks if the component propagates ...rest properly', () => {
101
+ describe("ref should work", () => {
102
+ it("should give back the proper data prop, this also checks if the component propagates ...rest properly", () => {
103
103
  const ExampleComponent = ({
104
- propagateRef,
104
+ propagateRef
105
105
  }: {
106
106
  propagateRef?: (ref: React.RefObject<HTMLElement>) => void;
107
107
  }) => {
@@ -119,7 +119,7 @@ describe('ref should work', () => {
119
119
  };
120
120
 
121
121
  const refCheck = (ref: React.RefObject<HTMLElement>) => {
122
- expect(ref.current).toHaveAttribute('data-ref', 'testing');
122
+ expect(ref.current).toHaveAttribute("data-ref", "testing");
123
123
  };
124
124
 
125
125
  render(<ExampleComponent propagateRef={refCheck} />);
@@ -1,22 +1,22 @@
1
- import React, { ComponentPropsWithRef, ReactNode } from 'react';
2
- import { Typography, Props as TypographyProps } from '../Typography/Typography';
3
- import classes from './StatusIndicator.module.scss';
1
+ import React, { ComponentPropsWithRef, ReactNode } from "react";
2
+ import { Typography, Props as TypographyProps } from "../Typography/Typography";
3
+ import classes from "./StatusIndicator.module.scss";
4
4
 
5
- export interface Props extends ComponentPropsWithRef<'div'> {
5
+ export interface Props extends ComponentPropsWithRef<"div"> {
6
6
  children?: ReactNode;
7
- status: 'active' | 'error' | 'neutral' | 'warning';
8
- badgeProps?: ComponentPropsWithRef<'div'>;
7
+ status: "active" | "error" | "neutral" | "warning";
8
+ badgeProps?: ComponentPropsWithRef<"div">;
9
9
  typographyProps?: TypographyProps;
10
10
  }
11
11
 
12
12
  export const StatusIndicator = React.forwardRef<HTMLDivElement, Props>(
13
13
  ({ children, status, badgeProps, typographyProps, ...rest }: Props, ref) => {
14
14
  return (
15
- <div {...rest} className={classes['status-indicator']} ref={ref}>
15
+ <div {...rest} className={classes["status-indicator"]} ref={ref}>
16
16
  <div
17
- className={`${classes['status-badge']} ${classes[status]} ${badgeProps?.className ?? ''}`}
17
+ className={`${classes["status-badge"]} ${classes[status]} ${badgeProps?.className ?? ""}`}
18
18
  />
19
- <Typography {...typographyProps} spacing={{ margin: '0' }} variant="body" tag="div">
19
+ <Typography {...typographyProps} spacing={{ margin: "0" }} variant="body" tag="div">
20
20
  {typographyProps?.children || children}
21
21
  </Typography>
22
22
  </div>