@dxc-technology/halstack-react 0.0.0-d20b360 → 0.0.0-d3554d7

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 (273) 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 +4 -0
  28. package/box/Box.js +6 -32
  29. package/box/{Box.stories.jsx → Box.stories.tsx} +0 -0
  30. package/box/Box.test.js +18 -0
  31. package/box/types.d.ts +43 -0
  32. package/box/types.js +5 -0
  33. package/button/Button.d.ts +1 -1
  34. package/button/Button.js +15 -26
  35. package/button/Button.stories.tsx +223 -242
  36. package/button/Button.test.js +35 -0
  37. package/button/types.d.ts +9 -13
  38. package/card/Card.js +5 -6
  39. package/card/Card.stories.tsx +201 -0
  40. package/card/Card.test.js +50 -0
  41. package/card/ice-cream.jpg +0 -0
  42. package/card/types.d.ts +4 -6
  43. package/checkbox/Checkbox.js +2 -2
  44. package/checkbox/Checkbox.test.js +65 -0
  45. package/checkbox/types.d.ts +2 -2
  46. package/chip/Chip.d.ts +4 -0
  47. package/chip/Chip.js +16 -76
  48. package/chip/Chip.stories.tsx +119 -0
  49. package/chip/Chip.test.js +56 -0
  50. package/chip/types.d.ts +45 -0
  51. package/chip/types.js +5 -0
  52. package/common/variables.js +85 -281
  53. package/date-input/DateInput.js +10 -13
  54. package/date-input/DateInput.stories.tsx +138 -0
  55. package/date-input/DateInput.test.js +469 -0
  56. package/dialog/Dialog.js +4 -3
  57. package/dialog/Dialog.stories.tsx +212 -0
  58. package/dialog/Dialog.test.js +40 -0
  59. package/dropdown/Dropdown.d.ts +1 -1
  60. package/dropdown/Dropdown.js +13 -35
  61. package/dropdown/Dropdown.stories.tsx +249 -0
  62. package/dropdown/Dropdown.test.js +189 -0
  63. package/dropdown/types.d.ts +6 -15
  64. package/file-input/FileInput.d.ts +4 -0
  65. package/file-input/FileInput.js +167 -109
  66. package/file-input/FileInput.stories.tsx +507 -0
  67. package/file-input/FileInput.test.js +457 -0
  68. package/file-input/FileItem.d.ts +14 -0
  69. package/file-input/FileItem.js +12 -21
  70. package/file-input/types.d.ts +112 -0
  71. package/file-input/types.js +5 -0
  72. package/footer/Footer.d.ts +1 -1
  73. package/footer/Footer.js +28 -36
  74. package/footer/{Footer.stories.jsx → Footer.stories.tsx} +1 -22
  75. package/footer/Footer.test.js +109 -0
  76. package/footer/Icons.d.ts +2 -0
  77. package/footer/Icons.js +3 -3
  78. package/footer/types.d.ts +22 -18
  79. package/header/Header.js +2 -2
  80. package/header/Header.stories.tsx +162 -0
  81. package/header/Header.test.js +63 -0
  82. package/header/Icons.d.ts +2 -0
  83. package/header/types.d.ts +4 -2
  84. package/heading/Heading.d.ts +4 -0
  85. package/heading/Heading.js +7 -24
  86. package/heading/Heading.stories.tsx +54 -0
  87. package/heading/Heading.test.js +186 -0
  88. package/heading/types.d.ts +33 -0
  89. package/heading/types.js +5 -0
  90. package/inset/Inset.d.ts +3 -0
  91. package/inset/Inset.js +84 -0
  92. package/inset/Inset.stories.tsx +229 -0
  93. package/inset/types.d.ts +13 -0
  94. package/inset/types.js +5 -0
  95. package/layout/ApplicationLayout.d.ts +10 -0
  96. package/layout/ApplicationLayout.js +17 -21
  97. package/layout/ApplicationLayout.stories.tsx +171 -0
  98. package/layout/types.d.ts +57 -0
  99. package/layout/types.js +5 -0
  100. package/link/Link.d.ts +3 -0
  101. package/link/Link.js +10 -40
  102. package/link/Link.stories.tsx +151 -0
  103. package/link/Link.test.js +91 -0
  104. package/link/types.d.ts +70 -0
  105. package/link/types.js +5 -0
  106. package/list/List.d.ts +4 -0
  107. package/list/List.js +47 -0
  108. package/list/List.stories.tsx +95 -0
  109. package/list/types.d.ts +7 -0
  110. package/list/types.js +5 -0
  111. package/main.d.ts +10 -8
  112. package/main.js +54 -38
  113. package/number-input/NumberInput.d.ts +4 -0
  114. package/number-input/NumberInput.js +5 -50
  115. package/number-input/{NumberInput.stories.jsx → NumberInput.stories.tsx} +0 -0
  116. package/number-input/NumberInput.test.js +508 -0
  117. package/number-input/NumberInputContext.d.ts +4 -0
  118. package/number-input/NumberInputContext.js +5 -2
  119. package/number-input/numberInputContextTypes.d.ts +19 -0
  120. package/number-input/numberInputContextTypes.js +5 -0
  121. package/number-input/types.d.ts +117 -0
  122. package/number-input/types.js +5 -0
  123. package/package.json +4 -2
  124. package/paginator/Paginator.js +2 -8
  125. package/paginator/Paginator.test.js +266 -0
  126. package/password-input/PasswordInput.d.ts +4 -0
  127. package/password-input/PasswordInput.js +19 -55
  128. package/password-input/{PasswordInput.stories.jsx → PasswordInput.stories.tsx} +4 -4
  129. package/password-input/PasswordInput.test.js +183 -0
  130. package/password-input/types.d.ts +107 -0
  131. package/password-input/types.js +5 -0
  132. package/progress-bar/ProgressBar.js +4 -4
  133. package/progress-bar/ProgressBar.stories.jsx +58 -0
  134. package/progress-bar/ProgressBar.test.js +65 -0
  135. package/radio/Radio.js +2 -2
  136. package/radio/Radio.test.js +71 -0
  137. package/radio/types.d.ts +2 -2
  138. package/radio-group/Radio.d.ts +4 -0
  139. package/radio-group/Radio.js +141 -0
  140. package/radio-group/RadioGroup.d.ts +4 -0
  141. package/radio-group/RadioGroup.js +279 -0
  142. package/radio-group/RadioGroup.stories.tsx +96 -0
  143. package/radio-group/RadioGroup.test.js +694 -0
  144. package/radio-group/types.d.ts +37 -0
  145. package/radio-group/types.js +5 -0
  146. package/resultsetTable/ResultsetTable.d.ts +4 -0
  147. package/resultsetTable/ResultsetTable.js +9 -29
  148. package/resultsetTable/ResultsetTable.stories.tsx +275 -0
  149. package/resultsetTable/ResultsetTable.test.js +306 -0
  150. package/resultsetTable/types.d.ts +67 -0
  151. package/resultsetTable/types.js +5 -0
  152. package/row/Row.d.ts +3 -0
  153. package/row/Row.js +127 -0
  154. package/row/Row.stories.tsx +237 -0
  155. package/row/types.d.ts +10 -0
  156. package/row/types.js +5 -0
  157. package/select/Select.d.ts +4 -0
  158. package/select/Select.js +26 -22
  159. package/select/Select.stories.tsx +582 -0
  160. package/select/Select.test.js +1900 -0
  161. package/select/types.d.ts +170 -0
  162. package/select/types.js +5 -0
  163. package/sidenav/Sidenav.d.ts +9 -0
  164. package/sidenav/Sidenav.js +6 -15
  165. package/sidenav/Sidenav.stories.tsx +182 -0
  166. package/sidenav/Sidenav.test.js +56 -0
  167. package/sidenav/types.d.ts +50 -0
  168. package/sidenav/types.js +5 -0
  169. package/slider/Slider.d.ts +1 -1
  170. package/slider/Slider.js +43 -32
  171. package/slider/Slider.stories.tsx +177 -0
  172. package/slider/Slider.test.js +129 -0
  173. package/slider/types.d.ts +2 -7
  174. package/spinner/Spinner.d.ts +4 -0
  175. package/spinner/Spinner.js +2 -19
  176. package/spinner/Spinner.stories.jsx +1 -0
  177. package/spinner/Spinner.test.js +64 -0
  178. package/spinner/types.d.ts +32 -0
  179. package/spinner/types.js +5 -0
  180. package/stack/Stack.d.ts +3 -0
  181. package/stack/Stack.js +97 -0
  182. package/stack/Stack.stories.tsx +164 -0
  183. package/stack/types.d.ts +9 -0
  184. package/stack/types.js +5 -0
  185. package/switch/Switch.js +4 -4
  186. package/switch/Switch.stories.tsx +160 -0
  187. package/switch/Switch.test.js +73 -0
  188. package/table/Table.d.ts +4 -0
  189. package/table/Table.js +3 -3
  190. package/table/Table.stories.jsx +2 -1
  191. package/table/Table.test.js +26 -0
  192. package/table/types.d.ts +21 -0
  193. package/table/types.js +5 -0
  194. package/tabs/Tabs.js +11 -9
  195. package/tabs/Tabs.stories.tsx +120 -0
  196. package/tabs/Tabs.test.js +123 -0
  197. package/tabs/types.d.ts +25 -18
  198. package/tag/Tag.d.ts +4 -0
  199. package/tag/Tag.js +26 -46
  200. package/tag/Tag.stories.tsx +138 -0
  201. package/tag/Tag.test.js +60 -0
  202. package/tag/types.d.ts +69 -0
  203. package/tag/types.js +5 -0
  204. package/text/Text.d.ts +7 -0
  205. package/text/Text.js +30 -0
  206. package/text/Text.stories.tsx +19 -0
  207. package/text-input/TextInput.d.ts +4 -0
  208. package/text-input/TextInput.js +59 -88
  209. package/text-input/TextInput.stories.tsx +474 -0
  210. package/text-input/TextInput.test.js +1691 -0
  211. package/text-input/types.d.ts +159 -0
  212. package/text-input/types.js +5 -0
  213. package/textarea/Textarea.d.ts +4 -0
  214. package/textarea/Textarea.js +32 -63
  215. package/textarea/Textarea.stories.jsx +34 -12
  216. package/textarea/Textarea.test.js +436 -0
  217. package/textarea/types.d.ts +130 -0
  218. package/textarea/types.js +5 -0
  219. package/toggle-group/ToggleGroup.d.ts +4 -0
  220. package/toggle-group/ToggleGroup.js +16 -45
  221. package/toggle-group/ToggleGroup.stories.tsx +173 -0
  222. package/toggle-group/ToggleGroup.test.js +125 -0
  223. package/toggle-group/types.d.ts +97 -0
  224. package/toggle-group/types.js +5 -0
  225. package/useTheme.d.ts +2 -0
  226. package/useTheme.js +1 -1
  227. package/wizard/Wizard.d.ts +4 -0
  228. package/wizard/Wizard.js +69 -59
  229. package/wizard/Wizard.stories.tsx +224 -0
  230. package/wizard/Wizard.test.js +128 -0
  231. package/wizard/types.d.ts +60 -0
  232. package/wizard/types.js +5 -0
  233. package/V3Select/V3Select.js +0 -455
  234. package/V3Select/index.d.ts +0 -27
  235. package/V3Textarea/V3Textarea.js +0 -260
  236. package/V3Textarea/index.d.ts +0 -27
  237. package/box/index.d.ts +0 -25
  238. package/chip/index.d.ts +0 -22
  239. package/date/Date.js +0 -373
  240. package/date/index.d.ts +0 -27
  241. package/file-input/index.d.ts +0 -81
  242. package/heading/index.d.ts +0 -17
  243. package/input-text/Icons.js +0 -22
  244. package/input-text/InputText.js +0 -611
  245. package/input-text/index.d.ts +0 -36
  246. package/link/index.d.ts +0 -23
  247. package/number-input/index.d.ts +0 -113
  248. package/password-input/index.d.ts +0 -94
  249. package/resultsetTable/index.d.ts +0 -19
  250. package/select/index.d.ts +0 -131
  251. package/sidenav/index.d.ts +0 -13
  252. package/spinner/index.d.ts +0 -17
  253. package/table/index.d.ts +0 -13
  254. package/tag/index.d.ts +0 -24
  255. package/text-input/index.d.ts +0 -135
  256. package/textarea/index.d.ts +0 -117
  257. package/toggle/Toggle.js +0 -186
  258. package/toggle/index.d.ts +0 -21
  259. package/toggle-group/index.d.ts +0 -21
  260. package/upload/Upload.js +0 -201
  261. package/upload/buttons-upload/ButtonsUpload.js +0 -111
  262. package/upload/buttons-upload/Icons.js +0 -40
  263. package/upload/dragAndDropArea/DragAndDropArea.js +0 -225
  264. package/upload/dragAndDropArea/Icons.js +0 -39
  265. package/upload/file-upload/FileToUpload.js +0 -115
  266. package/upload/file-upload/Icons.js +0 -66
  267. package/upload/files-upload/FilesToUpload.js +0 -109
  268. package/upload/index.d.ts +0 -15
  269. package/upload/transaction/Icons.js +0 -160
  270. package/upload/transaction/Transaction.js +0 -104
  271. package/upload/transactions/Transactions.js +0 -94
  272. package/wizard/Icons.js +0 -65
  273. package/wizard/index.d.ts +0 -18
