@dxc-technology/halstack-react 0.0.0-c9c1158 → 0.0.0-c9efd3e

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 (216) hide show
  1. package/BackgroundColorContext.d.ts +1 -10
  2. package/BackgroundColorContext.js +2 -7
  3. package/HalstackContext.d.ts +29 -133
  4. package/HalstackContext.js +1 -1
  5. package/accordion/Accordion.accessibility.test.js +71 -0
  6. package/accordion/Accordion.js +10 -26
  7. package/accordion/Accordion.stories.tsx +4 -36
  8. package/accordion/types.d.ts +1 -1
  9. package/accordion-group/AccordionGroup.accessibility.test.js +88 -0
  10. package/accordion-group/AccordionGroup.d.ts +2 -3
  11. package/accordion-group/AccordionGroup.js +3 -3
  12. package/accordion-group/AccordionGroupAccordion.js +2 -2
  13. package/accordion-group/AccordionGroupContext.d.ts +3 -0
  14. package/accordion-group/AccordionGroupContext.js +8 -0
  15. package/accordion-group/types.d.ts +1 -1
  16. package/action-icon/ActionIcon.accessibility.test.js +63 -0
  17. package/action-icon/ActionIcon.d.ts +4 -0
  18. package/action-icon/ActionIcon.js +48 -0
  19. package/action-icon/ActionIcon.stories.tsx +41 -0
  20. package/action-icon/ActionIcon.test.js +64 -0
  21. package/action-icon/types.d.ts +26 -0
  22. package/action-icon/types.js +5 -0
  23. package/alert/Alert.accessibility.test.js +95 -0
  24. package/alert/Alert.js +15 -72
  25. package/badge/Badge.accessibility.test.js +129 -0
  26. package/badge/Badge.d.ts +1 -1
  27. package/badge/Badge.js +141 -28
  28. package/badge/Badge.stories.tsx +210 -0
  29. package/badge/Badge.test.js +30 -0
  30. package/badge/types.d.ts +52 -3
  31. package/box/Box.accessibility.test.js +33 -0
  32. package/box/Box.js +1 -4
  33. package/bulleted-list/BulletedList.accessibility.test.js +107 -0
  34. package/bulleted-list/BulletedList.js +15 -22
  35. package/bulleted-list/BulletedList.stories.tsx +1 -2
  36. package/button/Button.accessibility.test.js +127 -0
  37. package/button/Button.js +15 -15
  38. package/button/Button.stories.tsx +32 -51
  39. package/button/Button.test.js +3 -1
  40. package/button/types.d.ts +1 -1
  41. package/card/Card.accessibility.test.js +36 -0
  42. package/checkbox/Checkbox.accessibility.test.js +87 -0
  43. package/checkbox/Checkbox.js +26 -31
  44. package/chip/Chip.accessibility.test.js +67 -0
  45. package/chip/Chip.js +8 -5
  46. package/chip/Chip.stories.tsx +5 -24
  47. package/chip/Chip.test.js +4 -4
  48. package/common/coreTokens.d.ts +1 -1
  49. package/common/coreTokens.js +3 -3
  50. package/common/variables.d.ts +29 -133
  51. package/common/variables.js +38 -142
  52. package/container/Container.js +3 -7
  53. package/container/Container.stories.tsx +10 -25
  54. package/contextual-menu/ContextualMenu.accessibility.test.js +86 -0
  55. package/contextual-menu/ContextualMenu.d.ts +7 -0
  56. package/contextual-menu/ContextualMenu.js +71 -0
  57. package/contextual-menu/ContextualMenu.stories.tsx +182 -0
  58. package/contextual-menu/ContextualMenu.test.js +71 -0
  59. package/contextual-menu/MenuItemAction.d.ts +4 -0
  60. package/contextual-menu/MenuItemAction.js +46 -0
  61. package/contextual-menu/types.d.ts +22 -0
  62. package/contextual-menu/types.js +5 -0
  63. package/date-input/DateInput.accessibility.test.js +216 -0
  64. package/date-input/types.d.ts +2 -2
  65. package/dialog/Dialog.accessibility.test.js +69 -0
  66. package/dialog/Dialog.js +2 -5
  67. package/dialog/Dialog.stories.tsx +170 -0
  68. package/dialog/Dialog.test.js +1 -1
  69. package/divider/Divider.accessibility.test.js +33 -0
  70. package/divider/Divider.d.ts +4 -0
  71. package/divider/Divider.js +36 -0
  72. package/divider/Divider.stories.tsx +223 -0
  73. package/divider/Divider.test.js +38 -0
  74. package/divider/types.d.ts +21 -0
  75. package/divider/types.js +5 -0
  76. package/dropdown/Dropdown.accessibility.test.js +180 -0
  77. package/dropdown/Dropdown.js +21 -36
  78. package/dropdown/Dropdown.stories.tsx +5 -16
  79. package/dropdown/DropdownMenuItem.js +6 -3
  80. package/dropdown/types.d.ts +3 -5
  81. package/file-input/FileInput.accessibility.test.js +160 -0
  82. package/file-input/FileInput.js +3 -39
  83. package/file-input/FileInput.test.js +7 -84
  84. package/file-input/FileItem.js +13 -27
  85. package/footer/Footer.accessibility.test.js +117 -0
  86. package/footer/Footer.d.ts +1 -1
  87. package/footer/Footer.js +36 -31
  88. package/footer/Footer.stories.tsx +46 -2
  89. package/footer/Icons.d.ts +1 -0
  90. package/footer/Icons.js +65 -1
  91. package/footer/types.d.ts +8 -8
  92. package/header/Header.accessibility.test.js +84 -0
  93. package/header/Header.js +18 -40
  94. package/header/types.d.ts +4 -3
  95. package/heading/Heading.accessibility.test.js +33 -0
  96. package/icon/Icon.accessibility.test.js +30 -0
  97. package/icon/Icon.d.ts +4 -0
  98. package/icon/Icon.js +33 -0
  99. package/icon/Icon.stories.tsx +28 -0
  100. package/icon/types.d.ts +4 -0
  101. package/icon/types.js +5 -0
  102. package/image/Image.accessibility.test.js +56 -0
  103. package/image/Image.stories.tsx +3 -1
  104. package/layout/ApplicationLayout.d.ts +1 -1
  105. package/layout/ApplicationLayout.js +1 -1
  106. package/layout/Icons.js +0 -2
  107. package/link/Link.accessibility.test.js +112 -0
  108. package/link/Link.js +7 -5
  109. package/link/Link.stories.tsx +2 -2
  110. package/link/types.d.ts +1 -1
  111. package/main.d.ts +5 -3
  112. package/main.js +22 -8
  113. package/nav-tabs/NavTabs.accessibility.test.js +52 -0
  114. package/nav-tabs/NavTabs.d.ts +1 -2
  115. package/nav-tabs/NavTabs.js +9 -6
  116. package/nav-tabs/NavTabs.stories.tsx +6 -4
  117. package/nav-tabs/NavTabs.test.js +3 -2
  118. package/nav-tabs/NavTabsContext.d.ts +3 -0
  119. package/nav-tabs/NavTabsContext.js +8 -0
  120. package/nav-tabs/Tab.js +8 -7
  121. package/number-input/NumberInput.accessibility.test.js +228 -0
  122. package/number-input/NumberInput.d.ts +0 -7
  123. package/number-input/NumberInput.js +24 -5
  124. package/number-input/NumberInput.test.js +165 -6
  125. package/number-input/NumberInputContext.d.ts +3 -0
  126. package/number-input/NumberInputContext.js +8 -0
  127. package/number-input/types.d.ts +6 -0
  128. package/package.json +12 -12
  129. package/paginator/Paginator.accessibility.test.js +79 -0
  130. package/paginator/Paginator.js +1 -4
  131. package/paragraph/Paragraph.accessibility.test.js +28 -0
  132. package/paragraph/Paragraph.js +2 -7
  133. package/password-input/PasswordInput.accessibility.test.js +153 -0
  134. package/password-input/PasswordInput.stories.tsx +0 -1
  135. package/progress-bar/ProgressBar.accessibility.test.js +35 -0
  136. package/progress-bar/ProgressBar.js +5 -11
  137. package/quick-nav/QuickNav.accessibility.test.js +57 -0
  138. package/radio-group/RadioGroup.accessibility.test.js +97 -0
  139. package/radio-group/RadioGroup.js +1 -1
  140. package/resultset-table/ResultsetTable.accessibility.test.js +274 -0
  141. package/resultset-table/ResultsetTable.d.ts +4 -1
  142. package/resultset-table/ResultsetTable.js +23 -12
  143. package/resultset-table/ResultsetTable.stories.tsx +106 -5
  144. package/resultset-table/ResultsetTable.test.js +76 -0
  145. package/resultset-table/types.d.ts +40 -7
  146. package/select/Option.js +8 -1
  147. package/select/Select.accessibility.test.js +217 -0
  148. package/select/Select.js +35 -27
  149. package/select/Select.stories.tsx +0 -1
  150. package/select/Select.test.js +498 -462
  151. package/select/types.d.ts +2 -2
  152. package/sidenav/Sidenav.accessibility.test.js +59 -0
  153. package/sidenav/Sidenav.js +20 -18
  154. package/sidenav/Sidenav.stories.tsx +4 -9
  155. package/sidenav/types.d.ts +2 -2
  156. package/slider/Slider.accessibility.test.js +104 -0
  157. package/slider/Slider.js +37 -46
  158. package/spinner/Spinner.accessibility.test.js +96 -0
  159. package/spinner/Spinner.js +6 -14
  160. package/status-light/StatusLight.accessibility.test.js +157 -0
  161. package/status-light/StatusLight.d.ts +4 -0
  162. package/status-light/StatusLight.js +51 -0
  163. package/status-light/StatusLight.stories.tsx +74 -0
  164. package/status-light/StatusLight.test.js +25 -0
  165. package/status-light/types.d.ts +17 -0
  166. package/status-light/types.js +5 -0
  167. package/switch/Switch.accessibility.test.js +89 -0
  168. package/switch/Switch.js +23 -28
  169. package/table/DropdownTheme.js +62 -0
  170. package/table/Table.accessibility.test.js +82 -0
  171. package/table/Table.d.ts +6 -2
  172. package/table/Table.js +73 -11
  173. package/table/Table.stories.tsx +297 -2
  174. package/table/Table.test.js +92 -0
  175. package/table/types.d.ts +28 -0
  176. package/tabs/Tab.js +7 -4
  177. package/tabs/Tabs.accessibility.test.js +56 -0
  178. package/tabs/Tabs.js +4 -5
  179. package/tabs/Tabs.stories.tsx +1 -1
  180. package/tag/Tag.accessibility.test.js +69 -0
  181. package/tag/Tag.js +6 -6
  182. package/tag/Tag.stories.tsx +4 -7
  183. package/tag/Tag.test.js +4 -12
  184. package/tag/types.d.ts +2 -2
  185. package/text-input/Suggestions.js +7 -10
  186. package/text-input/TextInput.accessibility.test.js +321 -0
  187. package/text-input/TextInput.js +77 -102
  188. package/text-input/TextInput.stories.tsx +1 -1
  189. package/text-input/TextInput.test.js +96 -79
  190. package/textarea/Textarea.accessibility.test.js +155 -0
  191. package/textarea/Textarea.js +10 -16
  192. package/textarea/Textarea.stories.tsx +0 -1
  193. package/toggle-group/ToggleGroup.accessibility.test.js +107 -0
  194. package/toggle-group/ToggleGroup.js +1 -4
  195. package/typography/Typography.accessibility.test.js +339 -0
  196. package/useTheme.d.ts +29 -133
  197. package/utils/FocusLock.js +15 -5
  198. package/wizard/Wizard.accessibility.test.js +55 -0
  199. package/wizard/types.d.ts +1 -1
  200. package/common/OpenSans.css +0 -69
  201. package/common/fonts/OpenSans-Bold.ttf +0 -0
  202. package/common/fonts/OpenSans-BoldItalic.ttf +0 -0
  203. package/common/fonts/OpenSans-ExtraBold.ttf +0 -0
  204. package/common/fonts/OpenSans-ExtraBoldItalic.ttf +0 -0
  205. package/common/fonts/OpenSans-Italic.ttf +0 -0
  206. package/common/fonts/OpenSans-Light.ttf +0 -0
  207. package/common/fonts/OpenSans-LightItalic.ttf +0 -0
  208. package/common/fonts/OpenSans-Regular.ttf +0 -0
  209. package/common/fonts/OpenSans-SemiBold.ttf +0 -0
  210. package/common/fonts/OpenSans-SemiBoldItalic.ttf +0 -0
  211. package/sidenav/Icons.d.ts +0 -7
  212. package/sidenav/Icons.js +0 -47
  213. package/text-input/Icons.d.ts +0 -8
  214. package/text-input/Icons.js +0 -56
  215. /package/{layout → sidenav}/SidenavContext.d.ts +0 -0
  216. /package/{layout → sidenav}/SidenavContext.js +0 -0
