@dxc-technology/halstack-react 0.0.0-c908d78 → 0.0.0-cae3419

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 (257) hide show
  1. package/BackgroundColorContext.d.ts +10 -0
  2. package/BackgroundColorContext.js +1 -4
  3. package/ThemeContext.d.ts +10 -0
  4. package/ThemeContext.js +26 -29
  5. package/accordion/Accordion.d.ts +1 -1
  6. package/accordion/Accordion.js +11 -22
  7. package/accordion/Accordion.stories.tsx +307 -0
  8. package/accordion/Accordion.test.js +57 -0
  9. package/accordion/types.d.ts +4 -8
  10. package/accordion-group/AccordionGroup.js +2 -2
  11. package/accordion-group/AccordionGroup.stories.tsx +225 -0
  12. package/accordion-group/AccordionGroup.test.js +133 -0
  13. package/accordion-group/types.d.ts +4 -8
  14. package/alert/Alert.js +2 -2
  15. package/alert/Alert.stories.tsx +170 -0
  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 +1 -1
  20. package/badge/types.d.ts +4 -0
  21. package/badge/types.js +5 -0
  22. package/bleed/Bleed.d.ts +3 -0
  23. package/bleed/Bleed.js +84 -0
  24. package/bleed/Bleed.stories.tsx +342 -0
  25. package/bleed/types.d.ts +13 -0
  26. package/bleed/types.js +5 -0
  27. package/box/Box.d.ts +1 -1
  28. package/box/Box.js +4 -7
  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 +13 -19
  33. package/button/Button.stories.tsx +222 -241
  34. package/button/Button.test.js +35 -0
  35. package/button/types.d.ts +5 -9
  36. package/card/Card.js +5 -6
  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.js +2 -2
  42. package/checkbox/Checkbox.test.js +65 -0
  43. package/checkbox/types.d.ts +2 -2
  44. package/chip/Chip.d.ts +4 -0
  45. package/chip/Chip.js +16 -76
  46. package/chip/Chip.stories.tsx +119 -0
  47. package/chip/Chip.test.js +56 -0
  48. package/chip/types.d.ts +45 -0
  49. package/chip/types.js +5 -0
  50. package/common/variables.js +69 -265
  51. package/date-input/DateInput.js +10 -13
  52. package/date-input/DateInput.stories.tsx +138 -0
  53. package/date-input/DateInput.test.js +469 -0
  54. package/dialog/Dialog.js +4 -3
  55. package/dialog/Dialog.stories.tsx +212 -0
  56. package/dialog/Dialog.test.js +40 -0
  57. package/dropdown/Dropdown.d.ts +1 -1
  58. package/dropdown/Dropdown.js +13 -35
  59. package/dropdown/Dropdown.stories.tsx +249 -0
  60. package/dropdown/Dropdown.test.js +189 -0
  61. package/dropdown/types.d.ts +6 -15
  62. package/file-input/FileInput.d.ts +4 -0
  63. package/file-input/FileInput.js +167 -109
  64. package/file-input/FileInput.stories.tsx +507 -0
  65. package/file-input/FileInput.test.js +457 -0
  66. package/file-input/FileItem.d.ts +14 -0
  67. package/file-input/FileItem.js +12 -21
  68. package/file-input/types.d.ts +112 -0
  69. package/file-input/types.js +5 -0
  70. package/footer/Footer.d.ts +1 -1
  71. package/footer/Footer.js +28 -36
  72. package/footer/{Footer.stories.jsx → Footer.stories.tsx} +1 -22
  73. package/footer/Footer.test.js +109 -0
  74. package/footer/Icons.d.ts +2 -0
  75. package/footer/Icons.js +3 -3
  76. package/footer/types.d.ts +22 -18
  77. package/header/Header.js +2 -2
  78. package/header/Header.stories.tsx +162 -0
  79. package/header/Header.test.js +63 -0
  80. package/header/Icons.d.ts +2 -0
  81. package/header/types.d.ts +4 -2
  82. package/heading/Heading.d.ts +4 -0
  83. package/heading/Heading.js +7 -24
  84. package/heading/Heading.stories.tsx +54 -0
  85. package/heading/Heading.test.js +186 -0
  86. package/heading/types.d.ts +33 -0
  87. package/heading/types.js +5 -0
  88. package/inset/Inset.d.ts +3 -0
  89. package/inset/Inset.js +84 -0
  90. package/inset/Inset.stories.tsx +229 -0
  91. package/inset/types.d.ts +13 -0
  92. package/inset/types.js +5 -0
  93. package/layout/ApplicationLayout.d.ts +10 -0
  94. package/layout/ApplicationLayout.js +17 -21
  95. package/layout/ApplicationLayout.stories.tsx +171 -0
  96. package/layout/types.d.ts +57 -0
  97. package/layout/types.js +5 -0
  98. package/link/Link.js +10 -18
  99. package/link/Link.stories.tsx +151 -0
  100. package/link/Link.test.js +91 -0
  101. package/link/types.d.ts +5 -9
  102. package/list/List.d.ts +4 -0
  103. package/list/List.js +47 -0
  104. package/list/List.stories.tsx +95 -0
  105. package/list/types.d.ts +7 -0
  106. package/list/types.js +5 -0
  107. package/main.d.ts +10 -8
  108. package/main.js +54 -38
  109. package/number-input/NumberInput.d.ts +4 -0
  110. package/number-input/NumberInput.js +5 -50
  111. package/number-input/{NumberInput.stories.jsx → NumberInput.stories.tsx} +0 -0
  112. package/number-input/NumberInput.test.js +508 -0
  113. package/number-input/NumberInputContext.d.ts +4 -0
  114. package/number-input/NumberInputContext.js +5 -2
  115. package/number-input/numberInputContextTypes.d.ts +19 -0
  116. package/number-input/numberInputContextTypes.js +5 -0
  117. package/number-input/types.d.ts +117 -0
  118. package/number-input/types.js +5 -0
  119. package/package.json +4 -2
  120. package/paginator/Paginator.js +2 -8
  121. package/paginator/Paginator.test.js +266 -0
  122. package/password-input/PasswordInput.js +19 -18
  123. package/password-input/PasswordInput.stories.tsx +3 -3
  124. package/password-input/PasswordInput.test.js +183 -0
  125. package/password-input/types.d.ts +17 -10
  126. package/progress-bar/ProgressBar.js +4 -4
  127. package/progress-bar/ProgressBar.test.js +65 -0
  128. package/radio/Radio.js +2 -2
  129. package/radio/Radio.test.js +71 -0
  130. package/radio/types.d.ts +2 -2
  131. package/radio-group/Radio.d.ts +4 -0
  132. package/radio-group/Radio.js +141 -0
  133. package/radio-group/RadioGroup.d.ts +4 -0
  134. package/radio-group/RadioGroup.js +280 -0
  135. package/radio-group/RadioGroup.stories.tsx +100 -0
  136. package/radio-group/RadioGroup.test.js +695 -0
  137. package/radio-group/types.d.ts +114 -0
  138. package/radio-group/types.js +5 -0
  139. package/resultsetTable/ResultsetTable.d.ts +4 -0
  140. package/resultsetTable/ResultsetTable.js +9 -29
  141. package/resultsetTable/ResultsetTable.stories.tsx +275 -0
  142. package/resultsetTable/ResultsetTable.test.js +306 -0
  143. package/resultsetTable/types.d.ts +67 -0
  144. package/resultsetTable/types.js +5 -0
  145. package/row/Row.d.ts +3 -0
  146. package/row/Row.js +127 -0
  147. package/row/Row.stories.tsx +237 -0
  148. package/row/types.d.ts +10 -0
  149. package/row/types.js +5 -0
  150. package/select/Icons.d.ts +10 -0
  151. package/select/Icons.js +93 -0
  152. package/select/Option.d.ts +4 -0
  153. package/select/Option.js +110 -0
  154. package/select/Select.d.ts +4 -0
  155. package/select/Select.js +101 -226
  156. package/select/Select.stories.tsx +582 -0
  157. package/select/Select.test.js +2016 -0
  158. package/select/types.d.ts +191 -0
  159. package/select/types.js +5 -0
  160. package/sidenav/Sidenav.d.ts +9 -0
  161. package/sidenav/Sidenav.js +6 -15
  162. package/sidenav/Sidenav.stories.tsx +182 -0
  163. package/sidenav/Sidenav.test.js +56 -0
  164. package/sidenav/types.d.ts +50 -0
  165. package/sidenav/types.js +5 -0
  166. package/slider/Slider.d.ts +1 -1
  167. package/slider/Slider.js +43 -32
  168. package/slider/Slider.stories.tsx +177 -0
  169. package/slider/Slider.test.js +129 -0
  170. package/slider/types.d.ts +2 -7
  171. package/spinner/Spinner.js +2 -2
  172. package/spinner/Spinner.stories.jsx +1 -0
  173. package/spinner/Spinner.test.js +64 -0
  174. package/stack/Stack.d.ts +3 -0
  175. package/stack/Stack.js +97 -0
  176. package/stack/Stack.stories.tsx +164 -0
  177. package/stack/types.d.ts +24 -0
  178. package/stack/types.js +5 -0
  179. package/switch/Switch.js +2 -2
  180. package/switch/Switch.stories.tsx +1 -1
  181. package/switch/Switch.test.js +73 -0
  182. package/table/Table.js +3 -3
  183. package/table/Table.stories.jsx +2 -1
  184. package/table/Table.test.js +26 -0
  185. package/tabs/Tabs.js +11 -9
  186. package/tabs/Tabs.stories.tsx +120 -0
  187. package/tabs/Tabs.test.js +123 -0
  188. package/tabs/types.d.ts +25 -18
  189. package/tag/Tag.d.ts +1 -1
  190. package/tag/Tag.js +16 -23
  191. package/tag/Tag.stories.tsx +26 -29
  192. package/tag/Tag.test.js +60 -0
  193. package/tag/types.d.ts +23 -14
  194. package/text/Text.d.ts +7 -0
  195. package/text/Text.js +30 -0
  196. package/text/Text.stories.tsx +19 -0
  197. package/text-input/TextInput.d.ts +4 -0
  198. package/text-input/TextInput.js +62 -89
  199. package/text-input/TextInput.stories.tsx +474 -0
  200. package/text-input/TextInput.test.js +1725 -0
  201. package/text-input/types.d.ts +163 -0
  202. package/text-input/types.js +5 -0
  203. package/textarea/Textarea.d.ts +4 -0
  204. package/textarea/Textarea.js +35 -64
  205. package/textarea/Textarea.stories.jsx +37 -15
  206. package/textarea/Textarea.test.js +447 -0
  207. package/textarea/types.d.ts +134 -0
  208. package/textarea/types.js +5 -0
  209. package/toggle-group/ToggleGroup.d.ts +4 -0
  210. package/toggle-group/ToggleGroup.js +16 -45
  211. package/toggle-group/ToggleGroup.stories.tsx +173 -0
  212. package/toggle-group/ToggleGroup.test.js +125 -0
  213. package/toggle-group/types.d.ts +97 -0
  214. package/toggle-group/types.js +5 -0
  215. package/useTheme.d.ts +2 -0
  216. package/useTheme.js +1 -1
  217. package/wizard/Wizard.d.ts +4 -0
  218. package/wizard/Wizard.js +69 -59
  219. package/wizard/Wizard.stories.tsx +224 -0
  220. package/wizard/Wizard.test.js +128 -0
  221. package/wizard/types.d.ts +60 -0
  222. package/wizard/types.js +5 -0
  223. package/V3Select/V3Select.js +0 -455
  224. package/V3Select/index.d.ts +0 -27
  225. package/V3Textarea/V3Textarea.js +0 -260
  226. package/V3Textarea/index.d.ts +0 -27
  227. package/chip/index.d.ts +0 -22
  228. package/date/Date.js +0 -373
  229. package/date/index.d.ts +0 -27
  230. package/file-input/index.d.ts +0 -81
  231. package/heading/index.d.ts +0 -17
  232. package/input-text/Icons.js +0 -22
  233. package/input-text/InputText.js +0 -611
  234. package/input-text/index.d.ts +0 -36
  235. package/number-input/index.d.ts +0 -113
  236. package/resultsetTable/index.d.ts +0 -19
  237. package/select/index.d.ts +0 -131
  238. package/sidenav/index.d.ts +0 -13
  239. package/text-input/index.d.ts +0 -135
  240. package/textarea/index.d.ts +0 -117
  241. package/toggle/Toggle.js +0 -186
  242. package/toggle/index.d.ts +0 -21
  243. package/toggle-group/index.d.ts +0 -21
  244. package/upload/Upload.js +0 -201
  245. package/upload/buttons-upload/ButtonsUpload.js +0 -111
  246. package/upload/buttons-upload/Icons.js +0 -40
  247. package/upload/dragAndDropArea/DragAndDropArea.js +0 -225
  248. package/upload/dragAndDropArea/Icons.js +0 -39
  249. package/upload/file-upload/FileToUpload.js +0 -115
  250. package/upload/file-upload/Icons.js +0 -66
  251. package/upload/files-upload/FilesToUpload.js +0 -109
  252. package/upload/index.d.ts +0 -15
  253. package/upload/transaction/Icons.js +0 -160
  254. package/upload/transaction/Transaction.js +0 -104
  255. package/upload/transactions/Transactions.js +0 -94
  256. package/wizard/Icons.js +0 -65
  257. package/wizard/index.d.ts +0 -18
