@dxc-technology/halstack-react 0.0.0-ee92231 → 0.0.0-f0d662d

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 (203) hide show
  1. package/BackgroundColorContext.d.ts +10 -0
  2. package/BackgroundColorContext.js +1 -4
  3. package/ThemeContext.d.ts +15 -0
  4. package/ThemeContext.js +5 -8
  5. package/V3Select/V3Select.js +2 -2
  6. package/V3Textarea/V3Textarea.js +2 -2
  7. package/accordion/Accordion.js +2 -2
  8. package/accordion/Accordion.stories.tsx +307 -0
  9. package/accordion/types.d.ts +1 -1
  10. package/accordion-group/AccordionGroup.js +2 -2
  11. package/accordion-group/AccordionGroup.stories.tsx +225 -0
  12. package/accordion-group/types.d.ts +1 -1
  13. package/alert/Alert.js +2 -2
  14. package/alert/Alert.stories.tsx +170 -0
  15. package/alert/types.d.ts +1 -1
  16. package/badge/Badge.js +1 -1
  17. package/bleed/Bleed.d.ts +3 -0
  18. package/bleed/Bleed.js +84 -0
  19. package/bleed/Bleed.stories.tsx +342 -0
  20. package/bleed/types.d.ts +13 -0
  21. package/bleed/types.js +5 -0
  22. package/box/Box.d.ts +1 -1
  23. package/box/Box.js +4 -7
  24. package/box/types.d.ts +0 -4
  25. package/button/Button.d.ts +1 -1
  26. package/button/Button.js +13 -19
  27. package/button/Button.stories.tsx +222 -241
  28. package/button/types.d.ts +5 -9
  29. package/card/Card.js +5 -6
  30. package/card/Card.stories.tsx +201 -0
  31. package/card/ice-cream.jpg +0 -0
  32. package/card/types.d.ts +4 -6
  33. package/checkbox/Checkbox.js +2 -2
  34. package/checkbox/types.d.ts +2 -2
  35. package/chip/Chip.d.ts +4 -0
  36. package/chip/Chip.js +5 -27
  37. package/chip/Chip.stories.tsx +121 -0
  38. package/chip/types.d.ts +53 -0
  39. package/chip/types.js +5 -0
  40. package/common/variables.js +70 -27
  41. package/date/Date.js +1 -1
  42. package/date-input/DateInput.js +10 -13
  43. package/date-input/DateInput.stories.tsx +138 -0
  44. package/dialog/Dialog.js +4 -3
  45. package/dialog/Dialog.stories.tsx +212 -0
  46. package/dropdown/Dropdown.js +1 -1
  47. package/dropdown/Dropdown.stories.tsx +247 -0
  48. package/dropdown/types.d.ts +1 -1
  49. package/file-input/FileInput.d.ts +4 -0
  50. package/file-input/FileInput.js +167 -109
  51. package/file-input/FileInput.stories.tsx +507 -0
  52. package/file-input/FileItem.d.ts +14 -0
  53. package/file-input/FileItem.js +12 -21
  54. package/file-input/types.d.ts +112 -0
  55. package/file-input/types.js +5 -0
  56. package/footer/Footer.d.ts +1 -1
  57. package/footer/Footer.js +28 -36
  58. package/footer/{Footer.stories.jsx → Footer.stories.tsx} +1 -22
  59. package/footer/Icons.d.ts +2 -0
  60. package/footer/Icons.js +3 -3
  61. package/footer/types.d.ts +22 -18
  62. package/header/Header.js +2 -2
  63. package/header/Header.stories.tsx +162 -0
  64. package/header/Icons.d.ts +2 -0
  65. package/header/types.d.ts +4 -2
  66. package/heading/Heading.d.ts +4 -0
  67. package/heading/Heading.js +7 -24
  68. package/heading/Heading.stories.tsx +54 -0
  69. package/heading/types.d.ts +33 -0
  70. package/heading/types.js +5 -0
  71. package/input-text/InputText.js +2 -2
  72. package/inset/Inset.d.ts +3 -0
  73. package/inset/Inset.js +84 -0
  74. package/inset/Inset.stories.tsx +229 -0
  75. package/inset/types.d.ts +13 -0
  76. package/inset/types.js +5 -0
  77. package/layout/ApplicationLayout.d.ts +10 -0
  78. package/layout/ApplicationLayout.js +9 -19
  79. package/layout/ApplicationLayout.stories.tsx +171 -0
  80. package/layout/types.d.ts +57 -0
  81. package/layout/types.js +5 -0
  82. package/link/Link.js +3 -3
  83. package/link/Link.stories.tsx +146 -0
  84. package/list/List.d.ts +4 -0
  85. package/list/List.js +47 -0
  86. package/list/List.stories.tsx +95 -0
  87. package/list/types.d.ts +7 -0
  88. package/list/types.js +5 -0
  89. package/main.d.ts +7 -3
  90. package/main.js +34 -2
  91. package/number-input/NumberInput.d.ts +4 -0
  92. package/number-input/NumberInput.js +5 -50
  93. package/number-input/{NumberInput.stories.jsx → NumberInput.stories.tsx} +0 -0
  94. package/number-input/NumberInputContext.d.ts +4 -0
  95. package/number-input/NumberInputContext.js +5 -2
  96. package/number-input/numberInputContextTypes.d.ts +19 -0
  97. package/number-input/numberInputContextTypes.js +5 -0
  98. package/number-input/types.d.ts +117 -0
  99. package/number-input/types.js +5 -0
  100. package/package.json +4 -2
  101. package/paginator/Paginator.js +2 -8
  102. package/password-input/PasswordInput.js +19 -18
  103. package/password-input/PasswordInput.stories.tsx +3 -3
  104. package/password-input/types.d.ts +17 -10
  105. package/progress-bar/ProgressBar.js +4 -4
  106. package/radio/Radio.js +2 -2
  107. package/radio/types.d.ts +2 -2
  108. package/radio-group/Radio.d.ts +4 -0
  109. package/radio-group/Radio.js +140 -0
  110. package/radio-group/RadioGroup.d.ts +4 -0
  111. package/radio-group/RadioGroup.js +273 -0
  112. package/radio-group/RadioGroup.stories.tsx +79 -0
  113. package/radio-group/RadioGroup.test.js +248 -0
  114. package/radio-group/types.d.ts +36 -0
  115. package/radio-group/types.js +5 -0
  116. package/resultsetTable/ResultsetTable.d.ts +4 -0
  117. package/resultsetTable/ResultsetTable.js +5 -28
  118. package/resultsetTable/ResultsetTable.stories.tsx +275 -0
  119. package/resultsetTable/types.d.ts +67 -0
  120. package/resultsetTable/types.js +5 -0
  121. package/row/Row.d.ts +3 -0
  122. package/row/Row.js +127 -0
  123. package/row/Row.stories.tsx +237 -0
  124. package/row/types.d.ts +10 -0
  125. package/row/types.js +5 -0
  126. package/select/Select.d.ts +4 -0
  127. package/select/Select.js +20 -22
  128. package/select/Select.stories.tsx +572 -0
  129. package/select/types.d.ts +170 -0
  130. package/select/types.js +5 -0
  131. package/sidenav/Sidenav.d.ts +9 -0
  132. package/sidenav/Sidenav.js +6 -15
  133. package/sidenav/Sidenav.stories.tsx +182 -0
  134. package/sidenav/types.d.ts +50 -0
  135. package/sidenav/types.js +5 -0
  136. package/slider/Slider.d.ts +1 -1
  137. package/slider/Slider.js +43 -32
  138. package/slider/Slider.stories.tsx +177 -0
  139. package/slider/types.d.ts +2 -7
  140. package/spinner/Spinner.js +2 -2
  141. package/spinner/Spinner.stories.jsx +1 -0
  142. package/stack/Stack.d.ts +3 -0
  143. package/stack/Stack.js +97 -0
  144. package/stack/Stack.stories.tsx +164 -0
  145. package/stack/types.d.ts +9 -0
  146. package/stack/types.js +5 -0
  147. package/switch/Switch.js +2 -2
  148. package/switch/Switch.stories.tsx +1 -1
  149. package/table/Table.js +3 -3
  150. package/table/Table.stories.jsx +2 -1
  151. package/tabs/Tabs.js +11 -9
  152. package/tabs/Tabs.stories.tsx +120 -0
  153. package/tabs/types.d.ts +25 -18
  154. package/tag/Tag.d.ts +4 -0
  155. package/tag/Tag.js +4 -25
  156. package/tag/{Tag.stories.jsx → Tag.stories.tsx} +1 -1
  157. package/tag/types.d.ts +60 -0
  158. package/tag/types.js +5 -0
  159. package/text/Text.d.ts +7 -0
  160. package/text/Text.js +30 -0
  161. package/text/Text.stories.tsx +19 -0
  162. package/text-input/TextInput.d.ts +4 -0
  163. package/text-input/TextInput.js +54 -85
  164. package/text-input/TextInput.stories.tsx +456 -0
  165. package/text-input/types.d.ts +159 -0
  166. package/text-input/types.js +5 -0
  167. package/textarea/Textarea.d.ts +4 -0
  168. package/textarea/Textarea.js +27 -60
  169. package/textarea/Textarea.stories.jsx +4 -3
  170. package/textarea/types.d.ts +130 -0
  171. package/textarea/types.js +5 -0
  172. package/toggle/Toggle.js +1 -1
  173. package/toggle-group/ToggleGroup.d.ts +4 -0
  174. package/toggle-group/ToggleGroup.js +16 -45
  175. package/toggle-group/ToggleGroup.stories.tsx +173 -0
  176. package/toggle-group/types.d.ts +97 -0
  177. package/toggle-group/types.js +5 -0
  178. package/upload/buttons-upload/ButtonsUpload.js +2 -2
  179. package/upload/dragAndDropArea/DragAndDropArea.js +2 -2
  180. package/upload/file-upload/FileToUpload.js +1 -1
  181. package/upload/files-upload/FilesToUpload.js +1 -1
  182. package/upload/transaction/Transaction.js +2 -2
  183. package/upload/transactions/Transactions.js +1 -1
  184. package/useTheme.d.ts +2 -0
  185. package/useTheme.js +1 -1
  186. package/wizard/Wizard.d.ts +4 -0
  187. package/wizard/Wizard.js +69 -59
  188. package/wizard/Wizard.stories.tsx +224 -0
  189. package/wizard/types.d.ts +60 -0
  190. package/wizard/types.js +5 -0
  191. package/chip/index.d.ts +0 -22
  192. package/file-input/index.d.ts +0 -81
  193. package/heading/index.d.ts +0 -17
  194. package/number-input/index.d.ts +0 -113
  195. package/resultsetTable/index.d.ts +0 -19
  196. package/select/index.d.ts +0 -131
  197. package/sidenav/index.d.ts +0 -13
  198. package/tag/index.d.ts +0 -24
  199. package/text-input/index.d.ts +0 -135
  200. package/textarea/index.d.ts +0 -117
  201. package/toggle-group/index.d.ts +0 -21
  202. package/wizard/Icons.js +0 -65
  203. package/wizard/index.d.ts +0 -18
