@dxc-technology/halstack-react 0.0.0-c908d78 → 0.0.0-c9b5c13

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 (291) hide show
  1. package/BackgroundColorContext.d.ts +10 -0
  2. package/BackgroundColorContext.js +1 -4
  3. package/HalstackContext.d.ts +12 -0
  4. package/HalstackContext.js +295 -0
  5. package/accordion/Accordion.d.ts +1 -1
  6. package/accordion/Accordion.js +15 -47
  7. package/accordion/Accordion.stories.tsx +307 -0
  8. package/accordion/Accordion.test.js +72 -0
  9. package/accordion/types.d.ts +8 -8
  10. package/accordion-group/AccordionGroup.d.ts +1 -1
  11. package/accordion-group/AccordionGroup.js +15 -17
  12. package/accordion-group/AccordionGroup.stories.tsx +225 -0
  13. package/accordion-group/AccordionGroup.test.js +151 -0
  14. package/accordion-group/types.d.ts +8 -8
  15. package/alert/Alert.js +6 -3
  16. package/alert/Alert.stories.tsx +170 -0
  17. package/alert/Alert.test.js +92 -0
  18. package/alert/types.d.ts +1 -1
  19. package/badge/Badge.d.ts +4 -0
  20. package/badge/Badge.js +6 -4
  21. package/badge/types.d.ts +5 -0
  22. package/{radio → badge}/types.js +0 -0
  23. package/bleed/Bleed.d.ts +3 -0
  24. package/bleed/Bleed.js +84 -0
  25. package/bleed/Bleed.stories.tsx +342 -0
  26. package/bleed/types.d.ts +37 -0
  27. package/bleed/types.js +5 -0
  28. package/box/Box.d.ts +1 -1
  29. package/box/Box.js +26 -39
  30. package/box/Box.test.js +18 -0
  31. package/box/types.d.ts +0 -4
  32. package/button/Button.d.ts +1 -1
  33. package/button/Button.js +24 -27
  34. package/button/Button.stories.tsx +222 -241
  35. package/button/Button.test.js +35 -0
  36. package/button/types.d.ts +5 -9
  37. package/card/Card.js +26 -30
  38. package/card/Card.stories.tsx +201 -0
  39. package/card/Card.test.js +50 -0
  40. package/card/ice-cream.jpg +0 -0
  41. package/card/types.d.ts +4 -6
  42. package/checkbox/Checkbox.d.ts +1 -1
  43. package/checkbox/Checkbox.js +45 -41
  44. package/checkbox/Checkbox.stories.tsx +124 -128
  45. package/checkbox/Checkbox.test.js +78 -0
  46. package/checkbox/types.d.ts +9 -5
  47. package/chip/Chip.d.ts +4 -0
  48. package/chip/Chip.js +16 -76
  49. package/chip/Chip.stories.tsx +119 -0
  50. package/chip/Chip.test.js +56 -0
  51. package/chip/types.d.ts +45 -0
  52. package/chip/types.js +5 -0
  53. package/common/variables.js +247 -346
  54. package/date-input/DateInput.js +63 -52
  55. package/date-input/DateInput.stories.tsx +138 -0
  56. package/date-input/DateInput.test.js +479 -0
  57. package/date-input/types.d.ts +16 -9
  58. package/dialog/Dialog.js +8 -35
  59. package/dialog/Dialog.stories.tsx +212 -0
  60. package/dialog/Dialog.test.js +40 -0
  61. package/dropdown/Dropdown.d.ts +1 -1
  62. package/dropdown/Dropdown.js +22 -48
  63. package/dropdown/Dropdown.stories.tsx +249 -0
  64. package/dropdown/Dropdown.test.js +189 -0
  65. package/dropdown/types.d.ts +6 -15
  66. package/file-input/FileInput.d.ts +4 -0
  67. package/file-input/FileInput.js +172 -111
  68. package/file-input/FileInput.stories.tsx +507 -0
  69. package/file-input/FileInput.test.js +457 -0
  70. package/file-input/FileItem.d.ts +14 -0
  71. package/file-input/FileItem.js +16 -23
  72. package/file-input/types.d.ts +112 -0
  73. package/file-input/types.js +5 -0
  74. package/footer/Footer.d.ts +1 -1
  75. package/footer/Footer.js +32 -113
  76. package/footer/{Footer.stories.jsx → Footer.stories.tsx} +1 -22
  77. package/footer/Footer.test.js +109 -0
  78. package/footer/Icons.d.ts +2 -0
  79. package/footer/Icons.js +3 -3
  80. package/footer/types.d.ts +22 -18
  81. package/header/Header.js +29 -50
  82. package/header/Header.stories.tsx +172 -0
  83. package/header/Header.test.js +79 -0
  84. package/header/Icons.d.ts +2 -0
  85. package/header/types.d.ts +4 -2
  86. package/heading/Heading.d.ts +4 -0
  87. package/heading/Heading.js +7 -24
  88. package/heading/Heading.stories.tsx +54 -0
  89. package/heading/Heading.test.js +186 -0
  90. package/heading/types.d.ts +33 -0
  91. package/heading/types.js +5 -0
  92. package/inset/Inset.d.ts +3 -0
  93. package/inset/Inset.js +84 -0
  94. package/inset/Inset.stories.tsx +229 -0
  95. package/inset/types.d.ts +37 -0
  96. package/inset/types.js +5 -0
  97. package/layout/ApplicationLayout.d.ts +11 -0
  98. package/layout/ApplicationLayout.js +84 -120
  99. package/layout/ApplicationLayout.stories.tsx +126 -0
  100. package/layout/Icons.d.ts +5 -0
  101. package/layout/Icons.js +13 -2
  102. package/layout/SidenavContext.d.ts +5 -0
  103. package/layout/SidenavContext.js +19 -0
  104. package/layout/types.d.ts +52 -0
  105. package/layout/types.js +5 -0
  106. package/link/Link.d.ts +3 -2
  107. package/link/Link.js +61 -86
  108. package/link/Link.stories.tsx +186 -0
  109. package/link/Link.test.js +83 -0
  110. package/link/types.d.ts +9 -29
  111. package/list/List.d.ts +4 -0
  112. package/list/List.js +47 -0
  113. package/list/List.stories.tsx +95 -0
  114. package/list/types.d.ts +7 -0
  115. package/list/types.js +5 -0
  116. package/main.d.ts +12 -9
  117. package/main.js +72 -42
  118. package/number-input/NumberInput.d.ts +4 -0
  119. package/number-input/NumberInput.js +16 -68
  120. package/number-input/{NumberInput.stories.jsx → NumberInput.stories.tsx} +5 -5
  121. package/number-input/NumberInput.test.js +506 -0
  122. package/number-input/NumberInputContext.d.ts +4 -0
  123. package/number-input/NumberInputContext.js +5 -2
  124. package/number-input/numberInputContextTypes.d.ts +19 -0
  125. package/number-input/numberInputContextTypes.js +5 -0
  126. package/number-input/types.d.ts +124 -0
  127. package/number-input/types.js +5 -0
  128. package/package.json +9 -6
  129. package/paginator/Paginator.js +19 -46
  130. package/paginator/Paginator.test.js +266 -0
  131. package/password-input/PasswordInput.js +23 -19
  132. package/password-input/PasswordInput.stories.tsx +3 -3
  133. package/password-input/PasswordInput.test.js +180 -0
  134. package/password-input/types.d.ts +29 -19
  135. package/progress-bar/ProgressBar.js +5 -5
  136. package/progress-bar/ProgressBar.stories.jsx +11 -11
  137. package/progress-bar/ProgressBar.test.js +65 -0
  138. package/quick-nav/QuickNav.d.ts +4 -0
  139. package/quick-nav/QuickNav.js +112 -0
  140. package/quick-nav/QuickNav.stories.tsx +237 -0
  141. package/quick-nav/types.d.ts +21 -0
  142. package/quick-nav/types.js +5 -0
  143. package/radio-group/Radio.d.ts +4 -0
  144. package/radio-group/Radio.js +141 -0
  145. package/radio-group/RadioGroup.d.ts +4 -0
  146. package/radio-group/RadioGroup.js +282 -0
  147. package/radio-group/RadioGroup.stories.tsx +100 -0
  148. package/radio-group/RadioGroup.test.js +695 -0
  149. package/radio-group/types.d.ts +114 -0
  150. package/radio-group/types.js +5 -0
  151. package/resultsetTable/ResultsetTable.d.ts +4 -0
  152. package/resultsetTable/ResultsetTable.js +9 -29
  153. package/resultsetTable/ResultsetTable.stories.tsx +275 -0
  154. package/resultsetTable/ResultsetTable.test.js +306 -0
  155. package/resultsetTable/types.d.ts +67 -0
  156. package/resultsetTable/types.js +5 -0
  157. package/row/Row.d.ts +3 -0
  158. package/row/Row.js +127 -0
  159. package/row/Row.stories.tsx +237 -0
  160. package/row/types.d.ts +28 -0
  161. package/row/types.js +5 -0
  162. package/select/Icons.d.ts +10 -0
  163. package/select/Icons.js +93 -0
  164. package/select/Listbox.d.ts +4 -0
  165. package/select/Listbox.js +152 -0
  166. package/select/Option.d.ts +4 -0
  167. package/select/Option.js +110 -0
  168. package/select/Select.d.ts +4 -0
  169. package/select/Select.js +122 -342
  170. package/select/Select.stories.tsx +594 -0
  171. package/select/Select.test.js +2120 -0
  172. package/select/types.d.ts +213 -0
  173. package/select/types.js +5 -0
  174. package/sidenav/Sidenav.d.ts +9 -0
  175. package/sidenav/Sidenav.js +26 -24
  176. package/sidenav/Sidenav.stories.tsx +182 -0
  177. package/sidenav/Sidenav.test.js +56 -0
  178. package/sidenav/types.d.ts +50 -0
  179. package/sidenav/types.js +5 -0
  180. package/slider/Slider.d.ts +1 -1
  181. package/slider/Slider.js +45 -33
  182. package/slider/Slider.stories.tsx +177 -0
  183. package/slider/Slider.test.js +150 -0
  184. package/slider/types.d.ts +6 -7
  185. package/spinner/Spinner.js +3 -3
  186. package/spinner/Spinner.stories.jsx +1 -0
  187. package/spinner/Spinner.test.js +64 -0
  188. package/stack/Stack.d.ts +3 -0
  189. package/stack/Stack.js +97 -0
  190. package/stack/Stack.stories.tsx +164 -0
  191. package/stack/types.d.ts +24 -0
  192. package/stack/types.js +5 -0
  193. package/switch/Switch.d.ts +1 -1
  194. package/switch/Switch.js +37 -21
  195. package/switch/Switch.stories.tsx +15 -15
  196. package/switch/Switch.test.js +98 -0
  197. package/switch/types.d.ts +6 -2
  198. package/table/Table.js +3 -3
  199. package/table/Table.stories.jsx +2 -1
  200. package/table/Table.test.js +26 -0
  201. package/tabs/Tabs.d.ts +1 -1
  202. package/tabs/Tabs.js +20 -20
  203. package/tabs/Tabs.stories.tsx +112 -0
  204. package/tabs/Tabs.test.js +140 -0
  205. package/tabs/types.d.ts +29 -18
  206. package/tabs-nav/NavTabs.d.ts +8 -0
  207. package/tabs-nav/NavTabs.js +125 -0
  208. package/tabs-nav/NavTabs.stories.tsx +170 -0
  209. package/tabs-nav/NavTabs.test.js +82 -0
  210. package/tabs-nav/Tab.d.ts +4 -0
  211. package/tabs-nav/Tab.js +132 -0
  212. package/tabs-nav/types.d.ts +53 -0
  213. package/tabs-nav/types.js +5 -0
  214. package/tag/Tag.d.ts +1 -1
  215. package/tag/Tag.js +18 -28
  216. package/tag/Tag.stories.tsx +26 -29
  217. package/tag/Tag.test.js +60 -0
  218. package/tag/types.d.ts +23 -14
  219. package/text/Text.d.ts +7 -0
  220. package/text/Text.js +30 -0
  221. package/text/Text.stories.tsx +19 -0
  222. package/text-input/Suggestion.d.ts +4 -0
  223. package/text-input/Suggestion.js +55 -0
  224. package/text-input/TextInput.d.ts +4 -0
  225. package/text-input/TextInput.js +91 -146
  226. package/text-input/TextInput.stories.tsx +474 -0
  227. package/text-input/TextInput.test.js +1712 -0
  228. package/text-input/types.d.ts +178 -0
  229. package/text-input/types.js +5 -0
  230. package/textarea/Textarea.d.ts +4 -0
  231. package/textarea/Textarea.js +39 -79
  232. package/textarea/Textarea.stories.jsx +37 -15
  233. package/textarea/Textarea.test.js +437 -0
  234. package/textarea/types.d.ts +137 -0
  235. package/textarea/types.js +5 -0
  236. package/toggle-group/ToggleGroup.d.ts +4 -0
  237. package/toggle-group/ToggleGroup.js +18 -46
  238. package/toggle-group/ToggleGroup.stories.tsx +173 -0
  239. package/toggle-group/ToggleGroup.test.js +156 -0
  240. package/toggle-group/types.d.ts +105 -0
  241. package/toggle-group/types.js +5 -0
  242. package/useTheme.d.ts +2 -0
  243. package/useTheme.js +2 -2
  244. package/useTranslatedLabels.d.ts +2 -0
  245. package/useTranslatedLabels.js +20 -0
  246. package/wizard/Wizard.d.ts +4 -0
  247. package/wizard/Wizard.js +115 -94
  248. package/wizard/Wizard.stories.tsx +214 -0
  249. package/wizard/Wizard.test.js +141 -0
  250. package/wizard/types.d.ts +64 -0
  251. package/wizard/types.js +5 -0
  252. package/ThemeContext.js +0 -246
  253. package/V3Select/V3Select.js +0 -455
  254. package/V3Select/index.d.ts +0 -27
  255. package/V3Textarea/V3Textarea.js +0 -260
  256. package/V3Textarea/index.d.ts +0 -27
  257. package/chip/index.d.ts +0 -22
  258. package/date/Date.js +0 -373
  259. package/date/index.d.ts +0 -27
  260. package/file-input/index.d.ts +0 -81
  261. package/heading/index.d.ts +0 -17
  262. package/input-text/Icons.js +0 -22
  263. package/input-text/InputText.js +0 -611
  264. package/input-text/index.d.ts +0 -36
  265. package/number-input/index.d.ts +0 -113
  266. package/radio/Radio.d.ts +0 -4
  267. package/radio/Radio.js +0 -174
  268. package/radio/Radio.stories.tsx +0 -192
  269. package/radio/types.d.ts +0 -54
  270. package/resultsetTable/index.d.ts +0 -19
  271. package/select/index.d.ts +0 -131
  272. package/sidenav/index.d.ts +0 -13
  273. package/text-input/index.d.ts +0 -135
  274. package/textarea/index.d.ts +0 -117
  275. package/toggle/Toggle.js +0 -186
  276. package/toggle/index.d.ts +0 -21
  277. package/toggle-group/index.d.ts +0 -21
  278. package/upload/Upload.js +0 -201
  279. package/upload/buttons-upload/ButtonsUpload.js +0 -111
  280. package/upload/buttons-upload/Icons.js +0 -40
  281. package/upload/dragAndDropArea/DragAndDropArea.js +0 -225
  282. package/upload/dragAndDropArea/Icons.js +0 -39
  283. package/upload/file-upload/FileToUpload.js +0 -115
  284. package/upload/file-upload/Icons.js +0 -66
  285. package/upload/files-upload/FilesToUpload.js +0 -109
  286. package/upload/index.d.ts +0 -15
  287. package/upload/transaction/Icons.js +0 -160
  288. package/upload/transaction/Transaction.js +0 -104
  289. package/upload/transactions/Transactions.js +0 -94
  290. package/wizard/Icons.js +0 -65
  291. package/wizard/index.d.ts +0 -18