package/stack/Stack.js ADDED
@@ -0,0 +1,97 @@
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"] = Stack;
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
+ function Stack(_ref) {
19
+ var gutter = _ref.gutter,
20
+ divider = _ref.divider,
21
+ align = _ref.align,
22
+ _ref$as = _ref.as,
23
+ as = _ref$as === void 0 ? "div" : _ref$as,
24
+ children = _ref.children;
25
+ return /*#__PURE__*/_react["default"].createElement(StyledStack, {
26
+ gutter: gutter,
27
+ divider: divider,
28
+ align: align,
29
+ as: as
30
+ }, _react["default"].Children.map(children, function (child, index) {
31
+ return /*#__PURE__*/_react["default"].createElement(_react["default"].Fragment, null, child, divider && index !== _react["default"].Children.count(children) - 1 && /*#__PURE__*/_react["default"].createElement(Divider, null));
32
+ }));
33
+ }
34
+
35
+ var Divider = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n height: 1px;\n background-color: #999999;\n"])));
36
+
37
+ var StyledStack = _styledComponents["default"].div(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n flex-direction: column;\n align-items: ", ";\n gap: ", ";\n margin: 0;\n padding: 0;\n"])), function (_ref2) {
38
+ var align = _ref2.align;
39
+
40
+ switch (align) {
41
+ case "start":
42
+ return "flex-start";
43
+
44
+ case "center":
45
+ return "center";
46
+
47
+ case "end":
48
+ return "flex-end";
49
+
50
+ case "baseline":
51
+ return "baseline";
52
+
53
+ case "stretch":
54
+ return "stretch";
55
+
56
+ default:
57
+ return "initial";
58
+ }
59
+ }, function (_ref3) {
60
+ var gutter = _ref3.gutter,
61
+ divider = _ref3.divider;
62
+
63
+ switch (gutter) {
64
+ case "none":
65
+ return "0";
66
+
67
+ case "xxxsmall":
68
+ return "calc(0.125rem / ".concat(divider ? 2 : 1, ")");
69
+
70
+ case "xxsmall":
71
+ return "calc(0.25rem / ".concat(divider ? 2 : 1, ")");
72
+
73
+ case "xsmall":
74
+ return "calc(0.5rem / ".concat(divider ? 2 : 1, ")");
75
+
76
+ case "small":
77
+ return "calc(1rem / ".concat(divider ? 2 : 1, ")");
78
+
79
+ case "medium":
80
+ return "calc(1.5rem / ".concat(divider ? 2 : 1, ")");
81
+
82
+ case "large":
83
+ return "calc(2rem / ".concat(divider ? 2 : 1, ")");
84
+
85
+ case "xlarge":
86
+ return "calc(3rem / ".concat(divider ? 2 : 1, ")");
87
+
88
+ case "xxlarge":
89
+ return "calc(4rem / ".concat(divider ? 2 : 1, ")");
90
+
91
+ case "xxxlarge":
92
+ return "calc(5rem / ".concat(divider ? 2 : 1, ")");
93
+
94
+ default:
95
+ return "0";
96
+ }
97
+ });
@@ -0,0 +1,164 @@
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></Placeholder>
17
+ <Placeholder></Placeholder>
18
+ <Placeholder></Placeholder>
19
+ </DxcStack>
20
+ </Container>
21
+ <Title title="Align = baseline" theme="light" level={4} />
22
+ <Container>
23
+ <DxcStack align="baseline">
24
+ <Placeholder paddingLeft={20}></Placeholder>
25
+ <Placeholder></Placeholder>
26
+ <Placeholder paddingRight={60}></Placeholder>
27
+ </DxcStack>
28
+ </Container>
29
+ <Title title="Align = center" theme="light" level={4} />
30
+ <Container>
31
+ <DxcStack align="center">
32
+ <Placeholder paddingLeft={20}></Placeholder>
33
+ <Placeholder></Placeholder>
34
+ <Placeholder paddingLeft={60}></Placeholder>
35
+ </DxcStack>
36
+ </Container>
37
+ <Title title="Align = end" theme="light" level={4} />
38
+ <Container>
39
+ <DxcStack align="end">
40
+ <Placeholder paddingLeft={20}></Placeholder>
41
+ <Placeholder></Placeholder>
42
+ <Placeholder paddingLeft={60}></Placeholder>
43
+ </DxcStack>
44
+ </Container>
45
+ <Title title="Align = start" theme="light" level={4} />
46
+ <Container>
47
+ <DxcStack align="start">
48
+ <Placeholder paddingLeft={20}></Placeholder>
49
+ <Placeholder></Placeholder>
50
+ <Placeholder paddingLeft={60}></Placeholder>
51
+ </DxcStack>
52
+ </Container>
53
+ <Title title="Align = stretch" theme="light" level={4} />
54
+ <Container>
55
+ <DxcStack align="stretch">
56
+ <Placeholder paddingLeft={20}></Placeholder>
57
+ <Placeholder></Placeholder>
58
+ <Placeholder paddingLeft={60}></Placeholder>
59
+ </DxcStack>
60
+ </Container>
61
+ <Title title="gutter = xxxsmall" theme="light" level={4} />
62
+ <Container>
63
+ <DxcStack gutter="xxxsmall">
64
+ <Placeholder></Placeholder>
65
+ <Placeholder></Placeholder>
66
+ <Placeholder></Placeholder>
67
+ </DxcStack>
68
+ </Container>
69
+ <Title title="gutter = xxsmall" theme="light" level={4} />
70
+ <Container>
71
+ <DxcStack gutter="xxsmall">
72
+ <Placeholder></Placeholder>
73
+ <Placeholder></Placeholder>
74
+ <Placeholder></Placeholder>
75
+ </DxcStack>
76
+ </Container>
77
+ <Title title="gutter = xsmall" theme="light" level={4} />
78
+ <Container>
79
+ <DxcStack gutter="xsmall">
80
+ <Placeholder></Placeholder>
81
+ <Placeholder></Placeholder>
82
+ <Placeholder></Placeholder>
83
+ </DxcStack>
84
+ </Container>
85
+ <Title title="gutter = small" theme="light" level={4} />
86
+ <Container>
87
+ <DxcStack gutter="small">
88
+ <Placeholder></Placeholder>
89
+ <Placeholder></Placeholder>
90
+ <Placeholder></Placeholder>
91
+ </DxcStack>
92
+ </Container>
93
+ <Title title="gutter = medium" theme="light" level={4} />
94
+ <Container>
95
+ <DxcStack gutter="medium">
96
+ <Placeholder></Placeholder>
97
+ <Placeholder></Placeholder>
98
+ <Placeholder></Placeholder>
99
+ </DxcStack>
100
+ </Container>
101
+ <Title title="gutter = large" theme="light" level={4} />
102
+ <Container>
103
+ <DxcStack gutter="large">
104
+ <Placeholder></Placeholder>
105
+ <Placeholder></Placeholder>
106
+ <Placeholder></Placeholder>
107
+ </DxcStack>
108
+ </Container>
109
+ <Title title="gutter = xlarge" theme="light" level={4} />
110
+ <Container>
111
+ <DxcStack gutter="xlarge">
112
+ <Placeholder></Placeholder>
113
+ <Placeholder></Placeholder>
114
+ <Placeholder></Placeholder>
115
+ </DxcStack>
116
+ </Container>
117
+ <Title title="gutter = xxlarge" theme="light" level={4} />
118
+ <Container>
119
+ <DxcStack gutter="xxlarge">
120
+ <Placeholder></Placeholder>
121
+ <Placeholder></Placeholder>
122
+ <Placeholder></Placeholder>
123
+ </DxcStack>
124
+ </Container>
125
+ <Title title="gutter = xxxlarge" theme="light" level={4} />
126
+ <Container>
127
+ <DxcStack gutter="xxxlarge">
128
+ <Placeholder></Placeholder>
129
+ <Placeholder></Placeholder>
130
+ <Placeholder></Placeholder>
131
+ </DxcStack>
132
+ </Container>
133
+ <Title title="gutter = xxlarge && divider" theme="light" level={4} />
134
+ <Container>
135
+ <DxcStack gutter="xxlarge" divider>
136
+ <Placeholder></Placeholder>
137
+ <Placeholder></Placeholder>
138
+ <Placeholder></Placeholder>
139
+ </DxcStack>
140
+ </Container>
141
+ <Title title="gutter = none" theme="light" level={4} />
142
+ <Container>
143
+ <DxcStack gutter="none">
144
+ <Placeholder></Placeholder>
145
+ <Placeholder></Placeholder>
146
+ <Placeholder></Placeholder>
147
+ </DxcStack>
148
+ </Container>
149
+ </>
150
+ );
151
+
152
+ const Container = styled.div`
153
+ background: #f2eafa;
154
+ padding: 10px;
155
+ `;
156
+
157
+ const Placeholder = styled.div`
158
+ min-height: 40px;
159
+ min-width: 120px;
160
+ border: 1px solid #a46ede;
161
+ background-color: #e5d5f6;
162
+ padding-left: ${({ paddingLeft }) => `${paddingLeft ?? 0}px`};
163
+ padding-right: ${({ paddingRight }) => `${paddingRight ?? 0}px`};
164
+ `;
@@ -0,0 +1,24 @@
1
+ /// <reference types="react" />
2
+ declare type Props = {
3
+ /**
4
+ * Space applied between each child.
5
+ */
6
+ gutter?: "none" | "xxxsmall" | "xxsmall" | "xsmall" | "small" | "medium" | "large" | "xlarge" | "xxlarge" | "xxxlarge";
7
+ /**
8
+ * If true, a divider is shown between children.
9
+ */
10
+ divider?: boolean;
11
+ /**
12
+ * Alignment applied to children.
13
+ */
14
+ align?: "start" | "center" | "end" | "baseline" | "stretch";
15
+ /**
16
+ * Specifies the HTML tag or component that is rendered as the wrapper element.
17
+ */
18
+ as?: React.ElementType;
19
+ /**
20
+ * Custom content inside the stack.
21
+ */
22
+ children: React.ReactNode;
23
+ };
24
+ export default Props;
package/stack/types.js ADDED
@@ -0,0 +1,5 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
package/switch/Switch.js CHANGED
@@ -27,9 +27,9 @@ var _variables = require("../common/variables.js");
27
27
 
