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

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 (355) hide show
  1. package/BackgroundColorContext.d.ts +10 -0
  2. package/BackgroundColorContext.js +7 -22
  3. package/HalstackContext.d.ts +1353 -0
  4. package/HalstackContext.js +310 -0
  5. package/README.md +47 -0
  6. package/accordion/Accordion.d.ts +1 -1
  7. package/accordion/Accordion.js +119 -192
  8. package/accordion/Accordion.stories.tsx +283 -0
  9. package/accordion/Accordion.test.js +56 -0
  10. package/accordion/types.d.ts +12 -23
  11. package/accordion-group/AccordionGroup.d.ts +5 -4
  12. package/accordion-group/AccordionGroup.js +39 -108
  13. package/accordion-group/AccordionGroup.stories.tsx +252 -0
  14. package/accordion-group/AccordionGroup.test.js +98 -0
  15. package/accordion-group/AccordionGroupAccordion.d.ts +4 -0
  16. package/accordion-group/AccordionGroupAccordion.js +31 -0
  17. package/accordion-group/types.d.ts +18 -23
  18. package/alert/Alert.js +24 -57
  19. package/alert/Alert.stories.tsx +198 -0
  20. package/alert/Alert.test.js +75 -0
  21. package/alert/types.d.ts +6 -6
  22. package/badge/Badge.d.ts +4 -0
  23. package/badge/Badge.js +9 -20
  24. package/badge/types.d.ts +5 -0
  25. package/bleed/Bleed.d.ts +3 -0
  26. package/bleed/Bleed.js +43 -0
  27. package/bleed/Bleed.stories.tsx +342 -0
  28. package/bleed/types.d.ts +37 -0
  29. package/bleed/types.js +5 -0
  30. package/box/Box.d.ts +1 -1
  31. package/box/Box.js +32 -83
  32. package/box/Box.stories.tsx +38 -51
  33. package/box/Box.test.js +13 -0
  34. package/box/types.d.ts +3 -18
  35. package/bulleted-list/BulletedList.d.ts +7 -0
  36. package/bulleted-list/BulletedList.js +99 -0
  37. package/bulleted-list/BulletedList.stories.tsx +116 -0
  38. package/bulleted-list/types.d.ts +38 -0
  39. package/bulleted-list/types.js +5 -0
  40. package/button/Button.d.ts +1 -1
  41. package/button/Button.js +64 -120
  42. package/button/Button.stories.tsx +328 -277
  43. package/button/Button.test.js +36 -0
  44. package/button/types.d.ts +14 -14
  45. package/card/Card.d.ts +1 -1
  46. package/card/Card.js +59 -104
  47. package/card/Card.stories.tsx +171 -0
  48. package/card/Card.test.js +39 -0
  49. package/card/types.d.ts +8 -15
  50. package/checkbox/Checkbox.d.ts +2 -2
  51. package/checkbox/Checkbox.js +147 -180
  52. package/checkbox/Checkbox.stories.tsx +166 -136
  53. package/checkbox/Checkbox.test.js +199 -0
  54. package/checkbox/types.d.ts +20 -8
  55. package/chip/Chip.d.ts +4 -0
  56. package/chip/Chip.js +48 -148
  57. package/chip/Chip.stories.tsx +214 -0
  58. package/chip/Chip.test.js +41 -0
  59. package/chip/types.d.ts +45 -0
  60. package/chip/types.js +5 -0
  61. package/common/OpenSans.css +68 -80
  62. package/common/coreTokens.d.ts +237 -0
  63. package/common/coreTokens.js +184 -0
  64. package/common/utils.d.ts +1 -0
  65. package/common/utils.js +6 -12
  66. package/common/variables.d.ts +1499 -0
  67. package/common/variables.js +1119 -1317
  68. package/container/Container.d.ts +4 -0
  69. package/container/Container.js +198 -0
  70. package/container/Container.stories.tsx +229 -0
  71. package/container/types.d.ts +74 -0
  72. package/container/types.js +5 -0
  73. package/date-input/Calendar.d.ts +4 -0
  74. package/date-input/Calendar.js +214 -0
  75. package/date-input/DateInput.js +175 -313
  76. package/date-input/DateInput.stories.tsx +285 -0
  77. package/date-input/DateInput.test.js +808 -0
  78. package/date-input/DatePicker.d.ts +4 -0
  79. package/date-input/DatePicker.js +115 -0
  80. package/date-input/Icons.d.ts +6 -0
  81. package/date-input/Icons.js +58 -0
  82. package/date-input/YearPicker.d.ts +4 -0
  83. package/date-input/YearPicker.js +100 -0
  84. package/date-input/types.d.ts +86 -22
  85. package/dialog/Dialog.d.ts +1 -1
  86. package/dialog/Dialog.js +72 -130
  87. package/dialog/Dialog.stories.tsx +195 -0
  88. package/dialog/Dialog.test.js +307 -0
  89. package/dialog/types.d.ts +18 -25
  90. package/dropdown/Dropdown.d.ts +1 -1
  91. package/dropdown/Dropdown.js +245 -328
  92. package/dropdown/Dropdown.stories.tsx +438 -0
  93. package/dropdown/Dropdown.test.js +599 -0
  94. package/dropdown/DropdownMenu.d.ts +4 -0
  95. package/dropdown/DropdownMenu.js +63 -0
  96. package/dropdown/DropdownMenuItem.d.ts +4 -0
  97. package/dropdown/DropdownMenuItem.js +67 -0
  98. package/dropdown/types.d.ts +37 -28
  99. package/file-input/FileInput.d.ts +4 -0
  100. package/file-input/FileInput.js +274 -327
  101. package/file-input/FileInput.stories.tsx +618 -0
  102. package/file-input/FileInput.test.js +459 -0
  103. package/file-input/FileItem.d.ts +4 -0
  104. package/file-input/FileItem.js +54 -112
  105. package/file-input/types.d.ts +129 -0
  106. package/file-input/types.js +5 -0
  107. package/flex/Flex.d.ts +4 -0
  108. package/flex/Flex.js +57 -0
  109. package/flex/Flex.stories.tsx +112 -0
  110. package/flex/types.d.ts +97 -0
  111. package/flex/types.js +5 -0
  112. package/footer/Footer.d.ts +1 -1
  113. package/footer/Footer.js +61 -192
  114. package/footer/{Footer.stories.jsx → Footer.stories.tsx} +38 -37
  115. package/footer/Footer.test.js +85 -0
  116. package/footer/Icons.d.ts +2 -0
  117. package/footer/Icons.js +4 -9
  118. package/footer/types.d.ts +36 -33
  119. package/grid/Grid.d.ts +7 -0
  120. package/grid/Grid.js +76 -0
  121. package/grid/Grid.stories.tsx +219 -0
  122. package/grid/types.d.ts +115 -0
  123. package/grid/types.js +5 -0
  124. package/header/Header.d.ts +4 -3
  125. package/header/Header.js +106 -199
  126. package/header/Header.stories.tsx +251 -0
  127. package/header/Header.test.js +66 -0
  128. package/header/Icons.d.ts +2 -0
  129. package/header/Icons.js +4 -9
  130. package/header/types.d.ts +4 -17
  131. package/heading/Heading.d.ts +4 -0
  132. package/heading/Heading.js +16 -55
  133. package/heading/Heading.stories.tsx +54 -0
  134. package/heading/Heading.test.js +169 -0
  135. package/heading/types.d.ts +33 -0
  136. package/heading/types.js +5 -0
  137. package/image/Image.d.ts +4 -0
  138. package/image/Image.js +70 -0
  139. package/image/Image.stories.tsx +127 -0
  140. package/image/types.d.ts +72 -0
  141. package/image/types.js +5 -0
  142. package/inset/Inset.d.ts +3 -0
  143. package/inset/Inset.js +43 -0
  144. package/inset/Inset.stories.tsx +230 -0
  145. package/inset/types.d.ts +37 -0
  146. package/inset/types.js +5 -0
  147. package/layout/ApplicationLayout.d.ts +20 -0
  148. package/layout/ApplicationLayout.js +83 -184
  149. package/layout/ApplicationLayout.stories.tsx +162 -0
  150. package/layout/Icons.d.ts +8 -0
  151. package/layout/Icons.js +51 -48
  152. package/layout/SidenavContext.d.ts +5 -0
  153. package/layout/SidenavContext.js +13 -0
  154. package/layout/types.d.ts +41 -0
  155. package/layout/types.js +5 -0
  156. package/link/Link.d.ts +3 -2
  157. package/link/Link.js +65 -111
  158. package/link/Link.stories.tsx +253 -0
  159. package/link/Link.test.js +63 -0
  160. package/link/types.d.ts +15 -35
  161. package/main.d.ts +16 -13
  162. package/main.js +71 -91
  163. package/nav-tabs/NavTabs.d.ts +8 -0
  164. package/nav-tabs/NavTabs.js +90 -0
  165. package/nav-tabs/NavTabs.stories.tsx +274 -0
  166. package/nav-tabs/NavTabs.test.js +75 -0
  167. package/nav-tabs/Tab.d.ts +4 -0
  168. package/nav-tabs/Tab.js +117 -0
  169. package/nav-tabs/types.d.ts +52 -0
  170. package/nav-tabs/types.js +5 -0
  171. package/number-input/NumberInput.d.ts +11 -0
  172. package/number-input/NumberInput.js +28 -89
  173. package/number-input/{NumberInput.stories.jsx → NumberInput.stories.tsx} +44 -28
  174. package/number-input/NumberInput.test.js +830 -0
  175. package/number-input/types.d.ts +130 -0
  176. package/number-input/types.js +5 -0
  177. package/package.json +46 -45
  178. package/paginator/Icons.d.ts +5 -0
  179. package/paginator/Icons.js +21 -47
  180. package/paginator/Paginator.js +35 -95
  181. package/paginator/Paginator.stories.tsx +24 -0
  182. package/paginator/Paginator.test.js +335 -0
  183. package/paginator/types.d.ts +3 -3
  184. package/paragraph/Paragraph.d.ts +5 -0
  185. package/paragraph/Paragraph.js +27 -0
  186. package/paragraph/Paragraph.stories.tsx +27 -0
  187. package/password-input/Icons.d.ts +6 -0
  188. package/password-input/Icons.js +35 -0
  189. package/password-input/PasswordInput.js +60 -125
  190. package/password-input/PasswordInput.stories.tsx +3 -34
  191. package/password-input/PasswordInput.test.js +198 -0
  192. package/password-input/types.d.ts +35 -24
  193. package/progress-bar/ProgressBar.js +69 -89
  194. package/progress-bar/ProgressBar.stories.tsx +93 -0
  195. package/progress-bar/ProgressBar.test.js +93 -0
  196. package/progress-bar/types.d.ts +3 -3
  197. package/quick-nav/QuickNav.d.ts +4 -0
  198. package/quick-nav/QuickNav.js +94 -0
  199. package/quick-nav/QuickNav.stories.tsx +356 -0
  200. package/quick-nav/types.d.ts +21 -0
  201. package/quick-nav/types.js +5 -0
  202. package/radio-group/Radio.d.ts +4 -0
  203. package/radio-group/Radio.js +124 -0
  204. package/radio-group/RadioGroup.d.ts +4 -0
  205. package/radio-group/RadioGroup.js +235 -0
  206. package/radio-group/RadioGroup.stories.tsx +214 -0
  207. package/radio-group/RadioGroup.test.js +756 -0
  208. package/radio-group/types.d.ts +114 -0
  209. package/radio-group/types.js +5 -0
  210. package/resultset-table/Icons.d.ts +7 -0
  211. package/resultset-table/Icons.js +47 -0
  212. package/resultset-table/ResultsetTable.d.ts +4 -0
  213. package/resultset-table/ResultsetTable.js +159 -0
  214. package/resultset-table/ResultsetTable.stories.tsx +300 -0
  215. package/resultset-table/ResultsetTable.test.js +305 -0
  216. package/resultset-table/types.d.ts +67 -0
  217. package/resultset-table/types.js +5 -0
  218. package/select/Icons.d.ts +10 -0
  219. package/select/Icons.js +89 -0
  220. package/select/Listbox.d.ts +4 -0
  221. package/select/Listbox.js +143 -0
  222. package/select/Option.d.ts +4 -0
  223. package/select/Option.js +80 -0
  224. package/select/Select.d.ts +4 -0
  225. package/select/Select.js +221 -504
  226. package/select/Select.stories.tsx +971 -0
  227. package/select/Select.test.js +2334 -0
  228. package/select/types.d.ts +209 -0
  229. package/select/types.js +5 -0
  230. package/sidenav/Icons.d.ts +7 -0
  231. package/sidenav/Icons.js +47 -0
  232. package/sidenav/Sidenav.d.ts +10 -0
  233. package/sidenav/Sidenav.js +135 -81
  234. package/sidenav/Sidenav.stories.tsx +282 -0
  235. package/sidenav/Sidenav.test.js +37 -0
  236. package/sidenav/types.d.ts +76 -0
  237. package/sidenav/types.js +5 -0
  238. package/slider/Slider.d.ts +2 -2
  239. package/slider/Slider.js +168 -180
  240. package/slider/Slider.test.js +254 -0
  241. package/slider/types.d.ts +13 -10
  242. package/spinner/Spinner.js +30 -66
  243. package/spinner/{Spinner.stories.jsx → Spinner.stories.tsx} +53 -26
  244. package/spinner/Spinner.test.js +55 -0
  245. package/spinner/types.d.ts +3 -3
  246. package/switch/Switch.d.ts +2 -2
  247. package/switch/Switch.js +154 -114
  248. package/switch/Switch.stories.tsx +45 -68
  249. package/switch/Switch.test.js +180 -0
  250. package/switch/types.d.ts +13 -5
  251. package/table/Table.js +10 -29
  252. package/table/{Table.stories.jsx → Table.stories.tsx} +81 -1
  253. package/table/Table.test.js +21 -0
  254. package/table/types.d.ts +8 -8
  255. package/tabs/Tab.d.ts +4 -0
  256. package/tabs/Tab.js +113 -0
  257. package/tabs/Tabs.d.ts +1 -1
  258. package/tabs/Tabs.js +319 -145
  259. package/tabs/Tabs.stories.tsx +226 -0
  260. package/tabs/Tabs.test.js +294 -0
  261. package/tabs/types.d.ts +48 -27
  262. package/tag/Tag.d.ts +1 -1
  263. package/tag/Tag.js +44 -86
  264. package/tag/Tag.stories.tsx +38 -28
  265. package/tag/Tag.test.js +49 -0
  266. package/tag/types.d.ts +25 -16
  267. package/text-input/Icons.d.ts +8 -0
  268. package/text-input/Icons.js +56 -0
  269. package/text-input/Suggestion.d.ts +4 -0
  270. package/text-input/Suggestion.js +67 -0
  271. package/text-input/Suggestions.d.ts +4 -0
  272. package/text-input/Suggestions.js +89 -0
  273. package/text-input/TextInput.d.ts +4 -0
  274. package/text-input/TextInput.js +310 -543
  275. package/text-input/TextInput.stories.tsx +465 -0
  276. package/text-input/TextInput.test.js +1739 -0
  277. package/text-input/types.d.ts +205 -0
  278. package/text-input/types.js +5 -0
  279. package/textarea/Textarea.d.ts +4 -0
  280. package/textarea/Textarea.js +94 -171
  281. package/textarea/Textarea.stories.tsx +175 -0
  282. package/textarea/Textarea.test.js +406 -0
  283. package/textarea/types.d.ts +141 -0
  284. package/textarea/types.js +5 -0
  285. package/toggle-group/ToggleGroup.d.ts +4 -0
  286. package/toggle-group/ToggleGroup.js +103 -142
  287. package/toggle-group/ToggleGroup.stories.tsx +218 -0
  288. package/toggle-group/ToggleGroup.test.js +137 -0
  289. package/toggle-group/types.d.ts +114 -0
  290. package/toggle-group/types.js +5 -0
  291. package/typography/Typography.d.ts +4 -0
  292. package/typography/Typography.js +23 -0
  293. package/typography/Typography.stories.tsx +198 -0
  294. package/typography/types.d.ts +18 -0
  295. package/typography/types.js +5 -0
  296. package/useTheme.d.ts +1252 -0
  297. package/useTheme.js +4 -11
  298. package/useTranslatedLabels.d.ts +85 -0
  299. package/useTranslatedLabels.js +14 -0
  300. package/utils/BaseTypography.d.ts +21 -0
  301. package/utils/BaseTypography.js +94 -0
  302. package/utils/FocusLock.d.ts +13 -0
  303. package/utils/FocusLock.js +114 -0
  304. package/wizard/Wizard.d.ts +4 -0
  305. package/wizard/Wizard.js +130 -151
  306. package/wizard/Wizard.stories.tsx +253 -0
  307. package/wizard/Wizard.test.js +114 -0
  308. package/wizard/types.d.ts +64 -0
  309. package/wizard/types.js +5 -0
  310. package/ThemeContext.js +0 -246
  311. package/V3Select/V3Select.js +0 -455
  312. package/V3Select/index.d.ts +0 -27
  313. package/V3Textarea/V3Textarea.js +0 -260
  314. package/V3Textarea/index.d.ts +0 -27
  315. package/chip/index.d.ts +0 -22
  316. package/common/RequiredComponent.js +0 -32
  317. package/date/Date.js +0 -373
  318. package/date/index.d.ts +0 -27
  319. package/file-input/index.d.ts +0 -81
  320. package/heading/index.d.ts +0 -17
  321. package/input-text/Icons.js +0 -22
  322. package/input-text/InputText.js +0 -611
  323. package/input-text/index.d.ts +0 -36
  324. package/number-input/NumberInputContext.js +0 -16
  325. package/number-input/index.d.ts +0 -113
  326. package/progress-bar/ProgressBar.stories.jsx +0 -58
  327. package/radio/Radio.d.ts +0 -4
  328. package/radio/Radio.js +0 -174
  329. package/radio/Radio.stories.tsx +0 -192
  330. package/radio/types.d.ts +0 -54
  331. package/resultsetTable/ResultsetTable.js +0 -274
  332. package/resultsetTable/index.d.ts +0 -19
  333. package/select/index.d.ts +0 -131
  334. package/sidenav/index.d.ts +0 -13
  335. package/text-input/index.d.ts +0 -135
  336. package/textarea/Textarea.stories.jsx +0 -135
  337. package/textarea/index.d.ts +0 -117
  338. package/toggle/Toggle.js +0 -186
  339. package/toggle/index.d.ts +0 -21
  340. package/toggle-group/index.d.ts +0 -21
  341. package/upload/Upload.js +0 -201
  342. package/upload/buttons-upload/ButtonsUpload.js +0 -111
  343. package/upload/buttons-upload/Icons.js +0 -40
  344. package/upload/dragAndDropArea/DragAndDropArea.js +0 -225
  345. package/upload/dragAndDropArea/Icons.js +0 -39
  346. package/upload/file-upload/FileToUpload.js +0 -115
  347. package/upload/file-upload/Icons.js +0 -66
  348. package/upload/files-upload/FilesToUpload.js +0 -109
  349. package/upload/index.d.ts +0 -15
  350. package/upload/transaction/Icons.js +0 -160
  351. package/upload/transaction/Transaction.js +0 -104
  352. package/upload/transactions/Transactions.js +0 -94
  353. package/wizard/Icons.js +0 -65
  354. package/wizard/index.d.ts +0 -18
  355. /package/{radio → badge}/types.js +0 -0
