@dxc-technology/halstack-react 0.0.0-e345e78 → 0.0.0-e3e5511

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 (269) hide show
  1. package/BackgroundColorContext.js +46 -0
  2. package/ThemeContext.js +250 -0
  3. package/V3Select/V3Select.js +549 -0
  4. package/V3Select/index.d.ts +27 -0
  5. package/V3Textarea/V3Textarea.js +264 -0
  6. package/V3Textarea/index.d.ts +27 -0
  7. package/accordion/Accordion.js +353 -0
  8. package/accordion/index.d.ts +28 -0
  9. package/accordion-group/AccordionGroup.js +186 -0
  10. package/accordion-group/index.d.ts +16 -0
  11. package/alert/Alert.js +403 -0
  12. package/alert/index.d.ts +51 -0
  13. package/badge/Badge.js +63 -0
  14. package/{dist/box → box}/Box.js +31 -23
  15. package/box/index.d.ts +25 -0
  16. package/button/Button.js +238 -0
  17. package/button/Button.stories.js +27 -0
  18. package/button/index.d.ts +24 -0
  19. package/{dist/card → card}/Card.js +72 -35
  20. package/card/index.d.ts +22 -0
  21. package/{dist/checkbox → checkbox}/Checkbox.js +107 -32
  22. package/checkbox/index.d.ts +24 -0
  23. package/chip/Chip.js +265 -0
  24. package/chip/index.d.ts +22 -0
  25. package/{dist/common → common}/OpenSans.css +0 -0
  26. package/{dist/common → common}/RequiredComponent.js +2 -8
  27. package/{dist/common → common}/fonts/OpenSans-Bold.ttf +0 -0
  28. package/{dist/common → common}/fonts/OpenSans-BoldItalic.ttf +0 -0
  29. package/{dist/common → common}/fonts/OpenSans-ExtraBold.ttf +0 -0
  30. package/{dist/common → common}/fonts/OpenSans-ExtraBoldItalic.ttf +0 -0
  31. package/{dist/common → common}/fonts/OpenSans-Italic.ttf +0 -0
  32. package/{dist/common → common}/fonts/OpenSans-Light.ttf +0 -0
  33. package/{dist/common → common}/fonts/OpenSans-LightItalic.ttf +0 -0
  34. package/{dist/common → common}/fonts/OpenSans-Regular.ttf +0 -0
  35. package/{dist/common → common}/fonts/OpenSans-SemiBold.ttf +0 -0
  36. package/{dist/common → common}/fonts/OpenSans-SemiBoldItalic.ttf +0 -0
  37. package/common/utils.js +22 -0
  38. package/common/variables.js +1574 -0
  39. package/{dist/date → date}/Date.js +81 -59
  40. package/date/index.d.ts +27 -0
  41. package/date-input/DateInput.js +400 -0
  42. package/date-input/index.d.ts +95 -0
  43. package/{dist/dialog → dialog}/Dialog.js +61 -36
  44. package/dialog/index.d.ts +18 -0
  45. package/dropdown/Dropdown.js +544 -0
  46. package/dropdown/index.d.ts +26 -0
  47. package/file-input/FileInput.js +644 -0
  48. package/file-input/FileItem.js +287 -0
  49. package/file-input/index.d.ts +81 -0
  50. package/{dist/footer → footer}/Footer.js +122 -47
  51. package/footer/Icons.js +77 -0
  52. package/footer/index.d.ts +25 -0
  53. package/header/Header.js +470 -0
  54. package/header/Icons.js +59 -0
  55. package/header/index.d.ts +25 -0
  56. package/{dist/heading → heading}/Heading.js +93 -22
  57. package/heading/index.d.ts +17 -0
  58. package/input-text/Icons.js +22 -0
  59. package/input-text/InputText.js +705 -0
  60. package/input-text/index.d.ts +36 -0
  61. package/layout/ApplicationLayout.js +327 -0
  62. package/layout/Icons.js +55 -0
  63. package/link/Link.js +237 -0
  64. package/link/index.d.ts +23 -0
  65. package/main.d.ts +40 -0
  66. package/{dist/main.js → main.js} +112 -16
  67. package/number-input/NumberInput.js +136 -0
  68. package/{dist/ThemeContext.js → number-input/NumberInputContext.js} +3 -2
  69. package/number-input/index.d.ts +113 -0
  70. package/package.json +31 -19
  71. package/paginator/Icons.js +66 -0
  72. package/paginator/Paginator.js +305 -0
  73. package/paginator/index.d.ts +20 -0
  74. package/password-input/PasswordInput.js +203 -0
  75. package/password-input/index.d.ts +94 -0
  76. package/{dist/progress-bar → progress-bar}/ProgressBar.js +97 -44
  77. package/progress-bar/index.d.ts +18 -0
  78. package/{dist/radio → radio}/Radio.js +39 -21
  79. package/radio/index.d.ts +23 -0
  80. package/{dist/resultsetTable → resultsetTable}/ResultsetTable.js +93 -69
  81. package/resultsetTable/index.d.ts +19 -0
  82. package/select/Select.js +1137 -0
  83. package/select/index.d.ts +131 -0
  84. package/sidenav/Sidenav.js +179 -0
  85. package/sidenav/index.d.ts +13 -0
  86. package/slider/Slider.js +404 -0
  87. package/slider/index.d.ts +29 -0
  88. package/spinner/Spinner.js +381 -0
  89. package/spinner/index.d.ts +17 -0
  90. package/{dist/switch → switch}/Switch.js +52 -25
  91. package/switch/index.d.ts +24 -0
  92. package/table/Table.js +132 -0
  93. package/table/index.d.ts +13 -0
  94. package/tabs/Tabs.js +343 -0
  95. package/tabs/index.d.ts +19 -0
  96. package/{dist/tag → tag}/Tag.js +100 -35
  97. package/tag/index.d.ts +24 -0
  98. package/text-input/TextInput.js +974 -0
  99. package/text-input/index.d.ts +135 -0
  100. package/textarea/Textarea.js +369 -0
  101. package/textarea/index.d.ts +117 -0
  102. package/{dist/toggle → toggle}/Toggle.js +16 -19
  103. package/toggle/index.d.ts +21 -0
  104. package/toggle-group/ToggleGroup.js +327 -0
  105. package/toggle-group/index.d.ts +21 -0
  106. package/{dist/upload → upload}/Upload.js +13 -8
  107. package/{dist/upload → upload}/buttons-upload/ButtonsUpload.js +35 -25
  108. package/upload/buttons-upload/Icons.js +40 -0
  109. package/{dist/upload → upload}/dragAndDropArea/DragAndDropArea.js +84 -37
  110. package/upload/dragAndDropArea/Icons.js +39 -0
  111. package/upload/file-upload/FileToUpload.js +189 -0
  112. package/upload/file-upload/Icons.js +66 -0
  113. package/{dist/upload → upload}/files-upload/FilesToUpload.js +16 -16
  114. package/upload/index.d.ts +15 -0
  115. package/upload/transaction/Icons.js +160 -0
  116. package/upload/transaction/Transaction.js +148 -0
  117. package/{dist/upload → upload}/transactions/Transactions.js +38 -20
  118. package/useTheme.js +22 -0
  119. package/wizard/Icons.js +65 -0
  120. package/wizard/Wizard.js +405 -0
  121. package/wizard/index.d.ts +18 -0
  122. package/README.md +0 -66
  123. package/babel.config.js +0 -4
  124. package/dist/accordion/Accordion.js +0 -264
  125. package/dist/accordion/Accordion.stories.js +0 -207
  126. package/dist/accordion/readme.md +0 -96
  127. package/dist/alert/Alert.js +0 -302
  128. package/dist/alert/Alert.stories.js +0 -158
  129. package/dist/alert/close.svg +0 -4
  130. package/dist/alert/error.svg +0 -4
  131. package/dist/alert/info.svg +0 -4
  132. package/dist/alert/readme.md +0 -43
  133. package/dist/alert/success.svg +0 -4
  134. package/dist/alert/warning.svg +0 -4
  135. package/dist/button/Button.js +0 -183
  136. package/dist/button/Button.stories.js +0 -224
  137. package/dist/button/readme.md +0 -93
  138. package/dist/checkbox/Checkbox.stories.js +0 -144
  139. package/dist/checkbox/readme.md +0 -116
  140. package/dist/chip/Chip.js +0 -170
  141. package/dist/common/services/example-service.js +0 -10
  142. package/dist/common/services/example-service.test.js +0 -12
  143. package/dist/common/utils.js +0 -42
  144. package/dist/common/variables.js +0 -260
  145. package/dist/date/Date.stories.js +0 -205
  146. package/dist/date/calendar.svg +0 -1
  147. package/dist/date/calendar_dark.svg +0 -1
  148. package/dist/date/readme.md +0 -73
  149. package/dist/dialog/Dialog.stories.js +0 -217
  150. package/dist/dialog/readme.md +0 -32
  151. package/dist/dropdown/Dropdown.js +0 -412
  152. package/dist/dropdown/Dropdown.stories.js +0 -249
  153. package/dist/dropdown/baseline-arrow_drop_down.svg +0 -1
  154. package/dist/dropdown/baseline-arrow_drop_down_wh.svg +0 -4
  155. package/dist/dropdown/baseline-arrow_drop_up.svg +0 -1
  156. package/dist/dropdown/baseline-arrow_drop_up_wh.svg +0 -4
  157. package/dist/dropdown/readme.md +0 -69
  158. package/dist/footer/Footer.stories.js +0 -94
  159. package/dist/footer/dxc_logo_wht.png +0 -0
  160. package/dist/footer/readme.md +0 -41
  161. package/dist/header/Header.js +0 -350
  162. package/dist/header/Header.stories.js +0 -176
  163. package/dist/header/close_icon.svg +0 -1
  164. package/dist/header/dxc_logo_black.png +0 -0
  165. package/dist/header/dxc_logo_white.png +0 -0
  166. package/dist/header/hamb_menu_black.svg +0 -1
  167. package/dist/header/hamb_menu_white.svg +0 -1
  168. package/dist/header/readme.md +0 -33
  169. package/dist/input-text/InputText.js +0 -519
  170. package/dist/input-text/InputText.stories.js +0 -209
  171. package/dist/input-text/error.svg +0 -1
  172. package/dist/input-text/readme.md +0 -91
  173. package/dist/link/Link.js +0 -136
  174. package/dist/link/readme.md +0 -51
  175. package/dist/paginator/Paginator.js +0 -178
  176. package/dist/paginator/images/next.svg +0 -3
  177. package/dist/paginator/images/nextPage.svg +0 -3
  178. package/dist/paginator/images/previous.svg +0 -3
  179. package/dist/paginator/images/previousPage.svg +0 -3
  180. package/dist/paginator/readme.md +0 -50
  181. package/dist/progress-bar/ProgressBar.stories.js +0 -280
  182. package/dist/progress-bar/readme.md +0 -63
  183. package/dist/radio/Radio.stories.js +0 -166
  184. package/dist/radio/readme.md +0 -70
  185. package/dist/resultsetTable/arrow_downward-24px_wht.svg +0 -1
  186. package/dist/resultsetTable/arrow_upward-24px_wht.svg +0 -1
  187. package/dist/resultsetTable/unfold_more-24px_wht.svg +0 -1
  188. package/dist/select/Select.js +0 -442
  189. package/dist/select/Select.stories.js +0 -235
  190. package/dist/select/readme.md +0 -72
  191. package/dist/sidenav/Sidenav.js +0 -217
  192. package/dist/sidenav/arrow_icon.svg +0 -3
  193. package/dist/slider/Slider.js +0 -258
  194. package/dist/slider/Slider.stories.js +0 -241
  195. package/dist/slider/readme.md +0 -64
  196. package/dist/spinner/Spinner.js +0 -196
  197. package/dist/spinner/Spinner.stories.js +0 -183
  198. package/dist/spinner/readme.md +0 -65
  199. package/dist/switch/Switch.stories.js +0 -134
  200. package/dist/switch/readme.md +0 -133
  201. package/dist/table/Table.js +0 -84
  202. package/dist/tabs/Tabs.js +0 -170
  203. package/dist/tabs/Tabs.stories.js +0 -130
  204. package/dist/tabs/readme.md +0 -78
  205. package/dist/tabs-for-sections/TabsForSections.js +0 -107
  206. package/dist/tabs-for-sections/readme.md +0 -78
  207. package/dist/textarea/Textarea.js +0 -226
  208. package/dist/toggle/Toggle.stories.js +0 -297
  209. package/dist/toggle/readme.md +0 -80
  210. package/dist/upload/Upload.stories.js +0 -72
  211. package/dist/upload/buttons-upload/drag-drop-icon.svg +0 -4
  212. package/dist/upload/buttons-upload/upload-button.svg +0 -1
  213. package/dist/upload/dragAndDropArea/upload_drop.svg +0 -4
  214. package/dist/upload/dragAndDropArea/upload_file.svg +0 -4
  215. package/dist/upload/file-upload/FileToUpload.js +0 -158
  216. package/dist/upload/file-upload/audio-icon.svg +0 -4
  217. package/dist/upload/file-upload/close.svg +0 -4
  218. package/dist/upload/file-upload/file-icon.svg +0 -4
  219. package/dist/upload/file-upload/video-icon.svg +0 -4
  220. package/dist/upload/readme.md +0 -37
  221. package/dist/upload/transaction/Transaction.js +0 -155
  222. package/dist/upload/transaction/audio-icon-err.svg +0 -4
  223. package/dist/upload/transaction/audio-icon.svg +0 -4
  224. package/dist/upload/transaction/error-icon.svg +0 -4
  225. package/dist/upload/transaction/file-icon-err.svg +0 -4
  226. package/dist/upload/transaction/file-icon.svg +0 -4
  227. package/dist/upload/transaction/image-icon-err.svg +0 -4
  228. package/dist/upload/transaction/image-icon.svg +0 -4
  229. package/dist/upload/transaction/success-icon.svg +0 -4
  230. package/dist/upload/transaction/video-icon-err.svg +0 -4
  231. package/dist/upload/transaction/video-icon.svg +0 -4
  232. package/dist/wizard/Wizard.js +0 -310
  233. package/dist/wizard/invalid_icon.svg +0 -6
  234. package/dist/wizard/valid_icon.svg +0 -6
  235. package/dist/wizard/validation-wrong.svg +0 -6
  236. package/test/Accordion.test.js +0 -33
  237. package/test/Alert.test.js +0 -53
  238. package/test/Box.test.js +0 -10
  239. package/test/Button.test.js +0 -18
  240. package/test/Card.test.js +0 -30
  241. package/test/Checkbox.test.js +0 -45
  242. package/test/Chip.test.js +0 -25
  243. package/test/Date.test.js +0 -393
  244. package/test/Dialog.test.js +0 -23
  245. package/test/Dropdown.test.js +0 -130
  246. package/test/Footer.test.js +0 -99
  247. package/test/Header.test.js +0 -39
  248. package/test/Heading.test.js +0 -35
  249. package/test/InputText.test.js +0 -236
  250. package/test/Link.test.js +0 -25
  251. package/test/Paginator.test.js +0 -165
  252. package/test/ProgressBar.test.js +0 -35
  253. package/test/Radio.test.js +0 -37
  254. package/test/ResultsetTable.test.js +0 -282
  255. package/test/Select.test.js +0 -191
  256. package/test/Sidenav.test.js +0 -87
  257. package/test/Slider.test.js +0 -65
  258. package/test/Spinner.test.js +0 -27
  259. package/test/Switch.test.js +0 -45
  260. package/test/Table.test.js +0 -36
  261. package/test/Tabs.test.js +0 -88
  262. package/test/TabsForSections.test.js +0 -34
  263. package/test/Tag.test.js +0 -32
  264. package/test/TextArea.test.js +0 -52
  265. package/test/Toggle.test.js +0 -43
  266. package/test/Upload.test.js +0 -60
  267. package/test/Wizard.test.js +0 -130
  268. package/test/mocks/pngMock.js +0 -1
  269. package/test/mocks/svgMock.js +0 -1
