@dxc-technology/halstack-react 0.0.0-cd617f3 → 0.0.0-ce0214d

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 (332) 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 +4 -0
  29. package/box/Box.js +28 -64
  30. package/box/Box.stories.tsx +132 -0
  31. package/box/Box.test.js +18 -0
  32. package/box/types.d.ts +43 -0
  33. package/box/types.js +5 -0
  34. package/button/Button.d.ts +1 -1
  35. package/button/Button.js +24 -32
  36. package/button/Button.stories.tsx +223 -242
  37. package/button/Button.test.js +35 -0
  38. package/button/types.d.ts +9 -13
  39. package/card/Card.d.ts +4 -0
  40. package/card/Card.js +44 -81
  41. package/card/Card.stories.tsx +201 -0
  42. package/card/Card.test.js +50 -0
  43. package/card/ice-cream.jpg +0 -0
  44. package/card/types.d.ts +67 -0
  45. package/card/types.js +5 -0
  46. package/checkbox/Checkbox.d.ts +1 -1
  47. package/checkbox/Checkbox.js +45 -41
  48. package/checkbox/Checkbox.stories.tsx +188 -0
  49. package/checkbox/Checkbox.test.js +78 -0
  50. package/checkbox/types.d.ts +9 -6
  51. package/chip/Chip.d.ts +4 -0
  52. package/chip/Chip.js +16 -76
  53. package/chip/Chip.stories.tsx +119 -0
  54. package/chip/Chip.test.js +56 -0
  55. package/chip/types.d.ts +45 -0
  56. package/chip/types.js +5 -0
  57. package/common/variables.js +264 -363
  58. package/date-input/DateInput.js +63 -52
  59. package/date-input/DateInput.stories.tsx +138 -0
  60. package/date-input/DateInput.test.js +479 -0
  61. package/date-input/types.d.ts +16 -9
  62. package/dialog/Dialog.d.ts +4 -0
  63. package/dialog/Dialog.js +10 -56
  64. package/dialog/Dialog.stories.tsx +212 -0
  65. package/dialog/Dialog.test.js +40 -0
  66. package/dialog/types.d.ts +43 -0
  67. package/dialog/types.js +5 -0
  68. package/dropdown/Dropdown.d.ts +4 -0
  69. package/dropdown/Dropdown.js +28 -87
  70. package/dropdown/Dropdown.stories.tsx +249 -0
  71. package/dropdown/Dropdown.test.js +189 -0
  72. package/dropdown/types.d.ts +80 -0
  73. package/dropdown/types.js +5 -0
  74. package/file-input/FileInput.d.ts +4 -0
  75. package/file-input/FileInput.js +172 -111
  76. package/file-input/FileInput.stories.tsx +507 -0
  77. package/file-input/FileInput.test.js +457 -0
  78. package/file-input/FileItem.d.ts +14 -0
  79. package/file-input/FileItem.js +16 -23
  80. package/file-input/types.d.ts +112 -0
  81. package/file-input/types.js +5 -0
  82. package/footer/Footer.d.ts +4 -0
  83. package/footer/Footer.js +36 -148
  84. package/footer/Footer.stories.tsx +130 -0
  85. package/footer/Footer.test.js +109 -0
  86. package/footer/Icons.d.ts +2 -0
  87. package/footer/Icons.js +3 -3
  88. package/footer/types.d.ts +65 -0
  89. package/footer/types.js +5 -0
  90. package/header/Header.d.ts +7 -0
  91. package/header/Header.js +55 -78
  92. package/header/Header.stories.tsx +172 -0
  93. package/header/Header.test.js +79 -0
  94. package/header/Icons.d.ts +2 -0
  95. package/header/Icons.js +2 -27
  96. package/header/types.d.ts +47 -0
  97. package/header/types.js +5 -0
  98. package/heading/Heading.d.ts +4 -0
  99. package/heading/Heading.js +7 -24
  100. package/heading/Heading.stories.tsx +54 -0
  101. package/heading/Heading.test.js +186 -0
  102. package/heading/types.d.ts +33 -0
  103. package/heading/types.js +5 -0
  104. package/inset/Inset.d.ts +3 -0
  105. package/inset/Inset.js +84 -0
  106. package/inset/Inset.stories.tsx +229 -0
  107. package/inset/types.d.ts +37 -0
  108. package/inset/types.js +5 -0
  109. package/layout/ApplicationLayout.d.ts +11 -0
  110. package/layout/ApplicationLayout.js +84 -120
  111. package/layout/ApplicationLayout.stories.tsx +126 -0
  112. package/layout/Icons.d.ts +5 -0
  113. package/layout/Icons.js +13 -2
  114. package/layout/SidenavContext.d.ts +5 -0
  115. package/layout/SidenavContext.js +19 -0
  116. package/layout/types.d.ts +52 -0
  117. package/layout/types.js +5 -0
  118. package/link/Link.d.ts +4 -0
  119. package/link/Link.js +60 -107
  120. package/link/Link.stories.tsx +186 -0
  121. package/link/Link.test.js +83 -0
  122. package/link/types.d.ts +54 -0
  123. package/link/types.js +5 -0
  124. package/list/List.d.ts +4 -0
  125. package/list/List.js +47 -0
  126. package/list/List.stories.tsx +95 -0
  127. package/list/types.d.ts +7 -0
  128. package/list/types.js +5 -0
  129. package/main.d.ts +12 -9
  130. package/main.js +72 -42
  131. package/number-input/NumberInput.d.ts +4 -0
  132. package/number-input/NumberInput.js +16 -68
  133. package/number-input/NumberInput.stories.tsx +115 -0
  134. package/number-input/NumberInput.test.js +506 -0
  135. package/number-input/NumberInputContext.d.ts +4 -0
  136. package/number-input/NumberInputContext.js +5 -2
  137. package/number-input/numberInputContextTypes.d.ts +19 -0
  138. package/number-input/numberInputContextTypes.js +5 -0
  139. package/number-input/types.d.ts +124 -0
  140. package/number-input/types.js +5 -0
  141. package/package.json +9 -6
  142. package/paginator/Paginator.js +19 -46
  143. package/paginator/Paginator.stories.tsx +63 -0
  144. package/paginator/Paginator.test.js +266 -0
  145. package/password-input/PasswordInput.d.ts +4 -0
  146. package/password-input/PasswordInput.js +22 -55
  147. package/password-input/{PasswordInput.stories.jsx → PasswordInput.stories.tsx} +4 -4
  148. package/password-input/PasswordInput.test.js +180 -0
  149. package/password-input/types.d.ts +110 -0
  150. package/password-input/types.js +5 -0
  151. package/progress-bar/ProgressBar.d.ts +4 -0
  152. package/progress-bar/ProgressBar.js +6 -24
  153. package/progress-bar/ProgressBar.stories.jsx +58 -0
  154. package/progress-bar/ProgressBar.test.js +65 -0
  155. package/progress-bar/types.d.ts +37 -0
  156. package/progress-bar/types.js +5 -0
  157. package/quick-nav/QuickNav.d.ts +4 -0
  158. package/quick-nav/QuickNav.js +112 -0
  159. package/quick-nav/QuickNav.stories.tsx +237 -0
  160. package/quick-nav/types.d.ts +21 -0
  161. package/quick-nav/types.js +5 -0
  162. package/radio-group/Radio.d.ts +4 -0
  163. package/radio-group/Radio.js +141 -0
  164. package/radio-group/RadioGroup.d.ts +4 -0
  165. package/radio-group/RadioGroup.js +282 -0
  166. package/radio-group/RadioGroup.stories.tsx +100 -0
  167. package/radio-group/RadioGroup.test.js +695 -0
  168. package/radio-group/types.d.ts +114 -0
  169. package/radio-group/types.js +5 -0
  170. package/resultsetTable/ResultsetTable.d.ts +4 -0
  171. package/resultsetTable/ResultsetTable.js +9 -29
  172. package/resultsetTable/ResultsetTable.stories.tsx +275 -0
  173. package/resultsetTable/ResultsetTable.test.js +306 -0
  174. package/resultsetTable/types.d.ts +67 -0
  175. package/resultsetTable/types.js +5 -0
  176. package/row/Row.d.ts +3 -0
  177. package/row/Row.js +127 -0
  178. package/row/Row.stories.tsx +237 -0
  179. package/row/types.d.ts +28 -0
  180. package/row/types.js +5 -0
  181. package/select/Icons.d.ts +10 -0
  182. package/select/Icons.js +93 -0
  183. package/select/Listbox.d.ts +4 -0
  184. package/select/Listbox.js +152 -0
  185. package/select/Option.d.ts +4 -0
  186. package/select/Option.js +110 -0
  187. package/select/Select.d.ts +4 -0
  188. package/select/Select.js +122 -342
  189. package/select/Select.stories.tsx +594 -0
  190. package/select/Select.test.js +2120 -0
  191. package/select/types.d.ts +213 -0
  192. package/select/types.js +5 -0
  193. package/sidenav/Sidenav.d.ts +9 -0
  194. package/sidenav/Sidenav.js +26 -24
  195. package/sidenav/Sidenav.stories.tsx +182 -0
  196. package/sidenav/Sidenav.test.js +56 -0
  197. package/sidenav/types.d.ts +50 -0
  198. package/sidenav/types.js +5 -0
  199. package/slider/Slider.d.ts +4 -0
  200. package/slider/Slider.js +63 -85
  201. package/slider/Slider.stories.tsx +177 -0
  202. package/slider/Slider.test.js +150 -0
  203. package/slider/types.d.ts +82 -0
  204. package/slider/types.js +5 -0
  205. package/spinner/Spinner.d.ts +4 -0
  206. package/spinner/Spinner.js +9 -26
  207. package/spinner/Spinner.stories.jsx +103 -0
  208. package/spinner/Spinner.test.js +64 -0
  209. package/spinner/types.d.ts +32 -0
  210. package/spinner/types.js +5 -0
  211. package/stack/Stack.d.ts +3 -0
  212. package/stack/Stack.js +97 -0
  213. package/stack/Stack.stories.tsx +164 -0
  214. package/stack/types.d.ts +24 -0
  215. package/stack/types.js +5 -0
  216. package/switch/Switch.d.ts +1 -1
  217. package/switch/Switch.js +37 -21
  218. package/switch/Switch.stories.tsx +160 -0
  219. package/switch/Switch.test.js +98 -0
  220. package/switch/types.d.ts +6 -2
  221. package/table/Table.d.ts +4 -0
  222. package/table/Table.js +3 -3
  223. package/table/Table.stories.jsx +277 -0
  224. package/table/Table.test.js +26 -0
  225. package/table/types.d.ts +21 -0
  226. package/table/types.js +5 -0
  227. package/tabs/Tabs.d.ts +4 -0
  228. package/tabs/Tabs.js +24 -72
  229. package/tabs/Tabs.stories.tsx +112 -0
  230. package/tabs/Tabs.test.js +140 -0
  231. package/tabs/types.d.ts +82 -0
  232. package/tabs/types.js +5 -0
  233. package/tabs-nav/NavTabs.d.ts +8 -0
  234. package/tabs-nav/NavTabs.js +125 -0
  235. package/tabs-nav/NavTabs.stories.tsx +170 -0
  236. package/tabs-nav/NavTabs.test.js +82 -0
  237. package/tabs-nav/Tab.d.ts +4 -0
  238. package/tabs-nav/Tab.js +132 -0
  239. package/tabs-nav/types.d.ts +53 -0
  240. package/tabs-nav/types.js +5 -0
  241. package/tag/Tag.d.ts +4 -0
  242. package/tag/Tag.js +34 -59
  243. package/tag/Tag.stories.tsx +142 -0
  244. package/tag/Tag.test.js +60 -0
  245. package/tag/types.d.ts +69 -0
  246. package/tag/types.js +5 -0
  247. package/text/Text.d.ts +7 -0
  248. package/text/Text.js +30 -0
  249. package/text/Text.stories.tsx +19 -0
  250. package/text-input/Suggestion.d.ts +4 -0
  251. package/text-input/Suggestion.js +55 -0
  252. package/text-input/TextInput.d.ts +4 -0
  253. package/text-input/TextInput.js +91 -146
  254. package/text-input/TextInput.stories.tsx +474 -0
  255. package/text-input/TextInput.test.js +1712 -0
  256. package/text-input/types.d.ts +178 -0
  257. package/text-input/types.js +5 -0
  258. package/textarea/Textarea.d.ts +4 -0
  259. package/textarea/Textarea.js +39 -79
  260. package/textarea/Textarea.stories.jsx +157 -0
  261. package/textarea/Textarea.test.js +437 -0
  262. package/textarea/types.d.ts +137 -0
  263. package/textarea/types.js +5 -0
  264. package/toggle-group/ToggleGroup.d.ts +4 -0
  265. package/toggle-group/ToggleGroup.js +18 -46
  266. package/toggle-group/ToggleGroup.stories.tsx +173 -0
  267. package/toggle-group/ToggleGroup.test.js +156 -0
  268. package/toggle-group/types.d.ts +105 -0
  269. package/toggle-group/types.js +5 -0
  270. package/useTheme.d.ts +2 -0
  271. package/useTheme.js +2 -2
  272. package/useTranslatedLabels.d.ts +2 -0
  273. package/useTranslatedLabels.js +20 -0
  274. package/wizard/Wizard.d.ts +4 -0
  275. package/wizard/Wizard.js +115 -94
  276. package/wizard/Wizard.stories.tsx +214 -0
  277. package/wizard/Wizard.test.js +141 -0
  278. package/wizard/types.d.ts +64 -0
  279. package/wizard/types.js +5 -0
  280. package/ThemeContext.js +0 -246
  281. package/V3Select/V3Select.js +0 -455
  282. package/V3Select/index.d.ts +0 -27
  283. package/V3Textarea/V3Textarea.js +0 -260
  284. package/V3Textarea/index.d.ts +0 -27
  285. package/box/index.d.ts +0 -25
  286. package/card/index.d.ts +0 -22
  287. package/chip/index.d.ts +0 -22
  288. package/date/Date.js +0 -373
  289. package/date/index.d.ts +0 -27
  290. package/dialog/index.d.ts +0 -18
  291. package/dropdown/index.d.ts +0 -26
  292. package/file-input/index.d.ts +0 -81
  293. package/footer/index.d.ts +0 -25
  294. package/header/index.d.ts +0 -25
  295. package/heading/index.d.ts +0 -17
  296. package/input-text/Icons.js +0 -22
  297. package/input-text/InputText.js +0 -611
  298. package/input-text/index.d.ts +0 -36
  299. package/link/index.d.ts +0 -23
  300. package/number-input/index.d.ts +0 -113
  301. package/password-input/index.d.ts +0 -94
  302. package/progress-bar/index.d.ts +0 -18
  303. package/radio/Radio.d.ts +0 -4
  304. package/radio/Radio.js +0 -174
  305. package/radio/types.d.ts +0 -54
  306. package/resultsetTable/index.d.ts +0 -19
  307. package/select/index.d.ts +0 -131
  308. package/sidenav/index.d.ts +0 -13
  309. package/slider/index.d.ts +0 -29
  310. package/spinner/index.d.ts +0 -17
  311. package/table/index.d.ts +0 -13
  312. package/tabs/index.d.ts +0 -19
  313. package/tag/index.d.ts +0 -24
  314. package/text-input/index.d.ts +0 -135
  315. package/textarea/index.d.ts +0 -117
  316. package/toggle/Toggle.js +0 -186
  317. package/toggle/index.d.ts +0 -21
  318. package/toggle-group/index.d.ts +0 -21
  319. package/upload/Upload.js +0 -201
  320. package/upload/buttons-upload/ButtonsUpload.js +0 -111
  321. package/upload/buttons-upload/Icons.js +0 -40
  322. package/upload/dragAndDropArea/DragAndDropArea.js +0 -225
  323. package/upload/dragAndDropArea/Icons.js +0 -39
  324. package/upload/file-upload/FileToUpload.js +0 -115
  325. package/upload/file-upload/Icons.js +0 -66
  326. package/upload/files-upload/FilesToUpload.js +0 -109
  327. package/upload/index.d.ts +0 -15
  328. package/upload/transaction/Icons.js +0 -160
  329. package/upload/transaction/Transaction.js +0 -104
  330. package/upload/transactions/Transactions.js +0 -94
  331. package/wizard/Icons.js +0 -65
  332. package/wizard/index.d.ts +0 -18
