@dxc-technology/halstack-react 0.0.0-c7d5596 → 0.0.0-c7ec4d1

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 (199) hide show
  1. package/README.md +1 -1
  2. package/babel.config.js +6 -2
  3. package/dist/BackgroundColorContext.js +46 -0
  4. package/dist/ThemeContext.js +237 -2
  5. package/dist/V3Select/V3Select.js +549 -0
  6. package/dist/V3Textarea/V3Textarea.js +264 -0
  7. package/dist/accordion/Accordion.js +152 -67
  8. package/dist/accordion-group/AccordionGroup.js +186 -0
  9. package/dist/alert/Alert.js +183 -84
  10. package/dist/alert/index.d.ts +51 -0
  11. package/dist/badge/Badge.js +63 -0
  12. package/dist/box/Box.js +31 -23
  13. package/dist/button/Button.js +63 -27
  14. package/dist/card/Card.js +72 -35
  15. package/dist/checkbox/Checkbox.js +99 -40
  16. package/dist/chip/Chip.js +97 -40
  17. package/dist/common/RequiredComponent.js +2 -8
  18. package/dist/common/utils.js +2 -22
  19. package/dist/common/variables.js +1452 -304
  20. package/dist/date/Date.js +80 -57
  21. package/dist/date-input/DateInput.js +400 -0
  22. package/dist/date-input/index.d.ts +95 -0
  23. package/dist/dialog/Dialog.js +58 -37
  24. package/dist/dropdown/Dropdown.js +177 -82
  25. package/dist/file-input/FileInput.js +644 -0
  26. package/dist/file-input/FileItem.js +287 -0
  27. package/dist/file-input/index.d.ts +81 -0
  28. package/dist/footer/Footer.js +90 -40
  29. package/dist/footer/Icons.js +77 -0
  30. package/dist/header/Header.js +192 -95
  31. package/dist/header/Icons.js +59 -0
  32. package/dist/heading/Heading.js +93 -16
  33. package/dist/input-text/Icons.js +22 -0
  34. package/dist/input-text/InputText.js +251 -116
  35. package/dist/layout/ApplicationLayout.js +18 -26
  36. package/dist/layout/Icons.js +55 -0
  37. package/dist/link/Link.js +89 -41
  38. package/dist/main.d.ts +8 -0
  39. package/dist/main.js +98 -18
  40. package/dist/number-input/NumberInput.js +136 -0
  41. package/dist/number-input/NumberInputContext.js +16 -0
  42. package/dist/number-input/index.d.ts +113 -0
  43. package/dist/paginator/Icons.js +66 -0
  44. package/dist/paginator/Paginator.js +122 -66
  45. package/dist/password-input/PasswordInput.js +203 -0
  46. package/dist/password-input/index.d.ts +94 -0
  47. package/dist/progress-bar/ProgressBar.js +95 -38
  48. package/dist/radio/Radio.js +31 -17
  49. package/dist/resultsetTable/ResultsetTable.js +82 -65
  50. package/dist/select/Select.js +896 -284
  51. package/dist/select/index.d.ts +53 -0
  52. package/dist/sidenav/Sidenav.js +66 -15
  53. package/dist/slider/Slider.js +211 -73
  54. package/dist/spinner/Spinner.js +247 -59
  55. package/dist/switch/Switch.js +50 -27
  56. package/dist/table/Table.js +51 -24
  57. package/dist/tabs/Tabs.js +193 -35
  58. package/dist/tag/Tag.js +68 -35
  59. package/dist/text-input/TextInput.js +974 -0
  60. package/dist/text-input/index.d.ts +135 -0
  61. package/dist/textarea/Textarea.js +248 -106
  62. package/dist/textarea/index.d.ts +117 -0
  63. package/dist/toggle/Toggle.js +16 -19
  64. package/dist/toggle-group/ToggleGroup.js +142 -41
  65. package/dist/upload/Upload.js +16 -11
  66. package/dist/upload/buttons-upload/ButtonsUpload.js +32 -19
  67. package/dist/upload/buttons-upload/Icons.js +40 -0
  68. package/dist/upload/dragAndDropArea/DragAndDropArea.js +84 -34
  69. package/dist/upload/dragAndDropArea/Icons.js +39 -0
  70. package/dist/upload/file-upload/FileToUpload.js +64 -33
  71. package/dist/upload/file-upload/Icons.js +66 -0
  72. package/dist/upload/files-upload/FilesToUpload.js +16 -16
  73. package/dist/upload/transaction/Icons.js +160 -0
  74. package/dist/upload/transaction/Transaction.js +42 -49
  75. package/dist/upload/transactions/Transactions.js +38 -20
  76. package/dist/useTheme.js +22 -0
  77. package/dist/wizard/Icons.js +65 -0
  78. package/dist/wizard/Wizard.js +125 -60
  79. package/package.json +14 -11
  80. package/test/AccordionGroup.test.js +125 -0
  81. package/test/Date.test.js +49 -45
  82. package/test/DateInput.test.js +242 -0
  83. package/test/Dropdown.test.js +15 -0
  84. package/test/FileInput.test.js +201 -0
  85. package/test/Footer.test.js +2 -7
  86. package/test/Header.test.js +5 -10
  87. package/test/Heading.test.js +60 -12
  88. package/test/InputText.test.js +53 -41
  89. package/test/Link.test.js +12 -2
  90. package/test/NumberInput.test.js +259 -0
  91. package/test/Paginator.test.js +50 -77
  92. package/test/PasswordInput.test.js +83 -0
  93. package/test/ResultsetTable.test.js +61 -25
  94. package/test/Slider.test.js +9 -17
  95. package/test/Spinner.test.js +5 -0
  96. package/test/Tabs.test.js +21 -0
  97. package/test/TextInput.test.js +732 -0
  98. package/test/Textarea.test.js +193 -0
  99. package/test/ToggleGroup.test.js +5 -1
  100. package/test/Upload.test.js +5 -5
  101. package/test/{Select.test.js → V3Select.test.js} +67 -46
  102. package/test/{TextArea.test.js → V3TextArea.test.js} +6 -7
  103. package/dist/accordion/Accordion.stories.js +0 -207
  104. package/dist/accordion/readme.md +0 -96
  105. package/dist/alert/Alert.stories.js +0 -158
  106. package/dist/alert/close.svg +0 -4
  107. package/dist/alert/error.svg +0 -4
  108. package/dist/alert/info.svg +0 -4
  109. package/dist/alert/readme.md +0 -43
  110. package/dist/alert/success.svg +0 -4
  111. package/dist/alert/warning.svg +0 -4
  112. package/dist/button/Button.stories.js +0 -224
  113. package/dist/button/readme.md +0 -93
  114. package/dist/checkbox/Checkbox.stories.js +0 -144
  115. package/dist/checkbox/readme.md +0 -116
  116. package/dist/common/services/example-service.js +0 -10
  117. package/dist/common/services/example-service.test.js +0 -12
  118. package/dist/date/Date.stories.js +0 -205
  119. package/dist/date/calendar.svg +0 -1
  120. package/dist/date/calendar_dark.svg +0 -1
  121. package/dist/date/readme.md +0 -73
  122. package/dist/dialog/Dialog.stories.js +0 -217
  123. package/dist/dialog/readme.md +0 -32
  124. package/dist/dropdown/Dropdown.stories.js +0 -249
  125. package/dist/dropdown/baseline-arrow_drop_down.svg +0 -1
  126. package/dist/dropdown/baseline-arrow_drop_down_wh.svg +0 -4
  127. package/dist/dropdown/baseline-arrow_drop_up.svg +0 -1
  128. package/dist/dropdown/baseline-arrow_drop_up_wh.svg +0 -4
  129. package/dist/dropdown/readme.md +0 -69
  130. package/dist/footer/Footer.stories.js +0 -94
  131. package/dist/footer/dxc_logo_wht.png +0 -0
  132. package/dist/footer/readme.md +0 -41
  133. package/dist/header/Header.stories.js +0 -176
  134. package/dist/header/close_icon.svg +0 -1
  135. package/dist/header/dxc_logo_black.png +0 -0
  136. package/dist/header/dxc_logo_blk_rgb.svg +0 -6
  137. package/dist/header/dxc_logo_white.png +0 -0
  138. package/dist/header/hamb_menu_black.svg +0 -1
  139. package/dist/header/hamb_menu_white.svg +0 -1
  140. package/dist/header/readme.md +0 -33
  141. package/dist/input-text/InputText.stories.js +0 -209
  142. package/dist/input-text/error.svg +0 -1
  143. package/dist/input-text/readme.md +0 -91
  144. package/dist/layout/facebook.svg +0 -45
  145. package/dist/layout/linkedin.svg +0 -50
  146. package/dist/layout/twitter.svg +0 -53
  147. package/dist/link/readme.md +0 -51
  148. package/dist/paginator/images/next.svg +0 -3
  149. package/dist/paginator/images/nextPage.svg +0 -3
  150. package/dist/paginator/images/previous.svg +0 -3
  151. package/dist/paginator/images/previousPage.svg +0 -3
  152. package/dist/paginator/readme.md +0 -50
  153. package/dist/progress-bar/ProgressBar.stories.js +0 -280
  154. package/dist/progress-bar/readme.md +0 -63
  155. package/dist/radio/Radio.stories.js +0 -166
  156. package/dist/radio/readme.md +0 -70
  157. package/dist/resultsetTable/arrow_downward-24px_wht.svg +0 -1
  158. package/dist/resultsetTable/arrow_upward-24px_wht.svg +0 -1
  159. package/dist/resultsetTable/unfold_more-24px_wht.svg +0 -1
  160. package/dist/select/Select.stories.js +0 -235
  161. package/dist/select/readme.md +0 -72
  162. package/dist/slider/Slider.stories.js +0 -241
  163. package/dist/slider/readme.md +0 -64
  164. package/dist/spinner/Spinner.stories.js +0 -183
  165. package/dist/spinner/readme.md +0 -65
  166. package/dist/switch/Switch.stories.js +0 -134
  167. package/dist/switch/readme.md +0 -133
  168. package/dist/tabs/Tabs.stories.js +0 -130
  169. package/dist/tabs/readme.md +0 -78
  170. package/dist/tabs-for-sections/TabsForSections.js +0 -92
  171. package/dist/tabs-for-sections/readme.md +0 -78
  172. package/dist/toggle/Toggle.stories.js +0 -297
  173. package/dist/toggle/readme.md +0 -80
  174. package/dist/toggle-group/readme.md +0 -82
  175. package/dist/upload/Upload.stories.js +0 -72
  176. package/dist/upload/buttons-upload/drag-drop-icon.svg +0 -4
  177. package/dist/upload/buttons-upload/upload-button.svg +0 -1
  178. package/dist/upload/dragAndDropArea/upload_drop.svg +0 -4
  179. package/dist/upload/dragAndDropArea/upload_file.svg +0 -4
  180. package/dist/upload/file-upload/audio-icon.svg +0 -4
  181. package/dist/upload/file-upload/close.svg +0 -4
  182. package/dist/upload/file-upload/file-icon.svg +0 -4
  183. package/dist/upload/file-upload/video-icon.svg +0 -4
  184. package/dist/upload/readme.md +0 -37
  185. package/dist/upload/transaction/audio-icon-err.svg +0 -4
  186. package/dist/upload/transaction/audio-icon.svg +0 -4
  187. package/dist/upload/transaction/error-icon.svg +0 -4
  188. package/dist/upload/transaction/file-icon-err.svg +0 -4
  189. package/dist/upload/transaction/file-icon.svg +0 -4
  190. package/dist/upload/transaction/image-icon-err.svg +0 -4
  191. package/dist/upload/transaction/image-icon.svg +0 -4
  192. package/dist/upload/transaction/success-icon.svg +0 -4
  193. package/dist/upload/transaction/video-icon-err.svg +0 -4
  194. package/dist/upload/transaction/video-icon.svg +0 -4
  195. package/dist/wizard/invalid_icon.svg +0 -6
  196. package/dist/wizard/valid_icon.svg +0 -6
  197. package/dist/wizard/validation-wrong.svg +0 -6
  198. package/test/TabsForSections.test.js +0 -34
  199. package/test/Toggle.test.js +0 -43
