@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,67 @@
1
+ /// <reference types="react" />
2
+ declare type Space = "xxsmall" | "xsmall" | "small" | "medium" | "large" | "xlarge" | "xxlarge";
3
+ declare type Margin = {
4
+ top?: Space;
5
+ bottom?: Space;
6
+ left?: Space;
7
+ right?: Space;
8
+ };
9
+ declare type Column = {
10
+ /**
11
+ * Column display value.
12
+ */
13
+ displayValue: React.ReactNode;
14
+ /**
15
+ * Boolean value to indicate whether the column is sortable or not.
16
+ */
17
+ isSortable?: boolean;
18
+ };
19
+ declare type Row = {
20
+ /**
21
+ * Value to be displayed in the cell.
22
+ */
23
+ displayValue: React.ReactNode;
24
+ /**
25
+ * Value to be used when sorting the table by that
26
+ * column. If not indicated displayValue will be used for sorting.
27
+ */
28
+ sortValue?: string;
29
+ };
30
+ declare type Props = {
31
+ /**
32
+ * An array of objects representing the columns of the table.
33
+ */
34
+ columns: Column[];
35
+ /**
36
+ * An array of objects representing the rows of the table, you will have
37
+ * as many objects as columns in the table.
38
+ */
39
+ rows: Row[][];
40
+ /**
41
+ * If true, a select component for navigation between pages will be displayed.
42
+ */
43
+ showGoToPage?: boolean;
44
+ /**
45
+ * Number of items per page.
46
+ */
47
+ itemsPerPage?: number;
48
+ /**
49
+ * An array of numbers representing the items per page options.
50
+ */
51
+ itemsPerPageOptions?: number[];
52
+ /**
53
+ * This function will be called when the user selects an item per page
54
+ * option. The value selected will be passed as a parameter.
55
+ */
56
+ itemsPerPageFunction?: (newValue: number) => void;
57
+ /**
58
+ * Size of the margin to be applied to the component. You can pass an object with 'top',
59
+ * 'bottom', 'left' and 'right' properties in order to specify different margin sizes.
60
+ */
61
+ margin?: Space | Margin;
62
+ /**
63
+ * Value of the tabindex attribute given to the sortable icon.
64
+ */
65
+ tabIndex?: number;
66
+ };
67
+ export default Props;
@@ -0,0 +1,5 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
package/row/Row.d.ts ADDED
@@ -0,0 +1,3 @@
1
+ /// <reference types="react" />
2
+ import RowPropsType from "./types";
3
+ export default function Row({ gutter, align, justify, wrap, reverse, children, }: RowPropsType): JSX.Element;
package/row/Row.js ADDED
@@ -0,0 +1,127 @@
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"] = Row;
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;
17
+
18
+ function Row(_ref) {
19
+ var _ref$gutter = _ref.gutter,
20
+ gutter = _ref$gutter === void 0 ? "none" : _ref$gutter,
21
+ align = _ref.align,
22
+ justify = _ref.justify,
23
+ _ref$wrap = _ref.wrap,
24
+ wrap = _ref$wrap === void 0 ? true : _ref$wrap,
25
+ _ref$reverse = _ref.reverse,
26
+ reverse = _ref$reverse === void 0 ? false : _ref$reverse,
27
+ children = _ref.children;
28
+ return /*#__PURE__*/_react["default"].createElement(StyledRow, {
29
+ gutter: gutter,
30
+ align: align,
31
+ justify: justify,
32
+ wrap: wrap,
33
+ reverse: reverse
34
+ }, children);
35
+ }
36
+
37
+ var StyledRow = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n flex-direction: ", ";\n flex-wrap: ", ";\n align-items: ", ";\n justify-content: ", ";\n gap: ", ";\n"])), function (_ref2) {
38
+ var reverse = _ref2.reverse;
39
+ return reverse ? "row-reverse" : "row";
40
+ }, function (_ref3) {
41
+ var wrap = _ref3.wrap;
42
+ return wrap ? "wrap" : "nowrap";
43
+ }, function (_ref4) {
44
+ var align = _ref4.align;
45
+
46
+ switch (align) {
47
+ case "start":
48
+ return "flex-start";
49
+
50
+ case "center":
51
+ return "center";
52
+
53
+ case "end":
54
+ return "flex-end";
55
+
56
+ case "baseline":
57
+ return "baseline";
58
+
59
+ case "stretch":
60
+ return "stretch";
61
+
62
+ default:
63
+ return "initial";
64
+ }
65
+ }, function (_ref5) {
66
+ var justify = _ref5.justify;
67
+
68
+ switch (justify) {
69
+ case "spaceBetween":
70
+ return "space-between";
71
+
72
+ case "spaceAround":
73
+ return "space-around";
74
+
75
+ case "spaceEvenly":
76
+ return "space-evenly";
77
+
78
+ case "start":
79
+ return "flex-start";
80
+
81
+ case "center":
82
+ return "center";
83
+
84
+ case "end":
85
+ return "flex-end";
86
+
87
+ default:
88
+ return "initial";
89
+ }
90
+ }, function (_ref6) {
91
+ var gutter = _ref6.gutter;
92
+
93
+ switch (gutter) {
94
+ case "none":
95
+ return "0";
96
+
97
+ case "xxxsmall":
98
+ return "0.125rem";
99
+
100
+ case "xxsmall":
101
+ return "0.25rem";
102
+
103
+ case "xsmall":
104
+ return "0.5rem";
105
+
106
+ case "small":
107
+ return "1rem";
108
+
109
+ case "medium":
110
+ return "1.5rem";
111
+
112
+ case "large":
113
+ return "2rem";
114
+
115
+ case "xlarge":
116
+ return "3rem";
117
+
118
+ case "xxlarge":
119
+ return "4rem";
120
+
121
+ case "xxxlarge":
122
+ return "5rem";
123
+
124
+ default:
125
+ return "0";
126
+ }
127
+ });
@@ -0,0 +1,237 @@
1
+ import React from "react";
2
+ import Title from "../../.storybook/components/Title";
3
+ import styled from "styled-components";
4
+ import DxcRow from "./Row";
5
+
6
+ export default {
7
+ title: "Row",
8
+ component: DxcRow,
9
+ };
10
+
11
+ export const Chromatic = () => (
12
+ <>
13
+ <Title title="Default" theme="light" level={4} />
14
+ <Container>
15
+ <DxcRow>
16
+ <Placeholder></Placeholder>
17
+ <Placeholder></Placeholder>
18
+ <Placeholder></Placeholder>
19
+ </DxcRow>
20
+ </Container>
21
+ <Title title="Justify = center" theme="light" level={4} />
22
+ <Container>
23
+ <DxcRow justify="center">
24
+ <Placeholder></Placeholder>
25
+ <Placeholder></Placeholder>
26
+ <Placeholder></Placeholder>
27
+ </DxcRow>
28
+ </Container>
29
+ <Title title="Justify = end" theme="light" level={4} />
30
+ <Container>
31
+ <DxcRow justify="end">
32
+ <Placeholder></Placeholder>
33
+ <Placeholder></Placeholder>
34
+ <Placeholder></Placeholder>
35
+ </DxcRow>
36
+ </Container>
37
+ <Title title="Justify = spaceAround" theme="light" level={4} />
38
+ <Container>
39
+ <DxcRow justify="spaceAround">
40
+ <Placeholder></Placeholder>
41
+ <Placeholder></Placeholder>
42
+ <Placeholder></Placeholder>
43
+ </DxcRow>
44
+ </Container>
45
+ <Title title="Justify = spaceBetween" theme="light" level={4} />
46
+ <Container>
47
+ <DxcRow justify="spaceBetween">
48
+ <Placeholder></Placeholder>
49
+ <Placeholder></Placeholder>
50
+ <Placeholder></Placeholder>
51
+ </DxcRow>
52
+ </Container>
53
+ <Title title="Justify = spaceEvenly" theme="light" level={4} />
54
+ <Container>
55
+ <DxcRow justify="spaceEvenly">
56
+ <Placeholder></Placeholder>
57
+ <Placeholder></Placeholder>
58
+ <Placeholder></Placeholder>
59
+ </DxcRow>
60
+ </Container>
61
+ <Title title="Justify = start" theme="light" level={4} />
62
+ <Container>
63
+ <DxcRow justify="start">
64
+ <Placeholder></Placeholder>
65
+ <Placeholder></Placeholder>
66
+ <Placeholder></Placeholder>
67
+ </DxcRow>
68
+ </Container>
69
+ <Title title="Align = baseline" theme="light" level={4} />
70
+ <Container>
71
+ <DxcRow align="baseline">
72
+ <Placeholder paddingTop={20}>test</Placeholder>
73
+ <Placeholder>test</Placeholder>
74
+ <Placeholder paddingBottom={60}>test</Placeholder>
75
+ </DxcRow>
76
+ </Container>
77
+ <Title title="Align = center" theme="light" level={4} />
78
+ <Container>
79
+ <DxcRow align="center">
80
+ <Placeholder paddingTop={20}></Placeholder>
81
+ <Placeholder></Placeholder>
82
+ <Placeholder paddingTop={60}></Placeholder>
83
+ </DxcRow>
84
+ </Container>
85
+ <Title title="Align = end" theme="light" level={4} />
86
+ <Container>
87
+ <DxcRow align="end">
88
+ <Placeholder paddingTop={20}></Placeholder>
89
+ <Placeholder></Placeholder>
90
+ <Placeholder paddingTop={60}></Placeholder>
91
+ </DxcRow>
92
+ </Container>
93
+ <Title title="Align = start" theme="light" level={4} />
94
+ <Container>
95
+ <DxcRow align="start">
96
+ <Placeholder paddingTop={20}></Placeholder>
97
+ <Placeholder></Placeholder>
98
+ <Placeholder paddingTop={60}></Placeholder>
99
+ </DxcRow>
100
+ </Container>
101
+ <Title title="Align = stretch" theme="light" level={4} />
102
+ <Container>
103
+ <DxcRow align="stretch">
104
+ <Placeholder paddingTop={20}></Placeholder>
105
+ <Placeholder></Placeholder>
106
+ <Placeholder paddingTop={60}></Placeholder>
107
+ </DxcRow>
108
+ </Container>
109
+ <Title title="gutter = xxxsmall" theme="light" level={4} />
110
+ <Container>
111
+ <DxcRow gutter="xxxsmall">
112
+ <Placeholder></Placeholder>
113
+ <Placeholder></Placeholder>
114
+ <Placeholder></Placeholder>
115
+ </DxcRow>
116
+ </Container>
117
+ <Title title="gutter = xxsmall" theme="light" level={4} />
118
+ <Container>
119
+ <DxcRow gutter="xxsmall">
120
+ <Placeholder></Placeholder>
121
+ <Placeholder></Placeholder>
122
+ <Placeholder></Placeholder>
123
+ </DxcRow>
124
+ </Container>
125
+ <Title title="gutter = xsmall" theme="light" level={4} />
126
+ <Container>
127
+ <DxcRow gutter="xsmall">
128
+ <Placeholder></Placeholder>
129
+ <Placeholder></Placeholder>
130
+ <Placeholder></Placeholder>
131
+ </DxcRow>
132
+ </Container>
133
+ <Title title="gutter = small" theme="light" level={4} />
134
+ <Container>
135
+ <DxcRow gutter="small">
136
+ <Placeholder></Placeholder>
137
+ <Placeholder></Placeholder>
138
+ <Placeholder></Placeholder>
139
+ </DxcRow>
140
+ </Container>
141
+ <Title title="gutter = medium" theme="light" level={4} />
142
+ <Container>
143
+ <DxcRow gutter="medium">
144
+ <Placeholder></Placeholder>
145
+ <Placeholder></Placeholder>
146
+ <Placeholder></Placeholder>
147
+ </DxcRow>
148
+ </Container>
149
+ <Title title="gutter = large" theme="light" level={4} />
150
+ <Container>
151
+ <DxcRow gutter="large">
152
+ <Placeholder></Placeholder>
153
+ <Placeholder></Placeholder>
154
+ <Placeholder></Placeholder>
155
+ </DxcRow>
156
+ </Container>
157
+ <Title title="gutter = xlarge" theme="light" level={4} />
158
+ <Container>
159
+ <DxcRow gutter="xlarge">
160
+ <Placeholder></Placeholder>
161
+ <Placeholder></Placeholder>
162
+ <Placeholder></Placeholder>
163
+ </DxcRow>
164
+ </Container>
165
+ <Title title="gutter = xxlarge" theme="light" level={4} />
166
+ <Container>
167
+ <DxcRow gutter="xxlarge">
168
+ <Placeholder></Placeholder>
169
+ <Placeholder></Placeholder>
170
+ <Placeholder></Placeholder>
171
+ </DxcRow>
172
+ </Container>
173
+ <Title title="gutter = xxxlarge" theme="light" level={4} />
174
+ <Container>
175
+ <DxcRow gutter="xxxlarge">
176
+ <Placeholder></Placeholder>
177
+ <Placeholder></Placeholder>
178
+ <Placeholder></Placeholder>
179
+ </DxcRow>
180
+ </Container>
181
+ <Title title="gutter = none" theme="light" level={4} />
182
+ <Container>
183
+ <DxcRow gutter="none">
184
+ <Placeholder></Placeholder>
185
+ <Placeholder></Placeholder>
186
+ <Placeholder></Placeholder>
187
+ </DxcRow>
188
+ </Container>
189
+ <Title title="reverse = false" theme="light" level={4} />
190
+ <Container>
191
+ <DxcRow reverse={false}>
192
+ <Placeholder>1</Placeholder>
193
+ <Placeholder>2</Placeholder>
194
+ <Placeholder>3</Placeholder>
195
+ </DxcRow>
196
+ </Container>
197
+ <Title title="reverse = true" theme="light" level={4} />
198
+ <Container>
199
+ <DxcRow reverse={true}>
200
+ <Placeholder>1</Placeholder>
201
+ <Placeholder>2</Placeholder>
202
+ <Placeholder>3</Placeholder>
203
+ </DxcRow>
204
+ </Container>
205
+ <Title title="wrap = true" theme="light" level={4} />
206
+ <Container width={300}>
207
+ <DxcRow wrap={true}>
208
+ <Placeholder>1</Placeholder>
209
+ <Placeholder>2</Placeholder>
210
+ <Placeholder>3</Placeholder>
211
+ </DxcRow>
212
+ </Container>
213
+ <Title title="wrap = false" theme="light" level={4} />
214
+ <Container width={300}>
215
+ <DxcRow wrap={false}>
216
+ <Placeholder>1</Placeholder>
217
+ <Placeholder>2</Placeholder>
218
+ <Placeholder>3</Placeholder>
219
+ </DxcRow>
220
+ </Container>
221
+ </>
222
+ );
223
+
224
+ const Container = styled.div`
225
+ background: #f2eafa;
226
+ padding: 10px;
227
+ width: ${({ width }) => (width ? `${width}px` : "unset")};
228
+ `;
229
+
230
+ const Placeholder = styled.div`
231
+ min-height: 40px;
232
+ min-width: 120px;
233
+ border: 1px solid #a46ede;
234
+ background-color: #e5d5f6;
235
+ padding-top: ${({ paddingTop }) => `${paddingTop ?? 0}px`};
236
+ padding-bottom: ${({ paddingBottom }) => `${paddingBottom ?? 0}px`};
237
+ `;
package/row/types.d.ts ADDED
@@ -0,0 +1,10 @@
1
+ /// <reference types="react" />
2
+ declare type Props = {
3
+ gutter?: "none" | "xxxsmall" | "xxsmall" | "xsmall" | "small" | "medium" | "large" | "xlarge" | "xxlarge" | "xxxlarge";
4
+ align?: "start" | "center" | "end" | "baseline" | "stretch";
5
+ justify?: "start" | "center" | "end" | "spaceBetween" | "spaceAround" | "spaceEvenly";
6
+ wrap?: boolean;
7
+ reverse?: boolean;
8
+ children: React.ReactNode;
9
+ };
10
+ export default Props;
package/row/types.js ADDED
@@ -0,0 +1,5 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
@@ -0,0 +1,4 @@
1
+ import React from "react";
2
+ import SelectPropsType from "./types";
3
+ declare const DxcSelect: React.ForwardRefExoticComponent<SelectPropsType & React.RefAttributes<HTMLDivElement>>;
4
+ export default DxcSelect;
package/select/Select.js CHANGED
@@ -21,7 +21,7 @@ var _react = _interopRequireWildcard(require("react"));
21
21
 
