@dxc-technology/halstack-react 0.0.0-fa60fbe → 0.0.0-fb2efcc

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 (284) 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 +42 -26
  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.js +275 -0
  24. package/checkbox/index.d.ts +24 -0
  25. package/chip/Chip.js +221 -0
  26. package/chip/index.d.ts +22 -0
  27. package/{dist/common → common}/OpenSans.css +0 -0
  28. package/{dist/common → common}/RequiredComponent.js +5 -19
  29. package/{dist/common → common}/fonts/OpenSans-Bold.ttf +0 -0
  30. package/{dist/common → common}/fonts/OpenSans-BoldItalic.ttf +0 -0
  31. package/{dist/common → common}/fonts/OpenSans-ExtraBold.ttf +0 -0
  32. package/{dist/common → common}/fonts/OpenSans-ExtraBoldItalic.ttf +0 -0
  33. package/{dist/common → common}/fonts/OpenSans-Italic.ttf +0 -0
  34. package/{dist/common → common}/fonts/OpenSans-Light.ttf +0 -0
  35. package/{dist/common → common}/fonts/OpenSans-LightItalic.ttf +0 -0
  36. package/{dist/common → common}/fonts/OpenSans-Regular.ttf +0 -0
  37. package/{dist/common → common}/fonts/OpenSans-SemiBold.ttf +0 -0
  38. package/{dist/common → common}/fonts/OpenSans-SemiBoldItalic.ttf +0 -0
  39. package/common/utils.js +22 -0
  40. package/common/variables.js +1569 -0
  41. package/{dist/date → date}/Date.js +121 -90
  42. package/date/index.d.ts +27 -0
  43. package/date-input/DateInput.js +396 -0
  44. package/date-input/index.d.ts +95 -0
  45. package/dialog/Dialog.js +184 -0
  46. package/dialog/index.d.ts +18 -0
  47. package/dropdown/Dropdown.js +450 -0
  48. package/dropdown/index.d.ts +26 -0
  49. package/file-input/FileInput.js +532 -0
  50. package/file-input/FileItem.js +193 -0
  51. package/file-input/index.d.ts +81 -0
  52. package/footer/Footer.js +297 -0
  53. package/footer/Icons.js +77 -0
  54. package/footer/index.d.ts +25 -0
  55. package/header/Header.js +326 -0
  56. package/header/Icons.js +59 -0
  57. package/header/index.d.ts +25 -0
  58. package/heading/Heading.js +176 -0
  59. package/heading/index.d.ts +17 -0
  60. package/input-text/Icons.js +22 -0
  61. package/input-text/InputText.js +611 -0
  62. package/input-text/index.d.ts +36 -0
  63. package/layout/ApplicationLayout.js +235 -0
  64. package/layout/Icons.js +55 -0
  65. package/link/Link.js +183 -0
  66. package/link/index.d.ts +23 -0
  67. package/main.d.ts +44 -0
  68. package/{dist/main.js → main.js} +143 -43
  69. package/number-input/NumberInput.js +128 -0
  70. package/{dist/ThemeContext.js → number-input/NumberInputContext.js} +3 -2
  71. package/number-input/index.d.ts +113 -0
  72. package/package.json +39 -24
  73. package/paginator/Icons.js +66 -0
  74. package/paginator/Paginator.js +221 -0
  75. package/paginator/index.d.ts +20 -0
  76. package/password-input/PasswordInput.js +199 -0
  77. package/password-input/index.d.ts +94 -0
  78. package/progress-bar/ProgressBar.js +188 -0
  79. package/progress-bar/index.d.ts +18 -0
  80. package/{dist/radio → radio}/Radio.js +48 -44
  81. package/radio/index.d.ts +23 -0
  82. package/resultsetTable/ResultsetTable.js +274 -0
  83. package/resultsetTable/index.d.ts +19 -0
  84. package/select/Select.js +865 -0
  85. package/select/index.d.ts +131 -0
  86. package/sidenav/Sidenav.js +145 -0
  87. package/sidenav/index.d.ts +13 -0
  88. package/slider/Slider.js +340 -0
  89. package/slider/index.d.ts +29 -0
  90. package/spinner/Spinner.js +267 -0
  91. package/spinner/index.d.ts +17 -0
  92. package/switch/Switch.js +208 -0
  93. package/switch/index.d.ts +24 -0
  94. package/table/Table.js +118 -0
  95. package/table/index.d.ts +13 -0
  96. package/tabs/Tabs.js +259 -0
  97. package/tabs/index.d.ts +19 -0
  98. package/tag/Tag.js +208 -0
  99. package/tag/index.d.ts +24 -0
  100. package/text-input/TextInput.js +825 -0
  101. package/text-input/index.d.ts +135 -0
  102. package/textarea/Textarea.js +317 -0
  103. package/textarea/index.d.ts +117 -0
  104. package/{dist/toggle → toggle}/Toggle.js +30 -67
  105. package/toggle/index.d.ts +21 -0
  106. package/toggle-group/ToggleGroup.js +243 -0
  107. package/toggle-group/index.d.ts +21 -0
  108. package/{dist/upload → upload}/Upload.js +23 -22
  109. package/upload/buttons-upload/ButtonsUpload.js +111 -0
  110. package/upload/buttons-upload/Icons.js +40 -0
  111. package/upload/dragAndDropArea/DragAndDropArea.js +225 -0
  112. package/upload/dragAndDropArea/Icons.js +39 -0
  113. package/upload/file-upload/FileToUpload.js +115 -0
  114. package/upload/file-upload/Icons.js +66 -0
  115. package/upload/files-upload/FilesToUpload.js +109 -0
  116. package/upload/index.d.ts +15 -0
  117. package/upload/transaction/Icons.js +160 -0
  118. package/upload/transaction/Transaction.js +104 -0
  119. package/upload/transactions/Transactions.js +94 -0
  120. package/useTheme.js +22 -0
  121. package/wizard/Icons.js +65 -0
  122. package/wizard/Wizard.js +271 -0
  123. package/wizard/index.d.ts +18 -0
  124. package/README.md +0 -66
  125. package/babel.config.js +0 -4
  126. package/dist/accordion/Accordion.js +0 -264
  127. package/dist/accordion/Accordion.stories.js +0 -207
  128. package/dist/accordion/readme.md +0 -96
  129. package/dist/alert/Alert.js +0 -302
  130. package/dist/alert/Alert.stories.js +0 -158
  131. package/dist/alert/close.svg +0 -4
  132. package/dist/alert/error.svg +0 -4
  133. package/dist/alert/info.svg +0 -4
  134. package/dist/alert/readme.md +0 -43
  135. package/dist/alert/success.svg +0 -4
  136. package/dist/alert/warning.svg +0 -4
  137. package/dist/button/Button.js +0 -183
  138. package/dist/button/Button.stories.js +0 -224
  139. package/dist/button/readme.md +0 -93
  140. package/dist/card/Card.js +0 -246
  141. package/dist/checkbox/Checkbox.js +0 -224
  142. package/dist/checkbox/Checkbox.stories.js +0 -144
  143. package/dist/checkbox/readme.md +0 -116
  144. package/dist/chip/Chip.js +0 -170
  145. package/dist/common/services/example-service.js +0 -10
  146. package/dist/common/services/example-service.test.js +0 -12
  147. package/dist/common/utils.js +0 -42
  148. package/dist/common/variables.js +0 -188
  149. package/dist/date/Date.stories.js +0 -205
  150. package/dist/date/calendar.svg +0 -1
  151. package/dist/date/calendar_dark.svg +0 -1
  152. package/dist/date/readme.md +0 -73
  153. package/dist/dialog/Dialog.js +0 -193
  154. package/dist/dialog/Dialog.stories.js +0 -217
  155. package/dist/dialog/readme.md +0 -32
  156. package/dist/dropdown/Dropdown.js +0 -412
  157. package/dist/dropdown/Dropdown.stories.js +0 -249
  158. package/dist/dropdown/baseline-arrow_drop_down.svg +0 -1
  159. package/dist/dropdown/baseline-arrow_drop_down_wh.svg +0 -4
  160. package/dist/dropdown/baseline-arrow_drop_up.svg +0 -1
  161. package/dist/dropdown/baseline-arrow_drop_up_wh.svg +0 -4
  162. package/dist/dropdown/readme.md +0 -69
  163. package/dist/footer/Footer.js +0 -341
  164. package/dist/footer/Footer.stories.js +0 -94
  165. package/dist/footer/dxc_logo_wht.png +0 -0
  166. package/dist/footer/readme.md +0 -41
  167. package/dist/header/Header.js +0 -350
  168. package/dist/header/Header.stories.js +0 -176
  169. package/dist/header/close_icon.svg +0 -1
  170. package/dist/header/dxc_logo_black.png +0 -0
  171. package/dist/header/dxc_logo_white.png +0 -0
  172. package/dist/header/hamb_menu_black.svg +0 -1
  173. package/dist/header/hamb_menu_white.svg +0 -1
  174. package/dist/header/readme.md +0 -33
  175. package/dist/heading/Heading.js +0 -159
  176. package/dist/input-text/InputText.js +0 -515
  177. package/dist/input-text/InputText.stories.js +0 -209
  178. package/dist/input-text/error.svg +0 -1
  179. package/dist/input-text/readme.md +0 -91
  180. package/dist/link/Link.js +0 -129
  181. package/dist/link/readme.md +0 -51
  182. package/dist/paginator/Paginator.js +0 -178
  183. package/dist/paginator/images/next.svg +0 -3
  184. package/dist/paginator/images/nextPage.svg +0 -3
  185. package/dist/paginator/images/previous.svg +0 -3
  186. package/dist/paginator/images/previousPage.svg +0 -3
  187. package/dist/paginator/readme.md +0 -50
  188. package/dist/progress-bar/ProgressBar.js +0 -189
  189. package/dist/progress-bar/ProgressBar.stories.js +0 -280
  190. package/dist/progress-bar/readme.md +0 -63
  191. package/dist/radio/Radio.stories.js +0 -166
  192. package/dist/radio/readme.md +0 -70
  193. package/dist/resultsetTable/ResultsetTable.js +0 -334
  194. package/dist/resultsetTable/arrow_downward-24px_wht.svg +0 -1
  195. package/dist/resultsetTable/arrow_upward-24px_wht.svg +0 -1
  196. package/dist/resultsetTable/unfold_more-24px_wht.svg +0 -1
  197. package/dist/select/Select.js +0 -425
  198. package/dist/select/Select.stories.js +0 -235
  199. package/dist/select/readme.md +0 -72
  200. package/dist/sidenav/Sidenav.js +0 -217
  201. package/dist/sidenav/arrow_icon.svg +0 -3
  202. package/dist/slider/Slider.js +0 -258
  203. package/dist/slider/Slider.stories.js +0 -241
  204. package/dist/slider/readme.md +0 -64
  205. package/dist/spinner/Spinner.js +0 -196
  206. package/dist/spinner/Spinner.stories.js +0 -183
  207. package/dist/spinner/readme.md +0 -65
  208. package/dist/switch/Switch.js +0 -195
  209. package/dist/switch/Switch.stories.js +0 -134
  210. package/dist/switch/readme.md +0 -133
  211. package/dist/table/Table.js +0 -84
  212. package/dist/tabs/Tabs.js +0 -183
  213. package/dist/tabs/Tabs.stories.js +0 -130
  214. package/dist/tabs/readme.md +0 -78
  215. package/dist/tabs-for-sections/TabsForSections.js +0 -107
  216. package/dist/tabs-for-sections/readme.md +0 -78
  217. package/dist/tag/Tag.js +0 -217
  218. package/dist/textarea/Textarea.js +0 -226
  219. package/dist/toggle/Toggle.stories.js +0 -297
  220. package/dist/toggle/readme.md +0 -80
  221. package/dist/upload/Upload.stories.js +0 -72
  222. package/dist/upload/buttons-upload/ButtonsUpload.js +0 -125
  223. package/dist/upload/buttons-upload/drag-drop-icon.svg +0 -4
  224. package/dist/upload/buttons-upload/upload-button.svg +0 -1
  225. package/dist/upload/dragAndDropArea/DragAndDropArea.js +0 -282
  226. package/dist/upload/dragAndDropArea/upload_drop.svg +0 -4
  227. package/dist/upload/dragAndDropArea/upload_file.svg +0 -4
  228. package/dist/upload/file-upload/FileToUpload.js +0 -158
  229. package/dist/upload/file-upload/audio-icon.svg +0 -4
  230. package/dist/upload/file-upload/close.svg +0 -4
  231. package/dist/upload/file-upload/file-icon.svg +0 -4
  232. package/dist/upload/file-upload/video-icon.svg +0 -4
  233. package/dist/upload/files-upload/FilesToUpload.js +0 -123
  234. package/dist/upload/readme.md +0 -37
  235. package/dist/upload/transaction/Transaction.js +0 -155
  236. package/dist/upload/transaction/audio-icon-err.svg +0 -4
  237. package/dist/upload/transaction/audio-icon.svg +0 -4
  238. package/dist/upload/transaction/error-icon.svg +0 -4
  239. package/dist/upload/transaction/file-icon-err.svg +0 -4
  240. package/dist/upload/transaction/file-icon.svg +0 -4
  241. package/dist/upload/transaction/image-icon-err.svg +0 -4
  242. package/dist/upload/transaction/image-icon.svg +0 -4
  243. package/dist/upload/transaction/success-icon.svg +0 -4
  244. package/dist/upload/transaction/video-icon-err.svg +0 -4
  245. package/dist/upload/transaction/video-icon.svg +0 -4
  246. package/dist/upload/transactions/Transactions.js +0 -120
  247. package/dist/wizard/Wizard.js +0 -310
  248. package/dist/wizard/invalid_icon.svg +0 -6
  249. package/dist/wizard/valid_icon.svg +0 -6
  250. package/dist/wizard/validation-wrong.svg +0 -6
  251. package/test/Accordion.test.js +0 -33
  252. package/test/Alert.test.js +0 -53
  253. package/test/Box.test.js +0 -10
  254. package/test/Button.test.js +0 -18
  255. package/test/Card.test.js +0 -30
  256. package/test/Checkbox.test.js +0 -45
  257. package/test/Chip.test.js +0 -25
  258. package/test/Date.test.js +0 -393
  259. package/test/Dialog.test.js +0 -23
  260. package/test/Dropdown.test.js +0 -130
  261. package/test/Footer.test.js +0 -99
  262. package/test/Header.test.js +0 -39
  263. package/test/Heading.test.js +0 -35
  264. package/test/InputText.test.js +0 -236
  265. package/test/Link.test.js +0 -25
  266. package/test/Paginator.test.js +0 -165
  267. package/test/ProgressBar.test.js +0 -35
  268. package/test/Radio.test.js +0 -37
  269. package/test/ResultsetTable.test.js +0 -282
  270. package/test/Select.test.js +0 -191
  271. package/test/Sidenav.test.js +0 -87
  272. package/test/Slider.test.js +0 -65
  273. package/test/Spinner.test.js +0 -27
  274. package/test/Switch.test.js +0 -45
  275. package/test/Table.test.js +0 -36
  276. package/test/Tabs.test.js +0 -88
  277. package/test/TabsForSections.test.js +0 -34
  278. package/test/Tag.test.js +0 -32
  279. package/test/TextArea.test.js +0 -52
  280. package/test/Toggle.test.js +0 -43
  281. package/test/Upload.test.js +0 -60
  282. package/test/Wizard.test.js +0 -130
  283. package/test/mocks/pngMock.js +0 -1
  284. package/test/mocks/svgMock.js +0 -1
