@dxc-technology/halstack-react 0.0.0-faa7105 → 0.0.0-fb9047c

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 (288) hide show
  1. package/BackgroundColorContext.js +50 -0
  2. package/ThemeContext.js +246 -0
  3. package/V3Select/V3Select.js +455 -0
  4. package/V3Select/index.d.ts +27 -0
  5. package/V3Textarea/V3Textarea.js +260 -0
  6. package/V3Textarea/index.d.ts +27 -0
  7. package/accordion/Accordion.js +289 -0
  8. package/accordion/index.d.ts +28 -0
  9. package/accordion-group/AccordionGroup.js +184 -0
  10. package/accordion-group/index.d.ts +16 -0
  11. package/alert/Alert.js +309 -0
  12. package/alert/index.d.ts +51 -0
  13. package/badge/Badge.js +59 -0
  14. package/{dist/box → box}/Box.js +38 -34
  15. package/box/index.d.ts +25 -0
  16. package/button/Button.d.ts +4 -0
  17. package/button/Button.js +182 -0
  18. package/button/Button.stories.tsx +306 -0
  19. package/button/types.d.ts +57 -0
  20. package/button/types.js +5 -0
  21. package/card/Card.js +200 -0
  22. package/card/index.d.ts +22 -0
  23. package/checkbox/Checkbox.d.ts +4 -0
  24. package/checkbox/Checkbox.js +253 -0
  25. package/checkbox/types.d.ts +61 -0
  26. package/checkbox/types.js +5 -0
  27. package/chip/Chip.js +221 -0
  28. package/chip/index.d.ts +22 -0
  29. package/{dist/common → common}/OpenSans.css +0 -0
  30. package/{dist/common → common}/RequiredComponent.js +5 -19
  31. package/{dist/common → common}/fonts/OpenSans-Bold.ttf +0 -0
  32. package/{dist/common → common}/fonts/OpenSans-BoldItalic.ttf +0 -0
  33. package/{dist/common → common}/fonts/OpenSans-ExtraBold.ttf +0 -0
  34. package/{dist/common → common}/fonts/OpenSans-ExtraBoldItalic.ttf +0 -0
  35. package/{dist/common → common}/fonts/OpenSans-Italic.ttf +0 -0
  36. package/{dist/common → common}/fonts/OpenSans-Light.ttf +0 -0
  37. package/{dist/common → common}/fonts/OpenSans-LightItalic.ttf +0 -0
  38. package/{dist/common → common}/fonts/OpenSans-Regular.ttf +0 -0
  39. package/{dist/common → common}/fonts/OpenSans-SemiBold.ttf +0 -0
  40. package/{dist/common → common}/fonts/OpenSans-SemiBoldItalic.ttf +0 -0
  41. package/common/utils.js +22 -0
  42. package/common/variables.js +1569 -0
  43. package/{dist/date → date}/Date.js +87 -71
  44. package/date/index.d.ts +27 -0
  45. package/date-input/DateInput.js +396 -0
  46. package/date-input/index.d.ts +95 -0
  47. package/dialog/Dialog.js +184 -0
  48. package/dialog/index.d.ts +18 -0
  49. package/dropdown/Dropdown.js +450 -0
  50. package/dropdown/index.d.ts +26 -0
  51. package/file-input/FileInput.js +532 -0
  52. package/file-input/FileItem.js +193 -0
  53. package/file-input/index.d.ts +81 -0
  54. package/footer/Footer.js +297 -0
  55. package/footer/Icons.js +77 -0
  56. package/footer/index.d.ts +25 -0
  57. package/header/Header.js +326 -0
  58. package/header/Icons.js +59 -0
  59. package/header/index.d.ts +25 -0
  60. package/heading/Heading.js +176 -0
  61. package/heading/index.d.ts +17 -0
  62. package/input-text/Icons.js +22 -0
  63. package/input-text/InputText.js +611 -0
  64. package/input-text/index.d.ts +36 -0
  65. package/layout/ApplicationLayout.js +235 -0
  66. package/layout/Icons.js +55 -0
  67. package/link/Link.js +183 -0
  68. package/link/index.d.ts +23 -0
  69. package/main.d.ts +44 -0
  70. package/{dist/main.js → main.js} +143 -43
  71. package/number-input/NumberInput.js +128 -0
  72. package/{dist/ThemeContext.js → number-input/NumberInputContext.js} +3 -2
  73. package/number-input/index.d.ts +113 -0
  74. package/package.json +39 -24
  75. package/paginator/Icons.js +66 -0
  76. package/paginator/Paginator.d.ts +4 -0
  77. package/paginator/Paginator.js +198 -0
  78. package/paginator/types.d.ts +38 -0
  79. package/paginator/types.js +5 -0
  80. package/password-input/PasswordInput.js +199 -0
  81. package/password-input/index.d.ts +94 -0
  82. package/progress-bar/ProgressBar.js +188 -0
  83. package/progress-bar/index.d.ts +18 -0
  84. package/{dist/radio → radio}/Radio.js +48 -40
  85. package/radio/index.d.ts +23 -0
  86. package/resultsetTable/ResultsetTable.js +274 -0
  87. package/resultsetTable/index.d.ts +19 -0
  88. package/select/Select.js +865 -0
  89. package/select/index.d.ts +131 -0
  90. package/sidenav/Sidenav.js +145 -0
  91. package/sidenav/index.d.ts +13 -0
  92. package/slider/Slider.js +340 -0
  93. package/slider/index.d.ts +29 -0
  94. package/spinner/Spinner.js +267 -0
  95. package/spinner/index.d.ts +17 -0
  96. package/switch/Switch.js +208 -0
  97. package/switch/index.d.ts +24 -0
  98. package/table/Table.js +118 -0
  99. package/table/index.d.ts +13 -0
  100. package/tabs/Tabs.js +259 -0
  101. package/tabs/index.d.ts +19 -0
  102. package/tag/Tag.js +208 -0
  103. package/tag/index.d.ts +24 -0
  104. package/text-input/TextInput.js +825 -0
  105. package/text-input/index.d.ts +135 -0
  106. package/textarea/Textarea.js +317 -0
  107. package/textarea/index.d.ts +117 -0
  108. package/{dist/toggle → toggle}/Toggle.js +30 -67
  109. package/toggle/index.d.ts +21 -0
  110. package/toggle-group/ToggleGroup.js +243 -0
  111. package/toggle-group/index.d.ts +21 -0
  112. package/{dist/upload → upload}/Upload.js +23 -22
  113. package/upload/buttons-upload/ButtonsUpload.js +111 -0
  114. package/upload/buttons-upload/Icons.js +40 -0
  115. package/upload/dragAndDropArea/DragAndDropArea.js +225 -0
  116. package/upload/dragAndDropArea/Icons.js +39 -0
  117. package/upload/file-upload/FileToUpload.js +115 -0
  118. package/upload/file-upload/Icons.js +66 -0
  119. package/upload/files-upload/FilesToUpload.js +109 -0
  120. package/upload/index.d.ts +15 -0
  121. package/upload/transaction/Icons.js +160 -0
  122. package/upload/transaction/Transaction.js +104 -0
  123. package/upload/transactions/Transactions.js +94 -0
  124. package/useTheme.js +22 -0
  125. package/wizard/Icons.js +65 -0
  126. package/wizard/Wizard.js +271 -0
  127. package/wizard/index.d.ts +18 -0
  128. package/README.md +0 -66
  129. package/babel.config.js +0 -4
  130. package/dist/accordion/Accordion.js +0 -242
  131. package/dist/accordion/Accordion.stories.js +0 -207
  132. package/dist/accordion/readme.md +0 -96
  133. package/dist/alert/Alert.js +0 -304
  134. package/dist/alert/Alert.stories.js +0 -158
  135. package/dist/alert/close.svg +0 -4
  136. package/dist/alert/error.svg +0 -4
  137. package/dist/alert/info.svg +0 -4
  138. package/dist/alert/readme.md +0 -43
  139. package/dist/alert/success.svg +0 -4
  140. package/dist/alert/warning.svg +0 -4
  141. package/dist/button/Button.js +0 -181
  142. package/dist/button/Button.stories.js +0 -224
  143. package/dist/button/readme.md +0 -93
  144. package/dist/card/Card.js +0 -217
  145. package/dist/checkbox/Checkbox.js +0 -224
  146. package/dist/checkbox/Checkbox.stories.js +0 -144
  147. package/dist/checkbox/readme.md +0 -116
  148. package/dist/chip/Chip.js +0 -173
  149. package/dist/common/services/example-service.js +0 -10
  150. package/dist/common/services/example-service.test.js +0 -12
  151. package/dist/common/utils.js +0 -42
  152. package/dist/common/variables.js +0 -400
  153. package/dist/date/Date.stories.js +0 -205
  154. package/dist/date/calendar.svg +0 -1
  155. package/dist/date/calendar_dark.svg +0 -1
  156. package/dist/date/readme.md +0 -73
  157. package/dist/dialog/Dialog.js +0 -197
  158. package/dist/dialog/Dialog.stories.js +0 -217
  159. package/dist/dialog/readme.md +0 -32
  160. package/dist/dropdown/Dropdown.js +0 -424
  161. package/dist/dropdown/Dropdown.stories.js +0 -249
  162. package/dist/dropdown/baseline-arrow_drop_down.svg +0 -1
  163. package/dist/dropdown/baseline-arrow_drop_down_wh.svg +0 -4
  164. package/dist/dropdown/baseline-arrow_drop_up.svg +0 -1
  165. package/dist/dropdown/baseline-arrow_drop_up_wh.svg +0 -4
  166. package/dist/dropdown/readme.md +0 -69
  167. package/dist/footer/Footer.js +0 -346
  168. package/dist/footer/Footer.stories.js +0 -94
  169. package/dist/footer/dxc_logo_wht.png +0 -0
  170. package/dist/footer/readme.md +0 -41
  171. package/dist/header/Header.js +0 -372
  172. package/dist/header/Header.stories.js +0 -176
  173. package/dist/header/close_icon.svg +0 -1
  174. package/dist/header/dxc_logo_black.png +0 -0
  175. package/dist/header/dxc_logo_white.png +0 -0
  176. package/dist/header/hamb_menu_black.svg +0 -1
  177. package/dist/header/hamb_menu_white.svg +0 -1
  178. package/dist/header/readme.md +0 -33
  179. package/dist/heading/Heading.js +0 -153
  180. package/dist/input-text/InputText.js +0 -519
  181. package/dist/input-text/InputText.stories.js +0 -209
  182. package/dist/input-text/error.svg +0 -1
  183. package/dist/input-text/readme.md +0 -91
  184. package/dist/link/Link.js +0 -136
  185. package/dist/link/readme.md +0 -51
  186. package/dist/paginator/Paginator.js +0 -196
  187. package/dist/paginator/images/next.svg +0 -3
  188. package/dist/paginator/images/nextPage.svg +0 -3
  189. package/dist/paginator/images/previous.svg +0 -3
  190. package/dist/paginator/images/previousPage.svg +0 -3
  191. package/dist/paginator/readme.md +0 -50
  192. package/dist/progress-bar/ProgressBar.js +0 -185
  193. package/dist/progress-bar/ProgressBar.stories.js +0 -280
  194. package/dist/progress-bar/readme.md +0 -63
  195. package/dist/radio/Radio.stories.js +0 -166
  196. package/dist/radio/readme.md +0 -70
  197. package/dist/resultsetTable/ResultsetTable.js +0 -333
  198. package/dist/resultsetTable/arrow_downward-24px_wht.svg +0 -1
  199. package/dist/resultsetTable/arrow_upward-24px_wht.svg +0 -1
  200. package/dist/resultsetTable/unfold_more-24px_wht.svg +0 -1
  201. package/dist/select/Select.js +0 -445
  202. package/dist/select/Select.stories.js +0 -235
  203. package/dist/select/readme.md +0 -72
  204. package/dist/sidenav/Sidenav.js +0 -236
  205. package/dist/sidenav/arrow_icon.svg +0 -3
  206. package/dist/slider/Slider.js +0 -258
  207. package/dist/slider/Slider.stories.js +0 -241
  208. package/dist/slider/readme.md +0 -64
  209. package/dist/spinner/Spinner.js +0 -193
  210. package/dist/spinner/Spinner.stories.js +0 -183
  211. package/dist/spinner/readme.md +0 -65
  212. package/dist/switch/Switch.js +0 -199
  213. package/dist/switch/Switch.stories.js +0 -134
  214. package/dist/switch/readme.md +0 -133
  215. package/dist/table/Table.js +0 -87
  216. package/dist/tabs/Tabs.js +0 -172
  217. package/dist/tabs/Tabs.stories.js +0 -130
  218. package/dist/tabs/readme.md +0 -78
  219. package/dist/tabs-for-sections/TabsForSections.js +0 -107
  220. package/dist/tabs-for-sections/readme.md +0 -78
  221. package/dist/tag/Tag.js +0 -217
  222. package/dist/textarea/Textarea.js +0 -227
  223. package/dist/toggle/Toggle.stories.js +0 -297
  224. package/dist/toggle/readme.md +0 -80
  225. package/dist/upload/Upload.stories.js +0 -72
  226. package/dist/upload/buttons-upload/ButtonsUpload.js +0 -122
  227. package/dist/upload/buttons-upload/drag-drop-icon.svg +0 -4
  228. package/dist/upload/buttons-upload/upload-button.svg +0 -1
  229. package/dist/upload/dragAndDropArea/DragAndDropArea.js +0 -279
  230. package/dist/upload/dragAndDropArea/upload_drop.svg +0 -4
  231. package/dist/upload/dragAndDropArea/upload_file.svg +0 -4
  232. package/dist/upload/file-upload/FileToUpload.js +0 -158
  233. package/dist/upload/file-upload/audio-icon.svg +0 -4
  234. package/dist/upload/file-upload/close.svg +0 -4
  235. package/dist/upload/file-upload/file-icon.svg +0 -4
  236. package/dist/upload/file-upload/video-icon.svg +0 -4
  237. package/dist/upload/files-upload/FilesToUpload.js +0 -123
  238. package/dist/upload/readme.md +0 -37
  239. package/dist/upload/transaction/Transaction.js +0 -155
  240. package/dist/upload/transaction/audio-icon-err.svg +0 -4
  241. package/dist/upload/transaction/audio-icon.svg +0 -4
  242. package/dist/upload/transaction/error-icon.svg +0 -4
  243. package/dist/upload/transaction/file-icon-err.svg +0 -4
  244. package/dist/upload/transaction/file-icon.svg +0 -4
  245. package/dist/upload/transaction/image-icon-err.svg +0 -4
  246. package/dist/upload/transaction/image-icon.svg +0 -4
  247. package/dist/upload/transaction/success-icon.svg +0 -4
  248. package/dist/upload/transaction/video-icon-err.svg +0 -4
  249. package/dist/upload/transaction/video-icon.svg +0 -4
  250. package/dist/upload/transactions/Transactions.js +0 -120
  251. package/dist/wizard/Wizard.js +0 -327
  252. package/dist/wizard/invalid_icon.svg +0 -6
  253. package/dist/wizard/valid_icon.svg +0 -6
  254. package/dist/wizard/validation-wrong.svg +0 -6
  255. package/test/Accordion.test.js +0 -33
  256. package/test/Alert.test.js +0 -53
  257. package/test/Box.test.js +0 -10
  258. package/test/Button.test.js +0 -18
  259. package/test/Card.test.js +0 -30
  260. package/test/Checkbox.test.js +0 -45
  261. package/test/Chip.test.js +0 -25
  262. package/test/Date.test.js +0 -393
  263. package/test/Dialog.test.js +0 -23
  264. package/test/Dropdown.test.js +0 -130
  265. package/test/Footer.test.js +0 -99
  266. package/test/Header.test.js +0 -39
  267. package/test/Heading.test.js +0 -35
  268. package/test/InputText.test.js +0 -236
  269. package/test/Link.test.js +0 -25
  270. package/test/Paginator.test.js +0 -165
  271. package/test/ProgressBar.test.js +0 -35
  272. package/test/Radio.test.js +0 -37
  273. package/test/ResultsetTable.test.js +0 -282
  274. package/test/Select.test.js +0 -191
  275. package/test/Sidenav.test.js +0 -87
  276. package/test/Slider.test.js +0 -65
  277. package/test/Spinner.test.js +0 -27
  278. package/test/Switch.test.js +0 -45
  279. package/test/Table.test.js +0 -36
  280. package/test/Tabs.test.js +0 -88
  281. package/test/TabsForSections.test.js +0 -34
  282. package/test/Tag.test.js +0 -32
  283. package/test/TextArea.test.js +0 -52
  284. package/test/Toggle.test.js +0 -43
  285. package/test/Upload.test.js +0 -60
  286. package/test/Wizard.test.js +0 -130
  287. package/test/mocks/pngMock.js +0 -1
  288. package/test/mocks/svgMock.js +0 -1