@@ -9,46 +9,222 @@ Object.defineProperty(exports, "__esModule", {
9
9
  });
10
10
  exports["default"] = void 0;
11
11
 
12
- var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray"));
12
+ var _typeof2 = _interopRequireDefault(require("@babel/runtime/helpers/typeof"));
13
13
 
14
14
  var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
15
15
 
16
- var _typeof2 = _interopRequireDefault(require("@babel/runtime/helpers/typeof"));
17
-
18
- var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
16
+ var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray"));
19
17
 
20
18
  var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
21
19
 
22
20
  var _react = _interopRequireWildcard(require("react"));
23
21
 
24
- var _Select = _interopRequireDefault(require("@material-ui/core/Select"));
25
-
26
- var _InputLabel = _interopRequireDefault(require("@material-ui/core/InputLabel"));
22
+ var _styledComponents = _interopRequireWildcard(require("styled-components"));
27
23
 
28
- var _FormControl = _interopRequireDefault(require("@material-ui/core/FormControl"));
24
+ var _useTheme = _interopRequireDefault(require("../useTheme.js"));
29
25
 
30
- var _styledComponents = _interopRequireWildcard(require("styled-components"));
26
+ var _variables = require("../common/variables.js");
31
27
 
32
- var _MenuItem = _interopRequireDefault(require("@material-ui/core/MenuItem"));
28
+ var _BackgroundColorContext = _interopRequireDefault(require("../BackgroundColorContext.js"));
33
29
 
34
- var _styles = require("@material-ui/core/styles");
30
+ var _uuid = require("uuid");
35
31
 
36
- var _propTypes = _interopRequireDefault(require("prop-types"));
32
+ var _utils = require("../common/utils.js");
37
33
 
38
34
  var _Checkbox = _interopRequireDefault(require("../checkbox/Checkbox"));
39
35
 
