@dxc-technology/halstack-react 0.0.0-bd47c58 → 0.0.0-bdaadec

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 (329) hide show
  1. package/BackgroundColorContext.d.ts +1 -10
  2. package/BackgroundColorContext.js +4 -21
  3. package/HalstackContext.d.ts +43 -138
  4. package/HalstackContext.js +10 -35
  5. package/accordion/Accordion.accessibility.test.js +71 -0
  6. package/accordion/Accordion.js +31 -84
  7. package/accordion/Accordion.stories.tsx +5 -51
  8. package/accordion/Accordion.test.js +18 -33
  9. package/accordion/types.d.ts +6 -6
  10. package/accordion-group/AccordionGroup.accessibility.test.js +88 -0
  11. package/accordion-group/AccordionGroup.d.ts +2 -3
  12. package/accordion-group/AccordionGroup.js +17 -44
  13. package/accordion-group/AccordionGroup.stories.tsx +1 -1
  14. package/accordion-group/AccordionGroup.test.js +42 -60
  15. package/accordion-group/AccordionGroupAccordion.js +11 -23
  16. package/accordion-group/AccordionGroupContext.d.ts +3 -0
  17. package/accordion-group/AccordionGroupContext.js +8 -0
  18. package/accordion-group/types.d.ts +7 -7
  19. package/action-icon/ActionIcon.accessibility.test.js +63 -0
  20. package/action-icon/ActionIcon.d.ts +4 -0
  21. package/action-icon/ActionIcon.js +48 -0
  22. package/action-icon/ActionIcon.stories.tsx +41 -0
  23. package/action-icon/ActionIcon.test.js +64 -0
  24. package/action-icon/types.d.ts +26 -0
  25. package/alert/Alert.accessibility.test.js +95 -0
  26. package/alert/Alert.js +29 -118
  27. package/alert/Alert.test.js +28 -45
  28. package/alert/types.d.ts +5 -5
  29. package/badge/Badge.accessibility.test.js +129 -0
  30. package/badge/Badge.d.ts +1 -1
  31. package/badge/Badge.js +141 -43
  32. package/badge/Badge.stories.tsx +210 -0
  33. package/badge/Badge.test.js +30 -0
  34. package/badge/types.d.ts +52 -3
  35. package/bleed/Bleed.js +13 -21
  36. package/bleed/types.d.ts +2 -2
  37. package/box/Box.accessibility.test.js +33 -0
  38. package/box/Box.js +11 -33
  39. package/box/Box.test.js +1 -6
  40. package/box/types.d.ts +3 -3
  41. package/bulleted-list/BulletedList.accessibility.test.js +107 -0
  42. package/bulleted-list/BulletedList.js +22 -55
  43. package/bulleted-list/BulletedList.stories.tsx +2 -93
  44. package/bulleted-list/types.d.ts +5 -5
  45. package/button/Button.accessibility.test.js +127 -0
  46. package/button/Button.js +36 -59
  47. package/button/Button.stories.tsx +33 -133
  48. package/button/Button.test.js +13 -21
  49. package/button/types.d.ts +5 -5
  50. package/card/Card.accessibility.test.js +36 -0
  51. package/card/Card.js +21 -44
  52. package/card/Card.test.js +10 -21
  53. package/card/types.d.ts +5 -5
  54. package/checkbox/Checkbox.accessibility.test.js +87 -0
  55. package/checkbox/Checkbox.js +85 -120
  56. package/checkbox/Checkbox.stories.tsx +16 -54
  57. package/checkbox/Checkbox.test.js +107 -63
  58. package/checkbox/types.d.ts +8 -4
  59. package/chip/Chip.accessibility.test.js +67 -0
  60. package/chip/Chip.js +20 -36
  61. package/chip/Chip.stories.tsx +5 -24
  62. package/chip/Chip.test.js +17 -30
  63. package/chip/types.d.ts +4 -4
  64. package/common/coreTokens.d.ts +105 -14
  65. package/common/coreTokens.js +40 -23
  66. package/common/utils.js +2 -8
  67. package/common/variables.d.ts +44 -139
  68. package/common/variables.js +55 -157
  69. package/container/Container.d.ts +4 -0
  70. package/container/Container.js +194 -0
  71. package/container/Container.stories.tsx +214 -0
  72. package/container/types.d.ts +74 -0
  73. package/container/types.js +5 -0
  74. package/contextual-menu/ContextualMenu.accessibility.test.js +86 -0
  75. package/contextual-menu/ContextualMenu.d.ts +7 -0
  76. package/contextual-menu/ContextualMenu.js +71 -0
  77. package/contextual-menu/ContextualMenu.stories.tsx +182 -0
  78. package/contextual-menu/ContextualMenu.test.js +71 -0
  79. package/contextual-menu/MenuItemAction.d.ts +4 -0
  80. package/contextual-menu/MenuItemAction.js +46 -0
  81. package/contextual-menu/types.d.ts +22 -0
  82. package/contextual-menu/types.js +5 -0
  83. package/date-input/Calendar.js +13 -57
  84. package/date-input/DateInput.accessibility.test.js +216 -0
  85. package/date-input/DateInput.js +50 -96
  86. package/date-input/DateInput.stories.tsx +11 -30
  87. package/date-input/DateInput.test.js +674 -701
  88. package/date-input/DatePicker.js +11 -42
  89. package/date-input/Icons.d.ts +6 -6
  90. package/date-input/Icons.js +6 -23
  91. package/date-input/YearPicker.js +8 -34
  92. package/date-input/types.d.ts +28 -22
  93. package/dialog/Dialog.accessibility.test.js +69 -0
  94. package/dialog/Dialog.js +13 -40
  95. package/dialog/Dialog.stories.tsx +170 -0
  96. package/dialog/Dialog.test.js +126 -188
  97. package/dialog/types.d.ts +18 -13
  98. package/divider/Divider.accessibility.test.js +33 -0
  99. package/divider/Divider.d.ts +4 -0
  100. package/divider/Divider.js +36 -0
  101. package/divider/Divider.stories.tsx +223 -0
  102. package/divider/Divider.test.js +38 -0
  103. package/divider/types.d.ts +21 -0
  104. package/divider/types.js +5 -0
  105. package/dropdown/Dropdown.accessibility.test.js +180 -0
  106. package/dropdown/Dropdown.js +59 -128
  107. package/dropdown/Dropdown.stories.tsx +5 -16
  108. package/dropdown/Dropdown.test.js +391 -378
  109. package/dropdown/DropdownMenu.js +8 -19
  110. package/dropdown/DropdownMenuItem.js +11 -20
  111. package/dropdown/types.d.ts +20 -24
  112. package/file-input/FileInput.accessibility.test.js +160 -0
  113. package/file-input/FileInput.js +180 -284
  114. package/file-input/FileInput.stories.tsx +1 -1
  115. package/file-input/FileInput.test.js +279 -354
  116. package/file-input/FileItem.js +25 -66
  117. package/file-input/types.d.ts +9 -9
  118. package/flex/Flex.js +25 -39
  119. package/flex/types.d.ts +6 -6
  120. package/footer/Footer.accessibility.test.js +117 -0
  121. package/footer/Footer.d.ts +1 -1
  122. package/footer/Footer.js +43 -68
  123. package/footer/Footer.stories.tsx +54 -9
  124. package/footer/Footer.test.js +18 -32
  125. package/footer/Icons.d.ts +3 -2
  126. package/footer/Icons.js +66 -7
  127. package/footer/types.d.ts +17 -17
  128. package/grid/Grid.js +1 -16
  129. package/grid/types.d.ts +10 -10
  130. package/header/Header.accessibility.test.js +84 -0
  131. package/header/Header.d.ts +1 -1
  132. package/header/Header.js +28 -84
  133. package/header/Header.test.js +12 -25
  134. package/header/Icons.d.ts +2 -2
  135. package/header/Icons.js +2 -7
  136. package/header/types.d.ts +7 -8
  137. package/heading/Heading.accessibility.test.js +33 -0
  138. package/heading/Heading.js +9 -31
  139. package/heading/Heading.test.js +70 -87
  140. package/heading/types.d.ts +7 -7
  141. package/icon/Icon.accessibility.test.js +30 -0
  142. package/icon/Icon.d.ts +4 -0
  143. package/icon/Icon.js +33 -0
  144. package/icon/Icon.stories.tsx +28 -0
  145. package/icon/types.d.ts +4 -0
  146. package/icon/types.js +5 -0
  147. package/image/Image.accessibility.test.js +56 -0
  148. package/image/Image.d.ts +2 -2
  149. package/image/Image.js +17 -32
  150. package/image/Image.stories.tsx +3 -1
  151. package/image/types.d.ts +2 -2
  152. package/inset/Inset.js +13 -21
  153. package/inset/types.d.ts +2 -2
  154. package/layout/ApplicationLayout.d.ts +2 -2
  155. package/layout/ApplicationLayout.js +26 -66
  156. package/layout/ApplicationLayout.stories.tsx +1 -1
  157. package/layout/Icons.d.ts +8 -5
  158. package/layout/Icons.js +49 -59
  159. package/layout/types.d.ts +3 -3
  160. package/link/Link.accessibility.test.js +112 -0
  161. package/link/Link.js +28 -47
  162. package/link/Link.stories.tsx +2 -2
  163. package/link/Link.test.js +23 -41
  164. package/link/types.d.ts +14 -14
  165. package/main.d.ts +7 -4
  166. package/main.js +32 -60
  167. package/nav-tabs/NavTabs.accessibility.test.js +52 -0
  168. package/nav-tabs/NavTabs.d.ts +1 -2
  169. package/nav-tabs/NavTabs.js +19 -48
  170. package/nav-tabs/NavTabs.stories.tsx +7 -5
  171. package/nav-tabs/NavTabs.test.js +38 -44
  172. package/nav-tabs/NavTabsContext.d.ts +3 -0
  173. package/nav-tabs/NavTabsContext.js +8 -0
  174. package/nav-tabs/Tab.js +24 -52
  175. package/nav-tabs/types.d.ts +9 -9
  176. package/number-input/NumberInput.accessibility.test.js +228 -0
  177. package/number-input/NumberInput.d.ts +0 -7
  178. package/number-input/NumberInput.js +47 -39
  179. package/number-input/NumberInput.stories.tsx +42 -26
  180. package/number-input/NumberInput.test.js +839 -575
  181. package/number-input/NumberInputContext.d.ts +3 -0
  182. package/number-input/NumberInputContext.js +8 -0
  183. package/number-input/types.d.ts +17 -5
  184. package/package.json +39 -37
  185. package/paginator/Icons.d.ts +5 -5
  186. package/paginator/Icons.js +5 -19
  187. package/paginator/Paginator.accessibility.test.js +79 -0
  188. package/paginator/Paginator.js +15 -43
  189. package/paginator/Paginator.test.js +224 -207
  190. package/paginator/types.d.ts +3 -3
  191. package/paragraph/Paragraph.accessibility.test.js +28 -0
  192. package/paragraph/Paragraph.js +3 -19
  193. package/paragraph/Paragraph.stories.tsx +0 -17
  194. package/password-input/Icons.d.ts +3 -3
  195. package/password-input/Icons.js +1 -5
  196. package/password-input/PasswordInput.accessibility.test.js +153 -0
  197. package/password-input/PasswordInput.js +26 -48
  198. package/password-input/PasswordInput.stories.tsx +1 -34
  199. package/password-input/PasswordInput.test.js +153 -129
  200. package/password-input/types.d.ts +8 -7
  201. package/progress-bar/ProgressBar.accessibility.test.js +35 -0
  202. package/progress-bar/ProgressBar.js +21 -53
  203. package/progress-bar/{ProgressBar.stories.jsx → ProgressBar.stories.tsx} +1 -1
  204. package/progress-bar/ProgressBar.test.js +35 -52
  205. package/progress-bar/types.d.ts +3 -3
  206. package/quick-nav/QuickNav.accessibility.test.js +57 -0
  207. package/quick-nav/QuickNav.js +4 -27
  208. package/quick-nav/QuickNav.stories.tsx +1 -1
  209. package/quick-nav/types.d.ts +10 -10
  210. package/radio-group/Radio.d.ts +1 -1
  211. package/radio-group/Radio.js +22 -54
  212. package/radio-group/RadioGroup.accessibility.test.js +97 -0
  213. package/radio-group/RadioGroup.js +37 -83
  214. package/radio-group/RadioGroup.stories.tsx +10 -10
  215. package/radio-group/RadioGroup.test.js +504 -470
  216. package/radio-group/types.d.ts +8 -8
  217. package/resultset-table/Icons.d.ts +7 -0
  218. package/{resultsetTable → resultset-table}/Icons.js +1 -5
  219. package/resultset-table/ResultsetTable.accessibility.test.js +274 -0
  220. package/resultset-table/ResultsetTable.d.ts +7 -0
  221. package/{resultsetTable → resultset-table}/ResultsetTable.js +44 -69
  222. package/{resultsetTable → resultset-table}/ResultsetTable.stories.tsx +106 -5
  223. package/{resultsetTable → resultset-table}/ResultsetTable.test.js +148 -92
  224. package/{resultsetTable → resultset-table}/types.d.ts +44 -11
  225. package/resultset-table/types.js +5 -0
  226. package/select/Icons.d.ts +7 -7
  227. package/select/Icons.js +1 -5
  228. package/select/Listbox.js +13 -39
  229. package/select/Option.js +17 -27
  230. package/select/Select.accessibility.test.js +217 -0
  231. package/select/Select.js +87 -163
  232. package/select/Select.stories.tsx +3 -4
  233. package/select/Select.test.js +1946 -1804
  234. package/select/types.d.ts +14 -15
  235. package/sidenav/Icons.d.ts +4 -4
  236. package/sidenav/Icons.js +1 -5
  237. package/sidenav/Sidenav.accessibility.test.js +59 -0
  238. package/sidenav/Sidenav.js +29 -70
  239. package/sidenav/Sidenav.stories.tsx +0 -1
  240. package/sidenav/Sidenav.test.js +3 -10
  241. package/{layout → sidenav}/SidenavContext.d.ts +1 -1
  242. package/{layout → sidenav}/SidenavContext.js +3 -9
  243. package/sidenav/types.d.ts +18 -18
  244. package/slider/Slider.accessibility.test.js +104 -0
  245. package/slider/Slider.js +68 -125
  246. package/slider/Slider.test.js +107 -103
  247. package/slider/types.d.ts +4 -4
  248. package/spinner/Spinner.accessibility.test.js +96 -0
  249. package/spinner/Spinner.js +16 -54
  250. package/spinner/Spinner.test.js +25 -34
  251. package/spinner/types.d.ts +3 -3
  252. package/status-light/StatusLight.accessibility.test.js +157 -0
  253. package/status-light/StatusLight.d.ts +4 -0
  254. package/status-light/StatusLight.js +51 -0
  255. package/status-light/StatusLight.stories.tsx +74 -0
  256. package/status-light/StatusLight.test.js +25 -0
  257. package/status-light/types.d.ts +17 -0
  258. package/status-light/types.js +5 -0
  259. package/switch/Switch.accessibility.test.js +89 -0
  260. package/switch/Switch.js +49 -97
  261. package/switch/Switch.stories.tsx +0 -34
  262. package/switch/Switch.test.js +51 -96
  263. package/switch/types.d.ts +4 -4
  264. package/table/DropdownTheme.js +62 -0
  265. package/table/Table.accessibility.test.js +82 -0
  266. package/table/Table.d.ts +6 -2
  267. package/table/Table.js +76 -33
  268. package/table/{Table.stories.jsx → Table.stories.tsx} +297 -2
  269. package/table/Table.test.js +93 -6
  270. package/table/types.d.ts +34 -6
  271. package/tabs/Tab.js +17 -33
  272. package/tabs/Tabs.accessibility.test.js +56 -0
  273. package/tabs/Tabs.js +52 -129
  274. package/tabs/Tabs.stories.tsx +1 -1
  275. package/tabs/Tabs.test.js +62 -118
  276. package/tabs/types.d.ts +19 -19
  277. package/tag/Tag.accessibility.test.js +69 -0
  278. package/tag/Tag.js +21 -51
  279. package/tag/Tag.test.js +19 -30
  280. package/tag/types.d.ts +7 -7
  281. package/text-input/Suggestion.js +9 -26
  282. package/text-input/Suggestions.d.ts +1 -1
  283. package/text-input/Suggestions.js +19 -67
  284. package/text-input/TextInput.accessibility.test.js +321 -0
  285. package/text-input/TextInput.js +197 -287
  286. package/text-input/TextInput.stories.tsx +49 -153
  287. package/text-input/TextInput.test.js +1227 -1194
  288. package/text-input/types.d.ts +25 -17
  289. package/textarea/Textarea.accessibility.test.js +155 -0
  290. package/textarea/Textarea.js +67 -109
  291. package/textarea/{Textarea.stories.jsx → Textarea.stories.tsx} +58 -100
  292. package/textarea/Textarea.test.js +150 -179
  293. package/textarea/types.d.ts +9 -5
  294. package/toggle-group/ToggleGroup.accessibility.test.js +107 -0
  295. package/toggle-group/ToggleGroup.js +21 -61
  296. package/toggle-group/ToggleGroup.stories.tsx +4 -4
  297. package/toggle-group/ToggleGroup.test.js +48 -81
  298. package/toggle-group/types.d.ts +10 -10
  299. package/typography/Typography.accessibility.test.js +339 -0
  300. package/typography/Typography.js +4 -13
  301. package/typography/types.d.ts +1 -1
  302. package/useTheme.d.ts +41 -136
  303. package/useTheme.js +1 -8
  304. package/useTranslatedLabels.js +1 -7
  305. package/utils/BaseTypography.d.ts +2 -2
  306. package/utils/BaseTypography.js +16 -30
  307. package/utils/FocusLock.js +25 -39
  308. package/wizard/Wizard.accessibility.test.js +55 -0
  309. package/wizard/Wizard.js +14 -49
  310. package/wizard/Wizard.test.js +53 -80
  311. package/wizard/types.d.ts +7 -7
  312. package/common/OpenSans.css +0 -69
  313. package/common/fonts/OpenSans-Bold.ttf +0 -0
  314. package/common/fonts/OpenSans-BoldItalic.ttf +0 -0
  315. package/common/fonts/OpenSans-ExtraBold.ttf +0 -0
  316. package/common/fonts/OpenSans-ExtraBoldItalic.ttf +0 -0
  317. package/common/fonts/OpenSans-Italic.ttf +0 -0
  318. package/common/fonts/OpenSans-Light.ttf +0 -0
  319. package/common/fonts/OpenSans-LightItalic.ttf +0 -0
  320. package/common/fonts/OpenSans-Regular.ttf +0 -0
  321. package/common/fonts/OpenSans-SemiBold.ttf +0 -0
  322. package/common/fonts/OpenSans-SemiBoldItalic.ttf +0 -0
  323. package/resultsetTable/Icons.d.ts +0 -7
  324. package/resultsetTable/ResultsetTable.d.ts +0 -4
  325. package/slider/Slider.stories.tsx +0 -240
  326. package/text-input/Icons.d.ts +0 -8
  327. package/text-input/Icons.js +0 -60
  328. /package/{resultsetTable → action-icon}/types.js +0 -0
  329. /package/spinner/{Spinner.stories.jsx → Spinner.stories.tsx} +0 -0