@@ -1,196 +1,181 @@
1
1
  "use strict";
2
2
 
3
3
  var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
-
5
4
  var _typeof3 = require("@babel/runtime/helpers/typeof");
6
-
7
5
  Object.defineProperty(exports, "__esModule", {
8
6
  value: true
9
7
  });
10
8
  exports["default"] = void 0;
11
-
12
9
  var _typeof2 = _interopRequireDefault(require("@babel/runtime/helpers/typeof"));
13
-
14
10
  var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
15
-
16
11
  var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
17
-
18
12
  var _react = _interopRequireWildcard(require("react"));
19
-
20
13
  var _styledComponents = _interopRequireWildcard(require("styled-components"));
21
-
22
- var _Checkbox = _interopRequireDefault(require("@material-ui/core/Checkbox"));
23
-
24
- var _RequiredComponent = _interopRequireDefault(require("../common/RequiredComponent"));
25
-
26
- var _variables = require("../common/variables.js");
27
-
28
- var _utils = require("../common/utils.js");
29
-
30
- var _useTheme = _interopRequireDefault(require("../useTheme.js"));
31
-
32
- var _BackgroundColorContext = _interopRequireDefault(require("../BackgroundColorContext.js"));
33
-
34
- var _templateObject, _templateObject2, _templateObject3;
35
-
36
- function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
37
-
38
- function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof3(obj) !== "object" && typeof obj !== "function") { return { "default": obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj["default"] = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
39
-
40
- var DxcCheckbox = function DxcCheckbox(_ref) {
14
+ var _variables = require("../common/variables");
15
+ var _utils = require("../common/utils");
16
+ var _uuid = require("uuid");
17
+ var _useTheme = _interopRequireDefault(require("../useTheme"));
18
+ var _useTranslatedLabels = _interopRequireDefault(require("../useTranslatedLabels"));
19
+ var _BackgroundColorContext = _interopRequireDefault(require("../BackgroundColorContext"));
20
+ var _templateObject, _templateObject2, _templateObject3, _templateObject4, _templateObject5;
21
+ function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(e) { return e ? t : r; })(e); }
22
+ function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != _typeof3(e) && "function" != typeof e) return { "default": e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && Object.prototype.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n["default"] = e, t && t.set(e, n), n; }
23
+ var checkedIcon = /*#__PURE__*/_react["default"].createElement("svg", {
24
+ fill: "currentColor",
25
+ focusable: "false",
26
+ "aria-hidden": "true",
27
+ viewBox: "0 0 24 24"
28
+ }, /*#__PURE__*/_react["default"].createElement("path", {
29
+ d: "M19 3H5c-1.11 0-2 .9-2 2v14c0 1.1.89 2 2 2h14c1.11 0 2-.9 2-2V5c0-1.1-.89-2-2-2zm-9 14-5-5 1.41-1.41L10 14.17l7.59-7.59L19 8l-9 9z"
30
+ }));
31
+ var DxcCheckbox = /*#__PURE__*/_react["default"].forwardRef(function (_ref, ref) {
41
32
  var checked = _ref.checked,
42
- value = _ref.value,
43
- _ref$label = _ref.label,
44
- label = _ref$label === void 0 ? "" : _ref$label,
45
- _ref$labelPosition = _ref.labelPosition,
46
- labelPosition = _ref$labelPosition === void 0 ? "before" : _ref$labelPosition,
47
- _ref$name = _ref.name,
48
- name = _ref$name === void 0 ? "" : _ref$name,
49
- _ref$disabled = _ref.disabled,
50
- disabled = _ref$disabled === void 0 ? false : _ref$disabled,
51
- onChange = _ref.onChange,
52
- _ref$required = _ref.required,
53
- required = _ref$required === void 0 ? false : _ref$required,
54
- margin = _ref.margin,
55
- _ref$size = _ref.size,
56
- size = _ref$size === void 0 ? "fitContent" : _ref$size,
57
- _ref$tabIndex = _ref.tabIndex,
58
- tabIndex = _ref$tabIndex === void 0 ? 0 : _ref$tabIndex;
59
-
60
- var _useState = (0, _react.useState)(false),
61
- _useState2 = (0, _slicedToArray2["default"])(_useState, 2),
62
- innerChecked = _useState2[0],
63
- setInnerChecked = _useState2[1];
64
-
65
- var _useState3 = (0, _react.useState)(false),
66
- _useState4 = (0, _slicedToArray2["default"])(_useState3, 2),
67
- isLabelHovered = _useState4[0],
68
- setIsLabelHovered = _useState4[1];
69
-
33
+ _ref$defaultChecked = _ref.defaultChecked,
34
+ defaultChecked = _ref$defaultChecked === void 0 ? false : _ref$defaultChecked,
35
+ value = _ref.value,
36
+ _ref$label = _ref.label,
37
+ label = _ref$label === void 0 ? "" : _ref$label,
38
+ _ref$labelPosition = _ref.labelPosition,
39
+ labelPosition = _ref$labelPosition === void 0 ? "before" : _ref$labelPosition,
40
+ _ref$name = _ref.name,
41
+ name = _ref$name === void 0 ? "" : _ref$name,
42
+ _ref$disabled = _ref.disabled,
43
+ disabled = _ref$disabled === void 0 ? false : _ref$disabled,
44
+ _ref$optional = _ref.optional,
45
+ optional = _ref$optional === void 0 ? false : _ref$optional,
46
+ _ref$readOnly = _ref.readOnly,
47
+ readOnly = _ref$readOnly === void 0 ? false : _ref$readOnly,
48
+ onChange = _ref.onChange,
49
+ margin = _ref.margin,
50
+ _ref$size = _ref.size,
51
+ size = _ref$size === void 0 ? "fitContent" : _ref$size,
52
+ _ref$tabIndex = _ref.tabIndex,
53
+ tabIndex = _ref$tabIndex === void 0 ? 0 : _ref$tabIndex;
54
+ var _useState = (0, _react.useState)("label-checkbox-".concat((0, _uuid.v4)())),
55
+ _useState2 = (0, _slicedToArray2["default"])(_useState, 1),
56
+ labelId = _useState2[0];
57
+ var _useState3 = (0, _react.useState)(defaultChecked),
58
+ _useState4 = (0, _slicedToArray2["default"])(_useState3, 2),
59
+ innerChecked = _useState4[0],
60
+ setInnerChecked = _useState4[1];
61
+ var checkboxRef = (0, _react.useRef)(null);
70
62
  var colorsTheme = (0, _useTheme["default"])();
71
63
  var backgroundType = (0, _react.useContext)(_BackgroundColorContext["default"]);
72
-
73
- var handlerCheckboxChange = function handlerCheckboxChange(checkboxValue) {
74
- if (checked === undefined) {
75
- var isChecked = checkboxValue.target.checked === undefined ? !innerChecked : checkboxValue.target.checked;
76
- setInnerChecked(isChecked);
77
-
78
- if (typeof onChange === "function") {
79
- onChange(isChecked);
80
- }
81
- } else {
82
- if (typeof onChange === "function") {
83
- onChange(!checked);
84
- }
64
+ var translatedLabels = (0, _useTranslatedLabels["default"])();
65
+ var handleCheckboxChange = function handleCheckboxChange() {
66
+ if (!disabled && !readOnly) {
67
+ var _checkboxRef$current;
68
+ document.activeElement !== (checkboxRef === null || checkboxRef === void 0 ? void 0 : checkboxRef.current) && (checkboxRef === null || checkboxRef === void 0 ? void 0 : (_checkboxRef$current = checkboxRef.current) === null || _checkboxRef$current === void 0 ? void 0 : _checkboxRef$current.focus());
69
+ var newChecked = checked !== null && checked !== void 0 ? checked : innerChecked;
70
+ checked !== null && checked !== void 0 ? checked : setInnerChecked(function (innerChecked) {
71
+ return !innerChecked;
72
+ });
73
+ onChange === null || onChange === void 0 ? void 0 : onChange(!newChecked);
85
74
  }
86
75
  };
87
-
88
- var handleLabelHover = function handleLabelHover() {
89
- setIsLabelHovered(!isLabelHovered);
76
+ var handleKeyboard = function handleKeyboard(event) {
77
+ switch (event.key) {
78
+ case " ":
79
+ event.preventDefault();
80
+ handleCheckboxChange();
81
+ }
90
82
  };
91
-
92
83
  return /*#__PURE__*/_react["default"].createElement(_styledComponents.ThemeProvider, {
93
84
  theme: colorsTheme.checkbox
94
- }, /*#__PURE__*/_react["default"].createElement(CheckboxContainer, {
95
- id: name,
96
- brightness: _variables.componentTokens,
97
- label: label,
98
- labelPosition: labelPosition,
85
+ }, /*#__PURE__*/_react["default"].createElement(MainContainer, {
99
86
  disabled: disabled,
87
+ readOnly: readOnly,
88
+ onClick: handleCheckboxChange,
100
89
  margin: margin,
101
90
  size: size,
91
+ checked: checked !== null && checked !== void 0 ? checked : innerChecked,
102
92
  backgroundType: backgroundType,
103
- isLabelHovered: isLabelHovered
104
- }, /*#__PURE__*/_react["default"].createElement(_Checkbox["default"], {
105
- checked: checked != undefined ? checked : innerChecked,
106
- inputProps: {
107
- name: name,
108
- "aria-label": label,
109
- role: "checkbox",
110
- "aria-checked": checked != undefined ? checked : innerChecked
111
- },
112
- onChange: handlerCheckboxChange,
113
- value: value,
114
- disabled: disabled,
115
- disableRipple: true,
116
- className: "test",
117
- tabIndex: tabIndex
118
- }), /*#__PURE__*/_react["default"].createElement(CheckboxBlackBack, {
119
- labelPosition: labelPosition,
93
+ ref: ref
94
+ }, label && /*#__PURE__*/_react["default"].createElement(LabelContainer, {
95
+ id: labelId,
120
96
  disabled: disabled,
121
- checked: checked != undefined ? checked : innerChecked,
122
- 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,
97
+ backgroundType: backgroundType,
98
+ labelPosition: labelPosition
99
+ }, label, optional && " ".concat(translatedLabels.formFields.optionalLabel)), /*#__PURE__*/_react["default"].createElement(ValueInput, {
100
+ type: "checkbox",
101
+ checked: checked !== null && checked !== void 0 ? checked : innerChecked,
102
+ name: name,
103
+ "aria-hidden": "true",
104
+ value: value,
126
105
  disabled: disabled,
127
- className: "labelContainer",
106
+ readOnly: true
107
+ }), /*#__PURE__*/_react["default"].createElement(CheckboxContainer, null, /*#__PURE__*/_react["default"].createElement(Checkbox, {
108
+ onKeyDown: handleKeyboard,
109
+ role: "checkbox",
110
+ tabIndex: disabled ? -1 : tabIndex,
111
+ "aria-checked": checked !== null && checked !== void 0 ? checked : innerChecked,
112
+ "aria-disabled": disabled,
113
+ "aria-readonly": readOnly,
114
+ "aria-required": !disabled && !optional,
115
+ "aria-labelledby": labelId,
128
116
  backgroundType: backgroundType,
129
- onMouseOver: handleLabelHover,
130
- onMouseOut: handleLabelHover
131
- }, label)));
132
- };
133
-
117
+ checked: checked !== null && checked !== void 0 ? checked : innerChecked,
118
+ disabled: disabled,
119
+ readOnly: readOnly,
120
+ ref: checkboxRef
121
+ }, (checked !== null && checked !== void 0 ? checked : innerChecked) && checkedIcon))));
122
+ });
134
123
  var sizes = {
135
124
  small: "120px",
136
125
  medium: "240px",
137
126
  large: "480px",
138
127
  fillParent: "100%",
139
- fitContent: "unset"
128
+ fitContent: "fit-content"
140
129
  };