package/main.js CHANGED
@@ -5,12 +5,6 @@ var _typeof = require("@babel/runtime/helpers/typeof");
5
5
  Object.defineProperty(exports, "__esModule", {
6
6
  value: true
7
7
  });
8
- Object.defineProperty(exports, "BackgroundColorProvider", {
9
- enumerable: true,
10
- get: function get() {
11
- return _BackgroundColorContext.BackgroundColorProvider;
12
- }
13
- });
14
8
  Object.defineProperty(exports, "DxcAccordion", {
15
9
  enumerable: true,
16
10
  get: function get() {
@@ -89,6 +83,12 @@ Object.defineProperty(exports, "DxcContainer", {
89
83
  return _Container["default"];
90
84
  }
91
85
  });
86
+ Object.defineProperty(exports, "DxcContextualMenu", {
87
+ enumerable: true,
88
+ get: function get() {
89
+ return _ContextualMenu["default"];
90
+ }
91
+ });
92
92
  Object.defineProperty(exports, "DxcDateInput", {
93
93
  enumerable: true,
94
94
  get: function get() {
@@ -101,6 +101,12 @@ Object.defineProperty(exports, "DxcDialog", {
101
101
  return _Dialog["default"];
102
102
  }
103
103
  });
104
+ Object.defineProperty(exports, "DxcDivider", {
105
+ enumerable: true,
106
+ get: function get() {
107
+ return _Divider["default"];
108
+ }
109
+ });
104
110
  Object.defineProperty(exports, "DxcDropdown", {
105
111
  enumerable: true,
106
112
  get: function get() {
@@ -221,6 +227,12 @@ Object.defineProperty(exports, "DxcSpinner", {
221
227
  return _Spinner["default"];
222
228
  }
223
229
  });
230
+ Object.defineProperty(exports, "DxcStatusLight", {
231
+ enumerable: true,
232
+ get: function get() {
233
+ return _StatusLight["default"];
234
+ }
235
+ });
224
236
  Object.defineProperty(exports, "DxcSwitch", {
225
237
  enumerable: true,
226
238
  get: function get() {
@@ -317,7 +329,6 @@ var _Chip = _interopRequireDefault(require("./chip/Chip"));
317
329
  var _ApplicationLayout = _interopRequireDefault(require("./layout/ApplicationLayout"));
318
330
  var _ToggleGroup = _interopRequireDefault(require("./toggle-group/ToggleGroup"));
319
331
  var _AccordionGroup = _interopRequireDefault(require("./accordion-group/AccordionGroup"));
320
- var _Badge = _interopRequireDefault(require("./badge/Badge"));
321
332
  var _TextInput = _interopRequireDefault(require("./text-input/TextInput"));
322
333
  var _PasswordInput = _interopRequireDefault(require("./password-input/PasswordInput"));
323
334
  var _DateInput = _interopRequireDefault(require("./date-input/DateInput"));
@@ -337,7 +348,10 @@ var _BulletedList = _interopRequireDefault(require("./bulleted-list/BulletedList
337
348
  var _Grid = _interopRequireDefault(require("./grid/Grid"));
338
349
  var _Image = _interopRequireDefault(require("./image/Image"));
339
350
  var _Container = _interopRequireDefault(require("./container/Container"));
351
+ var _Badge = _interopRequireDefault(require("./badge/Badge"));
352
+ var _StatusLight = _interopRequireDefault(require("./status-light/StatusLight"));
353
+ var _ContextualMenu = _interopRequireDefault(require("./contextual-menu/ContextualMenu"));
354
+ var _Divider = _interopRequireDefault(require("./divider/Divider"));
340
355
  var _HalstackContext = _interopRequireWildcard(require("./HalstackContext"));
341
- var _BackgroundColorContext = require("./BackgroundColorContext");
342
356
  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); }
343
357
  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; }
@@ -0,0 +1,52 @@
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 _react = _interopRequireDefault(require("react"));
7
+ var _react2 = require("@testing-library/react");
8
+ var _jestAxe = require("jest-axe");
9
+ var _NavTabs = _interopRequireDefault(require("./NavTabs.tsx"));
10
+ var iconSVG = /*#__PURE__*/_react["default"].createElement("svg", {
11
+ viewBox: "0 0 24 24",
12
+ fill: "currentColor"
13
+ }, /*#__PURE__*/_react["default"].createElement("path", {
14
+ d: "M0 0h24v24H0z",
15
+ fill: "none"
16
+ }), /*#__PURE__*/_react["default"].createElement("path", {
17
+ d: "M12 21.35l-1.45-1.32C5.4 15.36 2 12.28 2 8.5 2 5.42 4.42 3 7.5 3c1.74 0 3.41.81 4.5 2.09C13.09 3.81 14.76 3 16.5 3 19.58 3 22 5.42 22 8.5c0 3.78-3.4 6.86-8.55 11.54L12 21.35z"
18
+ }));
19
+ var largeIcon = "https://www.iconpacks.net/icons/1/free-pin-icon-48-thumb.png";
20
+ describe("Tabs component accessibility tests", function () {
21
+ it("Should not have basic accessibility issues", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee() {
22
+ var _render, container, results;
23
+ return _regenerator["default"].wrap(function _callee$(_context) {
24
+ while (1) switch (_context.prev = _context.next) {
25
+ case 0:
26
+ _render = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_NavTabs["default"], {
27
+ iconPosition: "left"
28
+ }, /*#__PURE__*/_react["default"].createElement(_NavTabs["default"].Tab, {
29
+ href: "/test1",
30
+ icon: iconSVG,
31
+ active: true
32
+ }, "Tab 1"), /*#__PURE__*/_react["default"].createElement(_NavTabs["default"].Tab, {
33
+ href: "/test2",
34
+ icon: iconSVG,
35
+ disabled: true
36
+ }, "Tab 2"), /*#__PURE__*/_react["default"].createElement(_NavTabs["default"].Tab, {
37
+ href: "/test3",
38
+ icon: largeIcon,
39
+ notificationNumber: 12
40
+ }, "Tab 3"))), container = _render.container;
41
+ _context.next = 3;
42
+ return (0, _jestAxe.axe)(container);
43
+ case 3:
44
+ results = _context.sent;
45
+ expect(results).toHaveNoViolations();
46
+ case 5:
47
+ case "end":
48
+ return _context.stop();
49
+ }
50
+ }, _callee);
51
+ })));
52
+ });
@@ -1,6 +1,5 @@
1
1
  import React from "react";
2
- import NavTabsPropsType, { NavTabsContextProps } from "./types";
3
- export declare const NavTabsContext: React.Context<NavTabsContextProps>;
2
+ import NavTabsPropsType from "./types";
4
3
  declare const DxcNavTabs: {
5
4
  ({ iconPosition, tabIndex, children }: NavTabsPropsType): JSX.Element;
6
5
  Tab: React.ForwardRefExoticComponent<import("./types").TabProps & React.RefAttributes<HTMLAnchorElement>>;
@@ -5,17 +5,17 @@ var _typeof = require("@babel/runtime/helpers/typeof");
5
5
  Object.defineProperty(exports, "__esModule", {
6
6
  value: true
7
7
  });
8
- exports["default"] = exports.NavTabsContext = void 0;
8
+ exports["default"] = void 0;
9
9
  var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
10
10
  var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
11
11
  var _react = _interopRequireWildcard(require("react"));
12
12
  var _styledComponents = _interopRequireWildcard(require("styled-components"));
13
13
  var _useTheme = _interopRequireDefault(require("../useTheme"));
14
14
  var _Tab = _interopRequireDefault(require("./Tab"));
15
- var _templateObject;
15
+ var _NavTabsContext = require("./NavTabsContext");
16
+ var _templateObject, _templateObject2;
16
17
  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); }
17
18
  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; }
18
- var NavTabsContext = exports.NavTabsContext = /*#__PURE__*/(0, _react.createContext)(null);
19
19
  var getPropInChild = function getPropInChild(child, propName) {
20
20
  return child.props ? child.props[propName] ? child.props[propName] : child.props.children ? getPropInChild(child.props.children, propName) : undefined : undefined;
21
21
  };
@@ -81,10 +81,13 @@ var DxcNavTabs = function DxcNavTabs(_ref) {
81
81
  onKeyDown: handleOnKeyDown,
82
82
  role: "tablist",
83
83
  "aria-label": "Navigation tabs"
84
- }, /*#__PURE__*/_react["default"].createElement(NavTabsContext.Provider, {
84
+ }, /*#__PURE__*/_react["default"].createElement(_NavTabsContext.NavTabsContext.Provider, {
85
85
  value: contextValue
86
- }, children)));
86
+ }, children), /*#__PURE__*/_react["default"].createElement(Underline, null)));
87
87
  };
