@dxc-technology/halstack-react 0.0.0-a45812e → 0.0.0-a4bef7b

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 (281) 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 +10 -0
  19. package/button/types.d.ts +22 -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/common/RequiredComponent.js +32 -0
  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/{dist/common → common}/utils.js +0 -0
  40. package/common/variables.js +1567 -0
  41. package/{dist/date → date}/Date.js +121 -93
  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} +147 -47
  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 +40 -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 +47 -56
  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 +864 -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 +818 -0
  101. package/text-input/index.d.ts +135 -0
  102. package/textarea/Textarea.js +315 -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/babel.config.js +0 -4
  125. package/dist/accordion/Accordion.js +0 -264
  126. package/dist/accordion/Accordion.stories.js +0 -207
  127. package/dist/accordion/readme.md +0 -96
  128. package/dist/alert/Alert.js +0 -302
  129. package/dist/alert/Alert.stories.js +0 -158
  130. package/dist/alert/close.svg +0 -4
  131. package/dist/alert/error.svg +0 -4
  132. package/dist/alert/info.svg +0 -4
  133. package/dist/alert/readme.md +0 -43
  134. package/dist/alert/success.svg +0 -4
  135. package/dist/alert/warning.svg +0 -4
  136. package/dist/button/Button.js +0 -187
  137. package/dist/button/Button.stories.js +0 -224
  138. package/dist/button/readme.md +0 -93
  139. package/dist/card/Card.js +0 -246
  140. package/dist/checkbox/Checkbox.js +0 -221
  141. package/dist/checkbox/Checkbox.stories.js +0 -144
  142. package/dist/checkbox/readme.md +0 -116
  143. package/dist/common/RequiredComponent.js +0 -50
  144. package/dist/common/services/example-service.js +0 -10
  145. package/dist/common/services/example-service.test.js +0 -12
  146. package/dist/common/variables.js +0 -77
  147. package/dist/date/Date.stories.js +0 -205
  148. package/dist/date/calendar.svg +0 -1
  149. package/dist/date/calendar_dark.svg +0 -1
  150. package/dist/date/readme.md +0 -73
  151. package/dist/dialog/Dialog.js +0 -164
  152. package/dist/dialog/Dialog.stories.js +0 -217
  153. package/dist/dialog/readme.md +0 -32
  154. package/dist/dropdown/Dropdown.js +0 -412
  155. package/dist/dropdown/Dropdown.stories.js +0 -249
  156. package/dist/dropdown/baseline-arrow_drop_down.svg +0 -1
  157. package/dist/dropdown/baseline-arrow_drop_down_wh.svg +0 -4
  158. package/dist/dropdown/baseline-arrow_drop_up.svg +0 -1
  159. package/dist/dropdown/baseline-arrow_drop_up_wh.svg +0 -4
  160. package/dist/dropdown/readme.md +0 -69
  161. package/dist/footer/Footer.js +0 -341
  162. package/dist/footer/Footer.stories.js +0 -94
  163. package/dist/footer/dxc_logo_wht.png +0 -0
  164. package/dist/footer/readme.md +0 -41
  165. package/dist/header/Header.js +0 -343
  166. package/dist/header/Header.stories.js +0 -176
  167. package/dist/header/close_icon.svg +0 -1
  168. package/dist/header/dxc_logo_black.png +0 -0
  169. package/dist/header/dxc_logo_white.png +0 -0
  170. package/dist/header/hamb_menu_black.svg +0 -1
  171. package/dist/header/hamb_menu_white.svg +0 -1
  172. package/dist/header/readme.md +0 -33
  173. package/dist/heading/Heading.js +0 -159
  174. package/dist/input-text/InputText.js +0 -510
  175. package/dist/input-text/InputText.stories.js +0 -209
  176. package/dist/input-text/error.svg +0 -1
  177. package/dist/input-text/readme.md +0 -91
  178. package/dist/link/Link.js +0 -129
  179. package/dist/link/readme.md +0 -51
  180. package/dist/paginator/Paginator.js +0 -178
  181. package/dist/paginator/images/next.svg +0 -3
  182. package/dist/paginator/images/nextPage.svg +0 -3
  183. package/dist/paginator/images/previous.svg +0 -3
  184. package/dist/paginator/images/previousPage.svg +0 -3
  185. package/dist/paginator/readme.md +0 -50
  186. package/dist/progress-bar/ProgressBar.js +0 -189
  187. package/dist/progress-bar/ProgressBar.stories.js +0 -280
  188. package/dist/progress-bar/readme.md +0 -63
  189. package/dist/radio/Radio.stories.js +0 -166
  190. package/dist/radio/readme.md +0 -70
  191. package/dist/resultsetTable/ResultsetTable.js +0 -334
  192. package/dist/resultsetTable/arrow_downward-24px_wht.svg +0 -1
  193. package/dist/resultsetTable/arrow_upward-24px_wht.svg +0 -1
  194. package/dist/resultsetTable/unfold_more-24px_wht.svg +0 -1
  195. package/dist/select/Select.js +0 -425
  196. package/dist/select/Select.stories.js +0 -235
  197. package/dist/select/readme.md +0 -72
  198. package/dist/sidenav/Sidenav.js +0 -217
  199. package/dist/sidenav/arrow_icon.svg +0 -3
  200. package/dist/slider/Slider.js +0 -268
  201. package/dist/slider/Slider.stories.js +0 -241
  202. package/dist/slider/readme.md +0 -64
  203. package/dist/spinner/Spinner.js +0 -196
  204. package/dist/spinner/Spinner.stories.js +0 -183
  205. package/dist/spinner/readme.md +0 -65
  206. package/dist/switch/Switch.js +0 -219
  207. package/dist/switch/Switch.stories.js +0 -134
  208. package/dist/switch/readme.md +0 -133
  209. package/dist/table/Table.js +0 -84
  210. package/dist/tabs/Tabs.js +0 -183
  211. package/dist/tabs/Tabs.stories.js +0 -130
  212. package/dist/tabs/readme.md +0 -78
  213. package/dist/tabs-for-sections/TabsForSections.js +0 -107
  214. package/dist/tabs-for-sections/readme.md +0 -78
  215. package/dist/tag/Tag.js +0 -217
  216. package/dist/textarea/Textarea.js +0 -226
  217. package/dist/toggle/Toggle.stories.js +0 -297
  218. package/dist/toggle/readme.md +0 -80
  219. package/dist/upload/Upload.stories.js +0 -72
  220. package/dist/upload/buttons-upload/ButtonsUpload.js +0 -125
  221. package/dist/upload/buttons-upload/drag-drop-icon.svg +0 -4
  222. package/dist/upload/buttons-upload/upload-button.svg +0 -1
  223. package/dist/upload/dragAndDropArea/DragAndDropArea.js +0 -282
  224. package/dist/upload/dragAndDropArea/upload_drop.svg +0 -4
  225. package/dist/upload/dragAndDropArea/upload_file.svg +0 -4
  226. package/dist/upload/file-upload/FileToUpload.js +0 -158
  227. package/dist/upload/file-upload/audio-icon.svg +0 -4
  228. package/dist/upload/file-upload/close.svg +0 -4
  229. package/dist/upload/file-upload/file-icon.svg +0 -4
  230. package/dist/upload/file-upload/video-icon.svg +0 -4
  231. package/dist/upload/files-upload/FilesToUpload.js +0 -123
  232. package/dist/upload/readme.md +0 -37
  233. package/dist/upload/transaction/Transaction.js +0 -155
  234. package/dist/upload/transaction/audio-icon-err.svg +0 -4
  235. package/dist/upload/transaction/audio-icon.svg +0 -4
  236. package/dist/upload/transaction/error-icon.svg +0 -4
  237. package/dist/upload/transaction/file-icon-err.svg +0 -4
  238. package/dist/upload/transaction/file-icon.svg +0 -4
  239. package/dist/upload/transaction/image-icon-err.svg +0 -4
  240. package/dist/upload/transaction/image-icon.svg +0 -4
  241. package/dist/upload/transaction/success-icon.svg +0 -4
  242. package/dist/upload/transaction/video-icon-err.svg +0 -4
  243. package/dist/upload/transaction/video-icon.svg +0 -4
  244. package/dist/upload/transactions/Transactions.js +0 -120
  245. package/dist/wizard/Wizard.js +0 -310
  246. package/dist/wizard/invalid_icon.svg +0 -6
  247. package/dist/wizard/valid_icon.svg +0 -6
  248. package/dist/wizard/validation-wrong.svg +0 -6
  249. package/test/Accordion.test.js +0 -33
  250. package/test/Alert.test.js +0 -53
  251. package/test/Box.test.js +0 -10
  252. package/test/Button.test.js +0 -18
  253. package/test/Card.test.js +0 -30
  254. package/test/Checkbox.test.js +0 -45
  255. package/test/Date.test.js +0 -393
  256. package/test/Dialog.test.js +0 -23
  257. package/test/Dropdown.test.js +0 -130
  258. package/test/Footer.test.js +0 -99
  259. package/test/Header.test.js +0 -39
  260. package/test/Heading.test.js +0 -35
  261. package/test/InputText.test.js +0 -236
  262. package/test/Link.test.js +0 -25
  263. package/test/Paginator.test.js +0 -165
  264. package/test/ProgressBar.test.js +0 -35
  265. package/test/Radio.test.js +0 -37
  266. package/test/ResultsetTable.test.js +0 -282
  267. package/test/Select.test.js +0 -191
  268. package/test/Sidenav.test.js +0 -87
  269. package/test/Slider.test.js +0 -65
  270. package/test/Spinner.test.js +0 -27
  271. package/test/Switch.test.js +0 -45
  272. package/test/Table.test.js +0 -36
  273. package/test/Tabs.test.js +0 -88
  274. package/test/TabsForSections.test.js +0 -34
  275. package/test/Tag.test.js +0 -32
  276. package/test/TextArea.test.js +0 -52
  277. package/test/Toggle.test.js +0 -43
  278. package/test/Upload.test.js +0 -60
  279. package/test/Wizard.test.js +0 -130
  280. package/test/mocks/pngMock.js +0 -1
  281. 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
- });