@@ -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,
@@ -234,6 +231,7 @@ var DxcSelect = /*#__PURE__*/_react["default"].forwardRef(function (_ref, ref) {
234
231
  selectId = _useState2[0];
235
232
 
236
233
  var selectLabelId = "label-".concat(selectId);
234
+ var errorId = "error-".concat(selectId);
237
235
  var optionsListId = "".concat(selectId, "-listbox");
238
236
 
239
237
  var _useState3 = (0, _react.useState)(multiple ? [] : ""),
@@ -549,13 +547,14 @@ var DxcSelect = /*#__PURE__*/_react["default"].forwardRef(function (_ref, ref) {
549
547
  margin: margin,
550
548
  size: size,
551
549
  ref: ref
552
- }, /*#__PURE__*/_react["default"].createElement(Label, {
550
+ }, label && /*#__PURE__*/_react["default"].createElement(Label, {
553
551
  id: selectLabelId,
554
552
  disabled: disabled,
555
553
  onClick: function onClick() {
556
554
  selectContainerRef.current.focus();
557
- }
558
- }, label, " ", optional && /*#__PURE__*/_react["default"].createElement(OptionalLabel, null, "(Optional)")), /*#__PURE__*/_react["default"].createElement(HelperText, {
555
+ },
556
+ helperText: helperText
557
+ }, label, " ", optional && /*#__PURE__*/_react["default"].createElement(OptionalLabel, null, "(Optional)")), helperText && /*#__PURE__*/_react["default"].createElement(HelperText, {
559
558
  disabled: disabled
560
559
  }, helperText), /*#__PURE__*/_react["default"].createElement(Select, {
561
560
  id: selectId,
@@ -569,11 +568,13 @@ var DxcSelect = /*#__PURE__*/_react["default"].forwardRef(function (_ref, ref) {
569
568
  tabIndex: tabIndex,
570
569
  role: "combobox",
571
570
  "aria-controls": optionsListId,
571
+ "aria-disabled": disabled,
572
572
  "aria-expanded": isOpen,
573
573
  "aria-haspopup": "listbox",
574
574
  "aria-labelledby": selectLabelId,
575
575
  "aria-activedescendant": visualFocusIndex >= 0 ? "option-".concat(visualFocusIndex) : undefined,
576
576
  "aria-invalid": error ? "true" : "false",
577
+ "aria-errormessage": error ? errorId : undefined,
577
578
  "aria-required": !optional
578
579
  }, multiple && selectedOption.length > 0 && /*#__PURE__*/_react["default"].createElement(SelectionIndicator, null, /*#__PURE__*/_react["default"].createElement(SelectionNumber, {
579
580
  disabled: disabled
@@ -585,8 +586,8 @@ var DxcSelect = /*#__PURE__*/_react["default"].forwardRef(function (_ref, ref) {
585
586
  },
586
587
  onClick: handleClearOptionsActionOnClick,
587
588
  tabIndex: -1,
588
- title: "Clear selected options",
589
- "aria-label": "Clear selected options"
589
+ title: "Clear selection",
590
+ "aria-label": "Clear selection"
590
591
  }, selectIcons.clear)), /*#__PURE__*/_react["default"].createElement(SearchableValueContainer, null, /*#__PURE__*/_react["default"].createElement(ValueInput, {
591
592
  name: name,
592
593
  value: multiple ? (value !== null && value !== void 0 ? value : innerValue).join(", ") : value !== null && value !== void 0 ? value : innerValue,
@@ -615,8 +616,8 @@ var DxcSelect = /*#__PURE__*/_react["default"].forwardRef(function (_ref, ref) {
615
616
  },
616
617
  onClick: handleClearSearchActionOnClick,
617
618
  tabIndex: -1,
618
- title: "Clear search text",
619
- "aria-label": "Clear search text"
619
+ title: "Clear search",
620
+ "aria-label": "Clear search"
620
621
  }, selectIcons.clear), /*#__PURE__*/_react["default"].createElement(CollapseIndicator, {
621
622
  disabled: disabled
622
623
  }, isOpen ? selectIcons.arrowUp : selectIcons.arrowDown), isOpen && /*#__PURE__*/_react["default"].createElement(OptionsList, {
@@ -633,7 +634,10 @@ var DxcSelect = /*#__PURE__*/_react["default"].forwardRef(function (_ref, ref) {
633
634
  }, 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
635
  option: optionalEmptyOption,
635
636
  index: 0
636
- }), searchable ? filteredOptions.map(mapOptionFunc) : options.map(mapOptionFunc))), !disabled && /*#__PURE__*/_react["default"].createElement(Error, null, error)));
637
+ }), searchable ? filteredOptions.map(mapOptionFunc) : options.map(mapOptionFunc))), !disabled && typeof error === "string" && /*#__PURE__*/_react["default"].createElement(Error, {
638
+ id: errorId,
639
+ "aria-live": error ? "assertive" : "off"
640
+ }, error)));
637
641
  });
