@dxc-technology/halstack-react 0.0.0-eb2a4cc → 0.0.0-ebb089f

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 (229) hide show
  1. package/README.md +2 -2
  2. package/babel.config.js +5 -2
  3. package/dist/BackgroundColorContext.js +46 -0
  4. package/dist/ThemeContext.js +237 -2
  5. package/dist/V3Select/V3Select.js +549 -0
  6. package/dist/V3Select/index.d.ts +27 -0
  7. package/dist/V3Textarea/V3Textarea.js +264 -0
  8. package/dist/V3Textarea/index.d.ts +27 -0
  9. package/dist/accordion/Accordion.js +170 -81
  10. package/dist/accordion/index.d.ts +28 -0
  11. package/dist/accordion-group/AccordionGroup.js +186 -0
  12. package/dist/accordion-group/index.d.ts +16 -0
  13. package/dist/alert/Alert.js +184 -83
  14. package/dist/alert/index.d.ts +51 -0
  15. package/dist/badge/Badge.js +63 -0
  16. package/dist/box/Box.js +31 -23
  17. package/dist/box/index.d.ts +25 -0
  18. package/dist/button/Button.js +84 -29
  19. package/dist/button/Button.stories.js +14 -211
  20. package/dist/button/index.d.ts +24 -0
  21. package/dist/card/Card.js +72 -35
  22. package/dist/card/index.d.ts +22 -0
  23. package/dist/checkbox/Checkbox.js +107 -32
  24. package/dist/checkbox/index.d.ts +24 -0
  25. package/dist/chip/Chip.js +135 -40
  26. package/dist/chip/index.d.ts +22 -0
  27. package/dist/common/RequiredComponent.js +2 -8
  28. package/dist/common/utils.js +2 -22
  29. package/dist/common/variables.js +1472 -159
  30. package/dist/date/Date.js +81 -59
  31. package/dist/date/index.d.ts +27 -0
  32. package/dist/date-input/DateInput.js +400 -0
  33. package/dist/date-input/index.d.ts +95 -0
  34. package/dist/dialog/Dialog.js +61 -36
  35. package/dist/dialog/index.d.ts +18 -0
  36. package/dist/dropdown/Dropdown.js +226 -94
  37. package/dist/dropdown/index.d.ts +26 -0
  38. package/dist/file-input/FileInput.js +644 -0
  39. package/dist/file-input/FileItem.js +287 -0
  40. package/dist/file-input/index.d.ts +81 -0
  41. package/dist/footer/Footer.js +122 -47
  42. package/dist/footer/Icons.js +77 -0
  43. package/dist/footer/index.d.ts +25 -0
  44. package/dist/header/Header.js +211 -91
  45. package/dist/header/Icons.js +59 -0
  46. package/dist/header/index.d.ts +25 -0
  47. package/dist/heading/Heading.js +93 -22
  48. package/dist/heading/index.d.ts +17 -0
  49. package/dist/input-text/Icons.js +22 -0
  50. package/dist/input-text/InputText.js +290 -104
  51. package/dist/input-text/index.d.ts +36 -0
  52. package/dist/layout/ApplicationLayout.js +327 -0
  53. package/dist/layout/Icons.js +55 -0
  54. package/dist/link/Link.js +136 -35
  55. package/dist/link/index.d.ts +23 -0
  56. package/dist/main.d.ts +40 -0
  57. package/dist/main.js +112 -16
  58. package/dist/number-input/NumberInput.js +136 -0
  59. package/dist/number-input/NumberInputContext.js +16 -0
  60. package/dist/number-input/index.d.ts +113 -0
  61. package/dist/paginator/Icons.js +66 -0
  62. package/dist/paginator/Paginator.js +184 -57
  63. package/dist/paginator/index.d.ts +20 -0
  64. package/dist/password-input/PasswordInput.js +203 -0
  65. package/dist/password-input/index.d.ts +94 -0
  66. package/dist/progress-bar/ProgressBar.js +97 -44
  67. package/dist/progress-bar/index.d.ts +18 -0
  68. package/dist/radio/Radio.js +39 -21
  69. package/dist/radio/index.d.ts +23 -0
  70. package/dist/resultsetTable/ResultsetTable.js +93 -69
  71. package/dist/resultsetTable/index.d.ts +19 -0
  72. package/dist/select/Select.js +957 -262
  73. package/dist/select/index.d.ts +131 -0
  74. package/dist/sidenav/Sidenav.js +87 -125
  75. package/dist/sidenav/index.d.ts +13 -0
  76. package/dist/slider/Slider.js +219 -73
  77. package/dist/slider/index.d.ts +29 -0
  78. package/dist/spinner/Spinner.js +249 -64
  79. package/dist/spinner/index.d.ts +17 -0
  80. package/dist/switch/Switch.js +51 -26
  81. package/dist/switch/index.d.ts +24 -0
  82. package/dist/table/Table.js +63 -15
  83. package/dist/table/index.d.ts +13 -0
  84. package/dist/tabs/Tabs.js +208 -35
  85. package/dist/tabs/index.d.ts +19 -0
  86. package/dist/tag/Tag.js +100 -35
  87. package/dist/tag/index.d.ts +24 -0
  88. package/dist/text-input/TextInput.js +974 -0
  89. package/dist/text-input/index.d.ts +135 -0
  90. package/dist/textarea/Textarea.js +250 -107
  91. package/dist/textarea/index.d.ts +117 -0
  92. package/dist/toggle/Toggle.js +16 -19
  93. package/dist/toggle/index.d.ts +21 -0
  94. package/dist/toggle-group/ToggleGroup.js +327 -0
  95. package/dist/toggle-group/index.d.ts +21 -0
  96. package/dist/upload/Upload.js +13 -8
  97. package/dist/upload/buttons-upload/ButtonsUpload.js +35 -25
  98. package/dist/upload/buttons-upload/Icons.js +40 -0
  99. package/dist/upload/dragAndDropArea/DragAndDropArea.js +84 -37
  100. package/dist/upload/dragAndDropArea/Icons.js +39 -0
  101. package/dist/upload/file-upload/FileToUpload.js +64 -33
  102. package/dist/upload/file-upload/Icons.js +66 -0
  103. package/dist/upload/files-upload/FilesToUpload.js +16 -16
  104. package/dist/upload/index.d.ts +15 -0
  105. package/dist/upload/transaction/Icons.js +160 -0
  106. package/dist/upload/transaction/Transaction.js +42 -49
  107. package/dist/upload/transactions/Transactions.js +38 -20
  108. package/dist/useTheme.js +22 -0
  109. package/dist/wizard/Icons.js +65 -0
  110. package/dist/wizard/Wizard.js +156 -61
  111. package/dist/wizard/index.d.ts +18 -0
  112. package/package.json +26 -14
  113. package/test/AccordionGroup.test.js +125 -0
  114. package/test/Date.test.js +15 -13
  115. package/test/DateInput.test.js +242 -0
  116. package/test/Dropdown.test.js +19 -4
  117. package/test/FileInput.test.js +201 -0
  118. package/test/Footer.test.js +2 -7
  119. package/test/Header.test.js +5 -10
  120. package/test/Heading.test.js +60 -12
  121. package/test/InputText.test.js +31 -28
  122. package/test/Link.test.js +25 -7
  123. package/test/NumberInput.test.js +259 -0
  124. package/test/Paginator.test.js +76 -60
  125. package/test/PasswordInput.test.js +83 -0
  126. package/test/ResultsetTable.test.js +65 -17
  127. package/test/Select.test.js +869 -132
  128. package/test/Sidenav.test.js +22 -64
  129. package/test/Slider.test.js +24 -15
  130. package/test/Spinner.test.js +5 -0
  131. package/test/Tabs.test.js +21 -0
  132. package/test/TextInput.test.js +731 -0
  133. package/test/Textarea.test.js +193 -0
  134. package/test/ToggleGroup.test.js +85 -0
  135. package/test/Upload.test.js +1 -1
  136. package/test/V3Select.test.js +212 -0
  137. package/test/{TextArea.test.js → V3TextArea.test.js} +6 -7
  138. package/dist/accordion/Accordion.stories.js +0 -207
  139. package/dist/accordion/readme.md +0 -96
  140. package/dist/alert/Alert.stories.js +0 -158
  141. package/dist/alert/close.svg +0 -4
  142. package/dist/alert/error.svg +0 -4
  143. package/dist/alert/info.svg +0 -4
  144. package/dist/alert/readme.md +0 -43
  145. package/dist/alert/success.svg +0 -4
  146. package/dist/alert/warning.svg +0 -4
  147. package/dist/button/readme.md +0 -93
  148. package/dist/checkbox/Checkbox.stories.js +0 -144
  149. package/dist/checkbox/readme.md +0 -116
  150. package/dist/common/services/example-service.js +0 -10
  151. package/dist/common/services/example-service.test.js +0 -12
  152. package/dist/date/Date.stories.js +0 -205
  153. package/dist/date/calendar.svg +0 -1
  154. package/dist/date/calendar_dark.svg +0 -1
  155. package/dist/date/readme.md +0 -73
  156. package/dist/dialog/Dialog.stories.js +0 -217
  157. package/dist/dialog/readme.md +0 -32
  158. package/dist/dropdown/Dropdown.stories.js +0 -249
  159. package/dist/dropdown/baseline-arrow_drop_down.svg +0 -1
  160. package/dist/dropdown/baseline-arrow_drop_down_wh.svg +0 -4
  161. package/dist/dropdown/baseline-arrow_drop_up.svg +0 -1
  162. package/dist/dropdown/baseline-arrow_drop_up_wh.svg +0 -4
  163. package/dist/dropdown/readme.md +0 -69
  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.stories.js +0 -176
  168. package/dist/header/close_icon.svg +0 -1
  169. package/dist/header/dxc_logo_black.png +0 -0
  170. package/dist/header/dxc_logo_white.png +0 -0
  171. package/dist/header/hamb_menu_black.svg +0 -1
  172. package/dist/header/hamb_menu_white.svg +0 -1
  173. package/dist/header/readme.md +0 -33
  174. package/dist/input-text/InputText.stories.js +0 -209
  175. package/dist/input-text/error.svg +0 -1
  176. package/dist/input-text/readme.md +0 -91
  177. package/dist/link/readme.md +0 -51
  178. package/dist/paginator/images/next.svg +0 -3
  179. package/dist/paginator/images/nextPage.svg +0 -3
  180. package/dist/paginator/images/previous.svg +0 -3
  181. package/dist/paginator/images/previousPage.svg +0 -3
  182. package/dist/paginator/readme.md +0 -50
  183. package/dist/progress-bar/ProgressBar.stories.js +0 -280
  184. package/dist/progress-bar/readme.md +0 -63
  185. package/dist/radio/Radio.stories.js +0 -166
  186. package/dist/radio/readme.md +0 -70
  187. package/dist/resultsetTable/arrow_downward-24px_wht.svg +0 -1
  188. package/dist/resultsetTable/arrow_upward-24px_wht.svg +0 -1
  189. package/dist/resultsetTable/unfold_more-24px_wht.svg +0 -1
  190. package/dist/select/Select.stories.js +0 -235
  191. package/dist/select/readme.md +0 -72
  192. package/dist/sidenav/arrow_icon.svg +0 -3
  193. package/dist/slider/Slider.stories.js +0 -241
  194. package/dist/slider/readme.md +0 -64
  195. package/dist/spinner/Spinner.stories.js +0 -183
  196. package/dist/spinner/readme.md +0 -65
  197. package/dist/switch/Switch.stories.js +0 -134
  198. package/dist/switch/readme.md +0 -133
  199. package/dist/tabs/Tabs.stories.js +0 -130
  200. package/dist/tabs/readme.md +0 -78
  201. package/dist/tabs-for-sections/TabsForSections.js +0 -107
  202. package/dist/tabs-for-sections/readme.md +0 -78
  203. package/dist/toggle/Toggle.stories.js +0 -297
  204. package/dist/toggle/readme.md +0 -80
  205. package/dist/upload/Upload.stories.js +0 -72
  206. package/dist/upload/buttons-upload/drag-drop-icon.svg +0 -4
  207. package/dist/upload/buttons-upload/upload-button.svg +0 -1
  208. package/dist/upload/dragAndDropArea/upload_drop.svg +0 -4
  209. package/dist/upload/dragAndDropArea/upload_file.svg +0 -4
  210. package/dist/upload/file-upload/audio-icon.svg +0 -4
  211. package/dist/upload/file-upload/close.svg +0 -4
  212. package/dist/upload/file-upload/file-icon.svg +0 -4
  213. package/dist/upload/file-upload/video-icon.svg +0 -4
  214. package/dist/upload/readme.md +0 -37
  215. package/dist/upload/transaction/audio-icon-err.svg +0 -4
  216. package/dist/upload/transaction/audio-icon.svg +0 -4
  217. package/dist/upload/transaction/error-icon.svg +0 -4
  218. package/dist/upload/transaction/file-icon-err.svg +0 -4
  219. package/dist/upload/transaction/file-icon.svg +0 -4
  220. package/dist/upload/transaction/image-icon-err.svg +0 -4
  221. package/dist/upload/transaction/image-icon.svg +0 -4
  222. package/dist/upload/transaction/success-icon.svg +0 -4
  223. package/dist/upload/transaction/video-icon-err.svg +0 -4
  224. package/dist/upload/transaction/video-icon.svg +0 -4
  225. package/dist/wizard/invalid_icon.svg +0 -6
  226. package/dist/wizard/valid_icon.svg +0 -6
  227. package/dist/wizard/validation-wrong.svg +0 -6
  228. package/test/TabsForSections.test.js +0 -34
  229. package/test/Toggle.test.js +0 -43
