@dxc-technology/halstack-react 0.0.0-dfcca07 → 0.0.0-dfd09f9
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.
- package/BackgroundColorContext.d.ts +10 -0
- package/BackgroundColorContext.js +1 -4
- package/ThemeContext.d.ts +10 -0
- package/ThemeContext.js +26 -29
- package/accordion/Accordion.d.ts +1 -1
- package/accordion/Accordion.js +13 -45
- package/accordion/Accordion.stories.tsx +307 -0
- package/accordion/Accordion.test.js +72 -0
- package/accordion/types.d.ts +8 -8
- package/accordion-group/AccordionGroup.d.ts +1 -1
- package/accordion-group/AccordionGroup.js +14 -16
- package/accordion-group/AccordionGroup.stories.tsx +1 -1
- package/accordion-group/AccordionGroup.test.js +151 -0
- package/accordion-group/types.d.ts +8 -8
- package/alert/Alert.js +2 -2
- package/alert/Alert.test.js +92 -0
- package/badge/Badge.d.ts +4 -0
- package/badge/Badge.js +1 -1
- package/badge/types.d.ts +4 -0
- package/badge/types.js +5 -0
- package/bleed/Bleed.d.ts +3 -0
- package/bleed/Bleed.js +84 -0
- package/bleed/Bleed.stories.tsx +342 -0
- package/bleed/types.d.ts +37 -0
- package/bleed/types.js +5 -0
- package/box/Box.js +2 -2
- package/box/Box.test.js +18 -0
- package/button/Button.d.ts +1 -1
- package/button/Button.js +11 -19
- package/button/Button.stories.tsx +6 -8
- package/button/Button.test.js +35 -0
- package/button/types.d.ts +3 -7
- package/card/Card.js +1 -1
- package/card/Card.stories.tsx +1 -1
- package/card/Card.test.js +50 -0
- package/checkbox/Checkbox.d.ts +1 -1
- package/checkbox/Checkbox.js +33 -32
- package/checkbox/Checkbox.stories.tsx +124 -128
- package/checkbox/Checkbox.test.js +78 -0
- package/checkbox/types.d.ts +10 -4
- package/chip/Chip.d.ts +4 -0
- package/chip/Chip.js +16 -76
- package/chip/Chip.stories.tsx +6 -8
- package/chip/Chip.test.js +56 -0
- package/chip/types.d.ts +45 -0
- package/chip/types.js +5 -0
- package/common/variables.js +59 -265
- package/date-input/DateInput.js +54 -46
- package/date-input/DateInput.stories.tsx +7 -7
- package/date-input/DateInput.test.js +479 -0
- package/date-input/types.d.ts +16 -9
- package/dialog/Dialog.js +8 -35
- package/dialog/Dialog.test.js +40 -0
- package/dropdown/Dropdown.d.ts +1 -1
- package/dropdown/Dropdown.js +13 -35
- package/dropdown/Dropdown.stories.tsx +249 -0
- package/dropdown/Dropdown.test.js +189 -0
- package/dropdown/types.d.ts +5 -14
- package/file-input/FileInput.d.ts +1 -1
- package/file-input/FileInput.js +148 -69
- package/file-input/FileInput.stories.tsx +507 -0
- package/file-input/FileInput.test.js +457 -0
- package/file-input/FileItem.js +3 -3
- package/file-input/types.d.ts +32 -7
- package/footer/Footer.d.ts +1 -1
- package/footer/Footer.js +28 -111
- package/footer/{Footer.stories.jsx → Footer.stories.tsx} +1 -22
- package/footer/Footer.test.js +109 -0
- package/footer/Icons.d.ts +2 -0
- package/footer/Icons.js +3 -3
- package/footer/types.d.ts +5 -9
- package/header/Header.js +22 -46
- package/header/Header.stories.tsx +46 -36
- package/header/Header.test.js +79 -0
- package/header/Icons.d.ts +2 -0
- package/heading/Heading.js +1 -1
- package/heading/Heading.stories.tsx +3 -2
- package/heading/Heading.test.js +186 -0
- package/inset/Inset.d.ts +3 -0
- package/inset/Inset.js +84 -0
- package/inset/Inset.stories.tsx +229 -0
- package/inset/types.d.ts +37 -0
- package/inset/types.js +5 -0
- package/layout/ApplicationLayout.d.ts +10 -0
- package/layout/ApplicationLayout.js +14 -31
- package/layout/ApplicationLayout.stories.tsx +171 -0
- package/layout/types.d.ts +57 -0
- package/layout/types.js +5 -0
- package/link/Link.js +8 -16
- package/link/Link.stories.tsx +6 -1
- package/link/Link.test.js +91 -0
- package/link/types.d.ts +5 -9
- package/list/List.d.ts +4 -0
- package/list/List.js +47 -0
- package/list/List.stories.tsx +95 -0
- package/list/types.d.ts +7 -0
- package/list/types.js +5 -0
- package/main.d.ts +11 -8
- package/main.js +62 -38
- package/number-input/NumberInput.js +14 -24
- package/number-input/NumberInput.stories.tsx +5 -5
- package/number-input/NumberInput.test.js +506 -0
- package/number-input/types.d.ts +16 -9
- package/package.json +6 -3
- package/paginator/Paginator.js +2 -8
- package/paginator/Paginator.test.js +266 -0
- package/password-input/PasswordInput.js +15 -16
- package/password-input/PasswordInput.stories.tsx +3 -3
- package/password-input/PasswordInput.test.js +181 -0
- package/password-input/types.d.ts +13 -10
- package/progress-bar/ProgressBar.js +4 -4
- package/progress-bar/ProgressBar.test.js +65 -0
- package/quick-nav/QuickNav.d.ts +4 -0
- package/quick-nav/QuickNav.js +64 -0
- package/quick-nav/QuickNav.stories.tsx +237 -0
- package/quick-nav/types.d.ts +21 -0
- package/quick-nav/types.js +5 -0
- package/radio/Radio.js +2 -2
- package/radio/Radio.test.js +71 -0
- package/radio-group/Radio.d.ts +4 -0
- package/radio-group/Radio.js +141 -0
- package/radio-group/RadioGroup.d.ts +4 -0
- package/radio-group/RadioGroup.js +280 -0
- package/radio-group/RadioGroup.stories.tsx +100 -0
- package/radio-group/RadioGroup.test.js +695 -0
- package/radio-group/types.d.ts +114 -0
- package/radio-group/types.js +5 -0
- package/resultsetTable/ResultsetTable.js +6 -3
- package/resultsetTable/ResultsetTable.stories.tsx +275 -0
- package/resultsetTable/ResultsetTable.test.js +306 -0
- package/resultsetTable/types.d.ts +1 -1
- package/row/Row.d.ts +3 -0
- package/row/Row.js +127 -0
- package/row/Row.stories.tsx +237 -0
- package/row/types.d.ts +28 -0
- package/row/types.js +5 -0
- package/select/Icons.d.ts +10 -0
- package/select/Icons.js +93 -0
- package/select/Listbox.d.ts +4 -0
- package/select/Listbox.js +148 -0
- package/select/Option.d.ts +4 -0
- package/select/Option.js +110 -0
- package/select/Select.d.ts +4 -0
- package/select/Select.js +107 -317
- package/select/Select.stories.tsx +91 -81
- package/select/Select.test.js +2057 -0
- package/select/types.d.ts +213 -0
- package/select/types.js +5 -0
- package/sidenav/Sidenav.js +2 -2
- package/sidenav/Sidenav.stories.tsx +18 -1
- package/sidenav/Sidenav.test.js +56 -0
- package/slider/Slider.d.ts +1 -1
- package/slider/Slider.js +4 -3
- package/slider/Slider.stories.tsx +8 -8
- package/slider/Slider.test.js +150 -0
- package/slider/types.d.ts +4 -0
- package/spinner/Spinner.js +2 -2
- package/spinner/Spinner.stories.jsx +1 -0
- package/spinner/Spinner.test.js +64 -0
- package/stack/Stack.d.ts +3 -0
- package/stack/Stack.js +97 -0
- package/stack/Stack.stories.tsx +164 -0
- package/stack/types.d.ts +24 -0
- package/stack/types.js +5 -0
- package/switch/Switch.d.ts +1 -1
- package/switch/Switch.js +21 -8
- package/switch/Switch.stories.tsx +7 -7
- package/switch/Switch.test.js +98 -0
- package/switch/types.d.ts +4 -0
- package/table/Table.js +2 -2
- package/table/Table.stories.jsx +2 -1
- package/table/Table.test.js +26 -0
- package/tabs/Tabs.d.ts +1 -1
- package/tabs/Tabs.js +17 -19
- package/tabs/Tabs.stories.tsx +8 -11
- package/tabs/Tabs.test.js +140 -0
- package/tabs/types.d.ts +27 -15
- package/tag/Tag.d.ts +1 -1
- package/tag/Tag.js +16 -23
- package/tag/Tag.stories.tsx +26 -29
- package/tag/Tag.test.js +60 -0
- package/tag/types.d.ts +23 -14
- package/text/Text.d.ts +7 -0
- package/text/Text.js +30 -0
- package/text/Text.stories.tsx +19 -0
- package/text-input/TextInput.js +46 -36
- package/text-input/TextInput.stories.tsx +34 -16
- package/text-input/TextInput.test.js +1712 -0
- package/text-input/types.d.ts +18 -11
- package/textarea/Textarea.d.ts +4 -0
- package/textarea/Textarea.js +26 -56
- package/textarea/Textarea.stories.jsx +37 -15
- package/textarea/Textarea.test.js +437 -0
- package/textarea/types.d.ts +137 -0
- package/textarea/types.js +5 -0
- package/toggle-group/ToggleGroup.d.ts +1 -1
- package/toggle-group/ToggleGroup.js +15 -17
- package/toggle-group/ToggleGroup.stories.tsx +27 -32
- package/toggle-group/ToggleGroup.test.js +156 -0
- package/toggle-group/types.d.ts +46 -25
- package/useTheme.d.ts +2 -0
- package/useTheme.js +1 -1
- package/wizard/Wizard.d.ts +1 -1
- package/wizard/Wizard.js +81 -22
- package/wizard/{Wizard.stories.jsx → Wizard.stories.tsx} +13 -23
- package/wizard/Wizard.test.js +141 -0
- package/wizard/types.d.ts +8 -8
- package/V3Select/V3Select.js +0 -455
- package/V3Select/index.d.ts +0 -27
- package/V3Textarea/V3Textarea.js +0 -260
- package/V3Textarea/index.d.ts +0 -27
- package/chip/index.d.ts +0 -22
- package/date/Date.js +0 -373
- package/date/index.d.ts +0 -27
- package/input-text/Icons.js +0 -22
- package/input-text/InputText.js +0 -611
- package/input-text/index.d.ts +0 -36
- package/select/index.d.ts +0 -131
- package/textarea/index.d.ts +0 -127
- package/toggle/Toggle.js +0 -186
- package/toggle/index.d.ts +0 -21
- package/upload/Upload.js +0 -201
- package/upload/buttons-upload/ButtonsUpload.js +0 -111
- package/upload/buttons-upload/Icons.js +0 -40
- package/upload/dragAndDropArea/DragAndDropArea.js +0 -225
- package/upload/dragAndDropArea/Icons.js +0 -39
- package/upload/file-upload/FileToUpload.js +0 -115
- package/upload/file-upload/Icons.js +0 -66
- package/upload/files-upload/FilesToUpload.js +0 -109
- package/upload/index.d.ts +0 -15
- package/upload/transaction/Icons.js +0 -160
- package/upload/transaction/Transaction.js +0 -104
- package/upload/transactions/Transactions.js +0 -94
- package/wizard/Icons.js +0 -65
|
@@ -30,25 +30,28 @@ declare type Props = {
|
|
|
30
30
|
* This function will be called when the user types within the input
|
|
31
31
|
* element of the component. An object including the current value and
|
|
32
32
|
* the error (if the value entered is not valid) will be passed to this
|
|
33
|
-
* function. If there is no error, error will be
|
|
33
|
+
* function. If there is no error, error will not be defined.
|
|
34
34
|
* */
|
|
35
35
|
onChange?: (val: {
|
|
36
36
|
value: string;
|
|
37
|
-
error
|
|
37
|
+
error?: string;
|
|
38
38
|
}) => void;
|
|
39
39
|
/**
|
|
40
40
|
* This function will be called when the input element loses the focus.
|
|
41
41
|
* An object including the input value and the error (if the value entered is
|
|
42
|
-
* not valid) will be passed to this function. If there is no error, error will be
|
|
42
|
+
* not valid) will be passed to this function. If there is no error, error will not be defined.
|
|
43
43
|
*/
|
|
44
44
|
onBlur?: (val: {
|
|
45
45
|
value: string;
|
|
46
|
-
error
|
|
46
|
+
error?: string;
|
|
47
47
|
}) => void;
|
|
48
48
|
/**
|
|
49
|
-
* If it is defined
|
|
50
|
-
* the error below the password input
|
|
51
|
-
*
|
|
49
|
+
* If it is a defined value and also a truthy string, the component will
|
|
50
|
+
* change its appearance, showing the error below the password input
|
|
51
|
+
* component. If the defined value is an empty string, it will reserve a
|
|
52
|
+
* space below the component for a future error, but it would not change
|
|
53
|
+
* its look. In case of being undefined or null, both the appearance and
|
|
54
|
+
* the space for the error message would not be modified.
|
|
52
55
|
*/
|
|
53
56
|
error?: string;
|
|
54
57
|
/**
|
|
@@ -58,7 +61,7 @@ declare type Props = {
|
|
|
58
61
|
* the pattern, the onBlur and onChange functions will be called with the
|
|
59
62
|
* current value and an internal error informing that this value does not
|
|
60
63
|
* match the pattern. If the pattern is met, the error parameter of both
|
|
61
|
-
* events will be
|
|
64
|
+
* events will not be defined.
|
|
62
65
|
*/
|
|
63
66
|
pattern?: string;
|
|
64
67
|
/**
|
|
@@ -68,7 +71,7 @@ declare type Props = {
|
|
|
68
71
|
* comply the minimum length, the onBlur and onChange functions will be called
|
|
69
72
|
* with the current value and an internal error informing that the value
|
|
70
73
|
* length does not comply the specified range. If a valid length is
|
|
71
|
-
* reached, the error parameter of both events will be
|
|
74
|
+
* reached, the error parameter of both events will not be defined.
|
|
72
75
|
*/
|
|
73
76
|
minLength?: number;
|
|
74
77
|
/**
|
|
@@ -78,7 +81,7 @@ declare type Props = {
|
|
|
78
81
|
* comply the maximum length, the onBlur and onChange functions will be called
|
|
79
82
|
* with the current value and an internal error informing that the value
|
|
80
83
|
* length does not comply the specified range. If a valid length is
|
|
81
|
-
* reached, the error parameter of both events will be
|
|
84
|
+
* reached, the error parameter of both events will not be defined.
|
|
82
85
|
*/
|
|
83
86
|
maxLength?: number;
|
|
84
87
|
/**
|
|
@@ -21,9 +21,9 @@ var _LinearProgress = _interopRequireDefault(require("@material-ui/core/LinearPr
|
|
|
21
21
|
|
|
22
22
|
var _variables = require("../common/variables.js");
|
|
23
23
|
|
|
24
|
-
var _useTheme = _interopRequireDefault(require("../useTheme
|
|
24
|
+
var _useTheme = _interopRequireDefault(require("../useTheme"));
|
|
25
25
|
|
|
26
|
-
var _BackgroundColorContext = _interopRequireDefault(require("../BackgroundColorContext
|
|
26
|
+
var _BackgroundColorContext = _interopRequireDefault(require("../BackgroundColorContext"));
|
|
27
27
|
|
|
28
28
|
var _templateObject, _templateObject2, _templateObject3, _templateObject4, _templateObject5, _templateObject6;
|
|
29
29
|
|
|
@@ -59,9 +59,9 @@ var DxcProgressBar = function DxcProgressBar(_ref) {
|
|
|
59
59
|
overlay: overlay,
|
|
60
60
|
showValue: showValue,
|
|
61
61
|
backgroundType: backgroundType
|
|
62
|
-
}, value === null ? 0 : value >= 0 && value <= 100 ? value : value < 0 ? 0 : 100, " %")), /*#__PURE__*/_react["default"].createElement(_LinearProgress["default"], {
|
|
62
|
+
}, value === null || value === undefined ? 0 : value >= 0 && value <= 100 ? value : value < 0 ? 0 : 100, " %")), /*#__PURE__*/_react["default"].createElement(_LinearProgress["default"], {
|
|
63
63
|
variant: showValue ? "determinate" : "indeterminate",
|
|
64
|
-
value: value === null ? 0 : value >= 0 && value <= 100 ? value : value < 0 ? 0 : 100
|
|
64
|
+
value: value === null || value === undefined ? 0 : value >= 0 && value <= 100 ? value : value < 0 ? 0 : 100
|
|
65
65
|
}), helperText && /*#__PURE__*/_react["default"].createElement(HelperText, {
|
|
66
66
|
overlay: overlay,
|
|
67
67
|
backgroundType: backgroundType
|
|
@@ -0,0 +1,65 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
+
|
|
5
|
+
var _react = _interopRequireDefault(require("react"));
|
|
6
|
+
|
|
7
|
+
var _react2 = require("@testing-library/react");
|
|
8
|
+
|
|
9
|
+
var _ProgressBar = _interopRequireDefault(require("./ProgressBar"));
|
|
10
|
+
|
|
11
|
+
describe("ProgressBar component tests", function () {
|
|
12
|
+
test("ProgressBar renders with label", function () {
|
|
13
|
+
var _render = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_ProgressBar["default"], {
|
|
14
|
+
label: "test-label"
|
|
15
|
+
})),
|
|
16
|
+
getByText = _render.getByText;
|
|
17
|
+
|
|
18
|
+
expect(getByText("test-label")).toBeTruthy();
|
|
19
|
+
});
|
|
20
|
+
test("Overlay progressBar renders with label", function () {
|
|
21
|
+
var _render2 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_ProgressBar["default"], {
|
|
22
|
+
label: "test-label",
|
|
23
|
+
overlay: true
|
|
24
|
+
})),
|
|
25
|
+
getByText = _render2.getByText;
|
|
26
|
+
|
|
27
|
+
expect(getByText("test-label")).toBeTruthy();
|
|
28
|
+
});
|
|
29
|
+
test("ProgressBar renders with default value", function () {
|
|
30
|
+
var _render3 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_ProgressBar["default"], {
|
|
31
|
+
showValue: true
|
|
32
|
+
})),
|
|
33
|
+
getByText = _render3.getByText;
|
|
34
|
+
|
|
35
|
+
expect(getByText("0 %")).toBeTruthy();
|
|
36
|
+
});
|
|
37
|
+
test("Overlay progressBar renders with default value", function () {
|
|
38
|
+
var _render4 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_ProgressBar["default"], {
|
|
39
|
+
showValue: true,
|
|
40
|
+
overlay: true
|
|
41
|
+
})),
|
|
42
|
+
getByText = _render4.getByText;
|
|
43
|
+
|
|
44
|
+
expect(getByText("0 %")).toBeTruthy();
|
|
45
|
+
});
|
|
46
|
+
test("ProgressBar renders with value", function () {
|
|
47
|
+
var _render5 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_ProgressBar["default"], {
|
|
48
|
+
showValue: true,
|
|
49
|
+
value: 25
|
|
50
|
+
})),
|
|
51
|
+
getByText = _render5.getByText;
|
|
52
|
+
|
|
53
|
+
expect(getByText("25 %")).toBeTruthy();
|
|
54
|
+
});
|
|
55
|
+
test("Overlay progressBar renders with value", function () {
|
|
56
|
+
var _render6 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_ProgressBar["default"], {
|
|
57
|
+
showValue: true,
|
|
58
|
+
value: 25,
|
|
59
|
+
overlay: true
|
|
60
|
+
})),
|
|
61
|
+
getByText = _render6.getByText;
|
|
62
|
+
|
|
63
|
+
expect(getByText("25 %")).toBeTruthy();
|
|
64
|
+
});
|
|
65
|
+
});
|
|
@@ -0,0 +1,64 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
+
|
|
5
|
+
Object.defineProperty(exports, "__esModule", {
|
|
6
|
+
value: true
|
|
7
|
+
});
|
|
8
|
+
exports["default"] = void 0;
|
|
9
|
+
|
|
10
|
+
var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
|
|
11
|
+
|
|
12
|
+
var _react = _interopRequireDefault(require("react"));
|
|
13
|
+
|
|
14
|
+
var _styledComponents = _interopRequireDefault(require("styled-components"));
|
|
15
|
+
|
|
16
|
+
var _slugify = _interopRequireDefault(require("slugify"));
|
|
17
|
+
|
|
18
|
+
var _Heading = _interopRequireDefault(require("../heading/Heading"));
|
|
19
|
+
|
|
20
|
+
var _Stack = _interopRequireDefault(require("../stack/Stack"));
|
|
21
|
+
|
|
22
|
+
var _Inset = _interopRequireDefault(require("../inset/Inset"));
|
|
23
|
+
|
|
24
|
+
var _List = _interopRequireDefault(require("../list/List"));
|
|
25
|
+
|
|
26
|
+
var _Text = _interopRequireDefault(require("../text/Text"));
|
|
27
|
+
|
|
28
|
+
var _templateObject, _templateObject2;
|
|
29
|
+
|
|
30
|
+
var DxcQuickNav = function DxcQuickNav(_ref) {
|
|
31
|
+
var title = _ref.title,
|
|
32
|
+
links = _ref.links;
|
|
33
|
+
return /*#__PURE__*/_react["default"].createElement(QuickNavContainer, null, /*#__PURE__*/_react["default"].createElement(_Stack["default"], {
|
|
34
|
+
gutter: "small"
|
|
35
|
+
}, /*#__PURE__*/_react["default"].createElement(_Heading["default"], {
|
|
36
|
+
level: 4,
|
|
37
|
+
text: title
|
|
38
|
+
}), /*#__PURE__*/_react["default"].createElement(_List["default"], null, links.map(function (link) {
|
|
39
|
+
var _link$links;
|
|
40
|
+
|
|
41
|
+
return /*#__PURE__*/_react["default"].createElement(_Inset["default"], {
|
|
42
|
+
space: "xxsmall"
|
|
43
|
+
}, /*#__PURE__*/_react["default"].createElement(_Text["default"], null, /*#__PURE__*/_react["default"].createElement(Link, {
|
|
44
|
+
href: "#".concat((0, _slugify["default"])(link === null || link === void 0 ? void 0 : link.label, {
|
|
45
|
+
lower: true
|
|
46
|
+
}))
|
|
47
|
+
}, link === null || link === void 0 ? void 0 : link.label), (_link$links = link.links) === null || _link$links === void 0 ? void 0 : _link$links.map(function (sublink) {
|
|
48
|
+
return /*#__PURE__*/_react["default"].createElement(_Inset["default"], {
|
|
49
|
+
horizontal: "xsmall"
|
|
50
|
+
}, /*#__PURE__*/_react["default"].createElement(_Text["default"], null, /*#__PURE__*/_react["default"].createElement(Link, {
|
|
51
|
+
href: "#".concat((0, _slugify["default"])(sublink === null || sublink === void 0 ? void 0 : sublink.label, {
|
|
52
|
+
lower: true
|
|
53
|
+
}))
|
|
54
|
+
}, sublink === null || sublink === void 0 ? void 0 : sublink.label)));
|
|
55
|
+
})));
|
|
56
|
+
}))));
|
|
57
|
+
};
|
|
58
|
+
|
|
59
|
+
var QuickNavContainer = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n padding: 5px 15px;\n border-left: 2px solid #bfbfbf;\n li {\n div:first-child {\n display: none;\n }\n }\n"])));
|
|
60
|
+
|
|
61
|
+
var Link = _styledComponents["default"].a(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n text-decoration: none;\n font-size: 14px;\n color: #666666;\n &:hover {\n color: #ab63cf;\n }\n &:focus {\n border-radius: 2px;\n border-color: #0095ff;\n }\n"])));
|
|
62
|
+
|
|
63
|
+
var _default = DxcQuickNav;
|
|
64
|
+
exports["default"] = _default;
|
|
@@ -0,0 +1,237 @@
|
|
|
1
|
+
import React from "react";
|
|
2
|
+
import styled from "styled-components";
|
|
3
|
+
import DxcQuickNav from "./QuickNav";
|
|
4
|
+
import DxcHeading from "../heading/Heading";
|
|
5
|
+
import DxcText from "../text/Text";
|
|
6
|
+
import Title from "../../.storybook/components/Title";
|
|
7
|
+
import ExampleContainer from "../../.storybook/components/ExampleContainer";
|
|
8
|
+
|
|
9
|
+
export default {
|
|
10
|
+
title: "QuickNav",
|
|
11
|
+
component: DxcQuickNav,
|
|
12
|
+
};
|
|
13
|
+
|
|
14
|
+
const links = [
|
|
15
|
+
{
|
|
16
|
+
label: "Overview",
|
|
17
|
+
id: "overview",
|
|
18
|
+
links: [
|
|
19
|
+
{
|
|
20
|
+
label: "Introduction",
|
|
21
|
+
id: "introduction",
|
|
22
|
+
},
|
|
23
|
+
],
|
|
24
|
+
},
|
|
25
|
+
{
|
|
26
|
+
label: "Principles",
|
|
27
|
+
id: "principles",
|
|
28
|
+
links: [
|
|
29
|
+
{ label: "Color", id: "color" },
|
|
30
|
+
{ label: "Spacing", id: "spacing" },
|
|
31
|
+
{ label: "Typography", id: "typography" },
|
|
32
|
+
],
|
|
33
|
+
},
|
|
34
|
+
];
|
|
35
|
+
|
|
36
|
+
export const Chromatic = () => (
|
|
37
|
+
<>
|
|
38
|
+
<ExampleContainer>
|
|
39
|
+
<Title title="Default" level={4} />
|
|
40
|
+
<QuickNavContainer>
|
|
41
|
+
<DxcQuickNav title="Sections" links={links}></DxcQuickNav>
|
|
42
|
+
</QuickNavContainer>
|
|
43
|
+
</ExampleContainer>
|
|
44
|
+
<ExampleContainer pseudoState="pseudo-hover">
|
|
45
|
+
<Title title="Link hovered" level={4} />
|
|
46
|
+
<QuickNavContainer>
|
|
47
|
+
<DxcQuickNav title="Sections" links={links}></DxcQuickNav>
|
|
48
|
+
</QuickNavContainer>
|
|
49
|
+
</ExampleContainer>
|
|
50
|
+
<ExampleContainer>
|
|
51
|
+
<Title title="QuickNav with content" level={4} />
|
|
52
|
+
<Container>
|
|
53
|
+
<ContentContainer>
|
|
54
|
+
<Content id="overview">
|
|
55
|
+
<DxcHeading level={1} text="Overview" margin={{ bottom: "small" }} />
|
|
56
|
+
<DxcText>
|
|
57
|
+
Halstack is the DXC Technology's open source design system for insurance products and digital experiences.
|
|
58
|
+
Our system provides all the tools and resources needed to create superior, beautiful but above all,
|
|
59
|
+
functional user experiences. Halstack is the DXC Technology's open source design system for insurance
|
|
60
|
+
products and digital experiences. Our system provides all the tools and resources needed to create
|
|
61
|
+
superior, beautiful but above all, functional user experiences.Halstack is the DXC Technology's open
|
|
62
|
+
source design system for insurance products and digital experiences. Our system provides all the tools and
|
|
63
|
+
resources needed to create superior, beautiful but above all, functional user experiences.Halstack is the
|
|
64
|
+
DXC Technology's open source design system for insurance products and digital experiences. Our system
|
|
65
|
+
provides all the tools and resources needed to create superior, beautiful but above all, functional user
|
|
66
|
+
experiences.Halstack is the DXC Technology's open source design system for insurance products and digital
|
|
67
|
+
experiences. Our system provides all the tools and resources needed to create superior, beautiful but
|
|
68
|
+
above all, functional user experiences.Halstack is the DXC Technology's open source design system for
|
|
69
|
+
insurance products and digital experiences. Our system provides all the tools and resources needed to
|
|
70
|
+
create superior, beautiful but above all, functional user experiences.Halstack is the DXC Technology's
|
|
71
|
+
open source design system for insurance products and digital experiences. Our system provides all the
|
|
72
|
+
tools and resources needed to create superior, beautiful but above all, functional user experiences.
|
|
73
|
+
</DxcText>
|
|
74
|
+
<Content id="introduction">
|
|
75
|
+
<DxcHeading level={2} text="Introduction" margin={{ top: "xsmall", bottom: "xsmall" }} />
|
|
76
|
+
<DxcText>
|
|
77
|
+
Design principles Halstack design principles are the fundamental part of DXC Technology's approach to
|
|
78
|
+
provide guidance for development teams in order to deliver delightful and consistent user experiences to
|
|
79
|
+
our customers: Balance Consistency Visual hierarchy All our components, design tokens, accessibility
|
|
80
|
+
guidelines, responsive design techniques, and layout proposals have been carefully curated by DXC design
|
|
81
|
+
and engineering teams with the objective of creating a unique visual language and ecosystem for our
|
|
82
|
+
applications. This is the DXC way of creating User Experiences. Open Source Halstack is an open source
|
|
83
|
+
design system, this means that we work towards DXC Technology bussines needs, but it is open for anyone
|
|
84
|
+
to use and contribute back to. We are charmed to receive external contributions to help us find bugs,
|
|
85
|
+
design new features, or help us improve the project documentation. If you're interested, definitely
|
|
86
|
+
check out our contribution guidelines.Design principles Halstack design principles are the fundamental
|
|
87
|
+
part of DXC Technology's approach to provide guidance for development teams in order to deliver
|
|
88
|
+
delightful and consistent user experiences to our customers: Balance Consistency Visual hierarchy All
|
|
89
|
+
our components, design tokens, accessibility guidelines, responsive design techniques, and layout
|
|
90
|
+
proposals have been carefully curated by DXC design and engineering teams with the objective of creating
|
|
91
|
+
a unique visual language and ecosystem for our applications. This is the DXC way of creating User
|
|
92
|
+
Experiences. Open Source Halstack is an open source design system, this means that we work towards DXC
|
|
93
|
+
Technology bussines needs, but it is open for anyone to use and contribute back to. We are charmed to
|
|
94
|
+
receive external contributions to help us find bugs, design new features, or help us improve the project
|
|
95
|
+
documentation. If you're interested, definitely check out our contribution guidelines.Design principles
|
|
96
|
+
Halstack design principles are the fundamental part of DXC Technology's approach to provide guidance for
|
|
97
|
+
development teams in order to deliver delightful and consistent user experiences to our customers:
|
|
98
|
+
Balance Consistency Visual hierarchy All our components, design tokens, accessibility guidelines,
|
|
99
|
+
responsive design techniques, and layout proposals have been carefully curated by DXC design and
|
|
100
|
+
engineering teams with the objective of creating a unique visual language and ecosystem for our
|
|
101
|
+
applications. This is the DXC way of creating User Experiences. Open Source Halstack is an open source
|
|
102
|
+
design system, this means that we work towards DXC Technology bussines needs, but it is open for anyone
|
|
103
|
+
to use and contribute back to. We are charmed to receive external contributions to help us find bugs,
|
|
104
|
+
design new features, or help us improve the project documentation. If you're interested, definitely
|
|
105
|
+
check out our contribution guidelines.
|
|
106
|
+
</DxcText>
|
|
107
|
+
</Content>
|
|
108
|
+
</Content>
|
|
109
|
+
<Content id="principles">
|
|
110
|
+
<DxcHeading level={1} text="Principles" margin={{ top: "small", bottom: "xsmall" }} />
|
|
111
|
+
<Content id="color">
|
|
112
|
+
<DxcHeading level={2} text="Color" margin={{ top: "xsmall", bottom: "xsmall" }} />
|
|
113
|
+
<DxcText>
|
|
114
|
+
The color palette is an essential asset as a communication resource of our design system. Halstack color
|
|
115
|
+
palette brings a unified consistency and helps in guiding the user's perception order. Our color palette
|
|
116
|
+
is based in the HSL model . All our color families are calculated using the lightness value of the
|
|
117
|
+
standard DXC palette colors. Color Tokens Halstack uses tokens to manage color. Appart from a
|
|
118
|
+
multi-purpose greyscale family, purple and blue are the core color families used in our set of
|
|
119
|
+
components. Additional families as red, green and yellow help as feedback role-based color palettes and
|
|
120
|
+
must not be used outside this context.The color palette is an essential asset as a communication
|
|
121
|
+
resource of our design system. Halstack color palette brings a unified consistency and helps in guiding
|
|
122
|
+
the user's perception order. Our color palette is based in the HSL model . All our color families are
|
|
123
|
+
calculated using the lightness value of the standard DXC palette colors. Color Tokens Halstack uses
|
|
124
|
+
tokens to manage color. Appart from a multi-purpose greyscale family, purple and blue are the core color
|
|
125
|
+
families used in our set of components. Additional families as red, green and yellow help as feedback
|
|
126
|
+
role-based color palettes and must not be used outside this context.The color palette is an essential
|
|
127
|
+
asset as a communication resource of our design system. Halstack color palette brings a unified
|
|
128
|
+
consistency and helps in guiding the user's perception order. Our color palette is based in the HSL
|
|
129
|
+
model . All our color families are calculated using the lightness value of the standard DXC palette
|
|
130
|
+
colors. Color Tokens Halstack uses tokens to manage color. Appart from a multi-purpose greyscale family,
|
|
131
|
+
purple and blue are the core color families used in our set of components. Additional families as red,
|
|
132
|
+
green and yellow help as feedback role-based color palettes and must not be used outside this
|
|
133
|
+
context.The color palette is an essential asset as a communication resource of our design system.
|
|
134
|
+
Halstack color palette brings a unified consistency and helps in guiding the user's perception order.
|
|
135
|
+
Our color palette is based in the HSL model . All our color families are calculated using the lightness
|
|
136
|
+
value of the standard DXC palette colors. Color Tokens Halstack uses tokens to manage color. Appart from
|
|
137
|
+
a multi-purpose greyscale family, purple and blue are the core color families used in our set of
|
|
138
|
+
components. Additional families as red, green and yellow help as feedback role-based color palettes and
|
|
139
|
+
must not be used outside this context.The color palette is an essential asset as a communication
|
|
140
|
+
resource of our design system. Halstack color palette brings a unified consistency and helps in guiding
|
|
141
|
+
the user's perception order. Our color palette is based in the HSL model . All our color families are
|
|
142
|
+
calculated using the lightness value of the standard DXC palette colors. Color Tokens Halstack uses
|
|
143
|
+
tokens to manage color. Appart from a multi-purpose greyscale family, purple and blue are the core color
|
|
144
|
+
families used in our set of components. Additional families as red, green and yellow help as feedback
|
|
145
|
+
role-based color palettes and must not be used outside this context.
|
|
146
|
+
</DxcText>
|
|
147
|
+
</Content>
|
|
148
|
+
<Content id="spacing">
|
|
149
|
+
<DxcHeading level={2} text="Spacing" margin={{ top: "xsmall", bottom: "xsmall" }} />
|
|
150
|
+
<DxcText>
|
|
151
|
+
In the search of consistent alignment between the elements we provide a spacing scale based on a root
|
|
152
|
+
values of 8px and 4px. The numbers 4 and 8 are easily multiplied, they provide flexible and consistent,
|
|
153
|
+
yet distinct enough, steps between them.In the search of consistent alignment between the elements we
|
|
154
|
+
provide a spacing scale based on a root values of 8px and 4px. The numbers 4 and 8 are easily
|
|
155
|
+
multiplied, they provide flexible and consistent, yet distinct enough, steps between them.In the search
|
|
156
|
+
of consistent alignment between the elements we provide a spacing scale based on a root values of 8px
|
|
157
|
+
and 4px. The numbers 4 and 8 are easily multiplied, they provide flexible and consistent, yet distinct
|
|
158
|
+
enough, steps between them.In the search of consistent alignment between the elements we provide a
|
|
159
|
+
spacing scale based on a root values of 8px and 4px. The numbers 4 and 8 are easily multiplied, they
|
|
160
|
+
provide flexible and consistent, yet distinct enough, steps between them.In the search of consistent
|
|
161
|
+
alignment between the elements we provide a spacing scale based on a root values of 8px and 4px. The
|
|
162
|
+
numbers 4 and 8 are easily multiplied, they provide flexible and consistent, yet distinct enough, steps
|
|
163
|
+
between them.In the search of consistent alignment between the elements we provide a spacing scale based
|
|
164
|
+
on a root values of 8px and 4px. The numbers 4 and 8 are easily multiplied, they provide flexible and
|
|
165
|
+
consistent, yet distinct enough, steps between them.In the search of consistent alignment between the
|
|
166
|
+
elements we provide a spacing scale based on a root values of 8px and 4px. The numbers 4 and 8 are
|
|
167
|
+
easily multiplied, they provide flexible and consistent, yet distinct enough, steps between them.
|
|
168
|
+
</DxcText>
|
|
169
|
+
</Content>
|
|
170
|
+
<Content id="typography">
|
|
171
|
+
<DxcHeading level={2} text="Typography" margin={{ top: "xsmall", bottom: "xsmall" }} />
|
|
172
|
+
<DxcText>
|
|
173
|
+
Our selected typography helps in structuring our user's experience based on the visual impact that it
|
|
174
|
+
has on the user interface content. It defines what is the first noticeable piece of information or data
|
|
175
|
+
based on the font shape, size, color, or type and it highlights some pieces of text over the rest. Some
|
|
176
|
+
typographic elements used in Halstack Design System include headers, body, taglines, captions, and
|
|
177
|
+
labels. Make sure you include all the different typographic variants in order to enhance the
|
|
178
|
+
application's content structure, including the Heading component which defines different levels of page
|
|
179
|
+
and section titles.Our selected typography helps in structuring our user's experience based on the
|
|
180
|
+
visual impact that it has on the user interface content. It defines what is the first noticeable piece
|
|
181
|
+
of information or data based on the font shape, size, color, or type and it highlights some pieces of
|
|
182
|
+
text over the rest. Some typographic elements used in Halstack Design System include headers, body,
|
|
183
|
+
taglines, captions, and labels. Make sure you include all the different typographic variants in order to
|
|
184
|
+
enhance the application's content structure, including the Heading component which defines different
|
|
185
|
+
levels of page and section titles.Our selected typography helps in structuring our user's experience
|
|
186
|
+
based on the visual impact that it has on the user interface content. It defines what is the first
|
|
187
|
+
noticeable piece of information or data based on the font shape, size, color, or type and it highlights
|
|
188
|
+
some pieces of text over the rest. Some typographic elements used in Halstack Design System include
|
|
189
|
+
headers, body, taglines, captions, and labels. Make sure you include all the different typographic
|
|
190
|
+
variants in order to enhance the application's content structure, including the Heading component which
|
|
191
|
+
defines different levels of page and section titles.Our selected typography helps in structuring our
|
|
192
|
+
user's experience based on the visual impact that it has on the user interface content. It defines what
|
|
193
|
+
is the first noticeable piece of information or data based on the font shape, size, color, or type and
|
|
194
|
+
it highlights some pieces of text over the rest. Some typographic elements used in Halstack Design
|
|
195
|
+
System include headers, body, taglines, captions, and labels. Make sure you include all the different
|
|
196
|
+
typographic variants in order to enhance the application's content structure, including the Heading
|
|
197
|
+
component which defines different levels of page and section titles.Our selected typography helps in
|
|
198
|
+
structuring our user's experience based on the visual impact that it has on the user interface content.
|
|
199
|
+
It defines what is the first noticeable piece of information or data based on the font shape, size,
|
|
200
|
+
color, or type and it highlights some pieces of text over the rest. Some typographic elements used in
|
|
201
|
+
Halstack Design System include headers, body, taglines, captions, and labels. Make sure you include all
|
|
202
|
+
the different typographic variants in order to enhance the application's content structure, including
|
|
203
|
+
the Heading component which defines different levels of page and section titles.
|
|
204
|
+
</DxcText>
|
|
205
|
+
</Content>
|
|
206
|
+
</Content>
|
|
207
|
+
</ContentContainer>
|
|
208
|
+
<QuickNavContainer>
|
|
209
|
+
<DxcQuickNav title="Sections" links={links}></DxcQuickNav>
|
|
210
|
+
</QuickNavContainer>
|
|
211
|
+
</Container>
|
|
212
|
+
</ExampleContainer>
|
|
213
|
+
</>
|
|
214
|
+
);
|
|
215
|
+
|
|
216
|
+
const Container = styled.div`
|
|
217
|
+
display: flex;
|
|
218
|
+
flex-direction: row;
|
|
219
|
+
width: 100%;
|
|
220
|
+
`;
|
|
221
|
+
|
|
222
|
+
const ContentContainer = styled.div`
|
|
223
|
+
display: flex;
|
|
224
|
+
flex-direction: column;
|
|
225
|
+
padding: 60px;
|
|
226
|
+
margin: 0 auto;
|
|
227
|
+
width: 800px;
|
|
228
|
+
`;
|
|
229
|
+
|
|
230
|
+
const Content = styled.div``;
|
|
231
|
+
|
|
232
|
+
const QuickNavContainer = styled.div`
|
|
233
|
+
max-height: calc(100vh - 100px);
|
|
234
|
+
position: sticky;
|
|
235
|
+
top: 100px;
|
|
236
|
+
width: 300px;
|
|
237
|
+
`;
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
declare type Props = {
|
|
2
|
+
/**
|
|
3
|
+
* Title of the quick nav component.
|
|
4
|
+
*/
|
|
5
|
+
title: string;
|
|
6
|
+
/**
|
|
7
|
+
* Links to be shown inside the quick nav component.
|
|
8
|
+
*/
|
|
9
|
+
links: Link[];
|
|
10
|
+
};
|
|
11
|
+
declare type Link = {
|
|
12
|
+
/**
|
|
13
|
+
* Label to be shown in the link.
|
|
14
|
+
*/
|
|
15
|
+
label: string;
|
|
16
|
+
/**
|
|
17
|
+
* Sublinks of the link.
|
|
18
|
+
*/
|
|
19
|
+
links?: Link[];
|
|
20
|
+
};
|
|
21
|
+
export default Props;
|
package/radio/Radio.js
CHANGED
|
@@ -27,9 +27,9 @@ var _variables = require("../common/variables.js");
|
|
|
27
27
|
|
|
28
28
|
var _utils = require("../common/utils.js");
|
|
29
29
|
|
|
30
|
-
var _useTheme = _interopRequireDefault(require("../useTheme
|
|
30
|
+
var _useTheme = _interopRequireDefault(require("../useTheme"));
|
|
31
31
|
|
|
32
|
-
var _BackgroundColorContext = _interopRequireDefault(require("../BackgroundColorContext
|
|
32
|
+
var _BackgroundColorContext = _interopRequireDefault(require("../BackgroundColorContext"));
|
|
33
33
|
|
|
34
34
|
var _templateObject, _templateObject2;
|
|
35
35
|
|
|
@@ -0,0 +1,71 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
+
|
|
5
|
+
var _react = _interopRequireDefault(require("react"));
|
|
6
|
+
|
|
7
|
+
var _react2 = require("@testing-library/react");
|
|
8
|
+
|
|
9
|
+
var _Radio = _interopRequireDefault(require("./Radio"));
|
|
10
|
+
|
|
11
|
+
describe("Radio component tests", function () {
|
|
12
|
+
test("Radio renders correctly", function () {
|
|
13
|
+
var _render = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Radio["default"], {
|
|
14
|
+
label: "Radio button"
|
|
15
|
+
})),
|
|
16
|
+
getByText = _render.getByText;
|
|
17
|
+
|
|
18
|
+
expect(getByText("Radio button")).toBeTruthy();
|
|
19
|
+
});
|
|
20
|
+
test("Calls correct function on click", function () {
|
|
21
|
+
var onClick = jest.fn();
|
|
22
|
+
|
|
23
|
+
var _render2 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Radio["default"], {
|
|
24
|
+
label: "Radio button",
|
|
25
|
+
onClick: onClick
|
|
26
|
+
})),
|
|
27
|
+
getByText = _render2.getByText;
|
|
28
|
+
|
|
29
|
+
_react2.fireEvent.click(getByText("Radio button"));
|
|
30
|
+
|
|
31
|
+
expect(onClick).toHaveBeenCalled();
|
|
32
|
+
expect(onClick).toHaveBeenCalledWith(true);
|
|
33
|
+
});
|
|
34
|
+
test("Controlled Radio", function () {
|
|
35
|
+
var onClick = jest.fn();
|
|
36
|
+
|
|
37
|
+
var _render3 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Radio["default"], {
|
|
38
|
+
label: "Radio button",
|
|
39
|
+
checked: false,
|
|
40
|
+
onClick: onClick
|
|
41
|
+
})),
|
|
42
|
+
getByText = _render3.getByText,
|
|
43
|
+
getByRole = _render3.getByRole;
|
|
44
|
+
|
|
45
|
+
expect(getByRole("radio").checked).toBe(false);
|
|
46
|
+
|
|
47
|
+
_react2.fireEvent.click(getByText("Radio button"));
|
|
48
|
+
|
|
49
|
+
expect(onClick).toHaveBeenCalled();
|
|
50
|
+
expect(onClick).toHaveBeenCalledWith(true);
|
|
51
|
+
expect(getByRole("radio").checked).toBe(false);
|
|
52
|
+
});
|
|
53
|
+
test("Uncontrolled Radio", function () {
|
|
54
|
+
var onClick = jest.fn();
|
|
55
|
+
|
|
56
|
+
var _render4 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Radio["default"], {
|
|
57
|
+
label: "Radio button",
|
|
58
|
+
onClick: onClick
|
|
59
|
+
})),
|
|
60
|
+
getByText = _render4.getByText,
|
|
61
|
+
getByRole = _render4.getByRole;
|
|
62
|
+
|
|
63
|
+
expect(getByRole("radio").checked).toBe(false);
|
|
64
|
+
|
|
65
|
+
_react2.fireEvent.click(getByText("Radio button"));
|
|
66
|
+
|
|
67
|
+
expect(onClick).toHaveBeenCalled();
|
|
68
|
+
expect(onClick).toHaveBeenCalledWith(true);
|
|
69
|
+
expect(getByRole("radio").checked).toBe(false);
|
|
70
|
+
});
|
|
71
|
+
});
|