package/box/Box.js CHANGED
@@ -21,9 +21,9 @@ var _variables = require("../common/variables.js");
21
21
 
22
22
  var _utils = require("../common/utils.js");
23
23
 
24
- var _useTheme = _interopRequireDefault(require("../useTheme.js"));
24
+ var _useTheme = _interopRequireDefault(require("../useTheme"));
25
25
 
26
- var _BackgroundColorContext = require("../BackgroundColorContext.js");
26
+ var _BackgroundColorContext = require("../BackgroundColorContext");
27
27
 
28
28
  var _templateObject;
29
29
 
@@ -40,9 +40,7 @@ var DxcBox = function DxcBox(_ref) {
40
40
  margin = _ref.margin,
41
41
  padding = _ref.padding,
42
42
  _ref$size = _ref.size,
43
- size = _ref$size === void 0 ? "fitContent" : _ref$size,
44
- _ref$tabIndex = _ref.tabIndex,
45
- tabIndex = _ref$tabIndex === void 0 ? 0 : _ref$tabIndex;
43
+ size = _ref$size === void 0 ? "fitContent" : _ref$size;
46
44
  var colorsTheme = (0, _useTheme["default"])();
47
45
  return /*#__PURE__*/_react["default"].createElement(_styledComponents.ThemeProvider, {
48
46
  theme: colorsTheme.box
@@ -51,8 +49,7 @@ var DxcBox = function DxcBox(_ref) {
51
49
  display: display,
52
50
  margin: margin,
53
51
  padding: padding,
54
- size: size,
55
- tabIndex: tabIndex
52
+ size: size
56
53
  }, /*#__PURE__*/_react["default"].createElement(_BackgroundColorContext.BackgroundColorProvider, {
57
54
  color: colorsTheme.box.backgroundColor
58
55
  }, children)));
@@ -74,9 +71,8 @@ var calculateWidth = function calculateWidth(margin, size, padding) {
74
71
  return sizes[size];
75
72
  };
76
73
 
77
- var StyledDxcBox = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n display: ", ";\n border-radius: ", ";\n border-width: ", ";\n border-style: ", ";\n border-color: ", ";\n letter-spacing: ", ";\n overflow: hidden;\n width: ", ";\n background-color: ", ";\n box-shadow: ", ";\n\n margin: ", ";\n margin-top: ", ";\n margin-right: ", ";\n margin-bottom: ", ";\n margin-left: ", ";\n\n padding: ", ";\n padding-top: ", ";\n padding-right: ", ";\n padding-bottom: ", ";\n padding-left: ", ";\n"])), function (_ref2) {
78
- var display = _ref2.display;
79
- return display;
74
+ var StyledDxcBox = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n display: ", ";\n border-radius: ", ";\n border-width: ", ";\n border-style: ", ";\n border-color: ", ";\n letter-spacing: ", ";\n overflow: hidden;\n width: ", ";\n background-color: ", ";\n box-shadow: ", ";\n\n margin: ", ";\n margin-top: ", ";\n margin-right: ", ";\n margin-bottom: ", ";\n margin-left: ", ";\n\n padding: ", ";\n padding-top: ", ";\n padding-right: ", ";\n padding-bottom: ", ";\n padding-left: ", ";\n"])), function (props) {
75
+ return props.display;
80
76
  }, function (props) {
81
77
  return props.theme.borderRadius;
82
78
  }, function (props) {
@@ -93,36 +89,27 @@ var StyledDxcBox = _styledComponents["default"].div(_templateObject || (_templat
93
89
  return props.theme.backgroundColor;
94
90
  }, function (props) {
95
91
  return props.shadowDepth === 1 ? "".concat(props.theme.oneShadowDepthShadowOffsetX, " ").concat(props.theme.oneShadowDepthShadowOffsetY, " ").concat(props.theme.oneShadowDepthShadowBlur, " ").concat(props.theme.oneShadowDepthShadowSpread, " ").concat(props.theme.oneShadowDepthShadowColor) : props.shadowDepth === 2 ? "".concat(props.theme.twoShadowDepthShadowOffsetX, " ").concat(props.theme.twoShadowDepthShadowOffsetY, " ").concat(props.theme.twoShadowDepthShadowBlur, " ").concat(props.theme.twoShadowDepthShadowSpread, " ").concat(props.theme.twoShadowDepthShadowColor) : "".concat(props.theme.noneShadowDepthShadowOffsetX, " ").concat(props.theme.noneShadowDepthShadowOffsetY, " ").concat(props.theme.noneShadowDepthShadowBlur, " ").concat(props.theme.noneShadowDepthShadowSpread, " ").concat(props.theme.noneShadowDepthShadowColor);
96
- }, function (_ref3) {
97
- var margin = _ref3.margin;
98
- return margin && (0, _typeof2["default"])(margin) !== "object" ? _variables.spaces[margin] : "0px";
99
- }, function (_ref4) {
100
- var margin = _ref4.margin;
101
- return margin && margin.top ? _variables.spaces[margin.top] : "";
102
- }, function (_ref5) {
103
- var margin = _ref5.margin;
104
- return margin && margin.right ? _variables.spaces[margin.right] : "";
105
- }, function (_ref6) {
106
- var margin = _ref6.margin;
107
- return margin && margin.bottom ? _variables.spaces[margin.bottom] : "";
108
- }, function (_ref7) {
109
- var margin = _ref7.margin;
110
- return margin && margin.left ? _variables.spaces[margin.left] : "";
111
- }, function (_ref8) {
112
- var padding = _ref8.padding;
92
+ }, function (props) {
93
+ return props.margin && (0, _typeof2["default"])(props.margin) !== "object" ? _variables.spaces[props.margin] : "0px";
94
+ }, function (props) {
95
+ return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.top ? _variables.spaces[props.margin.top] : "";
96
+ }, function (props) {
97
+ return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.right ? _variables.spaces[props.margin.right] : "";
98
+ }, function (props) {
99
+ return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.bottom ? _variables.spaces[props.margin.bottom] : "";
100
+ }, function (props) {
101
+ return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.left ? _variables.spaces[props.margin.left] : "";
102
+ }, function (_ref2) {
103
+ var padding = _ref2.padding;
113
104
  return padding && (0, _typeof2["default"])(padding) !== "object" ? _variables.spaces[padding] : "0px";
114
- }, function (_ref9) {
115
- var padding = _ref9.padding;
116
- return padding && padding.top ? _variables.spaces[padding.top] : "";
117
- }, function (_ref10) {
118
- var padding = _ref10.padding;
119
- return padding && padding.right ? _variables.spaces[padding.right] : "";
120
- }, function (_ref11) {
121
- var padding = _ref11.padding;
122
- return padding && padding.bottom ? _variables.spaces[padding.bottom] : "";
123
- }, function (_ref12) {
124
- var padding = _ref12.padding;
125
- return padding && padding.left ? _variables.spaces[padding.left] : "";
105
+ }, function (props) {
106
+ return props.padding && (0, _typeof2["default"])(props.padding) === "object" && props.padding.top ? _variables.spaces[props.padding.top] : "";
107
+ }, function (props) {
108
+ return props.padding && (0, _typeof2["default"])(props.padding) === "object" && props.padding.right ? _variables.spaces[props.padding.right] : "";
109
+ }, function (props) {
110
+ return props.padding && (0, _typeof2["default"])(props.padding) === "object" && props.padding.bottom ? _variables.spaces[props.padding.bottom] : "";
111
+ }, function (props) {
112
+ return props.padding && (0, _typeof2["default"])(props.padding) === "object" && props.padding.left ? _variables.spaces[props.padding.left] : "";
126
113
  });
127
114
 
128
115
  var _default = DxcBox;
@@ -0,0 +1,18 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+
5
+ var _react = _interopRequireDefault(require("react"));
6
+
7
+ var _react2 = require("@testing-library/react");
8
+
9
+ var _Card = _interopRequireDefault(require("../card/Card"));
10
+
11
+ describe("Box component tests", function () {
12
+ test("Box renders with correct text", function () {
13
+ var _render = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Card["default"], null, "test-box")),
14
+ getByText = _render.getByText;
15
+
16
+ expect(getByText("test-box")).toBeTruthy();
17
+ });
18
+ });
package/box/types.d.ts CHANGED
@@ -39,9 +39,5 @@ declare type Props = {
39
39
  * Size of the component.
40
40
  */
41
41
  size?: "small" | "medium" | "large" | "fillParent" | "fitContent";
42
- /**
43
- * Value of the tabindex attribute.
44
- */
45
- tabIndex?: number;
46
42
  };