141
-
142
130
  var calculateWidth = function calculateWidth(margin, size) {
143
- if (size === "fillParent") {
144
- return "calc(".concat(sizes[size], " - ").concat((0, _utils.getMargin)(margin, "left"), " - ").concat((0, _utils.getMargin)(margin, "right"), ")");
145
- }
146
-
147
- return sizes[size];
131
+ return size === "fillParent" ? "calc(".concat(sizes[size], " - ").concat((0, _utils.getMargin)(margin, "left"), " - ").concat((0, _utils.getMargin)(margin, "right"), ")") : sizes[size];
148
132
  };
149
-
150
133
  var getDisabledColor = function getDisabledColor(props, element) {
151
134
  switch (element) {
152
135
  case "check":
153
- return props.backgroundType && props.backgroundType === "dark" ? props.theme.disabledCheckColorOnDark : props.theme.disabledCheckColor;
154
- break;
155
-
136
+ return props.backgroundType === "dark" ? props.theme.disabledCheckColorOnDark : props.theme.disabledCheckColor;
156
137
  case "background":
157
- return props.backgroundType && props.backgroundType === "dark" ? props.theme.disabledBackgroundColorCheckedOnDark : props.theme.disabledBackgroundColorChecked;
158
- break;
159
-
138
+ return props.backgroundType === "dark" ? props.theme.disabledBackgroundColorCheckedOnDark : props.theme.disabledBackgroundColorChecked;
160
139
  case "border":
161
- return props.backgroundType && props.backgroundType === "dark" ? props.theme.disabledBorderColorOnDark : props.theme.disabledBorderColor;
162
- break;
163
-
140
+ return props.backgroundType === "dark" ? props.theme.disabledBorderColorOnDark : props.theme.disabledBorderColor;
164
141
  case "label":
165
- return props.backgroundType && props.backgroundType === "dark" ? props.theme.disabledFontColorOnDark : props.theme.disabledFontColor;
166
- break;
142
+ return props.backgroundType === "dark" ? props.theme.disabledFontColorOnDark : props.theme.disabledFontColor;
167
143
  }
168
144
  };