88
+ var Underline = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n position: absolute;\n bottom: 0;\n left: 0;\n width: 100%;\n height: 2px;\n background-color: ", ";\n"])), function (props) {
89
+ return props.theme.dividerColor;
90
+ });
88
91
  DxcNavTabs.Tab = _Tab["default"];
89
- var NavTabsContainer = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n"])));
92
+ var NavTabsContainer = _styledComponents["default"].div(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n position: relative;\n"])));
90
93
  var _default = exports["default"] = DxcNavTabs;
@@ -91,7 +91,9 @@ export const Chromatic = () => (
91
91
  <DxcNavTabs.Tab href="#" notificationNumber={120}>
92
92
  Tab 3
93
93
  </DxcNavTabs.Tab>
94
- <DxcNavTabs.Tab href="#">Tab 4</DxcNavTabs.Tab>
94
+ <DxcNavTabs.Tab href="#" notificationNumber={12}>
95
+ Tab 4
96
+ </DxcNavTabs.Tab>
95
97
  </DxcNavTabs>
96
98
  </ExampleContainer>
97
99
  <ExampleContainer>
@@ -140,7 +142,7 @@ export const Chromatic = () => (
140
142
  <DxcNavTabs.Tab href="#" icon={iconSVG} notificationNumber={120}>
141
143
  Tab 3
142
144
  </DxcNavTabs.Tab>
143
- <DxcNavTabs.Tab href="#" icon={largeIcon}>
145
+ <DxcNavTabs.Tab href="#" icon={largeIcon} notificationNumber={12}>
144
146
  Tab 4
145
147
  </DxcNavTabs.Tab>
146
148
  </DxcNavTabs>
@@ -157,7 +159,7 @@ export const Chromatic = () => (
157
159
  <DxcNavTabs.Tab href="#" icon={largeIcon} notificationNumber={120}>
158
160
  Tab 3
159
161
  </DxcNavTabs.Tab>
160
- <DxcNavTabs.Tab href="#" icon={iconSVG}>
162
+ <DxcNavTabs.Tab href="#" icon={iconSVG} notificationNumber={12}>
161
163
  Tab 4
162
164
  </DxcNavTabs.Tab>
163
165
  </DxcNavTabs>
@@ -264,7 +266,7 @@ export const Chromatic = () => (
264
266
  <DxcNavTabs.Tab href="#" icon={iconSVG} notificationNumber={120}>
265
267
  Tab 3
266
268
  </DxcNavTabs.Tab>
267
- <DxcNavTabs.Tab href="#" icon={iconSVG}>
269
+ <DxcNavTabs.Tab href="#" icon={iconSVG} notificationNumber={12}>
268
270
  Tab 4
269
271
  </DxcNavTabs.Tab>
270
272
  </DxcNavTabs>
@@ -49,9 +49,10 @@ describe("Tabs component tests", function () {
49
49
  icon: "/testIcon.png"
50
50
  }, "Tab 3"))),
51
51
  getByText = _render2.getByText,
52
- getByRole = _render2.getByRole;
52
+ getByRole = _render2.getByRole,
53
+ queryByText = _render2.queryByText;
53
54
  expect(getByText("10")).toBeTruthy();
54
- expect(getByText("20")).toBeTruthy();
55
+ expect(queryByText("20")).toBeFalsy();
55
56
  expect(getByText("+99")).toBeTruthy();
56
57
  expect(getByRole("img")).toBeTruthy();
57
58
  });
@@ -0,0 +1,3 @@
1
+ /// <reference types="react" />
2
+ import { NavTabsContextProps } from "./types";
3
+ export declare const NavTabsContext: import("react").Context<NavTabsContextProps>;
@@ -0,0 +1,8 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.NavTabsContext = void 0;
7
+ var _react = require("react");
8
+ var NavTabsContext = exports.NavTabsContext = /*#__PURE__*/(0, _react.createContext)(null);
package/nav-tabs/Tab.js CHANGED
@@ -13,9 +13,9 @@ var _react = _interopRequireWildcard(require("react"));
13
13
  var _styledComponents = _interopRequireDefault(require("styled-components"));
14
14
  var _Badge = _interopRequireDefault(require("../badge/Badge"));
15
15
  var _Flex = _interopRequireDefault(require("../flex/Flex"));
16
- var _NavTabs = require("./NavTabs");
17
16
  var _BaseTypography = _interopRequireDefault(require("../utils/BaseTypography"));
18
17
  var _useTheme = _interopRequireDefault(require("../useTheme"));
18
+ var _NavTabsContext = require("./NavTabsContext");
19
19
  var _templateObject, _templateObject2, _templateObject3;
20
20
  var _excluded = ["href", "active", "icon", "disabled", "notificationNumber", "children"];
21
21
  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); }
