@dxc-technology/halstack-react 0.0.0-bcc5ff3 → 0.0.0-bd364ae

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 (70) hide show
  1. package/HalstackContext.d.ts +4 -2
  2. package/HalstackContext.js +110 -58
  3. package/alert/Alert.js +4 -1
  4. package/badge/Badge.d.ts +1 -1
  5. package/badge/Badge.js +5 -3
  6. package/badge/types.d.ts +1 -0
  7. package/bleed/Bleed.js +1 -34
  8. package/bleed/Bleed.stories.tsx +31 -32
  9. package/bleed/types.d.ts +1 -1
  10. package/box/Box.js +22 -32
  11. package/card/Card.js +34 -36
  12. package/checkbox/Checkbox.js +4 -1
  13. package/common/variables.js +162 -68
  14. package/date-input/DateInput.js +5 -2
  15. package/file-input/FileInput.js +9 -6
  16. package/footer/Footer.js +7 -5
  17. package/header/Header.js +7 -4
  18. package/inset/Inset.js +1 -34
  19. package/inset/Inset.stories.tsx +32 -32
  20. package/inset/types.d.ts +1 -1
  21. package/layout/ApplicationLayout.d.ts +4 -3
  22. package/layout/ApplicationLayout.js +83 -102
  23. package/layout/ApplicationLayout.stories.tsx +14 -59
  24. package/layout/Icons.d.ts +5 -0
  25. package/layout/Icons.js +13 -2
  26. package/layout/SidenavContext.d.ts +5 -0
  27. package/layout/SidenavContext.js +19 -0
  28. package/layout/types.d.ts +5 -10
  29. package/link/Link.d.ts +2 -2
  30. package/link/Link.js +23 -49
  31. package/link/types.d.ts +2 -3
  32. package/main.d.ts +3 -3
  33. package/main.js +14 -8
  34. package/package.json +1 -1
  35. package/paginator/Paginator.js +17 -38
  36. package/password-input/PasswordInput.js +7 -4
  37. package/password-input/PasswordInput.test.js +1 -2
  38. package/progress-bar/ProgressBar.js +1 -1
  39. package/progress-bar/ProgressBar.stories.jsx +11 -11
  40. package/quick-nav/QuickNav.js +65 -17
  41. package/quick-nav/QuickNav.stories.tsx +2 -2
  42. package/quick-nav/types.d.ts +1 -1
  43. package/radio-group/Radio.js +1 -1
  44. package/radio-group/RadioGroup.js +8 -6
  45. package/select/Listbox.js +4 -1
  46. package/select/Select.js +37 -47
  47. package/select/Select.stories.tsx +14 -2
  48. package/select/Select.test.js +257 -194
  49. package/sidenav/Sidenav.d.ts +1 -1
  50. package/sidenav/Sidenav.js +20 -9
  51. package/spinner/Spinner.js +1 -1
  52. package/switch/Switch.js +4 -1
  53. package/tabs-nav/NavTabs.d.ts +8 -0
  54. package/tabs-nav/NavTabs.js +125 -0
  55. package/tabs-nav/NavTabs.stories.tsx +170 -0
  56. package/tabs-nav/NavTabs.test.js +82 -0
  57. package/tabs-nav/Tab.d.ts +4 -0
  58. package/tabs-nav/Tab.js +132 -0
  59. package/tabs-nav/types.d.ts +53 -0
  60. package/{radio → tabs-nav}/types.js +0 -0
  61. package/text-input/TextInput.js +19 -20
  62. package/textarea/Textarea.js +10 -19
  63. package/useTranslatedLabels.d.ts +2 -0
  64. package/useTranslatedLabels.js +20 -0
  65. package/wizard/Wizard.js +27 -25
  66. package/radio/Radio.d.ts +0 -4
  67. package/radio/Radio.js +0 -173
  68. package/radio/Radio.stories.tsx +0 -192
  69. package/radio/Radio.test.js +0 -71
  70. package/radio/types.d.ts +0 -54
@@ -0,0 +1,5 @@
1
+ /// <reference types="react" />
2
+ export declare const facebookLogo: JSX.Element;
3
+ export declare const twitterLogo: JSX.Element;
4
+ export declare const linkedinLogo: JSX.Element;
5
+ export declare const hamburgerIcon: JSX.Element;
package/layout/Icons.js CHANGED
@@ -5,7 +5,7 @@ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefau
5
5
  Object.defineProperty(exports, "__esModule", {
6
6
  value: true
7
7
  });
8
- exports.twitterLogo = exports.linkedinLogo = exports.facebookLogo = void 0;
8
+ exports.twitterLogo = exports.linkedinLogo = exports.hamburgerIcon = exports.facebookLogo = void 0;
9
9
 
10
10
  var _react = _interopRequireDefault(require("react"));
11
11
 