@@ -0,0 +1,65 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+
5
+ Object.defineProperty(exports, "__esModule", {
6
+ value: true
7
+ });
8
+ exports.validIcon = exports.invalidIcon = void 0;
9
+
10
+ var _react = _interopRequireDefault(require("react"));
11
+
12
+ var invalidIcon = _react["default"].createElement("svg", {
13
+ id: "highlight_off_black_18dp",
14
+ xmlns: "http://www.w3.org/2000/svg",
15
+ width: "18",
16
+ height: "18",
17
+ viewBox: "0 0 18 18"
18
+ }, _react["default"].createElement("path", {
19
+ id: "Path_2943",
20
+ "data-name": "Path 2943",
21
+ d: "M0,0H18V18H0Z",
22
+ fill: "none"
23
+ }), _react["default"].createElement("path", {
24
+ id: "Path_2944",
25
+ "data-name": "Path 2944",
26
+ d: "M10,4a6,6,0,1,0,6,6A6.01,6.01,0,0,0,10,4Zm3,7.945L11.945,13,10,11.06,8.059,13,7,11.945,8.944,10,7,8.059,8.059,7,10,8.944,11.945,7,13,8.059,11.06,10Z",
27
+ transform: "translate(-1.002 -1.002)",
28
+ fill: "#ffe6e9"
29
+ }), _react["default"].createElement("path", {
30
+ id: "Path_2945",
31
+ "data-name": "Path 2945",
32
+ d: "M11.444,6.5,9.5,8.443,7.558,6.5,6.5,7.558,8.443,9.5,6.5,11.444,7.558,12.5,9.5,10.558,11.444,12.5,12.5,11.444,10.558,9.5,12.5,7.558ZM9.5,2A7.5,7.5,0,1,0,17,9.5,7.494,7.494,0,0,0,9.5,2Zm0,13.5a6,6,0,1,1,6-6A6.009,6.009,0,0,1,9.5,15.5Z",
33
+ transform: "translate(-0.501 -0.501)",
34
+ fill: "#d0011b"
35
+ }));
36
+
37
+ exports.invalidIcon = invalidIcon;
38
+
39
+ var validIcon = _react["default"].createElement("svg", {
40
+ id: "check_circle_black_18dp",
41
+ xmlns: "http://www.w3.org/2000/svg",
42
+ width: "18",
43
+ height: "18",
44
+ viewBox: "0 0 18 18"
45
+ }, _react["default"].createElement("path", {
46
+ id: "Path_2946",
47
+ "data-name": "Path 2946",
48
+ d: "M0,0H18V18H0Z",
49
+ fill: "none"
50
+ }), _react["default"].createElement("path", {
51
+ id: "Path_2947",
52
+ "data-name": "Path 2947",
53
+ d: "M9.986,4a5.986,5.986,0,1,0,5.986,5.986A5.994,5.994,0,0,0,9.986,4Zm-1.5,9.727L5.5,10.734,6.551,9.679l1.938,1.93L13.42,6.679l1.055,1.063Z",
54
+ transform: "translate(-0.986 -0.986)",
55
+ fill: "#eafaef",
56
+ opacity: "0.999"
57
+ }), _react["default"].createElement("path", {
58
+ id: "Path_2948",
59
+ "data-name": "Path 2948",
60
+ d: "M9.493,2a7.493,7.493,0,1,0,7.493,7.493A7.5,7.5,0,0,0,9.493,2Zm0,13.487a5.994,5.994,0,1,1,5.994-5.994A6,6,0,0,1,9.493,15.487Zm3.439-9.306L7.994,11.119,6.054,9.186,5,10.242l3,3,5.994-5.994Z",
61
+ transform: "translate(-0.493 -0.493)",
62
+ fill: "#24a148"
63
+ }));
64
+
65
+ exports.validIcon = validIcon;
@@ -1,5 +1,7 @@
1
1
  "use strict";