@@ -33,7 +33,7 @@ var DxcTab = /*#__PURE__*/(0, _react.forwardRef)(function (_ref, _ref2) {
33
33
  otherProps = (0, _objectWithoutProperties2["default"])(_ref, _excluded);
34
34
  var tabRef = (0, _react.useRef)();
35
35
  var colorsTheme = (0, _useTheme["default"])();
36
- var _useContext = (0, _react.useContext)(_NavTabs.NavTabsContext),
36
+ var _useContext = (0, _react.useContext)(_NavTabsContext.NavTabsContext),
37
37
  iconPosition = _useContext.iconPosition,
38
38
  tabIndex = _useContext.tabIndex,
39
39
  focusedLabel = _useContext.focusedLabel;
@@ -86,13 +86,14 @@ var DxcTab = /*#__PURE__*/(0, _react.forwardRef)(function (_ref, _ref2) {
86
86
  textAlign: "center",
87
87
  letterSpacing: "0.025em",
88
88
  lineHeight: "1.715em"
89
- }, children), notificationNumber && /*#__PURE__*/_react["default"].createElement(_Badge["default"], {
90
- notificationText: typeof notificationNumber === "number" && notificationNumber > 99 ? "+99" : notificationNumber,
91
- disabled: disabled
89
+ }, children), notificationNumber && !disabled && /*#__PURE__*/_react["default"].createElement(_Badge["default"], {
90
+ mode: "notification",
91
+ size: "small",
92
+ label: typeof notificationNumber === "number" && notificationNumber
92
93
  }))));