@@ -1,424 +0,0 @@
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 _typeof2 = _interopRequireDefault(require("@babel/runtime/helpers/typeof"));
15
-
16
- var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
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 _baselineArrow_drop_up = _interopRequireDefault(require("./baseline-arrow_drop_up.svg"));
39
-
40
- var _baselineArrow_drop_down = _interopRequireDefault(require("./baseline-arrow_drop_down.svg"));
41
-
42
- require("../common/OpenSans.css");
43
-
44
- var _variables = require("../common/variables.js");
45
-
46
- var _utils = require("../common/utils.js");
47
-
48
- var _ThemeContext = _interopRequireDefault(require("../ThemeContext.js"));
49
-
50
- function _templateObject7() {
51
- var data = (0, _taggedTemplateLiteral2["default"])(["\n display: ", ";\n margin-left: 10px;\n margin-right: 10px;\n"]);
52
-
53
- _templateObject7 = function _templateObject7() {
54
- return data;
55
- };
56
-
57
- return data;
58
- }
59
-
60
- function _templateObject6() {
61
- var data = (0, _taggedTemplateLiteral2["default"])(["\n max-height: 20px;\n max-width: 20px;\n width: 20px;\n height: 20px;\n margin-right: ", ";\n margin-left: ", ";\n"]);
62
-
63
- _templateObject6 = function _templateObject6() {
64
- return data;
65
- };
66
-
67
- return data;
68
- }
69
-
70
- function _templateObject5() {
71
- 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"]);
72
-
73
- _templateObject5 = function _templateObject5() {
74
- return data;
75
- };
76
-
77
- return data;
78
- }
79
-
80
- function _templateObject4() {
81
- var data = (0, _taggedTemplateLiteral2["default"])(["\n text-align: left;\n text-overflow: ellipsis;\n overflow: hidden;\n"]);
82
-
83
- _templateObject4 = function _templateObject4() {
84
- return data;
85
- };
86
-
87
- return data;
88
- }
89
-
90
- function _templateObject3() {
91
- var data = (0, _taggedTemplateLiteral2["default"])(["\n cursor: pointer;\n font-family: \"Open Sans\", sans-serif;\n font-size: 16px;\n width: 100%;\n height: auto;\n min-height: 46px;\n display: inline-flex;\n justify-content: space-between;\n align-items: center;\n min-width: ", ";\n\n padding: ", ";\n &:focus {\n outline: none;\n }\n\n background-color: ", ";\n\n color: ", ";\n\n border: none;\n border-radius: 2px;\n border-bottom-right-radius: ", ";\n border-bottom-left-radius: ", ";\n &:hover {\n background-color: ", ";\n }\n"]);
92
-
93
- _templateObject3 = function _templateObject3() {
94
- return data;
95
- };
96
-
97
- return data;
98
- }
99
-
100
- function _templateObject2() {
101
- var data = (0, _taggedTemplateLiteral2["default"])(["\n z-index: 1;\n\n .MuiMenuItem-gutters {\n width: ", ";\n }\n .MuiMenuItem-root {\n min-height: 46px;\n height: auto;\n }\n\n .MuiPaper-root {\n min-width: ", ";\n\n background-color: ", ";\n\n color: ", ";\n\n border-bottom-left-radius: 2px;\n border-bottom-right-radius: 2px;\n border-top-left-radius: 0px;\n border-top-right-radius: 0px;\n max-height: 230px;\n overflow: auto;\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 font-size: 16px;\n font-family: \"Open Sans\", sans-serif;\n cursor: pointer;\n }\n .MuiListItem-button:hover {\n background-color: ", ";\n color: ", ";\n }\n\n ::-webkit-scrollbar {\n width: 3px;\n }\n\n ::-webkit-scrollbar-track {\n background-color: ", ";\n border-radius: 3px;\n }\n\n ::-webkit-scrollbar-thumb {\n background-color: ", ";\n border-radius: 3px;\n }\n }\n"]);
102
-
103
- _templateObject2 = function _templateObject2() {
104
- return data;
105
- };
106
-
107
- return data;
108
- }
109
-
110
- function _templateObject() {
111
- 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\n &:focus {\n outline: ", " auto 1px;\n }\n"]);
112
-
113
- _templateObject = function _templateObject() {
114
- return data;
115
- };
116
-
117
- return data;
118
- }
119
-
120
- var DxcDropdown = function DxcDropdown(_ref) {
121
- var _ref$options = _ref.options,
122
- options = _ref$options === void 0 ? [] : _ref$options,
123
- _ref$optionsIconPosit = _ref.optionsIconPosition,
124
- optionsIconPosition = _ref$optionsIconPosit === void 0 ? "before" : _ref$optionsIconPosit,
125
- _ref$iconSrc = _ref.iconSrc,
126
- iconSrc = _ref$iconSrc === void 0 ? "" : _ref$iconSrc,
127
- _ref$iconPosition = _ref.iconPosition,
128
- iconPosition = _ref$iconPosition === void 0 ? "before" : _ref$iconPosition,
129
- _ref$label = _ref.label,
130
- label = _ref$label === void 0 ? "" : _ref$label,
131
- _ref$caretHidden = _ref.caretHidden,
132
- caretHidden = _ref$caretHidden === void 0 ? false : _ref$caretHidden,
133
- onSelectOption = _ref.onSelectOption,
134
- margin = _ref.margin,
135
- _ref$size = _ref.size,
136
- size = _ref$size === void 0 ? "fitContent" : _ref$size,
137
- _ref$expandOnHover = _ref.expandOnHover,
138
- expandOnHover = _ref$expandOnHover === void 0 ? false : _ref$expandOnHover;
139
-
140
- var _useState = (0, _react.useState)(),
141
- _useState2 = (0, _slicedToArray2["default"])(_useState, 2),
142
- width = _useState2[0],
143
- setWidth = _useState2[1];
144
-
145
- var customTheme = (0, _react.useContext)(_ThemeContext["default"]);
146
- var colorsTheme = (0, _react.useMemo)(function () {
147
- return (0, _utils.getCustomTheme)(_variables.theme, (0, _utils.getCustomTheme)(_variables.defaultTheme, customTheme));
148
- }, [customTheme]);
149
- var ref = (0, _react.useRef)(null);
150
-
151
- var handleResize = function handleResize() {
152
- setWidth(ref.current.offsetWidth);
153
- };
154
-
155
- (0, _react.useEffect)(function () {
156
- if (ref.current) ref.current.addEventListener("resize", handleResize);
157
- handleResize();
158
- return function () {
159
- ref.current.removeEventListener("resize", handleResize);
160
- };
161
- }, []);
162
-
163
- var _useState3 = (0, _react.useState)(null),
164
- _useState4 = (0, _slicedToArray2["default"])(_useState3, 2),
165
- anchorEl = _useState4[0],
166
- setAnchorEl = _useState4[1];
167
-
168
- function handleClickListItem(event) {
169
- setAnchorEl(event.currentTarget);
170
- }
171
-
172
- function handleMenuItemClick(option) {
173
- setAnchorEl(null);
174
-
175
- if (typeof onSelectOption === "function") {
176
- onSelectOption(option.value);
177
- }
178
- }
179
-
180
- function handleClose() {
181
- setAnchorEl(null);
182
- }
183
-
184
- var handleCloseOver = expandOnHover ? handleClose : undefined;
185
-
186
- var UpArrowIcon = function UpArrowIcon(_ref2) {
187
- var fill = _ref2.fill;
188
- return _react["default"].createElement("svg", {
189
- xmlns: "http://www.w3.org/2000/svg",
190
- width: "24",
191
- height: "24",
192
- viewBox: "0 0 24 24"
193
- }, _react["default"].createElement("path", {
194
- d: "M7 14l5-5 5 5z",
195
- fill: fill
196
- }), _react["default"].createElement("path", {
197
- d: "M0 0h24v24H0z",
198
- fill: "none"
199
- }));
200
- };
201
-
202
- var DownArrowIcon = function DownArrowIcon(_ref3) {
203
- var fill = _ref3.fill;
204
- return _react["default"].createElement("svg", {
205
- xmlns: "http://www.w3.org/2000/svg",
206
- width: "24",
207
- height: "24",
208
- viewBox: "0 0 24 24"
209
- }, _react["default"].createElement("path", {
210
- d: "M7 10l5 5 5-5z",
211
- fill: fill
212
- }), _react["default"].createElement("path", {
213
- d: "M0 0h24v24H0z",
214
- fill: "none"
215
- }));
216
- };
217
-
218
- return _react["default"].createElement(_styledComponents.ThemeProvider, {
219
- theme: colorsTheme.dropdown
220
- }, _react["default"].createElement(DxCDropdownContainer, {
221
- margin: margin,
222
- size: size,
223
- tabIndex: "0"
224
- }, _react["default"].createElement("div", {
225
- onMouseOver: expandOnHover ? handleClickListItem : undefined,
226
- onMouseOut: handleCloseOver,
227
- onFocus: handleCloseOver,
228
- onBlur: handleCloseOver
229
- }, _react["default"].createElement(DropdownTrigger, {
230
- opened: anchorEl === null ? false : true,
231
- onClick: handleClickListItem,
232
- label: label,
233
- caretHidden: caretHidden,
234
- margin: margin,
235
- size: size,
236
- ref: ref
237
- }, _react["default"].createElement(DropdownTriggerContainer, {
238
- iconPosition: iconPosition,
239
- caretHidden: caretHidden
240
- }, iconSrc && _react["default"].createElement(ListIcon, {
241
- label: label,
242
- src: iconSrc,
243
- iconPosition: iconPosition
244
- }), _react["default"].createElement(DropdownTriggerLabel, {
245
- iconPosition: iconPosition,
246
- label: label
247
- }, label)), _react["default"].createElement(CaretIcon, null, anchorEl === null ? _react["default"].createElement(DownArrowIcon, {
248
- caretHidden: caretHidden,
249
- margin: margin,
250
- fill: _variables.theme.dropdown.fontColor
251
- }) : _react["default"].createElement(UpArrowIcon, {
252
- caretHidden: caretHidden,
253
- margin: margin,
254
- fill: _variables.theme.dropdown.fontColor
255
- }))), _react["default"].createElement(DxcMenu, {
256
- anchorEl: anchorEl,
257
- open: Boolean(anchorEl),
258
- onClose: handleClose,
259
- getContentAnchorEl: null,
260
- anchorOrigin: {
261
- vertical: "bottom",
262
- horizontal: "left"
263
- },
264
- transformOrigin: {
265
- vertical: "top",
266
- horizontal: "left"
267
- },
268
- optionsIconPosition: optionsIconPosition,
269
- size: size,
270
- width: width,
271
- role: undefined,
272
- transition: true,
273
- disablePortal: true,
274
- placement: "bottom-start"
275
- }, function (_ref4) {
276
- var TransitionProps = _ref4.TransitionProps;
277
- return _react["default"].createElement(_Grow["default"], TransitionProps, _react["default"].createElement(_Paper["default"], null, _react["default"].createElement(_core.ClickAwayListener, {
278
- onClickAway: handleClose
279
- }, _react["default"].createElement(_MenuList["default"], {
280
- autoFocusItem: Boolean(anchorEl),
281
- id: "menu-list-grow",
282
- onKeyDown: handleClose
283
- }, options.map(function (option) {
284
- return _react["default"].createElement(_MenuItem["default"], {
285
- key: option.value,
286
- value: option.value,
287
- disableRipple: true,
288
- onClick: function onClick(event) {
289
- return handleMenuItemClick(option);
290
- }
291
- }, option.iconSrc && _react["default"].createElement(ListIcon, {
292
- label: option.label,
293
- src: option.iconSrc,
294
- iconPosition: optionsIconPosition
295
- }), _react["default"].createElement("span", {
296
- className: "optionLabel"
297
- }, option.label));
298
- })))));
299
- }))));
300
- };
301
-
302
- var sizes = {
303
- small: "60px",
304
- medium: "240px",
305
- large: "480px",
306
- fillParent: "100%",
307
- fitContent: "unset"
308
- };
309
-
310
- var calculateWidth = function calculateWidth(margin, size) {
311
- if (size === "fillParent") {
312
- return "calc(".concat(sizes[size], " - ").concat((0, _utils.getMargin)(margin, "left"), " - ").concat((0, _utils.getMargin)(margin, "right"), ")");
313
- }
314
-
315
- return sizes[size];
316
- };
317
-
318
- var DxCDropdownContainer = _styledComponents["default"].div(_templateObject(), function (props) {
319
- return calculateWidth(props.margin, props.size);
320
- }, function (props) {
321
- return props.margin && (0, _typeof2["default"])(props.margin) !== "object" ? _variables.spaces[props.margin] : "0px";
322
- }, function (props) {
323
- return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.top ? _variables.spaces[props.margin.top] : "";
324
- }, function (props) {
325
- return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.right ? _variables.spaces[props.margin.right] : "";
326
- }, function (props) {
327
- return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.bottom ? _variables.spaces[props.margin.bottom] : "";
328
- }, function (props) {
329
- return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.left ? _variables.spaces[props.margin.left] : "";
330
- }, function (props) {
331
- return props.theme.focusColor;
332
- });
333
-
334
- var DxcMenu = (0, _styledComponents["default"])(_Popper["default"])(_templateObject2(), function (props) {
335
- return calculateWidth(props.margin, props.size);
336
- }, function (props) {
337
- return "".concat(props.width, "px");
338
- }, function (props) {
339
- return props.theme.dropdownBackgroundColor;
340
- }, function (props) {
341
- return props.theme.dropdownFontColor;
342
- }, function (props) {
343
- return props.optionsIconPosition === "after" && "row-reverse" || "row";
344
- }, function (props) {
345
- return props.optionsIconPosition === "after" && "flex-end" || "";
346
- }, function (props) {
347
- return props.theme.backgroundColor + props.theme.hoverBackgroundOption;
348
- }, function (props) {
349
- return props.theme.dropdownFontColor;
350
- }, function (props) {
351
- return props.theme.scrollBarTrackColor;
352
- }, function (props) {
353
- return props.theme.scrollBarThumbColor;
354
- });
355
-
356
- var DropdownTrigger = _styledComponents["default"].button(_templateObject3(), function (props) {
357
- return props.label === "" ? "0px" : calculateWidth(props.margin, props.size);
358
- }, function (props) {
359
- if (props.caretHidden === true && props.label === "") {
360
- return "10px 15px";
361
- } else {
362
- return "10px 15px 10px 20px";
363
- }
364
- }, function (props) {
365
- return props.opened === true ? props.theme.backgroundColor + props.theme.hoverBackgroundColor : props.theme.backgroundColor;
366
- }, function (props) {
367
- return props.theme.fontColor;
368
- }, function (props) {
369
- return props.opened === true ? "0px" : "2px";
370
- }, function (props) {
371
- return props.opened === true ? "0px" : "2px";
372
- }, function (props) {
373
- return props.theme.backgroundColor + props.theme.hoverBackgroundColor;
374
- });
375
-
376
- var DropdownTriggerLabel = _styledComponents["default"].span(_templateObject4());
377
-
378
- var DropdownTriggerContainer = _styledComponents["default"].span(_templateObject5(), function (props) {
379
- return props.iconPosition === "after" && "row-reverse" || "row";
380
- }, function (props) {
381
- return props.caretHidden ? "100%" : "calc(100% - 44px)";
382
- });
383
-
384
- var ListIcon = _styledComponents["default"].img(_templateObject6(), function (props) {
385
- if (props.iconPosition === "before" && props.label !== "") {
386
- return "10px";
387
- } else {
388
- return "0px";
389
- }
390
- }, function (props) {
391
- if (props.iconPosition === "after" && props.label !== "") {
392
- return "10px";
393
- } else {
394
- return "0px";
395
- }
396
- });
397
-
398
- var CaretIcon = _styledComponents["default"].div(_templateObject7(), function (props) {
399
- return props.caretHidden === true ? "none" : "block";
400
- });
401
-
402
- DxcDropdown.propTypes = {
403
- size: _propTypes["default"].oneOf((0, _toConsumableArray2["default"])(Object.keys(sizes))),
404
- margin: _propTypes["default"].oneOfType([_propTypes["default"].shape({
405
- top: _propTypes["default"].oneOf(Object.keys(_variables.spaces)),
406
- bottom: _propTypes["default"].oneOf(Object.keys(_variables.spaces)),
407
- left: _propTypes["default"].oneOf(Object.keys(_variables.spaces)),
408
- right: _propTypes["default"].oneOf(Object.keys(_variables.spaces))
409
- }), _propTypes["default"].oneOf((0, _toConsumableArray2["default"])(Object.keys(_variables.spaces)))]),
410
- optionsIconPosition: _propTypes["default"].oneOf(["after", "before", ""]),
411
- iconSrc: _propTypes["default"].string,
412
- iconPosition: _propTypes["default"].oneOf(["after", "before", ""]),
413
- label: _propTypes["default"].string,
414
- caretHidden: _propTypes["default"].bool,
415
- expandOnHover: _propTypes["default"].bool,
416
- onSelectOption: _propTypes["default"].func,
417
- options: _propTypes["default"].arrayOf(_propTypes["default"].shape({
418
- value: _propTypes["default"].any.isRequired,
419
- label: _propTypes["default"].any.isRequired,
420
- iconSrc: _propTypes["default"].string
421
- }))
422
- };
423
- var _default = DxcDropdown;
424
- exports["default"] = _default;
@@ -1,249 +0,0 @@
1
- "use strict";
2
-
3
- var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
-
5
- var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
6
-
7
- var _react = _interopRequireDefault(require("react"));
8
-
9
- var _react2 = require("@storybook/react");
10
-
11
- var _addonActions = require("@storybook/addon-actions");
12
-
13
- var _amazon = _interopRequireDefault(require("../../.storybook/public/amazon.svg"));
14
-
15
- var _addonKnobs = require("@storybook/addon-knobs");
16
-
17
- var _readme = _interopRequireDefault(require("./readme.md"));
18
-
19
- var _Dropdown = _interopRequireDefault(require("./Dropdown"));
20
-
21
- var onChange = (0, _addonActions.action)("onChange");
22
-
23
- onChange.toString = function () {
24
- return "onChangeHandler";
25
- };
26
-
27
- var optionsWithoutIcon = [{
28
- value: 1,
29
- label: "Amazon"
30
- }, {
31
- value: 2,
32
- label: "Ebay"
33
- }, {
34
- value: 3,
35
- label: "Apple"
36
- }];
37
- var optionsWithIcon = [{
38
- value: 1,
39
- label: "Amazon",
40
- iconSrc: _amazon["default"]
41
- }, {
42
- value: 2,
43
- label: "Ebay",
44
- iconSrc: _amazon["default"]
45
- }, {
46
- value: 3,
47
- label: "Apple",
48
- iconSrc: _amazon["default"]
49
- }];
50
-
51
- var selectOption = function selectOption(option) {
52
- console.log(option);
53
- };
54
-
55
- (0, _react2.storiesOf)("Form Components|Dropdown", module).add("Component", function () {
56
- return _react["default"].createElement("div", null, _react["default"].createElement("div", {
57
- style: {
58
- height: "200px",
59
- display: "flex",
60
- flexWrap: "wrap"
61
- }
62
- }, _react["default"].createElement(_Dropdown["default"], {
63
- options: optionsWithoutIcon,
64
- onSelectOption: selectOption,
65
- iconSrc: _amazon["default"],
66
- label: "Basic dropdown",
67
- theme: "light",
68
- mode: "basic",
69
- optionsIconPosition: "before"
70
- }), _react["default"].createElement(_Dropdown["default"], {
71
- options: optionsWithIcon,
72
- onSelectOption: selectOption,
73
- iconSrc: _amazon["default"],
74
- label: "Outlined dropdown",
75
- theme: "light",
76
- mode: "outlined",
77
- optionsIconPosition: "after"
78
- }), _react["default"].createElement(_Dropdown["default"], {
79
- options: optionsWithoutIcon,
80
- onSelectOption: selectOption,
81
- label: "Basic dropdown",
82
- theme: "light",
83
- mode: "basic",
84
- optionsIconPosition: "before"
85
- }), _react["default"].createElement(_Dropdown["default"], {
86
- options: optionsWithoutIcon,
87
- onSelectOption: selectOption,
88
- label: "Outlined dropdown",
89
- theme: "light",
90
- mode: "outlined",
91
- optionsIconPosition: "after"
92
- }), _react["default"].createElement(_Dropdown["default"], {
93
- options: optionsWithIcon,
94
- onSelectOption: selectOption,
95
- iconSrc: _amazon["default"],
96
- label: "",
97
- theme: "light",
98
- mode: "basic",
99
- caretHidden: true,
100
- optionsIconPosition: "before"
101
- }), _react["default"].createElement(_Dropdown["default"], {
102
- options: optionsWithIcon,
103
- onSelectOption: selectOption,
104
- iconSrc: _amazon["default"],
105
- label: "",
106
- theme: "light",
107
- mode: "outlined",
108
- caretHidden: true,
109
- optionsIconPosition: "after"
110
- }), _react["default"].createElement(_Dropdown["default"], {
111
- options: optionsWithIcon,
112
- onSelectOption: selectOption,
113
- iconSrc: _amazon["default"],
114
- label: "",
115
- theme: "light",
116
- mode: "basic",
117
- caretHidden: false,
118
- optionsIconPosition: "before"
119
- }), _react["default"].createElement(_Dropdown["default"], {
120
- options: optionsWithIcon,
121
- onSelectOption: selectOption,
122
- iconSrc: _amazon["default"],
123
- label: "",
124
- theme: "light",
125
- mode: "outlined",
126
- caretHidden: false,
127
- optionsIconPosition: "after"
128
- })), _react["default"].createElement("div", {
129
- style: {
130
- background: "black",
131
- display: "flex",
132
- height: "250px",
133
- flexWrap: "wrap"
134
- }
135
- }, _react["default"].createElement(_Dropdown["default"], {
136
- options: optionsWithIcon,
137
- onSelectOption: selectOption,
138
- iconSrc: _amazon["default"],
139
- label: "Basic dropdown",
140
- theme: "dark",
141
- mode: "basic",
142
- optionsIconPosition: "before"
143
- }), _react["default"].createElement(_Dropdown["default"], {
144
- options: optionsWithIcon,
145
- onSelectOption: selectOption,
146
- iconSrc: _amazon["default"],
147
- label: "Outlined dropdown",
148
- theme: "dark",
149
- mode: "outlined",
150
- optionsIconPosition: "after"
151
- }), _react["default"].createElement(_Dropdown["default"], {
152
- options: optionsWithoutIcon,
153
- onSelectOption: selectOption,
154
- label: "Basic dropdown",
155
- theme: "dark",
156
- mode: "basic",
157
- optionsIconPosition: "before"
158
- }), _react["default"].createElement(_Dropdown["default"], {
159
- options: optionsWithoutIcon,
160
- onSelectOption: selectOption,
161
- label: "Outlined dropdown",
162
- theme: "dark",
163
- mode: "outlined",
164
- optionsIconPosition: "after"
165
- }), _react["default"].createElement(_Dropdown["default"], {
166
- options: optionsWithIcon,
167
- onSelectOption: selectOption,
168
- iconSrc: _amazon["default"],
169
- label: "",
170
- theme: "dark",
171
- mode: "basic",
172
- caretHidden: true,
173
- optionsIconPosition: "before"
174
- }), _react["default"].createElement(_Dropdown["default"], {
175
- options: optionsWithIcon,
176
- onSelectOption: selectOption,
177
- iconSrc: _amazon["default"],
178
- label: "",
179
- theme: "dark",
180
- mode: "outlined",
181
- caretHidden: true,
182
- optionsIconPosition: "after"
183
- }), _react["default"].createElement(_Dropdown["default"], {
184
- options: optionsWithIcon,
185
- onSelectOption: selectOption,
186
- iconSrc: _amazon["default"],
187
- label: "",
188
- theme: "dark",
189
- mode: "basic",
190
- caretHidden: false,
191
- optionsIconPosition: "before"
192
- }), _react["default"].createElement(_Dropdown["default"], {
193
- options: optionsWithIcon,
194
- onSelectOption: selectOption,
195
- iconSrc: _amazon["default"],
196
- label: "",
197
- theme: "dark",
198
- mode: "outlined",
199
- caretHidden: false,
200
- optionsIconPosition: "after"
201
- })));
202
- }, {
203
- notes: {
204
- markdown: _readme["default"]
205
- }
206
- });
207
-
208
- var knobProps = function knobProps() {
209
- return {
210
- optionsIconPosition: (0, _addonKnobs.select)("Options Icon Position", {
211
- before: "before",
212
- after: "after"
213
- }, "before"),
214
- iconPosition: (0, _addonKnobs.select)("Icon Position", {
215
- before: "before",
216
- after: "after"
217
- }, "before"),
218
- label: (0, _addonKnobs.text)("Label", "Test Dropdown"),
219
- theme: (0, _addonKnobs.select)("Theme", {
220
- light: "light",
221
- dark: "dark"
222
- }, "light"),
223
- mode: (0, _addonKnobs.select)("Mode", {
224
- basic: "basic",
225
- outlined: "outlined"
226
- }, "basic"),
227
- caretHidden: (0, _addonKnobs["boolean"])("Caret Hidden", false),
228
- disableRipple: (0, _addonKnobs["boolean"])("Disable Ripple", false)
229
- };
230
- };
231
-
232
- (0, _react2.storiesOf)("Form Components|Dropdown", module).add("Knobs example", function () {
233
- var props = knobProps();
234
- return _react["default"].createElement("div", {
235
- style: {
236
- paddingTop: "20px",
237
- height: "200px",
238
- background: props.theme === "dark" && "black" || "transparent"
239
- }
240
- }, _react["default"].createElement(_Dropdown["default"], (0, _extends2["default"])({}, props, {
241
- iconSrc: _amazon["default"],
242
- options: optionsWithIcon,
243
- onSelectOption: selectOption
244
- })));
245
- }, {
246
- notes: {
247
- markdown: _readme["default"]
248
- }
249
- });
@@ -1 +0,0 @@
1
- <svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24"><path d="M7 10l5 5 5-5z"/><path d="M0 0h24v24H0z" fill="none"/></svg>
@@ -1,4 +0,0 @@
1
- <svg id="baseline-arrow_drop_down-24px" xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24">
2
- <path id="Trazado_2384" data-name="Trazado 2384" d="M7,10l5,5,5-5Z" fill="#fff"/>
3
- <path id="Trazado_2385" data-name="Trazado 2385" d="M0,0H24V24H0Z" fill="none"/>
4
- </svg>
@@ -1 +0,0 @@
1
- <svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24"><path d="M7 14l5-5 5 5z"/><path d="M0 0h24v24H0z" fill="none"/></svg>
@@ -1,4 +0,0 @@
1
- <svg id="baseline-arrow_drop_up-24px" xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24">
2
- <path id="Trazado_2386" data-name="Trazado 2386" d="M7,14l5-5,5,5Z" fill="#fff"/>
3
- <path id="Trazado_2387" data-name="Trazado 2387" d="M0,0H24V24H0Z" fill="none"/>
4
- </svg>