47
43
  export default Props;
@@ -1,4 +1,4 @@
1
1
  /// <reference types="react" />
2
2
  import ButtonPropsType from "./types";
3
- declare const DxcButton: ({ label, mode, disabled, iconPosition, type, icon, iconSrc, onClick, margin, size, tabIndex }: ButtonPropsType) => JSX.Element;
3
+ declare const DxcButton: ({ label, mode, disabled, iconPosition, type, icon, onClick, margin, size, tabIndex, }: ButtonPropsType) => JSX.Element;
4
4
  export default DxcButton;
package/button/Button.js CHANGED
@@ -9,10 +9,10 @@ Object.defineProperty(exports, "__esModule", {
9
9
  });
10
10
  exports["default"] = void 0;
11
11
 
12
- var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
13
-
14
12
  var _typeof2 = _interopRequireDefault(require("@babel/runtime/helpers/typeof"));
15
13
 
14
+ var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
15
+
16
16
  var _react = _interopRequireWildcard(require("react"));
17
17
 
18
18
  var _Button = _interopRequireDefault(require("@material-ui/core/Button"));
@@ -23,9 +23,9 @@ var _variables = require("../common/variables.js");
23
23
 
24
24
  var _utils = require("../common/utils.js");
25
25
 
26
- var _useTheme = _interopRequireDefault(require("../useTheme.js"));
26
+ var _useTheme = _interopRequireDefault(require("../useTheme"));
27
27
 