93
94
  });
94
- var TabContainer = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n align-items: stretch;\n border-bottom: 2px solid ", ";\n padding: 0.5rem;\n\n svg {\n color: ", ";\n }\n &[aria-selected=\"true\"] {\n svg {\n color: ", ";\n }\n }\n &[aria-disabled=\"true\"] {\n svg {\n color: ", ";\n }\n }\n"])), function (props) {
95
- return props.active ? props.theme.selectedUnderlineColor : props.theme.dividerColor;
95
+ var TabContainer = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n align-items: stretch;\n border-bottom: 2px solid ", ";\n padding: 0.5rem;\n z-index: 1;\n svg {\n color: ", ";\n }\n &[aria-selected=\"true\"] {\n svg {\n color: ", ";\n }\n }\n &[aria-disabled=\"true\"] {\n svg {\n color: ", ";\n }\n }\n"])), function (props) {
96
+ return props.active ? props.theme.selectedUnderlineColor : 'transparent';
96
97
  }, function (props) {
97
98
  return props.theme.unselectedIconColor;
98
99
  }, function (props) {
@@ -0,0 +1,228 @@
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 _NumberInput = _interopRequireDefault(require("./NumberInput.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
+ describe("Number input component accessibility tests", function () {
43
+ it("Should not have basic accessibility issues", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee() {
44
+ var _render, container, results;
45
+ return _regenerator["default"].wrap(function _callee$(_context) {
46
+ while (1) switch (_context.prev = _context.next) {
47
+ case 0:
48
+ _render = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_NumberInput["default"], {
49
+ label: "Number input label",
50
+ helperText: "Helper text",
51
+ placeholder: "Placeholder",
52
+ defaultValue: "10",
53
+ margin: "medium",
54
+ min: 0,
55
+ max: 100,
56
+ suffix: "Suffix",
57
+ prefix: "Prefix",
58
+ name: "Name",
59
+ size: "medium",
60
+ step: 1
61
+ })), container = _render.container;
62
+ _context.next = 3;
63
+ return (0, _jestAxe.axe)(container);
64
+ case 3:
65
+ results = _context.sent;
66
+ expect(results).toHaveNoViolations();
67
+ case 5:
68
+ case "end":
69
+ return _context.stop();
70
+ }
71
+ }, _callee);
72
+ })));
73
+ it("Should not have basic accessibility issues for optional mode", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee2() {
74
+ var _render2, container, results;
75
+ return _regenerator["default"].wrap(function _callee2$(_context2) {
76
+ while (1) switch (_context2.prev = _context2.next) {
77
+ case 0:
78
+ _render2 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_NumberInput["default"], {
79
+ label: "Number input label",
80
+ helperText: "Helper text",
81
+ placeholder: "Placeholder",
82
+ defaultValue: "10",
83
+ margin: "medium",
84
+ min: 0,
85
+ max: 100,
86
+ suffix: "Suffix",
87
+ prefix: "Prefix",
88
+ name: "Name",
89
+ size: "medium",
90
+ step: 1,
91
+ optional: true
92
+ })), container = _render2.container;
93
+ _context2.next = 3;
94
+ return (0, _jestAxe.axe)(container);
95
+ case 3:
96
+ results = _context2.sent;
97
+ expect(results).toHaveNoViolations();
98
+ case 5:
99
+ case "end":
100
+ return _context2.stop();
101
+ }
102
+ }, _callee2);
103
+ })));
104
+ it("Should not have basic accessibility issues for error mode", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee3() {
105
+ var _render3, container, results;
106
+ return _regenerator["default"].wrap(function _callee3$(_context3) {
107
+ while (1) switch (_context3.prev = _context3.next) {
108
+ case 0:
109
+ _render3 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_NumberInput["default"], {
110
+ label: "Number input label",
111
+ helperText: "Helper text",
112
+ placeholder: "Placeholder",
113
+ defaultValue: "10",
114
+ margin: "medium",
115
+ min: 0,
116
+ max: 100,
117
+ suffix: "Suffix",
118
+ prefix: "Prefix",
119
+ name: "Name",
120
+ error: "Input error",
121
+ size: "medium",
122
+ step: 1
123
+ })), container = _render3.container;
124
+ _context3.next = 3;
125
+ return (0, _jestAxe.axe)(container);
126
+ case 3:
127
+ results = _context3.sent;
128
+ expect(results).toHaveNoViolations();
129
+ case 5:
130
+ case "end":
131
+ return _context3.stop();
132
+ }
133
+ }, _callee3);
134
+ })));
135
+ it("Should not have basic accessibility issues for disabled mode", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee4() {
136
+ var _render4, container, results;
137
+ return _regenerator["default"].wrap(function _callee4$(_context4) {
138
+ while (1) switch (_context4.prev = _context4.next) {
139
+ case 0:
140
+ _render4 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_NumberInput["default"], {
141
+ label: "Number input label",
142
+ helperText: "Helper text",
143
+ placeholder: "Placeholder",
144
+ defaultValue: "10",
145
+ margin: "medium",
146
+ min: 0,
147
+ max: 100,
148
+ suffix: "Suffix",
149
+ prefix: "Prefix",
150
+ name: "Name",
151
+ size: "medium",
152
+ step: 1,
153
+ disabled: true
154
+ })), container = _render4.container;
155
+ _context4.next = 3;
156
+ return (0, _jestAxe.axe)(container);
157
+ case 3:
158
+ results = _context4.sent;
159
+ expect(results).toHaveNoViolations();
160
+ case 5:
161
+ case "end":
162
+ return _context4.stop();
163
+ }
164
+ }, _callee4);
165
+ })));
166
+ it("Should not have basic accessibility issues for read-only mode", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee5() {
167
+ var _render5, container, results;
168
+ return _regenerator["default"].wrap(function _callee5$(_context5) {
169
+ while (1) switch (_context5.prev = _context5.next) {
170
+ case 0:
171
+ _render5 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_NumberInput["default"], {
172
+ label: "Number input label",
173
+ helperText: "Helper text",
174
+ placeholder: "Placeholder",
175
+ defaultValue: "10",
176
+ margin: "medium",
177
+ min: 0,
178
+ max: 100,
179
+ suffix: "Suffix",
180
+ prefix: "Prefix",
181
+ name: "Name",
182
+ size: "medium",
183
+ step: 1,
184
+ readOnly: true
185
+ })), container = _render5.container;
186
+ _context5.next = 3;
187
+ return (0, _jestAxe.axe)(container);
188
+ case 3:
189
+ results = _context5.sent;
190
+ expect(results).toHaveNoViolations();
191
+ case 5:
192
+ case "end":
193
+ return _context5.stop();
194
+ }
195
+ }, _callee5);
196
+ })));
197
+ it("Should not have basic accessibility issues for autocomplete mode", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee6() {
198
+ var _render6, container, results;
199
+ return _regenerator["default"].wrap(function _callee6$(_context6) {
200
+ while (1) switch (_context6.prev = _context6.next) {
201
+ case 0:
202
+ _render6 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_NumberInput["default"], {
203
+ label: "Number input label",
204
+ helperText: "Helper text",
205
+ placeholder: "Placeholder",
206
+ defaultValue: "10",
207
+ margin: "medium",
208
+ min: 0,
209
+ max: 100,
210
+ suffix: "Suffix",
211
+ prefix: "Prefix",
212
+ name: "Name",
213
+ size: "medium",
214
+ step: 1,
215
+ autocomplete: "on"
216
+ })), container = _render6.container;
217
+ _context6.next = 3;
218
+ return (0, _jestAxe.axe)(container);
219
+ case 3:
220
+ results = _context6.sent;
221
+ expect(results).toHaveNoViolations();
222
+ case 5:
223
+ case "end":
224
+ return _context6.stop();
225
+ }
226
+ }, _callee6);
227
+ })));
228
+ });
@@ -1,11 +1,4 @@
1
1
  import React from "react";