@@ -0,0 +1,177 @@
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
+
8
+ export default {
9
+ title: "Slider",
10
+ component: DxcSlider,
11
+ };
12
+
13
+ const labelFormat = (value) => `${value}E100000000000000000000000`;
14
+
15
+ export const Chromatic = () => (
16
+ <>
17
+ <Title title="States" theme="light" level={2} />
18
+ <ExampleContainer pseudoState="pseudo-hover">
19
+ <Title title="Hovered" theme="light" level={4} />
20
+ <DxcSlider label="Slider" helperText="Help message" showLimitsValues />
21
+ </ExampleContainer>
22
+ <ExampleContainer pseudoState="pseudo-active">
23
+ <Title title="Active" theme="light" level={4} />
24
+ <DxcSlider label="Slider" helperText="Help message" showLimitsValues />
25
+ </ExampleContainer>
26
+ <ExampleContainer pseudoState="pseudo-focus">
27
+ <Title title="Focused" theme="light" level={4} />
28
+ <DxcSlider label="Slider" helperText="Help message" showLimitsValues />
29
+ </ExampleContainer>
30
+ <ExampleContainer>
31
+ <Title title="Disabled" theme="light" level={4} />
32
+ <DxcSlider label="Slider" helperText="Help message" disabled showLimitsValues />
33
+ </ExampleContainer>
34
+ <ExampleContainer>
35
+ <Title title="Disabled discrete slider with input" theme="light" level={4} />
36
+ <DxcSlider
37
+ label="Slider"
38
+ helperText="Help message"
39
+ disabled
40
+ value={40}
41
+ minValue={0}
42
+ maxValue={50}
43
+ showLimitsValues
44
+ showInput
45
+ marks
46
+ step={10}
47
+ />
48
+ </ExampleContainer>
49
+ <Title title="Variants" theme="light" level={2} />
50
+ <ExampleContainer>
51
+ <Title title="Continuous slider" theme="light" level={4} />
52
+ <DxcSlider value={65} label="Slider" helperText="Help message" showLimitsValues />
53
+ </ExampleContainer>
54
+ <ExampleContainer>
55
+ <Title title="Discrete slider" theme="light" level={4} />
56
+ <DxcSlider value={20} label="Slider" helperText="Help message" showLimitsValues marks step={5} />
57
+ </ExampleContainer>
58
+ <ExampleContainer>
59
+ <Title title="Discrete slider with input" theme="light" level={4} />
60
+ <DxcSlider
61
+ value={20}
62
+ minValue={0}
63
+ maxValue={50}
64
+ label="Slider"
65
+ helperText="Help message"
66
+ showLimitsValues
67
+ showInput
68
+ marks
69
+ step={10}
70
+ />
71
+ </ExampleContainer>
72
+ <BackgroundColorProvider color="#333333">
73
+ <DarkContainer>
74
+ <Title title="Dark" theme="dark" level={2} />
75
+ <ExampleContainer pseudoState="pseudo-hover">
76
+ <Title title="Hovered" theme="dark" level={4} />
77
+ <DxcSlider label="Slider" helperText="Help message" showLimitsValues />
78
+ </ExampleContainer>
79
+ <ExampleContainer pseudoState="pseudo-active">
80
+ <Title title="Active" theme="dark" level={4} />
81
+ <DxcSlider label="Slider" helperText="Help message" showLimitsValues />
82
+ </ExampleContainer>
83
+ <ExampleContainer pseudoState="pseudo-focus">
84
+ <Title title="Focused" theme="dark" level={4} />
85
+ <DxcSlider label="Slider" helperText="Help message" showLimitsValues />
86
+ </ExampleContainer>
87
+ <ExampleContainer>
88
+ <Title title="Disabled" theme="dark" level={4} />
89
+ <DxcSlider label="Slider" helperText="Help message" disabled showLimitsValues />
90
+ </ExampleContainer>
91
+ <ExampleContainer>
92
+ <Title title="Disabled discrete slider with input" theme="dark" level={4} />
93
+ <DxcSlider
94
+ label="Slider"
95
+ helperText="Help message"
96
+ disabled
97
+ value={40}
98
+ minValue={0}
99
+ maxValue={50}
100
+ showLimitsValues
101
+ showInput
102
+ marks
103
+ step={5}
104
+ />
105
+ </ExampleContainer>
106
+ <ExampleContainer>
107
+ <Title title="Continuous slider" theme="dark" level={4} />
108
+ <DxcSlider value={65} label="Slider" helperText="Help message" showLimitsValues />
109
+ </ExampleContainer>
110
+ <ExampleContainer>
111
+ <Title title="Discrete slider" theme="dark" level={4} />
112
+ <DxcSlider value={20} label="Slider" helperText="Help message" showLimitsValues marks step={5} />
113
+ </ExampleContainer>
114
+ <ExampleContainer>
115
+ <Title title="Discrete slider with input" theme="dark" level={4} />
116
+ <DxcSlider
117
+ value={20}
118
+ minValue={0}
119
+ maxValue={50}
120
+ label="Slider"
121
+ helperText="Help message"
122
+ showLimitsValues
123
+ showInput
124
+ marks
125
+ step={10}
126
+ />
127
+ </ExampleContainer>
128
+ </DarkContainer>
129
+ </BackgroundColorProvider>
130
+ <Title title="Margins" theme="light" level={2} />
131
+ <ExampleContainer>
132
+ <Title title="Xxsmall" theme="light" level={4} />
133
+ <DxcSlider label="Xxsmall" margin="xxsmall" />
134
+ </ExampleContainer>
135
+ <ExampleContainer>
136
+ <Title title="Xsmall" theme="light" level={4} />
137
+ <DxcSlider label="Xsmall" margin="xsmall" />
138
+ </ExampleContainer>
139
+ <ExampleContainer>
140
+ <Title title="Small" theme="light" level={4} />
141
+ <DxcSlider label="Small" margin="small" />
142
+ </ExampleContainer>
143
+ <ExampleContainer>
144
+ <Title title="Medium" theme="light" level={4} />
145
+ <DxcSlider label="Medium" margin="medium" />
146
+ </ExampleContainer>
147
+ <ExampleContainer>
148
+ <Title title="Large" theme="light" level={4} />
149
+ <DxcSlider label="Large" margin="large" />
150
+ </ExampleContainer>
151
+ <ExampleContainer>
152
+ <Title title="Xlarge" theme="light" level={4} />
153
+ <DxcSlider label="Xlarge" margin="xlarge" />
154
+ </ExampleContainer>
155
+ <ExampleContainer>
156
+ <Title title="Xxlarge" theme="light" level={4} />
157
+ <DxcSlider label="Xxlarge" margin="xxlarge" />
158
+ </ExampleContainer>
159
+ <Title title="Sizes" theme="light" level={2} />
160
+ <ExampleContainer>
161
+ <Title title="Medium" theme="light" level={4} />
162
+ <DxcSlider label="Medium" size="medium" />
163
+ </ExampleContainer>
164
+ <ExampleContainer>
165
+ <Title title="Large" theme="light" level={4} />
166
+ <DxcSlider label="Large" size="large" />
167
+ </ExampleContainer>
168
+ <ExampleContainer>
169
+ <Title title="FillParent" theme="light" level={4} />
170
+ <DxcSlider label="FillParent" size="fillParent" />
171
+ </ExampleContainer>
172
+ <ExampleContainer>
173
+ <Title title="Large limit values labels" theme="light" level={4} />
174
+ <DxcSlider label="Slider" helperText="Help message" showLimitsValues labelFormatCallback={labelFormat} size="large" />
175
+ </ExampleContainer>
176
+ </>
177
+ );
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;
@@ -65,7 +64,7 @@ declare type Props = {
65
64
  * This function will be used to format the labels displayed next to the slider.
66
65
  * The value will be passed as parameter and the function must return the formatted value.
67
66
  */
68
- labelFormatCallback?: (value: number) => void;
67
+ labelFormatCallback?: (value: number) => string;
69
68
  /**
70
69
  * Size of the margin to be applied to the component ('xxsmall' | 'xsmall' | 'small' | 'medium' | 'large' | 'xlarge' | 'xxlarge').
71
70
  * You can pass an object with 'top', 'bottom', 'left' and 'right' properties in order to specify different margin sizes.
@@ -74,10 +73,6 @@ declare type Props = {
74
73
  /**
75
74
  * Size of the component.
76
75
  */
77
- size?: Size;
78
- /**
79
- * Value of the tabindex attribute.
80
- */
81
- tabIndex?: number;
76
+ size?: "medium" | "large" | "fillParent";
82
77
  };
83
78
  export default Props;
@@ -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
 
@@ -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,3 @@
1
+ /// <reference types="react" />
2
+ import StackPropsType from "./types";
3
+ export default function Stack({ gutter, divider, align, as, children }: StackPropsType): JSX.Element;
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,9 @@
1
+ /// <reference types="react" />
2
+ declare type Props = {
3
+ gutter?: "none" | "xxxsmall" | "xxsmall" | "xsmall" | "small" | "medium" | "large" | "xlarge" | "xxlarge" | "xxxlarge";
4
+ divider?: boolean;
5
+ align?: "start" | "center" | "end" | "baseline" | "stretch";
6
+ as?: React.ElementType;
7
+ children: React.ReactNode;
8
+ };
9
+ 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} />
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
+ );
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" || "";