22
22
  var _styledComponents = _interopRequireWildcard(require("styled-components"));
23
23
 
24
- var _useTheme = _interopRequireDefault(require("../useTheme.js"));
24
+ var _useTheme = _interopRequireDefault(require("../useTheme"));
25
25
 
26
26
  var _variables = require("../common/variables.js");
27
27
 
@@ -153,7 +153,7 @@ var getLastOptionIndex = function getLastOptionIndex(options, filteredOptions, s
153
153
 
154
154
  var getSelectedOption = function getSelectedOption(options, multiple, optional, optionalEmptyOption, value, innerValue) {
155
155
  var val = value !== null && value !== void 0 ? value : innerValue;
156
- var selectedOption = multiple ? [] : "";
156
+ var selectedOption = multiple ? [] : {};
157
157
  var singleSelectionIndex;
158
158
 
159
159
  if (multiple) {
@@ -201,14 +201,12 @@ var getSelectedOption = function getSelectedOption(options, multiple, optional,
201
201
  var DxcSelect = /*#__PURE__*/_react["default"].forwardRef(function (_ref, ref) {
202
202
  var _selectedOption$label;
203
203
 
204
- var _ref$label = _ref.label,
205
- label = _ref$label === void 0 ? "" : _ref$label,
204
+ var label = _ref.label,
206
205
  _ref$name = _ref.name,
207
206
  name = _ref$name === void 0 ? "" : _ref$name,
208
207
  value = _ref.value,
209
208
  options = _ref.options,
210
- _ref$helperText = _ref.helperText,
211
- helperText = _ref$helperText === void 0 ? "" : _ref$helperText,
209
+ helperText = _ref.helperText,
212
210
  _ref$placeholder = _ref.placeholder,
213
211
  placeholder = _ref$placeholder === void 0 ? "" : _ref$placeholder,
214
212
  _ref$disabled = _ref.disabled,
@@ -221,8 +219,7 @@ var DxcSelect = /*#__PURE__*/_react["default"].forwardRef(function (_ref, ref) {
221
219
  multiple = _ref$multiple === void 0 ? false : _ref$multiple,
222
220
  onChange = _ref.onChange,
223
221
  onBlur = _ref.onBlur,
224
- _ref$error = _ref.error,
225
- error = _ref$error === void 0 ? "" : _ref$error,
222
+ error = _ref.error,
226
223
  margin = _ref.margin,
227
224
  _ref$size = _ref.size,
228
225
  size = _ref$size === void 0 ? "medium" : _ref$size,
@@ -549,13 +546,14 @@ var DxcSelect = /*#__PURE__*/_react["default"].forwardRef(function (_ref, ref) {
549
546
  margin: margin,
550
547
  size: size,
551
548
  ref: ref
552
- }, /*#__PURE__*/_react["default"].createElement(Label, {
549
+ }, label && /*#__PURE__*/_react["default"].createElement(Label, {
553
550
  id: selectLabelId,
554
551
  disabled: disabled,
555
552
  onClick: function onClick() {
556
553
  selectContainerRef.current.focus();
557
- }
558
- }, label, " ", optional && /*#__PURE__*/_react["default"].createElement(OptionalLabel, null, "(Optional)")), /*#__PURE__*/_react["default"].createElement(HelperText, {
554
+ },
555
+ helperText: helperText
556
+ }, label, " ", optional && /*#__PURE__*/_react["default"].createElement(OptionalLabel, null, "(Optional)")), helperText && /*#__PURE__*/_react["default"].createElement(HelperText, {
559
557
  disabled: disabled
560
558
  }, helperText), /*#__PURE__*/_react["default"].createElement(Select, {
561
559
  id: selectId,
@@ -585,8 +583,8 @@ var DxcSelect = /*#__PURE__*/_react["default"].forwardRef(function (_ref, ref) {
585
583
  },
586
584
  onClick: handleClearOptionsActionOnClick,
587
585
  tabIndex: -1,
588
- title: "Clear selected options",
589
- "aria-label": "Clear selected options"
586
+ title: "Clear selection",
587
+ "aria-label": "Clear selection"
590
588
  }, selectIcons.clear)), /*#__PURE__*/_react["default"].createElement(SearchableValueContainer, null, /*#__PURE__*/_react["default"].createElement(ValueInput, {
591
589
  name: name,
592
590
  value: multiple ? (value !== null && value !== void 0 ? value : innerValue).join(", ") : value !== null && value !== void 0 ? value : innerValue,
@@ -615,8 +613,8 @@ var DxcSelect = /*#__PURE__*/_react["default"].forwardRef(function (_ref, ref) {
615
613
  },
616
614
  onClick: handleClearSearchActionOnClick,
617
615
  tabIndex: -1,
618
- title: "Clear search text",
619
- "aria-label": "Clear search text"
616
+ title: "Clear search",
617
+ "aria-label": "Clear search"
620
618
  }, selectIcons.clear), /*#__PURE__*/_react["default"].createElement(CollapseIndicator, {
621
619
  disabled: disabled
622
620
  }, isOpen ? selectIcons.arrowUp : selectIcons.arrowDown), isOpen && /*#__PURE__*/_react["default"].createElement(OptionsList, {
@@ -633,7 +631,7 @@ var DxcSelect = /*#__PURE__*/_react["default"].forwardRef(function (_ref, ref) {
633
631
  }, searchable && (filteredOptions.length === 0 || !filteredGroupsHaveOptions()) ? /*#__PURE__*/_react["default"].createElement(OptionsSystemMessage, null, /*#__PURE__*/_react["default"].createElement(NoMatchesFoundIcon, null, selectIcons.searchOff), "No matches found") : optional && !multiple && /*#__PURE__*/_react["default"].createElement(Option, {
634
632
  option: optionalEmptyOption,
635
633
  index: 0
636
- }), searchable ? filteredOptions.map(mapOptionFunc) : options.map(mapOptionFunc))), !disabled && /*#__PURE__*/_react["default"].createElement(Error, null, error)));
634
+ }), searchable ? filteredOptions.map(mapOptionFunc) : options.map(mapOptionFunc))), !disabled && typeof error === "string" && /*#__PURE__*/_react["default"].createElement(Error, null, error)));
637
635
  });
638
636
 
639
637
  var sizes = {
@@ -661,7 +659,7 @@ var SelectContainer = _styledComponents["default"].div(_templateObject || (_temp
661
659
  return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.left ? _variables.spaces[props.margin.left] : "";
662
660
  });
663
661
 
664
- var Label = _styledComponents["default"].span(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n color: ", ";\n font-family: ", ";\n font-size: ", ";\n font-style: ", ";\n font-weight: ", ";\n line-height: ", ";\n cursor: default;\n"])), function (props) {
662
+ var Label = _styledComponents["default"].span(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n color: ", ";\n font-family: ", ";\n font-size: ", ";\n font-style: ", ";\n font-weight: ", ";\n line-height: ", ";\n cursor: default;\n ", "\n"])), function (props) {
665
663
  return props.disabled ? props.theme.disabledColor : props.theme.labelFontColor;
666
664
  }, function (props) {
667
665
  return props.theme.fontFamily;
@@ -673,13 +671,15 @@ var Label = _styledComponents["default"].span(_templateObject2 || (_templateObje
673
671
  return props.theme.labelFontWeight;
674
672
  }, function (props) {
675
673
  return props.theme.labelLineHeight;
674
+ }, function (props) {
675
+ return !props.helperText && "margin-bottom: 0.25rem";
676
676
  });
677
677
 
678
678
  var OptionalLabel = _styledComponents["default"].span(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n font-weight: ", ";\n"])), function (props) {
679
679
  return props.theme.optionalLabelFontWeight;
680
680
  });
681
681
 
682
- var HelperText = _styledComponents["default"].span(_templateObject4 || (_templateObject4 = (0, _taggedTemplateLiteral2["default"])(["\n color: ", ";\n font-family: ", ";\n font-size: ", ";\n font-style: ", ";\n font-weight: ", ";\n line-height: ", ";\n"])), function (props) {
682
+ var HelperText = _styledComponents["default"].span(_templateObject4 || (_templateObject4 = (0, _taggedTemplateLiteral2["default"])(["\n color: ", ";\n font-family: ", ";\n font-size: ", ";\n font-style: ", ";\n font-weight: ", ";\n line-height: ", ";\n margin-bottom: 0.25rem;\n"])), function (props) {
683
683
  return props.disabled ? props.theme.disabledColor : props.theme.helperTextFontColor;
684
684
  }, function (props) {
685
685
  return props.theme.fontFamily;
@@ -693,9 +693,7 @@ var HelperText = _styledComponents["default"].span(_templateObject4 || (_templat
693
693
  return props.theme.helperTextLineHeight;
694
694
  });
695
695
 
696
- var Select = _styledComponents["default"].div(_templateObject5 || (_templateObject5 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n position: relative;\n align-items: center;\n height: calc(2.5rem - 2px);\n margin: ", ";\n padding: 0 0.5rem;\n outline: none;\n ", ";\n box-shadow: 0 0 0 2px transparent;\n border-radius: 4px;\n border: 1px solid\n ", ";\n ", "\n ", ";\n\n ", ";\n"])), function (props) {
697
- return "".concat(props.theme.inputMarginTop, " 0 ").concat(props.theme.inputMarginBottom, " 0");
698
- }, function (props) {
696
+ var Select = _styledComponents["default"].div(_templateObject5 || (_templateObject5 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n position: relative;\n align-items: center;\n height: calc(2.5rem - 2px);\n padding: 0 0.5rem;\n outline: none;\n ", ";\n box-shadow: 0 0 0 2px transparent;\n border-radius: 4px;\n border: 1px solid\n ", ";\n ", "\n ", ";\n\n ", ";\n"])), function (props) {
699
697
  return props.disabled && "background-color: ".concat(props.theme.disabledInputBackgroundColor);
700
698
  }, function (props) {
701
699
  return props.disabled ? props.theme.disabledInputBorderColor : props.theme.enabledInputBorderColor;
@@ -773,7 +771,7 @@ var ErrorIcon = _styledComponents["default"].span(_templateObject13 || (_templat
773
771
  return props.theme.errorIconColor;
774
772
  });
775
773
 
776
- var Error = _styledComponents["default"].span(_templateObject14 || (_templateObject14 = (0, _taggedTemplateLiteral2["default"])(["\n min-height: 1.5em;\n color: ", ";\n font-family: ", ";\n font-size: 0.75rem;\n font-weight: 400;\n"])), function (props) {
774
+ var Error = _styledComponents["default"].span(_templateObject14 || (_templateObject14 = (0, _taggedTemplateLiteral2["default"])(["\n min-height: 1.5em;\n color: ", ";\n font-family: ", ";\n font-size: 0.75rem;\n font-weight: 400;\n line-height: 1.5em;\n margin-top: 0.25rem;\n"])), function (props) {
777
775
  return props.theme.errorMessageColor;
778
776
  }, function (props) {
779
777
  return props.theme.fontFamily;