2
2
  import NumberInputPropsType from "./types";
3
- type NumberInputContextProps = {
4
- typeNumber?: string;
5
- minNumber?: number;
6
- maxNumber?: number;
7
- stepNumber?: number;
8
- };
9
- export declare const NumberInputContext: React.Context<NumberInputContextProps>;
10
3
  declare const DxcNumberInput: React.ForwardRefExoticComponent<NumberInputPropsType & React.RefAttributes<HTMLDivElement>>;
11
4
  export default DxcNumberInput;
@@ -1,16 +1,19 @@
1
1
  "use strict";
2
2
 
3
3
  var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+ var _typeof = require("@babel/runtime/helpers/typeof");
4
5
  Object.defineProperty(exports, "__esModule", {
5
6
  value: true
6
7
  });
7
- exports["default"] = exports.NumberInputContext = void 0;
8
+ exports["default"] = void 0;
8
9
  var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
9
- var _react = _interopRequireDefault(require("react"));
10
+ var _react = _interopRequireWildcard(require("react"));
10
11
  var _styledComponents = _interopRequireDefault(require("styled-components"));
11
12
  var _TextInput = _interopRequireDefault(require("../text-input/TextInput"));
13
+ var _NumberInputContext = require("./NumberInputContext");
12
14
  var _templateObject;