40
- require("../common/OpenSans.css");
36
+ function _templateObject27() {
37
+ var data = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n height: 16px;\n width: 16px;\n margin-left: 4px;\n color: #4d4d4d;\n"]);
41
38
 
42
- var _variables = require("../common/variables.js");
39
+ _templateObject27 = function _templateObject27() {
40
+ return data;
41
+ };
43
42
 
44
- var _utils = require("../common/utils.js");
43
+ return data;
44
+ }
45
+
46
+ function _templateObject26() {
47
+ var data = (0, _taggedTemplateLiteral2["default"])(["\n overflow: hidden;\n text-overflow: ellipsis;\n white-space: nowrap;\n"]);
48
+
49
+ _templateObject26 = function _templateObject26() {
50
+ return data;
51
+ };
52
+
53
+ return data;
54
+ }
55
+
56
+ function _templateObject25() {
57
+ var data = (0, _taggedTemplateLiteral2["default"])(["\n width: 16px;\n height: 16px;\n"]);
58
+
59
+ _templateObject25 = function _templateObject25() {
60
+ return data;
61
+ };
62
+
63
+ return data;
64
+ }
65
+
66
+ function _templateObject24() {
67
+ var data = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n flex-wrap: wrap;\n align-content: center;\n height: 24px;\n width: 24px;\n margin-left: 8px;\n"]);
68
+
69
+ _templateObject24 = function _templateObject24() {
70
+ return data;
71
+ };
72
+
73
+ return data;
74
+ }
75
+
76
+ function _templateObject23() {
77
+ var data = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n justify-content: space-between;\n width: 100%;\n overflow: hidden;\n padding-left: 8px;\n ", "\n"]);
78
+
79
+ _templateObject23 = function _templateObject23() {
80
+ return data;
81
+ };
82
+
83
+ return data;
84
+ }
85
+
86
+ function _templateObject22() {
87
+ var data = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n padding: 4px 8px 3px 0;\n min-height: 24px;\n ", "\n ", ";\n"]);
88
+
89
+ _templateObject22 = function _templateObject22() {
90
+ return data;
91
+ };
92
+
93
+ return data;
94
+ }
95
+
96
+ function _templateObject21() {
97
+ var data = (0, _taggedTemplateLiteral2["default"])(["\n padding: 0 8px;\n line-height: 1.715em;\n cursor: pointer;\n\n ", ";\n"]);
98
+
99
+ _templateObject21 = function _templateObject21() {
100
+ return data;
101
+ };
102
+
103
+ return data;
104
+ }
105
+
106
+ function _templateObject20() {
107
+ var data = (0, _taggedTemplateLiteral2["default"])(["\n padding: 4px 16px;\n line-height: 1.715em;\n font-weight: 600;\n"]);
108
+
109
+ _templateObject20 = function _templateObject20() {
110
+ return data;
111
+ };
112
+
113
+ return data;
114
+ }
115
+
116
+ function _templateObject19() {
117
+ var data = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n flex-wrap: wrap;\n align-content: center;\n height: 16px;\n width: 16px;\n padding: 4px;\n margin-right: calc(1rem * 0.25);\n"]);
118
+
119
+ _templateObject19 = function _templateObject19() {
120
+ return data;
121
+ };
122
+
123
+ return data;
124
+ }
125
+
126
+ function _templateObject18() {
127
+ var data = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n padding: 4px 16px;\n color: ", ";\n font-size: 0.875rem;\n line-height: 1.715em;\n"]);
128
+
129
+ _templateObject18 = function _templateObject18() {
130
+ return data;
131
+ };
45
132
 
46
- var _ThemeContext = _interopRequireDefault(require("../ThemeContext.js"));
133
+ return data;
134
+ }
135
+
136
+ function _templateObject17() {
137
+ var data = (0, _taggedTemplateLiteral2["default"])(["\n position: absolute;\n z-index: 1;\n max-height: 304px;\n overflow-x: auto;\n top: calc(100% + 4px);\n left: 0;\n margin: 0;\n padding: 4px 0;\n width: 100%;\n box-sizing: border-box;\n background-color: #ffffff;\n border-radius: 4px;\n border: 1px solid ", ";\n box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1);\n cursor: default;\n font-family: ", ";\n color: ", ";\n font-size: ", ";\n font-style: ", ";\n font-weight: ", ";\n"]);
138
+
139
+ _templateObject17 = function _templateObject17() {
140
+ return data;
141
+ };
142
+
143
+ return data;
144
+ }
145
+
146
+ function _templateObject16() {
147
+ var data = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n flex-wrap: wrap;\n align-content: center;\n height: 24px;\n width: 24px;\n font-size: 1rem;\n font-family: ", ";\n border: 1px solid transparent;\n border-radius: 2px;\n padding: 3px;\n margin-left: calc(1rem * 0.25);\n ", "\n\n background-color: ", ";\n color: ", ";\n\n ", "\n\n svg {\n line-height: 18px;\n }\n"]);
148
+
149
+ _templateObject16 = function _templateObject16() {
150
+ return data;
151
+ };
152
+
153
+ return data;
154
+ }
155
+
156
+ function _templateObject15() {
157
+ var data = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n flex-wrap: wrap;\n align-content: center;\n height: 16px;\n width: 16px;\n padding: 4px;\n margin-left: calc(1rem * 0.25);\n\n color: ", ";\n"]);
158
+
159
+ _templateObject15 = function _templateObject15() {
160
+ return data;
161
+ };
162
+
163
+ return data;
164
+ }
165
+
166
+ function _templateObject14() {
167
+ var data = (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"]);
168
+
169
+ _templateObject14 = function _templateObject14() {
170
+ return data;
171
+ };
172
+
173
+ return data;
174
+ }
175
+
176
+ function _templateObject13() {
177
+ var data = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n flex-wrap: wrap;\n align-content: center;\n padding: 3px;\n height: 18px;\n width: 18px;\n margin-left: calc(1rem * 0.25);\n pointer-events: none;\n color: ", ";\n\n svg {\n line-height: 18px;\n font-size: 1.25rem;\n }\n"]);
178
+
179
+ _templateObject13 = function _templateObject13() {
180
+ return data;
181
+ };
182
+
183
+ return data;
184
+ }
185
+
186
+ function _templateObject12() {
187
+ var data = (0, _taggedTemplateLiteral2["default"])(["\n grid-area: 1 / 1 / 1 / 1;\n height: calc(calc(1rem * 2.5) - calc(1px * 2));\n background: none;\n border: none;\n outline: none;\n padding: 0 calc(1rem * 0.5);\n\n color: ", ";\n\n font-family: ", ";\n font-size: ", ";\n font-style: ", ";\n font-weight: ", ";\n line-height: 1.5em;\n\n ::placeholder {\n color: ", ";\n }\n"]);
47
188
 
48
- var _RequiredComponent = _interopRequireDefault(require("../common/RequiredComponent"));
189
+ _templateObject12 = function _templateObject12() {
190
+ return data;
191
+ };
192
+
193
+ return data;
194
+ }
195
+
196
+ function _templateObject11() {
197
+ var data = (0, _taggedTemplateLiteral2["default"])(["\n display: none;\n"]);
198
+
199
+ _templateObject11 = function _templateObject11() {
200
+ return data;
201
+ };
202
+
203
+ return data;
204
+ }
205
+
206
+ function _templateObject10() {
207
+ var data = (0, _taggedTemplateLiteral2["default"])(["\n grid-area: 1 / 1 / 1 / 1;\n display: inline-flex;\n align-items: center;\n height: calc(calc(1rem * 2.5) - calc(1px * 2));\n padding: 0 calc(1rem * 0.5);\n user-select: none;\n overflow: hidden;\n\n color: ", ";\n\n font-family: ", ";\n font-size: ", ";\n font-style: ", ";\n font-weight: ", ";\n line-height: 1.5em;\n"]);
208
+
209
+ _templateObject10 = function _templateObject10() {
210
+ return data;
211
+ };
212
+
213
+ return data;
214
+ }
215
+
216
+ function _templateObject9() {
217
+ var data = (0, _taggedTemplateLiteral2["default"])(["\n display: grid;\n width: 100%;\n"]);
218
+
219
+ _templateObject9 = function _templateObject9() {
220
+ return data;
221
+ };
222
+
223
+ return data;
224
+ }
49
225
 
50
226
  function _templateObject8() {
51
- var data = (0, _taggedTemplateLiteral2["default"])(["\n width: ", ";\n margin: ", ";\n margin-top: ", ";\n margin-right: ", ";\n margin-bottom: ", ";\n margin-left: ", ";\n display: inline-block;\n .MuiFormControl-root {\n width: 100%;\n }\n .MuiFormLabel-root {\n font-size: 16px;\n color: ", ";\n margin-top: -3px;\n text-overflow: ellipsis;\n overflow: hidden;\n white-space: nowrap;\n height: 22px;\n display: flex;\n align-items: center;\n\n &.Mui-disabled {\n color: ", ";\n opacity: ", ";\n }\n &.Mui-focused {\n font-size: 16px;\n color: ", ";\n }\n }\n .MuiSelect-select {\n width: 100%;\n height: 20px;\n display: flex;\n padding-right: unset;\n color: ", ";\n align-items: center;\n :focus {\n background-color: transparent;\n }\n & > *:last-child::after {\n content: unset;\n }\n & > *:last-child::before {\n content: unset;\n }\n &.Mui-disabled {\n color: ", ";\n cursor: not-allowed;\n }\n }\n .MuiInputBase-root {\n width: 100%;\n &:focus {\n outline: ", " auto 1px;\n }\n &.Mui-disabled {\n opacity: ", ";\n cursor: not-allowed;\n &:focus {\n outline: none;\n }\n }\n }\n .MuiInput-underline {\n &:focus {\n border-bottom: 2px solid;\n border-bottom-color: ", ";\n }\n &.Mui-disabled:before {\n border-bottom-style: solid;\n }\n }\n .MuiInput-underline:hover:not(.Mui-disabled):before {\n border-bottom: 1px solid;\n border-bottom-color: ", ";\n }\n .MuiInput-underline:after {\n border-bottom: 1px solid;\n border-bottom-color: ", ";\n }\n .MuiInput-underline:before {\n border-bottom: 1px solid;\n border-bottom-color: ", "};\n }\n .MuiSelect-icon {\n color: ", ";\n }\n & label {\n text-overflow: ellipsis;\n overflow: hidden;\n width: calc(100% - 24px);\n }\n"]);
227
+ var data = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n align-items: center;\n justify-content: center;\n width: 24px;\n user-select: none;\n background-color: ", ";\n border-right: 1px solid ", ";\n font-family: ", ";\n font-size: 11px;\n ", "\n"]);
52
228
 
53
229
  _templateObject8 = function _templateObject8() {
54
230
  return data;
@@ -58,7 +234,7 @@ function _templateObject8() {
58
234
  }
59
235
 
60
236
  function _templateObject7() {
61
- var data = (0, _taggedTemplateLiteral2["default"])(["\n max-height: 20px;\n max-width: 20px;\n width: 20px;\n height: 20px;\n margin-left: ", ";\n margin-right: ", ";\n overflow: hidden;\n\n img,\n svg {\n height: 100%;\n width: 100%;\n }\n"]);
237
+ var data = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n flex-wrap: wrap;\n align-content: center;\n height: 24px;\n width: 24px;\n font-size: 1rem;\n font-family: ", ";\n border: 1px solid transparent;\n padding: 3px;\n ", "\n background-color: ", ";\n color: ", ";\n\n ", "\n\n svg {\n line-height: 18px;\n }\n"]);
62
238
 
63
239
  _templateObject7 = function _templateObject7() {
64
240
  return data;
@@ -68,7 +244,7 @@ function _templateObject7() {
68
244
  }
69
245
 
70
246
  function _templateObject6() {
71
- var data = (0, _taggedTemplateLiteral2["default"])(["\n max-height: 20px;\n max-width: 20px;\n width: 20px;\n height: 20px;\n margin-left: ", ";\n margin-right: ", ";\n"]);
247
+ var data = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n border: 1px solid ", ";\n border-radius: 2px;\n width: 48px;\n"]);
72
248
 
73
249
  _templateObject6 = function _templateObject6() {
74
250
  return data;
@@ -78,7 +254,7 @@ function _templateObject6() {
78
254
  }
79
255
 
80
256
  function _templateObject5() {
81
- var data = (0, _taggedTemplateLiteral2["default"])(["\n font-family: \"Open Sans\", sans-serif;\n display: flex;\n align-items: center;\n flex-direction: ", ";\n overflow: hidden;\n text-overflow: ellipsis;\n"]);
257
+ var data = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n position: relative;\n align-items: center;\n height: calc(calc(1rem * 2.5) - calc(1px * 2));\n margin: calc(1rem * 0.25) 0;\n padding: 0 calc(1rem * 0.5);\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"]);
82
258
 
83
259
  _templateObject5 = function _templateObject5() {
84
260
  return data;
@@ -88,7 +264,7 @@ function _templateObject5() {
88
264
  }
89
265
 
90
266
  function _templateObject4() {
91
- var data = (0, _taggedTemplateLiteral2["default"])(["\n font-family: \"Open Sans\", sans-serif;\n margin-left: ", ";\n margin-right: ", ";\n overflow: hidden;\n text-overflow: ellipsis;\n"]);
267
+ var data = (0, _taggedTemplateLiteral2["default"])(["\n color: ", ";\n\n font-family: ", ";\n font-size: ", ";\n font-style: ", ";\n font-weight: ", ";\n line-height: 1.5em;\n"]);
92
268
 
93
269
  _templateObject4 = function _templateObject4() {
94
270
  return data;
@@ -98,7 +274,7 @@ function _templateObject4() {
98
274
  }
99
275
 
100
276
  function _templateObject3() {
101
- var data = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n flex-direction: ", ";\n justify-content: ", ";\n margin-right: ", ";\n overflow: hidden;\n text-overflow: ellipsis;\n width: ", ";\n\n &::before {\n margin: 0 4px;\n ", ";\n }\n &::after {\n margin: 0 4px;\n ", ";\n }\n"]);
277
+ var data = (0, _taggedTemplateLiteral2["default"])(["\n font-weight: ", ";\n"]);
102
278
 
103
279
  _templateObject3 = function _templateObject3() {
104
280
  return data;
@@ -108,7 +284,7 @@ function _templateObject3() {
108
284
  }
109
285
 
110
286
  function _templateObject2() {
111
- var data = (0, _taggedTemplateLiteral2["default"])(["\n overflow: hidden;\n text-overflow: ellipsis;\n"]);
287
+ var data = (0, _taggedTemplateLiteral2["default"])(["\n color: ", ";\n\n font-family: ", ";\n font-size: ", ";\n font-style: ", ";\n font-weight: ", ";\n line-height: 1.715em;\n cursor: default;\n"]);
112
288
 
113
289
  _templateObject2 = function _templateObject2() {
114
290
  return data;
@@ -118,7 +294,7 @@ function _templateObject2() {
118
294
  }
119
295
 
120
296
  function _templateObject() {
121
- var data = (0, _taggedTemplateLiteral2["default"])(["\n width: calc(100% - 24px);\n overflow: hidden;\n text-overflow: ellipsis;\n"]);
297
+ var data = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n flex-direction: column;\n\n width: ", ";\n margin: ", ";\n margin-top: ", ";\n margin-right: ", ";\n margin-bottom: ", ";\n margin-left: ", ";\n"]);
122
298
 
123
299
  _templateObject = function _templateObject() {
124
300
  return data;
@@ -127,347 +303,783 @@ function _templateObject() {
127
303
  return data;
128
304
  }
129
305
 
130
- function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }
131
-
132
- function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(source, true).forEach(function (key) { (0, _defineProperty2["default"])(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(source).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
306
+ var selectIcons = {
307
+ error: _react["default"].createElement("svg", {
308
+ xmlns: "http://www.w3.org/2000/svg",
309
+ height: "24px",
310
+ viewBox: "0 0 24 24",
311
+ width: "24px",
312
+ fill: "currentColor"
313
+ }, _react["default"].createElement("path", {
314
+ d: "M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zm1 15h-2v-2h2v2zm0-4h-2V7h2v6z"
315
+ })),
316
+ arrowUp: _react["default"].createElement("svg", {
317
+ xmlns: "http://www.w3.org/2000/svg",
318
+ height: "24px",
319
+ viewBox: "0 0 24 24",
320
+ width: "24px",
321
+ fill: "currentColor"
322
+ }, _react["default"].createElement("path", {
323
+ d: "M0 0h24v24H0V0z",
324
+ fill: "none"
325
+ }), _react["default"].createElement("path", {
326
+ d: "M7.41 15.41L12 10.83l4.59 4.58L18 14l-6-6-6 6 1.41 1.41z"
327
+ })),
328
+ arrowDown: _react["default"].createElement("svg", {
329
+ xmlns: "http://www.w3.org/2000/svg",
330
+ height: "24px",
331
+ viewBox: "0 0 24 24",
332
+ width: "24px",
333
+ fill: "currentColor"
334
+ }, _react["default"].createElement("path", {
335
+ d: "M0 0h24v24H0V0z",
336
+ fill: "none"
337
+ }), _react["default"].createElement("path", {
338
+ d: "M7.41 8.59L12 13.17l4.59-4.58L18 10l-6 6-6-6 1.41-1.41z"
339
+ })),
340
+ clear: _react["default"].createElement("svg", {
341
+ xmlns: "http://www.w3.org/2000/svg",
342
+ width: "24",
343
+ height: "24",
344
+ viewBox: "0 0 24 24",
345
+ fill: "currentColor"
346
+ }, _react["default"].createElement("path", {
347
+ d: "M0 0h24v24H0V0z",
348
+ fill: "none"
349
+ }), _react["default"].createElement("path", {
350
+ d: "M19 6.41L17.59 5 12 10.59 6.41 5 5 6.41 10.59 12 5 17.59 6.41 19 12 13.41 17.59 19 19 17.59 13.41 12 19 6.41z"
351
+ })),
352
+ selected: _react["default"].createElement("svg", {
353
+ xmlns: "http://www.w3.org/2000/svg",
354
+ height: "24px",
355
+ viewBox: "0 0 24 24",
356
+ width: "24px",
357
+ fill: "currentColor"
358
+ }, _react["default"].createElement("path", {
359
+ d: "M0 0h24v24H0z",
360
+ fill: "none"
361
+ }), _react["default"].createElement("path", {
362
+ d: "M9 16.2L4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4L9 16.2z"
363
+ })),
364
+ searchOff: _react["default"].createElement("svg", {
365
+ xmlns: "http://www.w3.org/2000/svg",
366
+ height: "24px",
367
+ viewBox: "0 0 24 24",
368
+ width: "24px",
369
+ fill: "currentColor"
370
+ }, _react["default"].createElement("g", null, _react["default"].createElement("rect", {
371
+ fill: "none",
372
+ height: "24",
373
+ width: "24"
374
+ })), _react["default"].createElement("g", null, _react["default"].createElement("g", null, _react["default"].createElement("path", {
375
+ d: "M15.5,14h-0.79l-0.28-0.27C15.41,12.59,16,11.11,16,9.5C16,5.91,13.09,3,9.5,3C6.08,3,3.28,5.64,3.03,9h2.02 C5.3,6.75,7.18,5,9.5,5C11.99,5,14,7.01,14,9.5S11.99,14,9.5,14c-0.17,0-0.33-0.03-0.5-0.05v2.02C9.17,15.99,9.33,16,9.5,16 c1.61,0,3.09-0.59,4.23-1.57L14,14.71v0.79l5,4.99L20.49,19L15.5,14z"
376
+ }), _react["default"].createElement("polygon", {
377
+ points: "6.47,10.82 4,13.29 1.53,10.82 0.82,11.53 3.29,14 0.82,16.47 1.53,17.18 4,14.71 6.47,17.18 7.18,16.47 4.71,14 7.18,11.53"
378
+ }))))
379
+ };
133
380
 
134
- var useStyles = (0, _styles.makeStyles)(function () {
135
- return {
136
- root: function root(props) {
137
- return {
138
- minWidth: props.width
139
- };
140
- },
141
- dropdownStyle: function dropdownStyle(props) {
142
- return {
143
- boxShadow: "0px 2px 10px 0px rgba(0, 0, 0, 0.3)",
144
- minWidth: props.width,
145
- width: props.width,
146
- maxHeight: "250px",
147
- "&::-webkit-scrollbar": {
148
- width: "3px",
149
- margin: "5px"
150
- },
151
- "&::-webkit-scrollbar-track": {
152
- borderRadius: "3px",
153
- backgroundColor: props.scrollBarTrackColor
154
- },
155
- "&::-webkit-scrollbar-thumb": {
156
- borderRadius: "3px",
157
- backgroundColor: props.scrollBarThumbColor
158
- },
159
- "& .MuiList-root": {
160
- width: "auto !important",
161
- paddingRight: "0 !important"
162
- }
163
- };
164
- },
165
- itemList: function itemList(props) {
166
- return {
167
- color: props.color,
168
- "&.MuiList-padding": {
169
- paddingBottom: "0px",
170
- paddingTop: "0px"
171
- },
172
- "& li": {
173
- fontSize: "16px",
174
- "&:hover": {
175
- backgroundColor: props.selectedOptionBackgroundColor + props.hoverOptionBackgroundColor,
176
- color: props.color
177
- },
178
- "&:active": {
179
- backgroundColor: props.selectedOptionBackgroundColor + props.hoverOptionBackgroundColor,
180
- color: props.color
181
- },
182
- "&.MuiListItem-root.Mui-selected": {
183
- backgroundColor: props.selectedOptionBackgroundColor,
184
- color: props.color
185
- }
186
- }
187
- };
188
- }
189
- };
190
- });
381
+ var getNotOptionalErrorMessage = function getNotOptionalErrorMessage() {
382
+ return "This field is required. Please, enter a value.";
383
+ };
191
384
 
192
- var DxcSelect = function DxcSelect(_ref) {
193
- var value = _ref.value,
194
- name = _ref.name,
195
- onChange = _ref.onChange,
196
- label = _ref.label,
197
- _ref$required = _ref.required,
198
- required = _ref$required === void 0 ? false : _ref$required,
385
+ var DxcSelect = _react["default"].forwardRef(function (_ref, ref) {
386
+ var _ref3;
387
+
388
+ var _ref$label = _ref.label,
389
+ label = _ref$label === void 0 ? "" : _ref$label,
390
+ _ref$name = _ref.name,
391
+ name = _ref$name === void 0 ? "" : _ref$name,
392
+ value = _ref.value,
393
+ options = _ref.options,
394
+ _ref$helperText = _ref.helperText,
395
+ helperText = _ref$helperText === void 0 ? "" : _ref$helperText,
396
+ _ref$placeholder = _ref.placeholder,
397
+ placeholder = _ref$placeholder === void 0 ? "" : _ref$placeholder,
199
398
  _ref$disabled = _ref.disabled,
200
399
  disabled = _ref$disabled === void 0 ? false : _ref$disabled,
201
- _ref$invalid = _ref.invalid,
202
- invalid = _ref$invalid === void 0 ? false : _ref$invalid,
203
- _ref$options = _ref.options,
204
- options = _ref$options === void 0 ? [] : _ref$options,
205
- _ref$iconPosition = _ref.iconPosition,
206
- iconPosition = _ref$iconPosition === void 0 ? "before" : _ref$iconPosition,
400
+ _ref$optional = _ref.optional,
401
+ optional = _ref$optional === void 0 ? false : _ref$optional,
402
+ _ref$searchable = _ref.searchable,
403
+ searchable = _ref$searchable === void 0 ? false : _ref$searchable,
207
404
  _ref$multiple = _ref.multiple,
208
405
  multiple = _ref$multiple === void 0 ? false : _ref$multiple,
406
+ onChange = _ref.onChange,
407
+ onBlur = _ref.onBlur,
408
+ _ref$error = _ref.error,
409
+ error = _ref$error === void 0 ? "" : _ref$error,
209
410
  margin = _ref.margin,
210
411
  _ref$size = _ref.size,
211
- size = _ref$size === void 0 ? "medium" : _ref$size;
212
- var customTheme = (0, _react.useContext)(_ThemeContext["default"]);
213
- var colorsTheme = (0, _react.useMemo)(function () {
214
- return (0, _utils.getCustomTheme)(_variables.theme, (0, _utils.getCustomTheme)(_variables.defaultTheme, customTheme));
215
- }, [customTheme]);
412
+ size = _ref$size === void 0 ? "medium" : _ref$size,
413
+ _ref$tabIndex = _ref.tabIndex,
414
+ tabIndex = _ref$tabIndex === void 0 ? 0 : _ref$tabIndex;
415
+
416
+ var _useState = (0, _react.useState)("select-".concat((0, _uuid.v4)())),
417
+ _useState2 = (0, _slicedToArray2["default"])(_useState, 1),
418
+ selectId = _useState2[0];
419
+
420
+ var selectLabelId = "label-".concat(selectId);
421
+
422
+ var _useState3 = (0, _react.useState)(multiple ? [] : ""),
423
+ _useState4 = (0, _slicedToArray2["default"])(_useState3, 2),
424
+ innerValue = _useState4[0],
425
+ setInnerValue = _useState4[1];
426
+
427
+ var _useState5 = (0, _react.useState)(""),
428
+ _useState6 = (0, _slicedToArray2["default"])(_useState5, 2),
429
+ searchValue = _useState6[0],
430
+ setSearchValue = _useState6[1];
431
+
432
+ var _useState7 = (0, _react.useState)(false),
433
+ _useState8 = (0, _slicedToArray2["default"])(_useState7, 2),
434
+ isBackgroundValue = _useState8[0],
435
+ changeIsBackgroundValue = _useState8[1];
436
+
437
+ var _useState9 = (0, _react.useState)(false),
438
+ _useState10 = (0, _slicedToArray2["default"])(_useState9, 2),
439
+ isOpen = _useState10[0],
440
+ changeIsOpen = _useState10[1];
441
+
442
+ var _useState11 = (0, _react.useState)(false),
443
+ _useState12 = (0, _slicedToArray2["default"])(_useState11, 2),
444
+ isActiveOption = _useState12[0],
445
+ changeIsActiveOption = _useState12[1];
446
+
447
+ var _useState13 = (0, _react.useState)(false),
448
+ _useState14 = (0, _slicedToArray2["default"])(_useState13, 2),
449
+ isScrollable = _useState14[0],
450
+ changeIsScrollable = _useState14[1];
451
+
452
+ var _useState15 = (0, _react.useState)([]),
453
+ _useState16 = (0, _slicedToArray2["default"])(_useState15, 2),
454
+ filteredOptions = _useState16[0],
455
+ setFilteredOptions = _useState16[1];
456
+
457
+ var _useState17 = (0, _react.useState)(-1),
458
+ _useState18 = (0, _slicedToArray2["default"])(_useState17, 2),
459
+ visualFocusIndex = _useState18[0],
460
+ changeVisualFocusIndex = _useState18[1];
461
+
462
+ var selectContainerRef = (0, _react.useRef)(null);
463
+ var selectSearchInputRef = (0, _react.useRef)(null);
464
+ var selectOptionsListRef = (0, _react.useRef)(null);
465
+ var colorsTheme = (0, _useTheme["default"])();
466
+ var backgroundType = (0, _react.useContext)(_BackgroundColorContext["default"]);
467
+ var optionalEmptyOption = {
468
+ label: placeholder,
469
+ value: ""
470
+ };
216
471
 
217
- var _useState = (0, _react.useState)(multiple && [] || ""),
218
- _useState2 = (0, _slicedToArray2["default"])(_useState, 2),
219
- selectedValue = _useState2[0],
220
- setSelectedValue = _useState2[1];
472
+ var notOptionalCheck = function notOptionalCheck(value) {
473
+ return value === "" && !optional;
474
+ };
221
475
 
222
- var selectValues = _objectSpread({
223
- width: "auto"
224
- }, colorsTheme.select);
476
+ var notOptionalMultipleCheck = function notOptionalMultipleCheck() {
477
+ return (value !== null && value !== void 0 ? value : innerValue).length === 0 && !optional;
478
+ };
225
479
 
226
- var classes = useStyles(selectValues);
480
+ var canBeOpenOptions = function canBeOpenOptions() {
481
+ return !disabled && (options === null || options === void 0 ? void 0 : options.length) > 0 && groupsHaveOptions();
482
+ };
227
483
 
228
- var handleSelectChange = function handleSelectChange(selectedOption) {
229
- if (multiple) {
230
- setSelectedValue(selectedOption.target.value);
484
+ var groupsHaveOptions = function groupsHaveOptions() {
485
+ return options[0].hasOwnProperty("options") ? options[0].options ? options.some(function (groupOption) {
486
+ return groupOption.options.length > 0;
487
+ }) : false : true;
488
+ };
231
489
 
232
- if (typeof onChange === "function") {
233
- onChange(selectedOption.target.value);
234
- }
490
+ var filteredGroupsHaveOptions = function filteredGroupsHaveOptions() {
491
+ return filteredOptions !== null && filteredOptions !== void 0 && filteredOptions[0].options ? filteredOptions.some(function (groupOption) {
492
+ var _groupOption$options;
493
+
494
+ return ((_groupOption$options = groupOption.options) === null || _groupOption$options === void 0 ? void 0 : _groupOption$options.length) > 0;
495
+ }) : true;
496
+ };
497
+
498
+ var openOptions = function openOptions() {
499
+ if (!isOpen && canBeOpenOptions()) {
500
+ searchable && changeIsBackgroundValue(true);
501
+ changeIsOpen(true);
502
+ }
503
+ };
504
+
505
+ var closeOptions = function closeOptions() {
506
+ if (isOpen) {
507
+ searchable && changeIsBackgroundValue(false);
508
+ changeIsOpen(false);
509
+ changeVisualFocusIndex(-1);
510
+ }
511
+ };
512
+
513
+ var handleSelectChangeValue = function handleSelectChangeValue(newOption) {
514
+ if (multiple) {
515
+ var _res, _res2;
516
+
517
+ var res;
518
+ if ((value !== null && value !== void 0 ? value : innerValue).includes(newOption.value)) value ? res = value.filter(function (optionVal) {
519
+ return optionVal !== newOption.value;
520
+ }) : setInnerValue(function (previous) {
521
+ return previous.filter(function (optionVal) {
522
+ return optionVal !== newOption.value;
523
+ });
524
+ });else value ? res = [].concat((0, _toConsumableArray2["default"])(value), [newOption.value]) : setInnerValue(function (previous) {
525
+ return [].concat((0, _toConsumableArray2["default"])(previous), [newOption.value]);
526
+ });
527
+ if (notOptionalMultipleCheck(newOption.value)) onChange === null || onChange === void 0 ? void 0 : onChange({
528
+ value: (_res = res) !== null && _res !== void 0 ? _res : innerValue,
529
+ error: getNotOptionalErrorMessage()
530
+ });else onChange === null || onChange === void 0 ? void 0 : onChange({
531
+ value: (_res2 = res) !== null && _res2 !== void 0 ? _res2 : innerValue,
532
+ error: null
533
+ });
235
534
  } else {
236
- setSelectedValue(selectedOption.target.value);
535
+ value !== null && value !== void 0 ? value : setInnerValue(newOption.value);
536
+ if (notOptionalCheck(newOption.value)) onChange === null || onChange === void 0 ? void 0 : onChange({
537
+ value: newOption.value,
538
+ error: getNotOptionalErrorMessage()
539
+ });else onChange === null || onChange === void 0 ? void 0 : onChange({
540
+ value: newOption.value,
541
+ error: null
542
+ });
543
+ }
544
+ };
237
545
 
238
- if (typeof onChange === "function") {
239
- onChange(selectedOption.target.value);
240
- }
546
+ var handleSelectOnClick = function handleSelectOnClick() {
547
+ changeVisualFocusIndex(0);
548
+ isOpen ? closeOptions() : openOptions();
549
+ searchable && selectSearchInputRef.current.focus();
550
+ };
551
+
552
+ var handleSelectOnFocus = function handleSelectOnFocus() {
553
+ searchable && selectSearchInputRef.current.focus();
554
+ };
555
+
556
+ var handleSelectOnBlur = function handleSelectOnBlur(event) {
557
+ // focus leaves container (outside, not to childs)
558
+ if (!event.currentTarget.contains(event.relatedTarget)) {
559
+ closeOptions();
560
+ setSearchValue("");
561
+ if (notOptionalCheck(value !== null && value !== void 0 ? value : innerValue)) onBlur === null || onBlur === void 0 ? void 0 : onBlur({
562
+ value: value !== null && value !== void 0 ? value : innerValue,
563
+ error: getNotOptionalErrorMessage()
564
+ });else onBlur === null || onBlur === void 0 ? void 0 : onBlur({
565
+ value: value !== null && value !== void 0 ? value : innerValue,
566
+ error: null
567
+ });
568
+ }
569
+ };
570
+
571
+ var handleSelectOnKeyDown = function handleSelectOnKeyDown(event) {
572
+ switch (event.keyCode) {
573
+ case 40:
574
+ // Arrow Down
575
+ event.preventDefault();
576
+ changeVisualFocusIndex(function (visualFocusIndex) {
577
+ if (visualFocusIndex < lastOptionIndex) return visualFocusIndex + 1;else if (visualFocusIndex === lastOptionIndex) return 0;
578
+ });
579
+ openOptions();
580
+ changeIsActiveOption(false);
581
+ isOpen && changeIsScrollable(true);
582
+ break;
583
+
584
+ case 38:
585
+ // Arrow Up
586
+ event.preventDefault();
587
+ changeVisualFocusIndex(function (visualFocusIndex) {
588
+ return visualFocusIndex === 0 || visualFocusIndex === -1 ? lastOptionIndex : visualFocusIndex - 1;
589
+ });
590
+ openOptions();
591
+ changeIsActiveOption(false);
592
+ isOpen && changeIsScrollable(true);
593
+ break;
594
+
595
+ case 27:
596
+ // Esc
597
+ event.preventDefault();
598
+ closeOptions();
599
+ setSearchValue("");
600
+ break;
601
+
602
+ case 13:
603
+ // Enter
604
+ if (isOpen) {
605
+ var accLength = optional && !multiple ? 1 : 0;
606
+
607
+ if (searchable) {
608
+ if (filteredOptions.length > 0) {
609
+ if (optional && !multiple && visualFocusIndex === 0 && filteredGroupsHaveOptions()) handleSelectChangeValue(optionalEmptyOption);else filteredOptions[0].options ? filteredGroupsHaveOptions() && filteredOptions.some(function (groupOption) {
610
+ var groupLength = accLength + groupOption.options.length;
611
+ groupLength > visualFocusIndex && handleSelectChangeValue(groupOption.options[visualFocusIndex - accLength]);
612
+ accLength = groupLength;
613
+ return groupLength > visualFocusIndex;
614
+ }) : handleSelectChangeValue(filteredOptions[visualFocusIndex - accLength]);
615
+ }
616
+ } else {
617
+ if (optional && !multiple && visualFocusIndex === 0) handleSelectChangeValue(optionalEmptyOption);else options[0].options ? options.some(function (groupOption) {
618
+ var groupLength = accLength + groupOption.options.length;
619
+ groupLength > visualFocusIndex && handleSelectChangeValue(groupOption.options[visualFocusIndex - accLength]);
620
+ accLength = groupLength;
621
+ return groupLength > visualFocusIndex;
622
+ }) : handleSelectChangeValue(options[visualFocusIndex - accLength]);
623
+ }
624
+
625
+ !multiple && closeOptions();
626
+ setSearchValue("");
627
+ }
628
+
629
+ break;
241
630
  }
242
631
  };
243
632
 
244
- var getLabelForSingleSelect = function getLabelForSingleSelect(selected) {
245
- var selectedItem = options.filter(function (option) {
246
- return option.value === selected;
247
- })[0];
248
- return _react["default"].createElement(SelectedIconContainer, {
249
- iconPosition: iconPosition,
250
- multiple: multiple,
251
- label: selectedItem && selectedItem.label,
252
- key: selectedItem && selectedItem.label
253
- }, selectedItem && selectedItem.icon ? _react["default"].createElement(ListIconContainer, null, (0, _typeof2["default"])(selectedItem.icon) === "object" ? selectedItem.icon : _react["default"].createElement(selectedItem.icon)) : selectedItem && selectedItem.iconSrc && _react["default"].createElement(ListIcon, {
254
- src: selectedItem && selectedItem.iconSrc
255
- }), selectedItem && selectedItem.label && _react["default"].createElement(SelectedLabelContainer, {
256
- iconSrc: selectedItem && selectedItem.iconSrc && selectedItem.icon,
257
- iconPosition: iconPosition,
258
- disabled: disabled
259
- }, selectedItem && selectedItem.label));
260
- };
261
-
262
- var getSelectedValuesWithLabel = function getSelectedValuesWithLabel(optionsList, selected) {
263
- return _react["default"].createElement(MultipleLabelSelected, null, optionsList.filter(function (x) {
264
- return selected.includes(x.value);
265
- }).map(function (optionToRender) {
266
- return optionToRender.label;
267
- }).join(", "));
268
- };
269
-
270
- var getSelectedValuesWithIcons = function getSelectedValuesWithIcons(optionsList, selected) {
271
- return options.filter(function (x) {
272
- return selected.includes(x.value);
273
- }).map(function (optionToRender) {
274
- return getLabelForSingleSelect(optionToRender.value);
633
+ var handleSearchIOnChange = function handleSearchIOnChange(event) {
634
+ setSearchValue(event.target.value);
635
+ !isOpen && changeVisualFocusIndex(0);
636
+ openOptions();
637
+ };
638
+
639
+ var handleClearActionOnClick = function handleClearActionOnClick(event) {
640
+ event.stopPropagation();
641
+ setSearchValue("");
642
+ };
643
+
644
+ var handleClearOptionsActionOnClick = function handleClearOptionsActionOnClick(event) {
645
+ event.stopPropagation();
646
+ value !== null && value !== void 0 ? value : setInnerValue([]);
647
+ onChange === null || onChange === void 0 ? void 0 : onChange({
648
+ value: [],
649
+ error: getNotOptionalErrorMessage()
275
650
  });
651
+ selectContainerRef.current.focus();
276
652
  };
277
653
 
278
- var labelForMultipleSelect = function labelForMultipleSelect(selected) {
279
- return options.findIndex(function (option) {
280
- return !option.label;
281
- }) !== -1 ? getSelectedValuesWithIcons(options, selected) : getSelectedValuesWithLabel(options, selected);
654
+ var getLastOptionIndex = function getLastOptionIndex() {
655
+ var last = 0;
656
+
657
+ var reducer = function reducer(acc, current) {
658
+ var _current$options;
659
+
660
+ return acc + ((_current$options = current.options) === null || _current$options === void 0 ? void 0 : _current$options.length);
661
+ };
662
+
663
+ if (searchable && filteredOptions.length > 0) filteredOptions[0].options ? last = filteredOptions.reduce(reducer, 0) - 1 : last = filteredOptions.length - 1;else if ((options === null || options === void 0 ? void 0 : options.length) > 0) options[0].options ? last = options.reduce(reducer, 0) - 1 : last = options.length - 1;
664
+ return optional && !multiple ? last + 1 : last;
282
665
  };
283
666
 
284
- var getRenderValue = function getRenderValue(selected) {
285
- return multiple && labelForMultipleSelect(selected) || getLabelForSingleSelect(selected);
667
+ var lastOptionIndex = (0, _react.useMemo)(function () {
668
+ return getLastOptionIndex();
669
+ }, [searchable, optional, multiple, searchable ? filteredOptions : options]);
670
+
671
+ var getSelectedOption = function getSelectedOption() {
672
+ var val = value !== null && value !== void 0 ? value : innerValue;
673
+ var selectedOption = multiple ? [] : "";
674
+
675
+ if (multiple) {
676
+ if ((options === null || options === void 0 ? void 0 : options.length) > 0) {
677
+ options.forEach(function (option) {
678
+ if (option.options) {
679
+ option.options.forEach(function (singleOption) {
680
+ if (val.includes(singleOption.value)) selectedOption.push(singleOption);
681
+ });
682
+ } else if (val.includes(option.value)) selectedOption.push(option);
683
+ });
684
+ }
685
+ } else {
686
+ if ((options === null || options === void 0 ? void 0 : options.length) > 0) {
687
+ options.forEach(function (option) {
688
+ if (option.options) {
689
+ option.options.forEach(function (singleOption) {
690
+ if (singleOption.value === val) selectedOption = singleOption;
691
+ });
692
+ } else if (option.value === val) selectedOption = option;
693
+ });
694
+ }
695
+ }
696
+
697
+ return selectedOption;
286
698
  };
287
699
 
288
- var isChecked = function isChecked(checkedValue, value, option) {
289
- if (value !== undefined) {
290
- var result = false;
291
- value.map(function (val) {
292
- if (val === option.value) {
293
- result = true;
700
+ var selectedOption = (0, _react.useMemo)(function () {
701
+ return getSelectedOption();
702
+ }, [options, multiple, value !== null && value !== void 0 ? value : innerValue]);
703
+ (0, _react.useLayoutEffect)(function () {
704
+ if (isScrollable) {
705
+ var _selectOptionsListRef;
706
+
707
+ var visualFocusedOptionEl = selectOptionsListRef === null || selectOptionsListRef === void 0 ? void 0 : (_selectOptionsListRef = selectOptionsListRef.current) === null || _selectOptionsListRef === void 0 ? void 0 : _selectOptionsListRef.querySelectorAll("[role='option']")[visualFocusIndex];
708
+ visualFocusedOptionEl === null || visualFocusedOptionEl === void 0 ? void 0 : visualFocusedOptionEl.scrollIntoView({
709
+ block: "nearest",
710
+ inline: "start"
711
+ });
712
+ return changeIsScrollable(false);
713
+ }
714
+ }, [isScrollable]);
715
+ (0, _react.useEffect)(function () {
716
+ if (searchable && (options === null || options === void 0 ? void 0 : options.length) > 0) {
717
+ if (options[0].options) {
718
+ setFilteredOptions(options.map(function (optionGroup) {
719
+ var group = JSON.parse(JSON.stringify(optionGroup)); // circular issue
720
+
721
+ group.options = group.options.filter(function (option) {
722
+ return option.label.toUpperCase().includes(searchValue.toUpperCase());
723
+ });
724
+ return group;
725
+ }));
726
+ } else setFilteredOptions(options.filter(function (option) {
727
+ return option.label.toUpperCase().includes(searchValue.toUpperCase());
728
+ }));
729
+ }
730
+ }, [options, searchable, searchValue]);
731
+ (0, _react.useEffect)(function () {
732
+ visualFocusIndex > lastOptionIndex && changeVisualFocusIndex(0);
733
+ }, [filteredOptions]);
734
+
735
+ var Option = function Option(_ref2) {
736
+ var option = _ref2.option,
737
+ index = _ref2.index,
738
+ _ref2$isGroupedOption = _ref2.isGroupedOption,
739
+ isGroupedOption = _ref2$isGroupedOption === void 0 ? false : _ref2$isGroupedOption;
740
+ var isSelected = multiple ? (value !== null && value !== void 0 ? value : innerValue).includes(option.value) : (value !== null && value !== void 0 ? value : innerValue) === option.value;
741
+ var isLastOption = index === lastOptionIndex;
742
+ return _react["default"].createElement(OptionItem, {
743
+ onMouseDown: function onMouseDown(event) {
744
+ // left mouse button only
745
+ event.button === 0 && changeIsActiveOption(true);
746
+ },
747
+ onMouseUp: function onMouseUp(event) {
748
+ if (event.button === 0 && isActiveOption) {
749
+ // left mouse button only
750
+ handleSelectChangeValue(option);
751
+ !multiple && closeOptions();
752
+ setSearchValue("");
753
+ changeIsActiveOption(false);
294
754
  }
755
+ },
756
+ onMouseEnter: function onMouseEnter() {
757
+ changeVisualFocusIndex(index);
758
+ },
759
+ onMouseLeave: function onMouseLeave() {
760
+ changeIsActiveOption(false);
761
+ },
762
+ visualFocused: visualFocusIndex === index,
763
+ active: visualFocusIndex === index && isActiveOption,
764
+ selected: isSelected,
765
+ "aria-selected": isSelected && "true",
766
+ role: "option"
767
+ }, _react["default"].createElement(StyledOption, {
768
+ visualFocused: visualFocusIndex === index,
769
+ active: visualFocusIndex === index && isActiveOption,
770
+ selected: isSelected,
771
+ last: isLastOption,
772
+ grouped: isGroupedOption,
773
+ multiple: multiple
774
+ }, multiple && _react["default"].createElement(_Checkbox["default"], {
775
+ tabIndex: -1,
776
+ checked: isSelected
777
+ }), option.icon && _react["default"].createElement(OptionIcon, null, typeof option.icon === "string" ? _react["default"].createElement(OptionIconImg, {
778
+ src: option.icon
779
+ }) : option.icon), _react["default"].createElement(OptionContent, {
780
+ grouped: isGroupedOption,
781
+ hasIcon: option.icon,
782
+ multiple: multiple
783
+ }, _react["default"].createElement(OptionLabel, null, option.label), !multiple && isSelected && _react["default"].createElement(SelectedIcon, null, selectIcons.selected))));
784
+ };
785
+
786
+ var global_index = optional && !multiple ? 0 : -1; // index for options (not groups), starting from 0 to options.length -1
787
+
788
+ var mapOptionFunc = function mapOptionFunc(option) {
789
+ if (option.options) {
790
+ return _react["default"].createElement(_react["default"].Fragment, null, option.options.length > 0 && _react["default"].createElement(OptionGroupLabel, null, option.label), option.options.map(function (singleOption) {
791
+ global_index++;
792
+ return _react["default"].createElement(Option, {
793
+ option: singleOption,
794
+ index: global_index,
795
+ isGroupedOption: true
796
+ });
797
+ }));
798
+ } else {
799
+ global_index++;
800
+ return _react["default"].createElement(Option, {
801
+ option: option,
802
+ index: global_index
295
803
  });
296
- return result;
297
- } else if (checkedValue) {
298
- return checkedValue.findIndex(function (element) {
299
- return element === option.value;
300
- }) !== -1 || false;
301
804
  }
302
805
  };
303
806
 
304
807
  return _react["default"].createElement(_styledComponents.ThemeProvider, {
305
- theme: colorsTheme
306
- }, _react["default"].createElement(SelectContainer, {
808
+ theme: colorsTheme.select
809
+ }, _react["default"].createElement(DxcSelectContainer, {
307
810
  margin: margin,
308
811
  size: size,
309
- invalid: invalid
310
- }, _react["default"].createElement(_FormControl["default"], null, _react["default"].createElement(_InputLabel["default"], {
311
- disabled: disabled
312
- }, required && _react["default"].createElement(_RequiredComponent["default"], null), label), _react["default"].createElement(_Select["default"], {
313
- tabIndex: "0",
314
- name: name,
315
- multiple: multiple,
316
- renderValue: getRenderValue,
317
- onChange: handleSelectChange,
318
- value: value !== undefined ? value : selectedValue,
812
+ ref: ref
813
+ }, _react["default"].createElement(Label, {
814
+ id: selectLabelId,
319
815
  disabled: disabled,
320
- MenuProps: {
321
- classes: {
322
- paper: classes.dropdownStyle,
323
- list: classes.itemList
324
- },
325
- getContentAnchorEl: null,
326
- anchorOrigin: {
327
- vertical: "bottom",
328
- horizontal: "left"
329
- }
816
+ backgroundType: backgroundType,
817
+ onClick: function onClick() {
818
+ selectContainerRef.current.focus();
330
819
  }
331
- }, options.map(function (option) {
332
- return _react["default"].createElement(_MenuItem["default"], {
333
- id: option.value,
334
- value: option.value,
335
- disableRipple: true,
336
- key: option.value
337
- }, multiple && _react["default"].createElement(_Checkbox["default"], {
338
- size: "fitContent",
339
- checked: isChecked(selectedValue, value, option)
340
- }), _react["default"].createElement(OptionContainer, {
341
- iconPosition: iconPosition
342
- }, option.icon ? _react["default"].createElement(ListIconContainer, {
343
- label: option.label,
344
- iconPosition: iconPosition
345
- }, (0, _typeof2["default"])(option.icon) === "object" ? option.icon : _react["default"].createElement(option.icon)) : option.iconSrc && _react["default"].createElement(ListIcon, {
346
- src: option.iconSrc,
347
- label: option.label,
348
- iconPosition: iconPosition
349
- }), " ", _react["default"].createElement(LabelCont, null, option.label)));
350
- })))));
351
- };
820
+ }, label, " ", optional && _react["default"].createElement(OptionalLabel, null, "(Optional)")), _react["default"].createElement(HelperText, {
821
+ disabled: disabled,
822
+ backgroundType: backgroundType
823
+ }, helperText), _react["default"].createElement(SelectContainer, {
824
+ id: selectId,
825
+ backgroundType: backgroundType,
826
+ disabled: disabled,
827
+ error: error,
828
+ onBlur: handleSelectOnBlur,
829
+ onClick: handleSelectOnClick,
830
+ onFocus: handleSelectOnFocus,
831
+ onKeyDown: handleSelectOnKeyDown,
832
+ ref: selectContainerRef,
833
+ tabIndex: tabIndex,
834
+ "aria-labelledby": selectLabelId
835
+ }, multiple && selectedOption.length > 0 && _react["default"].createElement(SelectionIndicator, null, _react["default"].createElement(SelectionValue, null, selectedOption.length, " "), _react["default"].createElement(ClearOptionsAction, {
836
+ onClick: handleClearOptionsActionOnClick,
837
+ backgroundType: backgroundType,
838
+ tabIndex: -1,
839
+ title: "Clear selected options",
840
+ "aria-label": "Clear selected options"
841
+ }, selectIcons.clear)), _react["default"].createElement(SearchableValueContainer, null, _react["default"].createElement(ValueInput, {
842
+ name: name,
843
+ value: value !== null && value !== void 0 ? value : innerValue,
844
+ readOnly: true
845
+ }), searchable && _react["default"].createElement(SearchInput, {
846
+ value: searchValue,
847
+ disabled: disabled,
848
+ onChange: handleSearchIOnChange,
849
+ ref: selectSearchInputRef,
850
+ autoComplete: "off",
851
+ autoCorrect: "off"
852
+ }), (!searchable || searchValue === "") && (multiple ? _react["default"].createElement(SelectedOption, {
853
+ disabled: disabled,
854
+ backgroundValue: (value !== null && value !== void 0 ? value : innerValue).length === 0 || isBackgroundValue
855
+ }, _react["default"].createElement(OptionLabel, null, selectedOption.map(function (option) {
856
+ return option.label;
857
+ }).join(", ")), selectedOption.length === 0 && placeholder) : _react["default"].createElement(SelectedOption, {
858
+ disabled: disabled,
859
+ backgroundValue: !(value !== null && value !== void 0 ? value : innerValue) || isBackgroundValue
860
+ }, _react["default"].createElement(OptionLabel, null, (_ref3 = selectedOption === null || selectedOption === void 0 ? void 0 : selectedOption.label) !== null && _ref3 !== void 0 ? _ref3 : placeholder)))), !disabled && error && _react["default"].createElement(ErrorIcon, {
861
+ backgroundType: backgroundType
862
+ }, selectIcons.error), searchable && searchValue.length > 0 && _react["default"].createElement(ClearAction, {
863
+ onClick: handleClearActionOnClick,
864
+ backgroundType: backgroundType,
865
+ tabIndex: -1,
866
+ title: "Clear search text",
867
+ "aria-label": "Clear search text"
868
+ }, selectIcons.clear), _react["default"].createElement(Arrow, {
869
+ disabled: disabled,
870
+ backgroundType: backgroundType
871
+ }, isOpen ? selectIcons.arrowUp : selectIcons.arrowDown), isOpen && _react["default"].createElement(OptionsList, {
872
+ onClick: function onClick(event) {
873
+ event.stopPropagation();
874
+ },
875
+ onMouseDown: function onMouseDown(event) {
876
+ event.preventDefault();
877
+ },
878
+ ref: selectOptionsListRef,
879
+ role: "listbox",
880
+ "aria-label": label
881
+ }, searchable && (filteredOptions.length === 0 || !filteredGroupsHaveOptions()) ? _react["default"].createElement(OptionsSystemMessage, null, _react["default"].createElement(NoMatchesFoundIcon, null, selectIcons.searchOff), "No matches found") : optional && !multiple && _react["default"].createElement(Option, {
882
+ option: optionalEmptyOption,
883
+ index: 0
884
+ }), searchable ? filteredOptions.map(mapOptionFunc) : options.map(mapOptionFunc))), !disabled && _react["default"].createElement(Error, {
885
+ backgroundType: backgroundType
886
+ }, error)));
887
+ });
352
888
 
353
889
  var sizes = {
354
- small: "60px",
355
- medium: "240px",
890
+ small: "240px",
891
+ medium: "360px",
356
892
  large: "480px",
357
893
  fillParent: "100%"
358
894
  };
359
895
 
360
896
  var calculateWidth = function calculateWidth(margin, size) {
361
- if (size === "fillParent") {
362
- return "calc(".concat(sizes[size], " - ").concat((0, _utils.getMargin)(margin, "left"), " - ").concat((0, _utils.getMargin)(margin, "right"), ")");
363
- }
364
-
365
- return sizes[size];
897
+ return size === "fillParent" ? "calc(".concat(sizes[size], " - ").concat((0, _utils.getMargin)(margin, "left"), " - ").concat((0, _utils.getMargin)(margin, "right"), ")") : sizes[size];
366
898
  };
367
899
 
368
- var MultipleLabelSelected = _styledComponents["default"].div(_templateObject());
369
-
370
- var LabelCont = _styledComponents["default"].span(_templateObject2());
900
+ var DxcSelectContainer = _styledComponents["default"].div(_templateObject(), function (props) {
901
+ return calculateWidth(props.margin, props.size);
902
+ }, function (props) {
903
+ return props.margin && (0, _typeof2["default"])(props.margin) !== "object" ? _variables.spaces[props.margin] : "0px";
904
+ }, function (props) {
905
+ return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.top ? _variables.spaces[props.margin.top] : "";
906
+ }, function (props) {
907
+ return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.right ? _variables.spaces[props.margin.right] : "";
908
+ }, function (props) {
909
+ return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.bottom ? _variables.spaces[props.margin.bottom] : "";
910
+ }, function (props) {
911
+ return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.left ? _variables.spaces[props.margin.left] : "";
912
+ });
371
913
 
372
- var SelectedIconContainer = _styledComponents["default"].div(_templateObject3(), function (props) {
373
- return props.iconPosition === "before" && "row" || "row-reverse";
914
+ var Label = _styledComponents["default"].span(_templateObject2(), function (props) {
915
+ return props.disabled ? props.backgroundType === "dark" ? props.theme.disabledLabelFontColorOnDark : props.theme.disabledLabelFontColor : props.backgroundType === "dark" ? props.theme.labelFontColorOnDark : props.theme.labelFontColor;
916
+ }, function (props) {
917
+ return props.theme.fontFamily;
918
+ }, function (props) {
919
+ return props.theme.labelFontSize;
920
+ }, function (props) {
921
+ return props.theme.labelFontStyle;
374
922
  }, function (props) {
375
- return props.iconPosition === "before" && "flex-start" || "flex-end";
923
+ return props.theme.labelFontWeight;
924
+ });
925
+
926
+ var OptionalLabel = _styledComponents["default"].span(_templateObject3(), function (props) {
927
+ return props.theme.optionalLabelFontWeight;
928
+ });
929
+
930
+ var HelperText = _styledComponents["default"].span(_templateObject4(), function (props) {
931
+ return props.disabled ? props.backgroundType === "dark" ? props.theme.disabledHelperTextFontColorOnDark : props.theme.disabledHelperTextFontColor : props.backgroundType === "dark" ? props.theme.helperTextFontColorOnDark : props.theme.helperTextFontColor;
376
932
  }, function (props) {
377
- return props.multiple && props.label && "15px" || "0px";
933
+ return props.theme.fontFamily;
378
934
  }, function (props) {
379
- return !props.multiple && "calc(100% - 24px)" || "auto";
935
+ return props.theme.helperTextFontSize;
380
936
  }, function (props) {
381
- return props.iconPosition === "after" && (props.label !== "" || props.label === undefined) && "content:','";
937
+ return props.theme.helperTextFontStyle;
382
938
  }, function (props) {
383
- return props.iconPosition === "before" && (props.label !== "" || props.label === undefined) && "content:','";
939
+ return props.theme.helperTextFontWeight;
384
940
  });
385
941
 
386
- var SelectedLabelContainer = _styledComponents["default"].span(_templateObject4(), function (props) {
387
- return (props.iconPosition === "after" || !props.iconSrc) && "0px" || "10px";
942
+ var SelectContainer = _styledComponents["default"].div(_templateObject5(), function (props) {
943
+ if (props.disabled) return props.backgroundType === "dark" ? "background-color: ".concat(props.theme.disabledContainerFillColorOnDark, ";") : "background-color: ".concat(props.theme.disabledContainerFillColor, ";");
944
+ }, function (props) {
945
+ if (props.disabled) return props.backgroundType === "dark" ? props.theme.disabledBorderColorOnDark : props.theme.disabledBorderColor;else return props.backgroundType === "dark" ? props.theme.enabledBorderColorOnDark : props.theme.enabledBorderColor;
388
946
  }, function (props) {
389
- return (props.iconPosition === "before" || !props.iconSrc) && "0px" || "10px";
947
+ return props.error && !props.disabled && "border-color: transparent;\n box-shadow: 0 0 0 2px ".concat(props.backgroundType === "dark" ? props.theme.errorBorderColorOnDark : props.theme.errorBorderColor, ";\n ");
948
+ }, function (props) {
949
+ return props.disabled ? "cursor: not-allowed;" : "cursor: pointer;";
950
+ }, function (props) {
951
+ return !props.disabled && "\n &:hover {\n border-color: ".concat(props.error ? "transparent" : props.backgroundType === "dark" ? props.theme.hoverBorderColorOnDark : props.theme.hoverBorderColor, ";\n ").concat(props.error && "box-shadow: 0 0 0 2px ".concat(props.backgroundType === "dark" ? props.theme.hoverErrorBorderColorOnDark : props.theme.hoverErrorBorderColor, ";"), "\n }\n &:focus-within {\n border-color: transparent;\n box-shadow: 0 0 0 2px ").concat(props.backgroundType === "dark" ? props.theme.focusBorderColorOnDark : props.theme.focusBorderColor, ";\n }\n ");
390
952
  });
391
953
 
392
- var OptionContainer = _styledComponents["default"].div(_templateObject5(), function (props) {
393
- return props.iconPosition === "before" && "row" || "row-reverse";
954
+ var SelectionIndicator = _styledComponents["default"].span(_templateObject6(), function (props) {
955
+ return props.theme.selectionIndicatorBorderColor;
394
956
  });
395
957
 
396
- var ListIcon = _styledComponents["default"].img(_templateObject6(), function (props) {
397
- return props.iconPosition === "after" && props.label !== "" && "10px" || "0px";
958
+ var ClearOptionsAction = _styledComponents["default"].button(_templateObject7(), function (props) {
959
+ return props.theme.fontFamily;
960
+ }, function (props) {
961
+ return props.disabled ? "cursor: not-allowed;" : "cursor: pointer;";
962
+ }, function (props) {
963
+ return props.theme.enabledSelectionIndicatorActionBackgroundColor;
964
+ }, function (props) {
965
+ return props.theme.enabledSelectionIndicatorActionIconColor;
398
966
  }, function (props) {
399
- return props.iconPosition === "before" && props.label !== "" && "10px" || "0px";
967
+ return !props.disabled && "\n &:hover {\n background-color: ".concat(props.theme.hoverSelectionIndicatorActionBackgroundColor, ";\n color: ").concat(props.theme.hoverSelectionIndicatorActionIconColor, ";\n }\n &:active {\n background-color: ").concat(props.theme.activeSelectionIndicatorActionBackgroundColor, ";\n color: ").concat(props.theme.activeSelectionIndicatorActionIconColor, ";\n }\n ");
400
968
  });
401
969
 
402
- var ListIconContainer = _styledComponents["default"].div(_templateObject7(), function (props) {
403
- return props.iconPosition === "after" && props.label !== "" && "10px" || "0px";
970
+ var SelectionValue = _styledComponents["default"].span(_templateObject8(), function (props) {
971
+ return props.theme.selectionIndicatorBackgroundColor;
404
972
  }, function (props) {
405
- return props.iconPosition === "before" && props.label !== "" && "10px" || "0px";
973
+ return props.theme.selectionIndicatorBorderColor;
974
+ }, function (props) {
975
+ return props.theme.fontFamily;
976
+ }, function (props) {
977
+ return props.disabled ? "cursor: not-allowed;" : "cursor: default;";
406
978
  });
407
979
 
408
- var SelectContainer = _styledComponents["default"].div(_templateObject8(), function (props) {
409
- return calculateWidth(props.margin, props.size);
980
+ var SearchableValueContainer = _styledComponents["default"].div(_templateObject9());
981
+
982
+ var SelectedOption = _styledComponents["default"].span(_templateObject10(), function (props) {
983
+ if (props.backgroundValue) return props.disabled ? props.backgroundType === "dark" ? props.theme.disabledPlaceholderFontColorOnDark : props.theme.disabledPlaceholderFontColor : props.backgroundType === "dark" ? props.theme.placeholderFontColorOnDark : props.theme.placeholderFontColor;else return props.disabled ? props.backgroundType === "dark" ? props.theme.disabledValueFontColorOnDark : props.theme.disabledValueFontColor : props.backgroundType === "dark" ? props.theme.valueFontColorOnDark : props.theme.valueFontColor;
410
984
  }, function (props) {
411
- return props.margin && (0, _typeof2["default"])(props.margin) !== "object" ? _variables.spaces[props.margin] : "0px";
985
+ return props.theme.fontFamily;
412
986
  }, function (props) {
413
- return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.top ? _variables.spaces[props.margin.top] : "";
987
+ return props.theme.valueFontSize;
414
988
  }, function (props) {
415
- return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.right ? _variables.spaces[props.margin.right] : "";
989
+ return props.theme.valueFontStyle;
416
990
  }, function (props) {
417
- return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.bottom ? _variables.spaces[props.margin.bottom] : "";
991
+ return props.theme.valueFontWeight;
992
+ });
993
+
994
+ var ValueInput = _styledComponents["default"].input(_templateObject11());
995
+
996
+ var SearchInput = _styledComponents["default"].input(_templateObject12(), function (props) {
997
+ return props.disabled ? props.backgroundType === "dark" ? props.theme.disabledValueFontColorOnDark : props.theme.disabledValueFontColor : props.backgroundType === "dark" ? props.theme.valueFontColorOnDark : props.theme.valueFontColor;
418
998
  }, function (props) {
419
- return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.left ? _variables.spaces[props.margin.left] : "";
999
+ return props.theme.fontFamily;
420
1000
  }, function (props) {
421
- return props.invalid === true ? props.theme.select.error : props.theme.select.color;
1001
+ return props.theme.valueFontSize;
422
1002
  }, function (props) {
423
- return props.theme.select.color;
1003
+ return props.theme.valueFontStyle;
424
1004
  }, function (props) {
425
- return props.theme.select.disabled;
1005
+ return props.theme.valueFontWeight;
426
1006
  }, function (props) {
427
- return props.invalid === true ? props.theme.select.error : props.theme.select.color;
1007
+ return props.disabled ? props.backgroundType === "dark" ? props.theme.disabledPlaceholderFontColorOnDark : props.theme.disabledPlaceholderFontColor : props.backgroundType === "dark" ? props.theme.placeholderFontColorOnDark : props.theme.placeholderFontColor;
1008
+ });
1009
+
1010
+ var ErrorIcon = _styledComponents["default"].span(_templateObject13(), function (props) {
1011
+ return props.backgroundType === "dark" ? props.theme.errorIconColorOnDark : props.theme.errorIconColor;
1012
+ });
1013
+
1014
+ var Error = _styledComponents["default"].span(_templateObject14(), function (props) {
1015
+ return props.backgroundType === "dark" ? props.theme.errorMessageColorOnDark : props.theme.errorMessageColor;
428
1016
  }, function (props) {
429
- return props.theme.select.color;
1017
+ return props.theme.fontFamily;
1018
+ });
1019
+
1020
+ var Arrow = _styledComponents["default"].span(_templateObject15(), function (props) {
1021
+ return props.disabled ? props.backgroundType === "dark" ? props.theme.disabledArrowColorOnDark : props.theme.disabledArrowColor : props.backgroundType === "dark" ? props.theme.arrowColorOnDark : props.theme.arrowColor;
1022
+ });
1023
+
1024
+ var ClearAction = _styledComponents["default"].button(_templateObject16(), function (props) {
1025
+ return props.theme.fontFamily;
1026
+ }, function (props) {
1027
+ return props.disabled ? "cursor: not-allowed;" : "cursor: pointer;";
430
1028
  }, function (props) {
431
- return props.theme.select.color;
1029
+ return props.disabled ? props.backgroundType === "dark" ? props.theme.disabledActionBackgroundColorOnDark : props.theme.disabledActionBackgroundColor : props.backgroundType === "dark" ? props.theme.actionBackgroundColorOnDark : props.theme.actionBackgroundColor;
432
1030
  }, function (props) {
433
- return props.theme.select.focusColor;
1031
+ return props.disabled ? props.backgroundType === "dark" ? props.theme.disabledActionIconColorOnDark : props.theme.disabledActionIconColor : props.backgroundType === "dark" ? props.theme.actionIconColorOnDark : props.theme.actionIconColor;
434
1032
  }, function (props) {
435
- return props.theme.select.disabled;
1033
+ return !props.disabled && "\n &:hover {\n background-color: ".concat(props.backgroundType === "dark" ? props.theme.hoverActionBackgroundColorOnDark : props.theme.hoverActionBackgroundColor, ";\n color: ").concat(props.backgroundType === "dark" ? props.theme.hoverActionIconColorOnDark : props.theme.hoverActionIconColor, ";\n }\n &:active {\n background-color: ").concat(props.backgroundType === "dark" ? props.theme.activeActionBackgroundColorOnDark : props.theme.activeActionBackgroundColor, ";\n color: ").concat(props.backgroundType === "dark" ? props.theme.activeActionIconColorOnDark : props.theme.activeActionIconColor, ";\n }\n ");
1034
+ });
1035
+
1036
+ var OptionsList = _styledComponents["default"].ul(_templateObject17(), function (props) {
1037
+ return props.theme.enabledListBorderColor;
436
1038
  }, function (props) {
437
- return props.invalid === true ? props.theme.select.error : props.theme.select.color;
1039
+ return props.theme.fontFamily;
438
1040
  }, function (props) {
439
- return props.invalid === true ? props.theme.select.error : props.theme.select.color;
1041
+ return props.theme.listOptionFontColor;
440
1042
  }, function (props) {
441
- return props.invalid === true ? props.theme.select.error : props.theme.select.color;
1043
+ return props.theme.listOptionFontSize;
442
1044
  }, function (props) {
443
- return props.invalid === true ? props.theme.select.error : props.theme.select.color;
1045
+ return props.theme.listOptionFontStyle;
444
1046
  }, function (props) {
445
- return props.theme.select.color;
1047
+ return props.theme.listOptionFontWeight;
446
1048
  });
447
1049
 
448
- DxcSelect.propTypes = {
449
- size: _propTypes["default"].oneOf((0, _toConsumableArray2["default"])(Object.keys(sizes))),
450
- label: _propTypes["default"].string,
451
- name: _propTypes["default"].string,
452
- value: _propTypes["default"].oneOfType([_propTypes["default"].string, _propTypes["default"].number, _propTypes["default"].arrayOf(_propTypes["default"].oneOfType([_propTypes["default"].string, _propTypes["default"].number]))]),
453
- disabled: _propTypes["default"].bool,
454
- required: _propTypes["default"].bool,
455
- invalid: _propTypes["default"].bool,
456
- iconPosition: _propTypes["default"].oneOf(["after", "before"]),
457
- onChange: _propTypes["default"].func,
458
- options: _propTypes["default"].arrayOf(_propTypes["default"].shape({
459
- value: _propTypes["default"].any.isRequired,
460
- label: _propTypes["default"].string,
461
- icon: _propTypes["default"].oneOfType([_propTypes["default"].element, _propTypes["default"].func]),
462
- iconSrc: _propTypes["default"].string
463
- })),
464
- multiple: _propTypes["default"].bool,
465
- margin: _propTypes["default"].oneOfType([_propTypes["default"].shape({
466
- top: _propTypes["default"].oneOf(Object.keys(_variables.spaces)),
467
- bottom: _propTypes["default"].oneOf(Object.keys(_variables.spaces)),
468
- left: _propTypes["default"].oneOf(Object.keys(_variables.spaces)),
469
- right: _propTypes["default"].oneOf(Object.keys(_variables.spaces))
470
- }), _propTypes["default"].oneOf((0, _toConsumableArray2["default"])(Object.keys(_variables.spaces)))])
471
- };
1050
+ var OptionsSystemMessage = _styledComponents["default"].span(_templateObject18(), function (props) {
1051
+ return props.theme.systemMessageFontColor;
1052
+ });
1053
+
1054
+ var NoMatchesFoundIcon = _styledComponents["default"].span(_templateObject19());
1055
+
1056
+ var OptionGroupLabel = _styledComponents["default"].li(_templateObject20());
1057
+
1058
+ var OptionItem = _styledComponents["default"].li(_templateObject21(), function (props) {
1059
+ if (props.selected) {
1060
+ if (props.active) return "background-color: #BFBFBF";else if (props.visualFocused) return "background-color: #CCCCCC";else return "background-color: ".concat(props.theme.selectedListOptionBackgroundColor);
1061
+ } else {
1062
+ if (props.active) return "background-color: ".concat(props.theme.activeListOptionBackgroundColor, ";");else if (props.visualFocused) return "background-color: ".concat(props.theme.hoverListOptionBackgroundColor, ";");
1063
+ }
1064
+ });
1065
+
1066
+ var StyledOption = _styledComponents["default"].span(_templateObject22(), function (props) {
1067
+ return props.grouped && props.multiple && "padding-left: 16px;";
1068
+ }, function (props) {
1069
+ return props.last ? "border-bottom: 1px solid transparent" : "border-bottom: 1px solid ".concat(props.theme.listOptionBorderBottomColor);
1070
+ });
1071
+
1072
+ var OptionContent = _styledComponents["default"].span(_templateObject23(), function (props) {
1073
+ return props.grouped && !props.multiple && !props.hasIcon && "padding-left: 16px;";
1074
+ });
1075
+
1076
+ var OptionIcon = _styledComponents["default"].span(_templateObject24());
1077
+
1078
+ var OptionIconImg = _styledComponents["default"].img(_templateObject25());
1079
+
1080
+ var OptionLabel = _styledComponents["default"].span(_templateObject26());
1081
+
1082
+ var SelectedIcon = _styledComponents["default"].span(_templateObject27());
1083
+
472
1084
  var _default = DxcSelect;
473
1085
  exports["default"] = _default;