28
- var _BackgroundColorContext = _interopRequireDefault(require("../BackgroundColorContext.js"));
28
+ var _BackgroundColorContext = _interopRequireDefault(require("../BackgroundColorContext"));
29
29
 
30
30
  var _templateObject, _templateObject2, _templateObject3, _templateObject4;
31
31
 
@@ -45,16 +45,22 @@ var DxcButton = function DxcButton(_ref) {
45
45
  _ref$type = _ref.type,
46
46
  type = _ref$type === void 0 ? "button" : _ref$type,
47
47
  icon = _ref.icon,
48
- _ref$iconSrc = _ref.iconSrc,
49
- iconSrc = _ref$iconSrc === void 0 ? "" : _ref$iconSrc,
50
- onClick = _ref.onClick,
48
+ _ref$onClick = _ref.onClick,
49
+ _onClick = _ref$onClick === void 0 ? function () {} : _ref$onClick,
51
50
  margin = _ref.margin,
52
51
  _ref$size = _ref.size,
53
52
  size = _ref$size === void 0 ? "fitContent" : _ref$size,
54
53
  _ref$tabIndex = _ref.tabIndex,
55
54
  tabIndex = _ref$tabIndex === void 0 ? 0 : _ref$tabIndex;
55
+
56
56
  var colorsTheme = (0, _useTheme["default"])();
57
57
  var backgroundType = (0, _react.useContext)(_BackgroundColorContext["default"]);
58
+
59
+ var labelComponent = /*#__PURE__*/_react["default"].createElement(LabelContainer, {
60
+ icon: icon,
61
+ iconPosition: iconPosition
62
+ }, label);
63
+
58
64
  return /*#__PURE__*/_react["default"].createElement(_styledComponents.ThemeProvider, {
59
65
  theme: colorsTheme.button
60
66
  }, /*#__PURE__*/_react["default"].createElement(DxCButton, {
@@ -72,18 +78,15 @@ var DxcButton = function DxcButton(_ref) {
72
78
  disableRipple: true,
73
79
  "aria-disabled": disabled,
74
80
  tabIndex: disabled ? -1 : tabIndex,
75
- onClick: onClick
76
- }, label && /*#__PURE__*/_react["default"].createElement(LabelContainer, {
77
- icon: icon,
78
- iconPosition: iconPosition
79
- }, label), icon ? /*#__PURE__*/_react["default"].createElement(IconContainer, {
81
+ onClick: function onClick() {
82
+ _onClick();
83
+ }
84
+ }, label && iconPosition === "after" && labelComponent, icon && /*#__PURE__*/_react["default"].createElement(IconContainer, {
80
85
  label: label,
81
86
  iconPosition: iconPosition
82
- }, (0, _typeof2["default"])(icon) === "object" ? icon : /*#__PURE__*/_react["default"].createElement(icon)) : iconSrc && /*#__PURE__*/_react["default"].createElement(ButtonIcon, {
83
- label: label,
84
- iconPosition: iconPosition,
85
- src: iconSrc
86
- }))));
87
+ }, typeof icon === "string" ? /*#__PURE__*/_react["default"].createElement(ButtonIcon, {
88
+ src: icon
89
+ }) : icon), label && iconPosition === "before" && labelComponent)));
87
90
  };