@@ -52,4 +52,15 @@ var linkedinLogo = /*#__PURE__*/_react["default"].createElement("svg", {
52
52
  d: "M414.41,24.123C398.333,8.042,378.963,0,356.315,0H82.228C59.58,0,40.21,8.042,24.126,24.123 C8.045,40.207,0.003,59.576,0.003,82.225v274.084c0,22.647,8.042,42.018,24.123,58.102c16.084,16.084,35.454,24.126,58.102,24.126 h274.084c22.648,0,42.018-8.042,58.095-24.126c16.084-16.084,24.126-35.454,24.126-58.102V82.225 C438.532,59.576,430.49,40.204,414.41,24.123z M133.618,367.157H67.666V169.016h65.952V367.157z M127.626,132.332 c-6.851,6.567-15.893,9.851-27.124,9.851h-0.288c-10.848,0-19.648-3.284-26.407-9.851c-6.76-6.567-10.138-14.703-10.138-24.41 c0-9.897,3.476-18.083,10.421-24.556c6.95-6.471,15.942-9.708,26.98-9.708c11.039,0,19.89,3.237,26.553,9.708 c6.661,6.473,10.088,14.659,10.277,24.556C137.899,117.625,134.477,125.761,127.626,132.332z M370.873,367.157h-65.952v-105.92 c0-29.879-11.036-44.823-33.116-44.823c-8.374,0-15.42,2.331-21.128,6.995c-5.715,4.661-9.996,10.324-12.847,16.991 c-1.335,3.422-1.999,8.75-1.999,15.981v110.775h-65.952c0.571-119.529,0.571-185.579,0-198.142h65.952v27.974 c13.867-21.681,33.558-32.544,59.101-32.544c22.84,0,41.21,7.52,55.104,22.554c13.895,15.037,20.841,37.214,20.841,66.519v113.64 H370.873z"
53
53
  })));
54
54
 
55
- exports.linkedinLogo = linkedinLogo;
55
+ exports.linkedinLogo = linkedinLogo;
56
+
57
+ var hamburgerIcon = /*#__PURE__*/_react["default"].createElement("svg", {
58
+ xmlns: "http://www.w3.org/2000/svg",
59
+ height: "24",
60
+ width: "24",
61
+ viewBox: "0 0 24 24"
62
+ }, /*#__PURE__*/_react["default"].createElement("path", {
63
+ d: "M3 18V16H21V18ZM3 13V11H21V13ZM3 8V6H21V8Z"
64
+ }));
65
+
66
+ exports.hamburgerIcon = hamburgerIcon;
@@ -0,0 +1,5 @@
1
+ /// <reference types="react" />
2
+ declare type SidenavContextType = (isSidenavVisible: boolean) => void;
3
+ export declare const SidenavContextProvider: import("react").Provider<SidenavContextType>;
4
+ export declare const useResponsiveSidenavVisibility: () => SidenavContextType;
5
+ export {};
@@ -0,0 +1,19 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.useResponsiveSidenavVisibility = exports.SidenavContextProvider = void 0;
7
+
8
+ var _react = require("react");
9
+
10
+ var SidenavContext = /*#__PURE__*/(0, _react.createContext)(null);
11
+ var SidenavContextProvider = SidenavContext.Provider;
12
+ exports.SidenavContextProvider = SidenavContextProvider;
13
+
14
+ var useResponsiveSidenavVisibility = function useResponsiveSidenavVisibility() {
15
+ var changeResponsiveSidenavVisibility = (0, _react.useContext)(SidenavContext);
16
+ return changeResponsiveSidenavVisibility;
17
+ };
18
+
19
+ exports.useResponsiveSidenavVisibility = useResponsiveSidenavVisibility;
package/layout/types.d.ts CHANGED
@@ -37,18 +37,13 @@ export declare type AppLayoutSidenavPropsType = {
37
37
  * The area inside the sidenav. This area can be used to render custom content.
38
38
  */
39
39
  children: React.ReactNode;
40
- /**
41
- * If false, the arrow button is hidden.
42
- * In lower resolutions the arrow will be always displayed.
43
- */
44
- displayArrow?: boolean;
45
- /**
46
- * Default action over the content of the page, overlay the content or push to the right ('push' | 'overlay').
47
- * In lower resolutions the mode will always be overlay.
48
- */
49
- mode: "push" | "overlay";
50
40
  };
51
41
  declare type AppLayoutPropsType = {
42
+ /**
43
+ * Text to be placed next to the hamburger button that toggles the
44
+ * visibility of the sidenav.
45
+ */
46
+ visibilityToggleLabel?: string;
52
47
  /**
53
48
  * The area inside the sidenav. This area can be used to render custom content.
54
49
  */
package/link/Link.d.ts CHANGED
@@ -1,4 +1,4 @@
1
- /// <reference types="react" />
1
+ import React from "react";
2
2
  import { LinkProps } from "./types";
3
- declare const DxcLink: ({ inheritColor, disabled, icon, iconPosition, href, newWindow, onClick, margin, tabIndex, children, }: LinkProps) => JSX.Element;
3
+ declare const DxcLink: React.ForwardRefExoticComponent<LinkProps & React.RefAttributes<HTMLAnchorElement>>;
4
4
  export default DxcLink;
package/link/Link.js CHANGED
@@ -13,7 +13,11 @@ var _typeof2 = _interopRequireDefault(require("@babel/runtime/helpers/typeof"));
13
13
 
14
14
  var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
15
15
 
16
- var _react = _interopRequireDefault(require("react"));
16
+ var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
17
+
18
+ var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties"));
19
+
20
+ var _react = _interopRequireWildcard(require("react"));
17
21
 
18
22
  var _styledComponents = _interopRequireWildcard(require("styled-components"));
19
23
 
@@ -21,7 +25,9 @@ var _variables = require("../common/variables.js");
21
25
 
22
26
  var _useTheme = _interopRequireDefault(require("../useTheme"));
23
27
 
24
- var _templateObject, _templateObject2, _templateObject3, _templateObject4, _templateObject5, _templateObject6;
28
+ var _templateObject, _templateObject2, _templateObject3;
29
+
30
+ var _excluded = ["inheritColor", "disabled", "icon", "iconPosition", "href", "newWindow", "onClick", "margin", "tabIndex", "children"];
25
31
 
26
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); }
27
33
 