28
28
  var _utils = require("../common/utils.js");
29
29
 
30
- var _useTheme = _interopRequireDefault(require("../useTheme.js"));
30
+ var _useTheme = _interopRequireDefault(require("../useTheme"));
31
31
 
32
- var _BackgroundColorContext = _interopRequireDefault(require("../BackgroundColorContext.js"));
32
+ var _BackgroundColorContext = _interopRequireDefault(require("../BackgroundColorContext"));
33
33
 
34
34
  var _templateObject, _templateObject2;
35
35
 
@@ -72,7 +72,7 @@ export const Chromatic = () => (
72
72
  <Title title="Margins" theme="light" level={2} />
73
73
  <ExampleContainer>
74
74
  <Title title="Xxsmall margin" theme="light" level={4} />
75
- <DxcSwitch label="Xxsmmall" margin="xxsmall" />
75
+ <DxcSwitch label="Xxsmall" margin="xxsmall" />
76
76
  </ExampleContainer>
77
77
  <ExampleContainer>
78
78
  <Title title="Xsmall margin" theme="light" level={4} />
@@ -0,0 +1,73 @@
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 _Switch = _interopRequireDefault(require("./Switch"));
10
+
11
+ describe("Switch component tests", function () {
12
+ test("Switch renders with correct text", function () {
13
+ var onChange = jest.fn(function (returnedValue) {
14
+ expect(returnedValue).toBe(true);
15
+ });
16
+
17
+ var _render = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Switch["default"], {
18
+ label: "SwitchComponent",
19
+ checked: false,
20
+ onChange: onChange
21
+ })),
22
+ getByText = _render.getByText;
23
+
24
+ expect(getByText("SwitchComponent")).toBeTruthy();
25
+ });
26
+ test("Calls correct function on click", function () {
27
+ var onChange = jest.fn();
28
+
29
+ var _render2 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Switch["default"], {
30
+ label: "SwitchComponent",
31
+ checked: false,
32
+ onChange: onChange
33
+ })),
34
+ getByText = _render2.getByText;
35
+
36
+ _react2.fireEvent.click(getByText("SwitchComponent"));
37
+
38
+ expect(onChange).toHaveBeenCalled();
39
+ });
40
+ test("Everytime the user clicks the component the onchange function is called with the correct value CONTROLLED COMPONENT", function () {
41
+ var onChange = jest.fn();
42
+
43
+ var _render3 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Switch["default"], {
44
+ label: "SwitchComponent",
45
+ checked: false,
46
+ onChange: onChange
47
+ })),
48
+ getByText = _render3.getByText;
49
+
50
+ _react2.fireEvent.click(getByText("SwitchComponent"));
51
+
52
+ _react2.fireEvent.click(getByText("SwitchComponent"));
53
+
54
+ expect(onChange.mock.calls[0][0]).toBe(true);
55
+ expect(onChange.mock.calls[1][0]).toBe(true);
56
+ });
57
+ test("Everytime the user clicks the component the onchange function is called with the correct value UNCONTROLLED COMPONENT", function () {
58
+ var onChange = jest.fn();
59
+
60
+ var _render4 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Switch["default"], {
61
+ label: "SwitchComponent",
62
+ onChange: onChange
63
+ })),
64
+ getByText = _render4.getByText;
65
+
66
+ _react2.fireEvent.click(getByText("SwitchComponent"));
67
+
68
+ _react2.fireEvent.click(getByText("SwitchComponent"));
69
+
70
+ expect(onChange.mock.calls[0][0]).toBe(true);
71
+ expect(onChange.mock.calls[1][0]).toBe(false);
72
+ });
73
+ });
package/table/Table.js CHANGED
@@ -21,9 +21,9 @@ var _variables = require("../common/variables.js");
21
21
 