169
-
170
- var getNotDisabledColor = function getNotDisabledColor(props, element) {
145
+ var getReadOnlyColor = function getReadOnlyColor(props, element) {
171
146
  switch (element) {
172
147
  case "check":
173
- return props.backgroundType && props.backgroundType === "dark" ? props.theme.checkColorOnDark : props.theme.checkColor;
174
- break;
175
-
148
+ return props.theme.readOnlyCheckColor;
176
149
  case "background":
177
- return props.backgroundType && props.backgroundType === "dark" ? props.theme.backgroundColorCheckedOnDark : props.theme.backgroundColorChecked;
178
- break;
179
-
150
+ return props.theme.readOnlyBackgroundColorChecked;
151
+ case "hoverBackground":
152
+ return props.theme.hoverReadOnlyBackgroundColorChecked;
180
153
  case "border":
181
- return props.backgroundType && props.backgroundType === "dark" ? props.theme.borderColorOnDark : props.theme.borderColor;
182
- break;
183
-
154
+ return props.theme.readOnlyBorderColor;
155
+ case "hoverBorder":
156
+ return props.theme.hoverReadOnlyBorderColor;
157
+ }
158
+ };
159
+ var getEnabledColor = function getEnabledColor(props, element) {
160
+ switch (element) {
161
+ case "check":
162
+ return props.backgroundType === "dark" ? props.theme.checkColorOnDark : props.theme.checkColor;
163
+ case "background":
164
+ return props.backgroundType === "dark" ? props.theme.backgroundColorCheckedOnDark : props.theme.backgroundColorChecked;
165
+ case "hoverBackground":
166
+ return props.backgroundType === "dark" ? props.theme.hoverBackgroundColorCheckedOnDark : props.theme.hoverBackgroundColorChecked;
167
+ case "border":
168
+ return props.backgroundType === "dark" ? props.theme.borderColorOnDark : props.theme.borderColor;
169
+ case "hoverBorder":
170
+ return props.backgroundType === "dark" ? props.theme.hoverBorderColorOnDark : props.theme.hoverBorderColor;
184
171
  case "label":
185
- return props.backgroundType && props.backgroundType === "dark" ? props.theme.fontColorOnDark : props.theme.fontColor;
186
- break;
172
+ return props.backgroundType === "dark" ? props.theme.fontColorOnDark : props.theme.fontColor;
187
173
  }
188
174
  };
189
-
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) {
191
- return props.disabled ? getDisabledColor(props, "label") : getNotDisabledColor(props, "label");
175
+ var LabelContainer = _styledComponents["default"].span(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n order: ", ";\n color: ", ";\n font-family: ", ";\n font-size: ", ";\n font-weight: ", ";\n"])), function (props) {
176
+ return props.labelPosition === "before" ? 0 : 1;
192
177
  }, function (props) {
193
- return props.disabled ? "not-allowed" : "pointer";
178
+ return props.disabled ? getDisabledColor(props, "label") : getEnabledColor(props, "label");
194
179
  }, function (props) {
195
180
  return props.theme.fontFamily;
196
181
  }, function (props) {
@@ -198,56 +183,38 @@ var LabelContainer = _styledComponents["default"].span(_templateObject || (_temp
198
183
  }, function (props) {
199
184
  return props.theme.fontWeight;
200
185
  });
201
-
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) {
203
- return props.margin && (0, _typeof2["default"])(props.margin) !== "object" ? _variables.spaces[props.margin] : "0px";
186
+ var ValueInput = _styledComponents["default"].input(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n display: none;\n"])));
187
+ var CheckboxContainer = _styledComponents["default"].span(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n align-items: center;\n justify-content: center;\n height: 24px;\n width: 24px;\n"])));
188
+ var Checkbox = _styledComponents["default"].span(_templateObject4 || (_templateObject4 = (0, _taggedTemplateLiteral2["default"])(["\n position: relative;\n box-sizing: border-box;\n display: flex;\n align-items: center;\n justify-content: center;\n height: 18px;\n width: 18px;\n border: 2px solid\n ", ";\n border-radius: 2px;\n background-color: ", ";\n color: ", ";\n\n &:focus {\n outline: 2px solid\n ", ";\n outline-offset: 2px;\n }\n svg {\n position: absolute;\n width: 22px;\n height: 22px;\n }\n ", "\n"])), function (props) {
189
+ return props.disabled ? getDisabledColor(props, "border") : props.readOnly ? getReadOnlyColor(props, "border") : getEnabledColor(props, "border");
204
190
  }, function (props) {
205
- return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.top ? _variables.spaces[props.margin.top] : "";
191
+ return props.checked ? props.disabled ? getDisabledColor(props, "check") : props.readOnly ? getReadOnlyColor(props, "check") : getEnabledColor(props, "check") : "transparent";
206
192
  }, function (props) {
207
- return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.right ? _variables.spaces[props.margin.right] : "";
193
+ return props.disabled ? getDisabledColor(props, "background") : props.readOnly ? getReadOnlyColor(props, "background") : getEnabledColor(props, "background");
208
194
  }, function (props) {
209
- return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.bottom ? _variables.spaces[props.margin.bottom] : "";
195
+ return props.backgroundType === "dark" ? props.theme.focusColorOnDark : props.theme.focusColor;
210
196
  }, function (props) {
211
- return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.left ? _variables.spaces[props.margin.left] : "";
197
+ return props.disabled && "pointer-events: none;";
198
+ });
199
+ var MainContainer = _styledComponents["default"].div(_templateObject5 || (_templateObject5 = (0, _taggedTemplateLiteral2["default"])(["\n display: inline-flex;\n align-items: center;\n gap: ", ";\n width: ", ";\n margin: ", ";\n margin-top: ", ";\n margin-right: ", ";\n margin-bottom: ", ";\n margin-left: ", ";\n cursor: ", ";\n\n &:hover ", " {\n border: 2px solid\n ", ";\n color: ", ";\n }\n"])), function (props) {
200
+ return props.theme.checkLabelSpacing;
212
201
  }, function (props) {
213
202
  return calculateWidth(props.margin, props.size);
214
203
  }, function (props) {
215
- return props.disabled ? "not-allowed" : "pointer";
216
- }, function (props) {
217
- return props.labelPosition === "before" ? "row-reverse" : "row";
218
- }, function (props) {
219
- return props.isLabelHovered ? props.backgroundType === "dark" ? props.theme.hoverBorderColorOnDark : props.theme.hoverBorderColor : getNotDisabledColor(props, "border");
220
- }, function (props) {
221
- return getDisabledColor(props, "border");
222
- }, function (props) {
223
- return props.disabled ? getDisabledColor(props, "background") : getNotDisabledColor(props, "background");
224
- }, function (props) {
225
- return props.backgroundType === "dark" ? props.theme.hoverBackgroundColorCheckedOnDark : props.theme.hoverBackgroundColorChecked;
226
- }, function (props) {
227
- return props.backgroundType === "dark" ? props.theme.hoverBorderColorOnDark : props.theme.hoverBorderColor;
228
- }, function (props) {
229
- return props.backgroundType === "dark" ? props.theme.focusColorOnDark : props.theme.focusColor;
230
- }, function (props) {
231
- return props.labelPosition === "before" && props.label ? props.theme.checkLabelSpacing : "0";
232
- }, function (props) {
233
- return props.labelPosition === "after" && props.label ? props.theme.checkLabelSpacing : "0";
204
+ return props.margin && (0, _typeof2["default"])(props.margin) !== "object" ? _variables.spaces[props.margin] : "0px";
234
205
  }, function (props) {
235
- return props.labelPosition === "before" ? "unset" : "1px";
206
+ return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.top ? _variables.spaces[props.margin.top] : "";
236
207
  }, function (props) {
237
- return props.labelPosition === "before" ? "1px" : "unset";
238
- });
239
-
240
- var CheckboxBlackBack = _styledComponents["default"].span(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n background-color: ", ";\n width: 16px;\n height: 16px;\n position: absolute;\n left: ", ";\n right: ", ";\n z-index: 0;\n margin-left: ", ";\n margin-right: ", ";\n"])), function (props) {
241
- return !props.checked ? "transparent" : props.disabled ? getDisabledColor(props, "check") : getNotDisabledColor(props, "check");
208
+ return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.right ? _variables.spaces[props.margin.right] : "";
242
209
  }, function (props) {
243
- return props.labelPosition === "before" ? "unset" : "5px";
210
+ return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.bottom ? _variables.spaces[props.margin.bottom] : "";
244
211
  }, function (props) {
245
- return props.labelPosition === "before" ? "5px" : "unset";
212
+ return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.left ? _variables.spaces[props.margin.left] : "";
246
213
  }, function (props) {
247
- return props.labelPosition === "after" ? "0px" : "";
214
+ return props.disabled ? "not-allowed" : props.readOnly ? "default" : "pointer";
215
+ }, Checkbox, function (props) {
216
+ if (!props.disabled) return props.readOnly ? getReadOnlyColor(props, "hoverBorder") : getEnabledColor(props, "hoverBorder");
248
217
  }, function (props) {
249
- return props.labelPosition === "before" ? "0px" : "";
218
+ if (!props.disabled) return props.readOnly ? getReadOnlyColor(props, "hoverBackground") : getEnabledColor(props, "hoverBackground");
250
219
  });
251
-
252
- var _default = DxcCheckbox;
253
- exports["default"] = _default;
220
+ var _default = exports["default"] = DxcCheckbox;