88
91
 
89
92
  var sizes = {
@@ -118,13 +121,9 @@ var IconContainer = _styledComponents["default"].div(_templateObject2 || (_templ
118
121
  return !props.label ? "0px" : props.iconPosition === "before" && props.label !== "" && "8px" || "8px";
119
122
  });
120
123
 
121
- var ButtonIcon = _styledComponents["default"].img(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n max-height: 24px;\n max-width: 24px;\n margin-left: ", ";\n margin-right: ", ";\n"])), function (props) {
122
- return props.iconPosition === "after" && props.label !== "" && "10px" || "0px";
123
- }, function (props) {
124
- return props.iconPosition === "before" && props.label !== "" && "10px" || "0px";
125
- });
124
+ var ButtonIcon = _styledComponents["default"].img(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])([""])));
126
125
 
127
- var DxCButton = _styledComponents["default"].div(_templateObject4 || (_templateObject4 = (0, _taggedTemplateLiteral2["default"])(["\n margin: ", ";\n margin-top: ", ";\n margin-right: ", ";\n margin-bottom: ", ";\n margin-left: ", ";\n\n display: inline-block;\n width: ", ";\n cursor: ", ";\n\n .MuiButtonBase-root {\n padding-left: ", ";\n padding-right: ", ";\n padding-top: ", ";\n padding-bottom: ", ";\n\n .MuiButton-label {\n display: flex;\n flex-direction: ", ";\n align-items: center;\n }\n\n box-shadow: 0 0 0 2px transparent;\n font-family: ", ";\n font-size: ", ";\n font-weight: ", ";\n letter-spacing: ", ";\n min-width: ", ";\n width: 100%;\n height: 40px;\n transition: none !important;\n\n &:focus {\n border-color: transparent;\n box-shadow: 0 0 0 2px\n ", ";\n }\n\n ", "\n }\n"])), function (props) {
126
+ var DxCButton = _styledComponents["default"].div(_templateObject4 || (_templateObject4 = (0, _taggedTemplateLiteral2["default"])(["\n margin: ", ";\n margin-top: ", ";\n margin-right: ", ";\n margin-bottom: ", ";\n margin-left: ", ";\n\n display: inline-block;\n width: ", ";\n cursor: ", ";\n\n .MuiButtonBase-root {\n padding-left: ", ";\n padding-right: ", ";\n padding-top: ", ";\n padding-bottom: ", ";\n\n .MuiButton-label {\n display: flex;\n align-items: center;\n }\n\n box-shadow: 0 0 0 2px transparent;\n font-family: ", ";\n font-size: ", ";\n font-weight: ", ";\n letter-spacing: ", ";\n min-width: ", ";\n width: 100%;\n height: 40px;\n transition: none !important;\n\n &:focus {\n border-color: transparent;\n box-shadow: 0 0 0 2px\n ", ";\n }\n\n ", "\n }\n"])), function (props) {
128
127
  return props.margin && (0, _typeof2["default"])(props.margin) !== "object" ? _variables.spaces[props.margin] : "0px";
129
128
  }, function (props) {
130
129
  return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.top ? _variables.spaces[props.margin.top] : "";
@@ -146,8 +145,6 @@ var DxCButton = _styledComponents["default"].div(_templateObject4 || (_templateO
146
145
  return props.theme.paddingTop;
147
146
  }, function (props) {
148
147
  return props.theme.paddingBottom;
149
- }, function (props) {
150
- return props.iconPosition === "after" && "row" || "row-reverse";
151
148
  }, function (props) {
152
149
  return props.theme.fontFamily;
153
150
  }, function (props) {
@@ -165,9 +162,9 @@ var DxCButton = _styledComponents["default"].div(_templateObject4 || (_templateO
165
162
  backgroundType = props.backgroundType;
166
163
 
167
164
  if (mode === "primary") {
168
- return "\n border-radius: ".concat(props.theme.primaryBorderRadius, ";\n border-width: ").concat(props.theme.primaryBorderThickness, ";\n border-style: ").concat(props.theme.primaryBorderStyle, ";\n font-family: ").concat(props.theme.primaryFontFamily, ";\n font-size: ").concat(props.theme.primaryFontSize, ";\n font-weight: ").concat(props.theme.primaryFontWeight, ";\n background-color: ").concat(backgroundType === "dark" ? props.theme.primaryBackgroundColorOnDark : props.theme.primaryBackgroundColor, ";\n color: ").concat(backgroundType && backgroundType === "dark" ? props.theme.primaryFontColorOnDark : props.theme.primaryFontColor, " !important;\n\n &:hover {\n background-color: ").concat(backgroundType === "dark" ? props.theme.primaryHoverBackgroundColorOnDark : props.theme.primaryHoverBackgroundColor, ";\n }\n &:active {\n background-color: ").concat(backgroundType === "dark" ? props.theme.primaryActiveBackgroundColorOnDark : props.theme.primaryActiveBackgroundColor, " !important;\n border-color: transparent;\n box-shadow: 0 0 0 2px ").concat(backgroundType === "dark" ? props.theme.focusBorderColorOnDark : props.theme.focusBorderColor, ";\n }\n &:disabled { \n cursor: not-allowed;\n background-color: ").concat(backgroundType === "dark" ? props.theme.primaryDisabledBackgroundColorOnDark : props.theme.primaryDisabledBackgroundColor, ";\n color: ").concat(backgroundType === "dark" ? props.theme.primaryDisabledFontColorOnDark : props.theme.primaryDisabledFontColor, "!important; \n }\n .MuiButton-label {\n z-index: 5;\n }\n ");
165
+ return "\n border-radius: ".concat(props.theme.primaryBorderRadius, ";\n border-width: ").concat(props.theme.primaryBorderThickness, ";\n border-style: ").concat(props.theme.primaryBorderStyle, ";\n font-family: ").concat(props.theme.primaryFontFamily, ";\n font-size: ").concat(props.theme.primaryFontSize, ";\n font-weight: ").concat(props.theme.primaryFontWeight, ";\n background-color: ").concat(backgroundType === "dark" ? props.theme.primaryBackgroundColorOnDark : props.theme.primaryBackgroundColor, ";\n color: ").concat(backgroundType && backgroundType === "dark" ? props.theme.primaryFontColorOnDark : props.theme.primaryFontColor, " !important;\n\n &:hover {\n background-color: ").concat(backgroundType === "dark" ? props.theme.primaryHoverBackgroundColorOnDark : props.theme.primaryHoverBackgroundColor, ";\n }\n &:active {\n background-color: ").concat(backgroundType === "dark" ? props.theme.primaryActiveBackgroundColorOnDark : props.theme.primaryActiveBackgroundColor, " !important;\n border-color: transparent;\n box-shadow: 0 0 0 2px ").concat(backgroundType === "dark" ? props.theme.focusBorderColorOnDark : props.theme.focusBorderColor, ";\n }\n &:disabled { \n cursor: not-allowed;\n background-color: ").concat(backgroundType === "dark" ? props.theme.primaryDisabledBackgroundColorOnDark : props.theme.primaryDisabledBackgroundColor, ";\n color: ").concat(backgroundType === "dark" ? props.theme.primaryDisabledFontColorOnDark : props.theme.primaryDisabledFontColor, " !important; \n }\n ");
169
166
  } else if (mode === "secondary") {
170
- return "\n border-radius: ".concat(props.theme.secondaryBorderRadius, ";\n border-width: ").concat(props.theme.secondaryBorderThickness, ";\n border-style: ").concat(props.theme.secondaryBorderStyle, ";\n font-family: ").concat(props.theme.secondaryFontFamily, ";\n font-size: ").concat(props.theme.secondaryFontSize, ";\n font-weight: ").concat(props.theme.secondaryFontWeight, ";\n background-color: ").concat(backgroundType === "dark" ? props.theme.secondaryBackgroundColorOnDark : props.theme.secondaryBackgroundColor, ";\n color: ").concat(backgroundType === "dark" ? props.theme.secondaryFontColorOnDark : props.theme.secondaryFontColor, " !important;\n border-color: ").concat(backgroundType === "dark" ? props.theme.secondaryBorderColorOnDark : props.theme.secondaryBorderColor, ";\n\n &:hover {\n background-color: ").concat(backgroundType === "dark" ? props.theme.secondaryHoverBackgroundColorOnDark : props.theme.secondaryHoverBackgroundColor, ";\n color: ").concat(backgroundType === "dark" ? props.theme.secondaryHoverFontColorOnDark : props.theme.secondaryHoverFontColor, " !important;\n }\n &:active {\n background-color: ").concat(backgroundType === "dark" ? props.theme.secondaryActiveBackgroundColorOnDark : props.theme.secondaryActiveBackgroundColor, " !important;\n color: ").concat(backgroundType === "dark" ? props.theme.secondaryHoverFontColorOnDark : props.theme.secondaryHoverFontColor, " !important;\n border-color: transparent;\n box-shadow: 0 0 0 2px ").concat(backgroundType === "dark" ? props.theme.focusBorderColorOnDark : props.theme.focusBorderColor, ";\n }\n &:disabled {\n cursor: not-allowed;\n background-color: ").concat(backgroundType === "dark" ? props.theme.secondaryDisabledBackgroundColorOnDark : props.theme.secondaryDisabledBackgroundColor, " !important;\n color: ").concat(backgroundType === "dark" ? props.theme.secondaryDisabledFontColorOnDark : props.theme.secondaryDisabledFontColor, " !important;\n border-color: ").concat(backgroundType === "dark" ? props.theme.secondaryDisabledBorderColorOnDark : props.theme.secondaryDisabledBorderColor, ";\n }\n .MuiButton-label {\n z-index: 5;\n }\n ");
167
+ return "\n border-radius: ".concat(props.theme.secondaryBorderRadius, ";\n border-width: ").concat(props.theme.secondaryBorderThickness, ";\n border-style: ").concat(props.theme.secondaryBorderStyle, ";\n font-family: ").concat(props.theme.secondaryFontFamily, ";\n font-size: ").concat(props.theme.secondaryFontSize, ";\n font-weight: ").concat(props.theme.secondaryFontWeight, ";\n background-color: ").concat(backgroundType === "dark" ? props.theme.secondaryBackgroundColorOnDark : props.theme.secondaryBackgroundColor, ";\n color: ").concat(backgroundType === "dark" ? props.theme.secondaryFontColorOnDark : props.theme.secondaryFontColor, " !important;\n border-color: ").concat(backgroundType === "dark" ? props.theme.secondaryBorderColorOnDark : props.theme.secondaryBorderColor, ";\n\n &:hover {\n background-color: ").concat(backgroundType === "dark" ? props.theme.secondaryHoverBackgroundColorOnDark : props.theme.secondaryHoverBackgroundColor, ";\n color: ").concat(backgroundType === "dark" ? props.theme.secondaryHoverFontColorOnDark : props.theme.secondaryHoverFontColor, " !important;\n }\n &:active {\n background-color: ").concat(backgroundType === "dark" ? props.theme.secondaryActiveBackgroundColorOnDark : props.theme.secondaryActiveBackgroundColor, " !important;\n color: ").concat(backgroundType === "dark" ? props.theme.secondaryHoverFontColorOnDark : props.theme.secondaryHoverFontColor, " !important;\n border-color: transparent;\n box-shadow: 0 0 0 2px ").concat(backgroundType === "dark" ? props.theme.focusBorderColorOnDark : props.theme.focusBorderColor, ";\n }\n &:disabled {\n cursor: not-allowed;\n background-color: ").concat(backgroundType === "dark" ? props.theme.secondaryDisabledBackgroundColorOnDark : props.theme.secondaryDisabledBackgroundColor, " !important;\n color: ").concat(backgroundType === "dark" ? props.theme.secondaryDisabledFontColorOnDark : props.theme.secondaryDisabledFontColor, " !important;\n border-color: ").concat(backgroundType === "dark" ? props.theme.secondaryDisabledBorderColorOnDark : props.theme.secondaryDisabledBorderColor, ";\n }\n ");
171
168
  } else if (mode === "text") {
172
169
  return "\n border-radius: ".concat(props.theme.textBorderRadius, ";\n border-width: ").concat(props.theme.textBorderThickness, ";\n border-style: ").concat(props.theme.textBorderStyle, ";\n font-family: ").concat(props.theme.textFontFamily, ";\n font-size: ").concat(props.theme.textFontSize, ";\n font-weight: ").concat(props.theme.textFontWeight, ";\n background-color: ").concat(backgroundType === "dark" ? props.theme.textBackgroundColorOnDark : props.theme.textBackgroundColor, ";\n color: ").concat(backgroundType === "dark" ? props.theme.textFontColorOnDark : props.theme.textFontColor, " !important;\n\n &:hover {\n background-color: ").concat(backgroundType === "dark" ? props.theme.textHoverBackgroundColorOnDark : props.theme.textHoverBackgroundColor, ";\n }\n &:active {\n background-color: ").concat(backgroundType === "dark" ? props.theme.textActiveBackgroundColorOnDark : props.theme.textActiveBackgroundColor, " !important;\n border-color: transparent;\n box-shadow: 0 0 0 2px ").concat(backgroundType === "dark" ? props.theme.focusBorderColorOnDark : props.theme.focusBorderColor, ";\n }\n &:disabled {\n cursor:not-allowed;\n color: ").concat(backgroundType === "dark" ? props.theme.textDisabledFontColorOnDark : props.theme.textDisabledFontColor, " !important;\n background-color: ").concat(backgroundType === "dark" ? props.theme.textDisabledBackgroundColorOnDark : props.theme.textDisabledBackgroundColor, ";\n }\n ");
173
170
  }