@@ -0,0 +1,18 @@
1
+ type Space = "xxsmall" | "xsmall" | "small" | "medium" | "large" | "xlarge" | "xxlarge";
2
+ type Padding = {
3
+ top?: Space;
4
+ bottom?: Space;
5
+ left?: Space;
6
+ right?: Space;
7
+ };
8
+
9
+ type Props = {
10
+ isCloseVisible?: boolean;
11
+ onCloseClick?: void;
12
+ overlay?: boolean;
13
+ onBackgroundClick?: void;
14
+ padding?: Padding,
15
+ tabIndex?: number;
16
+ };
17
+
18
+ export default function DxcDialog(props: Props): JSX.Element;
@@ -0,0 +1,544 @@
1
+ "use strict";
2
+
3
+ var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard");
4
+
5
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
6
+
7
+ Object.defineProperty(exports, "__esModule", {
8
+ value: true
9
+ });
10
+ exports["default"] = void 0;
11
+
12
+ var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray"));
13
+
14
+ var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
15
+
16
+ var _typeof2 = _interopRequireDefault(require("@babel/runtime/helpers/typeof"));
17
+
18
+ var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
19
+
20
+ var _react = _interopRequireWildcard(require("react"));
21
+
22
+ var _styledComponents = _interopRequireWildcard(require("styled-components"));
23
+
24
+ var _propTypes = _interopRequireDefault(require("prop-types"));
25
+
26
+ var _Popper = _interopRequireDefault(require("@material-ui/core/Popper"));
27
+
28
+ var _MenuItem = _interopRequireDefault(require("@material-ui/core/MenuItem"));
29
+
30
+ var _core = require("@material-ui/core");
31
+
32
+ var _Grow = _interopRequireDefault(require("@material-ui/core/Grow"));
33
+
34
+ var _Paper = _interopRequireDefault(require("@material-ui/core/Paper"));
35
+
36
+ var _MenuList = _interopRequireDefault(require("@material-ui/core/MenuList"));
37
+
38
+ var _variables = require("../common/variables.js");
39
+
40
+ var _utils = require("../common/utils.js");
41
+
42
+ var _useTheme = _interopRequireDefault(require("../useTheme.js"));
43
+
44
+ function _templateObject10() {
45
+ var data = (0, _taggedTemplateLiteral2["default"])(["\n display: ", ";\n margin-left: ", ";\n color: ", ";\n\n svg {\n width: ", ";\n height: ", ";\n }\n"]);
46
+
47
+ _templateObject10 = function _templateObject10() {
48
+ return data;
49
+ };
50
+
51
+ return data;
52
+ }
53
+
54
+ function _templateObject9() {
55
+ var data = (0, _taggedTemplateLiteral2["default"])(["\n overflow: hidden;\n width: ", ";\n height: ", ";\n margin-left: ", ";\n margin-right: ", ";\n color: ", ";\n\n img,\n svg {\n height: 100%;\n width: 100%;\n }\n"]);
56
+
57
+ _templateObject9 = function _templateObject9() {
58
+ return data;
59
+ };
60
+
61
+ return data;
62
+ }
63
+
64
+ function _templateObject8() {
65
+ var data = (0, _taggedTemplateLiteral2["default"])(["\n width: ", ";\n height: ", ";\n margin-left: ", ";\n margin-right: ", ";\n"]);
66
+
67
+ _templateObject8 = function _templateObject8() {
68
+ return data;
69
+ };
70
+
71
+ return data;
72
+ }
73
+
74
+ function _templateObject7() {
75
+ var data = (0, _taggedTemplateLiteral2["default"])(["\n overflow: hidden;\n width: ", ";\n height: ", ";\n margin-left: ", ";\n margin-right: ", ";\n color: ", ";\n\n img,\n svg {\n height: 100%;\n width: 100%;\n }\n"]);
76
+
77
+ _templateObject7 = function _templateObject7() {
78
+ return data;
79
+ };
80
+
81
+ return data;
82
+ }
83
+
84
+ function _templateObject6() {
85
+ var data = (0, _taggedTemplateLiteral2["default"])(["\n width: ", ";\n height: ", ";\n margin-left: ", ";\n margin-right: ", ";\n"]);
86
+
87
+ _templateObject6 = function _templateObject6() {
88
+ return data;
89
+ };
90
+
91
+ return data;
92
+ }
93
+
94
+ function _templateObject5() {
95
+ var data = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n align-items: center;\n flex-direction: ", ";\n margin-left: 0px;\n margin-right: 0px;\n width: ", ";\n white-space: nowrap;\n"]);
96
+
97
+ _templateObject5 = function _templateObject5() {
98
+ return data;
99
+ };
100
+
101
+ return data;
102
+ }
103
+
104
+ function _templateObject4() {
105
+ var data = (0, _taggedTemplateLiteral2["default"])(["\n text-align: left;\n text-overflow: ellipsis;\n overflow: hidden;\n"]);
106
+
107
+ _templateObject4 = function _templateObject4() {
108
+ return data;
109
+ };
110
+
111
+ return data;
112
+ }
113
+
114
+ function _templateObject3() {
115
+ var data = (0, _taggedTemplateLiteral2["default"])(["\n display: inline-flex;\n justify-content: space-between;\n align-items: center;\n width: 100%;\n height: auto;\n min-height: 40px;\n cursor: ", ";\n font-family: ", ";\n font-size: ", ";\n font-style: ", ";\n font-weight: ", ";\n border-radius: ", ";\n border-width: ", ";\n border-style: ", ";\n border-color: ", ";\n min-width: ", ";\n padding-top: ", ";\n padding-bottom: ", ";\n padding-left: ", ";\n padding-right: ", ";\n background-color: ", ";\n color: ", ";\n border-bottom-right-radius: ", ";\n border-bottom-left-radius: ", ";\n\n ", ";\n"]);
116
+
117
+ _templateObject3 = function _templateObject3() {
118
+ return data;
119
+ };
120
+
121
+ return data;
122
+ }
123
+
124
+ function _templateObject2() {
125
+ var data = (0, _taggedTemplateLiteral2["default"])(["\n z-index: 1;\n\n .MuiMenuItem-gutters {\n width: ", ";\n }\n .MuiMenuItem-root {\n min-height: 36px;\n padding-top: ", ";\n padding-bottom: ", ";\n padding-left: ", ";\n padding-right: ", ";\n height: auto;\n }\n .MuiPaper-root {\n min-width: ", ";\n border-width: ", ";\n border-style: ", ";\n border-color: ", ";\n border-bottom-left-radius: ", ";\n border-bottom-right-radius: ", ";\n border-top-left-radius: 0px;\n border-top-right-radius: 0px;\n max-height: 230px;\n overflow-y: auto;\n\n ::-webkit-scrollbar {\n width: 3px;\n }\n ::-webkit-scrollbar-track {\n background-color: ", ";\n border-radius: 3px;\n }\n ::-webkit-scrollbar-thumb {\n background-color: ", ";\n border-radius: 3px;\n }\n\n .MuiList-padding {\n padding-top: 0px;\n padding-bottom: 0px;\n }\n .MuiListItem-button {\n display: flex;\n flex-direction: ", ";\n justify-content: ", ";\n background-color: ", ";\n font-family: ", ";\n font-size: ", ";\n font-style: ", ";\n font-weight: ", ";\n color: ", ";\n cursor: pointer;\n }\n .MuiListItem-button:focus {\n outline: ", " solid 2px;\n outline-offset: -2px;\n }\n .MuiListItem-button:hover {\n background-color: ", ";\n }\n .MuiListItem-button:active {\n background-color: ", ";\n outline: ", " solid 2px;\n outline-offset: -2px;\n }\n }\n"]);
126
+
127
+ _templateObject2 = function _templateObject2() {
128
+ return data;
129
+ };
130
+
131
+ return data;
132
+ }
133
+
134
+ function _templateObject() {
135
+ var data = (0, _taggedTemplateLiteral2["default"])(["\n width: ", ";\n text-overflow: ellipsis;\n overflow: hidden;\n margin: ", ";\n margin-top: ", ";\n margin-right: ", ";\n margin-bottom: ", ";\n margin-left: ", ";\n display: inline-block;\n"]);
136
+
137
+ _templateObject = function _templateObject() {
138
+ return data;
139
+ };
140
+
141
+ return data;
142
+ }
143
+
144
+ var DxcDropdown = function DxcDropdown(_ref) {
145
+ var _ref$options = _ref.options,
146
+ options = _ref$options === void 0 ? [] : _ref$options,
147
+ _ref$optionsIconPosit = _ref.optionsIconPosition,
148
+ optionsIconPosition = _ref$optionsIconPosit === void 0 ? "before" : _ref$optionsIconPosit,
149
+ icon = _ref.icon,
150
+ _ref$iconSrc = _ref.iconSrc,
151
+ iconSrc = _ref$iconSrc === void 0 ? "" : _ref$iconSrc,
152
+ _ref$iconPosition = _ref.iconPosition,
153
+ iconPosition = _ref$iconPosition === void 0 ? "before" : _ref$iconPosition,
154
+ _ref$label = _ref.label,
155
+ label = _ref$label === void 0 ? "" : _ref$label,
156
+ _ref$disabled = _ref.disabled,
157
+ disabled = _ref$disabled === void 0 ? false : _ref$disabled,
158
+ _ref$caretHidden = _ref.caretHidden,
159
+ caretHidden = _ref$caretHidden === void 0 ? false : _ref$caretHidden,
160
+ onSelectOption = _ref.onSelectOption,
161
+ margin = _ref.margin,
162
+ _ref$size = _ref.size,
163
+ size = _ref$size === void 0 ? "fitContent" : _ref$size,
164
+ _ref$expandOnHover = _ref.expandOnHover,
165
+ expandOnHover = _ref$expandOnHover === void 0 ? false : _ref$expandOnHover,
166
+ _ref$tabIndex = _ref.tabIndex,
167
+ tabIndex = _ref$tabIndex === void 0 ? 0 : _ref$tabIndex;
168
+
169
+ var _useState = (0, _react.useState)(),
170
+ _useState2 = (0, _slicedToArray2["default"])(_useState, 2),
171
+ width = _useState2[0],
172
+ setWidth = _useState2[1];
173
+
174
+ var colorsTheme = (0, _useTheme["default"])();
175
+ var ref = (0, _react.useRef)(null);
176
+
177
+ var handleResize = function handleResize() {
178
+ if (ref.current) setWidth(ref.current.offsetWidth);
179
+ };
180
+
181
+ (0, _react.useEffect)(function () {
182
+ if (ref.current) {
183
+ ref.current.addEventListener("resize", handleResize);
184
+ handleResize();
185
+ }
186
+
187
+ return function () {
188
+ if (ref.current) ref.current.removeEventListener("resize", handleResize);
189
+ };
190
+ }, []);
191
+
192
+ var _useState3 = (0, _react.useState)(null),
193
+ _useState4 = (0, _slicedToArray2["default"])(_useState3, 2),
194
+ anchorEl = _useState4[0],
195
+ setAnchorEl = _useState4[1];
196
+
197
+ function handleClickListItem(event) {
198
+ setAnchorEl(event.currentTarget);
199
+ }
200
+
201
+ function handleMenuItemClick(option) {
202
+ setAnchorEl(null);
203
+
204
+ if (typeof onSelectOption === "function") {
205
+ onSelectOption(option.value);
206
+ }
207
+ }
208
+
209
+ function handleClose() {
210
+ setAnchorEl(null);
211
+ }
212
+
213
+ var handleCloseOver = expandOnHover ? handleClose : undefined;
214
+
215
+ var UpArrowIcon = function UpArrowIcon() {
216
+ return _react["default"].createElement("svg", {
217
+ xmlns: "http://www.w3.org/2000/svg",
218
+ width: "24",
219
+ height: "24",
220
+ viewBox: "0 0 24 24",
221
+ fill: "currentColor"
222
+ }, _react["default"].createElement("path", {
223
+ d: "M7 14l5-5 5 5z"
224
+ }), _react["default"].createElement("path", {
225
+ d: "M0 0h24v24H0z",
226
+ fill: "none"
227
+ }));
228
+ };
229
+
230
+ var DownArrowIcon = function DownArrowIcon() {
231
+ return _react["default"].createElement("svg", {
232
+ xmlns: "http://www.w3.org/2000/svg",
233
+ width: "24",
234
+ height: "24",
235
+ viewBox: "0 0 24 24",
236
+ fill: "currentColor"
237
+ }, _react["default"].createElement("path", {
238
+ d: "M7 10l5 5 5-5z"
239
+ }), _react["default"].createElement("path", {
240
+ d: "M0 0h24v24H0z",
241
+ fill: "none"
242
+ }));
243
+ };
244
+
245
+ return _react["default"].createElement(_styledComponents.ThemeProvider, {
246
+ theme: colorsTheme.dropdown
247
+ }, _react["default"].createElement(DXCDropdownContainer, {
248
+ margin: margin,
249
+ size: size,
250
+ disabled: disabled
251
+ }, _react["default"].createElement("div", {
252
+ onMouseOver: expandOnHover && !disabled ? handleClickListItem : undefined,
253
+ onMouseOut: handleCloseOver,
254
+ onFocus: handleCloseOver,
255
+ onBlur: handleCloseOver
256
+ }, _react["default"].createElement(DropdownTrigger, {
257
+ opened: anchorEl === null ? false : true,
258
+ onClick: handleClickListItem,
259
+ disabled: disabled,
260
+ label: label,
261
+ caretHidden: caretHidden,
262
+ margin: margin,
263
+ size: size,
264
+ ref: ref,
265
+ tabIndex: tabIndex
266
+ }, _react["default"].createElement(DropdownTriggerContainer, {
267
+ iconPosition: iconPosition,
268
+ caretHidden: caretHidden
269
+ }, icon ? _react["default"].createElement(ButtonIconContainer, {
270
+ label: label,
271
+ iconPosition: iconPosition,
272
+ disabled: disabled
273
+ }, (0, _typeof2["default"])(icon) === "object" ? icon : _react["default"].createElement(icon)) : iconSrc && _react["default"].createElement(ButtonIcon, {
274
+ label: label,
275
+ src: iconSrc,
276
+ iconPosition: iconPosition
277
+ }), _react["default"].createElement(DropdownTriggerLabel, {
278
+ iconPosition: iconPosition,
279
+ label: label
280
+ }, label)), _react["default"].createElement(CaretIconContainer, {
281
+ caretHidden: caretHidden,
282
+ disabled: disabled
283
+ }, !caretHidden && (anchorEl === null ? _react["default"].createElement(DownArrowIcon, null) : _react["default"].createElement(UpArrowIcon, null)))), _react["default"].createElement(DXCMenu, {
284
+ anchorEl: anchorEl,
285
+ open: Boolean(anchorEl),
286
+ onClose: handleClose,
287
+ getContentAnchorEl: null,
288
+ anchorOrigin: {
289
+ vertical: "bottom",
290
+ horizontal: "left"
291
+ },
292
+ transformOrigin: {
293
+ vertical: "top",
294
+ horizontal: "left"
295
+ },
296
+ optionsIconPosition: optionsIconPosition,
297
+ size: size,
298
+ width: width,
299
+ role: undefined,
300
+ transition: true,
301
+ disablePortal: true,
302
+ placement: "bottom-start"
303
+ }, function (_ref2) {
304
+ var TransitionProps = _ref2.TransitionProps;
305
+ return _react["default"].createElement(_Grow["default"], TransitionProps, _react["default"].createElement(_Paper["default"], null, _react["default"].createElement(_core.ClickAwayListener, {
306
+ onClickAway: handleClose
307
+ }, _react["default"].createElement(_MenuList["default"], {
308
+ autoFocusItem: Boolean(anchorEl),
309
+ id: "menu-list-grow"
310
+ }, options.map(function (option) {
311
+ return _react["default"].createElement(_MenuItem["default"], {
312
+ key: option.value,
313
+ value: option.value,
314
+ disableRipple: true,
315
+ onClick: function onClick(event) {
316
+ return handleMenuItemClick(option);
317
+ }
318
+ }, option.icon ? _react["default"].createElement(ListIconContainer, {
319
+ label: option.label,
320
+ iconPosition: optionsIconPosition
321
+ }, (0, _typeof2["default"])(option.icon) === "object" ? option.icon : _react["default"].createElement(option.icon)) : option.iconSrc && _react["default"].createElement(ListIcon, {
322
+ label: option.label,
323
+ src: option.iconSrc,
324
+ iconPosition: optionsIconPosition
325
+ }), _react["default"].createElement("span", {
326
+ className: "optionLabel"
327
+ }, option.label));
328
+ })))));
329
+ }))));
330
+ };
331
+
332
+ var sizes = {
333
+ small: "60px",
334
+ medium: "240px",
335
+ large: "480px",
336
+ fillParent: "100%",
337
+ fitContent: "unset"
338
+ };
339
+
340
+ var calculateWidth = function calculateWidth(margin, size) {
341
+ if (size === "fillParent") {
342
+ return "calc(".concat(sizes[size], " - ").concat((0, _utils.getMargin)(margin, "left"), " - ").concat((0, _utils.getMargin)(margin, "right"), ")");
343
+ }
344
+
345
+ return sizes[size];
346
+ };
347
+
348
+ var DXCDropdownContainer = _styledComponents["default"].div(_templateObject(), function (props) {
349
+ return calculateWidth(props.margin, props.size);
350
+ }, function (props) {
351
+ return props.margin && (0, _typeof2["default"])(props.margin) !== "object" ? _variables.spaces[props.margin] : "0px";
352
+ }, function (props) {
353
+ return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.top ? _variables.spaces[props.margin.top] : "";
354
+ }, function (props) {
355
+ return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.right ? _variables.spaces[props.margin.right] : "";
356
+ }, function (props) {
357
+ return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.bottom ? _variables.spaces[props.margin.bottom] : "";
358
+ }, function (props) {
359
+ return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.left ? _variables.spaces[props.margin.left] : "";
360
+ });
361
+
362
+ var DXCMenu = (0, _styledComponents["default"])(_Popper["default"])(_templateObject2(), function (props) {
363
+ return calculateWidth(props.margin, props.size);
364
+ }, function (props) {
365
+ return props.theme.optionPaddingTop;
366
+ }, function (props) {
367
+ return props.theme.optionPaddingBottom;
368
+ }, function (props) {
369
+ return props.theme.optionPaddingLeft;
370
+ }, function (props) {
371
+ return props.theme.optionPaddingRight;
372
+ }, function (props) {
373
+ return "".concat(props.width, "px");
374
+ }, function (props) {
375
+ return props.theme.borderThickness;
376
+ }, function (props) {
377
+ return props.theme.borderStyle;
378
+ }, function (props) {
379
+ return props.theme.borderColor;
380
+ }, function (props) {
381
+ return props.theme.borderRadius;
382
+ }, function (props) {
383
+ return props.theme.borderRadius;
384
+ }, function (props) {
385
+ return props.theme.scrollBarTrackColor;
386
+ }, function (props) {
387
+ return props.theme.scrollBarThumbColor;
388
+ }, function (props) {
389
+ return props.optionsIconPosition === "after" && "row-reverse" || "row";
390
+ }, function (props) {
391
+ return props.optionsIconPosition === "after" && "flex-end" || "";
392
+ }, function (props) {
393
+ return props.theme.optionBackgroundColor;
394
+ }, function (props) {
395
+ return props.theme.optionFontFamily;
396
+ }, function (props) {
397
+ return props.theme.optionFontSize;
398
+ }, function (props) {
399
+ return props.theme.optionFontStyle;
400
+ }, function (props) {
401
+ return props.theme.optionFontWeight;
402
+ }, function (props) {
403
+ return props.theme.optionFontColor;
404
+ }, function (props) {
405
+ return props.theme.focusColor;
406
+ }, function (props) {
407
+ return props.theme.hoverOptionBackgroundColor;
408
+ }, function (props) {
409
+ return props.theme.activeOptionBackgroundColor;
410
+ }, function (props) {
411
+ return props.theme.focusColor;
412
+ });
413
+
414
+ var DropdownTrigger = _styledComponents["default"].button(_templateObject3(), function (props) {
415
+ return props.disabled ? "not-allowed" : "pointer";
416
+ }, function (props) {
417
+ return props.theme.buttonFontFamily;
418
+ }, function (props) {
419
+ return props.theme.buttonFontSize;
420
+ }, function (props) {
421
+ return props.theme.buttonFontStyle;
422
+ }, function (props) {
423
+ return props.theme.buttonFontWeight;
424
+ }, function (props) {
425
+ return props.theme.borderRadius;
426
+ }, function (props) {
427
+ return props.theme.borderThickness;
428
+ }, function (props) {
429
+ return props.theme.borderStyle;
430
+ }, function (props) {
431
+ return props.disabled ? props.theme.disabledBorderColor : props.theme.borderColor;
432
+ }, function (props) {
433
+ return props.label === "" ? "0px" : calculateWidth(props.margin, props.size);
434
+ }, function (props) {
435
+ return props.theme.buttonPaddingTop;
436
+ }, function (props) {
437
+ return props.theme.buttonPaddingBottom;
438
+ }, function (props) {
439
+ return props.theme.buttonPaddingLeft;
440
+ }, function (props) {
441
+ return props.theme.buttonPaddingRight;
442
+ }, function (props) {
443
+ return props.disabled ? props.theme.disabledButtonBackgroundColor : props.theme.buttonBackgroundColor;
444
+ }, function (props) {
445
+ return props.disabled ? props.theme.disabledColor : props.theme.buttonFontColor;
446
+ }, function (props) {
447
+ return props.opened ? "0px" : props.theme.borderRadius;
448
+ }, function (props) {
449
+ return props.opened ? "0px" : props.theme.borderRadius;
450
+ }, function (props) {
451
+ return !props.disabled && " \n &:focus {\n outline: none;\n }\n &:focus-visible {\n outline: ".concat(props.theme.focusColor, " solid 2px;\n outline-offset: -2px;\n }\n &:hover {\n background-color: ").concat(props.theme.hoverButtonBackgroundColor, ";\n }\n &:active {\n background-color: ").concat(props.theme.activeButtonBackgroundColor, ";\n }\n ");
452
+ });
453
+
454
+ var DropdownTriggerLabel = _styledComponents["default"].span(_templateObject4());
455
+
456
+ var DropdownTriggerContainer = _styledComponents["default"].span(_templateObject5(), function (props) {
457
+ return props.iconPosition === "after" && "row-reverse" || "row";
458
+ }, function (props) {
459
+ return props.caretHidden ? "100%" : "calc(100% - 36px)";
460
+ });
461
+
462
+ var ButtonIcon = _styledComponents["default"].img(_templateObject6(), function (props) {
463
+ return props.theme.buttonIconSize;
464
+ }, function (props) {
465
+ return props.theme.buttonIconSize;
466
+ }, function (props) {
467
+ return props.iconPosition === "after" && props.label !== "" && props.theme.buttonIconSpacing || "0px";
468
+ }, function (props) {
469
+ return props.iconPosition === "before" && props.label !== "" && props.theme.buttonIconSpacing || "0px";
470
+ });
471
+
472
+ var ButtonIconContainer = _styledComponents["default"].div(_templateObject7(), function (props) {
473
+ return props.theme.buttonIconSize;
474
+ }, function (props) {
475
+ return props.theme.buttonIconSize;
476
+ }, function (props) {
477
+ return props.iconPosition === "after" && props.label !== "" && props.theme.buttonIconSpacing || "0px";
478
+ }, function (props) {
479
+ return props.iconPosition === "before" && props.label !== "" && props.theme.buttonIconSpacing || "0px";
480
+ }, function (props) {
481
+ return props.disabled ? props.theme.disabledColor : props.theme.buttonIconColor;
482
+ });
483
+
484
+ var ListIcon = _styledComponents["default"].img(_templateObject8(), function (props) {
485
+ return props.theme.optionIconSize;
486
+ }, function (props) {
487
+ return props.theme.optionIconSize;
488
+ }, function (props) {
489
+ return props.iconPosition === "after" && props.label !== "" && props.theme.optionIconSpacing || "0px";
490
+ }, function (props) {
491
+ return props.iconPosition === "before" && props.label !== "" && props.theme.optionIconSpacing || "0px";
492
+ });
493
+
494
+ var ListIconContainer = _styledComponents["default"].div(_templateObject9(), function (props) {
495
+ return props.theme.optionIconSize;
496
+ }, function (props) {
497
+ return props.theme.optionIconSize;
498
+ }, function (props) {
499
+ return props.iconPosition === "after" && props.label !== "" && props.theme.optionIconSpacing || "0px";
500
+ }, function (props) {
501
+ return props.iconPosition === "before" && props.label !== "" && props.theme.optionIconSpacing || "0px";
502
+ }, function (props) {
503
+ return props.theme.optionIconColor;
504
+ });
505
+
506
+ var CaretIconContainer = _styledComponents["default"].div(_templateObject10(), function (props) {
507
+ return props.caretHidden ? "none" : "inline-flex";
508
+ }, function (props) {
509
+ return props.theme.caretIconSpacing;
510
+ }, function (props) {
511
+ return props.disabled ? props.theme.disabledColor : props.theme.caretIconColor;
512
+ }, function (props) {
513
+ return props.theme.caretIconSize;
514
+ }, function (props) {
515
+ return props.theme.caretIconSize;
516
+ });
517
+
518
+ DxcDropdown.propTypes = {
519
+ size: _propTypes["default"].oneOf((0, _toConsumableArray2["default"])(Object.keys(sizes))),
520
+ margin: _propTypes["default"].oneOfType([_propTypes["default"].shape({
521
+ top: _propTypes["default"].oneOf(Object.keys(_variables.spaces)),
522
+ bottom: _propTypes["default"].oneOf(Object.keys(_variables.spaces)),
523
+ left: _propTypes["default"].oneOf(Object.keys(_variables.spaces)),
524
+ right: _propTypes["default"].oneOf(Object.keys(_variables.spaces))
525
+ }), _propTypes["default"].oneOf((0, _toConsumableArray2["default"])(Object.keys(_variables.spaces)))]),
526
+ optionsIconPosition: _propTypes["default"].oneOf(["after", "before", ""]),
527
+ icon: _propTypes["default"].oneOfType([_propTypes["default"].element, _propTypes["default"].func]),
528
+ iconSrc: _propTypes["default"].string,
529
+ iconPosition: _propTypes["default"].oneOf(["after", "before", ""]),
530
+ label: _propTypes["default"].string,
531
+ caretHidden: _propTypes["default"].bool,
532
+ disabled: _propTypes["default"].bool,
533
+ expandOnHover: _propTypes["default"].bool,
534
+ onSelectOption: _propTypes["default"].func,
535
+ options: _propTypes["default"].arrayOf(_propTypes["default"].shape({
536
+ value: _propTypes["default"].any.isRequired,
537
+ label: _propTypes["default"].any.isRequired,
538
+ icon: _propTypes["default"].oneOfType([_propTypes["default"].element, _propTypes["default"].func]),
539
+ iconSrc: _propTypes["default"].string
540
+ })),
541
+ tabIndex: _propTypes["default"].number
542
+ };
543
+ var _default = DxcDropdown;
544
+ exports["default"] = _default;
@@ -0,0 +1,26 @@
1
+ type Size = "small" | "medium" | "large" | "fillParent" | "fitContent";
2
+ type Space = "xxsmall" | "xsmall" | "small" | "medium" | "large" | "xlarge" | "xxlarge";
3
+ type Margin = {
4
+ top?: Space;
5
+ bottom?: Space;
6
+ left?: Space;
7
+ right?: Space;
8
+ };
9
+
10
+ type Props = {
11
+ options?: any;
12
+ optionsIconPosition?: "before" | "after";
13
+ icon?: any;
14
+ iconSrc?: string;
15
+ iconPosition?: "before" | "after";
16
+ label?: string;
17
+ disabled?: boolean;
18
+ caretHidden?: boolean;
19
+ onSelectOption?: void;
20
+ expandOnHover?: boolean;
21
+ margin?: Space | Margin;
22
+ size?: Size;
23
+ tabIndex?: number;
24
+ };
25
+
26
+ export default function DxcDropdown(props: Props): JSX.Element;