22
22
  var _utils = require("../common/utils.js");
23
23
 
24
- var _useTheme = _interopRequireDefault(require("../useTheme.js"));
24
+ var _useTheme = _interopRequireDefault(require("../useTheme"));
25
25
 
26
- var _BackgroundColorContext = require("../BackgroundColorContext.js");
26
+ var _BackgroundColorContext = require("../BackgroundColorContext");
27
27
 
28
28
  var _templateObject, _templateObject2;
29
29
 
@@ -48,7 +48,7 @@ var calculateWidth = function calculateWidth(margin) {
48
48
  return "calc(100% - ".concat((0, _utils.getMargin)(margin, "left"), " - ").concat((0, _utils.getMargin)(margin, "right"), ")");
49
49
  };
50
50
 
51
- var DxcTableContainer = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n width: ", ";\n margin: ", ";\n margin-top: ", ";\n margin-right: ", ";\n margin-bottom: ", ";\n margin-left: ", ";\n\n overflow: hidden auto;\n &::-webkit-scrollbar {\n width: 8px;\n }\n &::-webkit-scrollbar-thumb {\n background-color: ", ";\n border-radius: 6px;\n }\n &::-webkit-scrollbar-track {\n background-color: ", ";\n border-radius: 6px;\n }\n"])), function (props) {
51
+ var DxcTableContainer = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n width: ", ";\n margin: ", ";\n margin-top: ", ";\n margin-right: ", ";\n margin-bottom: ", ";\n margin-left: ", ";\n\n overflow: auto;\n &::-webkit-scrollbar {\n width: 8px;\n height: 8px;\n }\n &::-webkit-scrollbar-thumb {\n background-color: ", ";\n border-radius: 6px;\n }\n &::-webkit-scrollbar-track {\n background-color: ", ";\n border-radius: 6px;\n }\n"])), function (props) {
52
52
  return calculateWidth(props.margin);