13
- var NumberInputContext = exports.NumberInputContext = /*#__PURE__*/_react["default"].createContext(null);
15
+ 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); }
16
+ 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; }
14
17
  var DxcNumberInput = /*#__PURE__*/_react["default"].forwardRef(function (_ref, ref) {
15
18
  var label = _ref.label,
16
19
  name = _ref.name,
@@ -34,14 +37,30 @@ var DxcNumberInput = /*#__PURE__*/_react["default"].forwardRef(function (_ref, r
34
37
  margin = _ref.margin,
35
38
  size = _ref.size,
36
39
  tabIndex = _ref.tabIndex;
37
- return /*#__PURE__*/_react["default"].createElement(NumberInputContext.Provider, {
40
+ var numberInputRef = _react["default"].useRef(null);
41
+ (0, _react.useEffect)(function () {
42
+ var _numberInputRef$curre;
43
+ var input = (_numberInputRef$curre = numberInputRef.current) === null || _numberInputRef$curre === void 0 ? void 0 : _numberInputRef$curre.getElementsByTagName("input")[0];
44
+ var preventDefault = function preventDefault(event) {
45
+ event.preventDefault();
46
+ };
47
+ input === null || input === void 0 ? void 0 : input.addEventListener("wheel", preventDefault, {
48
+ passive: false
49
+ });
50
+ return function () {
51
+ input === null || input === void 0 ? void 0 : input.removeEventListener("wheel", preventDefault);
52
+ };
53
+ }, []);
54
+ return /*#__PURE__*/_react["default"].createElement(_NumberInputContext.NumberInputContext.Provider, {
38
55
  value: {
39
56
  typeNumber: "number",
40
57
  minNumber: min,
41
58
  maxNumber: max,
42
59
  stepNumber: step
43
60
  }
44
- }, /*#__PURE__*/_react["default"].createElement(NumberInputContainer, null, /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
61
+ }, /*#__PURE__*/_react["default"].createElement(NumberInputContainer, {
62
+ ref: numberInputRef
63
+ }, /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
45
64
  label: label,
46
65
  name: name,
47
66
  defaultValue: defaultValue,