638
642
 
639
643
  var sizes = {
@@ -661,7 +665,7 @@ var SelectContainer = _styledComponents["default"].div(_templateObject || (_temp
661
665
  return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.left ? _variables.spaces[props.margin.left] : "";
662
666
  });
663
667
 
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) {
668
+ 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
669
  return props.disabled ? props.theme.disabledColor : props.theme.labelFontColor;
666
670
  }, function (props) {
667
671
  return props.theme.fontFamily;
@@ -673,13 +677,15 @@ var Label = _styledComponents["default"].span(_templateObject2 || (_templateObje
673
677
  return props.theme.labelFontWeight;
674
678
  }, function (props) {
675
679
  return props.theme.labelLineHeight;
680
+ }, function (props) {
681
+ return !props.helperText && "margin-bottom: 0.25rem";
676
682
  });
677
683
 
678
684
  var OptionalLabel = _styledComponents["default"].span(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n font-weight: ", ";\n"])), function (props) {
679
685
  return props.theme.optionalLabelFontWeight;
680
686
  });
681
687
 
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) {
688
+ 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
689
  return props.disabled ? props.theme.disabledColor : props.theme.helperTextFontColor;
684
690
  }, function (props) {
685
691
  return props.theme.fontFamily;
@@ -693,9 +699,7 @@ var HelperText = _styledComponents["default"].span(_templateObject4 || (_templat
693
699
  return props.theme.helperTextLineHeight;
694
700
  });
695
701
 
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) {
702
+ 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
703
  return props.disabled && "background-color: ".concat(props.theme.disabledInputBackgroundColor);
700
704
  }, function (props) {
701
705
  return props.disabled ? props.theme.disabledInputBorderColor : props.theme.enabledInputBorderColor;
@@ -773,7 +777,7 @@ var ErrorIcon = _styledComponents["default"].span(_templateObject13 || (_templat
773
777
  return props.theme.errorIconColor;
774
778
  });
775
779
 
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) {
780
+ 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
781
  return props.theme.errorMessageColor;
778
782
  }, function (props) {
779
783
  return props.theme.fontFamily;