53
53
  }, function (props) {
54
54
  return props.margin && (0, _typeof2["default"])(props.margin) !== "object" ? _variables.spaces[props.margin] : "0px";
@@ -271,6 +271,7 @@ export const Chromatic = () => (
271
271
  <td>Cell 9</td>
272
272
  </tr>
273
273
  </DxcTable>
274
+ <hr />
274
275
  </ExampleContainer>
275
276
  </>
276
- );
277
+ );
@@ -0,0 +1,26 @@
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 _Table = _interopRequireDefault(require("./Table"));
10
+
11
+ describe("Table component tests", function () {
12
+ test("Table renders with correct content", function () {
13
+ var _render = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Table["default"], null, /*#__PURE__*/_react["default"].createElement("tr", null, /*#__PURE__*/_react["default"].createElement("th", null, "header-1"), /*#__PURE__*/_react["default"].createElement("th", null, "header-2"), /*#__PURE__*/_react["default"].createElement("th", null, "header-3")), /*#__PURE__*/_react["default"].createElement("tr", null, /*#__PURE__*/_react["default"].createElement("td", null, "cell-1"), /*#__PURE__*/_react["default"].createElement("td", null, "cell-2"), /*#__PURE__*/_react["default"].createElement("td", null, "cell-3")), /*#__PURE__*/_react["default"].createElement("tr", null, /*#__PURE__*/_react["default"].createElement("td", null, "cell-4"), /*#__PURE__*/_react["default"].createElement("td", null, "cell-5"), /*#__PURE__*/_react["default"].createElement("td", null, "cell-6")))),
14
+ getByText = _render.getByText;
15
+
16
+ expect(getByText("header-1")).toBeTruthy();
17
+ expect(getByText("header-2")).toBeTruthy();
18
+ expect(getByText("header-3")).toBeTruthy();
19
+ expect(getByText("cell-1")).toBeTruthy();
20
+ expect(getByText("cell-2")).toBeTruthy();
21
+ expect(getByText("cell-3")).toBeTruthy();
22
+ expect(getByText("cell-4")).toBeTruthy();
23
+ expect(getByText("cell-5")).toBeTruthy();
24
+ expect(getByText("cell-6")).toBeTruthy();
25
+ });
26
+ });
package/tabs/Tabs.js CHANGED
@@ -9,10 +9,10 @@ Object.defineProperty(exports, "__esModule", {
9
9
  });