@@ -0,0 +1,3 @@
1
+ /// <reference types="react" />
2
+ import { NumberInputContextProps } from "./types";
3
+ export declare const NumberInputContext: import("react").Context<NumberInputContextProps>;
@@ -0,0 +1,8 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.NumberInputContext = void 0;
7
+ var _react = require("react");
8
+ var NumberInputContext = exports.NumberInputContext = /*#__PURE__*/(0, _react.createContext)(null);
@@ -1,11 +1,11 @@
1
- declare type Space = "xxsmall" | "xsmall" | "small" | "medium" | "large" | "xlarge" | "xxlarge";
2
- declare type Margin = {
1
+ type Space = "xxsmall" | "xsmall" | "small" | "medium" | "large" | "xlarge" | "xxlarge";
2
+ type Margin = {
3
3
  top?: Space;
4
4
  bottom?: Space;
5
5
  left?: Space;
6
6
  right?: Space;
7
7
  };
8
- declare type Props = {
8
+ type Props = {
9
9
  /**
10
10
  * Text to be placed above the number.
11
11
  */
@@ -35,12 +35,18 @@ declare type Props = {
35
35
  */
36
36
  disabled?: boolean;
37
37
  /**
38
- * If true, the number will be optional, showing '(Optional)'
38
+ * If true, the number will be optional, showing the text '(Optional)'
39
39
  * next to the label. Otherwise, the field will be considered required
40
40
  * and an error will be passed as a parameter to the OnBlur and onChange
41
41
  * functions when it has not been filled.
42
42
  */
43
43
  optional?: boolean;
44
+ /**
45
+ * If true, the component will not be mutable, meaning the user can
46
+ * not edit the control. The value won't change when pressing on the
47
+ * up or down arrows and neither on the spin buttons.
48
+ */
49
+ readOnly?: boolean;
44
50
  /**
45
51
  * Prefix to be placed before the number value.
46
52
  */
@@ -117,8 +123,14 @@ declare type Props = {
117
123
  */
118
124
  tabIndex?: number;
119
125
  };
126
+ export type NumberInputContextProps = {
127
+ typeNumber?: string;
128
+ minNumber?: number;
129
+ maxNumber?: number;
130
+ stepNumber?: number;
131
+ };
120
132
  /**
121
133
  * Reference to the component.
122
134
  */
123
- export declare type RefType = HTMLDivElement;
135
+ export type RefType = HTMLDivElement;
124
136
  export default Props;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@dxc-technology/halstack-react",
3
- "version": "0.0.0-bd47c58",
3
+ "version": "0.0.0-bdaadec",
4
4
  "description": "DXC Halstack React components library",
5
5
  "repository": "dxc-technology/halstack-react",
6
6
  "homepage": "https://developer.dxc.com/halstack",
@@ -18,68 +18,70 @@
18
18
  "styled-components": "^5.0.1"
19
19
  },
20
20
  "dependencies": {
21
- "@radix-ui/react-popover": "0.1.6",
22
- "@types/styled-components": "^5.1.24",
23
- "@types/uuid": "^8.3.4",
21
+ "@radix-ui/react-popover": "^1.0.7",
24
22
  "color": "^3.1.3",
25
23
  "dayjs": "^1.11.1",
26
24
  "slugify": "^1.6.5",
27
25
  "uuid": "^8.3.2"
28
26
  },
29
27
  "scripts": {
30
- "test": "jest --env=jsdom",
28
+ "test": "jest --env=jsdom --config=./jest.config.js",
29
+ "test:accessibility": "jest --env=jsdom --config=./jest.config.accessibility.js",
31
30
  "test:watch": "npm test -- --watch --coverage",
32
31
  "build": "babel src --extensions .js,.jsx,.ts,.tsx --out-dir ../dist --copy-files --verbose && node ../scripts/build/copy-package.js && node ../scripts/build/copy-readme.js && tsc ",
33
32
  "build:watch": "babel src --watch --extensions .js,.jsx,.ts,.tsx --out-dir ../dist --copy-files --verbose",
34
- "storybook": "start-storybook -p 6006",
35
- "build-storybook": "build-storybook"
33
+ "storybook": "storybook dev -p 6006",
34
+ "storybook:accessibility": "test-storybook",
35
+ "storybook:accessibility:ci": "test-storybook --maxWorkers=2",
36
+ "build-storybook": "storybook build"
36
37
  },
37
38
  "devDependencies": {
38
39
  "@babel/cli": "^7.16.8",
39
- "@babel/core": "^7.16.7",
40
+ "@babel/core": "^7.24.0",
40
41
  "@babel/plugin-proposal-nullish-coalescing-operator": "^7.13.8",
41
42
  "@babel/plugin-proposal-optional-chaining": "^7.13.8",
42
43
  "@babel/plugin-transform-runtime": "^7.16.8",
43
44
  "@babel/preset-env": "^7.16.8",
44
45
  "@babel/preset-react": "^7.16.7",
45
46
  "@babel/preset-typescript": "^7.16.7",
46
- "@storybook/addon-actions": "^6.4.9",
47
- "@storybook/addon-essentials": "^6.4.9",
48
- "@storybook/addon-links": "^6.4.9",
49
- "@storybook/react": "^6.4.9",
50
- "@storybook/testing-library": "0.0.7",
47
+ "@storybook/addon-a11y": "^7.6.17",
48
+ "@storybook/addon-essentials": "^7.5.3",
49
+ "@storybook/addon-interactions": "^7.5.3",
50
+ "@storybook/addon-links": "^7.5.3",
51
+ "@storybook/blocks": "^7.5.3",
52
+ "@storybook/react": "^7.5.3",
53
+ "@storybook/react-vite": "^7.5.3",
54
+ "@storybook/test-runner": "^0.16.0",
55
+ "@storybook/testing-library": "^0.2.2",
51
56
  "@testing-library/react": "^13.0.0",
52
57
  "@testing-library/user-event": "^13.0.0",
53
58
  "@types/color": "^3.0.3",
54
59
  "@types/react": "^18.0.18",
60
+ "@types/styled-components": "5.1.29",
61
+ "@types/uuid": "^9.0.6",
62
+ "axe-playwright": "^2.0.1",
55
63
  "babel-jest": "^24.8.0",
56
64
  "babel-loader": "^8.0.6",
57
- "chromatic": "^6.3.3",
58
- "eslint": "^5.16.0",
59
- "eslint-config-airbnb": "^17.1.0",
60
- "eslint-config-prettier": "^6.7.0",
61
- "eslint-plugin-import": "^2.17.3",
62
- "eslint-plugin-jest": "^22.7.1",
63
- "eslint-plugin-jsx-a11y": "^6.2.1",
64
- "eslint-plugin-react": "^7.13.0",
65
- "eslint-plugin-react-hooks": "^4.2.0",
66
- "eslint-plugin-storybook": "^0.5.5",
65
+ "chromatic": "^8.0.0",
66
+ "eslint": "^8.53.0",
67
+ "eslint-config-airbnb": "^19.0.4",
68
+ "eslint-config-prettier": "^9.0.0",
69
+ "eslint-plugin-import": "^2.29.0",
70
+ "eslint-plugin-jest": "^27.6.0",
71
+ "eslint-plugin-jsx-a11y": "^6.8.0",
72
+ "eslint-plugin-react": "^7.33.2",
73
+ "eslint-plugin-react-hooks": "^4.6.0",
74
+ "eslint-plugin-storybook": "^0.6.15",
67
75
  "identity-obj-proxy": "^3.0.0",
68
- "jest": "^29.2.2",
76
+ "jest": "^29.7.0",
77
+ "jest-axe": "^8.0.0",
69
78
  "jest-environment-jsdom": "^29.3.1",
70
- "react": "^18.x",
71
- "react-dom": "^18.x",
72
- "react-test-renderer": "^16.8.6",
73
- "storybook-addon-pseudo-states": "^1.0.0",
79
+ "playwright": "^1.41.2",
80
+ "react": "^18.2.0",
81
+ "react-dom": "^18.2.0",
82
+ "storybook": "^7.5.3",
83
+ "storybook-addon-pseudo-states": "^2.1.2",
74
84
  "styled-components": "^5.0.1",
75
- "typescript": "^4.5.4"
76
- },
77
- "jest": {
78
- "moduleNameMapper": {
79
- "\\.(css|less|scss|sass)$": "identity-obj-proxy",
80
- "\\.(svg)$": "<rootDir>/test/mocks/svgMock.js",
81
- "\\.(png)$": "<rootDir>/test/mocks/pngMock.js",
82
- "^uuid$": "uuid"
83
- }
85
+ "typescript": "^5.3.3"
84
86
  }
85
87
  }
@@ -1,5 +1,5 @@
1
- /// <reference types="react" />
2
- export declare const firstIcon: JSX.Element;
3
- export declare const previousIcon: JSX.Element;
4
- export declare const nextIcon: JSX.Element;
5
- export declare const lastIcon: JSX.Element;
1
+ import React from "react";
2
+ export declare const firstIcon: React.JSX.Element;
3
+ export declare const previousIcon: React.JSX.Element;
4
+ export declare const nextIcon: React.JSX.Element;
5
+ export declare const lastIcon: React.JSX.Element;
@@ -1,15 +1,12 @@
1
1
  "use strict";
2
2
 
3
3
  var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
-
5
4
  Object.defineProperty(exports, "__esModule", {
6
5
  value: true
7
6
  });
8
7
  exports.previousIcon = exports.nextIcon = exports.lastIcon = exports.firstIcon = void 0;
9
-
10
8
  var _react = _interopRequireDefault(require("react"));
11
-
12
- var firstIcon = /*#__PURE__*/_react["default"].createElement("svg", {
9
+ var firstIcon = exports.firstIcon = /*#__PURE__*/_react["default"].createElement("svg", {
13
10
  xmlns: "http://www.w3.org/2000/svg",
14
11
  height: "24",
15
12
  width: "24",
@@ -17,10 +14,7 @@ var firstIcon = /*#__PURE__*/_react["default"].createElement("svg", {
17
14
  }, /*#__PURE__*/_react["default"].createElement("path", {
18
15
  d: "M6 18V6h2v12Zm11 0-6-6 6-6 1.4 1.4-4.6 4.6 4.6 4.6Z"
19
16
  }));
20
-
21
- exports.firstIcon = firstIcon;
22
-
23
- var previousIcon = /*#__PURE__*/_react["default"].createElement("svg", {
17
+ var previousIcon = exports.previousIcon = /*#__PURE__*/_react["default"].createElement("svg", {
24
18
  xmlns: "http://www.w3.org/2000/svg",
25
19
  height: "24",
26
20
  width: "24",
@@ -28,10 +22,7 @@ var previousIcon = /*#__PURE__*/_react["default"].createElement("svg", {
28
22
  }, /*#__PURE__*/_react["default"].createElement("path", {
29
23
  d: "m14 18-6-6 6-6 1.4 1.4-4.6 4.6 4.6 4.6Z"
30
24
  }));
31
-
32
- exports.previousIcon = previousIcon;
33
-
34
- var nextIcon = /*#__PURE__*/_react["default"].createElement("svg", {
25
+ var nextIcon = exports.nextIcon = /*#__PURE__*/_react["default"].createElement("svg", {
35
26
  xmlns: "http://www.w3.org/2000/svg",
36
27
  height: "24",
37
28
  width: "24",
@@ -39,16 +30,11 @@ var nextIcon = /*#__PURE__*/_react["default"].createElement("svg", {
39
30
  }, /*#__PURE__*/_react["default"].createElement("path", {
40
31
  d: "M9.4 18 8 16.6l4.6-4.6L8 7.4 9.4 6l6 6Z"
41
32
  }));
42
-
43
- exports.nextIcon = nextIcon;
44
-
45
- var lastIcon = /*#__PURE__*/_react["default"].createElement("svg", {
33
+ var lastIcon = exports.lastIcon = /*#__PURE__*/_react["default"].createElement("svg", {
46
34
  xmlns: "http://www.w3.org/2000/svg",
47
35
  height: "24",
48
36
  width: "24",
49
37
  fill: "currentColor"
50
38
  }, /*#__PURE__*/_react["default"].createElement("path", {
51
39
  d: "m7 18-1.4-1.4 4.6-4.6-4.6-4.6L7 6l6 6Zm9 0V6h2v12Z"
52
- }));
53
-
54
- exports.lastIcon = lastIcon;
40
+ }));
@@ -0,0 +1,79 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+ var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator"));
5
+ var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator"));
6
+ var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
7
+ var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
8
+ var _react = _interopRequireDefault(require("react"));
9
+ var _react2 = require("@testing-library/react");
10
+ var _jestAxe = require("jest-axe");
11
+ var _Paginator = _interopRequireDefault(require("./Paginator.tsx"));
12
+ // Mocking DOMRect for Radix Primitive Popover
13
+ global.globalThis = global;
14
+ global.DOMRect = {
15
+ fromRect: function fromRect() {
16
+ return {
17
+ top: 0,
18
+ left: 0,
19
+ bottom: 0,
20
+ right: 0,
21
+ width: 0,
22
+ height: 0
23
+ };
24
+ }
25
+ };
26
+ global.ResizeObserver = /*#__PURE__*/function () {
27
+ function ResizeObserver() {
28
+ (0, _classCallCheck2["default"])(this, ResizeObserver);
29
+ }
30
+ (0, _createClass2["default"])(ResizeObserver, [{
31
+ key: "observe",
32
+ value: function observe() {}
33
+ }, {
34
+ key: "unobserve",
35
+ value: function unobserve() {}
36
+ }, {
37
+ key: "disconnect",
38
+ value: function disconnect() {}
39
+ }]);
40
+ return ResizeObserver;
41
+ }();
42
+ global.DOMRect = {
43
+ fromRect: function fromRect() {
44
+ return {
45
+ top: 0,
46
+ left: 0,
47
+ bottom: 0,
48
+ right: 0,
49
+ width: 0,
50
+ height: 0
51
+ };
52
+ }
53
+ };
54
+ describe("Paginator component accessibility tests", function () {
55
+ it("Should not have basic accessibility issues", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee() {
56
+ var _render, container, results;
57
+ return _regenerator["default"].wrap(function _callee$(_context) {
58
+ while (1) switch (_context.prev = _context.next) {
59
+ case 0:
60
+ _render = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Paginator["default"], {
61
+ currentPage: 1,
62
+ itemsPerPage: 10,
63
+ totalItems: 27,
64
+ onPageChange: function onPageChange() {},
65
+ itemsPerPageOptions: [5, 10, 15],
66
+ showGoToPage: true
67
+ })), container = _render.container;
68
+ _context.next = 3;
69
+ return (0, _jestAxe.axe)(container);
70
+ case 3:
71
+ results = _context.sent;
72
+ expect(results).toHaveNoViolations();
73
+ case 5:
74
+ case "end":
75
+ return _context.stop();
76
+ }
77
+ }, _callee);
78
+ })));
79
+ });
@@ -1,51 +1,35 @@
1
1
  "use strict";
2
2
 
3
3
  var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
-
5
4
  var _typeof = require("@babel/runtime/helpers/typeof");
6
-
7
5
  Object.defineProperty(exports, "__esModule", {
8
6
  value: true
9
7
  });
10
8
  exports["default"] = void 0;
11
-
12
9
  var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
13
-
14
10
  var _react = _interopRequireDefault(require("react"));
15
-
16
11
  var _styledComponents = _interopRequireWildcard(require("styled-components"));
17
-
18
12
  var _useTheme = _interopRequireDefault(require("../useTheme"));
19
-
20
13
  var _useTranslatedLabels = _interopRequireDefault(require("../useTranslatedLabels"));
21
-
22
14
  var _Button = _interopRequireDefault(require("../button/Button"));
23
-
24
15
  var _Select = _interopRequireDefault(require("../select/Select"));
25
-
26
16
  var _Icons = require("./Icons");
27
-
28
- var _BackgroundColorContext = require("../BackgroundColorContext");
29
-
30
17
  var _templateObject, _templateObject2, _templateObject3, _templateObject4, _templateObject5, _templateObject6, _templateObject7, _templateObject8;
31
-
32
- function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
33
-
34
- function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { "default": obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj["default"] = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
35
-
18
+ function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(e) { return e ? t : r; })(e); }
19
+ function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != _typeof(e) && "function" != typeof e) return { "default": e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && Object.prototype.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n["default"] = e, t && t.set(e, n), n; }
36
20
  var DxcPaginator = function DxcPaginator(_ref) {
37
21
  var _ref$currentPage = _ref.currentPage,
38
- currentPage = _ref$currentPage === void 0 ? 1 : _ref$currentPage,
39
- _ref$itemsPerPage = _ref.itemsPerPage,
40
- itemsPerPage = _ref$itemsPerPage === void 0 ? 5 : _ref$itemsPerPage,
41
- itemsPerPageOptions = _ref.itemsPerPageOptions,
42
- _ref$totalItems = _ref.totalItems,
43
- totalItems = _ref$totalItems === void 0 ? 1 : _ref$totalItems,
44
- showGoToPage = _ref.showGoToPage,
45
- onPageChange = _ref.onPageChange,
46
- itemsPerPageFunction = _ref.itemsPerPageFunction,
47
- _ref$tabIndex = _ref.tabIndex,
48
- tabIndex = _ref$tabIndex === void 0 ? 0 : _ref$tabIndex;
22
+ currentPage = _ref$currentPage === void 0 ? 1 : _ref$currentPage,
23
+ _ref$itemsPerPage = _ref.itemsPerPage,
24
+ itemsPerPage = _ref$itemsPerPage === void 0 ? 5 : _ref$itemsPerPage,
25
+ itemsPerPageOptions = _ref.itemsPerPageOptions,
26
+ _ref$totalItems = _ref.totalItems,
27
+ totalItems = _ref$totalItems === void 0 ? 1 : _ref$totalItems,
28
+ showGoToPage = _ref.showGoToPage,
29
+ onPageChange = _ref.onPageChange,
30
+ itemsPerPageFunction = _ref.itemsPerPageFunction,
31
+ _ref$tabIndex = _ref.tabIndex,
32
+ tabIndex = _ref$tabIndex === void 0 ? 0 : _ref$tabIndex;
49
33
  var totalPages = itemsPerPage > 0 && Math.ceil(totalItems / itemsPerPage);
50
34
  var currentPageInternal = currentPage === -1 ? totalPages : currentPage;
51
35
  var minItemsPerPage = currentPageInternal === 1 || currentPageInternal === 0 ? currentPageInternal : (currentPageInternal - 1) * itemsPerPage + 1;
@@ -54,8 +38,6 @@ var DxcPaginator = function DxcPaginator(_ref) {
54
38
  var translatedLabels = (0, _useTranslatedLabels["default"])();
55
39
  return /*#__PURE__*/_react["default"].createElement(_styledComponents.ThemeProvider, {
56
40
  theme: colorsTheme.paginator
57
- }, /*#__PURE__*/_react["default"].createElement(_BackgroundColorContext.BackgroundColorProvider, {
58
- color: colorsTheme.paginator.backgroundColor
59
41
  }, /*#__PURE__*/_react["default"].createElement(DxcPaginatorContainer, null, /*#__PURE__*/_react["default"].createElement(LabelsContainer, null, itemsPerPageOptions && /*#__PURE__*/_react["default"].createElement(ItemsPageContainer, null, /*#__PURE__*/_react["default"].createElement(ItemsLabel, null, translatedLabels.paginator.itemsPerPageText), /*#__PURE__*/_react["default"].createElement(SelectContainer, null, /*#__PURE__*/_react["default"].createElement(_Select["default"], {
60
42
  options: itemsPerPageOptions.map(function (num) {
61
43
  return {
@@ -114,9 +96,8 @@ var DxcPaginator = function DxcPaginator(_ref) {
114
96
  onClick: function onClick() {
115
97
  onPageChange(totalPages);
116
98
  }
117
- })))));
99
+ }))));
118
100
  };
119
-
120
101
  var DxcPaginatorContainer = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n font-family: ", ";\n font-size: ", ";\n font-weight: ", ";\n font-style: ", ";\n text-transform: ", ";\n background-color: ", ";\n color: ", ";\n padding: ", " ", ";\n\n button {\n &:disabled {\n background-color: transparent !important;\n opacity: 0.3 !important;\n }\n }\n"])), function (props) {
121
102
  return props.theme.fontFamily;
122
103
  }, function (props) {
@@ -136,28 +117,19 @@ var DxcPaginatorContainer = _styledComponents["default"].div(_templateObject ||
136
117
  }, function (props) {
137
118
  return props.theme.horizontalPadding;
138
119
  });
139
-
140
120
  var SelectContainer = _styledComponents["default"].div(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n min-width: 5.25rem;\n"])));
141
-
142
121
  var ItemsPageContainer = _styledComponents["default"].span(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n align-items: center;\n margin-right: ", ";\n margin-left: ", ";\n"])), function (props) {
143
122
  return props.theme.itemsPerPageSelectorMarginRight;
144
123
  }, function (props) {
145
124
  return props.theme.itemsPerPageSelectorMarginLeft;
146
125
  });
147
-
148
126
  var ItemsLabel = _styledComponents["default"].span(_templateObject4 || (_templateObject4 = (0, _taggedTemplateLiteral2["default"])(["\n margin-right: 0.5rem;\n"])));
149
-
150
127
  var GoToLabel = _styledComponents["default"].span(_templateObject5 || (_templateObject5 = (0, _taggedTemplateLiteral2["default"])(["\n margin-right: 0.5rem;\n margin-left: 0.5rem;\n"])));
151
-
152
128
  var TotalItemsContainer = _styledComponents["default"].span(_templateObject6 || (_templateObject6 = (0, _taggedTemplateLiteral2["default"])(["\n margin-right: ", ";\n margin-left: ", ";\n"])), function (props) {
153
129
  return props.theme.totalItemsContainerMarginRight;
154
130
  }, function (props) {
155
131
  return props.theme.totalItemsContainerMarginLeft;
156
132
  });
157
-
158
133
  var LabelsContainer = _styledComponents["default"].div(_templateObject7 || (_templateObject7 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n gap: 0.5rem;\n width: 100%;\n justify-content: flex-end;\n align-items: center;\n"])));
159
-
160
134
  var PageToSelectContainer = _styledComponents["default"].span(_templateObject8 || (_templateObject8 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n align-items: center;\n margin-right: 0.5rem;\n"])));
161
-
162
- var _default = DxcPaginator;
163
- exports["default"] = _default;
135
+ var _default = exports["default"] = DxcPaginator;