@dxc-technology/halstack-react 0.0.0-c908d78 → 0.0.0-ca55cbe
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 +2 -5
- package/HalstackContext.d.ts +1336 -0
- package/HalstackContext.js +335 -0
- package/accordion/Accordion.d.ts +1 -1
- package/accordion/Accordion.js +118 -142
- package/accordion/Accordion.stories.tsx +395 -0
- package/accordion/Accordion.test.js +71 -0
- package/accordion/types.d.ts +9 -8
- package/accordion-group/AccordionGroup.d.ts +1 -1
- package/accordion-group/AccordionGroup.js +18 -39
- package/accordion-group/AccordionGroup.stories.tsx +251 -0
- package/accordion-group/AccordionGroup.test.js +126 -0
- package/accordion-group/types.d.ts +15 -8
- package/alert/Alert.js +10 -9
- package/alert/Alert.stories.tsx +198 -0
- 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/bleed/Bleed.d.ts +3 -0
- package/bleed/Bleed.js +51 -0
- package/bleed/Bleed.stories.tsx +342 -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 +29 -44
- package/box/Box.stories.tsx +15 -0
- package/box/Box.test.js +18 -0
- package/box/types.d.ts +1 -4
- package/bulleted-list/BulletedList.d.ts +7 -0
- package/bulleted-list/BulletedList.js +125 -0
- package/bulleted-list/BulletedList.stories.tsx +206 -0
- package/bulleted-list/types.d.ts +11 -0
- package/bulleted-list/types.js +5 -0
- package/button/Button.d.ts +1 -1
- package/button/Button.js +61 -85
- package/button/Button.stories.tsx +375 -243
- package/button/Button.test.js +35 -0
- package/button/types.d.ts +8 -12
- package/card/Card.js +35 -40
- package/card/Card.stories.tsx +200 -0
- package/card/Card.test.js +50 -0
- package/card/ice-cream.jpg +0 -0
- package/card/types.d.ts +5 -6
- package/checkbox/Checkbox.d.ts +2 -2
- package/checkbox/Checkbox.js +108 -111
- package/checkbox/Checkbox.stories.tsx +198 -130
- package/checkbox/Checkbox.test.js +155 -0
- package/checkbox/types.d.ts +13 -5
- package/chip/Chip.d.ts +4 -0
- package/chip/Chip.js +24 -92
- package/chip/Chip.stories.tsx +206 -0
- package/chip/Chip.test.js +54 -0
- package/chip/types.d.ts +45 -0
- package/chip/types.js +5 -0
- package/common/OpenSans.css +68 -80
- package/common/coreTokens.d.ts +146 -0
- package/common/coreTokens.js +167 -0
- package/common/utils.d.ts +1 -0
- package/common/utils.js +4 -4
- package/common/variables.d.ts +1482 -0
- package/common/variables.js +1100 -1308
- package/date-input/Calendar.d.ts +4 -0
- package/date-input/Calendar.js +258 -0
- package/date-input/DateInput.js +174 -266
- package/date-input/DateInput.stories.tsx +304 -0
- package/date-input/DateInput.test.js +835 -0
- package/date-input/DatePicker.d.ts +4 -0
- package/date-input/DatePicker.js +146 -0
- package/date-input/Icons.d.ts +6 -0
- package/date-input/Icons.js +75 -0
- package/date-input/YearPicker.d.ts +4 -0
- package/date-input/YearPicker.js +126 -0
- package/date-input/types.d.ts +67 -9
- package/dialog/Dialog.js +79 -95
- package/dialog/Dialog.stories.tsx +319 -0
- package/dialog/Dialog.test.js +369 -0
- package/dialog/types.d.ts +1 -0
- package/dropdown/Dropdown.d.ts +1 -1
- package/dropdown/Dropdown.js +248 -277
- package/dropdown/Dropdown.stories.tsx +438 -0
- package/dropdown/Dropdown.test.js +586 -0
- package/dropdown/DropdownMenu.d.ts +4 -0
- package/dropdown/DropdownMenu.js +74 -0
- package/dropdown/DropdownMenuItem.d.ts +4 -0
- package/dropdown/DropdownMenuItem.js +79 -0
- package/dropdown/types.d.ts +28 -17
- package/file-input/FileInput.d.ts +4 -0
- package/file-input/FileInput.js +183 -168
- package/file-input/FileInput.stories.tsx +618 -0
- package/file-input/FileInput.test.js +457 -0
- package/file-input/FileItem.d.ts +4 -0
- package/file-input/FileItem.js +50 -81
- package/file-input/types.d.ts +129 -0
- package/file-input/types.js +5 -0
- package/flex/Flex.d.ts +4 -0
- package/flex/Flex.js +71 -0
- package/flex/Flex.stories.tsx +112 -0
- package/flex/types.d.ts +97 -0
- package/flex/types.js +5 -0
- package/footer/Footer.d.ts +1 -1
- package/footer/Footer.js +34 -117
- package/footer/Footer.stories.tsx +228 -0
- package/footer/Footer.test.js +97 -0
- package/footer/Icons.d.ts +2 -0
- package/footer/Icons.js +4 -4
- package/footer/types.d.ts +23 -18
- package/grid/Grid.d.ts +7 -0
- package/grid/Grid.js +91 -0
- package/grid/Grid.stories.tsx +219 -0
- package/grid/types.d.ts +115 -0
- package/grid/types.js +5 -0
- package/header/Header.d.ts +3 -2
- package/header/Header.js +110 -131
- package/header/Header.stories.tsx +315 -0
- package/header/Header.test.js +79 -0
- package/header/Icons.d.ts +2 -0
- package/header/Icons.js +2 -2
- package/header/types.d.ts +5 -2
- package/heading/Heading.d.ts +4 -0
- package/heading/Heading.js +8 -25
- package/heading/Heading.stories.tsx +54 -0
- package/heading/Heading.test.js +186 -0
- package/heading/types.d.ts +33 -0
- package/heading/types.js +5 -0
- package/inset/Inset.d.ts +3 -0
- package/inset/Inset.js +51 -0
- package/inset/Inset.stories.tsx +230 -0
- package/inset/types.d.ts +37 -0
- package/inset/types.js +5 -0
- package/layout/ApplicationLayout.d.ts +20 -0
- package/layout/ApplicationLayout.js +72 -136
- package/layout/ApplicationLayout.stories.tsx +162 -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 +41 -0
- package/layout/types.js +5 -0
- package/link/Link.d.ts +3 -2
- package/link/Link.js +64 -89
- package/link/Link.stories.tsx +253 -0
- package/link/Link.test.js +81 -0
- package/link/types.d.ts +7 -27
- package/main.d.ts +13 -12
- package/main.js +68 -54
- package/nav-tabs/NavTabs.d.ts +8 -0
- package/nav-tabs/NavTabs.js +125 -0
- package/nav-tabs/NavTabs.stories.tsx +260 -0
- package/nav-tabs/NavTabs.test.js +82 -0
- package/nav-tabs/Tab.d.ts +4 -0
- package/nav-tabs/Tab.js +150 -0
- package/nav-tabs/types.d.ts +53 -0
- package/nav-tabs/types.js +5 -0
- package/number-input/NumberInput.d.ts +4 -0
- package/number-input/NumberInput.js +16 -68
- package/number-input/{NumberInput.stories.jsx → NumberInput.stories.tsx} +5 -5
- package/number-input/NumberInput.test.js +542 -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 +124 -0
- package/number-input/types.js +5 -0
- package/package.json +22 -23
- package/paginator/Icons.d.ts +5 -0
- package/paginator/Icons.js +16 -28
- package/paginator/Paginator.js +21 -56
- package/paginator/Paginator.stories.tsx +24 -0
- package/paginator/Paginator.test.js +305 -0
- package/paragraph/Paragraph.d.ts +5 -0
- package/paragraph/Paragraph.js +38 -0
- package/paragraph/Paragraph.stories.tsx +44 -0
- package/password-input/PasswordInput.js +23 -19
- package/password-input/PasswordInput.stories.tsx +3 -3
- package/password-input/PasswordInput.test.js +181 -0
- package/password-input/types.d.ts +29 -19
- package/progress-bar/ProgressBar.js +63 -57
- package/progress-bar/ProgressBar.stories.jsx +47 -12
- package/progress-bar/ProgressBar.test.js +110 -0
- package/quick-nav/QuickNav.d.ts +4 -0
- package/quick-nav/QuickNav.js +117 -0
- package/quick-nav/QuickNav.stories.tsx +356 -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 +156 -0
- package/radio-group/RadioGroup.d.ts +4 -0
- package/radio-group/RadioGroup.js +283 -0
- package/radio-group/RadioGroup.stories.tsx +214 -0
- package/radio-group/RadioGroup.test.js +722 -0
- package/radio-group/types.d.ts +114 -0
- package/radio-group/types.js +5 -0
- package/resultsetTable/Icons.d.ts +7 -0
- package/resultsetTable/Icons.js +51 -0
- package/resultsetTable/ResultsetTable.d.ts +4 -0
- package/resultsetTable/ResultsetTable.js +54 -133
- package/resultsetTable/ResultsetTable.stories.tsx +300 -0
- package/resultsetTable/ResultsetTable.test.js +325 -0
- package/resultsetTable/types.d.ts +67 -0
- package/resultsetTable/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 +169 -0
- package/select/Option.d.ts +4 -0
- package/select/Option.js +97 -0
- package/select/Select.d.ts +4 -0
- package/select/Select.js +202 -401
- package/select/Select.stories.tsx +971 -0
- package/select/Select.test.js +2228 -0
- package/select/types.d.ts +210 -0
- package/select/types.js +5 -0
- package/sidenav/Icons.d.ts +7 -0
- package/sidenav/Icons.js +51 -0
- package/sidenav/Sidenav.d.ts +10 -0
- package/sidenav/Sidenav.js +147 -54
- package/sidenav/Sidenav.stories.tsx +282 -0
- package/sidenav/Sidenav.test.js +44 -0
- package/sidenav/types.d.ts +76 -0
- package/sidenav/types.js +5 -0
- package/slider/Slider.d.ts +2 -2
- package/slider/Slider.js +150 -114
- package/slider/Slider.stories.tsx +240 -0
- package/slider/Slider.test.js +250 -0
- package/slider/types.d.ts +10 -7
- package/spinner/Spinner.js +20 -26
- package/spinner/Spinner.stories.jsx +53 -26
- package/spinner/Spinner.test.js +64 -0
- package/switch/Switch.d.ts +2 -2
- package/switch/Switch.js +153 -70
- package/switch/Switch.stories.tsx +54 -43
- package/switch/Switch.test.js +225 -0
- package/switch/types.d.ts +10 -2
- package/table/Table.js +6 -6
- package/table/Table.stories.jsx +81 -1
- package/table/Table.test.js +26 -0
- package/tabs/Tab.d.ts +4 -0
- package/tabs/Tab.js +132 -0
- package/tabs/Tabs.d.ts +1 -1
- package/tabs/Tabs.js +362 -112
- package/tabs/Tabs.stories.tsx +226 -0
- package/tabs/Tabs.test.js +350 -0
- package/tabs/types.d.ts +39 -18
- package/tag/Tag.d.ts +1 -1
- package/tag/Tag.js +25 -37
- package/tag/Tag.stories.tsx +38 -28
- package/tag/Tag.test.js +60 -0
- package/tag/types.d.ts +23 -14
- package/text-input/Icons.d.ts +8 -0
- package/text-input/Icons.js +60 -0
- package/text-input/Suggestion.d.ts +4 -0
- package/text-input/Suggestion.js +84 -0
- package/text-input/Suggestions.d.ts +4 -0
- package/text-input/Suggestions.js +134 -0
- package/text-input/TextInput.d.ts +4 -0
- package/text-input/TextInput.js +235 -387
- package/text-input/TextInput.stories.tsx +569 -0
- package/text-input/TextInput.test.js +1723 -0
- package/text-input/types.d.ts +197 -0
- package/text-input/types.js +5 -0
- package/textarea/Textarea.d.ts +4 -0
- package/textarea/Textarea.js +41 -82
- package/textarea/Textarea.stories.jsx +96 -15
- package/textarea/Textarea.test.js +435 -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 +24 -49
- package/toggle-group/ToggleGroup.stories.tsx +215 -0
- package/toggle-group/ToggleGroup.test.js +156 -0
- package/toggle-group/types.d.ts +105 -0
- package/toggle-group/types.js +5 -0
- package/typography/Typography.d.ts +4 -0
- package/typography/Typography.js +32 -0
- package/typography/Typography.stories.tsx +198 -0
- package/typography/types.d.ts +18 -0
- package/typography/types.js +5 -0
- package/useTheme.d.ts +1235 -0
- package/useTheme.js +3 -3
- package/useTranslatedLabels.d.ts +85 -0
- package/useTranslatedLabels.js +20 -0
- package/utils/BaseTypography.d.ts +21 -0
- package/utils/BaseTypography.js +108 -0
- package/utils/FocusLock.d.ts +13 -0
- package/utils/FocusLock.js +139 -0
- package/wizard/Wizard.d.ts +4 -0
- package/wizard/Wizard.js +119 -105
- package/wizard/Wizard.stories.tsx +253 -0
- package/wizard/Wizard.test.js +141 -0
- package/wizard/types.d.ts +64 -0
- package/wizard/types.js +5 -0
- 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/common/RequiredComponent.js +0 -32
- package/date/Date.js +0 -373
- package/date/index.d.ts +0 -27
- package/file-input/index.d.ts +0 -81
- package/footer/Footer.stories.jsx +0 -151
- package/heading/index.d.ts +0 -17
- package/input-text/Icons.js +0 -22
- package/input-text/InputText.js +0 -611
- package/input-text/index.d.ts +0 -36
- package/number-input/index.d.ts +0 -113
- 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/sidenav/index.d.ts +0 -13
- 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
- package/wizard/index.d.ts +0 -18
- /package/{radio → badge}/types.js +0 -0
|
@@ -0,0 +1,240 @@
|
|
|
1
|
+
import React from "react";
|
|
2
|
+
import DxcSlider from "./Slider";
|
|
3
|
+
import { BackgroundColorProvider } from "../BackgroundColorContext";
|
|
4
|
+
import Title from "../../.storybook/components/Title";
|
|
5
|
+
import ExampleContainer from "../../.storybook/components/ExampleContainer";
|
|
6
|
+
import DarkContainer from "../../.storybook/components/DarkSection";
|
|
7
|
+
import { HalstackProvider } from "../HalstackContext";
|
|
8
|
+
|
|
9
|
+
export default {
|
|
10
|
+
title: "Slider",
|
|
11
|
+
component: DxcSlider,
|
|
12
|
+
};
|
|
13
|
+
|
|
14
|
+
const labelFormat = (value) => `${value}E100000000000000000000000`;
|
|
15
|
+
|
|
16
|
+
const opinionatedTheme = {
|
|
17
|
+
slider: {
|
|
18
|
+
baseColor: "#0067b3",
|
|
19
|
+
fontColor: "#000000",
|
|
20
|
+
totalLineColor: "#e6e6e6",
|
|
21
|
+
},
|
|
22
|
+
};
|
|
23
|
+
|
|
24
|
+
export const Chromatic = () => (
|
|
25
|
+
<>
|
|
26
|
+
<Title title="States" theme="light" level={2} />
|
|
27
|
+
<ExampleContainer pseudoState="pseudo-hover">
|
|
28
|
+
<Title title="Hovered" theme="light" level={4} />
|
|
29
|
+
<DxcSlider label="Slider" helperText="Help message" showLimitsValues />
|
|
30
|
+
</ExampleContainer>
|
|
31
|
+
<ExampleContainer pseudoState="pseudo-active">
|
|
32
|
+
<Title title="Active" theme="light" level={4} />
|
|
33
|
+
<DxcSlider label="Slider" helperText="Help message" showLimitsValues />
|
|
34
|
+
</ExampleContainer>
|
|
35
|
+
<ExampleContainer pseudoState="pseudo-focus">
|
|
36
|
+
<Title title="Focused" theme="light" level={4} />
|
|
37
|
+
<DxcSlider label="Slider" helperText="Help message" showLimitsValues />
|
|
38
|
+
</ExampleContainer>
|
|
39
|
+
<ExampleContainer>
|
|
40
|
+
<Title title="Disabled" theme="light" level={4} />
|
|
41
|
+
<DxcSlider label="Slider" helperText="Help message" disabled showLimitsValues />
|
|
42
|
+
</ExampleContainer>
|
|
43
|
+
<ExampleContainer>
|
|
44
|
+
<Title title="Disabled discrete slider with input" theme="light" level={4} />
|
|
45
|
+
<DxcSlider
|
|
46
|
+
label="Slider"
|
|
47
|
+
helperText="Help message"
|
|
48
|
+
disabled
|
|
49
|
+
defaultValue={40}
|
|
50
|
+
minValue={0}
|
|
51
|
+
maxValue={50}
|
|
52
|
+
showLimitsValues
|
|
53
|
+
showInput
|
|
54
|
+
marks
|
|
55
|
+
step={10}
|
|
56
|
+
/>
|
|
57
|
+
</ExampleContainer>
|
|
58
|
+
<Title title="Variants" theme="light" level={2} />
|
|
59
|
+
<ExampleContainer>
|
|
60
|
+
<Title title="Continuous slider" theme="light" level={4} />
|
|
61
|
+
<DxcSlider defaultValue={65} label="Slider" helperText="Help message" showLimitsValues />
|
|
62
|
+
</ExampleContainer>
|
|
63
|
+
<ExampleContainer>
|
|
64
|
+
<Title title="Discrete slider" theme="light" level={4} />
|
|
65
|
+
<DxcSlider defaultValue={20} label="Slider" helperText="Help message" showLimitsValues marks step={5} />
|
|
66
|
+
</ExampleContainer>
|
|
67
|
+
<ExampleContainer>
|
|
68
|
+
<Title title="Discrete slider with input" theme="light" level={4} />
|
|
69
|
+
<DxcSlider
|
|
70
|
+
defaultValue={20}
|
|
71
|
+
minValue={0}
|
|
72
|
+
maxValue={50}
|
|
73
|
+
label="Slider"
|
|
74
|
+
helperText="Help message"
|
|
75
|
+
showLimitsValues
|
|
76
|
+
showInput
|
|
77
|
+
marks
|
|
78
|
+
step={10}
|
|
79
|
+
/>
|
|
80
|
+
</ExampleContainer>
|
|
81
|
+
<BackgroundColorProvider color="#333333">
|
|
82
|
+
<DarkContainer>
|
|
83
|
+
<Title title="Dark" theme="dark" level={2} />
|
|
84
|
+
<ExampleContainer pseudoState="pseudo-hover">
|
|
85
|
+
<Title title="Hovered" theme="dark" level={4} />
|
|
86
|
+
<DxcSlider label="Slider" helperText="Help message" showLimitsValues />
|
|
87
|
+
</ExampleContainer>
|
|
88
|
+
<ExampleContainer pseudoState="pseudo-active">
|
|
89
|
+
<Title title="Active" theme="dark" level={4} />
|
|
90
|
+
<DxcSlider label="Slider" helperText="Help message" showLimitsValues />
|
|
91
|
+
</ExampleContainer>
|
|
92
|
+
<ExampleContainer pseudoState="pseudo-focus">
|
|
93
|
+
<Title title="Focused" theme="dark" level={4} />
|
|
94
|
+
<DxcSlider label="Slider" helperText="Help message" showLimitsValues />
|
|
95
|
+
</ExampleContainer>
|
|
96
|
+
<ExampleContainer>
|
|
97
|
+
<Title title="Disabled" theme="dark" level={4} />
|
|
98
|
+
<DxcSlider label="Slider" helperText="Help message" disabled showLimitsValues />
|
|
99
|
+
</ExampleContainer>
|
|
100
|
+
<ExampleContainer>
|
|
101
|
+
<Title title="Disabled discrete slider with input" theme="dark" level={4} />
|
|
102
|
+
<DxcSlider
|
|
103
|
+
label="Slider"
|
|
104
|
+
helperText="Help message"
|
|
105
|
+
disabled
|
|
106
|
+
defaultValue={40}
|
|
107
|
+
minValue={0}
|
|
108
|
+
maxValue={50}
|
|
109
|
+
showLimitsValues
|
|
110
|
+
showInput
|
|
111
|
+
marks
|
|
112
|
+
step={5}
|
|
113
|
+
/>
|
|
114
|
+
</ExampleContainer>
|
|
115
|
+
<ExampleContainer>
|
|
116
|
+
<Title title="Continuous slider" theme="dark" level={4} />
|
|
117
|
+
<DxcSlider defaultValue={65} label="Slider" helperText="Help message" showLimitsValues />
|
|
118
|
+
</ExampleContainer>
|
|
119
|
+
<ExampleContainer>
|
|
120
|
+
<Title title="Discrete slider" theme="dark" level={4} />
|
|
121
|
+
<DxcSlider defaultValue={20} label="Slider" helperText="Help message" showLimitsValues marks step={5} />
|
|
122
|
+
</ExampleContainer>
|
|
123
|
+
<ExampleContainer>
|
|
124
|
+
<Title title="Discrete slider with input" theme="dark" level={4} />
|
|
125
|
+
<DxcSlider
|
|
126
|
+
defaultValue={20}
|
|
127
|
+
minValue={0}
|
|
128
|
+
maxValue={50}
|
|
129
|
+
label="Slider"
|
|
130
|
+
helperText="Help message"
|
|
131
|
+
showLimitsValues
|
|
132
|
+
showInput
|
|
133
|
+
marks
|
|
134
|
+
step={10}
|
|
135
|
+
/>
|
|
136
|
+
</ExampleContainer>
|
|
137
|
+
</DarkContainer>
|
|
138
|
+
</BackgroundColorProvider>
|
|
139
|
+
<Title title="Margins" theme="light" level={2} />
|
|
140
|
+
<ExampleContainer>
|
|
141
|
+
<Title title="Xxsmall" theme="light" level={4} />
|
|
142
|
+
<DxcSlider label="Xxsmall" margin="xxsmall" />
|
|
143
|
+
</ExampleContainer>
|
|
144
|
+
<ExampleContainer>
|
|
145
|
+
<Title title="Xsmall" theme="light" level={4} />
|
|
146
|
+
<DxcSlider label="Xsmall" margin="xsmall" />
|
|
147
|
+
</ExampleContainer>
|
|
148
|
+
<ExampleContainer>
|
|
149
|
+
<Title title="Small" theme="light" level={4} />
|
|
150
|
+
<DxcSlider label="Small" margin="small" />
|
|
151
|
+
</ExampleContainer>
|
|
152
|
+
<ExampleContainer>
|
|
153
|
+
<Title title="Medium" theme="light" level={4} />
|
|
154
|
+
<DxcSlider label="Medium" margin="medium" />
|
|
155
|
+
</ExampleContainer>
|
|
156
|
+
<ExampleContainer>
|
|
157
|
+
<Title title="Large" theme="light" level={4} />
|
|
158
|
+
<DxcSlider label="Large" margin="large" />
|
|
159
|
+
</ExampleContainer>
|
|
160
|
+
<ExampleContainer>
|
|
161
|
+
<Title title="Xlarge" theme="light" level={4} />
|
|
162
|
+
<DxcSlider label="Xlarge" margin="xlarge" />
|
|
163
|
+
</ExampleContainer>
|
|
164
|
+
<ExampleContainer>
|
|
165
|
+
<Title title="Xxlarge" theme="light" level={4} />
|
|
166
|
+
<DxcSlider label="Xxlarge" margin="xxlarge" />
|
|
167
|
+
</ExampleContainer>
|
|
168
|
+
<Title title="Sizes" theme="light" level={2} />
|
|
169
|
+
<ExampleContainer>
|
|
170
|
+
<Title title="Medium" theme="light" level={4} />
|
|
171
|
+
<DxcSlider label="Medium" size="medium" />
|
|
172
|
+
</ExampleContainer>
|
|
173
|
+
<ExampleContainer>
|
|
174
|
+
<Title title="Large" theme="light" level={4} />
|
|
175
|
+
<DxcSlider label="Large" size="large" />
|
|
176
|
+
</ExampleContainer>
|
|
177
|
+
<ExampleContainer>
|
|
178
|
+
<Title title="FillParent" theme="light" level={4} />
|
|
179
|
+
<DxcSlider label="FillParent" size="fillParent" />
|
|
180
|
+
</ExampleContainer>
|
|
181
|
+
<ExampleContainer>
|
|
182
|
+
<Title title="Large limit values labels" theme="light" level={4} />
|
|
183
|
+
<DxcSlider
|
|
184
|
+
label="Slider"
|
|
185
|
+
helperText="Help message"
|
|
186
|
+
showLimitsValues
|
|
187
|
+
labelFormatCallback={labelFormat}
|
|
188
|
+
size="large"
|
|
189
|
+
/>
|
|
190
|
+
</ExampleContainer>
|
|
191
|
+
<Title title="Opinionated theme" theme="light" level={2} />
|
|
192
|
+
<ExampleContainer pseudoState="pseudo-hover">
|
|
193
|
+
<Title title="Hovered" theme="light" level={4} />
|
|
194
|
+
<HalstackProvider theme={opinionatedTheme}>
|
|
195
|
+
<DxcSlider label="Slider" helperText="Help message" showLimitsValues />
|
|
196
|
+
</HalstackProvider>
|
|
197
|
+
</ExampleContainer>
|
|
198
|
+
<ExampleContainer pseudoState="pseudo-active">
|
|
199
|
+
<Title title="Active" theme="light" level={4} />
|
|
200
|
+
<HalstackProvider theme={opinionatedTheme}>
|
|
201
|
+
<DxcSlider label="Slider" helperText="Help message" showLimitsValues />
|
|
202
|
+
</HalstackProvider>
|
|
203
|
+
</ExampleContainer>
|
|
204
|
+
<ExampleContainer pseudoState="pseudo-focus">
|
|
205
|
+
<Title title="Focused" theme="light" level={4} />
|
|
206
|
+
<HalstackProvider theme={opinionatedTheme}>
|
|
207
|
+
<DxcSlider label="Slider" helperText="Help message" showLimitsValues />
|
|
208
|
+
</HalstackProvider>
|
|
209
|
+
</ExampleContainer>
|
|
210
|
+
<ExampleContainer>
|
|
211
|
+
<Title title="Disabled discrete slider with input" theme="light" level={4} />{" "}
|
|
212
|
+
<HalstackProvider theme={opinionatedTheme}>
|
|
213
|
+
<DxcSlider
|
|
214
|
+
label="Slider"
|
|
215
|
+
helperText="Help message"
|
|
216
|
+
disabled
|
|
217
|
+
defaultValue={40}
|
|
218
|
+
minValue={0}
|
|
219
|
+
maxValue={50}
|
|
220
|
+
showLimitsValues
|
|
221
|
+
showInput
|
|
222
|
+
marks
|
|
223
|
+
step={10}
|
|
224
|
+
/>
|
|
225
|
+
</HalstackProvider>
|
|
226
|
+
</ExampleContainer>
|
|
227
|
+
<ExampleContainer>
|
|
228
|
+
<Title title="Continuous slider" theme="light" level={4} />
|
|
229
|
+
<HalstackProvider theme={opinionatedTheme}>
|
|
230
|
+
<DxcSlider defaultValue={65} label="Slider" helperText="Help message" showLimitsValues />
|
|
231
|
+
</HalstackProvider>
|
|
232
|
+
</ExampleContainer>
|
|
233
|
+
<ExampleContainer>
|
|
234
|
+
<Title title="Discrete slider" theme="light" level={4} />
|
|
235
|
+
<HalstackProvider theme={opinionatedTheme}>
|
|
236
|
+
<DxcSlider defaultValue={20} label="Slider" helperText="Help message" showLimitsValues marks step={5} />
|
|
237
|
+
</HalstackProvider>
|
|
238
|
+
</ExampleContainer>
|
|
239
|
+
</>
|
|
240
|
+
);
|
|
@@ -0,0 +1,250 @@
|
|
|
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 _userEvent = _interopRequireDefault(require("@testing-library/user-event"));
|
|
10
|
+
|
|
11
|
+
var _Slider = _interopRequireDefault(require("./Slider.tsx"));
|
|
12
|
+
|
|
13
|
+
describe("Slider component tests", function () {
|
|
14
|
+
test("Slider renders with correct text and label id", function () {
|
|
15
|
+
var _render = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Slider["default"], {
|
|
16
|
+
label: "label",
|
|
17
|
+
minValue: 0,
|
|
18
|
+
maxValue: 100,
|
|
19
|
+
showLimitsValues: true
|
|
20
|
+
})),
|
|
21
|
+
getByText = _render.getByText,
|
|
22
|
+
getByRole = _render.getByRole;
|
|
23
|
+
|
|
24
|
+
expect(getByText("0")).toBeTruthy();
|
|
25
|
+
expect(getByText("100")).toBeTruthy();
|
|
26
|
+
var sliderId = getByText("label").getAttribute("id");
|
|
27
|
+
expect(getByRole("slider").getAttribute("aria-labelledby")).toBe(sliderId);
|
|
28
|
+
expect(getByRole("slider").getAttribute("aria-orientation")).toBe("horizontal");
|
|
29
|
+
});
|
|
30
|
+
test("Slider renders with correct initial value when it is uncontrolled", function () {
|
|
31
|
+
var _render2 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Slider["default"], {
|
|
32
|
+
defaultValue: 30,
|
|
33
|
+
minValue: 0,
|
|
34
|
+
maxValue: 100,
|
|
35
|
+
showLimitsValues: true,
|
|
36
|
+
showInput: true
|
|
37
|
+
})),
|
|
38
|
+
getByRole = _render2.getByRole;
|
|
39
|
+
|
|
40
|
+
var slider = getByRole("slider");
|
|
41
|
+
var input = getByRole("textbox");
|
|
42
|
+
expect(slider.getAttribute("aria-valuenow")).toBe("30");
|
|
43
|
+
expect(input.value).toBe("30");
|
|
44
|
+
});
|
|
45
|
+
test("Slider correct limit values", function () {
|
|
46
|
+
var _render3 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Slider["default"], {
|
|
47
|
+
defaultValue: 125,
|
|
48
|
+
minValue: 30,
|
|
49
|
+
maxValue: 125,
|
|
50
|
+
showLimitsValues: true
|
|
51
|
+
})),
|
|
52
|
+
getByRole = _render3.getByRole,
|
|
53
|
+
getByText = _render3.getByText;
|
|
54
|
+
|
|
55
|
+
var slider = getByRole("slider");
|
|
56
|
+
expect(slider.getAttribute("aria-valuemin")).toBe("30");
|
|
57
|
+
expect(slider.getAttribute("aria-valuemax")).toBe("125");
|
|
58
|
+
|
|
59
|
+
_userEvent["default"].tab();
|
|
60
|
+
|
|
61
|
+
_react2.fireEvent.keyDown(slider, {
|
|
62
|
+
key: "ArrowRight",
|
|
63
|
+
code: "ArrowRight",
|
|
64
|
+
keyCode: 39,
|
|
65
|
+
charCode: 39
|
|
66
|
+
});
|
|
67
|
+
|
|
68
|
+
expect(slider.getAttribute("aria-valuenow")).toBe("125");
|
|
69
|
+
expect(getByText("30")).toBeTruthy();
|
|
70
|
+
expect(getByText("125")).toBeTruthy();
|
|
71
|
+
});
|
|
72
|
+
test("Calls correct function onChange in controlled slider", function () {
|
|
73
|
+
var onChange = jest.fn();
|
|
74
|
+
|
|
75
|
+
var _render4 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Slider["default"], {
|
|
76
|
+
minValue: 0,
|
|
77
|
+
maxValue: 100,
|
|
78
|
+
onChange: onChange,
|
|
79
|
+
showLimitsValues: true,
|
|
80
|
+
value: 13,
|
|
81
|
+
showInput: true
|
|
82
|
+
})),
|
|
83
|
+
getByRole = _render4.getByRole;
|
|
84
|
+
|
|
85
|
+
expect(getByRole("slider").getAttribute("aria-valuenow")).toBe("13");
|
|
86
|
+
expect(getByRole("textbox").value).toBe("13");
|
|
87
|
+
(0, _react2.act)(function () {
|
|
88
|
+
_react2.fireEvent.change(getByRole("textbox"), {
|
|
89
|
+
target: {
|
|
90
|
+
value: 25
|
|
91
|
+
}
|
|
92
|
+
});
|
|
93
|
+
});
|
|
94
|
+
expect(onChange).toHaveBeenCalledWith(25);
|
|
95
|
+
expect(getByRole("slider").getAttribute("aria-valuenow")).toBe("13");
|
|
96
|
+
expect(getByRole("textbox").value).toBe("13");
|
|
97
|
+
});
|
|
98
|
+
test("Calls correct function onChange in uncontrolled slider", function () {
|
|
99
|
+
var onChange = jest.fn();
|
|
100
|
+
|
|
101
|
+
var _render5 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Slider["default"], {
|
|
102
|
+
minValue: 0,
|
|
103
|
+
maxValue: 100,
|
|
104
|
+
onChange: onChange,
|
|
105
|
+
showLimitsValues: true,
|
|
106
|
+
showInput: true
|
|
107
|
+
})),
|
|
108
|
+
getByRole = _render5.getByRole;
|
|
109
|
+
|
|
110
|
+
(0, _react2.act)(function () {
|
|
111
|
+
_react2.fireEvent.change(getByRole("textbox"), {
|
|
112
|
+
target: {
|
|
113
|
+
value: 25
|
|
114
|
+
}
|
|
115
|
+
});
|
|
116
|
+
});
|
|
117
|
+
expect(onChange).toHaveBeenCalledWith(25);
|
|
118
|
+
expect(getByRole("slider").getAttribute("aria-valuenow")).toBe("25");
|
|
119
|
+
expect(getByRole("textbox").value).toBe("25");
|
|
120
|
+
});
|
|
121
|
+
test("Disabled slider have disabled input and slider", function () {
|
|
122
|
+
var onChange = jest.fn();
|
|
123
|
+
|
|
124
|
+
var _render6 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Slider["default"], {
|
|
125
|
+
minValue: 0,
|
|
126
|
+
maxValue: 100,
|
|
127
|
+
onChange: onChange,
|
|
128
|
+
showLimitsValues: true,
|
|
129
|
+
disabled: true,
|
|
130
|
+
showInput: true,
|
|
131
|
+
value: 13
|
|
132
|
+
})),
|
|
133
|
+
getByRole = _render6.getByRole;
|
|
134
|
+
|
|
135
|
+
(0, _react2.act)(function () {
|
|
136
|
+
_react2.fireEvent.change(getByRole("textbox"), {
|
|
137
|
+
target: {
|
|
138
|
+
value: 25
|
|
139
|
+
}
|
|
140
|
+
});
|
|
141
|
+
});
|
|
142
|
+
expect(getByRole("textbox").hasAttribute("disabled")).toBeTruthy();
|
|
143
|
+
expect(getByRole("textbox").value).toBe("13");
|
|
144
|
+
expect(getByRole("slider").hasAttribute("disabled")).toBeTruthy();
|
|
145
|
+
});
|
|
146
|
+
test("Calls correct function onDragEnd when it is uncontrolled", function () {
|
|
147
|
+
var onDragEnd = jest.fn();
|
|
148
|
+
|
|
149
|
+
var _render7 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Slider["default"], {
|
|
150
|
+
minValue: 0,
|
|
151
|
+
maxValue: 150,
|
|
152
|
+
onDragEnd: onDragEnd,
|
|
153
|
+
showInput: true
|
|
154
|
+
})),
|
|
155
|
+
getByRole = _render7.getByRole;
|
|
156
|
+
|
|
157
|
+
var slider = getByRole("slider");
|
|
158
|
+
(0, _react2.act)(function () {
|
|
159
|
+
_react2.fireEvent.mouseDown(slider);
|
|
160
|
+
});
|
|
161
|
+
(0, _react2.act)(function () {
|
|
162
|
+
_react2.fireEvent.mouseUp(slider, {
|
|
163
|
+
target: {
|
|
164
|
+
value: 120
|
|
165
|
+
}
|
|
166
|
+
});
|
|
167
|
+
});
|
|
168
|
+
expect(onDragEnd).toHaveBeenCalledWith("120");
|
|
169
|
+
});
|
|
170
|
+
test("Calls correct function onDragEnd when it is controlled", function () {
|
|
171
|
+
var onDragEnd = jest.fn();
|
|
172
|
+
|
|
173
|
+
var _render8 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Slider["default"], {
|
|
174
|
+
minValue: 0,
|
|
175
|
+
maxValue: 150,
|
|
176
|
+
value: 50,
|
|
177
|
+
onDragEnd: onDragEnd,
|
|
178
|
+
showInput: true
|
|
179
|
+
})),
|
|
180
|
+
getByRole = _render8.getByRole;
|
|
181
|
+
|
|
182
|
+
var slider = getByRole("slider");
|
|
183
|
+
(0, _react2.act)(function () {
|
|
184
|
+
_react2.fireEvent.mouseDown(slider);
|
|
185
|
+
});
|
|
186
|
+
(0, _react2.act)(function () {
|
|
187
|
+
_react2.fireEvent.mouseUp(slider, {
|
|
188
|
+
target: {
|
|
189
|
+
value: 120
|
|
190
|
+
}
|
|
191
|
+
});
|
|
192
|
+
});
|
|
193
|
+
expect(onDragEnd).toHaveBeenCalledWith("120");
|
|
194
|
+
expect(slider.getAttribute("aria-valuenow")).toBe("50");
|
|
195
|
+
});
|
|
196
|
+
test("Calls correct function labelFormatCallback", function () {
|
|
197
|
+
var labelFormatCallback = jest.fn(function (x) {
|
|
198
|
+
return "".concat(x, "$");
|
|
199
|
+
});
|
|
200
|
+
|
|
201
|
+
var _render9 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Slider["default"], {
|
|
202
|
+
minValue: 0,
|
|
203
|
+
maxValue: 100,
|
|
204
|
+
showLimitsValues: true,
|
|
205
|
+
showInput: true,
|
|
206
|
+
value: 25,
|
|
207
|
+
labelFormatCallback: labelFormatCallback
|
|
208
|
+
})),
|
|
209
|
+
getByText = _render9.getByText;
|
|
210
|
+
|
|
211
|
+
expect(getByText("0$")).toBeTruthy();
|
|
212
|
+
expect(getByText("100$")).toBeTruthy();
|
|
213
|
+
expect(labelFormatCallback).toHaveBeenCalledTimes(2);
|
|
214
|
+
});
|
|
215
|
+
test("Change value correctly to 0 from external function", function () {
|
|
216
|
+
var onChange = jest.fn();
|
|
217
|
+
|
|
218
|
+
var _render10 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Slider["default"], {
|
|
219
|
+
minValue: 0,
|
|
220
|
+
maxValue: 100,
|
|
221
|
+
onChange: onChange,
|
|
222
|
+
showLimitsValues: true,
|
|
223
|
+
value: 13,
|
|
224
|
+
showInput: true
|
|
225
|
+
})),
|
|
226
|
+
rerender = _render10.rerender,
|
|
227
|
+
getByRole = _render10.getByRole;
|
|
228
|
+
|
|
229
|
+
var slider = getByRole("slider");
|
|
230
|
+
|
|
231
|
+
_userEvent["default"].tab();
|
|
232
|
+
|
|
233
|
+
_react2.fireEvent.keyDown(slider, {
|
|
234
|
+
key: "ArrowRight",
|
|
235
|
+
code: "ArrowRight",
|
|
236
|
+
keyCode: 39,
|
|
237
|
+
charCode: 39
|
|
238
|
+
});
|
|
239
|
+
|
|
240
|
+
rerender( /*#__PURE__*/_react["default"].createElement(_Slider["default"], {
|
|
241
|
+
minValue: 0,
|
|
242
|
+
maxValue: 100,
|
|
243
|
+
onChange: onChange,
|
|
244
|
+
showLimitsValues: true,
|
|
245
|
+
value: 0,
|
|
246
|
+
showInput: true
|
|
247
|
+
}));
|
|
248
|
+
expect(slider.getAttribute("aria-valuenow")).toBe("0");
|
|
249
|
+
});
|
|
250
|
+
});
|
package/slider/types.d.ts
CHANGED
|
@@ -1,4 +1,3 @@
|
|
|
1
|
-
declare type Size = "medium" | "large" | "fillParent";
|
|
2
1
|
declare type Space = "xxsmall" | "xsmall" | "small" | "medium" | "large" | "xlarge" | "xxlarge";
|
|
3
2
|
declare type Margin = {
|
|
4
3
|
top?: Space;
|
|
@@ -15,6 +14,10 @@ declare type Props = {
|
|
|
15
14
|
* Name attribute of the input element.
|
|
16
15
|
*/
|
|
17
16
|
name?: string;
|
|
17
|
+
/**
|
|
18
|
+
* Initial value of the slider, only when it is uncontrolled.
|
|
19
|
+
*/
|
|
20
|
+
defaultValue?: number;
|
|
18
21
|
/**
|
|
19
22
|
* The selected value. If undefined, the component will be uncontrolled and the value will be managed internally by the component.
|
|
20
23
|
*/
|
|
@@ -65,7 +68,7 @@ declare type Props = {
|
|
|
65
68
|
* This function will be used to format the labels displayed next to the slider.
|
|
66
69
|
* The value will be passed as parameter and the function must return the formatted value.
|
|
67
70
|
*/
|
|
68
|
-
labelFormatCallback?: (value: number) =>
|
|
71
|
+
labelFormatCallback?: (value: number) => string;
|
|
69
72
|
/**
|
|
70
73
|
* Size of the margin to be applied to the component ('xxsmall' | 'xsmall' | 'small' | 'medium' | 'large' | 'xlarge' | 'xxlarge').
|
|
71
74
|
* You can pass an object with 'top', 'bottom', 'left' and 'right' properties in order to specify different margin sizes.
|
|
@@ -74,10 +77,10 @@ declare type Props = {
|
|
|
74
77
|
/**
|
|
75
78
|
* Size of the component.
|
|
76
79
|
*/
|
|
77
|
-
size?:
|
|
78
|
-
/**
|
|
79
|
-
* Value of the tabindex attribute.
|
|
80
|
-
*/
|
|
81
|
-
tabIndex?: number;
|
|
80
|
+
size?: "medium" | "large" | "fillParent";
|
|
82
81
|
};
|
|
82
|
+
/**
|
|
83
|
+
* Reference to the component.
|
|
84
|
+
*/
|
|
85
|
+
export declare type RefType = HTMLDivElement;
|
|
83
86
|
export default Props;
|
package/spinner/Spinner.js
CHANGED
|
@@ -17,11 +17,11 @@ var _react = _interopRequireWildcard(require("react"));
|
|
|
17
17
|
|
|
18
18
|
var _styledComponents = _interopRequireWildcard(require("styled-components"));
|
|
19
19
|
|
|
20
|
-
var _variables = require("../common/variables
|
|
20
|
+
var _variables = require("../common/variables");
|
|
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
|
|
|
@@ -46,11 +46,8 @@ var DxcSpinner = function DxcSpinner(_ref) {
|
|
|
46
46
|
margin: margin,
|
|
47
47
|
mode: mode
|
|
48
48
|
}, /*#__PURE__*/_react["default"].createElement(SpinnerContainer, {
|
|
49
|
-
backgroundType: backgroundType,
|
|
50
|
-
mode: mode
|
|
51
|
-
}, mode === "overlay" && /*#__PURE__*/_react["default"].createElement(BackOverlay, null), /*#__PURE__*/_react["default"].createElement(BackgroundSpinner, {
|
|
52
49
|
mode: mode
|
|
53
|
-
}, mode !== "small" && /*#__PURE__*/_react["default"].createElement(SVGBackground, {
|
|
50
|
+
}, mode === "overlay" && /*#__PURE__*/_react["default"].createElement(BackOverlay, null), /*#__PURE__*/_react["default"].createElement(BackgroundSpinner, null, mode !== "small" && /*#__PURE__*/_react["default"].createElement(SVGBackground, {
|
|
54
51
|
viewBox: "0 0 140 140"
|
|
55
52
|
}, /*#__PURE__*/_react["default"].createElement(CircleBackground, {
|
|
56
53
|
cx: "70",
|
|
@@ -65,8 +62,7 @@ var DxcSpinner = function DxcSpinner(_ref) {
|
|
|
65
62
|
r: "6",
|
|
66
63
|
mode: mode
|
|
67
64
|
}))), value >= 0 && value <= 100 ? /*#__PURE__*/_react["default"].createElement(Spinner, {
|
|
68
|
-
role: "progressbar"
|
|
69
|
-
mode: mode
|
|
65
|
+
role: "progressbar"
|
|
70
66
|
}, mode !== "small" && /*#__PURE__*/_react["default"].createElement(SVGSpinner, {
|
|
71
67
|
viewBox: "0 0 140 140",
|
|
72
68
|
isDeterminated: true
|
|
@@ -90,8 +86,7 @@ var DxcSpinner = function DxcSpinner(_ref) {
|
|
|
90
86
|
isDeterminated: true,
|
|
91
87
|
value: value
|
|
92
88
|
}))) : /*#__PURE__*/_react["default"].createElement(Spinner, {
|
|
93
|
-
role: "progressbar"
|
|
94
|
-
mode: mode
|
|
89
|
+
role: "progressbar"
|
|
95
90
|
}, mode !== "small" && /*#__PURE__*/_react["default"].createElement(SVGSpinner, {
|
|
96
91
|
viewBox: "0 0 140 140",
|
|
97
92
|
isDeterminated: false
|
|
@@ -101,7 +96,8 @@ var DxcSpinner = function DxcSpinner(_ref) {
|
|
|
101
96
|
r: "65",
|
|
102
97
|
backgroundType: backgroundType,
|
|
103
98
|
mode: mode,
|
|
104
|
-
isDeterminated: false
|
|
99
|
+
isDeterminated: false,
|
|
100
|
+
value: value
|
|
105
101
|
})), mode === "small" && /*#__PURE__*/_react["default"].createElement(SVGSpinner, {
|
|
106
102
|
viewBox: "0 0 16 16",
|
|
107
103
|
isDeterminated: false
|
|
@@ -111,26 +107,24 @@ var DxcSpinner = function DxcSpinner(_ref) {
|
|
|
111
107
|
r: "6",
|
|
112
108
|
backgroundType: backgroundType,
|
|
113
109
|
mode: mode,
|
|
114
|
-
isDeterminated: false
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
value: value,
|
|
118
|
-
showValue: showValue
|
|
119
|
-
}, /*#__PURE__*/_react["default"].createElement(SpinnerLabel, {
|
|
110
|
+
isDeterminated: false,
|
|
111
|
+
value: value
|
|
112
|
+
}))), mode !== "small" && /*#__PURE__*/_react["default"].createElement(LabelsContainer, null, /*#__PURE__*/_react["default"].createElement(SpinnerLabel, {
|
|
120
113
|
backgroundType: backgroundType,
|
|
121
114
|
mode: mode
|
|
122
115
|
}, label), (value || value === 0) && showValue && /*#__PURE__*/_react["default"].createElement(SpinnerProgress, {
|
|
116
|
+
value: value,
|
|
123
117
|
backgroundType: backgroundType,
|
|
124
118
|
mode: mode,
|
|
125
119
|
showValue: showValue
|
|
126
120
|
}, value, "%")))));
|
|
127
121
|
};
|
|
128
122
|
|
|
129
|
-
var determinatedValue = function determinatedValue(
|
|
123
|
+
var determinatedValue = function determinatedValue(value, strokeDashArray) {
|
|
130
124
|
var val = 0;
|
|
131
125
|
|
|
132
|
-
if (
|
|
133
|
-
val = strokeDashArray * (1 -
|
|
126
|
+
if (value >= 0 && value <= 100) {
|
|
127
|
+
val = strokeDashArray * (1 - value / 100);
|
|
134
128
|
}
|
|
135
129
|
|
|
136
130
|
return val;
|
|
@@ -178,7 +172,7 @@ var BackOverlay = _styledComponents["default"].div(_templateObject3 || (_templat
|
|
|
178
172
|
return "".concat(props.theme.overlayOpacity);
|
|
179
173
|
});
|
|
180
174
|
|
|
181
|
-
var BackgroundSpinner = _styledComponents["default"].div(_templateObject4 || (_templateObject4 = (0, _taggedTemplateLiteral2["default"])(["\n height: inherit;\n width: inherit;\n position: absolute;\n
|
|
175
|
+
var BackgroundSpinner = _styledComponents["default"].div(_templateObject4 || (_templateObject4 = (0, _taggedTemplateLiteral2["default"])(["\n height: inherit;\n width: inherit;\n position: absolute;\n"])));
|
|
182
176
|
|
|
183
177
|
var SVGBackground = _styledComponents["default"].svg(_templateObject5 || (_templateObject5 = (0, _taggedTemplateLiteral2["default"])(["\n height: inherit;\n width: inherit;\n"])));
|
|
184
178
|
|
|
@@ -190,7 +184,7 @@ var CircleBackground = _styledComponents["default"].circle(_templateObject6 || (
|
|
|
190
184
|
return props.mode !== "small" ? "8.5px" : "2px";
|
|
191
185
|
});
|
|
192
186
|
|
|
193
|
-
var Spinner = _styledComponents["default"].div(_templateObject7 || (_templateObject7 = (0, _taggedTemplateLiteral2["default"])(["\n height: inherit;\n width: inherit;\n position: relative;\n
|
|
187
|
+
var Spinner = _styledComponents["default"].div(_templateObject7 || (_templateObject7 = (0, _taggedTemplateLiteral2["default"])(["\n height: inherit;\n width: inherit;\n position: relative;\n"])));
|
|
194
188
|
|
|
195
189
|
var SVGSpinner = _styledComponents["default"].svg(_templateObject8 || (_templateObject8 = (0, _taggedTemplateLiteral2["default"])(["\n height: inherit;\n width: inherit;\n transform: rotate(-90deg);\n top: 0;\n left: 0;\n transform-origin: center;\n overflow: visible;\n animation: ", ";\n"])), function (props) {
|
|
196
190
|
return !props.isDeterminated ? "1.4s linear infinite both spinner-svg" : "";
|
|
@@ -199,7 +193,7 @@ var SVGSpinner = _styledComponents["default"].svg(_templateObject8 || (_template
|
|
|
199
193
|
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
194
|
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
195
|
}, function (props) {
|
|
202
|
-
return props.backgroundType === "dark" ? props.theme.
|
|
196
|
+
return props.backgroundType === "dark" || props.mode === "overlay" ? props.theme.trackCircleColorOverlay : props.theme.trackCircleColor;
|
|
203
197
|
}, function (props) {
|
|
204
198
|
return !props.isDeterminated ? "50% 50%" : "";
|
|
205
199
|
}, function (props) {
|
|
@@ -207,7 +201,7 @@ var CircleSpinner = _styledComponents["default"].circle(_templateObject9 || (_te
|
|
|
207
201
|
}, function (props) {
|
|
208
202
|
return props.mode !== "small" ? "8.5px" : "2px";
|
|
209
203
|
}, function (props) {
|
|
210
|
-
return props.isDeterminated ? props.mode !== "small" ? determinatedValue(props, 409) : determinatedValue(props, 38) : "";
|
|
204
|
+
return props.isDeterminated ? props.mode !== "small" ? determinatedValue(props.value, 409) : determinatedValue(props.value, 38) : "";
|
|
211
205
|
});
|
|
212
206
|
|
|
213
207
|
var LabelsContainer = _styledComponents["default"].div(_templateObject10 || (_templateObject10 = (0, _taggedTemplateLiteral2["default"])(["\n display: block;\n margin: 0 auto;\n position: absolute;\n text-align: center;\n width: 110px;\n"])));
|
|
@@ -229,7 +223,7 @@ var SpinnerLabel = _styledComponents["default"].p(_templateObject11 || (_templat
|
|
|
229
223
|
});
|
|
230
224
|
|
|
231
225
|
var SpinnerProgress = _styledComponents["default"].p(_templateObject12 || (_templateObject12 = (0, _taggedTemplateLiteral2["default"])(["\n margin: 0;\n width: 100%;\n white-space: nowrap;\n overflow: hidden;\n text-overflow: ellipsis;\n display: ", ";\n font-family: ", ";\n font-weight: ", ";\n font-size: ", ";\n font-style: ", ";\n color: ", ";\n text-align: ", ";\n letter-spacing: ", ";\n"])), function (props) {
|
|
232
|
-
return props.value
|
|
226
|
+
return props.value && props.showValue === true && "block" || "none";
|
|
233
227
|
}, function (props) {
|
|
234
228
|
return props.mode === "overlay" ? props.theme.overlayProgressValueFontFamily : props.theme.progressValueFontFamily;
|
|
235
229
|
}, function (props) {
|