@@ -31,14 +37,14 @@ var LinkContent = /*#__PURE__*/_react["default"].memo(function (_ref) {
31
37
  var iconPosition = _ref.iconPosition,
32
38
  icon = _ref.icon,
33
39
  children = _ref.children;
34
- return /*#__PURE__*/_react["default"].createElement(LinkText, null, iconPosition === "after" && children, icon && /*#__PURE__*/_react["default"].createElement(LinkIconContainer, {
40
+ return /*#__PURE__*/_react["default"].createElement(_react["default"].Fragment, null, iconPosition === "after" && children, icon && /*#__PURE__*/_react["default"].createElement(LinkIconContainer, {
35
41
  iconPosition: iconPosition
36
42
  }, typeof icon === "string" ? /*#__PURE__*/_react["default"].createElement(LinkIcon, {
37
43
  src: icon
38
44
  }) : icon), iconPosition === "before" && children);
39
45
  });
40
46
 
41
- var DxcLink = function DxcLink(_ref2) {
47
+ var DxcLink = /*#__PURE__*/(0, _react.forwardRef)(function (_ref2, ref) {
42
48
  var _ref2$inheritColor = _ref2.inheritColor,
43
49
  inheritColor = _ref2$inheritColor === void 0 ? false : _ref2$inheritColor,
44
50
  _ref2$disabled = _ref2.disabled,
@@ -54,35 +60,29 @@ var DxcLink = function DxcLink(_ref2) {
54
60
  margin = _ref2.margin,
55
61
  _ref2$tabIndex = _ref2.tabIndex,
56
62
  tabIndex = _ref2$tabIndex === void 0 ? 0 : _ref2$tabIndex,
57
- children = _ref2.children;
63
+ children = _ref2.children,
64
+ otherProps = (0, _objectWithoutProperties2["default"])(_ref2, _excluded);
58
65
  var colorsTheme = (0, _useTheme["default"])();
59
66
  return /*#__PURE__*/_react["default"].createElement(_styledComponents.ThemeProvider, {
60
67
  theme: colorsTheme.link
61
- }, /*#__PURE__*/_react["default"].createElement(LinkContainer, {
62
- margin: margin
63
- }, typeof children === "string" && (href || onClick) ? /*#__PURE__*/_react["default"].createElement(StyledLink, {
68
+ }, /*#__PURE__*/_react["default"].createElement(StyledLink, (0, _extends2["default"])({
64
69
  as: href ? "a" : "button",
65
70
  tabIndex: tabIndex,
66
71
  onClick: !disabled && onClick,
67
72
  href: !disabled && href ? href : undefined,
68
73
  target: href ? newWindow ? "_blank" : "_self" : undefined,
69
74
  disabled: disabled,
70
- inheritColor: inheritColor
71
- }, /*#__PURE__*/_react["default"].createElement(LinkContent, {
72
- iconPosition: iconPosition,
73
- icon: icon,
74
- children: children
75
- })) : /*#__PURE__*/_react["default"].createElement(CustomLinkContainer, {
76
- disabled: disabled,
77
- inheritColor: inheritColor
78
- }, /*#__PURE__*/_react["default"].createElement(LinkContent, {
75
+ inheritColor: inheritColor,
76
+ margin: margin,
77
+ ref: ref
78
+ }, otherProps), /*#__PURE__*/_react["default"].createElement(LinkContent, {
79
79
  iconPosition: iconPosition,
80
80
  icon: icon,
81
81
  children: children
82
- }))));
83
- };
82
+ })));
83
+ });
84
84
 
85
- var LinkContainer = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n display: inline-flex;\n margin: ", ";\n margin-top: ", ";\n margin-right: ", ";\n margin-bottom: ", ";\n margin-left: ", ";\n\n * {\n background: none;\n border: none;\n padding: 0;\n cursor: pointer;\n font-size: ", ";\n font-weight: ", ";\n font-style: ", ";\n font-family: ", ";\n text-decoration-color: transparent;\n }\n"])), function (props) {
85
+ var StyledLink = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n display: inline-flex;\n margin: ", ";\n margin-top: ", ";\n margin-right: ", ";\n margin-bottom: ", ";\n margin-left: ", ";\n\n background: none;\n border: none;\n padding: 0;\n cursor: pointer;\n font-size: ", ";\n font-weight: ", ";\n font-style: ", ";\n font-family: ", ";\n text-decoration-color: transparent;\n width: fit-content;\n\n ", "\n ", "\n color: ", ";\n ", "\n\n &:visited {\n color: ", ";\n &:hover {\n ", "\n }\n }\n &:hover {\n ", "\n }\n &:focus {\n border-radius: 2px;\n outline: 2px solid ", ";\n ", "\n }\n &:active {\n ", "\n }\n"])), function (props) {
86
86
  return props.margin && (0, _typeof2["default"])(props.margin) !== "object" ? _variables.spaces[props.margin] : "0px";
87
87
  }, function (props) {
88
88
  return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.top ? _variables.spaces[props.margin.top] : "";
@@ -100,9 +100,7 @@ var LinkContainer = _styledComponents["default"].div(_templateObject || (_templa
100
100
  return props.theme.fontStyle;
101
101
  }, function (props) {
102
102
  return props.theme.fontFamily;
103
- });
104
-
105
- var StyledLink = _styledComponents["default"].div(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n ", "\n ", "\n color: ", ";\n ", "\n\n &:visited {\n color: ", ";\n &:hover {\n ", "\n }\n }\n &:hover {\n ", "\n }\n &:focus {\n border-radius: 2px;\n outline: 2px solid ", ";\n ", "\n }\n &:active {\n ", "\n }\n"])), function (props) {
103
+ }, function (props) {
106
104
  return "padding-bottom: ".concat(props.theme.underlineSpacing, ";\n border-bottom: ").concat(props.theme.underlineThickness, " ").concat(props.theme.underlineStyle, " transparent;");
107
105
  }, function (props) {
108
106
  return props.disabled && "cursor: default;";
@@ -124,33 +122,9 @@ var StyledLink = _styledComponents["default"].div(_templateObject2 || (_template
124
122
  return "color: ".concat(props.theme.activeFontColor, " !important;\n border-bottom-color: ").concat(props.theme.activeUnderlineColor, " !important;");
125
123
  });
126
124
 
127
- var CustomLinkContainer = _styledComponents["default"].div(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n ", "\n ", "\n ", "\n\n * {\n color: ", ";\n }\n\n &:hover {\n * {\n color: ", ";\n }\n ", "\n }\n &:focus-within {\n * {\n outline: none;\n }\n border-radius: 2px;\n outline: 2px solid ", ";\n ", "\n }\n &:active {\n * {\n color: ", " !important;\n }\n ", "\n }\n"])), function (props) {
128
- return "padding-bottom: ".concat(props.theme.underlineSpacing, ";\n border-bottom: ").concat(props.theme.underlineThickness, " ").concat(props.theme.underlineStyle, " transparent;");
129
- }, function (props) {
130
- return props.disabled && "cursor: default;";
131
- }, function (props) {
132
- return props.disabled ? "pointer-events: none;" : "";
133
- }, function (props) {
134
- return props.inheritColor ? "inherit" : !props.disabled ? props.theme.fontColor : props.theme.disabledColor;
135
- }, function (props) {
136
- return props.theme.hoverFontColor;
137
- }, function (props) {
138
- return "border-bottom-color: ".concat(props.theme.hoverUnderlineColor, ";\n cursor: pointer;");
139
- }, function (props) {
140
- return props.theme.focusColor;
141
- }, function (props) {
142
- return props.disabled && "outline: none";
143
- }, function (props) {
144
- return props.theme.activeFontColor;
145
- }, function (props) {
146
- return "border-bottom-color: ".concat(props.theme.activeUnderlineColor, " !important;");
147
- });
148
-
149
- var LinkText = _styledComponents["default"].div(_templateObject4 || (_templateObject4 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n align-items: baseline;\n max-width: 100%;\n"])));
150
-
151
- var LinkIcon = _styledComponents["default"].img(_templateObject5 || (_templateObject5 = (0, _taggedTemplateLiteral2["default"])([""])));
125
+ var LinkIcon = _styledComponents["default"].img(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])([""])));
152
126
 
153
- var LinkIconContainer = _styledComponents["default"].div(_templateObject6 || (_templateObject6 = (0, _taggedTemplateLiteral2["default"])(["\n width: ", ";\n height: ", ";\n ", ";\n overflow: hidden;\n align-self: center;\n\n img,\n svg {\n height: 100%;\n width: 100%;\n }\n"])), function (props) {
127
+ var LinkIconContainer = _styledComponents["default"].div(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n width: ", ";\n height: ", ";\n ", ";\n overflow: hidden;\n align-self: center;\n\n img,\n svg {\n height: 100%;\n width: 100%;\n }\n"])), function (props) {
154
128
  return props.theme.iconSize;
155
129
  }, function (props) {
156
130
  return props.theme.iconSize;
package/link/types.d.ts CHANGED
@@ -43,10 +43,9 @@ export declare type LinkProps = {
43
43
  */
44
44
  tabIndex?: number;
45
45
  /**
46
- * Content of the link. To use the component with other libraries (such as React Router or Next.js Link) pass the custom link as a child.
47
- * The component will apply the styles to the custom link.
46
+ * Content of the link.
48
47
  */
49
- children?: React.ReactNode;
48
+ children: string;
50
49
  /**
51
50
  * Element or path used as the icon that will be placed next to the link text.
52
51
  */
package/main.d.ts CHANGED
@@ -7,7 +7,6 @@ import DxcDialog from "./dialog/Dialog";
7
7
  import DxcDropdown from "./dropdown/Dropdown";
8
8
  import DxcFooter from "./footer/Footer";
9
9
  import DxcHeader from "./header/Header";
10
- import DxcRadio from "./radio/Radio";
11
10
  import DxcSlider from "./slider/Slider";
12
11
  import DxcSwitch from "./switch/Switch";
13
12
  import DxcTabs from "./tabs/Tabs";
@@ -42,6 +41,7 @@ import DxcRadioGroup from "./radio-group/RadioGroup";
42
41
  import DxcBleed from "./bleed/Bleed";
43
42
  import DxcInset from "./inset/Inset";
44
43
  import DxcQuickNav from "./quick-nav/QuickNav";
45
- import HalstackContext, { HalstackProvider } from "./HalstackContext";
44
+ import DxcNavTabs from "./tabs-nav/NavTabs";
45
+ import HalstackContext, { HalstackProvider, HalstackLanguageContext } from "./HalstackContext";
46
46
  import { BackgroundColorProvider } from "./BackgroundColorContext";
47
- export { DxcAlert, DxcButton, DxcFooter, DxcCheckbox, DxcTextInput, DxcDropdown, DxcSwitch, DxcSlider, DxcRadio, DxcHeader, DxcTable, DxcTabs, DxcToggleGroup, DxcDialog, DxcCard, DxcProgressBar, DxcAccordion, DxcSpinner, DxcBox, DxcTag, DxcPaginator, DxcSidenav, DxcWizard, DxcLink, DxcHeading, DxcResultsetTable, DxcChip, DxcApplicationLayout, HalstackContext, HalstackProvider, BackgroundColorProvider, DxcAccordionGroup, DxcBadge, DxcPasswordInput, DxcDateInput, DxcNumberInput, DxcTextarea, DxcSelect, DxcFileInput, DxcStack, DxcRow, DxcText, DxcList, DxcRadioGroup, DxcBleed, DxcInset, DxcQuickNav, };
47
+ export { DxcAlert, DxcButton, DxcFooter, DxcCheckbox, DxcTextInput, DxcDropdown, DxcSwitch, DxcSlider, DxcHeader, DxcTable, DxcTabs, DxcToggleGroup, DxcDialog, DxcCard, DxcProgressBar, DxcAccordion, DxcSpinner, DxcBox, DxcTag, DxcPaginator, DxcSidenav, DxcWizard, DxcLink, DxcHeading, DxcResultsetTable, DxcChip, DxcApplicationLayout, HalstackContext, HalstackLanguageContext, HalstackProvider, BackgroundColorProvider, DxcAccordionGroup, DxcBadge, DxcPasswordInput, DxcDateInput, DxcNumberInput, DxcTextarea, DxcSelect, DxcFileInput, DxcStack, DxcRow, DxcText, DxcList, DxcRadioGroup, DxcBleed, DxcInset, DxcQuickNav, DxcNavTabs, };
package/main.js CHANGED
@@ -139,6 +139,12 @@ Object.defineProperty(exports, "DxcList", {
139
139
  return _List["default"];
140
140
  }
141
141
  });
142
+ Object.defineProperty(exports, "DxcNavTabs", {
143
+ enumerable: true,
144
+ get: function get() {
145
+ return _NavTabs["default"];
146
+ }
147
+ });
142
148
  Object.defineProperty(exports, "DxcNumberInput", {
143
149
  enumerable: true,
144
150
  get: function get() {
@@ -169,12 +175,6 @@ Object.defineProperty(exports, "DxcQuickNav", {
169
175
  return _QuickNav["default"];
170
176
  }
171
177
  });
172
- Object.defineProperty(exports, "DxcRadio", {
173
- enumerable: true,
174
- get: function get() {
175
- return _Radio["default"];
176
- }
177
- });
178
178
  Object.defineProperty(exports, "DxcRadioGroup", {
179
179
  enumerable: true,
180
180
  get: function get() {
@@ -283,6 +283,12 @@ Object.defineProperty(exports, "HalstackContext", {
283
283
  return _HalstackContext["default"];
284
284
  }
285
285
  });
286
+ Object.defineProperty(exports, "HalstackLanguageContext", {
287
+ enumerable: true,
288
+ get: function get() {
289
+ return _HalstackContext.HalstackLanguageContext;
290
+ }
291
+ });
286
292
  Object.defineProperty(exports, "HalstackProvider", {
287
293
  enumerable: true,
288
294
  get: function get() {
@@ -308,8 +314,6 @@ var _Footer = _interopRequireDefault(require("./footer/Footer"));
308
314
 
309
315
  var _Header = _interopRequireDefault(require("./header/Header"));
310
316
 
311
- var _Radio = _interopRequireDefault(require("./radio/Radio"));
312
-
313
317
  var _Slider = _interopRequireDefault(require("./slider/Slider"));
314
318
 
315
319
  var _Switch = _interopRequireDefault(require("./switch/Switch"));
@@ -378,6 +382,8 @@ var _Inset = _interopRequireDefault(require("./inset/Inset"));
378
382
 
379
383
  var _QuickNav = _interopRequireDefault(require("./quick-nav/QuickNav"));
380
384
 
385
+ var _NavTabs = _interopRequireDefault(require("./tabs-nav/NavTabs"));
386
+
381
387
  var _HalstackContext = _interopRequireWildcard(require("./HalstackContext"));
382
388
 
383
389
  var _BackgroundColorContext = require("./BackgroundColorContext");
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@dxc-technology/halstack-react",
3
- "version": "0.0.0-bcc5ff3",
3
+ "version": "0.0.0-bd364ae",
4
4
  "description": "DXC Halstack React components library",
5
5
  "repository": "dxc-technology/halstack-react",
6
6
  "homepage": "http://developer.dxc.com/tools/react",
@@ -17,6 +17,8 @@ var _styledComponents = _interopRequireWildcard(require("styled-components"));
17
17
 
18
18
  var _useTheme = _interopRequireDefault(require("../useTheme"));
19
19
 
20
+ var _useTranslatedLabels = _interopRequireDefault(require("../useTranslatedLabels"));
21
+
20
22
  var _Button = _interopRequireDefault(require("../button/Button"));
21
23
 
22
24
  var _Select = _interopRequireDefault(require("../select/Select"));
@@ -49,13 +51,14 @@ var DxcPaginator = function DxcPaginator(_ref) {
49
51
  var minItemsPerPage = currentPageInternal === 1 || currentPageInternal === 0 ? currentPageInternal : (currentPageInternal - 1) * itemsPerPage + 1;
50
52
  var maxItemsPerPage = minItemsPerPage - 1 + itemsPerPage > totalItems ? totalItems : minItemsPerPage - 1 + itemsPerPage;
51
53
  var colorsTheme = (0, _useTheme["default"])();
54
+ var translatedLabels = (0, _useTranslatedLabels["default"])();
52
55
  return /*#__PURE__*/_react["default"].createElement(_styledComponents.ThemeProvider, {
53
56
  theme: colorsTheme.paginator
54
57
  }, /*#__PURE__*/_react["default"].createElement(_BackgroundColorContext.BackgroundColorProvider, {
55
58
  color: colorsTheme.paginator.backgroundColor
56
59
  }, /*#__PURE__*/_react["default"].createElement(DxcPaginatorContainer, {
57
60
  disabled: currentPageInternal === 1
58
- }, /*#__PURE__*/_react["default"].createElement(LabelsContainer, null, itemsPerPageOptions && /*#__PURE__*/_react["default"].createElement(ItemsPageContainer, null, /*#__PURE__*/_react["default"].createElement(ItemsLabel, null, "Items per page "), /*#__PURE__*/_react["default"].createElement(SelectContainer, null, /*#__PURE__*/_react["default"].createElement(_Select["default"], {
61
+ }, /*#__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"], {
59
62
  options: itemsPerPageOptions.map(function (num) {
60
63
  return {
61
64
  label: num.toString(),
@@ -68,14 +71,10 @@ var DxcPaginator = function DxcPaginator(_ref) {
68
71
  value: itemsPerPage.toString(),
69
72
  size: "fillParent",
70
73
  tabIndex: tabIndex
71
- }))), /*#__PURE__*/_react["default"].createElement(TotalItemsContainer, null, minItemsPerPage, " to ", maxItemsPerPage, " of ", totalItems), onPageChange && /*#__PURE__*/_react["default"].createElement(_Button["default"], {
74
+ }))), /*#__PURE__*/_react["default"].createElement(TotalItemsContainer, null, translatedLabels.paginator.minToMaxOfText(minItemsPerPage, maxItemsPerPage, totalItems)), onPageChange && /*#__PURE__*/_react["default"].createElement(_Button["default"], {
72
75
  size: "small",
73
76
  mode: "secondary",
74
77
  disabled: currentPageInternal === 1 || currentPageInternal === 0,
75
- margin: {
76
- left: "xxsmall",
77
- right: "xxsmall"
78
- },
79
78
  icon: _Icons.firstIcon,
80
79
  tabIndex: tabIndex,
81
80
  onClick: function onClick() {
@@ -85,16 +84,12 @@ var DxcPaginator = function DxcPaginator(_ref) {
85
84
  size: "small",
86
85
  mode: "secondary",
87
86
  disabled: currentPageInternal === 1 || currentPageInternal === 0,
88
- margin: {
89
- left: "xxsmall",
90
- right: "xxsmall"
91
- },
92
87
  icon: _Icons.previousIcon,
93
88
  tabIndex: tabIndex,
94
89
  onClick: function onClick() {
95
90
  onPageChange(currentPage - 1);
96
91
  }
97
- }), showGoToPage && /*#__PURE__*/_react["default"].createElement(PageToSelectContainer, null, /*#__PURE__*/_react["default"].createElement(GoToLabel, null, "Go to page: "), /*#__PURE__*/_react["default"].createElement(SelectContainer, null, /*#__PURE__*/_react["default"].createElement(_Select["default"], {
92
+ }), showGoToPage && /*#__PURE__*/_react["default"].createElement(PageToSelectContainer, null, /*#__PURE__*/_react["default"].createElement(GoToLabel, null, translatedLabels.paginator.goToPageText, " "), /*#__PURE__*/_react["default"].createElement(SelectContainer, null, /*#__PURE__*/_react["default"].createElement(_Select["default"], {
98
93
  options: Array.from(Array(totalPages), function (e, num) {
99
94
  return {
100
95
  label: (num + 1).toString(),
@@ -107,14 +102,10 @@ var DxcPaginator = function DxcPaginator(_ref) {
107
102
  value: currentPage.toString(),
108
103
  size: "fillParent",
109
104
  tabIndex: tabIndex
110
- }))) || /*#__PURE__*/_react["default"].createElement(TextContainer, null, "Page: ", currentPageInternal, " of ", totalPages), onPageChange && /*#__PURE__*/_react["default"].createElement(_Button["default"], {
105
+ }))) || /*#__PURE__*/_react["default"].createElement(TextContainer, null, translatedLabels.paginator.pageOfText(currentPageInternal, totalPages)), onPageChange && /*#__PURE__*/_react["default"].createElement(_Button["default"], {
111
106
  size: "small",
112
107
  mode: "secondary",
113
108
  disabled: currentPageInternal === totalPages,
114
- margin: {
115
- left: "xxsmall",
116
- right: "xxsmall"
117
- },
118
109
  icon: _Icons.nextIcon,
119
110
  tabIndex: tabIndex,
120
111
  onClick: function onClick() {
@@ -124,10 +115,6 @@ var DxcPaginator = function DxcPaginator(_ref) {
124
115
  size: "small",
125
116
  mode: "secondary",
126
117
  disabled: currentPageInternal === totalPages,
127
- margin: {
128
- left: "xxsmall",
129
- right: "xxsmall"
130
- },
131
118
  icon: _Icons.lastIcon,
132
119
  tabIndex: tabIndex,
133
120
  onClick: function onClick() {
@@ -136,11 +123,7 @@ var DxcPaginator = function DxcPaginator(_ref) {
136
123
  })))));
137
124
  };
138
125
 
139
- var DxcPaginatorContainer = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n height: ", ";\n width: ", ";\n font-family: ", ";\n font-size: ", ";\n font-weight: ", ";\n font-style: ", ";\n text-transform: ", ";\n background-color: ", ";\n color: ", ";\n\n button {\n &:disabled {\n background-color: transparent !important;\n opacity: 0.3 !important;\n }\n }\n"])), function (props) {
140
- return props.theme.height;
141
- }, function (props) {
142
- return props.theme.width;
143
- }, function (props) {
126
+ 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) {
144
127
  return props.theme.fontFamily;
145
128
  }, function (props) {
146
129
  return props.theme.fontSize;
@@ -154,9 +137,13 @@ var DxcPaginatorContainer = _styledComponents["default"].div(_templateObject ||
154
137
  return props.theme.backgroundColor;
155
138
  }, function (props) {
156
139
  return props.theme.fontColor;
140
+ }, function (props) {
141
+ return props.theme.verticalPadding;
142
+ }, function (props) {
143
+ return props.theme.horizontalPadding;
157
144
  });
158
145
 
159
- var SelectContainer = _styledComponents["default"].div(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n max-width: 100px;\n"])));
146
+ var SelectContainer = _styledComponents["default"].div(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n min-width: 5.25rem;\n"])));
160
147
 
161
148
  var ItemsPageContainer = _styledComponents["default"].span(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n align-items: center;\n margin-right: ", ";\n margin-left: ", ";\n\n label {\n height: 0px;\n }\n label + .MuiInput-formControl {\n margin-top: 0px;\n }\n"])), function (props) {
162
149
  return props.theme.itemsPerPageSelectorMarginRight;
@@ -164,9 +151,9 @@ var ItemsPageContainer = _styledComponents["default"].span(_templateObject3 || (
164
151
  return props.theme.itemsPerPageSelectorMarginLeft;
165
152
  });
166
153
 
167
- var ItemsLabel = _styledComponents["default"].span(_templateObject4 || (_templateObject4 = (0, _taggedTemplateLiteral2["default"])(["\n margin-right: 15px;\n"])));
154
+ var ItemsLabel = _styledComponents["default"].span(_templateObject4 || (_templateObject4 = (0, _taggedTemplateLiteral2["default"])(["\n margin-right: 0.5rem;\n"])));
168
155
 
169
- var GoToLabel = _styledComponents["default"].span(_templateObject5 || (_templateObject5 = (0, _taggedTemplateLiteral2["default"])(["\n margin-right: 10px;\n margin-left: 10px;\n"])));
156
+ var GoToLabel = _styledComponents["default"].span(_templateObject5 || (_templateObject5 = (0, _taggedTemplateLiteral2["default"])(["\n margin-right: 0.5rem;\n margin-left: 1rem;\n"])));
170
157
 
171
158
  var TotalItemsContainer = _styledComponents["default"].span(_templateObject6 || (_templateObject6 = (0, _taggedTemplateLiteral2["default"])(["\n margin-right: ", ";\n margin-left: ", ";\n"])), function (props) {
172
159
  return props.theme.totalItemsContainerMarginRight;
@@ -174,17 +161,9 @@ var TotalItemsContainer = _styledComponents["default"].span(_templateObject6 ||
174
161
  return props.theme.totalItemsContainerMarginLeft;
175
162
  });
176
163
 
177
- var LabelsContainer = _styledComponents["default"].div(_templateObject7 || (_templateObject7 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n width: 100%;\n justify-content: flex-end;\n align-items: center;\n margin: 0 ", " 0 ", ";\n"])), function (props) {
178
- return props.theme.marginRight;
179
- }, function (props) {
180
- return props.theme.marginLeft;
181
- });
164
+ 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"])));
182
165
 
183
- var PageToSelectContainer = _styledComponents["default"].span(_templateObject8 || (_templateObject8 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n align-items: center;\n margin-right: ", ";\n margin-left: ", ";\n\n label {\n height: 0px;\n }\n label + .MuiInput-formControl {\n margin-top: 0px;\n }\n"])), function (props) {
184
- return props.theme.pageSelectorMarginRight;
185
- }, function (props) {
186
- return props.theme.pageSelectorMarginLeft;
187
- });
166
+ var PageToSelectContainer = _styledComponents["default"].span(_templateObject8 || (_templateObject8 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n align-items: center;\n\n label {\n height: 0px;\n }\n label + .MuiInput-formControl {\n margin-top: 0px;\n }\n"])));
188
167
 
189
168
  var TextContainer = _styledComponents["default"].span(_templateObject9 || (_templateObject9 = (0, _taggedTemplateLiteral2["default"])([""])));
190
169
 
@@ -19,6 +19,8 @@ var _styledComponents = _interopRequireDefault(require("styled-components"));
19
19
 
20
20
  var _TextInput = _interopRequireDefault(require("../text-input/TextInput"));
21
21
 
22
+ var _useTranslatedLabels = _interopRequireDefault(require("../useTranslatedLabels"));
23
+
22
24
  var _templateObject;
23
25
 
24
26
  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); }
@@ -53,6 +55,7 @@ var DxcPasswordInput = /*#__PURE__*/_react["default"].forwardRef(function (_ref,
53
55
  setIsPasswordVisible = _useState2[1];
54
56
 
55
57
  var inputRef = (0, _react.useRef)(null);
58
+ var translatedLabels = (0, _useTranslatedLabels["default"])();
56
59
 
57
60
  var setInputType = function setInputType(type) {
58
61
  var _inputRef$current, _inputRef$current$chi;
@@ -82,18 +85,18 @@ var DxcPasswordInput = /*#__PURE__*/_react["default"].forwardRef(function (_ref,
82
85
  };
83
86
 
84
87
  var getIconTitle = function getIconTitle() {
85
- return isPasswordVisible ? "Hide password" : "Show password";
88
+ return isPasswordVisible ? translatedLabels.passwordInput.inputHidePasswordTitle : translatedLabels.passwordInput.inputShowPasswordTitle;
86
89
  };
87
90
 
88
91
  (0, _react.useEffect)(function () {
89
- setAriaAttributes(false, "Show password");
92
+ setAriaAttributes(false, translatedLabels.passwordInput.inputShowPasswordTitle);
90
93
 
91
94
  if (isPasswordVisible) {
92
95
  setInputType("text");
93
- setAriaAttributes(true, "Hide password");
96
+ setAriaAttributes(true, translatedLabels.passwordInput.inputHidePasswordTitle);
94
97
  } else {
95
98
  setInputType("password");
96
- setAriaAttributes(false, "Show password");
99
+ setAriaAttributes(false, translatedLabels.passwordInput.inputShowPasswordTitle);
97
100
  }
98
101
  }, [isPasswordVisible]);
99
102
 
@@ -169,13 +169,12 @@ describe("Password input component tests", function () {
169
169
  var passwordInput = getByRole("textbox");
170
170
  expect(passwordInput.getAttribute("aria-autocomplete")).toBeNull();
171
171
  expect(passwordInput.getAttribute("aria-controls")).toBeNull();
172
+ expect(passwordInput.getAttribute("aria-expanded")).toBeNull();
172
173
  var showButton = getByRole("button");
173
- expect(showButton.getAttribute("aria-expanded")).toBe("false");
174
174
  expect(showButton.getAttribute("aria-label")).toBe("Show password");
175
175
 
176
176
  _userEvent["default"].click(showButton);
177
177
 
178
- expect(showButton.getAttribute("aria-expanded")).toBe("true");
179
178
  expect(showButton.getAttribute("aria-label")).toBe("Hide password");
180
179
  });
181
180
  });
@@ -37,7 +37,7 @@ var DxcProgressBar = function DxcProgressBar(_ref) {
37
37
  _ref$helperText = _ref.helperText,
38
38
  helperText = _ref$helperText === void 0 ? "" : _ref$helperText,
39
39
  _ref$overlay = _ref.overlay,
40
- overlay = _ref$overlay === void 0 ? true : _ref$overlay,
40
+ overlay = _ref$overlay === void 0 ? false : _ref$overlay,
41
41
  value = _ref.value,
42
42
  _ref$showValue = _ref.showValue,
43
43
  showValue = _ref$showValue === void 0 ? false : _ref$showValue,
@@ -12,40 +12,40 @@ export const Chromatic = () => (
12
12
  <>
13
13
  <ExampleContainer>
14
14
  <Title title="Without labels" theme="light" level={4} />
15
- <DxcProgressBar overlay={false} value={50} showValue />
15
+ <DxcProgressBar value={50} showValue />
16
16
  <Title title="With helperText" theme="light" level={4} />
17
- <DxcProgressBar helperText="Helper text" value={50} overlay={false} showValue />
17
+ <DxcProgressBar helperText="Helper text" value={50} showValue />
18
18
  <Title title="Without default value" theme="light" level={4} />
19
- <DxcProgressBar label="Loading..." overlay={false} showValue />
19
+ <DxcProgressBar label="Loading..." showValue />
20
20
  </ExampleContainer>
21
21
  <Title title="Margins" theme="light" level={2} />
22
22
  <ExampleContainer>
23
23
  <Title title="Xxsmall margin" theme="light" level={4} />
24
- <DxcProgressBar label="Margin xxsmall" margin="xxsmall" overlay={false} value={50} showValue />
24
+ <DxcProgressBar label="Margin xxsmall" margin="xxsmall" value={50} showValue />
25
25
  </ExampleContainer>
26
26
  <ExampleContainer>
27
27
  <Title title="Xsmall margin" theme="light" level={4} />
28
- <DxcProgressBar label="Margin xsmall" margin="xsmall" overlay={false} value={50} showValue />
28
+ <DxcProgressBar label="Margin xsmall" margin="xsmall" value={50} showValue />
29
29
  </ExampleContainer>
30
30
  <ExampleContainer>
31
31
  <Title title="Small margin" theme="light" level={4} />
32
- <DxcProgressBar label="Margin small" margin="small" overlay={false} value={50} showValue />
32
+ <DxcProgressBar label="Margin small" margin="small" value={50} showValue />
33
33
  </ExampleContainer>
34
34
  <ExampleContainer>
35
35
  <Title title="Medium margin" theme="light" level={4} />
36
- <DxcProgressBar label="Margin medium" margin="medium" overlay={false} value={50} showValue />
36
+ <DxcProgressBar label="Margin medium" margin="medium" value={50} showValue />
37
37
  </ExampleContainer>
38
38
  <ExampleContainer>
39
39
  <Title title="Large margin" theme="light" level={4} />
40
- <DxcProgressBar label="Margin large" margin="large" overlay={false} value={50} showValue />
40
+ <DxcProgressBar label="Margin large" margin="large" value={50} showValue />
41
41
  </ExampleContainer>
42
42
  <ExampleContainer>
43
43
  <Title title="Xlarge margin" theme="light" level={4} />
44
- <DxcProgressBar label="Margin xlarge" margin="xlarge" overlay={false} value={50} showValue />
44
+ <DxcProgressBar label="Margin xlarge" margin="xlarge" value={50} showValue />
45
45
  </ExampleContainer>
46
46
  <ExampleContainer>
47
47
  <Title title="XxLarge margin" theme="light" level={4} />
48
- <DxcProgressBar label="Margin xxlarge" margin="xxlarge" overlay={false} value={50} showValue />
48
+ <DxcProgressBar label="Margin xxlarge" margin="xxlarge" value={50} showValue />
49
49
  </ExampleContainer>
50
50
  </>
51
51
  );
@@ -53,6 +53,6 @@ export const Chromatic = () => (
53
53
  export const ProgressBarOverlay = () => (
54
54
  <ExampleContainer>
55
55
  <Title title="Overlay" theme="dark" level={4} />
56
- <DxcProgressBar label="Overlay" helperText="Helper text" showValue value={50} />
56
+ <DxcProgressBar label="Overlay" helperText="Helper text" overlay={true} showValue value={50} />
57
57
  </ExampleContainer>
58
58
  );