@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.
Files changed (282) hide show
  1. package/BackgroundColorContext.d.ts +10 -0
  2. package/BackgroundColorContext.js +1 -4
  3. package/HalstackContext.d.ts +12 -0
  4. package/HalstackContext.js +295 -0
  5. package/accordion/Accordion.d.ts +1 -1
  6. package/accordion/Accordion.js +15 -47
  7. package/accordion/Accordion.stories.tsx +307 -0
  8. package/accordion/Accordion.test.js +72 -0
  9. package/accordion/types.d.ts +8 -8
  10. package/accordion-group/AccordionGroup.d.ts +1 -1
  11. package/accordion-group/AccordionGroup.js +16 -17
  12. package/accordion-group/AccordionGroup.stories.tsx +225 -0
  13. package/accordion-group/AccordionGroup.test.js +151 -0
  14. package/accordion-group/types.d.ts +8 -8
  15. package/alert/Alert.js +6 -3
  16. package/alert/Alert.test.js +92 -0
  17. package/alert/types.d.ts +1 -1
  18. package/badge/Badge.d.ts +4 -0
  19. package/badge/Badge.js +6 -4
  20. package/badge/types.d.ts +5 -0
  21. package/{radio → badge}/types.js +0 -0
  22. package/bleed/Bleed.d.ts +3 -0
  23. package/bleed/Bleed.js +51 -0
  24. package/bleed/Bleed.stories.tsx +341 -0
  25. package/bleed/types.d.ts +37 -0
  26. package/bleed/types.js +5 -0
  27. package/box/Box.d.ts +1 -1
  28. package/box/Box.js +26 -39
  29. package/box/Box.test.js +18 -0
  30. package/box/types.d.ts +0 -4
  31. package/button/Button.d.ts +1 -1
  32. package/button/Button.js +24 -27
  33. package/button/Button.stories.tsx +6 -8
  34. package/button/Button.test.js +35 -0
  35. package/button/types.d.ts +5 -9
  36. package/card/Card.js +26 -30
  37. package/card/Card.stories.tsx +201 -0
  38. package/card/Card.test.js +50 -0
  39. package/card/ice-cream.jpg +0 -0
  40. package/card/types.d.ts +4 -6
  41. package/checkbox/Checkbox.d.ts +1 -1
  42. package/checkbox/Checkbox.js +45 -41
  43. package/checkbox/Checkbox.stories.tsx +124 -128
  44. package/checkbox/Checkbox.test.js +78 -0
  45. package/checkbox/types.d.ts +9 -5
  46. package/chip/Chip.d.ts +4 -0
  47. package/chip/Chip.js +16 -76
  48. package/chip/Chip.stories.tsx +6 -8
  49. package/chip/Chip.test.js +56 -0
  50. package/chip/types.d.ts +45 -0
  51. package/chip/types.js +5 -0
  52. package/common/variables.js +234 -341
  53. package/date-input/DateInput.js +63 -52
  54. package/date-input/DateInput.stories.tsx +7 -7
  55. package/date-input/DateInput.test.js +479 -0
  56. package/date-input/types.d.ts +16 -9
  57. package/dialog/Dialog.js +8 -35
  58. package/dialog/Dialog.test.js +40 -0
  59. package/dropdown/Dropdown.d.ts +1 -1
  60. package/dropdown/Dropdown.js +22 -48
  61. package/dropdown/Dropdown.stories.tsx +249 -0
  62. package/dropdown/Dropdown.test.js +189 -0
  63. package/dropdown/types.d.ts +6 -15
  64. package/file-input/FileInput.d.ts +4 -0
  65. package/file-input/FileInput.js +172 -111
  66. package/file-input/FileInput.stories.tsx +507 -0
  67. package/file-input/FileInput.test.js +457 -0
  68. package/file-input/FileItem.d.ts +14 -0
  69. package/file-input/FileItem.js +16 -23
  70. package/file-input/types.d.ts +112 -0
  71. package/file-input/types.js +5 -0
  72. package/footer/Footer.d.ts +1 -1
  73. package/footer/Footer.js +32 -113
  74. package/footer/{Footer.stories.jsx → Footer.stories.tsx} +1 -22
  75. package/footer/Footer.test.js +109 -0
  76. package/footer/Icons.d.ts +2 -0
  77. package/footer/Icons.js +4 -4
  78. package/footer/types.d.ts +21 -17
  79. package/header/Header.js +29 -50
  80. package/header/Header.stories.tsx +172 -0
  81. package/header/Header.test.js +79 -0
  82. package/header/Icons.d.ts +2 -0
  83. package/header/types.d.ts +4 -2
  84. package/heading/Heading.js +1 -1
  85. package/heading/Heading.stories.tsx +54 -0
  86. package/heading/Heading.test.js +186 -0
  87. package/inline/Inline.d.ts +4 -0
  88. package/inline/Inline.js +60 -0
  89. package/inline/Inline.stories.tsx +319 -0
  90. package/inline/types.d.ts +36 -0
  91. package/inline/types.js +5 -0
  92. package/inset/Inset.d.ts +3 -0
  93. package/inset/Inset.js +51 -0
  94. package/inset/Inset.stories.tsx +229 -0
  95. package/inset/types.d.ts +37 -0
  96. package/inset/types.js +5 -0
  97. package/layout/ApplicationLayout.d.ts +11 -0
  98. package/layout/ApplicationLayout.js +84 -120
  99. package/layout/ApplicationLayout.stories.tsx +126 -0
  100. package/layout/Icons.d.ts +5 -0
  101. package/layout/Icons.js +13 -2
  102. package/layout/SidenavContext.d.ts +5 -0
  103. package/layout/SidenavContext.js +19 -0
  104. package/layout/types.d.ts +52 -0
  105. package/layout/types.js +5 -0
  106. package/link/Link.d.ts +3 -2
  107. package/link/Link.js +61 -86
  108. package/link/Link.stories.tsx +131 -15
  109. package/link/Link.test.js +83 -0
  110. package/link/types.d.ts +9 -29
  111. package/list/List.d.ts +4 -0
  112. package/list/List.js +47 -0
  113. package/list/List.stories.tsx +89 -0
  114. package/list/types.d.ts +7 -0
  115. package/list/types.js +5 -0
  116. package/main.d.ts +13 -9
  117. package/main.js +80 -42
  118. package/number-input/NumberInput.js +14 -24
  119. package/number-input/NumberInput.stories.tsx +5 -5
  120. package/number-input/NumberInput.test.js +506 -0
  121. package/number-input/NumberInputContext.d.ts +4 -0
  122. package/number-input/NumberInputContext.js +5 -2
  123. package/number-input/numberInputContextTypes.d.ts +19 -0
  124. package/number-input/numberInputContextTypes.js +5 -0
  125. package/number-input/types.d.ts +17 -10
  126. package/package.json +10 -6
  127. package/paginator/Paginator.js +19 -46
  128. package/paginator/Paginator.test.js +308 -0
  129. package/password-input/PasswordInput.js +23 -19
  130. package/password-input/PasswordInput.stories.tsx +3 -3
  131. package/password-input/PasswordInput.test.js +180 -0
  132. package/password-input/types.d.ts +29 -19
  133. package/progress-bar/ProgressBar.js +5 -5
  134. package/progress-bar/ProgressBar.stories.jsx +11 -11
  135. package/progress-bar/ProgressBar.test.js +65 -0
  136. package/quick-nav/QuickNav.d.ts +4 -0
  137. package/quick-nav/QuickNav.js +116 -0
  138. package/quick-nav/QuickNav.stories.tsx +237 -0
  139. package/quick-nav/types.d.ts +21 -0
  140. package/quick-nav/types.js +5 -0
  141. package/radio-group/Radio.d.ts +4 -0
  142. package/radio-group/Radio.js +141 -0
  143. package/radio-group/RadioGroup.d.ts +4 -0
  144. package/radio-group/RadioGroup.js +282 -0
  145. package/radio-group/RadioGroup.stories.tsx +100 -0
  146. package/radio-group/RadioGroup.test.js +695 -0
  147. package/radio-group/types.d.ts +114 -0
  148. package/radio-group/types.js +5 -0
  149. package/resultsetTable/ResultsetTable.d.ts +4 -0
  150. package/resultsetTable/ResultsetTable.js +9 -29
  151. package/resultsetTable/ResultsetTable.stories.tsx +275 -0
  152. package/resultsetTable/ResultsetTable.test.js +348 -0
  153. package/resultsetTable/types.d.ts +67 -0
  154. package/resultsetTable/types.js +5 -0
  155. package/row/Row.d.ts +3 -0
  156. package/row/Row.js +127 -0
  157. package/row/Row.stories.tsx +237 -0
  158. package/row/types.d.ts +28 -0
  159. package/row/types.js +5 -0
  160. package/select/Icons.d.ts +10 -0
  161. package/select/Icons.js +93 -0
  162. package/select/Listbox.d.ts +4 -0
  163. package/select/Listbox.js +175 -0
  164. package/select/Option.d.ts +4 -0
  165. package/select/Option.js +110 -0
  166. package/select/Select.d.ts +4 -0
  167. package/select/Select.js +161 -366
  168. package/select/Select.stories.tsx +230 -176
  169. package/select/Select.test.js +2162 -0
  170. package/select/types.d.ts +212 -0
  171. package/select/types.js +5 -0
  172. package/sidenav/Sidenav.d.ts +1 -1
  173. package/sidenav/Sidenav.js +22 -11
  174. package/sidenav/Sidenav.stories.tsx +182 -0
  175. package/sidenav/Sidenav.test.js +56 -0
  176. package/slider/Slider.d.ts +1 -1
  177. package/slider/Slider.js +6 -5
  178. package/slider/Slider.stories.tsx +8 -8
  179. package/slider/Slider.test.js +150 -0
  180. package/slider/types.d.ts +4 -0
  181. package/spinner/Spinner.js +3 -3
  182. package/spinner/Spinner.stories.jsx +1 -0
  183. package/spinner/Spinner.test.js +64 -0
  184. package/stack/Stack.d.ts +4 -0
  185. package/stack/Stack.js +56 -0
  186. package/stack/Stack.stories.tsx +263 -0
  187. package/stack/types.d.ts +32 -0
  188. package/stack/types.js +5 -0
  189. package/switch/Switch.d.ts +1 -1
  190. package/switch/Switch.js +37 -21
  191. package/switch/Switch.stories.tsx +15 -15
  192. package/switch/Switch.test.js +98 -0
  193. package/switch/types.d.ts +6 -2
  194. package/table/Table.js +3 -3
  195. package/table/Table.stories.jsx +2 -1
  196. package/table/Table.test.js +26 -0
  197. package/tabs/Tabs.d.ts +1 -1
  198. package/tabs/Tabs.js +20 -20
  199. package/tabs/Tabs.stories.tsx +112 -0
  200. package/tabs/Tabs.test.js +140 -0
  201. package/tabs/types.d.ts +29 -18
  202. package/tabs-nav/NavTabs.d.ts +8 -0
  203. package/tabs-nav/NavTabs.js +125 -0
  204. package/tabs-nav/NavTabs.stories.tsx +170 -0
  205. package/tabs-nav/NavTabs.test.js +82 -0
  206. package/tabs-nav/Tab.d.ts +4 -0
  207. package/tabs-nav/Tab.js +132 -0
  208. package/tabs-nav/types.d.ts +53 -0
  209. package/tabs-nav/types.js +5 -0
  210. package/tag/Tag.d.ts +1 -1
  211. package/tag/Tag.js +18 -28
  212. package/tag/Tag.stories.tsx +26 -29
  213. package/tag/Tag.test.js +60 -0
  214. package/tag/types.d.ts +23 -14
  215. package/text/Text.d.ts +7 -0
  216. package/text/Text.js +30 -0
  217. package/text/Text.stories.tsx +19 -0
  218. package/text-input/Suggestion.d.ts +4 -0
  219. package/text-input/Suggestion.js +55 -0
  220. package/text-input/TextInput.d.ts +4 -0
  221. package/text-input/TextInput.js +91 -146
  222. package/text-input/TextInput.stories.tsx +474 -0
  223. package/text-input/TextInput.test.js +1712 -0
  224. package/text-input/types.d.ts +178 -0
  225. package/text-input/types.js +5 -0
  226. package/textarea/Textarea.d.ts +4 -0
  227. package/textarea/Textarea.js +39 -79
  228. package/textarea/Textarea.stories.jsx +37 -15
  229. package/textarea/Textarea.test.js +437 -0
  230. package/textarea/types.d.ts +137 -0
  231. package/textarea/types.js +5 -0
  232. package/toggle-group/ToggleGroup.d.ts +4 -0
  233. package/toggle-group/ToggleGroup.js +18 -46
  234. package/toggle-group/ToggleGroup.stories.tsx +27 -32
  235. package/toggle-group/ToggleGroup.test.js +156 -0
  236. package/toggle-group/types.d.ts +105 -0
  237. package/toggle-group/types.js +5 -0
  238. package/useTheme.d.ts +2 -0
  239. package/useTheme.js +2 -2
  240. package/useTranslatedLabels.d.ts +2 -0
  241. package/useTranslatedLabels.js +20 -0
  242. package/wizard/Wizard.d.ts +1 -1
  243. package/wizard/Wizard.js +107 -46
  244. package/wizard/{Wizard.stories.jsx → Wizard.stories.tsx} +13 -23
  245. package/wizard/Wizard.test.js +141 -0
  246. package/wizard/types.d.ts +9 -9
  247. package/ThemeContext.js +0 -246
  248. package/V3Select/V3Select.js +0 -455
  249. package/V3Select/index.d.ts +0 -27
  250. package/V3Textarea/V3Textarea.js +0 -260
  251. package/V3Textarea/index.d.ts +0 -27
  252. package/chip/index.d.ts +0 -22
  253. package/date/Date.js +0 -373
  254. package/date/index.d.ts +0 -27
  255. package/file-input/index.d.ts +0 -81
  256. package/input-text/Icons.js +0 -22
  257. package/input-text/InputText.js +0 -611
  258. package/input-text/index.d.ts +0 -36
  259. package/radio/Radio.d.ts +0 -4
  260. package/radio/Radio.js +0 -174
  261. package/radio/Radio.stories.tsx +0 -192
  262. package/radio/types.d.ts +0 -54
  263. package/resultsetTable/index.d.ts +0 -19
  264. package/select/index.d.ts +0 -131
  265. package/text-input/index.d.ts +0 -135
  266. package/textarea/index.d.ts +0 -117
  267. package/toggle/Toggle.js +0 -186
  268. package/toggle/index.d.ts +0 -21
  269. package/toggle-group/index.d.ts +0 -21
  270. package/upload/Upload.js +0 -201
  271. package/upload/buttons-upload/ButtonsUpload.js +0 -111
  272. package/upload/buttons-upload/Icons.js +0 -40
  273. package/upload/dragAndDropArea/DragAndDropArea.js +0 -225
  274. package/upload/dragAndDropArea/Icons.js +0 -39
  275. package/upload/file-upload/FileToUpload.js +0 -115
  276. package/upload/file-upload/Icons.js +0 -66
  277. package/upload/files-upload/FilesToUpload.js +0 -109
  278. package/upload/index.d.ts +0 -15
  279. package/upload/transaction/Icons.js +0 -160
  280. package/upload/transaction/Transaction.js +0 -104
  281. package/upload/transactions/Transactions.js +0 -94
  282. 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
- value={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 value={65} label="Slider" helperText="Help message" showLimitsValues />
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 value={20} label="Slider" helperText="Help message" showLimitsValues marks step={5} />
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
- value={20}
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
- value={40}
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 value={65} label="Slider" helperText="Help message" showLimitsValues />
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 value={20} label="Slider" helperText="Help message" showLimitsValues marks step={5} />
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
- value={20}
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
  */
@@ -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.js"));
22
+ var _useTheme = _interopRequireDefault(require("../useTheme"));
23
23
 
24
- var _BackgroundColorContext = _interopRequireDefault(require("../BackgroundColorContext.js"));
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.trackCircleColorOnDark : props.theme.trackCircleColor;
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
+ });
@@ -0,0 +1,4 @@
1
+ /// <reference types="react" />
2
+ import StackPropsType from "./types";
3
+ declare const DxcStack: ({ alignX, as, divider, gutter, reverse, wrap, children, }: StackPropsType) => JSX.Element;
4
+ export default DxcStack;
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
+ `;
@@ -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;