@dxc-technology/halstack-react 0.0.0-d1e7610 → 0.0.0-d201da1
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/HalstackContext.d.ts +12 -0
- package/HalstackContext.js +295 -0
- package/accordion/Accordion.d.ts +1 -1
- package/accordion/Accordion.js +15 -47
- 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 +16 -17
- package/accordion-group/AccordionGroup.stories.tsx +225 -0
- package/accordion-group/AccordionGroup.test.js +151 -0
- package/accordion-group/types.d.ts +8 -8
- package/alert/Alert.js +6 -3
- package/alert/Alert.test.js +92 -0
- package/alert/types.d.ts +1 -1
- package/badge/Badge.d.ts +4 -0
- package/badge/Badge.js +6 -4
- package/badge/types.d.ts +5 -0
- package/{radio → badge}/types.js +0 -0
- package/bleed/Bleed.d.ts +3 -0
- package/bleed/Bleed.js +51 -0
- package/bleed/Bleed.stories.tsx +341 -0
- package/bleed/types.d.ts +37 -0
- package/bleed/types.js +5 -0
- package/box/Box.d.ts +1 -1
- package/box/Box.js +26 -39
- package/box/Box.test.js +18 -0
- package/box/types.d.ts +0 -4
- package/button/Button.d.ts +1 -1
- package/button/Button.js +24 -27
- package/button/Button.stories.tsx +6 -8
- package/button/Button.test.js +35 -0
- package/button/types.d.ts +5 -9
- package/card/Card.js +26 -30
- package/card/Card.stories.tsx +201 -0
- package/card/Card.test.js +50 -0
- package/card/ice-cream.jpg +0 -0
- package/card/types.d.ts +4 -6
- package/checkbox/Checkbox.d.ts +1 -1
- package/checkbox/Checkbox.js +45 -41
- package/checkbox/Checkbox.stories.tsx +124 -128
- package/checkbox/Checkbox.test.js +78 -0
- package/checkbox/types.d.ts +9 -5
- 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 +234 -341
- package/date-input/DateInput.js +63 -52
- 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 +22 -48
- package/dropdown/Dropdown.stories.tsx +249 -0
- package/dropdown/Dropdown.test.js +189 -0
- package/dropdown/types.d.ts +6 -15
- package/file-input/FileInput.d.ts +4 -0
- package/file-input/FileInput.js +172 -111
- package/file-input/FileInput.stories.tsx +507 -0
- package/file-input/FileInput.test.js +457 -0
- package/file-input/FileItem.d.ts +14 -0
- package/file-input/FileItem.js +16 -23
- package/file-input/types.d.ts +112 -0
- package/file-input/types.js +5 -0
- package/footer/Footer.d.ts +1 -1
- package/footer/Footer.js +32 -113
- 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 +4 -4
- package/footer/types.d.ts +21 -17
- package/header/Header.js +29 -50
- package/header/Header.stories.tsx +172 -0
- package/header/Header.test.js +79 -0
- package/header/Icons.d.ts +2 -0
- package/header/types.d.ts +4 -2
- package/heading/Heading.js +1 -1
- package/heading/Heading.stories.tsx +54 -0
- package/heading/Heading.test.js +186 -0
- package/inline/Inline.d.ts +4 -0
- package/inline/Inline.js +60 -0
- package/inline/Inline.stories.tsx +319 -0
- package/inline/types.d.ts +36 -0
- package/inline/types.js +5 -0
- package/inset/Inset.d.ts +3 -0
- package/inset/Inset.js +51 -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 +11 -0
- package/layout/ApplicationLayout.js +84 -120
- package/layout/ApplicationLayout.stories.tsx +126 -0
- package/layout/Icons.d.ts +5 -0
- package/layout/Icons.js +13 -2
- package/layout/SidenavContext.d.ts +5 -0
- package/layout/SidenavContext.js +19 -0
- package/layout/types.d.ts +52 -0
- package/layout/types.js +5 -0
- package/link/Link.d.ts +3 -2
- package/link/Link.js +61 -86
- package/link/Link.stories.tsx +131 -15
- package/link/Link.test.js +83 -0
- package/link/types.d.ts +9 -29
- package/list/List.d.ts +4 -0
- package/list/List.js +47 -0
- package/list/List.stories.tsx +89 -0
- package/list/types.d.ts +7 -0
- package/list/types.js +5 -0
- package/main.d.ts +13 -9
- package/main.js +80 -42
- 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/NumberInputContext.d.ts +4 -0
- package/number-input/NumberInputContext.js +5 -2
- package/number-input/numberInputContextTypes.d.ts +19 -0
- package/number-input/numberInputContextTypes.js +5 -0
- package/number-input/types.d.ts +17 -10
- package/package.json +10 -6
- package/paginator/Paginator.js +19 -46
- package/paginator/Paginator.test.js +308 -0
- package/password-input/PasswordInput.js +23 -19
- package/password-input/PasswordInput.stories.tsx +3 -3
- package/password-input/PasswordInput.test.js +180 -0
- package/password-input/types.d.ts +29 -19
- package/progress-bar/ProgressBar.js +5 -5
- package/progress-bar/ProgressBar.stories.jsx +11 -11
- package/progress-bar/ProgressBar.test.js +65 -0
- package/quick-nav/QuickNav.d.ts +4 -0
- package/quick-nav/QuickNav.js +116 -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-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 +282 -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.d.ts +4 -0
- package/resultsetTable/ResultsetTable.js +9 -29
- package/resultsetTable/ResultsetTable.stories.tsx +275 -0
- package/resultsetTable/ResultsetTable.test.js +348 -0
- package/resultsetTable/types.d.ts +67 -0
- package/resultsetTable/types.js +5 -0
- 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 +175 -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 +161 -366
- package/select/Select.stories.tsx +230 -176
- package/select/Select.test.js +2162 -0
- package/select/types.d.ts +212 -0
- package/select/types.js +5 -0
- package/sidenav/Sidenav.d.ts +1 -1
- package/sidenav/Sidenav.js +22 -11
- package/sidenav/Sidenav.stories.tsx +182 -0
- package/sidenav/Sidenav.test.js +56 -0
- package/slider/Slider.d.ts +1 -1
- package/slider/Slider.js +6 -5
- 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 +3 -3
- package/spinner/Spinner.stories.jsx +1 -0
- package/spinner/Spinner.test.js +64 -0
- package/stack/Stack.d.ts +4 -0
- package/stack/Stack.js +56 -0
- package/stack/Stack.stories.tsx +263 -0
- package/stack/types.d.ts +32 -0
- package/stack/types.js +5 -0
- package/switch/Switch.d.ts +1 -1
- package/switch/Switch.js +37 -21
- package/switch/Switch.stories.tsx +15 -15
- package/switch/Switch.test.js +98 -0
- package/switch/types.d.ts +6 -2
- package/table/Table.js +3 -3
- 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 +20 -20
- package/tabs/Tabs.stories.tsx +112 -0
- package/tabs/Tabs.test.js +140 -0
- package/tabs/types.d.ts +29 -18
- package/tabs-nav/NavTabs.d.ts +8 -0
- package/tabs-nav/NavTabs.js +125 -0
- package/tabs-nav/NavTabs.stories.tsx +170 -0
- package/tabs-nav/NavTabs.test.js +82 -0
- package/tabs-nav/Tab.d.ts +4 -0
- package/tabs-nav/Tab.js +132 -0
- package/tabs-nav/types.d.ts +53 -0
- package/tabs-nav/types.js +5 -0
- package/tag/Tag.d.ts +1 -1
- package/tag/Tag.js +18 -28
- 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/Suggestion.d.ts +4 -0
- package/text-input/Suggestion.js +55 -0
- package/text-input/TextInput.d.ts +4 -0
- package/text-input/TextInput.js +91 -146
- package/text-input/TextInput.stories.tsx +474 -0
- package/text-input/TextInput.test.js +1712 -0
- package/text-input/types.d.ts +178 -0
- package/text-input/types.js +5 -0
- package/textarea/Textarea.d.ts +4 -0
- package/textarea/Textarea.js +39 -79
- 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 +4 -0
- package/toggle-group/ToggleGroup.js +18 -46
- package/toggle-group/ToggleGroup.stories.tsx +27 -32
- package/toggle-group/ToggleGroup.test.js +156 -0
- package/toggle-group/types.d.ts +105 -0
- package/toggle-group/types.js +5 -0
- package/useTheme.d.ts +2 -0
- package/useTheme.js +2 -2
- package/useTranslatedLabels.d.ts +2 -0
- package/useTranslatedLabels.js +20 -0
- package/wizard/Wizard.d.ts +1 -1
- package/wizard/Wizard.js +107 -46
- package/wizard/{Wizard.stories.jsx → Wizard.stories.tsx} +13 -23
- package/wizard/Wizard.test.js +141 -0
- package/wizard/types.d.ts +9 -9
- package/ThemeContext.js +0 -246
- 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/file-input/index.d.ts +0 -81
- package/input-text/Icons.js +0 -22
- package/input-text/InputText.js +0 -611
- package/input-text/index.d.ts +0 -36
- package/radio/Radio.d.ts +0 -4
- package/radio/Radio.js +0 -174
- package/radio/Radio.stories.tsx +0 -192
- package/radio/types.d.ts +0 -54
- package/resultsetTable/index.d.ts +0 -19
- package/select/index.d.ts +0 -131
- package/text-input/index.d.ts +0 -135
- package/textarea/index.d.ts +0 -117
- package/toggle/Toggle.js +0 -186
- package/toggle/index.d.ts +0 -21
- package/toggle-group/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
|
@@ -37,7 +37,7 @@ export const Chromatic = () => (
|
|
|
37
37
|
label="Slider"
|
|
38
38
|
helperText="Help message"
|
|
39
39
|
disabled
|
|
40
|
-
|
|
40
|
+
defaultValue={40}
|
|
41
41
|
minValue={0}
|
|
42
42
|
maxValue={50}
|
|
43
43
|
showLimitsValues
|
|
@@ -49,16 +49,16 @@ export const Chromatic = () => (
|
|
|
49
49
|
<Title title="Variants" theme="light" level={2} />
|
|
50
50
|
<ExampleContainer>
|
|
51
51
|
<Title title="Continuous slider" theme="light" level={4} />
|
|
52
|
-
<DxcSlider
|
|
52
|
+
<DxcSlider defaultValue={65} label="Slider" helperText="Help message" showLimitsValues />
|
|
53
53
|
</ExampleContainer>
|
|
54
54
|
<ExampleContainer>
|
|
55
55
|
<Title title="Discrete slider" theme="light" level={4} />
|
|
56
|
-
<DxcSlider
|
|
56
|
+
<DxcSlider defaultValue={20} label="Slider" helperText="Help message" showLimitsValues marks step={5} />
|
|
57
57
|
</ExampleContainer>
|
|
58
58
|
<ExampleContainer>
|
|
59
59
|
<Title title="Discrete slider with input" theme="light" level={4} />
|
|
60
60
|
<DxcSlider
|
|
61
|
-
|
|
61
|
+
defaultValue={20}
|
|
62
62
|
minValue={0}
|
|
63
63
|
maxValue={50}
|
|
64
64
|
label="Slider"
|
|
@@ -94,7 +94,7 @@ export const Chromatic = () => (
|
|
|
94
94
|
label="Slider"
|
|
95
95
|
helperText="Help message"
|
|
96
96
|
disabled
|
|
97
|
-
|
|
97
|
+
defaultValue={40}
|
|
98
98
|
minValue={0}
|
|
99
99
|
maxValue={50}
|
|
100
100
|
showLimitsValues
|
|
@@ -105,16 +105,16 @@ export const Chromatic = () => (
|
|
|
105
105
|
</ExampleContainer>
|
|
106
106
|
<ExampleContainer>
|
|
107
107
|
<Title title="Continuous slider" theme="dark" level={4} />
|
|
108
|
-
<DxcSlider
|
|
108
|
+
<DxcSlider defaultValue={65} label="Slider" helperText="Help message" showLimitsValues />
|
|
109
109
|
</ExampleContainer>
|
|
110
110
|
<ExampleContainer>
|
|
111
111
|
<Title title="Discrete slider" theme="dark" level={4} />
|
|
112
|
-
<DxcSlider
|
|
112
|
+
<DxcSlider defaultValue={20} label="Slider" helperText="Help message" showLimitsValues marks step={5} />
|
|
113
113
|
</ExampleContainer>
|
|
114
114
|
<ExampleContainer>
|
|
115
115
|
<Title title="Discrete slider with input" theme="dark" level={4} />
|
|
116
116
|
<DxcSlider
|
|
117
|
-
|
|
117
|
+
defaultValue={20}
|
|
118
118
|
minValue={0}
|
|
119
119
|
maxValue={50}
|
|
120
120
|
label="Slider"
|
|
@@ -0,0 +1,150 @@
|
|
|
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 _Slider = _interopRequireDefault(require("./Slider"));
|
|
10
|
+
|
|
11
|
+
describe("Slider component tests", function () {
|
|
12
|
+
test("Slider renders with correct text", function () {
|
|
13
|
+
var _render = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Slider["default"], {
|
|
14
|
+
minValue: 0,
|
|
15
|
+
maxValue: 100,
|
|
16
|
+
showLimitsValues: true
|
|
17
|
+
})),
|
|
18
|
+
getByText = _render.getByText;
|
|
19
|
+
|
|
20
|
+
expect(getByText("0")).toBeTruthy();
|
|
21
|
+
expect(getByText("100")).toBeTruthy();
|
|
22
|
+
});
|
|
23
|
+
test("Slider renders with correct initial value when it is uncontrolled", function () {
|
|
24
|
+
var _render2 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Slider["default"], {
|
|
25
|
+
defaultValue: 30,
|
|
26
|
+
minValue: 0,
|
|
27
|
+
maxValue: 100,
|
|
28
|
+
showLimitsValues: true,
|
|
29
|
+
showInput: true
|
|
30
|
+
})),
|
|
31
|
+
getByRole = _render2.getByRole;
|
|
32
|
+
|
|
33
|
+
var slider = getByRole("slider");
|
|
34
|
+
var input = getByRole("textbox");
|
|
35
|
+
expect(slider.getAttribute("aria-valuenow")).toBe("30");
|
|
36
|
+
expect(input.value).toBe("30");
|
|
37
|
+
});
|
|
38
|
+
test("Calls correct function onChange in controlled slider", function () {
|
|
39
|
+
var onChange = jest.fn();
|
|
40
|
+
|
|
41
|
+
var _render3 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Slider["default"], {
|
|
42
|
+
minValue: 0,
|
|
43
|
+
maxValue: 100,
|
|
44
|
+
onChange: onChange,
|
|
45
|
+
showLimitsValues: true,
|
|
46
|
+
value: 13,
|
|
47
|
+
showInput: true
|
|
48
|
+
})),
|
|
49
|
+
getByRole = _render3.getByRole;
|
|
50
|
+
|
|
51
|
+
expect(getByRole("slider").getAttribute("aria-valuenow")).toBe("13");
|
|
52
|
+
expect(getByRole("textbox").value).toBe("13");
|
|
53
|
+
(0, _react2.act)(function () {
|
|
54
|
+
_react2.fireEvent.change(getByRole("textbox"), {
|
|
55
|
+
target: {
|
|
56
|
+
value: 25
|
|
57
|
+
}
|
|
58
|
+
});
|
|
59
|
+
});
|
|
60
|
+
expect(onChange).toHaveBeenCalledWith(25);
|
|
61
|
+
expect(getByRole("slider").getAttribute("aria-valuenow")).toBe("13");
|
|
62
|
+
expect(getByRole("textbox").value).toBe("13");
|
|
63
|
+
});
|
|
64
|
+
test("Calls correct function onChange in uncontrolled slider", function () {
|
|
65
|
+
var onChange = jest.fn();
|
|
66
|
+
|
|
67
|
+
var _render4 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Slider["default"], {
|
|
68
|
+
minValue: 0,
|
|
69
|
+
maxValue: 100,
|
|
70
|
+
onChange: onChange,
|
|
71
|
+
showLimitsValues: true,
|
|
72
|
+
showInput: true
|
|
73
|
+
})),
|
|
74
|
+
getByRole = _render4.getByRole;
|
|
75
|
+
|
|
76
|
+
(0, _react2.act)(function () {
|
|
77
|
+
_react2.fireEvent.change(getByRole("textbox"), {
|
|
78
|
+
target: {
|
|
79
|
+
value: 25
|
|
80
|
+
}
|
|
81
|
+
});
|
|
82
|
+
});
|
|
83
|
+
expect(onChange).toHaveBeenCalledWith(25);
|
|
84
|
+
expect(getByRole("slider").getAttribute("aria-valuenow")).toBe("25");
|
|
85
|
+
expect(getByRole("textbox").value).toBe("25");
|
|
86
|
+
});
|
|
87
|
+
test("Disabled slider have disabled input", function () {
|
|
88
|
+
var onChange = jest.fn();
|
|
89
|
+
|
|
90
|
+
var _render5 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Slider["default"], {
|
|
91
|
+
minValue: 0,
|
|
92
|
+
maxValue: 100,
|
|
93
|
+
onChange: onChange,
|
|
94
|
+
showLimitsValues: true,
|
|
95
|
+
disabled: true,
|
|
96
|
+
showInput: true,
|
|
97
|
+
value: 13
|
|
98
|
+
})),
|
|
99
|
+
getByRole = _render5.getByRole;
|
|
100
|
+
|
|
101
|
+
(0, _react2.act)(function () {
|
|
102
|
+
_react2.fireEvent.change(getByRole("textbox"), {
|
|
103
|
+
target: {
|
|
104
|
+
value: 25
|
|
105
|
+
}
|
|
106
|
+
});
|
|
107
|
+
});
|
|
108
|
+
expect(getByRole("textbox").hasAttribute("disabled")).toBeTruthy();
|
|
109
|
+
expect(getByRole("textbox").value).toBe("13");
|
|
110
|
+
});
|
|
111
|
+
test("Calls correct function onDragEnd", function () {
|
|
112
|
+
var onDragEnd = jest.fn();
|
|
113
|
+
|
|
114
|
+
var _render6 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Slider["default"], {
|
|
115
|
+
minValue: 0,
|
|
116
|
+
maxValue: 100,
|
|
117
|
+
showLimitsValues: true,
|
|
118
|
+
showInput: true,
|
|
119
|
+
onDragEnd: onDragEnd,
|
|
120
|
+
value: 25
|
|
121
|
+
})),
|
|
122
|
+
getByRole = _render6.getByRole;
|
|
123
|
+
|
|
124
|
+
(0, _react2.act)(function () {
|
|
125
|
+
_react2.fireEvent.mouseDown(getByRole("slider"));
|
|
126
|
+
|
|
127
|
+
_react2.fireEvent.mouseUp(getByRole("slider"));
|
|
128
|
+
});
|
|
129
|
+
expect(onDragEnd).toHaveBeenCalled();
|
|
130
|
+
});
|
|
131
|
+
test("Calls correct function labelFormatCallback", function () {
|
|
132
|
+
var labelFormatCallback = jest.fn(function (x) {
|
|
133
|
+
return "".concat(x, "$");
|
|
134
|
+
});
|
|
135
|
+
|
|
136
|
+
var _render7 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Slider["default"], {
|
|
137
|
+
minValue: 0,
|
|
138
|
+
maxValue: 100,
|
|
139
|
+
showLimitsValues: true,
|
|
140
|
+
showInput: true,
|
|
141
|
+
value: 25,
|
|
142
|
+
labelFormatCallback: labelFormatCallback
|
|
143
|
+
})),
|
|
144
|
+
getByText = _render7.getByText;
|
|
145
|
+
|
|
146
|
+
expect(getByText("0$")).toBeTruthy();
|
|
147
|
+
expect(getByText("100$")).toBeTruthy();
|
|
148
|
+
expect(labelFormatCallback).toHaveBeenCalledTimes(2);
|
|
149
|
+
});
|
|
150
|
+
});
|
package/slider/types.d.ts
CHANGED
|
@@ -14,6 +14,10 @@ declare type Props = {
|
|
|
14
14
|
* Name attribute of the input element.
|
|
15
15
|
*/
|
|
16
16
|
name?: string;
|
|
17
|
+
/**
|
|
18
|
+
* Initial value of the slider, only when it is uncontrolled.
|
|
19
|
+
*/
|
|
20
|
+
defaultValue?: number;
|
|
17
21
|
/**
|
|
18
22
|
* The selected value. If undefined, the component will be uncontrolled and the value will be managed internally by the component.
|
|
19
23
|
*/
|
package/spinner/Spinner.js
CHANGED
|
@@ -19,9 +19,9 @@ var _styledComponents = _interopRequireWildcard(require("styled-components"));
|
|
|
19
19
|
|
|
20
20
|
var _variables = require("../common/variables.js");
|
|
21
21
|
|
|
22
|
-
var _useTheme = _interopRequireDefault(require("../useTheme
|
|
22
|
+
var _useTheme = _interopRequireDefault(require("../useTheme"));
|
|
23
23
|
|
|
24
|
-
var _BackgroundColorContext = _interopRequireDefault(require("../BackgroundColorContext
|
|
24
|
+
var _BackgroundColorContext = _interopRequireDefault(require("../BackgroundColorContext"));
|
|
25
25
|
|
|
26
26
|
var _templateObject, _templateObject2, _templateObject3, _templateObject4, _templateObject5, _templateObject6, _templateObject7, _templateObject8, _templateObject9, _templateObject10, _templateObject11, _templateObject12;
|
|
27
27
|
|
|
@@ -199,7 +199,7 @@ var SVGSpinner = _styledComponents["default"].svg(_templateObject8 || (_template
|
|
|
199
199
|
var CircleSpinner = _styledComponents["default"].circle(_templateObject9 || (_templateObject9 = (0, _taggedTemplateLiteral2["default"])(["\n fill: transparent;\n stroke-linecap: initial;\n vector-effect: non-scaling-stroke;\n animation: ", ";\n stroke: ", ";\n transform-origin: ", ";\n stroke-dasharray: ", ";\n stroke-width: ", ";\n stroke-dashoffset: ", ";\n"])), function (props) {
|
|
200
200
|
return props.isDeterminated ? "none" : props.mode !== "small" ? "1.4s ease-in-out infinite both svg-circle-large" : "1.4s ease-in-out infinite both svg-circle-small";
|
|
201
201
|
}, function (props) {
|
|
202
|
-
return props.backgroundType === "dark" ? props.theme.
|
|
202
|
+
return props.backgroundType === "dark" || props.mode === "overlay" ? props.theme.trackCircleColorOverlay : props.theme.trackCircleColor;
|
|
203
203
|
}, function (props) {
|
|
204
204
|
return !props.isDeterminated ? "50% 50%" : "";
|
|
205
205
|
}, function (props) {
|
|
@@ -62,6 +62,7 @@ export const Chromatic = () => (
|
|
|
62
62
|
<DxcSpinner margin="xlarge" mode="small" value="75"></DxcSpinner>
|
|
63
63
|
<Title title="Xxlarge margin" theme="light" level={4} />
|
|
64
64
|
<DxcSpinner margin="xxlarge" mode="small" value="75"></DxcSpinner>
|
|
65
|
+
<hr />
|
|
65
66
|
</ExampleContainer>
|
|
66
67
|
</>
|
|
67
68
|
);
|
|
@@ -0,0 +1,64 @@
|
|
|
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 _Spinner = _interopRequireDefault(require("./Spinner"));
|
|
10
|
+
|
|
11
|
+
describe("Spinner component tests", function () {
|
|
12
|
+
test("Spinner renders with correct label", function () {
|
|
13
|
+
var _render = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Spinner["default"], {
|
|
14
|
+
label: "test-loading"
|
|
15
|
+
})),
|
|
16
|
+
getByText = _render.getByText;
|
|
17
|
+
|
|
18
|
+
expect(getByText("test-loading")).toBeTruthy();
|
|
19
|
+
});
|
|
20
|
+
test("Spinner shows value correctly", function () {
|
|
21
|
+
var _render2 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Spinner["default"], {
|
|
22
|
+
label: "test-loading",
|
|
23
|
+
value: 75,
|
|
24
|
+
showValue: true
|
|
25
|
+
})),
|
|
26
|
+
getByText = _render2.getByText;
|
|
27
|
+
|
|
28
|
+
expect(getByText("75%")).toBeTruthy();
|
|
29
|
+
});
|
|
30
|
+
test("Small spinner hides value and label correctly", function () {
|
|
31
|
+
var _render3 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Spinner["default"], {
|
|
32
|
+
mode: "small",
|
|
33
|
+
label: "test-loading",
|
|
34
|
+
value: 75,
|
|
35
|
+
showValue: true
|
|
36
|
+
})),
|
|
37
|
+
queryByText = _render3.queryByText;
|
|
38
|
+
|
|
39
|
+
expect(queryByText("test-loading")).toBeFalsy();
|
|
40
|
+
expect(queryByText("75%")).toBeFalsy();
|
|
41
|
+
});
|
|
42
|
+
test("Overlay spinner shows value and label correctly", function () {
|
|
43
|
+
var _render4 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Spinner["default"], {
|
|
44
|
+
mode: "overlay",
|
|
45
|
+
label: "test-loading",
|
|
46
|
+
value: 75,
|
|
47
|
+
showValue: true
|
|
48
|
+
})),
|
|
49
|
+
getByText = _render4.getByText;
|
|
50
|
+
|
|
51
|
+
expect(getByText("test-loading")).toBeTruthy();
|
|
52
|
+
expect(getByText("75%")).toBeTruthy();
|
|
53
|
+
});
|
|
54
|
+
test("Get spinner by role", function () {
|
|
55
|
+
var _render5 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Spinner["default"], {
|
|
56
|
+
label: "test-loading",
|
|
57
|
+
value: 75,
|
|
58
|
+
showValue: true
|
|
59
|
+
})),
|
|
60
|
+
getByRole = _render5.getByRole;
|
|
61
|
+
|
|
62
|
+
expect(getByRole("progressbar")).toBeTruthy();
|
|
63
|
+
});
|
|
64
|
+
});
|
package/stack/Stack.d.ts
ADDED
package/stack/Stack.js
ADDED
|
@@ -0,0 +1,56 @@
|
|
|
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 _templateObject, _templateObject2;
|
|
17
|
+
|
|
18
|
+
var DxcStack = function DxcStack(_ref) {
|
|
19
|
+
var _ref$alignX = _ref.alignX,
|
|
20
|
+
alignX = _ref$alignX === void 0 ? "stretch" : _ref$alignX,
|
|
21
|
+
_ref$as = _ref.as,
|
|
22
|
+
as = _ref$as === void 0 ? "div" : _ref$as,
|
|
23
|
+
_ref$divider = _ref.divider,
|
|
24
|
+
divider = _ref$divider === void 0 ? false : _ref$divider,
|
|
25
|
+
_ref$gutter = _ref.gutter,
|
|
26
|
+
gutter = _ref$gutter === void 0 ? "0rem" : _ref$gutter,
|
|
27
|
+
_ref$reverse = _ref.reverse,
|
|
28
|
+
reverse = _ref$reverse === void 0 ? false : _ref$reverse,
|
|
29
|
+
_ref$wrap = _ref.wrap,
|
|
30
|
+
wrap = _ref$wrap === void 0 ? false : _ref$wrap,
|
|
31
|
+
children = _ref.children;
|
|
32
|
+
return /*#__PURE__*/_react["default"].createElement(Stack, {
|
|
33
|
+
gutter: gutter,
|
|
34
|
+
alignX: alignX,
|
|
35
|
+
reverse: reverse,
|
|
36
|
+
as: as,
|
|
37
|
+
divider: divider,
|
|
38
|
+
wrap: wrap
|
|
39
|
+
}, _react["default"].Children.map(children, function (child, index) {
|
|
40
|
+
return /*#__PURE__*/_react["default"].createElement(_react["default"].Fragment, null, child, divider && index !== _react["default"].Children.count(children) - 1 && /*#__PURE__*/_react["default"].createElement(Divider, null));
|
|
41
|
+
}));
|
|
42
|
+
};
|
|
43
|
+
|
|
44
|
+
var Divider = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n width: 100%;\n height: 1px;\n background-color: #999999;\n"])));
|
|
45
|
+
|
|
46
|
+
var Stack = _styledComponents["default"].div(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n ", "\n padding: 0px;\n margin: 0px;\n height: 100%;\n"])), function (_ref2) {
|
|
47
|
+
var alignX = _ref2.alignX,
|
|
48
|
+
gutter = _ref2.gutter,
|
|
49
|
+
reverse = _ref2.reverse,
|
|
50
|
+
divider = _ref2.divider,
|
|
51
|
+
wrap = _ref2.wrap;
|
|
52
|
+
return "\n flex-direction: ".concat(reverse ? "column-reverse" : "column", ";\n align-items: ").concat(alignX === "start" || alignX === "end" ? "flex-".concat(alignX) : alignX, ";\n gap: ").concat(divider ? "calc(".concat(gutter, "/2 - 1px)") : gutter, ";\n flex-wrap: ").concat(wrap ? "wrap" : "nowrap", ";\n ");
|
|
53
|
+
});
|
|
54
|
+
|
|
55
|
+
var _default = DxcStack;
|
|
56
|
+
exports["default"] = _default;
|
|
@@ -0,0 +1,263 @@
|
|
|
1
|
+
import React from "react";
|
|
2
|
+
import Title from "../../.storybook/components/Title";
|
|
3
|
+
import styled from "styled-components";
|
|
4
|
+
import DxcStack from "./Stack";
|
|
5
|
+
|
|
6
|
+
export default {
|
|
7
|
+
title: "Stack",
|
|
8
|
+
component: DxcStack,
|
|
9
|
+
};
|
|
10
|
+
|
|
11
|
+
export const Chromatic = () => (
|
|
12
|
+
<>
|
|
13
|
+
<Title title="Default" theme="light" level={4} />
|
|
14
|
+
<Container>
|
|
15
|
+
<DxcStack>
|
|
16
|
+
<Placeholder height="small" width="small" />
|
|
17
|
+
<Placeholder height="medium" width="medium" />
|
|
18
|
+
<Placeholder height="large" width="large" />
|
|
19
|
+
<Placeholder height="small" width="large" />
|
|
20
|
+
</DxcStack>
|
|
21
|
+
</Container>
|
|
22
|
+
<Title title="Default with divider" theme="light" level={4} />
|
|
23
|
+
<Container>
|
|
24
|
+
<DxcStack divider>
|
|
25
|
+
<Placeholder height="medium" width="medium" />
|
|
26
|
+
<Placeholder height="large" width="large" />
|
|
27
|
+
<Placeholder height="small" width="large" />
|
|
28
|
+
</DxcStack>
|
|
29
|
+
</Container>
|
|
30
|
+
<Title title="Alignment with divider" theme="light" level={4} />
|
|
31
|
+
<Container>
|
|
32
|
+
<DxcStack alignX="end" divider>
|
|
33
|
+
<Placeholder height="small" width="small" />
|
|
34
|
+
<Placeholder height="small" width="medium" />
|
|
35
|
+
<Placeholder height="medium" width="small" />
|
|
36
|
+
</DxcStack>
|
|
37
|
+
</Container>
|
|
38
|
+
<Title title="Default with one child" theme="light" level={4} />
|
|
39
|
+
<Container>
|
|
40
|
+
<DxcStack divider>
|
|
41
|
+
<Placeholder height="large" width="xlarge" />
|
|
42
|
+
</DxcStack>
|
|
43
|
+
</Container>
|
|
44
|
+
<Title title="Wrap" theme="light" level={4} />
|
|
45
|
+
<FlexContainer customHeight>
|
|
46
|
+
<DxcStack wrap>
|
|
47
|
+
<Placeholder height="small" width="small" />
|
|
48
|
+
<Placeholder height="large" width="medium" />
|
|
49
|
+
<Placeholder height="medium" width="small" />
|
|
50
|
+
<Placeholder height="large" width="medium" />
|
|
51
|
+
</DxcStack>
|
|
52
|
+
</FlexContainer>
|
|
53
|
+
<Title title="No wrap in a flex container" theme="light" level={4} />
|
|
54
|
+
<FlexContainer customHeight>
|
|
55
|
+
<DxcStack>
|
|
56
|
+
<Placeholder height="small" width="small" />
|
|
57
|
+
<Placeholder height="medium" width="small" />
|
|
58
|
+
<Placeholder height="small" width="medium" />
|
|
59
|
+
</DxcStack>
|
|
60
|
+
</FlexContainer>
|
|
61
|
+
<Title title="No wrap (default)" theme="light" level={4} />
|
|
62
|
+
<Container customHeight>
|
|
63
|
+
<DxcStack>
|
|
64
|
+
<Placeholder height="small" width="medium" />
|
|
65
|
+
<Placeholder height="small" width="small" />
|
|
66
|
+
</DxcStack>
|
|
67
|
+
</Container>
|
|
68
|
+
<Title title="AlignX = start" theme="light" level={4} />
|
|
69
|
+
<Container>
|
|
70
|
+
<DxcStack alignX="start">
|
|
71
|
+
<Placeholder height="small" width="small" />
|
|
72
|
+
<Placeholder height="large" width="medium" />
|
|
73
|
+
<Placeholder height="medium" width="small" />
|
|
74
|
+
<Placeholder height="large" width="medium" />
|
|
75
|
+
</DxcStack>
|
|
76
|
+
</Container>
|
|
77
|
+
<Title title="AlignX = end" theme="light" level={4} />
|
|
78
|
+
<Container>
|
|
79
|
+
<DxcStack alignX="end">
|
|
80
|
+
<Placeholder height="small" width="small" />
|
|
81
|
+
<Placeholder height="large" width="medium" />
|
|
82
|
+
<Placeholder height="medium" width="small" />
|
|
83
|
+
</DxcStack>
|
|
84
|
+
</Container>
|
|
85
|
+
<Title title="AlignX = center" theme="light" level={4} />
|
|
86
|
+
<Container>
|
|
87
|
+
<DxcStack alignX="center">
|
|
88
|
+
<Placeholder height="small" width="small" />
|
|
89
|
+
<Placeholder height="large" width="medium" />
|
|
90
|
+
<Placeholder height="medium" width="small" />
|
|
91
|
+
<Placeholder height="large" width="medium" />
|
|
92
|
+
</DxcStack>
|
|
93
|
+
</Container>
|
|
94
|
+
<Title title="AlignX = baseline" theme="light" level={4} />
|
|
95
|
+
<Container>
|
|
96
|
+
<DxcStack alignX="baseline">
|
|
97
|
+
<Placeholder height="small" width="small" />
|
|
98
|
+
<Placeholder height="large" width="medium" />
|
|
99
|
+
<Placeholder height="medium" width="small" />
|
|
100
|
+
</DxcStack>
|
|
101
|
+
</Container>
|
|
102
|
+
<Title title="AlignX with wrapped items" theme="light" level={4} />
|
|
103
|
+
<Container customHeight>
|
|
104
|
+
<DxcStack alignX="center" wrap>
|
|
105
|
+
<Placeholder height="small" width="medium" />
|
|
106
|
+
<Placeholder height="small" width="small" />
|
|
107
|
+
</DxcStack>
|
|
108
|
+
</Container>
|
|
109
|
+
<Title title="Gutter = 0rem" theme="light" level={4} />
|
|
110
|
+
<Container>
|
|
111
|
+
<DxcStack gutter="0rem">
|
|
112
|
+
<Placeholder height="small" width="medium" />
|
|
113
|
+
<Placeholder height="large" width="small" />
|
|
114
|
+
<Placeholder height="medium" width="medium" />
|
|
115
|
+
<Placeholder height="large" width="small" />
|
|
116
|
+
<Placeholder height="small" width="medium" />
|
|
117
|
+
</DxcStack>
|
|
118
|
+
</Container>
|
|
119
|
+
<Title title="Gutter = 0.125rem" theme="light" level={4} />
|
|
120
|
+
<Container>
|
|
121
|
+
<DxcStack gutter="0.125rem">
|
|
122
|
+
<Placeholder height="small" width="small" />
|
|
123
|
+
<Placeholder height="large" width="medium" />
|
|
124
|
+
<Placeholder height="medium" width="small" />
|
|
125
|
+
</DxcStack>
|
|
126
|
+
</Container>
|
|
127
|
+
<Title title="Gutter = 0.25rem" theme="light" level={4} />
|
|
128
|
+
<Container>
|
|
129
|
+
<DxcStack gutter="0.25rem">
|
|
130
|
+
<Placeholder height="small" width="medium" />
|
|
131
|
+
<Placeholder height="large" width="small" />
|
|
132
|
+
<Placeholder height="medium" width="medium" />
|
|
133
|
+
<Placeholder height="large" width="small" />
|
|
134
|
+
<Placeholder height="small" width="medium" />
|
|
135
|
+
</DxcStack>
|
|
136
|
+
</Container>
|
|
137
|
+
<Title title="Gutter = 0.5rem" theme="light" level={4} />
|
|
138
|
+
<Container>
|
|
139
|
+
<DxcStack gutter="0.5rem">
|
|
140
|
+
<Placeholder height="small" width="small" />
|
|
141
|
+
<Placeholder height="large" width="medium" />
|
|
142
|
+
<Placeholder height="medium" width="small" />
|
|
143
|
+
</DxcStack>
|
|
144
|
+
</Container>
|
|
145
|
+
<Title title="Gutter = 0.75rem" theme="light" level={4} />
|
|
146
|
+
<Container>
|
|
147
|
+
<DxcStack gutter="0.75rem">
|
|
148
|
+
<Placeholder height="small" width="medium" />
|
|
149
|
+
<Placeholder height="large" width="small" />
|
|
150
|
+
<Placeholder height="medium" width="medium" />
|
|
151
|
+
<Placeholder height="large" width="small" />
|
|
152
|
+
<Placeholder height="small" width="medium" />
|
|
153
|
+
</DxcStack>
|
|
154
|
+
</Container>
|
|
155
|
+
<Title title="Gutter = 1rem" theme="light" level={4} />
|
|
156
|
+
<Container>
|
|
157
|
+
<DxcStack gutter="1rem">
|
|
158
|
+
<Placeholder height="small" width="small" />
|
|
159
|
+
<Placeholder height="large" width="medium" />
|
|
160
|
+
<Placeholder height="medium" width="small" />
|
|
161
|
+
</DxcStack>
|
|
162
|
+
</Container>
|
|
163
|
+
<Title title="Gutter = 1.5rem" theme="light" level={4} />
|
|
164
|
+
<Container>
|
|
165
|
+
<DxcStack gutter="1.5rem">
|
|
166
|
+
<Placeholder height="small" width="medium" />
|
|
167
|
+
<Placeholder height="large" width="small" />
|
|
168
|
+
<Placeholder height="medium" width="medium" />
|
|
169
|
+
<Placeholder height="large" width="small" />
|
|
170
|
+
<Placeholder height="small" width="medium" />
|
|
171
|
+
</DxcStack>
|
|
172
|
+
</Container>
|
|
173
|
+
<Title title="Gutter = 2rem & divider" theme="light" level={4} />
|
|
174
|
+
<Container>
|
|
175
|
+
<DxcStack gutter="2rem" divider>
|
|
176
|
+
<Placeholder height="small" width="small" />
|
|
177
|
+
<Placeholder height="large" width="medium" />
|
|
178
|
+
<Placeholder height="medium" width="small" />
|
|
179
|
+
</DxcStack>
|
|
180
|
+
</Container>
|
|
181
|
+
<Title title="Gutter = 3rem" theme="light" level={4} />
|
|
182
|
+
<Container>
|
|
183
|
+
<DxcStack gutter="3rem">
|
|
184
|
+
<Placeholder height="small" width="small" />
|
|
185
|
+
<Placeholder height="large" width="medium" />
|
|
186
|
+
<Placeholder height="medium" width="small" />
|
|
187
|
+
</DxcStack>
|
|
188
|
+
</Container>
|
|
189
|
+
<Title title="Gutter = 4rem" theme="light" level={4} />
|
|
190
|
+
<Container>
|
|
191
|
+
<DxcStack gutter="4rem">
|
|
192
|
+
<Placeholder height="large" width="medium" />
|
|
193
|
+
<Placeholder height="medium" width="small" />
|
|
194
|
+
</DxcStack>
|
|
195
|
+
</Container>
|
|
196
|
+
<Title title="Gutter = 5rem" theme="light" level={4} />
|
|
197
|
+
<Container>
|
|
198
|
+
<DxcStack gutter="5rem">
|
|
199
|
+
<Placeholder height="small" width="small" />
|
|
200
|
+
<Placeholder height="medium" width="small" />
|
|
201
|
+
</DxcStack>
|
|
202
|
+
</Container>
|
|
203
|
+
<Title title="Reverse" theme="light" level={4} />
|
|
204
|
+
<Container>
|
|
205
|
+
<DxcStack reverse>
|
|
206
|
+
<Placeholder height="small" width="medium">
|
|
207
|
+
1
|
|
208
|
+
</Placeholder>
|
|
209
|
+
<Placeholder height="large" width="small">
|
|
210
|
+
2
|
|
211
|
+
</Placeholder>
|
|
212
|
+
<Placeholder height="medium" width="medium">
|
|
213
|
+
3
|
|
214
|
+
</Placeholder>
|
|
215
|
+
<Placeholder height="large" width="small">
|
|
216
|
+
4
|
|
217
|
+
</Placeholder>
|
|
218
|
+
</DxcStack>
|
|
219
|
+
</Container>
|
|
220
|
+
<Title title="Wrapped and reversed children" theme="light" level={4} />
|
|
221
|
+
<FlexContainer customHeight>
|
|
222
|
+
<DxcStack reverse wrap>
|
|
223
|
+
<Placeholder height="small" width="medium">
|
|
224
|
+
1
|
|
225
|
+
</Placeholder>
|
|
226
|
+
<Placeholder height="large" width="small">
|
|
227
|
+
2
|
|
228
|
+
</Placeholder>
|
|
229
|
+
<Placeholder height="medium" width="medium">
|
|
230
|
+
3
|
|
231
|
+
</Placeholder>
|
|
232
|
+
<Placeholder height="large" width="small">
|
|
233
|
+
4
|
|
234
|
+
</Placeholder>
|
|
235
|
+
</DxcStack>
|
|
236
|
+
</FlexContainer>
|
|
237
|
+
</>
|
|
238
|
+
);
|
|
239
|
+
|
|
240
|
+
const FlexContainer = styled.div<{ customHeight?: boolean }>`
|
|
241
|
+
display: flex;
|
|
242
|
+
${({ customHeight }) => customHeight && `height: 100px;`};
|
|
243
|
+
background: #f2eafa;
|
|
244
|
+
`;
|
|
245
|
+
|
|
246
|
+
const Container = styled.div<{ customHeight?: boolean }>`
|
|
247
|
+
background: #f2eafa;
|
|
248
|
+
${({ customHeight }) => customHeight && `height: 100px;`};
|
|
249
|
+
`;
|
|
250
|
+
|
|
251
|
+
type PlaceholderProps = {
|
|
252
|
+
width?: "xlarge" | "large" | "medium" | "small" | "auto";
|
|
253
|
+
height?: "large" | "medium" | "small" | "auto";
|
|
254
|
+
};
|
|
255
|
+
|
|
256
|
+
const Placeholder = styled.div<PlaceholderProps>`
|
|
257
|
+
${({ width }) =>
|
|
258
|
+
width &&
|
|
259
|
+
`width: ${width === "xlarge" ? "350px" : width === "large" ? "150px" : width === "medium" ? "100px" : "50px"};`};
|
|
260
|
+
${({ height }) => height && `height: ${height === "large" ? "100px" : height === "medium" ? "80px" : "50px"};`};
|
|
261
|
+
border: 1px solid #a46ede;
|
|
262
|
+
background-color: #e5d5f6;
|
|
263
|
+
`;
|
package/stack/types.d.ts
ADDED
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
/// <reference types="react" />
|
|
2
|
+
declare type Props = {
|
|
3
|
+
/**
|
|
4
|
+
* Alignment applied to children in the main axis.
|
|
5
|
+
*/
|
|
6
|
+
alignX?: "start" | "end" | "center" | "baseline" | "stretch";
|
|
7
|
+
/**
|
|
8
|
+
* Specifies the HTML tag or component that is rendered as the wrapper element.
|
|
9
|
+
*/
|
|
10
|
+
as?: React.ElementType;
|
|
11
|
+
/**
|
|
12
|
+
* If true, a divider is shown between children.
|
|
13
|
+
*/
|
|
14
|
+
divider?: boolean;
|
|
15
|
+
/**
|
|
16
|
+
* Space applied between each child.
|
|
17
|
+
*/
|
|
18
|
+
gutter?: "0rem" | "0.125rem" | "0.25rem" | "0.5rem" | "0.75rem" | "1rem" | "1.5rem" | "2rem" | "3rem" | "4rem" | "5rem";
|
|
19
|
+
/**
|
|
20
|
+
* Change the direction of the stack to reverse.
|
|
21
|
+
*/
|
|
22
|
+
reverse?: boolean;
|
|
23
|
+
/**
|
|
24
|
+
* Sets whether the children are forced onto one column or can wrap onto multiple columns.
|
|
25
|
+
*/
|
|
26
|
+
wrap?: boolean;
|
|
27
|
+
/**
|
|
28
|
+
* Custom content inside the stack.
|
|
29
|
+
*/
|
|
30
|
+
children: React.ReactNode[] | React.ReactNode;
|
|
31
|
+
};
|
|
32
|
+
export default Props;
|