10
10
  exports["default"] = void 0;
11
11
 
12
- var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
13
-
14
12
  var _typeof2 = _interopRequireDefault(require("@babel/runtime/helpers/typeof"));
15
13
 
14
+ var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
15
+
16
16
  var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
17
17
 
18
18
  var _react = _interopRequireDefault(require("react"));
@@ -27,7 +27,7 @@ var _variables = require("../common/variables.js");
27
27
 
28
28
  var _Badge = _interopRequireDefault(require("../badge/Badge"));
29
29
 
30
- var _useTheme = _interopRequireDefault(require("../useTheme.js"));
30
+ var _useTheme = _interopRequireDefault(require("../useTheme"));
31
31
 
32
32
  var _templateObject, _templateObject2, _templateObject3, _templateObject4, _templateObject5, _templateObject6, _templateObject7, _templateObject8, _templateObject9;
33
33
 
@@ -70,12 +70,12 @@ var DxcTabs = function DxcTabs(_ref) {
70
70
  }, /*#__PURE__*/_react["default"].createElement(TabLabelContainer, {
71
71
  hasLabelAndIcon: hasLabelAndIcon,
72
72
  iconPosition: iconPosition
73
- }, tab.icon ? /*#__PURE__*/_react["default"].createElement(TabIconContainer, {
73
+ }, tab.icon && /*#__PURE__*/_react["default"].createElement(TabIconContainer, {
74
74
  hasLabelAndIcon: hasLabelAndIcon,
75
75
  iconPosition: iconPosition
76
- }, (0, _typeof2["default"])(tab.icon) === "object" ? tab.icon : /*#__PURE__*/_react["default"].createElement(tab.icon)) : tab.iconSrc && /*#__PURE__*/_react["default"].createElement(TabIcon, {
77
- src: tab.iconSrc
78
- }), /*#__PURE__*/_react["default"].createElement(LabelTextContainer, null, tab.label))), tab.notificationNumber && tab.notificationNumber !== false && /*#__PURE__*/_react["default"].createElement(BadgeContainer, {
76
+ }, typeof tab.icon === "string" ? /*#__PURE__*/_react["default"].createElement(TabIcon, {
77
+ src: tab.icon
78
+ }) : tab.icon), /*#__PURE__*/_react["default"].createElement(LabelTextContainer, null, tab.label))), tab.notificationNumber && tab.notificationNumber !== false && /*#__PURE__*/_react["default"].createElement(BadgeContainer, {
79
79
  hasLabelAndIcon: hasLabelAndIcon,
80
80
  iconPosition: iconPosition
81
81
  }, /*#__PURE__*/_react["default"].createElement(_Badge["default"], {
@@ -135,7 +135,7 @@ var Underline = _styledComponents["default"].div(_templateObject6 || (_templateO
135
135
  return props.theme.dividerColor;
136
136
  });
137
137
 
138
- var DxCTabs = _styledComponents["default"].div(_templateObject7 || (_templateObject7 = (0, _taggedTemplateLiteral2["default"])(["\n position: relative;\n margin: ", ";\n margin-top: ", ";\n margin-right: ", ";\n margin-bottom: ", ";\n margin-left: ", ";\n\n .MuiTabs-root {\n background: white;\n min-height: ", ";\n\n .MuiTabs-scroller {\n .MuiTabs-flexContainer + span {\n z-index: 4;\n }\n }\n .MuiTab-root {\n text-transform: ", " !important;\n }\n .MuiButtonBase-root {\n font-family: ", ";\n font-size: ", ";\n font-style: ", ";\n font-weight: ", ";\n\n padding: ", ";\n height: ", ";\n min-width: 90px;\n max-width: 360px;\n min-height: ", ";\n\n &:hover {\n background-color: ", ";\n }\n &:active {\n background-color: ", ";\n font-weight: ", ";\n }\n &:not(.Mui-selected) {\n background-color: ", ";\n color: ", ";\n svg {\n color: ", ";\n }\n }\n &.Mui-selected {\n background-color: ", ";\n color: ", ";\n svg {\n color: ", ";\n }\n }\n &.Mui-disabled {\n cursor: not-allowed !important;\n pointer-events: all;\n color: ", ";\n font-style: ", ";\n svg {\n color: ", ";\n }\n }\n &:focus {\n outline: ", " auto 1px;\n }\n }\n .MuiTabs-indicator {\n background-color: ", ";\n height: ", ";\n }\n .MuiTabs-scrollButtons {\n min-width: ", ";\n width: ", ";\n padding: 0;\n }\n @media (max-width: 599.95px) {\n .MuiTabs-scrollButtonsDesktop {\n display: flex;\n }\n }\n }\n"])), function (props) {
138
+ var DxCTabs = _styledComponents["default"].div(_templateObject7 || (_templateObject7 = (0, _taggedTemplateLiteral2["default"])(["\n position: relative;\n margin: ", ";\n margin-top: ", ";\n margin-right: ", ";\n margin-bottom: ", ";\n margin-left: ", ";\n\n .MuiTabs-root {\n background: white;\n min-height: ", ";\n\n .MuiTabs-scroller {\n .MuiTabs-flexContainer + span {\n z-index: 4;\n }\n }\n .MuiTab-root {\n text-transform: ", " !important;\n }\n .MuiButtonBase-root {\n font-family: ", ";\n font-size: ", ";\n font-style: ", ";\n font-weight: ", ";\n\n padding: ", ";\n height: ", ";\n min-width: 90px;\n max-width: 360px;\n min-height: ", ";\n\n &:hover {\n background-color: ", ";\n }\n &:active {\n background-color: ", ";\n font-weight: ", ";\n }\n &:not(.Mui-selected) {\n background-color: ", ";\n color: ", ";\n svg {\n color: ", ";\n }\n }\n &.Mui-selected {\n background-color: ", ";\n color: ", ";\n svg {\n color: ", ";\n }\n }\n &.Mui-disabled {\n background-color: ", " !important;\n cursor: not-allowed !important;\n pointer-events: all;\n color: ", ";\n font-style: ", ";\n svg {\n color: ", ";\n }\n outline: none !important;\n }\n &:focus {\n outline: ", " auto 1px;\n }\n }\n .MuiTabs-indicator {\n background-color: ", ";\n height: ", ";\n }\n .MuiTabs-scrollButtons {\n min-width: ", ";\n width: ", ";\n padding: 0;\n }\n @media (max-width: 599.95px) {\n .MuiTabs-scrollButtonsDesktop {\n display: flex;\n }\n }\n }\n"])), function (props) {
139
139
  return props.margin && (0, _typeof2["default"])(props.margin) !== "object" ? _variables.spaces[props.margin] : "0px";
140
140
  }, function (props) {
141
141
  return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.top ? _variables.spaces[props.margin.top] : "";
@@ -181,6 +181,8 @@ var DxCTabs = _styledComponents["default"].div(_templateObject7 || (_templateObj
181
181
  return props.theme.selectedFontColor;
182
182
  }, function (props) {
183
183
  return props.theme.selectedIconColor;
184
+ }, function (props) {
185
+ return props.theme.unselectedBackgroundColor;
184
186
  }, function (props) {
185
187
  return props.theme.disabledFontColor;
186
188
  }, function (props) {
@@ -199,7 +201,7 @@ var DxCTabs = _styledComponents["default"].div(_templateObject7 || (_templateObj
199
201
  return props.theme.scrollButtonsWidth;
200
202
  });
201
203
 
202
- var TabIcon = _styledComponents["default"].img(_templateObject8 || (_templateObject8 = (0, _taggedTemplateLiteral2["default"])(["\n max-height: 22px;\n max-width: 22px;\n"])));
204
+ var TabIcon = _styledComponents["default"].img(_templateObject8 || (_templateObject8 = (0, _taggedTemplateLiteral2["default"])([""])));
203
205
 
204
206
  var TabIconContainer = _styledComponents["default"].div(_templateObject9 || (_templateObject9 = (0, _taggedTemplateLiteral2["default"])(["\n max-height: 22px;\n max-width: 22px;\n margin-bottom: ", ";\n margin-right: ", ";\n overflow: hidden;\n display: flex;\n align-items: center;\n img,\n svg {\n height: 100%;\n width: 100%;\n }\n"])), function (props) {
205
207
  return props.hasLabelAndIcon && props.iconPosition === "top" && "8px" || "";
@@ -0,0 +1,120 @@
1
+ import React from "react";
2
+ import { userEvent, within } from "@storybook/testing-library";
3
+ import DxcTabs from "./Tabs";
4
+ import Title from "../../.storybook/components/Title";
5
+ import ExampleContainer from "../../.storybook/components/ExampleContainer";
6
+
7
+ export default {
8
+ title: "Tabs",
9
+ component: DxcTabs,
10
+ };
11
+
12
+ const iconSVG = (
13
+ <svg viewBox="0 0 24 24" fill="currentColor">
14
+ <path d="M0 0h24v24H0z" fill="none" />
15
+ <path d="M12 21.35l-1.45-1.32C5.4 15.36 2 12.28 2 8.5 2 5.42 4.42 3 7.5 3c1.74 0 3.41.81 4.5 2.09C13.09 3.81 14.76 3 16.5 3 19.58 3 22 5.42 22 8.5c0 3.78-3.4 6.86-8.55 11.54L12 21.35z" />
16
+ </svg>
17
+ );
18
+
19
+ const tabs: any = [
20
+ {
21
+ label: "Tab 1",
22
+ },
23
+ {
24
+ label: "Tab 2",
25
+ },
26
+ {
27
+ label: "Tab 3",
28
+ isDisabled: true,
29
+ },
30
+ {
31
+ label: "Tab 4",
32
+ },
33
+ ];
34
+
35
+ const tabsNotification = tabs.map((tab, index) => ({
36
+ ...tab,
37
+ notificationNumber: (index === 0 && true) || (index === 1 && 5) || (index === 2 && 200),
38
+ }));
39
+
40
+ const tabsIcon = tabs.map((tab) => ({ ...tab, icon: iconSVG }));
41
+
42
+ const tabsNotificationIcon = tabsNotification.map((tab) => ({ ...tab, icon: iconSVG }));
43
+
44
+ export const Chromatic = () => (
45
+ <>
46
+ <ExampleContainer>
47
+ <Title title="Only label" theme="light" level={4} />
48
+ <DxcTabs tabs={tabs} />
49
+ </ExampleContainer>
50
+ <ExampleContainer pseudoState="pseudo-hover">
51
+ <Title title="Hovered tabs" theme="light" level={4} />
52
+ <DxcTabs tabs={tabs} />
53
+ </ExampleContainer>
54
+ <ExampleContainer pseudoState="pseudo-focus">
55
+ <Title title="Focused tabs" theme="light" level={4} />
56
+ <DxcTabs tabs={tabs} />
57
+ </ExampleContainer>
58
+ <ExampleContainer pseudoState="pseudo-active">
59
+ <Title title="Actived tabs" theme="light" level={4} />
60
+ <DxcTabs tabs={tabs} />
61
+ </ExampleContainer>
62
+ <ExampleContainer>
63
+ <Title title="With notification number" theme="light" level={4} />
64
+ <DxcTabs tabs={tabsNotification} />
65
+ </ExampleContainer>
66
+ <ExampleContainer>
67
+ <Title title="With icon position top" theme="light" level={4} />
68
+ <DxcTabs tabs={tabsIcon} />
69
+ </ExampleContainer>
70
+ <ExampleContainer>
71
+ <Title title="With icon position left" theme="light" level={4} />
72
+ <DxcTabs tabs={tabsIcon} iconPosition="left" />
73
+ </ExampleContainer>
74
+ <ExampleContainer>
75
+ <Title title="With icon and notification number" theme="light" level={4} />
76
+ <DxcTabs tabs={tabsNotificationIcon} />
77
+ </ExampleContainer>
78
+ <ExampleContainer>
79
+ <Title title="With icon on the left and notification number" theme="light" level={4} />
80
+ <DxcTabs tabs={tabsNotificationIcon} iconPosition="left" />
81
+ </ExampleContainer>
82
+ <ExampleContainer>
83
+ <Title title="Scrollable" theme="light" level={4} />
84
+ <div style={{ width: "400px" }}>
85
+ <DxcTabs tabs={tabsNotificationIcon} iconPosition="left" activeTabIndex={1} />
86
+ </div>
87
+ </ExampleContainer>
88
+
89
+ <Title title="Margins" theme="light" level={2} />
90
+ <ExampleContainer>
91
+ <Title title="Xxsmall margin" theme="light" level={4} />
92
+ <DxcTabs tabs={tabs} margin="xxsmall" />
93
+ </ExampleContainer>
94
+ <ExampleContainer>
95
+ <Title title="Xsmall margin" theme="light" level={4} />
96
+ <DxcTabs tabs={tabs} margin="xsmall" />
97
+ </ExampleContainer>
98
+ <ExampleContainer>
99
+ <Title title="Small margin" theme="light" level={4} />
100
+ <DxcTabs tabs={tabs} margin="small" />
101
+ </ExampleContainer>
102
+ <ExampleContainer>
103
+ <Title title="Medium margin" theme="light" level={4} />
104
+ <DxcTabs tabs={tabs} margin="medium" />
105
+ </ExampleContainer>
106
+ <ExampleContainer>
107
+ <Title title="Large margin" theme="light" level={4} />
108
+ <DxcTabs tabs={tabs} margin="large" />
109
+ </ExampleContainer>
110
+ <ExampleContainer>
111
+ <Title title="Xlarge margin" theme="light" level={4} />
112
+ <DxcTabs tabs={tabs} margin="xlarge" />
113
+ </ExampleContainer>
114
+ <ExampleContainer>
115
+ <Title title="Xxlarge margin" theme="light" level={4} />
116
+ <DxcTabs tabs={tabs} margin="xxlarge" />
117
+ <hr />
118
+ </ExampleContainer>
119
+ </>
120
+ );