@@ -1,425 +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 _Select = _interopRequireDefault(require("@material-ui/core/Select"));
23
-
24
- var _InputLabel = _interopRequireDefault(require("@material-ui/core/InputLabel"));
25
-
26
- var _FormControl = _interopRequireDefault(require("@material-ui/core/FormControl"));
27
-
28
- var _styledComponents = _interopRequireWildcard(require("styled-components"));
29
-
30
- var _MenuItem = _interopRequireDefault(require("@material-ui/core/MenuItem"));
31
-
32
- var _styles = require("@material-ui/core/styles");
33
-
34
- var _propTypes = _interopRequireDefault(require("prop-types"));
35
-
36
- var _Checkbox = _interopRequireDefault(require("../checkbox/Checkbox"));
37
-
38
- require("../common/OpenSans.css");
39
-
40
- var _variables = require("../common/variables.js");
41
-
42
- var _utils = require("../common/utils.js");
43
-
44
- var _ThemeContext = _interopRequireDefault(require("../ThemeContext.js"));
45
-
46
- function _templateObject7() {
47
- 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 &::before {\n content:'", "';\n color: ", ";\n font-size: 18px; \n }\n &.Mui-disabled{\n opacity:0.5;\n color: ", ";\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 opacity:0.5;\n cursor: not-allowed;\n }\n }\n .MuiInputBase-root {\n width: 100%;\n &.Mui-disabled {\n opacity:0.5;\n cursor: not-allowed;\n }\n }\n .MuiInput-underline{\n &.Mui-disabled:before{\n border-bottom-style: solid;\n opacity: 0.5;\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"]);
48
-
49
- _templateObject7 = function _templateObject7() {
50
- return data;
51
- };
52
-
53
- return data;
54
- }
55
-
56
- function _templateObject6() {
57
- 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"]);
58
-
59
- _templateObject6 = function _templateObject6() {
60
- return data;
61
- };
62
-
63
- return data;
64
- }
65
-
66
- function _templateObject5() {
67
- 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"]);
68
-
69
- _templateObject5 = function _templateObject5() {
70
- return data;
71
- };
72
-
73
- return data;
74
- }
75
-
76
- function _templateObject4() {
77
- 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"]);
78
-
79
- _templateObject4 = function _templateObject4() {
80
- return data;
81
- };
82
-
83
- return data;
84
- }
85
-
86
- function _templateObject3() {
87
- 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"]);
88
-
89
- _templateObject3 = function _templateObject3() {
90
- return data;
91
- };
92
-
93
- return data;
94
- }
95
-
96
- function _templateObject2() {
97
- var data = (0, _taggedTemplateLiteral2["default"])(["\n overflow: hidden;\n text-overflow: ellipsis;\n"]);
98
-
99
- _templateObject2 = function _templateObject2() {
100
- return data;
101
- };
102
-
103
- return data;
104
- }
105
-
106
- function _templateObject() {
107
- var data = (0, _taggedTemplateLiteral2["default"])(["\n width: calc(100% - 24px);\n overflow: hidden;\n text-overflow: ellipsis;\n"]);
108
-
109
- _templateObject = function _templateObject() {
110
- return data;
111
- };
112
-
113
- return data;
114
- }
115
-
116
- var useStyles = (0, _styles.makeStyles)(function (theme) {
117
- return {
118
- root: function root(props) {
119
- return {
120
- minWidth: props.width
121
- };
122
- },
123
- dropdownStyle: function dropdownStyle(props) {
124
- return {
125
- boxShadow: "0px 2px 10px 0px rgba(0, 0, 0, 0.3)",
126
- minWidth: props.width,
127
- width: props.width
128
- };
129
- },
130
- itemList: function itemList(props) {
131
- return {
132
- color: props.darkGrey,
133
- "&.MuiList-padding": {
134
- paddingBottom: "0px",
135
- paddingTop: "0px"
136
- },
137
- "& li": {
138
- fontSize: "16px",
139
- "&:hover": {
140
- backgroundColor: props.darkWhite,
141
- color: props.darkGrey
142
- },
143
- "&:active": {
144
- backgroundColor: props.lightGrey,
145
- color: props.black
146
- },
147
- "&.Mui-selected": {
148
- backgroundColor: props.lightGrey,
149
- color: props.black
150
- }
151
- }
152
- };
153
- }
154
- };
155
- });
156
-
157
- var DxcSelect = function DxcSelect(_ref) {
158
- var value = _ref.value,
159
- name = _ref.name,
160
- onChange = _ref.onChange,
161
- label = _ref.label,
162
- _ref$required = _ref.required,
163
- required = _ref$required === void 0 ? false : _ref$required,
164
- _ref$disabled = _ref.disabled,
165
- disabled = _ref$disabled === void 0 ? false : _ref$disabled,
166
- _ref$options = _ref.options,
167
- options = _ref$options === void 0 ? [] : _ref$options,
168
- _ref$theme = _ref.theme,
169
- theme = _ref$theme === void 0 ? "light" : _ref$theme,
170
- _ref$disableRipple = _ref.disableRipple,
171
- disableRipple = _ref$disableRipple === void 0 ? false : _ref$disableRipple,
172
- _ref$iconPosition = _ref.iconPosition,
173
- iconPosition = _ref$iconPosition === void 0 ? "before" : _ref$iconPosition,
174
- _ref$multiple = _ref.multiple,
175
- multiple = _ref$multiple === void 0 ? false : _ref$multiple,
176
- margin = _ref.margin,
177
- _ref$size = _ref.size,
178
- size = _ref$size === void 0 ? "medium" : _ref$size;
179
-
180
- var colorsTheme = (0, _react.useContext)(_ThemeContext["default"]) || _variables.colors;
181
-
182
- var _useState = (0, _react.useState)(multiple && [] || ""),
183
- _useState2 = (0, _slicedToArray2["default"])(_useState, 2),
184
- selectedValue = _useState2[0],
185
- setSelectedValue = _useState2[1];
186
-
187
- var selectValues = {
188
- width: "auto"
189
- };
190
- var classes = useStyles(selectValues, colorsTheme);
191
-
192
- var handleSelectChange = function handleSelectChange(selectedOption) {
193
- if (multiple) {
194
- setSelectedValue(selectedOption.target.value);
195
-
196
- if (typeof onChange === "function") {
197
- onChange(selectedOption.target.value);
198
- }
199
- } else {
200
- setSelectedValue(selectedOption.target.value);
201
-
202
- if (typeof onChange === "function") {
203
- onChange(selectedOption.target.value);
204
- }
205
- }
206
- };
207
-
208
- var getLabelForSingleSelect = function getLabelForSingleSelect(selected) {
209
- var selectedItem = options.filter(function (option) {
210
- return option.value === selected;
211
- })[0];
212
- return _react["default"].createElement(SelectedIconContainer, {
213
- iconPosition: iconPosition,
214
- multiple: multiple,
215
- label: selectedItem && selectedItem.label
216
- }, selectedItem && selectedItem.iconSrc && _react["default"].createElement(ListIcon, {
217
- src: selectedItem && selectedItem.iconSrc
218
- }), selectedItem && selectedItem.label && _react["default"].createElement(SelectedLabelContainer, {
219
- iconSrc: selectedItem && selectedItem.iconSrc,
220
- iconPosition: iconPosition,
221
- brightness: theme,
222
- disabled: disabled
223
- }, selectedItem && selectedItem.label));
224
- };
225
-
226
- var getSelectedValuesWithLabel = function getSelectedValuesWithLabel(optionsList, selected) {
227
- return _react["default"].createElement(MultipleLabelSelected, null, optionsList.filter(function (x) {
228
- return selected.includes(x.value);
229
- }).map(function (optionToRender) {
230
- return optionToRender.label;
231
- }).join(", "));
232
- };
233
-
234
- var getSelectedValuesWithIcons = function getSelectedValuesWithIcons(optionsList, selected) {
235
- return options.filter(function (x) {
236
- return selected.includes(x.value);
237
- }).map(function (optionToRender) {
238
- return getLabelForSingleSelect(optionToRender.value);
239
- });
240
- };
241
-
242
- var labelForMultipleSelect = function labelForMultipleSelect(selected) {
243
- return options.findIndex(function (option) {
244
- return !option.label;
245
- }) !== -1 ? getSelectedValuesWithIcons(options, selected) : getSelectedValuesWithLabel(options, selected);
246
- };
247
-
248
- var getRenderValue = function getRenderValue(selected) {
249
- return multiple && labelForMultipleSelect(selected) || getLabelForSingleSelect(selected);
250
- };
251
-
252
- var isChecked = function isChecked(checkedValue, value, option) {
253
- if (value !== undefined) {
254
- var result = false;
255
- value.map(function (val) {
256
- if (val === option.value) {
257
- result = true;
258
- }
259
- });
260
- return result;
261
- } else if (checkedValue) {
262
- return checkedValue.findIndex(function (element) {
263
- return element === option.value;
264
- }) !== -1 || false;
265
- }
266
- };
267
-
268
- return _react["default"].createElement(_styledComponents.ThemeProvider, {
269
- theme: colorsTheme
270
- }, _react["default"].createElement(SelectContainer, {
271
- margin: margin,
272
- brightness: theme,
273
- required: required,
274
- size: size
275
- }, _react["default"].createElement(_FormControl["default"], null, _react["default"].createElement(_InputLabel["default"], {
276
- disabled: disabled
277
- }, label), _react["default"].createElement(_Select["default"], {
278
- name: name,
279
- brightness: theme,
280
- multiple: multiple,
281
- renderValue: getRenderValue,
282
- onChange: handleSelectChange,
283
- value: value !== undefined ? value : selectedValue,
284
- disabled: disabled,
285
- MenuProps: {
286
- classes: {
287
- paper: classes.dropdownStyle,
288
- list: classes.itemList
289
- },
290
- getContentAnchorEl: null,
291
- anchorOrigin: {
292
- vertical: "bottom",
293
- horizontal: "left"
294
- }
295
- }
296
- }, options.map(function (option) {
297
- return _react["default"].createElement(_MenuItem["default"], {
298
- id: option.value,
299
- value: option.value,
300
- disableRipple: disableRipple
301
- }, multiple && _react["default"].createElement(_Checkbox["default"], {
302
- size: "fitContent",
303
- disableRipple: true,
304
- checked: isChecked(selectedValue, value, option)
305
- }), _react["default"].createElement(OptionContainer, {
306
- iconPosition: iconPosition
307
- }, option.iconSrc && _react["default"].createElement(ListIcon, {
308
- src: option.iconSrc,
309
- label: option.label,
310
- iconPosition: iconPosition
311
- }), " ", _react["default"].createElement(LabelCont, null, option.label)));
312
- })))));
313
- };
314
-
315
- var sizes = {
316
- small: "60px",
317
- medium: "240px",
318
- large: "480px",
319
- fillParent: "100%"
320
- };
321
-
322
- var calculateWidth = function calculateWidth(margin, size) {
323
- if (size === "fillParent") {
324
- return "calc(".concat(sizes[size], " - ").concat((0, _utils.getMargin)(margin, "left"), " - ").concat((0, _utils.getMargin)(margin, "right"), ")");
325
- }
326
-
327
- return sizes[size];
328
- };
329
-
330
- var MultipleLabelSelected = _styledComponents["default"].div(_templateObject());
331
-
332
- var LabelCont = _styledComponents["default"].span(_templateObject2());
333
-
334
- var SelectedIconContainer = _styledComponents["default"].div(_templateObject3(), function (props) {
335
- return props.iconPosition === "before" && "row" || "row-reverse";
336
- }, function (props) {
337
- return props.iconPosition === "before" && "flex-start" || "flex-end";
338
- }, function (props) {
339
- return props.multiple && props.label && "15px" || "0px";
340
- }, function (props) {
341
- return !props.multiple && "calc(100% - 24px)" || "auto";
342
- }, function (props) {
343
- return props.iconPosition === "after" && (props.label !== "" || props.label === undefined) && "content:','";
344
- }, function (props) {
345
- return props.iconPosition === "before" && (props.label !== "" || props.label === undefined) && "content:','";
346
- });
347
-
348
- var SelectedLabelContainer = _styledComponents["default"].span(_templateObject4(), function (props) {
349
- return (props.iconPosition === "after" || !props.iconSrc) && "0px" || "10px";
350
- }, function (props) {
351
- return (props.iconPosition === "before" || !props.iconSrc) && "0px" || "10px";
352
- });
353
-
354
- var OptionContainer = _styledComponents["default"].div(_templateObject5(), function (props) {
355
- return props.iconPosition === "before" && "row" || "row-reverse";
356
- });
357
-
358
- var ListIcon = _styledComponents["default"].img(_templateObject6(), function (props) {
359
- return props.iconPosition === "after" && props.label !== "" && "10px" || "0px";
360
- }, function (props) {
361
- return props.iconPosition === "before" && props.label !== "" && "10px" || "0px";
362
- });
363
-
364
- var SelectContainer = _styledComponents["default"].div(_templateObject7(), function (props) {
365
- return calculateWidth(props.margin, props.size);
366
- }, function (props) {
367
- return props.margin && (0, _typeof2["default"])(props.margin) !== "object" ? _variables.spaces[props.margin] : "0px";
368
- }, function (props) {
369
- return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.top ? _variables.spaces[props.margin.top] : "";
370
- }, function (props) {
371
- return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.right ? _variables.spaces[props.margin.right] : "";
372
- }, function (props) {
373
- return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.bottom ? _variables.spaces[props.margin.bottom] : "";
374
- }, function (props) {
375
- return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.left ? _variables.spaces[props.margin.left] : "";
376
- }, function (props) {
377
- return props.brightness === "light" ? props.theme.darkGrey : props.theme.lightGrey;
378
- }, function (props) {
379
- return props.required && "*" || "";
380
- }, function (props) {
381
- return props.brightness === "light" ? props.theme.darkRed : props.theme.lightRed;
382
- }, function (props) {
383
- return props.brightness === "light" ? props.theme.darkGrey : props.theme.lightGrey;
384
- }, function (props) {
385
- return props.brightness === "light" ? props.theme.black : props.theme.lightGrey;
386
- }, function (props) {
387
- return props.brightness === "dark" ? props.theme.white : props.theme.black;
388
- }, function (props) {
389
- return props.brightness === "light" ? props.theme.darkGrey : props.theme.lightGrey;
390
- }, function (props) {
391
- return props.brightness === "dark" ? props.theme.white : props.theme.black;
392
- }, function (props) {
393
- return props.brightness === "dark" ? props.theme.white : props.theme.black;
394
- }, function (props) {
395
- return props.brightness === "dark" ? props.theme.white : props.theme.black;
396
- }, function (props) {
397
- return props.brightness === "dark" ? props.theme.white : props.theme.black;
398
- });
399
-
400
- DxcSelect.propTypes = {
401
- size: _propTypes["default"].oneOf((0, _toConsumableArray2["default"])(Object.keys(sizes))),
402
- label: _propTypes["default"].string,
403
- name: _propTypes["default"].string,
404
- value: _propTypes["default"].oneOfType([_propTypes["default"].string, _propTypes["default"].number, _propTypes["default"].arrayOf(_propTypes["default"].oneOfType([_propTypes["default"].string, _propTypes["default"].number]))]),
405
- disabled: _propTypes["default"].bool,
406
- required: _propTypes["default"].bool,
407
- disableRipple: _propTypes["default"].bool,
408
- theme: _propTypes["default"].oneOf(["dark", "light"]),
409
- iconPosition: _propTypes["default"].oneOf(["after", "before"]),
410
- onChange: _propTypes["default"].func,
411
- options: _propTypes["default"].arrayOf(_propTypes["default"].shape({
412
- value: _propTypes["default"].any.isRequired,
413
- label: _propTypes["default"].any.isRequired,
414
- iconSrc: _propTypes["default"].string
415
- })),
416
- multiple: _propTypes["default"].bool,
417
- margin: _propTypes["default"].oneOfType([_propTypes["default"].shape({
418
- top: _propTypes["default"].oneOf(Object.keys(_variables.spaces)),
419
- bottom: _propTypes["default"].oneOf(Object.keys(_variables.spaces)),
420
- left: _propTypes["default"].oneOf(Object.keys(_variables.spaces)),
421
- right: _propTypes["default"].oneOf(Object.keys(_variables.spaces))
422
- }), _propTypes["default"].oneOf((0, _toConsumableArray2["default"])(Object.keys(_variables.spaces)))])
423
- };
424
- var _default = DxcSelect;
425
- exports["default"] = _default;
@@ -1,235 +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 _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
8
-
9
- var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
10
-
11
- var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/possibleConstructorReturn"));
12
-
13
- var _getPrototypeOf2 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf"));
14
-
15
- var _assertThisInitialized2 = _interopRequireDefault(require("@babel/runtime/helpers/assertThisInitialized"));
16
-
17
- var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits"));
18
-
19
- var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
20
-
21
- var _react = _interopRequireDefault(require("react"));
22
-
23
- var _react2 = require("@storybook/react");
24
-
25
- var _addonActions = require("@storybook/addon-actions");
26
-
27
- var _amazon = _interopRequireDefault(require("../../.storybook/public/amazon.svg"));
28
-
29
- var _ebay = _interopRequireDefault(require("../../.storybook/public/ebay.svg"));
30
-
31
- var _apple = _interopRequireDefault(require("../../.storybook/public/apple.svg"));
32
-
33
- var _addonKnobs = require("@storybook/addon-knobs");
34
-
35
- var _readme = _interopRequireDefault(require("./readme.md"));
36
-
37
- var _Select = _interopRequireDefault(require("./Select"));
38
-
39
- 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; }
40
-
41
- 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; }
42
-
43
- var onChange = (0, _addonActions.action)("onChange");
44
-
45
- onChange.toString = function () {
46
- return "onChangeHandler";
47
- };
48
-
49
- var selectOptions = [{
50
- value: 1,
51
- label: "Amazon",
52
- iconSrc: _amazon["default"]
53
- }, {
54
- value: 2,
55
- label: "Ebay",
56
- iconSrc: _ebay["default"]
57
- }, {
58
- value: 3,
59
- label: "Apple",
60
- iconSrc: _apple["default"]
61
- }];
62
- var selectOptionsWithoutIcon = [{
63
- value: 1,
64
- label: "Amazon"
65
- }, {
66
- value: 2,
67
- label: "Ebay"
68
- }, {
69
- value: 3,
70
- label: "Apple"
71
- }];
72
- var selectOptionsWithoutLabel = [{
73
- value: 1,
74
- label: "",
75
- iconSrc: _amazon["default"]
76
- }, {
77
- value: 2,
78
- label: "",
79
- iconSrc: _ebay["default"]
80
- }, {
81
- value: 3,
82
- label: "",
83
- iconSrc: _apple["default"]
84
- }];
85
- (0, _react2.storiesOf)("Form Components|Select", module).add("Component", function () {
86
- return _react["default"].createElement("div", null, _react["default"].createElement("h2", null, "Light"), _react["default"].createElement("div", null, _react["default"].createElement(_Select["default"], {
87
- disabled: false,
88
- theme: "light",
89
- name: "selectName",
90
- label: "Select Label",
91
- options: selectOptionsWithoutIcon,
92
- required: false,
93
- onChange: onChange,
94
- iconPosition: "before"
95
- })), _react["default"].createElement("h4", null, "Multiple"), _react["default"].createElement("div", null, _react["default"].createElement(_Select["default"], {
96
- disabled: false,
97
- theme: "light",
98
- multiple: true,
99
- name: "selectNameMultiple",
100
- label: "Select Multiple",
101
- options: selectOptionsWithoutIcon,
102
- required: false,
103
- onChange: onChange,
104
- iconPosition: "after"
105
- })), _react["default"].createElement("h4", null, "Only Icons"), _react["default"].createElement("div", null, _react["default"].createElement(_Select["default"], {
106
- disabled: false,
107
- theme: "light",
108
- multiple: true,
109
- name: "selectNameOnlyIcons",
110
- label: "Only icons",
111
- options: selectOptionsWithoutLabel,
112
- required: false,
113
- onChange: onChange,
114
- iconPosition: "before"
115
- })), _react["default"].createElement("h2", null, "Dark"), _react["default"].createElement("div", {
116
- style: {
117
- background: "black"
118
- }
119
- }, _react["default"].createElement(_Select["default"], {
120
- disabled: false,
121
- theme: "dark",
122
- name: "selectNameDark",
123
- label: "Select Label Dark",
124
- options: selectOptions,
125
- required: false,
126
- onChange: onChange,
127
- iconPosition: "before"
128
- }), _react["default"].createElement("h4", null, "Multiple"), _react["default"].createElement("div", null, _react["default"].createElement(_Select["default"], {
129
- disabled: false,
130
- theme: "dark",
131
- multiple: true,
132
- name: "selectNameMultipleDark",
133
- label: "Select Multiple",
134
- options: selectOptions,
135
- required: false,
136
- onChange: onChange,
137
- iconPosition: "after"
138
- })), _react["default"].createElement("h4", null, "Only Icons"), _react["default"].createElement("div", null, _react["default"].createElement(_Select["default"], {
139
- disabled: false,
140
- theme: "dark",
141
- multiple: true,
142
- name: "selectNameOnlyIcons",
143
- label: "Only icons",
144
- options: selectOptionsWithoutLabel,
145
- required: false,
146
- onChange: onChange,
147
- iconPosition: "before"
148
- }))));
149
- }, {
150
- notes: {
151
- markdown: _readme["default"]
152
- }
153
- });
154
- (0, _react2.storiesOf)("Form Components|Select", module).add("Controlled Component", function () {
155
- var ControlledStory =
156
- /*#__PURE__*/
157
- function (_React$Component) {
158
- (0, _inherits2["default"])(ControlledStory, _React$Component);
159
-
160
- function ControlledStory(props) {
161
- var _this;
162
-
163
- (0, _classCallCheck2["default"])(this, ControlledStory);
164
- _this = (0, _possibleConstructorReturn2["default"])(this, (0, _getPrototypeOf2["default"])(ControlledStory).call(this, props));
165
- (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "onValueChange", function (value) {
166
- return _this.setState({
167
- value: value
168
- });
169
- });
170
- _this.state = {
171
- value: []
172
- };
173
- return _this;
174
- }
175
-
176
- (0, _createClass2["default"])(ControlledStory, [{
177
- key: "render",
178
- value: function render() {
179
- var props = _objectSpread({}, this.props, {
180
- onChange: this.onValueChange,
181
- value: this.state.value
182
- });
183
-
184
- return _react["default"].createElement(_Select["default"], props);
185
- }
186
- }]);
187
- return ControlledStory;
188
- }(_react["default"].Component);
189
-
190
- var props = {
191
- disabled: false,
192
- theme: "light",
193
- name: "selectName",
194
- multiple: true,
195
- options: selectOptions,
196
- required: false,
197
- iconPosition: "before",
198
- label: "Select label"
199
- };
200
- return _react["default"].createElement(ControlledStory, props);
201
- });
202
-
203
- var knobProps = function knobProps() {
204
- return {
205
- label: (0, _addonKnobs.text)("label", "Test Select"),
206
- theme: (0, _addonKnobs.select)("theme", {
207
- light: "light",
208
- dark: "dark"
209
- }, "light"),
210
- disabled: (0, _addonKnobs["boolean"])("disabled", false),
211
- required: (0, _addonKnobs["boolean"])("required", false),
212
- iconPosition: (0, _addonKnobs.select)("icon poistion", {
213
- before: "before",
214
- after: "after"
215
- }, "before") // ,
216
- // multiple: boolean("multiple", false)
217
-
218
- };
219
- };
220
-
221
- (0, _react2.storiesOf)("Form Components|Select", module).add("Knobs example", function () {
222
- var props = knobProps();
223
- return _react["default"].createElement("div", {
224
- style: {
225
- background: props.theme === "dark" && "black" || "transparent"
226
- }
227
- }, _react["default"].createElement(_Select["default"], (0, _extends2["default"])({}, props, {
228
- options: selectOptions,
229
- onChange: onChange
230
- })));
231
- }, {
232
- notes: {
233
- markdown: _readme["default"]
234
- }
235
- });