2
2
 
3
+ var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard");
4
+
3
5
  var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
6
 
5
7
  Object.defineProperty(exports, "__esModule", {
@@ -9,26 +11,46 @@ exports["default"] = void 0;
9
11
 
10
12
  var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray"));
11
13
 
12
- var _typeof2 = _interopRequireDefault(require("@babel/runtime/helpers/typeof"));
13
-
14
14
  var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
15
15
 
16
+ var _typeof2 = _interopRequireDefault(require("@babel/runtime/helpers/typeof"));
17
+
16
18
  var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
17
19
 
18
- var _react = _interopRequireDefault(require("react"));
20
+ var _react = _interopRequireWildcard(require("react"));
19
21
 
20
- var _styledComponents = _interopRequireDefault(require("styled-components"));
22
+ var _styledComponents = _interopRequireWildcard(require("styled-components"));
21
23
 
22
24
  var _propTypes = _interopRequireDefault(require("prop-types"));
23
25
 
24
26
  var _variables = require("../common/variables.js");
25
27
 
26
- var _valid_icon = _interopRequireDefault(require("./valid_icon.svg"));
28
+ var _useTheme = _interopRequireDefault(require("../useTheme.js"));
29
+
30
+ var _Icons = require("./Icons");
31
+
32
+ function _templateObject14() {
33
+ var data = (0, _taggedTemplateLiteral2["default"])(["\n width: ", ";\n height: ", ";\n ", "\n border: ", ";\n opacity: 1;\n flex-grow: 1;\n"]);
34
+
35
+ _templateObject14 = function _templateObject14() {
36
+ return data;
37
+ };
38
+
39
+ return data;
40
+ }
41
+
42
+ function _templateObject13() {
43
+ var data = (0, _taggedTemplateLiteral2["default"])(["\n text-align: ", ";\n font-family: ", ";\n font-size: ", ";\n font-style: ", ";\n font-weight: ", ";\n letter-spacing: ", ";\n text-transform: ", ";\n ", ";\n margin: 0;\n"]);
27
44
 
28
- var _invalid_icon = _interopRequireDefault(require("./invalid_icon.svg"));
45
+ _templateObject13 = function _templateObject13() {
46
+ return data;
47
+ };
48
+
49
+ return data;
50
+ }
29
51
 
30
52
  function _templateObject12() {
31
- var data = (0, _taggedTemplateLiteral2["default"])(["\n width: ", ";\n height: ", ";\n ", "\n border: 1px solid #D9D9D9;\n opacity: 1;\n flex-grow: 1;\n"]);
53
+ var data = (0, _taggedTemplateLiteral2["default"])(["\n text-align: ", ";\n font-family: ", ";\n font-size: ", ";\n font-style: ", ";\n font-weight: ", ";\n letter-spacing: ", ";\n ", ";\n text-transform: ", ";\n margin: 0;\n"]);
32
54
 
33
55
  _templateObject12 = function _templateObject12() {
34
56
  return data;
@@ -38,7 +60,7 @@ function _templateObject12() {
38
60
  }
39
61
 
40
62
  function _templateObject11() {
41
- var data = (0, _taggedTemplateLiteral2["default"])(["\n text-align: left;\n font: Lighter 12px/17px Open Sans;\n letter-spacing: 0.58px;\n color: inherit;\n margin: 0;\n"]);
63
+ var data = (0, _taggedTemplateLiteral2["default"])(["\n margin-left: 12px;\n"]);
42
64
 
43
65
  _templateObject11 = function _templateObject11() {
44
66
  return data;
@@ -48,7 +70,7 @@ function _templateObject11() {
48
70
  }
49
71
 
50
72
  function _templateObject10() {
51
- var data = (0, _taggedTemplateLiteral2["default"])(["\n text-align: left;\n font: Normal 16px/22px Open Sans;\n letter-spacing: 0.77px;\n color: inherit;\n margin: 0;\n"]);
73
+ var data = (0, _taggedTemplateLiteral2["default"])(["\n width: 18px;\n height: 18px;\n position: absolute;\n top: 22.5px;\n left: 22.5px;\n"]);
52
74
 
53
75
  _templateObject10 = function _templateObject10() {
54
76
  return data;
@@ -58,7 +80,7 @@ function _templateObject10() {
58
80
  }
59
81
 
60
82
  function _templateObject9() {
61
- var data = (0, _taggedTemplateLiteral2["default"])(["\n margin-left: 10px;\n color: ", ";\n"]);
83
+ var data = (0, _taggedTemplateLiteral2["default"])(["\n font-size: ", ";\n font-family: ", ";\n font-style: ", ";\n font-weight: ", ";\n letter-spacing: ", ";\n opacity: 1;\n margin: 0px 0px 0px 1px;\n"]);
62
84
 
63
85
  _templateObject9 = function _templateObject9() {
64
86
  return data;
@@ -68,7 +90,7 @@ function _templateObject9() {
68
90
  }
69
91
 
70
92
  function _templateObject8() {
71
- var data = (0, _taggedTemplateLiteral2["default"])(["\n width: 18px;\n height: 18px;\n position: absolute;\n bottom: 0px;\n right: 0px;\n"]);
93
+ var data = (0, _taggedTemplateLiteral2["default"])(["\n background-color: ", ";\n mask: url(", ") no-repeat center;\n mask-size: ", ";\n height: ", ";\n width: ", ";\n"]);
72
94
 
73
95
  _templateObject8 = function _templateObject8() {
74
96
  return data;
@@ -78,7 +100,7 @@ function _templateObject8() {
78
100
  }
79
101
 
80
102
  function _templateObject7() {
81
- var data = (0, _taggedTemplateLiteral2["default"])(["\n font: Normal 16px/22px Open Sans;\n letter-spacing: 0.77px;\n color: ", ";\n opacity: 1;\n margin: 0;\n"]);
103
+ var data = (0, _taggedTemplateLiteral2["default"])(["\n width: ", ";\n height: ", ";\n overflow: hidden;\n img,\n svg {\n height: 100%;\n width: 100%;\n }\n"]);
82
104
 
83
105
  _templateObject7 = function _templateObject7() {
84
106
  return data;
@@ -88,7 +110,7 @@ function _templateObject7() {
88
110
  }
89
111
 
90
112
  function _templateObject6() {
91
- var data = (0, _taggedTemplateLiteral2["default"])(["\n width: 19px;\n height: 19px;\n"]);
113
+ var data = (0, _taggedTemplateLiteral2["default"])(["\n width: ", ";\n height: ", ";\n"]);
92
114
 
93
115
  _templateObject6 = function _templateObject6() {
94
116
  return data;
@@ -98,7 +120,7 @@ function _templateObject6() {
98
120
  }
99
121
 
100
122
  function _templateObject5() {
101
- var data = (0, _taggedTemplateLiteral2["default"])(["\n width: ", ";\n height: ", ";\n\n ", "\n\n ", "\n\n ", "\n\n border-radius: 45px;\n\n display: flex;\n justify-content: center;\n align-items: center;\n"]);
123
+ var data = (0, _taggedTemplateLiteral2["default"])(["\n width: ", ";\n height: ", ";\n\n ", "\n ", ";\n\n border-radius: ", ";\n display: flex;\n justify-content: center;\n align-items: center;\n"]);
102
124
 
103
125
  _templateObject5 = function _templateObject5() {
104
126
  return data;
@@ -108,7 +130,7 @@ function _templateObject5() {
108
130
  }
109
131
 
110
132
  function _templateObject4() {
111
- var data = (0, _taggedTemplateLiteral2["default"])(["\n position: relative;\n display: inline-flex;\n padding-bottom: 3px;\n"]);
133
+ var data = (0, _taggedTemplateLiteral2["default"])(["\n position: relative;\n display: inline-flex;\n padding-bottom: 4px;\n"]);
112
134
 
113
135
  _templateObject4 = function _templateObject4() {
114
136
  return data;
@@ -118,7 +140,7 @@ function _templateObject4() {
118
140
  }
119
141
 
120
142
  function _templateObject3() {
121
- var data = (0, _taggedTemplateLiteral2["default"])(["\n border: none;\n background: inherit;\n display: flex;\n justify-content: flex-start;\n align-items: center;\n margin: ", ";\n\n padding: 0px;\n ", ";\n\n &:focus {\n outline: none;\n }\n\n &:hover {\n ", ";\n }\n"]);
143
+ var data = (0, _taggedTemplateLiteral2["default"])(["\n border: none;\n background: inherit;\n display: flex;\n justify-content: flex-start;\n align-items: center;\n margin: ", ";\n\n padding: 0px;\n ", ";\n\n &:hover {\n ", ";\n }\n &:focus {\n outline: ", " auto 1px;\n }\n"]);
122
144
 
123
145
  _templateObject3 = function _templateObject3() {
124
146
  return data;
@@ -128,7 +150,7 @@ function _templateObject3() {
128
150
  }
129
151
 
130
152
  function _templateObject2() {
131
- var data = (0, _taggedTemplateLiteral2["default"])(["\n display: inline-flex;\n ", "\n flex-grow: ", ";\n flex-direction: ", ";\n ", "\n \n"]);
153
+ var data = (0, _taggedTemplateLiteral2["default"])(["\n display: inline-flex;\n ", "\n flex-grow: ", ";\n flex-direction: ", ";\n ", "\n"]);
132
154
 
133
155
  _templateObject2 = function _templateObject2() {
134
156
  return data;
@@ -138,7 +160,7 @@ function _templateObject2() {
138
160
  }
139
161
 
140
162
  function _templateObject() {
141
- var data = (0, _taggedTemplateLiteral2["default"])(["\n display: inline-flex;\n flex-direction: ", ";\n justify-content: \"center\";\n ", ";\n\n margin: ", ";\n margin-top: ", ";\n margin-right: ", ";\n margin-bottom: ", ";\n margin-left: ", ";\n"]);
163
+ var data = (0, _taggedTemplateLiteral2["default"])(["\n display: inline-flex;\n flex-direction: ", ";\n justify-content: \"center\";\n ", ";\n font-family: ", ";\n\n margin: ", ";\n margin-top: ", ";\n margin-right: ", ";\n margin-bottom: ", ";\n margin-left: ", ";\n"]);
142
164
 
143
165
  _templateObject = function _templateObject() {
144
166
  return data;
@@ -150,19 +172,20 @@ function _templateObject() {
150
172
  var DxcWizard = function DxcWizard(_ref) {
151
173
  var _ref$mode = _ref.mode,
152
174
  mode = _ref$mode === void 0 ? "horizontal" : _ref$mode,
153
- _ref$theme = _ref.theme,
154
- theme = _ref$theme === void 0 ? "light" : _ref$theme,
155
175
  currentStep = _ref.currentStep,
156
176
  onStepClick = _ref.onStepClick,
157
177
  steps = _ref.steps,
158
- margin = _ref.margin;
178
+ margin = _ref.margin,
179
+ _ref$tabIndex = _ref.tabIndex,
180
+ tabIndex = _ref$tabIndex === void 0 ? 0 : _ref$tabIndex;
159
181
 
160
- var _React$useState = _react["default"].useState(currentStep || 0),
161
- _React$useState2 = (0, _slicedToArray2["default"])(_React$useState, 2),
162
- innerCurrent = _React$useState2[0],
163
- setInnerCurrentStep = _React$useState2[1];
182
+ var _useState = (0, _react.useState)(currentStep || 0),
183
+ _useState2 = (0, _slicedToArray2["default"])(_useState, 2),
184
+ innerCurrent = _useState2[0],
185
+ setInnerCurrentStep = _useState2[1];
164
186
 
165
187
  var renderedCurrent = currentStep == null ? innerCurrent : currentStep;
188
+ var colorsTheme = (0, _useTheme["default"])();
166
189
 
167
190
  var handleStepClick = function handleStepClick(newValue) {
168
191
  if (currentStep == null) {
@@ -174,7 +197,9 @@ var DxcWizard = function DxcWizard(_ref) {
174
197
  }
175
198
  };
176
199
 
177
- return _react["default"].createElement(StepsContainer, {
200
+ return _react["default"].createElement(_styledComponents.ThemeProvider, {
201
+ theme: colorsTheme.wizard
202
+ }, _react["default"].createElement(StepsContainer, {
178
203
  mode: mode,
179
204
  margin: margin
180
205
  }, steps.map(function (step, i) {
@@ -183,42 +208,46 @@ var DxcWizard = function DxcWizard(_ref) {
183
208
  mode: mode,
184
209
  lastStep: i === steps.length - 1
185
210
  }, _react["default"].createElement(Step, {
211
+ tabIndex: tabIndex,
186
212
  onClick: function onClick() {
187
213
  return handleStepClick(i);
188
214
  },
189
215
  mode: mode,
190
- disable: step.disabled,
191
216
  disabled: step.disabled,
192
217
  first: i === 0,
193
218
  last: i === steps.length - 1
194
219
  }, _react["default"].createElement(StepHeader, null, _react["default"].createElement(IconContainer, {
195
220
  current: i === renderedCurrent,
196
221
  visited: i < renderedCurrent,
197
- brightness: theme,
198
222
  disabled: step.disabled
199
- }, step.iconSrc ? _react["default"].createElement(Icon, {
223
+ }, step.icon ? _react["default"].createElement(StepIconContainer, {
224
+ disabled: step.disabled
225
+ }, (0, _typeof2["default"])(step.icon) === "object" ? step.icon.type === "img" ? _react["default"].createElement(ImgContainer, {
226
+ current: i === renderedCurrent,
227
+ img: step.icon.props.src
228
+ }) : step.icon : _react["default"].createElement(step.icon)) : step.iconSrc ? _react["default"].createElement(Icon, {
200
229
  src: step.iconSrc
201
230
  }) : _react["default"].createElement(Number, {
202
231
  disabled: step.disabled,
203
- current: i === renderedCurrent,
204
- brightness: theme
205
- }, i + 1)), step.valid !== undefined ? step.valid ? _react["default"].createElement(ValidityIcon, {
206
- src: _valid_icon["default"]
207
- }) : _react["default"].createElement(ValidityIcon, {
208
- src: _invalid_icon["default"]
209
- }) : ''), step.label || step.description ? _react["default"].createElement(InfoContainer, {
210
- active: i <= innerCurrent,
211
- brightness: theme
212
- }, step.label ? _react["default"].createElement(Label, null, step.label) : '', step.description ? _react["default"].createElement(Description, null, step.description) : '') : ''), i === steps.length - 1 ? '' : _react["default"].createElement(StepSeparator, {
232
+ current: i === renderedCurrent
233
+ }, i + 1)), step.valid !== undefined ? step.valid ? _react["default"].createElement(ValidityIconContainer, null, _Icons.validIcon) : _react["default"].createElement(ValidityIconContainer, null, _Icons.invalidIcon) : ""), step.label || step.description ? _react["default"].createElement(InfoContainer, null, step.label ? _react["default"].createElement(Label, {
234
+ disabled: step.disabled,
235
+ visited: i <= innerCurrent
236
+ }, step.label) : "", step.description ? _react["default"].createElement(Description, {
237
+ disabled: step.disabled,
238
+ visited: i <= innerCurrent
239
+ }, step.description) : "") : ""), i === steps.length - 1 ? "" : _react["default"].createElement(StepSeparator, {
213
240
  mode: mode
214
241
  }));
215
- }));
242
+ })));
216
243
  };
217
244
 
218
245
  var StepsContainer = _styledComponents["default"].div(_templateObject(), function (props) {
219
246
  return props.mode === "vertical" ? "column" : "row";
220
247
  }, function (props) {
221
248
  return props.mode === "vertical" ? "height: 500px" : "width: 100%";
249
+ }, function (props) {
250
+ return props.theme.fontFamily;
222
251
  }, function (props) {
223
252
  return props.margin && (0, _typeof2["default"])(props.margin) !== "object" ? _variables.spaces[props.margin] : "0px";
224
253
  }, function (props) {
@@ -242,59 +271,124 @@ var StepContainer = _styledComponents["default"].div(_templateObject2(), functio
242
271
  });
243
272
 
244
273
  var Step = _styledComponents["default"].button(_templateObject3(), function (props) {
245
- return props.first ? props.mode === "vertical" ? "0 0 25px 0" : "0 25px 0 0" : props.last ? props.mode === "vertical" ? "25px 0 0 0" : "0 0 0 25px" : props.mode === "vertical" ? "25px 0" : "0 25px";
274
+ return props.first ? props.mode === "vertical" ? "0 0 24px 0" : "0 24px 0 0" : props.last ? props.mode === "vertical" ? "24px 0 0 0" : "0 0 0 24px" : props.mode === "vertical" ? "24px 0" : "0 24px";
246
275
  }, function (props) {
247
- return props.disabled ? "cursor: not-allowed" : '';
276
+ return props.disabled ? "cursor: not-allowed" : "";
248
277
  }, function (props) {
249
278
  return props.disabled ? "" : "cursor: pointer";
279
+ }, function (props) {
280
+ return props.theme.focusColor;
250
281
  });
251
282
 
252
283
  var StepHeader = _styledComponents["default"].div(_templateObject4());
253
284
 
254
285
  var IconContainer = _styledComponents["default"].div(_templateObject5(), function (props) {
255
- return !props.current && !props.disabled ? "32px" : "36px";
286
+ return props.disabled ? props.theme.disabledCircleWidth : props.current ? props.theme.selectedCircleWidth : props.theme.circleWidth;
256
287
  }, function (props) {
257
- return !props.current && !props.disabled ? "32px" : "36px";
288
+ return props.disabled ? props.theme.disabledCircleHeight : props.current ? props.theme.selectedCircleHeight : props.theme.circleHeight;
258
289
  }, function (props) {
259
- return !props.current && !props.disabled ? "border: 2px solid ".concat(props.brightness === "light" ? '#000000' : '#FFFFFF', ";") : "";
290
+ return "\n ".concat(!props.current && !props.disabled ? "border: ".concat(props.theme.circleBorderThickness, " ").concat(props.theme.circleBorderStyle, " ").concat(props.theme.circleBorderColor, ";") : props.current ? "border: ".concat(props.theme.selectedCircleBorderThickness, " ").concat(props.theme.selectedCircleBorderStyle, " ").concat(props.theme.selectedCircleBorderColor, ";") : props.disabled ? "border: ".concat(props.theme.disabledCircleBorderThickness, " ").concat(props.theme.disabledCircleBorderStyle, " ").concat(props.theme.disabledCircleBorderColor, ";") : "", "\n background: ").concat(props.disabled ? "".concat(props.theme.disabledBackgroundColor) : props.current ? "".concat(props.theme.stepContainerSelectedBackgroundColor) : "".concat(props.theme.stepContainerBackgroundColor), ";\n ");
260
291
  }, function (props) {
261
- return props.disabled ? "background: #D9D9D9 0% 0% no-repeat padding-box;" : "";
292
+ return props.disabled ? "color: ".concat(props.theme.disabledFontColor, ";") : "color: ".concat(props.current ? props.theme.stepContainerSelectedFontColor : props.theme.stepContainerFontColor, ";");
262
293
  }, function (props) {
263
- return props.current ? "background: #FFED00 0% 0% no-repeat padding-box;" : '';
294
+ return !props.current && !props.disabled ? props.theme.circleBorderRadius : props.current ? props.theme.selectedCircleBorderRadius : props.disabled ? props.theme.disabledCircleBorderRadius : "";
264
295
  });
265
296
 
266
- var Icon = _styledComponents["default"].img(_templateObject6());
297
+ var Icon = _styledComponents["default"].img(_templateObject6(), function (props) {
298
+ return props.theme.stepContainerIconSize;
299
+ }, function (props) {
300
+ return props.theme.stepContainerIconSize;
301
+ });
267
302
 
268
- var Number = _styledComponents["default"].p(_templateObject7(), function (props) {
269
- return !props.current && !props.disabled ? props.brightness === "light" ? '#000000' : '#FFFFFF' : props.current ? '#000000' : '#666666';
303
+ var StepIconContainer = _styledComponents["default"].div(_templateObject7(), function (props) {
304
+ return props.theme.stepContainerIconSize;
305
+ }, function (props) {
306
+ return props.theme.stepContainerIconSize;
270
307
  });
271
308
 
272
- var ValidityIcon = _styledComponents["default"].img(_templateObject8());
309
+ var ImgContainer = _styledComponents["default"].div(_templateObject8(), function (props) {
310
+ return props.current ? props.theme.stepContainerSelectedFontColor : props.theme.stepContainerFontColor;
311
+ }, function (_ref2) {
312
+ var img = _ref2.img;
313
+ return img;
314
+ }, function (props) {
315
+ return "".concat(props.theme.stepContainerIconSize, " ").concat(props.theme.stepContainerIconSize);
316
+ }, function (props) {
317
+ return props.theme.stepContainerIconSize;
318
+ }, function (props) {
319
+ return props.theme.stepContainerIconSize;
320
+ });
273
321
 
274
- var InfoContainer = _styledComponents["default"].div(_templateObject9(), function (props) {
275
- return props.brightness === "light" ? props.active ? '#000000' : '#666666' : props.active ? "#FFFFFF" : "#D9D9D9";
322
+ var Number = _styledComponents["default"].p(_templateObject9(), function (props) {
323
+ return props.theme.stepContainerFontSize;
324
+ }, function (props) {
325
+ return props.theme.stepContainerFontFamily;
326
+ }, function (props) {
327
+ return props.theme.stepContainerFontStyle;
328
+ }, function (props) {
329
+ return props.theme.stepContainerFontWeight;
330
+ }, function (props) {
331
+ return props.theme.stepContainerLetterSpacing;
276
332
  });
277
333
 
278
- var Label = _styledComponents["default"].p(_templateObject10());
334
+ var ValidityIconContainer = _styledComponents["default"].div(_templateObject10());
335
+
336
+ var InfoContainer = _styledComponents["default"].div(_templateObject11());
337
+
338
+ var Label = _styledComponents["default"].p(_templateObject12(), function (props) {
339
+ return props.theme.labelTextAlign;
340
+ }, function (props) {
341
+ return props.theme.labelFontFamily;
342
+ }, function (props) {
343
+ return props.theme.labelFontSize;
344
+ }, function (props) {
345
+ return props.theme.labelFontStyle;
346
+ }, function (props) {
347
+ return props.theme.labelFontWeight;
348
+ }, function (props) {
349
+ return props.theme.labelLetterSpacing;
350
+ }, function (props) {
351
+ return props.disabled ? "color: ".concat(props.theme.disabledFontColor, ";") : "color: ".concat(props.visited ? props.theme.visitedLabelFontColor : props.theme.labelFontColor, ";");
352
+ }, function (props) {
353
+ return props.theme.labelFontTextTransform;
354
+ });
279
355
 
280
- var Description = _styledComponents["default"].p(_templateObject11());
356
+ var Description = _styledComponents["default"].p(_templateObject13(), function (props) {
357
+ return props.theme.descriptionTextAlign;
358
+ }, function (props) {
359
+ return props.theme.descriptionFontFamily;
360
+ }, function (props) {
361
+ return props.theme.descriptionFontSize;
362
+ }, function (props) {
363
+ return props.theme.descriptionFontStyle;
364
+ }, function (props) {
365
+ return props.theme.descriptionFontWeight;
366
+ }, function (props) {
367
+ return props.theme.descriptionLetterSpacing;
368
+ }, function (props) {
369
+ return props.theme.descriptionFontTextTransform;
370
+ }, function (props) {
371
+ return props.disabled ? "color: ".concat(props.theme.disabledFontColor, ";") : "color: ".concat(props.visited ? props.theme.visitedDescriptionFontColor : props.theme.descriptionFontColor, ";");
372
+ });
281
373
 
282
- var StepSeparator = _styledComponents["default"].div(_templateObject12(), function (props) {
283
- return props.mode === "horizontal" ? '' : '0';
374
+ var StepSeparator = _styledComponents["default"].div(_templateObject14(), function (props) {
375
+ return props.mode === "horizontal" ? "" : "0";
376
+ }, function (props) {
377
+ return props.mode === "horizontal" ? "0" : "";
284
378
  }, function (props) {
285
- return props.mode === "horizontal" ? '0' : '';
379
+ return props.mode === "vertical" ? "margin: 0 18px;" : "";
286
380
  }, function (props) {
287
- return props.mode === "vertical" ? "margin: 0 18px;" : '';
381
+ return "".concat(props.theme.separatorBorderStyle, " ").concat(props.theme.separatorBorderThickness, " ").concat(props.theme.separatorColor);
288
382
  });
289
383
 
290
384
  DxcWizard.propTypes = {
291
385
  mode: _propTypes["default"].oneOf(["horizontal", "vertical"]),
292
- theme: _propTypes["default"].oneOf(["light", "dark"]),
293
386
  currentStep: _propTypes["default"].number,
294
387
  onStepClick: _propTypes["default"].func,
295
388
  steps: _propTypes["default"].arrayOf(_propTypes["default"].shape({
296
389
  label: _propTypes["default"].string,
297
390
  description: _propTypes["default"].string,
391
+ icon: _propTypes["default"].oneOfType([_propTypes["default"].element, _propTypes["default"].func]),
298
392
  iconSrc: _propTypes["default"].string,
299
393
  disabled: _propTypes["default"].bool,
300
394
  valid: _propTypes["default"].bool
@@ -304,7 +398,8 @@ DxcWizard.propTypes = {
304
398
  bottom: _propTypes["default"].oneOf(Object.keys(_variables.spaces)),
305
399
  left: _propTypes["default"].oneOf(Object.keys(_variables.spaces)),
306
400
  right: _propTypes["default"].oneOf(Object.keys(_variables.spaces))
307
- }), _propTypes["default"].oneOf((0, _toConsumableArray2["default"])(Object.keys(_variables.spaces)))])
401
+ }), _propTypes["default"].oneOf((0, _toConsumableArray2["default"])(Object.keys(_variables.spaces)))]),
402
+ tabIndex: _propTypes["default"].number
308
403
  };
309
404
  var _default = DxcWizard;
310
405
  exports["default"] = _default;
@@ -0,0 +1,18 @@
1
+ type Space = "xxsmall" | "xsmall" | "small" | "medium" | "large" | "xlarge" | "xxlarge";
2
+ type Margin = {
3
+ top?: Space;
4
+ bottom?: Space;
5
+ left?: Space;
6
+ right?: Space;
7
+ };
8
+
9
+ type Props = {
10
+ mode?: "horizontal" | "vertical";
11
+ currentStep?: number;
12
+ onStepClick?: void;
13
+ steps?: any;
14
+ margin?: Space | Margin;
15
+ tabIndex?: number;
16
+ };
17
+
18
+ export default function DxcWizard(props: Props): JSX.Element;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@dxc-technology/halstack-react",
3
- "version": "0.0.0-eb2a4cc",
3
+ "version": "0.0.0-ebb089f",
4
4
  "description": "DXC Halstack React components library",
5
5
  "repository": "dxc-technology/halstack-react",
6
6
  "homepage": "http://developer.dxc.com/tools/react",
@@ -11,39 +11,52 @@
11
11
  "url": "https://dxc.com"
12
12
  },
13
13
  "main": "./dist/main.js",
14
+ "types": "./dist/main.d.ts",
14
15
  "peerDependencies": {
15
- "react": "^16.8.6",
16
- "react-dom": "^16.8.6",
17
- "styled-components": ">= 4.3.1"
16
+ "react": "^17.0.1",
17
+ "react-dom": "^17.0.1",
18
+ "styled-components": "^5.0.1"
18
19
  },
19
20
  "dependencies": {
20
21
  "@date-io/date-fns": "^1.3.9",
21
- "@material-ui/core": "4.1.1",
22
+ "@material-ui/core": "4.11.1",
22
23
  "@material-ui/icons": "4.4.3",
23
- "@material-ui/lab": "4.0.0-alpha.16",
24
+ "@material-ui/lab": "4.0.0-alpha.17",
24
25
  "@material-ui/pickers": "3.2.2",
25
26
  "@material-ui/styles": "4.0.2",
27
+ "@testing-library/user-event": "^12.6.3",
28
+ "color": "^3.1.3",
26
29
  "date-fns": "^2.0.0-beta.4",
27
30
  "moment": "2.24.0",
28
31
  "prop-types": "^15.7.2",
29
- "react-use-scrollspy": "^2.0.0"
32
+ "rgb-hex": "^3.0.0",
33
+ "uuid": "^8.3.2"
30
34
  },
31
35
  "scripts": {
32
36
  "test": "jest",
33
37
  "test:watch": "npm test -- --watch --coverage",
34
38
  "build": "babel src --out-dir dist --copy-files --verbose && node ../scripts/build/copy-readme.js",
35
- "build:watch": "babel src --watch --out-dir dist --copy-files --verbose"
39
+ "build:watch": "babel src --watch --out-dir dist --copy-files --verbose",
40
+ "storybook": "start-storybook -p 6006",
41
+ "build-storybook": "build-storybook"
36
42
  },
37
43
  "devDependencies": {
38
44
  "@babel/cli": "^7.6.2",
39
45
  "@babel/core": "^7.6.2",
40
46
  "@babel/plugin-proposal-class-properties": "^7.5.5",
47
+ "@babel/plugin-proposal-nullish-coalescing-operator": "7.13.8",
48
+ "@babel/plugin-proposal-optional-chaining": "7.13.8",
41
49
  "@babel/plugin-transform-runtime": "^7.10.1",
42
50
  "@babel/preset-env": "^7.6.2",
43
51
  "@babel/preset-react": "^7.0.0",
44
- "@testing-library/react": "^10.0.2",
52
+ "@storybook/addon-actions": "^6.4.9",
53
+ "@storybook/addon-essentials": "^6.4.9",
54
+ "@storybook/addon-links": "^6.4.9",
55
+ "@storybook/react": "^6.4.9",
56
+ "@testing-library/react": "^11.2.5",
45
57
  "babel-jest": "^24.8.0",
46
58
  "babel-loader": "^8.0.6",
59
+ "chromatic": "^6.3.3",
47
60
  "eslint": "^5.16.0",
48
61
  "eslint-config-airbnb": "^17.1.0",
49
62
  "eslint-config-prettier": "^6.7.0",
@@ -51,11 +64,13 @@
51
64
  "eslint-plugin-jest": "^22.7.1",
52
65
  "eslint-plugin-jsx-a11y": "^6.2.1",
53
66
  "eslint-plugin-react": "^7.13.0",
67
+ "eslint-plugin-react-hooks": "^4.2.0",
68
+ "eslint-plugin-storybook": "^0.5.5",
54
69
  "identity-obj-proxy": "^3.0.0",
55
70
  "jest": "^25.5.4",
56
- "react-test-renderer": "^16.8.6",
57
71
  "react": "file:../node_modules/react",
58
72
  "react-dom": "file:../node_modules/react-dom",
73
+ "react-test-renderer": "^16.8.6",
59
74
  "styled-components": "file:../node_modules/styled-components"
60
75
  },
61
76
  "jest": {
@@ -63,9 +78,6 @@
63
78
  "\\.(css|less|scss|sass)$": "identity-obj-proxy",
64
79
  "\\.(svg)$": "<rootDir>/test/mocks/svgMock.js",
65
80
  "\\.(png)$": "<rootDir>/test/mocks/pngMock.js"
66
- },
67
- "transformIgnorePatterns": [
68
- "/node_modules/(?!react-use-scrollspy).+\\.js$"
69
- ]
81
+ }
70
82
  }
71
83
  }