@@ -21,15 +21,17 @@ var _styledComponents = _interopRequireWildcard(require("styled-components"));
21
21
 
22
22
  var _Checkbox = _interopRequireDefault(require("@material-ui/core/Checkbox"));
23
23
 
24
- var _RequiredComponent = _interopRequireDefault(require("../common/RequiredComponent"));
25
-
26
24
  var _variables = require("../common/variables.js");
27
25
 
28
26
  var _utils = require("../common/utils.js");
29
27
 
30
- var _useTheme = _interopRequireDefault(require("../useTheme.js"));
28
+ var _uuid = require("uuid");
29
+
30
+ var _useTheme = _interopRequireDefault(require("../useTheme"));
31
+
32
+ var _useTranslatedLabels = _interopRequireDefault(require("../useTranslatedLabels"));
31
33
 
32
- var _BackgroundColorContext = _interopRequireDefault(require("../BackgroundColorContext.js"));
34
+ var _BackgroundColorContext = _interopRequireDefault(require("../BackgroundColorContext"));
33
35
 
34
36
  var _templateObject, _templateObject2, _templateObject3;
35
37
 
@@ -39,6 +41,8 @@ function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj &&
39
41
 
40
42
  var DxcCheckbox = function DxcCheckbox(_ref) {
41
43
  var checked = _ref.checked,
44
+ _ref$defaultChecked = _ref.defaultChecked,
45
+ defaultChecked = _ref$defaultChecked === void 0 ? false : _ref$defaultChecked,
42
46
  value = _ref.value,
43
47
  _ref$label = _ref.label,
44
48
  label = _ref$label === void 0 ? "" : _ref$label,
@@ -48,27 +52,34 @@ var DxcCheckbox = function DxcCheckbox(_ref) {
48
52
  name = _ref$name === void 0 ? "" : _ref$name,
49
53
  _ref$disabled = _ref.disabled,
50
54
  disabled = _ref$disabled === void 0 ? false : _ref$disabled,
55
+ _ref$optional = _ref.optional,
56
+ optional = _ref$optional === void 0 ? false : _ref$optional,
51
57
  onChange = _ref.onChange,
52
- _ref$required = _ref.required,
53
- required = _ref$required === void 0 ? false : _ref$required,
54
58
  margin = _ref.margin,
55
59
  _ref$size = _ref.size,
56
60
  size = _ref$size === void 0 ? "fitContent" : _ref$size,
57
61
  _ref$tabIndex = _ref.tabIndex,
58
62
  tabIndex = _ref$tabIndex === void 0 ? 0 : _ref$tabIndex;
59
63
 
60
- var _useState = (0, _react.useState)(false),
61
- _useState2 = (0, _slicedToArray2["default"])(_useState, 2),
62
- innerChecked = _useState2[0],
63
- setInnerChecked = _useState2[1];
64
+ var _useState = (0, _react.useState)("checkbox-".concat((0, _uuid.v4)())),
65
+ _useState2 = (0, _slicedToArray2["default"])(_useState, 1),
66
+ switchId = _useState2[0];
64
67
 
65
- var _useState3 = (0, _react.useState)(false),
68
+ var labelId = "label-".concat(switchId);
69
+
70
+ var _useState3 = (0, _react.useState)(defaultChecked),
66
71
  _useState4 = (0, _slicedToArray2["default"])(_useState3, 2),
67
- isLabelHovered = _useState4[0],
68
- setIsLabelHovered = _useState4[1];
72
+ innerChecked = _useState4[0],
73
+ setInnerChecked = _useState4[1];
74
+
75
+ var _useState5 = (0, _react.useState)(false),
76
+ _useState6 = (0, _slicedToArray2["default"])(_useState5, 2),
77
+ isLabelHovered = _useState6[0],
78
+ setIsLabelHovered = _useState6[1];
69
79
 
70
80
  var colorsTheme = (0, _useTheme["default"])();
71
81
  var backgroundType = (0, _react.useContext)(_BackgroundColorContext["default"]);
82
+ var translatedLabels = (0, _useTranslatedLabels["default"])();
72
83
 
73
84
  var handlerCheckboxChange = function handlerCheckboxChange(checkboxValue) {
74
85
  if (checked === undefined) {
@@ -89,6 +100,17 @@ var DxcCheckbox = function DxcCheckbox(_ref) {
89
100
  setIsLabelHovered(!isLabelHovered);
90
101
  };
91
102
 
103
+ var labelComponent = /*#__PURE__*/_react["default"].createElement(LabelContainer, {
104
+ id: labelId,
105
+ labelPosition: labelPosition,
106
+ onClick: disabled === true ? function () {} : handlerCheckboxChange,
107
+ disabled: disabled,
108
+ className: "labelContainer",
109
+ backgroundType: backgroundType,
110
+ onMouseOver: handleLabelHover,
111
+ onMouseOut: handleLabelHover
112
+ }, labelPosition === "before" ? /*#__PURE__*/_react["default"].createElement(_react["default"].Fragment, null, label, " ", optional && /*#__PURE__*/_react["default"].createElement("span", null, translatedLabels.formFields.optionalLabel)) : /*#__PURE__*/_react["default"].createElement(_react["default"].Fragment, null, optional && /*#__PURE__*/_react["default"].createElement("span", null, "(Optional)"), " ", label));
113
+
92
114
  return /*#__PURE__*/_react["default"].createElement(_styledComponents.ThemeProvider, {
93
115
  theme: colorsTheme.checkbox
94
116
  }, /*#__PURE__*/_react["default"].createElement(CheckboxContainer, {
@@ -101,13 +123,13 @@ var DxcCheckbox = function DxcCheckbox(_ref) {
101
123
  size: size,
102
124
  backgroundType: backgroundType,
103
125
  isLabelHovered: isLabelHovered
104
- }, /*#__PURE__*/_react["default"].createElement(_Checkbox["default"], {
105
- checked: checked != undefined ? checked : innerChecked,
126
+ }, label && labelPosition === "before" && labelComponent, /*#__PURE__*/_react["default"].createElement(_Checkbox["default"], {
127
+ checked: checked !== null && checked !== void 0 ? checked : innerChecked,
106
128
  inputProps: {
107
129
  name: name,
108
- "aria-label": label,
130
+ "aria-labelledby": labelId,
109
131
  role: "checkbox",
110
- "aria-checked": checked != undefined ? checked : innerChecked
132
+ "aria-checked": checked !== null && checked !== void 0 ? checked : innerChecked
111
133
  },
112
134
  onChange: handlerCheckboxChange,
113
135
  value: value,
@@ -118,17 +140,9 @@ var DxcCheckbox = function DxcCheckbox(_ref) {
118
140
  }), /*#__PURE__*/_react["default"].createElement(CheckboxBlackBack, {
119
141
  labelPosition: labelPosition,
120
142
  disabled: disabled,
121
- checked: checked != undefined ? checked : innerChecked,
143
+ checked: checked !== null && checked !== void 0 ? checked : innerChecked,
122
144
  backgroundType: backgroundType
123
- }), required && /*#__PURE__*/_react["default"].createElement(_RequiredComponent["default"], null), label && /*#__PURE__*/_react["default"].createElement(LabelContainer, {
124
- labelPosition: labelPosition,
125
- onClick: disabled === true ? function (e) {} : handlerCheckboxChange,
126
- disabled: disabled,
127
- className: "labelContainer",
128
- backgroundType: backgroundType,
129
- onMouseOver: handleLabelHover,
130
- onMouseOut: handleLabelHover
131
- }, label)));
145
+ }), label && labelPosition === "after" && labelComponent));
132
146
  };
133
147
 
134
148
  var sizes = {
@@ -151,19 +165,15 @@ var getDisabledColor = function getDisabledColor(props, element) {
151
165
  switch (element) {
152
166
  case "check":
153
167
  return props.backgroundType && props.backgroundType === "dark" ? props.theme.disabledCheckColorOnDark : props.theme.disabledCheckColor;
154
- break;
155
168
 
156
169
  case "background":
157
170
  return props.backgroundType && props.backgroundType === "dark" ? props.theme.disabledBackgroundColorCheckedOnDark : props.theme.disabledBackgroundColorChecked;
158
- break;
159
171
 
160
172
  case "border":
161
173
  return props.backgroundType && props.backgroundType === "dark" ? props.theme.disabledBorderColorOnDark : props.theme.disabledBorderColor;
162
- break;
163
174
 
164
175
  case "label":
165
176
  return props.backgroundType && props.backgroundType === "dark" ? props.theme.disabledFontColorOnDark : props.theme.disabledFontColor;
166
- break;
167
177
  }
168
178
  };
169
179
 
@@ -171,35 +181,31 @@ var getNotDisabledColor = function getNotDisabledColor(props, element) {
171
181
  switch (element) {
172
182
  case "check":
173
183
  return props.backgroundType && props.backgroundType === "dark" ? props.theme.checkColorOnDark : props.theme.checkColor;
174
- break;
175
184
 
176
185
  case "background":
177
186
  return props.backgroundType && props.backgroundType === "dark" ? props.theme.backgroundColorCheckedOnDark : props.theme.backgroundColorChecked;
178
- break;
179
187
 
180
188
  case "border":
181
189
  return props.backgroundType && props.backgroundType === "dark" ? props.theme.borderColorOnDark : props.theme.borderColor;
182
- break;
183
190
 
184
191
  case "label":
185
192
  return props.backgroundType && props.backgroundType === "dark" ? props.theme.fontColorOnDark : props.theme.fontColor;
186
- break;
187
193
  }
188
194
  };
189
195
 
190
- var LabelContainer = _styledComponents["default"].span(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n color: ", ";\n cursor: ", ";\n font-family: ", ";\n font-size: ", ";\n font-weight: ", ";\n"])), function (props) {
196
+ var LabelContainer = _styledComponents["default"].span(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n color: ", ";\n font-family: ", ";\n font-size: ", ";\n font-weight: ", ";\n cursor: ", ";\n"])), function (props) {
191
197
  return props.disabled ? getDisabledColor(props, "label") : getNotDisabledColor(props, "label");
192
- }, function (props) {
193
- return props.disabled ? "not-allowed" : "pointer";
194
198
  }, function (props) {
195
199
  return props.theme.fontFamily;
196
200
  }, function (props) {
197
201
  return props.theme.fontSize;
198
202
  }, function (props) {
199
203
  return props.theme.fontWeight;
204
+ }, function (props) {
205
+ return props.disabled ? "not-allowed" : "pointer";
200
206
  });
201
207
 
202
- var CheckboxContainer = _styledComponents["default"].span(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n margin: ", ";\n margin-top: ", ";\n margin-right: ", ";\n margin-bottom: ", ";\n margin-left: ", ";\n width: ", ";\n display: inline-flex;\n align-items: center;\n cursor: ", ";\n position: relative;\n flex-direction: ", ";\n .MuiCheckbox-colorSecondary {\n .MuiIconButton-label {\n & > .MuiSvgIcon-root {\n color: ", ";\n }\n }\n &.Mui-disabled {\n .MuiIconButton-label {\n & > .MuiSvgIcon-root {\n color: ", ";\n opacity: 0.34;\n }\n }\n }\n &.Mui-checked {\n .MuiIconButton-label {\n & > .MuiSvgIcon-root {\n color: ", ";\n }\n }\n\n &:hover {\n background-color: transparent;\n .MuiIconButton-label {\n & > .MuiSvgIcon-root {\n background-color: transparent;\n color: ", ";\n }\n }\n }\n }\n .MuiIconButton-label {\n & > .MuiSvgIcon-root {\n width: 24px;\n height: 24px;\n }\n }\n }\n\n .MuiIconButton-colorSecondary {\n &:hover {\n background-color: transparent;\n }\n }\n .MuiButtonBase-root {\n &:hover {\n .MuiIconButton-label {\n & > .MuiSvgIcon-root {\n color: ", ";\n }\n }\n }\n\n &.Mui-focusVisible {\n .MuiIconButton-label {\n box-shadow: 0 0 0 2px\n ", ";\n }\n }\n z-index: 1;\n margin-left: ", ";\n margin-right: ", ";\n padding: 0px;\n left: ", ";\n right: ", ";\n }\n"])), function (props) {
208
+ var CheckboxContainer = _styledComponents["default"].span(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n margin: ", ";\n margin-top: ", ";\n margin-right: ", ";\n margin-bottom: ", ";\n margin-left: ", ";\n width: ", ";\n display: inline-flex;\n align-items: center;\n cursor: ", ";\n position: relative;\n .MuiCheckbox-colorSecondary {\n .MuiIconButton-label {\n & > .MuiSvgIcon-root {\n color: ", ";\n }\n }\n &.Mui-disabled {\n .MuiIconButton-label {\n & > .MuiSvgIcon-root {\n color: ", ";\n opacity: 0.34;\n }\n }\n }\n &.Mui-checked {\n .MuiIconButton-label {\n & > .MuiSvgIcon-root {\n color: ", ";\n }\n }\n\n &:hover {\n background-color: transparent;\n .MuiIconButton-label {\n & > .MuiSvgIcon-root {\n background-color: transparent;\n color: ", ";\n }\n }\n }\n }\n .MuiIconButton-label {\n & > .MuiSvgIcon-root {\n width: 24px;\n height: 24px;\n }\n }\n }\n\n .MuiIconButton-colorSecondary {\n &:hover {\n background-color: transparent;\n }\n }\n .MuiButtonBase-root {\n &:hover {\n .MuiIconButton-label {\n & > .MuiSvgIcon-root {\n color: ", ";\n }\n }\n }\n\n &.Mui-focusVisible {\n .MuiIconButton-label {\n border-radius: 2px;\n outline: 2px solid\n ", ";\n outline-offset: -1px;\n }\n }\n z-index: 1;\n margin-left: ", ";\n margin-right: ", ";\n padding: 0px;\n left: ", ";\n right: ", ";\n }\n"])), function (props) {
203
209
  return props.margin && (0, _typeof2["default"])(props.margin) !== "object" ? _variables.spaces[props.margin] : "0px";
204
210
  }, function (props) {
205
211
  return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.top ? _variables.spaces[props.margin.top] : "";
@@ -213,8 +219,6 @@ var CheckboxContainer = _styledComponents["default"].span(_templateObject2 || (_
213
219
  return calculateWidth(props.margin, props.size);
214
220
  }, function (props) {
215
221
  return props.disabled ? "not-allowed" : "pointer";
216
- }, function (props) {
217
- return props.labelPosition === "before" ? "row-reverse" : "row";
218
222
  }, function (props) {
219
223
  return props.isLabelHovered ? props.backgroundType === "dark" ? props.theme.hoverBorderColorOnDark : props.theme.hoverBorderColor : getNotDisabledColor(props, "border");
220
224
  }, function (props) {
@@ -0,0 +1,188 @@
1
+ import React from "react";
2
+ import DxcCheckbox from "./Checkbox";
3
+ import { BackgroundColorProvider } from "../BackgroundColorContext";
4
+ import Title from "../../.storybook/components/Title";
5
+ import ExampleContainer from "../../.storybook/components/ExampleContainer";
6
+ import DarkContainer from "../../.storybook/components/DarkSection";
7
+ import { userEvent } from "@storybook/testing-library";
8
+
9
+ export default {
10
+ title: "Checkbox",
11
+ component: DxcCheckbox,
12
+ };
13
+
14
+ const Checkbox = () => (
15
+ <>
16
+ <ExampleContainer>
17
+ <Title title="Default" theme="light" level={4} />
18
+ <DxcCheckbox label="Checkbox" />
19
+ </ExampleContainer>
20
+ <ExampleContainer>
21
+ <Title title="Focused" theme="light" level={4} />
22
+ <DxcCheckbox label="Focused" />
23
+ </ExampleContainer>
24
+ <ExampleContainer>
25
+ <Title title="Checked" theme="light" level={4} />
26
+ <DxcCheckbox label="Checkbox" defaultChecked />
27
+ </ExampleContainer>
28
+ <ExampleContainer>
29
+ <Title title="Optional" theme="light" level={4} />
30
+ <DxcCheckbox label="Checkbox" optional />
31
+ </ExampleContainer>
32
+ <ExampleContainer>
33
+ <Title title="Disabled and checked" theme="light" level={4} />
34
+ <DxcCheckbox label="Checkbox" disabled defaultChecked />
35
+ </ExampleContainer>
36
+ <ExampleContainer>
37
+ <Title title="Disabled and optional" theme="light" level={4} />
38
+ <DxcCheckbox label="Checkbox" disabled optional />
39
+ </ExampleContainer>
40
+ <ExampleContainer>
41
+ <Title title="Disabled, optional and checked" theme="light" level={4} />
42
+ <DxcCheckbox label="Checkbox" disabled optional defaultChecked />
43
+ </ExampleContainer>
44
+ <ExampleContainer>
45
+ <Title title="Label after" theme="light" level={4} />
46
+ <DxcCheckbox label="Checkbox" labelPosition="after" />
47
+ </ExampleContainer>
48
+ <ExampleContainer>
49
+ <Title title="Checked with label after" theme="light" level={4} />
50
+ <DxcCheckbox label="Checkbox" defaultChecked labelPosition="after" />
51
+ </ExampleContainer>
52
+ <ExampleContainer>
53
+ <Title title="Optional with label after" theme="light" level={4} />
54
+ <DxcCheckbox label="Checkbox" optional labelPosition="after" />
55
+ </ExampleContainer>
56
+ <ExampleContainer>
57
+ <Title title="Disabled and checked with label after" theme="light" level={4} />
58
+ <DxcCheckbox label="Checkbox" disabled defaultChecked labelPosition="after" />
59
+ </ExampleContainer>
60
+ <ExampleContainer>
61
+ <Title title="Disabled and optional with label after" theme="light" level={4} />
62
+ <DxcCheckbox label="Checkbox" disabled optional labelPosition="after" />
63
+ </ExampleContainer>
64
+ <ExampleContainer>
65
+ <Title title="Disabled, optional and checked with label after" theme="light" level={4} />
66
+ <DxcCheckbox label="Checkbox" disabled optional defaultChecked labelPosition="after" />
67
+ </ExampleContainer>
68
+ <ExampleContainer pseudoState="pseudo-hover">
69
+ <Title title="Hovered" theme="light" level={4} />
70
+ <DxcCheckbox label="Hovered" />
71
+ </ExampleContainer>
72
+ <ExampleContainer pseudoState="pseudo-hover">
73
+ <Title title="Hovered and checked" theme="light" level={4} />
74
+ <DxcCheckbox label="Hovered" defaultChecked />
75
+ </ExampleContainer>
76
+ <BackgroundColorProvider color="#333333">
77
+ <DarkContainer>
78
+ <ExampleContainer>
79
+ <Title title="Default" theme="dark" level={4} />
80
+ <DxcCheckbox label="Checkbox" />
81
+ </ExampleContainer>
82
+ <ExampleContainer>
83
+ <Title title="Checked" theme="dark" level={4} />
84
+ <DxcCheckbox label="Checkbox" defaultChecked />
85
+ </ExampleContainer>
86
+ <ExampleContainer>
87
+ <Title title="Optional" theme="dark" level={4} />
88
+ <DxcCheckbox label="Checkbox" optional />
89
+ </ExampleContainer>
90
+ <ExampleContainer>
91
+ <Title title="Disabled and checked" theme="dark" level={4} />
92
+ <DxcCheckbox label="Checkbox" disabled defaultChecked />
93
+ </ExampleContainer>
94
+ <ExampleContainer>
95
+ <Title title="Disabled and optional" theme="dark" level={4} />
96
+ <DxcCheckbox label="Checkbox" disabled optional />
97
+ </ExampleContainer>
98
+ <ExampleContainer>
99
+ <Title title="Disabled, optional and checked" theme="dark" level={4} />
100
+ <DxcCheckbox label="Checkbox" disabled optional defaultChecked />
101
+ </ExampleContainer>
102
+ <ExampleContainer>
103
+ <Title title="Label after" theme="dark" level={4} />
104
+ <DxcCheckbox label="Checkbox" labelPosition="after" />
105
+ </ExampleContainer>
106
+ <ExampleContainer>
107
+ <Title title="Checked with label after" theme="dark" level={4} />
108
+ <DxcCheckbox label="Checkbox" defaultChecked labelPosition="after" />
109
+ </ExampleContainer>
110
+ <ExampleContainer>
111
+ <Title title="Optional with label after" theme="dark" level={4} />
112
+ <DxcCheckbox label="Checkbox" optional labelPosition="after" />
113
+ </ExampleContainer>
114
+ <ExampleContainer>
115
+ <Title title="Disabled and checked with label after" theme="dark" level={4} />
116
+ <DxcCheckbox label="Checkbox" disabled defaultChecked labelPosition="after" />
117
+ </ExampleContainer>
118
+ <ExampleContainer>
119
+ <Title title="Disabled and optional with label after" theme="dark" level={4} />
120
+ <DxcCheckbox label="Checkbox" disabled optional labelPosition="after" />
121
+ </ExampleContainer>
122
+ <ExampleContainer>
123
+ <Title title="Disabled, optional and checked with label after" theme="dark" level={4} />
124
+ <DxcCheckbox label="Checkbox" disabled optional defaultChecked labelPosition="after" />
125
+ </ExampleContainer>
126
+ <ExampleContainer pseudoState="pseudo-hover">
127
+ <Title title="Hovered" theme="dark" level={4} />
128
+ <DxcCheckbox label="Hovered" />
129
+ </ExampleContainer>
130
+ <ExampleContainer pseudoState="pseudo-hover">
131
+ <Title title="Hovered and checked" theme="dark" level={4} />
132
+ <DxcCheckbox label="Hovered" defaultChecked />
133
+ </ExampleContainer>
134
+ </DarkContainer>
135
+ </BackgroundColorProvider>
136
+ <Title title="Sizes" theme="light" level={2} />
137
+ <ExampleContainer>
138
+ <DxcCheckbox label="Small" size="small" />
139
+ </ExampleContainer>
140
+ <ExampleContainer>
141
+ <DxcCheckbox label="Medium" size="medium" />
142
+ </ExampleContainer>
143
+ <ExampleContainer>
144
+ <DxcCheckbox label="Large" size="large" />
145
+ </ExampleContainer>
146
+ <ExampleContainer>
147
+ <DxcCheckbox label="FitContent" size="fitContent" />
148
+ </ExampleContainer>
149
+ <ExampleContainer>
150
+ <DxcCheckbox label="FillParent" size="fillParent" />
151
+ </ExampleContainer>
152
+ <Title title="Margins" theme="light" level={2} />
153
+ <ExampleContainer>
154
+ <Title title="Xxsmall" theme="light" level={4} />
155
+ <DxcCheckbox label="Xxsmall" margin="xxsmall" />
156
+ </ExampleContainer>
157
+ <ExampleContainer>
158
+ <Title title="Xsmall" theme="light" level={4} />
159
+ <DxcCheckbox label="Xsmall" margin="xsmall" />
160
+ </ExampleContainer>
161
+ <ExampleContainer>
162
+ <Title title="Small" theme="light" level={4} />
163
+ <DxcCheckbox label="Small" margin="small" />
164
+ </ExampleContainer>
165
+ <ExampleContainer>
166
+ <Title title="Medium" theme="light" level={4} />
167
+ <DxcCheckbox label="Medium" margin="medium" />
168
+ </ExampleContainer>
169
+ <ExampleContainer>
170
+ <Title title="Large" theme="light" level={4} />
171
+ <DxcCheckbox label="Large" margin="large" />
172
+ </ExampleContainer>
173
+ <ExampleContainer>
174
+ <Title title="Xlarge" theme="light" level={4} />
175
+ <DxcCheckbox label="Xlarge" margin="xlarge" />
176
+ </ExampleContainer>
177
+ <ExampleContainer>
178
+ <Title title="Xxlarge" theme="light" level={4} />
179
+ <DxcCheckbox label="Xxlarge" margin="xxlarge" />
180
+ </ExampleContainer>
181
+ </>
182
+ );
183
+
184
+ export const Chromatic = Checkbox.bind({});
185
+ Chromatic.play = async () => {
186
+ await userEvent.tab();
187
+ await userEvent.tab();
188
+ };
@@ -0,0 +1,78 @@
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 _Checkbox = _interopRequireDefault(require("./Checkbox"));
10
+
11
+ describe("Checkbox component tests", function () {
12
+ test("Checkbox renders with correct text", function () {
13
+ var _render = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Checkbox["default"], {
14
+ label: "Checkbox"
15
+ })),
16
+ getByText = _render.getByText;
17
+
18
+ expect(getByText("Checkbox")).toBeTruthy();
19
+ });
20
+ test("Calls correct function on click", function () {
21
+ var onChange = jest.fn();
22
+
23
+ var _render2 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Checkbox["default"], {
24
+ label: "Checkbox",
25
+ onChange: onChange
26
+ })),
27
+ getByText = _render2.getByText;
28
+
29
+ _react2.fireEvent.click(getByText("Checkbox"));
30
+
31
+ expect(onChange).toHaveBeenCalled();
32
+ });
33
+ test("Uncontrolled checkbox", function () {
34
+ var onChange = jest.fn();
35
+ var component = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Checkbox["default"], {
36
+ label: "Checkbox",
37
+ onChange: onChange
38
+ }));
39
+ var visibleCheckbox = component.getByText("Checkbox");
40
+ var input = component.getByRole("checkbox");
41
+ expect(input.checked).toBe(false);
42
+
43
+ _react2.fireEvent.click(visibleCheckbox);
44
+
45
+ expect(onChange).toHaveBeenCalled();
46
+ expect(onChange).toHaveBeenCalledWith(true);
47
+ expect(input.checked).toBe(true);
48
+ });
49
+ test("Controlled checkbox", function () {
50
+ var onChange = jest.fn();
51
+ var component = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Checkbox["default"], {
52
+ label: "Checkbox",
53
+ checked: false,
54
+ onChange: onChange
55
+ }));
56
+ var input = component.getByRole("checkbox");
57
+ var visibleCheckbox = component.getByText("Checkbox");
58
+
59
+ _react2.fireEvent.click(visibleCheckbox);
60
+
61
+ expect(onChange).toHaveBeenCalled();
62
+ expect(onChange).toHaveBeenCalledWith(true);
63
+ expect(input.checked).toBe(false);
64
+ });
65
+ test("Renders with correct initial value and initial state when it is uncontrolled", function () {
66
+ var _render3 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Checkbox["default"], {
67
+ label: "Default label",
68
+ defaultChecked: true,
69
+ value: "test-defaultChecked"
70
+ })),
71
+ getByRole = _render3.getByRole;
72
+
73
+ var input = getByRole("checkbox");
74
+ expect(input.checked).toBe(true);
75
+ expect(input.value).toBe("test-defaultChecked");
76
+ expect(input.getAttribute("aria-checked")).toBe("true");
77
+ });
78
+ });
@@ -1,4 +1,3 @@
1
- declare type Size = "small" | "medium" | "large" | "fillParent" | "fitContent";
2
1
  declare type Space = "xxsmall" | "xsmall" | "small" | "medium" | "large" | "xlarge" | "xxlarge";
3
2
  declare type Margin = {
4
3
  top?: Space;
@@ -7,6 +6,10 @@ declare type Margin = {
7
6
  right?: Space;
8
7
  };
9
8
  declare type Props = {
9
+ /**
10
+ * Initial state of the checkbox, only when it is uncontrolled.
11
+ */
12
+ defaultChecked?: boolean;
10
13
  /**
11
14
  * If true, the component is checked. If undefined the component will be
12
15
  * uncontrolled and the value will be managed internally by the component.
@@ -34,14 +37,14 @@ declare type Props = {
34
37
  */
35
38
  disabled?: boolean;
36
39
  /**
37
- * If true, the checkbox will change its appearence, showing that the value is required.
40
+ * If true, the component will display '(Optional)' next to the label.
38
41
  */
39
- required?: boolean;
42
+ optional?: boolean;
40
43
  /**
41
44
  * This function will be called when the user clicks the checkbox.
42
45
  * The new value will be passed as a parameter.
43
46
  */
44
- onChange?: (val: boolean) => void;
47
+ onChange?: (value: boolean) => void;
45
48
  /**
46
49
  * Size of the margin to be applied to the component
47
50
  * ('xxsmall' | 'xsmall' | 'small' | 'medium' | 'large' | 'xlarge' | 'xxlarge').
@@ -50,9 +53,9 @@ declare type Props = {
50
53
  */
51
54
  margin?: Space | Margin;
52
55
  /**
53
- * Size of the component ('small' | 'medium' | 'large' | 'fillParent' | 'fitContent').
56
+ * Size of the component.
54
57
  */
55
- size?: Size;
58
+ size?: "small" | "medium" | "large" | "fillParent" | "fitContent";
56
59
  /**
57
60
  * Value of the tabindex.
58
61
  */
package/chip/Chip.d.ts ADDED
@@ -0,0 +1,4 @@
1
+ /// <reference types="react" />
2
+ import ChipPropsType from "./types";
3
+ declare const DxcChip: ({ label, suffixIcon, prefixIcon, onClickSuffix, onClickPrefix, disabled, margin, tabIndex, }: ChipPropsType) => JSX.Element;
4
+ export default DxcChip;