@dxc-technology/halstack-react 0.0.0-f0d662d → 0.0.0-f18281d

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 (361) hide show
  1. package/BackgroundColorContext.d.ts +1 -10
  2. package/BackgroundColorContext.js +5 -22
  3. package/HalstackContext.d.ts +1237 -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 +117 -193
  8. package/accordion/Accordion.stories.tsx +103 -127
  9. package/accordion/Accordion.test.js +56 -0
  10. package/accordion/types.d.ts +11 -22
  11. package/accordion-group/AccordionGroup.d.ts +5 -4
  12. package/accordion-group/AccordionGroup.js +38 -107
  13. package/accordion-group/AccordionGroup.stories.tsx +95 -68
  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 +17 -22
  18. package/action-icon/ActionIcon.d.ts +4 -0
  19. package/action-icon/ActionIcon.js +47 -0
  20. package/action-icon/ActionIcon.stories.tsx +41 -0
  21. package/action-icon/ActionIcon.test.js +64 -0
  22. package/action-icon/types.d.ts +26 -0
  23. package/alert/Alert.js +23 -59
  24. package/alert/Alert.stories.tsx +28 -0
  25. package/alert/Alert.test.js +75 -0
  26. package/alert/types.d.ts +5 -5
  27. package/badge/Badge.d.ts +4 -0
  28. package/badge/Badge.js +142 -40
  29. package/badge/Badge.stories.tsx +210 -0
  30. package/badge/Badge.test.js +30 -0
  31. package/badge/types.d.ts +54 -0
  32. package/bleed/Bleed.js +14 -55
  33. package/bleed/Bleed.stories.tsx +95 -95
  34. package/bleed/types.d.ts +26 -2
  35. package/box/Box.d.ts +1 -1
  36. package/box/Box.js +30 -81
  37. package/box/Box.stories.tsx +38 -51
  38. package/box/Box.test.js +13 -0
  39. package/box/types.d.ts +3 -14
  40. package/bulleted-list/BulletedList.d.ts +7 -0
  41. package/bulleted-list/BulletedList.js +89 -0
  42. package/bulleted-list/BulletedList.stories.tsx +115 -0
  43. package/bulleted-list/types.d.ts +38 -0
  44. package/button/Button.d.ts +1 -1
  45. package/button/Button.js +62 -113
  46. package/button/Button.stories.tsx +160 -90
  47. package/button/Button.test.js +38 -0
  48. package/button/types.d.ts +12 -8
  49. package/card/Card.d.ts +1 -1
  50. package/card/Card.js +58 -102
  51. package/card/Card.stories.tsx +12 -42
  52. package/card/Card.test.js +39 -0
  53. package/card/types.d.ts +6 -11
  54. package/checkbox/Checkbox.d.ts +2 -2
  55. package/checkbox/Checkbox.js +144 -182
  56. package/checkbox/Checkbox.stories.tsx +166 -136
  57. package/checkbox/Checkbox.test.js +199 -0
  58. package/checkbox/types.d.ts +18 -6
  59. package/chip/Chip.d.ts +1 -1
  60. package/chip/Chip.js +46 -124
  61. package/chip/Chip.stories.tsx +123 -30
  62. package/chip/Chip.test.js +41 -0
  63. package/chip/types.d.ts +8 -16
  64. package/common/OpenSans.css +68 -80
  65. package/common/coreTokens.d.ts +237 -0
  66. package/common/coreTokens.js +184 -0
  67. package/common/utils.d.ts +1 -0
  68. package/common/utils.js +6 -12
  69. package/common/variables.d.ts +1383 -0
  70. package/common/variables.js +1017 -1374
  71. package/container/Container.d.ts +4 -0
  72. package/container/Container.js +194 -0
  73. package/container/Container.stories.tsx +214 -0
  74. package/container/types.d.ts +74 -0
  75. package/date-input/Calendar.d.ts +4 -0
  76. package/date-input/Calendar.js +214 -0
  77. package/date-input/DateInput.js +171 -306
  78. package/date-input/DateInput.stories.tsx +203 -56
  79. package/date-input/DateInput.test.js +808 -0
  80. package/date-input/DatePicker.d.ts +4 -0
  81. package/date-input/DatePicker.js +115 -0
  82. package/date-input/Icons.d.ts +6 -0
  83. package/date-input/Icons.js +58 -0
  84. package/date-input/YearPicker.d.ts +4 -0
  85. package/date-input/YearPicker.js +100 -0
  86. package/date-input/types.d.ts +86 -22
  87. package/dialog/Dialog.d.ts +1 -1
  88. package/dialog/Dialog.js +68 -130
  89. package/dialog/Dialog.stories.tsx +320 -167
  90. package/dialog/Dialog.test.js +307 -0
  91. package/dialog/types.d.ts +18 -25
  92. package/dropdown/Dropdown.d.ts +1 -1
  93. package/dropdown/Dropdown.js +249 -330
  94. package/dropdown/Dropdown.stories.tsx +255 -64
  95. package/dropdown/Dropdown.test.js +599 -0
  96. package/dropdown/DropdownMenu.d.ts +4 -0
  97. package/dropdown/DropdownMenu.js +63 -0
  98. package/dropdown/DropdownMenuItem.d.ts +4 -0
  99. package/dropdown/DropdownMenuItem.js +67 -0
  100. package/dropdown/types.d.ts +36 -27
  101. package/file-input/FileInput.d.ts +2 -2
  102. package/file-input/FileInput.js +246 -357
  103. package/file-input/FileInput.stories.tsx +123 -12
  104. package/file-input/FileInput.test.js +459 -0
  105. package/file-input/FileItem.d.ts +4 -14
  106. package/file-input/FileItem.js +50 -99
  107. package/file-input/types.d.ts +25 -8
  108. package/flex/Flex.d.ts +4 -0
  109. package/flex/Flex.js +57 -0
  110. package/flex/Flex.stories.tsx +112 -0
  111. package/flex/types.d.ts +97 -0
  112. package/footer/Footer.d.ts +1 -1
  113. package/footer/Footer.js +70 -190
  114. package/footer/Footer.stories.tsx +60 -19
  115. package/footer/Footer.test.js +85 -0
  116. package/footer/Icons.d.ts +3 -2
  117. package/footer/Icons.js +67 -8
  118. package/footer/types.d.ts +25 -26
  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/header/Header.d.ts +4 -3
  124. package/header/Header.js +99 -203
  125. package/header/Header.stories.tsx +152 -63
  126. package/header/Header.test.js +66 -0
  127. package/header/Icons.d.ts +2 -2
  128. package/header/Icons.js +4 -9
  129. package/header/types.d.ts +5 -19
  130. package/heading/Heading.js +10 -32
  131. package/heading/Heading.test.js +169 -0
  132. package/heading/types.d.ts +7 -7
  133. package/image/Image.d.ts +4 -0
  134. package/image/Image.js +70 -0
  135. package/image/Image.stories.tsx +127 -0
  136. package/image/types.d.ts +72 -0
  137. package/image/types.js +5 -0
  138. package/inset/Inset.js +14 -55
  139. package/inset/Inset.stories.tsx +37 -36
  140. package/inset/types.d.ts +26 -2
  141. package/layout/ApplicationLayout.d.ts +16 -6
  142. package/layout/ApplicationLayout.js +83 -174
  143. package/layout/ApplicationLayout.stories.tsx +85 -94
  144. package/layout/Icons.d.ts +8 -0
  145. package/layout/Icons.js +51 -48
  146. package/layout/SidenavContext.d.ts +5 -0
  147. package/layout/SidenavContext.js +13 -0
  148. package/layout/types.d.ts +19 -35
  149. package/link/Link.d.ts +3 -2
  150. package/link/Link.js +64 -110
  151. package/link/Link.stories.tsx +159 -52
  152. package/link/Link.test.js +63 -0
  153. package/link/types.d.ts +15 -35
  154. package/main.d.ts +17 -18
  155. package/main.js +68 -120
  156. package/nav-tabs/NavTabs.d.ts +8 -0
  157. package/nav-tabs/NavTabs.js +93 -0
  158. package/nav-tabs/NavTabs.stories.tsx +276 -0
  159. package/nav-tabs/NavTabs.test.js +76 -0
  160. package/nav-tabs/Tab.d.ts +4 -0
  161. package/nav-tabs/Tab.js +118 -0
  162. package/nav-tabs/types.d.ts +52 -0
  163. package/nav-tabs/types.js +5 -0
  164. package/number-input/NumberInput.d.ts +7 -0
  165. package/number-input/NumberInput.js +27 -43
  166. package/number-input/NumberInput.stories.tsx +44 -28
  167. package/number-input/NumberInput.test.js +830 -0
  168. package/number-input/types.d.ts +28 -15
  169. package/package.json +46 -47
  170. package/paginator/Icons.d.ts +5 -0
  171. package/paginator/Icons.js +21 -47
  172. package/paginator/Paginator.js +34 -91
  173. package/paginator/Paginator.stories.tsx +24 -0
  174. package/paginator/Paginator.test.js +335 -0
  175. package/paginator/types.d.ts +3 -3
  176. package/paragraph/Paragraph.d.ts +5 -0
  177. package/paragraph/Paragraph.js +22 -0
  178. package/paragraph/Paragraph.stories.tsx +27 -0
  179. package/password-input/Icons.d.ts +6 -0
  180. package/password-input/Icons.js +35 -0
  181. package/password-input/PasswordInput.js +57 -123
  182. package/password-input/PasswordInput.stories.tsx +1 -33
  183. package/password-input/PasswordInput.test.js +198 -0
  184. package/password-input/types.d.ts +21 -17
  185. package/progress-bar/ProgressBar.js +65 -91
  186. package/progress-bar/ProgressBar.stories.tsx +93 -0
  187. package/progress-bar/ProgressBar.test.js +93 -0
  188. package/progress-bar/types.d.ts +3 -3
  189. package/quick-nav/QuickNav.d.ts +4 -0
  190. package/quick-nav/QuickNav.js +94 -0
  191. package/quick-nav/QuickNav.stories.tsx +356 -0
  192. package/quick-nav/types.d.ts +21 -0
  193. package/quick-nav/types.js +5 -0
  194. package/radio-group/Radio.d.ts +1 -1
  195. package/radio-group/Radio.js +64 -80
  196. package/radio-group/RadioGroup.js +101 -139
  197. package/radio-group/RadioGroup.stories.tsx +171 -36
  198. package/radio-group/RadioGroup.test.js +691 -183
  199. package/radio-group/types.d.ts +89 -11
  200. package/resultset-table/Icons.d.ts +7 -0
  201. package/resultset-table/Icons.js +47 -0
  202. package/resultset-table/ResultsetTable.d.ts +7 -0
  203. package/resultset-table/ResultsetTable.js +167 -0
  204. package/{resultsetTable → resultset-table}/ResultsetTable.stories.tsx +136 -30
  205. package/resultset-table/ResultsetTable.test.js +371 -0
  206. package/{resultsetTable → resultset-table}/types.d.ts +13 -7
  207. package/resultset-table/types.js +5 -0
  208. package/select/Icons.d.ts +10 -0
  209. package/select/Icons.js +89 -0
  210. package/select/Listbox.d.ts +4 -0
  211. package/select/Listbox.js +143 -0
  212. package/select/Option.d.ts +4 -0
  213. package/select/Option.js +87 -0
  214. package/select/Select.js +229 -502
  215. package/select/Select.stories.tsx +603 -204
  216. package/select/Select.test.js +2370 -0
  217. package/select/types.d.ts +64 -25
  218. package/sidenav/Icons.d.ts +7 -0
  219. package/sidenav/Icons.js +47 -0
  220. package/sidenav/Sidenav.d.ts +6 -5
  221. package/sidenav/Sidenav.js +131 -71
  222. package/sidenav/Sidenav.stories.tsx +251 -151
  223. package/sidenav/Sidenav.test.js +37 -0
  224. package/sidenav/types.d.ts +52 -26
  225. package/slider/Slider.d.ts +2 -2
  226. package/slider/Slider.js +148 -180
  227. package/slider/Slider.test.js +254 -0
  228. package/slider/types.d.ts +11 -3
  229. package/spinner/Spinner.js +31 -75
  230. package/spinner/{Spinner.stories.jsx → Spinner.stories.tsx} +53 -27
  231. package/spinner/Spinner.test.js +55 -0
  232. package/spinner/types.d.ts +3 -3
  233. package/status-light/StatusLight.d.ts +4 -0
  234. package/status-light/StatusLight.js +51 -0
  235. package/status-light/StatusLight.stories.tsx +74 -0
  236. package/status-light/StatusLight.test.js +25 -0
  237. package/status-light/types.d.ts +17 -0
  238. package/status-light/types.js +5 -0
  239. package/switch/Switch.d.ts +2 -2
  240. package/switch/Switch.js +149 -114
  241. package/switch/Switch.stories.tsx +44 -67
  242. package/switch/Switch.test.js +180 -0
  243. package/switch/types.d.ts +13 -5
  244. package/table/ActionsCell.d.ts +4 -0
  245. package/table/ActionsCell.js +54 -0
  246. package/table/DropdownTheme.js +57 -0
  247. package/table/Table.d.ts +4 -1
  248. package/table/Table.js +27 -32
  249. package/table/Table.stories.tsx +615 -0
  250. package/table/Table.test.js +113 -0
  251. package/table/types.d.ts +45 -6
  252. package/tabs/Tab.d.ts +4 -0
  253. package/tabs/Tab.js +116 -0
  254. package/tabs/Tabs.d.ts +1 -1
  255. package/tabs/Tabs.js +316 -145
  256. package/tabs/Tabs.stories.tsx +120 -14
  257. package/tabs/Tabs.test.js +294 -0
  258. package/tabs/types.d.ts +29 -15
  259. package/tag/Tag.d.ts +1 -1
  260. package/tag/Tag.js +43 -85
  261. package/tag/Tag.stories.tsx +37 -27
  262. package/tag/Tag.test.js +49 -0
  263. package/tag/types.d.ts +25 -16
  264. package/text-input/Icons.d.ts +8 -0
  265. package/text-input/Icons.js +56 -0
  266. package/text-input/Suggestion.d.ts +4 -0
  267. package/text-input/Suggestion.js +67 -0
  268. package/text-input/Suggestions.d.ts +4 -0
  269. package/text-input/Suggestions.js +84 -0
  270. package/text-input/TextInput.js +326 -548
  271. package/text-input/TextInput.stories.tsx +281 -272
  272. package/text-input/TextInput.test.js +1739 -0
  273. package/text-input/types.d.ts +70 -24
  274. package/textarea/Textarea.js +85 -135
  275. package/textarea/Textarea.stories.tsx +174 -0
  276. package/textarea/Textarea.test.js +406 -0
  277. package/textarea/types.d.ts +27 -16
  278. package/toggle-group/ToggleGroup.d.ts +2 -2
  279. package/toggle-group/ToggleGroup.js +92 -105
  280. package/toggle-group/ToggleGroup.stories.tsx +53 -8
  281. package/toggle-group/ToggleGroup.test.js +137 -0
  282. package/toggle-group/types.d.ts +34 -17
  283. package/typography/Typography.d.ts +4 -0
  284. package/typography/Typography.js +23 -0
  285. package/typography/Typography.stories.tsx +198 -0
  286. package/typography/types.d.ts +18 -0
  287. package/typography/types.js +5 -0
  288. package/useTheme.d.ts +1135 -1
  289. package/useTheme.js +4 -11
  290. package/useTranslatedLabels.d.ts +85 -0
  291. package/useTranslatedLabels.js +14 -0
  292. package/utils/BaseTypography.d.ts +21 -0
  293. package/utils/BaseTypography.js +94 -0
  294. package/utils/FocusLock.d.ts +13 -0
  295. package/utils/FocusLock.js +124 -0
  296. package/wizard/Wizard.d.ts +1 -1
  297. package/wizard/Wizard.js +70 -101
  298. package/wizard/Wizard.stories.tsx +48 -19
  299. package/wizard/Wizard.test.js +114 -0
  300. package/wizard/types.d.ts +12 -8
  301. package/ThemeContext.d.ts +0 -15
  302. package/ThemeContext.js +0 -243
  303. package/V3Select/V3Select.js +0 -455
  304. package/V3Select/index.d.ts +0 -27
  305. package/V3Textarea/V3Textarea.js +0 -260
  306. package/V3Textarea/index.d.ts +0 -27
  307. package/card/ice-cream.jpg +0 -0
  308. package/common/RequiredComponent.js +0 -32
  309. package/date/Date.js +0 -373
  310. package/date/index.d.ts +0 -27
  311. package/input-text/Icons.js +0 -22
  312. package/input-text/InputText.js +0 -611
  313. package/input-text/index.d.ts +0 -36
  314. package/list/List.d.ts +0 -4
  315. package/list/List.js +0 -47
  316. package/list/List.stories.tsx +0 -95
  317. package/list/types.d.ts +0 -7
  318. package/number-input/NumberInputContext.d.ts +0 -4
  319. package/number-input/NumberInputContext.js +0 -19
  320. package/number-input/numberInputContextTypes.d.ts +0 -19
  321. package/progress-bar/ProgressBar.stories.jsx +0 -58
  322. package/radio/Radio.d.ts +0 -4
  323. package/radio/Radio.js +0 -174
  324. package/radio/Radio.stories.tsx +0 -192
  325. package/radio/types.d.ts +0 -54
  326. package/resultsetTable/ResultsetTable.d.ts +0 -4
  327. package/resultsetTable/ResultsetTable.js +0 -251
  328. package/row/Row.d.ts +0 -3
  329. package/row/Row.js +0 -127
  330. package/row/Row.stories.tsx +0 -237
  331. package/row/types.d.ts +0 -10
  332. package/slider/Slider.stories.tsx +0 -177
  333. package/stack/Stack.d.ts +0 -3
  334. package/stack/Stack.js +0 -97
  335. package/stack/Stack.stories.tsx +0 -164
  336. package/stack/types.d.ts +0 -9
  337. package/table/Table.stories.jsx +0 -277
  338. package/text/Text.d.ts +0 -7
  339. package/text/Text.js +0 -30
  340. package/text/Text.stories.tsx +0 -19
  341. package/textarea/Textarea.stories.jsx +0 -136
  342. package/toggle/Toggle.js +0 -186
  343. package/toggle/index.d.ts +0 -21
  344. package/upload/Upload.js +0 -201
  345. package/upload/buttons-upload/ButtonsUpload.js +0 -111
  346. package/upload/buttons-upload/Icons.js +0 -40
  347. package/upload/dragAndDropArea/DragAndDropArea.js +0 -225
  348. package/upload/dragAndDropArea/Icons.js +0 -39
  349. package/upload/file-upload/FileToUpload.js +0 -115
  350. package/upload/file-upload/Icons.js +0 -66
  351. package/upload/files-upload/FilesToUpload.js +0 -109
  352. package/upload/index.d.ts +0 -15
  353. package/upload/transaction/Icons.js +0 -160
  354. package/upload/transaction/Transaction.js +0 -104
  355. package/upload/transactions/Transactions.js +0 -94
  356. /package/{list → action-icon}/types.js +0 -0
  357. /package/{radio → badge}/types.js +0 -0
  358. /package/{resultsetTable → bulleted-list}/types.js +0 -0
  359. /package/{row → container}/types.js +0 -0
  360. /package/{stack → flex}/types.js +0 -0
  361. /package/{number-input/numberInputContextTypes.js → grid/types.js} +0 -0
package/useTheme.js CHANGED
@@ -1,22 +1,15 @@
1
1
  "use strict";
2
2
 
3
3
  var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
-
5
4
  Object.defineProperty(exports, "__esModule", {
6
5
  value: true
7
6
  });
8
7
  exports["default"] = void 0;
9
-
10
8
  var _react = require("react");
11
-
12
- var _variables = require("./common/variables.js");
13
-
14
- var _ThemeContext = _interopRequireDefault(require("./ThemeContext"));
15
-
9
+ var _variables = require("./common/variables");
10
+ var _HalstackContext = _interopRequireDefault(require("./HalstackContext"));
16
11
  var useTheme = function useTheme() {
17
- var colorsTheme = (0, _react.useContext)(_ThemeContext["default"]);
12
+ var colorsTheme = (0, _react.useContext)(_HalstackContext["default"]);
18
13
  return colorsTheme || _variables.componentTokens;
19
14
  };
20
-
21
- var _default = useTheme;
22
- exports["default"] = _default;
15
+ var _default = exports["default"] = useTheme;
@@ -0,0 +1,85 @@
1
+ declare const useTranslatedLabels: () => {
2
+ formFields?: Partial<{
3
+ optionalLabel: string;
4
+ requiredSelectionErrorMessage: string;
5
+ requiredValueErrorMessage: string;
6
+ formatRequestedErrorMessage: string;
7
+ lengthErrorMessage: (minLength?: number, maxLength?: number) => string;
8
+ logoAlternativeText: string;
9
+ }>;
10
+ applicationLayout?: Partial<{
11
+ visibilityToggleTitle: string;
12
+ }>;
13
+ alert?: Partial<{
14
+ infoTitleText: string;
15
+ successTitleText: string;
16
+ warningTitleText: string;
17
+ errorTitleText: string;
18
+ }>;
19
+ dateInput?: Partial<{
20
+ invalidDateErrorMessage: string;
21
+ }>;
22
+ dialog?: Partial<{
23
+ closeIconAriaLabel: string;
24
+ }>;
25
+ fileInput?: Partial<{
26
+ fileSizeGreaterThanErrorMessage: string;
27
+ fileSizeLessThanErrorMessage: string;
28
+ multipleButtonLabelDefault: string;
29
+ singleButtonLabelDefault: string;
30
+ dropAreaButtonLabelDefault: string;
31
+ multipleDropAreaLabelDefault: string;
32
+ singleDropAreaLabelDefault: string;
33
+ deleteFileActionTitle: string;
34
+ }>;
35
+ footer?: Partial<{
36
+ copyrightText: (year: number) => string;
37
+ }>;
38
+ header?: Partial<{
39
+ closeIcon: string;
40
+ hamburguerTitle: string;
41
+ }>;
42
+ numberInput?: Partial<{
43
+ valueGreaterThanOrEqualToErrorMessage: (value: number) => string;
44
+ valueLessThanOrEqualToErrorMessage: (value: number) => string;
45
+ decrementValueTitle: string;
46
+ incrementValueTitle: string;
47
+ }>;
48
+ paginator?: Partial<{
49
+ itemsPerPageText: string;
50
+ minToMaxOfText: (minNumberOfItems: number, maxNumberOfItems: number, totalItems: number) => string;
51
+ goToPageText: string;
52
+ pageOfText: (pageNumber: number, totalPagesNumber: number) => string;
53
+ }>;
54
+ passwordInput?: Partial<{
55
+ inputShowPasswordTitle: string;
56
+ inputHidePasswordTitle: string;
57
+ }>;
58
+ quickNav?: Partial<{
59
+ contentTitle: string;
60
+ }>;
61
+ radioGroup?: Partial<{
62
+ optionalItemLabelDefault: string;
63
+ }>;
64
+ select?: Partial<{
65
+ noMatchesErrorMessage: string;
66
+ actionClearSelectionTitle: string;
67
+ actionClearSearchTitle: string;
68
+ }>;
69
+ tabs?: Partial<{
70
+ scrollLeft: string;
71
+ scrollRight: string;
72
+ }>;
73
+ textInput?: Partial<{
74
+ clearFieldActionTitle: string;
75
+ searchingMessage: string;
76
+ fetchingDataErrorMessage: string;
77
+ }>;
78
+ calendar?: Partial<{
79
+ daysShort: string[];
80
+ months: string[];
81
+ previousMonthTitle: string;
82
+ nextMonthTitle: string;
83
+ }>;
84
+ };
85
+ export default useTranslatedLabels;
@@ -0,0 +1,14 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports["default"] = void 0;
7
+ var _react = require("react");
8
+ var _variables = require("./common/variables");
9
+ var _HalstackContext = require("./HalstackContext");
10
+ var useTranslatedLabels = function useTranslatedLabels() {
11
+ var labels = (0, _react.useContext)(_HalstackContext.HalstackLanguageContext);
12
+ return labels || _variables.defaultTranslatedComponentLabels;
13
+ };
14
+ var _default = exports["default"] = useTranslatedLabels;
@@ -0,0 +1,21 @@
1
+ import React from "react";
2
+ type TypographyContextProps = {
3
+ as?: keyof HTMLElementTagNameMap;
4
+ display?: string;
5
+ fontFamily?: string;
6
+ fontSize?: string;
7
+ fontStyle?: string;
8
+ fontWeight?: string;
9
+ letterSpacing?: string;
10
+ lineHeight?: string;
11
+ textAlign?: string;
12
+ color?: string;
13
+ textDecoration?: string;
14
+ textOverflow?: string;
15
+ whiteSpace?: string;
16
+ };
17
+ type BaseTypographyProps = TypographyContextProps & {
18
+ children: React.ReactNode;
19
+ };
20
+ declare const BaseTypography: ({ as, display, fontFamily, fontSize, fontStyle, fontWeight, letterSpacing, lineHeight, textAlign, color, textDecoration, textOverflow, whiteSpace, children, }: BaseTypographyProps) => JSX.Element;
21
+ export default BaseTypography;
@@ -0,0 +1,94 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+ var _typeof = require("@babel/runtime/helpers/typeof");
5
+ Object.defineProperty(exports, "__esModule", {
6
+ value: true
7
+ });
8
+ exports["default"] = void 0;
9
+ var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
10
+ var _react = _interopRequireWildcard(require("react"));
11
+ var _styledComponents = _interopRequireDefault(require("styled-components"));
12
+ var _templateObject;
13
+ 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); }
14
+ function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != _typeof(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; }
15
+ var TypographyContext = /*#__PURE__*/_react["default"].createContext(null);
16
+ var BaseTypography = function BaseTypography(_ref) {
17
+ var as = _ref.as,
18
+ display = _ref.display,
19
+ fontFamily = _ref.fontFamily,
20
+ fontSize = _ref.fontSize,
21
+ fontStyle = _ref.fontStyle,
22
+ fontWeight = _ref.fontWeight,
23
+ letterSpacing = _ref.letterSpacing,
24
+ lineHeight = _ref.lineHeight,
25
+ textAlign = _ref.textAlign,
26
+ color = _ref.color,
27
+ textDecoration = _ref.textDecoration,
28
+ textOverflow = _ref.textOverflow,
29
+ whiteSpace = _ref.whiteSpace,
30
+ children = _ref.children;
31
+ var componentContext = (0, _react.useContext)(TypographyContext);
32
+ var contextValue = (0, _react.useMemo)(function () {
33
+ var _ref2, _ref3, _ref4, _ref5, _ref6, _ref7, _ref8, _ref9, _ref10, _ref11, _ref12, _ref13, _ref14;
34
+ return {
35
+ as: (_ref2 = as !== null && as !== void 0 ? as : componentContext === null || componentContext === void 0 ? void 0 : componentContext.as) !== null && _ref2 !== void 0 ? _ref2 : "span",
36
+ display: (_ref3 = display !== null && display !== void 0 ? display : componentContext === null || componentContext === void 0 ? void 0 : componentContext.display) !== null && _ref3 !== void 0 ? _ref3 : "inline",
37
+ fontFamily: (_ref4 = fontFamily !== null && fontFamily !== void 0 ? fontFamily : componentContext === null || componentContext === void 0 ? void 0 : componentContext.fontFamily) !== null && _ref4 !== void 0 ? _ref4 : "Open Sans, sans-serif",
38
+ fontSize: (_ref5 = fontSize !== null && fontSize !== void 0 ? fontSize : componentContext === null || componentContext === void 0 ? void 0 : componentContext.fontSize) !== null && _ref5 !== void 0 ? _ref5 : "1rem",
39
+ fontStyle: (_ref6 = fontStyle !== null && fontStyle !== void 0 ? fontStyle : componentContext === null || componentContext === void 0 ? void 0 : componentContext.fontStyle) !== null && _ref6 !== void 0 ? _ref6 : "normal",
40
+ fontWeight: (_ref7 = fontWeight !== null && fontWeight !== void 0 ? fontWeight : componentContext === null || componentContext === void 0 ? void 0 : componentContext.fontWeight) !== null && _ref7 !== void 0 ? _ref7 : "400",
41
+ letterSpacing: (_ref8 = letterSpacing !== null && letterSpacing !== void 0 ? letterSpacing : componentContext === null || componentContext === void 0 ? void 0 : componentContext.letterSpacing) !== null && _ref8 !== void 0 ? _ref8 : "0em",
42
+ lineHeight: (_ref9 = lineHeight !== null && lineHeight !== void 0 ? lineHeight : componentContext === null || componentContext === void 0 ? void 0 : componentContext.lineHeight) !== null && _ref9 !== void 0 ? _ref9 : "1.5em",
43
+ textAlign: (_ref10 = textAlign !== null && textAlign !== void 0 ? textAlign : componentContext === null || componentContext === void 0 ? void 0 : componentContext.textAlign) !== null && _ref10 !== void 0 ? _ref10 : "left",
44
+ color: (_ref11 = color !== null && color !== void 0 ? color : componentContext === null || componentContext === void 0 ? void 0 : componentContext.color) !== null && _ref11 !== void 0 ? _ref11 : "#000000",
45
+ textDecoration: (_ref12 = textDecoration !== null && textDecoration !== void 0 ? textDecoration : componentContext === null || componentContext === void 0 ? void 0 : componentContext.textDecoration) !== null && _ref12 !== void 0 ? _ref12 : "none",
46
+ textOverflow: (_ref13 = textOverflow !== null && textOverflow !== void 0 ? textOverflow : componentContext === null || componentContext === void 0 ? void 0 : componentContext.textOverflow) !== null && _ref13 !== void 0 ? _ref13 : "unset",
47
+ whiteSpace: (_ref14 = whiteSpace !== null && whiteSpace !== void 0 ? whiteSpace : componentContext === null || componentContext === void 0 ? void 0 : componentContext.whiteSpace) !== null && _ref14 !== void 0 ? _ref14 : "normal"
48
+ };
49
+ }, [as, display, fontFamily, fontSize, fontStyle, fontWeight, letterSpacing, lineHeight, textAlign, color, textDecoration, textOverflow, whiteSpace]);
50
+ return /*#__PURE__*/_react["default"].createElement(TypographyContext.Provider, {
51
+ value: contextValue
52
+ }, /*#__PURE__*/_react["default"].createElement(StyledTypography, contextValue, children));
53
+ };
54
+ var StyledTypography = _styledComponents["default"].span(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n display: ", ";\n color: ", ";\n font-family: ", ";\n font-size: ", ";\n font-style: ", ";\n font-weight: ", ";\n letter-spacing: ", ";\n line-height: ", ";\n text-align: ", ";\n text-decoration: ", ";\n text-overflow: ", ";\n white-space: ", ";\n overflow: ", ";\n margin: 0;\n"])), function (_ref15) {
55
+ var display = _ref15.display;
56
+ return display;
57
+ }, function (_ref16) {
58
+ var color = _ref16.color;
59
+ return color;
60
+ }, function (_ref17) {
61
+ var fontFamily = _ref17.fontFamily;
62
+ return fontFamily;
63
+ }, function (_ref18) {
64
+ var fontSize = _ref18.fontSize;
65
+ return fontSize;
66
+ }, function (_ref19) {
67
+ var fontStyle = _ref19.fontStyle;
68
+ return fontStyle;
69
+ }, function (_ref20) {
70
+ var fontWeight = _ref20.fontWeight;
71
+ return fontWeight;
72
+ }, function (_ref21) {
73
+ var letterSpacing = _ref21.letterSpacing;
74
+ return letterSpacing;
75
+ }, function (_ref22) {
76
+ var lineHeight = _ref22.lineHeight;
77
+ return lineHeight;
78
+ }, function (_ref23) {
79
+ var textAlign = _ref23.textAlign;
80
+ return textAlign;
81
+ }, function (_ref24) {
82
+ var textDecoration = _ref24.textDecoration;
83
+ return textDecoration;
84
+ }, function (_ref25) {
85
+ var textOverflow = _ref25.textOverflow;
86
+ return textOverflow;
87
+ }, function (_ref26) {
88
+ var whiteSpace = _ref26.whiteSpace;
89
+ return whiteSpace;
90
+ }, function (_ref27) {
91
+ var textOverflow = _ref27.textOverflow;
92
+ return textOverflow !== "unset" ? "hidden" : "visible";
93
+ });
94
+ var _default = exports["default"] = BaseTypography;
@@ -0,0 +1,13 @@
1
+ import React from "react";
2
+ /**
3
+ * Traps the focus inside the children of the component. It will focus the first focusable element when the component is mounted.
4
+ * When the focus is on the last focusable element and the user tries to focus the next element, it will focus the first element.
5
+ * When the focus is on the first focusable element and the user tries to focus the previous element, it will focus the last element.
6
+ * The focus can't be moved outside the children unless the children are removed from the DOM (for example, a Dialog, a Modal, etc).
7
+ * @param children: React.ReactNode
8
+ * @returns
9
+ */
10
+ declare const FocusLock: ({ children }: {
11
+ children: React.ReactNode;
12
+ }) => JSX.Element;
13
+ export default FocusLock;
@@ -0,0 +1,124 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+ var _typeof = require("@babel/runtime/helpers/typeof");
5
+ Object.defineProperty(exports, "__esModule", {
6
+ value: true
7
+ });
8
+ exports["default"] = void 0;
9
+ var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
10
+ var _react = _interopRequireWildcard(require("react"));
11
+ 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); }
12
+ function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != _typeof(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; }
13
+ var not = {
14
+ negTabIndex: ':not([tabindex^="-"])',
15
+ disabled: ":not(:disabled)"
16
+ };
17
+ var focusableQuery = ["a[href]".concat(not.negTabIndex), "area[href]".concat(not.negTabIndex), "input:not([type=\"hidden\"])".concat(not.negTabIndex).concat(not.disabled), "select".concat(not.negTabIndex).concat(not.disabled), "textarea".concat(not.negTabIndex).concat(not.disabled), "button".concat(not.negTabIndex).concat(not.disabled), "details > summary:first-of-type".concat(not.negTabIndex), "iframe".concat(not.negTabIndex), "audio[controls]".concat(not.negTabIndex), "video[controls]".concat(not.negTabIndex), "[contenteditable]".concat(not.negTabIndex), "[tabindex]".concat(not.negTabIndex).concat(not.disabled)].join(",");
18
+ var getFocusableElements = function getFocusableElements(container) {
19
+ return Array.prototype.slice.call(container.querySelectorAll(focusableQuery)).filter(function (element) {
20
+ return element.getAttribute("aria-hidden") !== "true" && window.getComputedStyle(element).display !== "none" && window.getComputedStyle(element).visibility !== "hidden";
21
+ });
22
+ };
23
+
24
+ /**
25
+ * This function will try to focus the element and return true if it was able to receive the focus.
26
+ * Even if the element is focusable (passes any of the conditions of our selector), there is the possibility
27
+ * that the element may not be focusable at all.
28
+ * @param element: HTMLElement
29
+ * @returns
30
+ */
31
+ var attemptFocus = function attemptFocus(element) {
32
+ element === null || element === void 0 ? void 0 : element.focus();
33
+ return document.activeElement === element;
34
+ };
35
+
36
+ /**
37
+ * @param element: HTMLElement
38
+ * @returns boolean: true if element is contained inside a Radix Portal, false otherwise.
39
+ */
40
+ var radixPortalContains = function radixPortalContains(activeElement) {
41
+ var radixPortals = document.querySelectorAll("[data-radix-portal]");
42
+ var radixPoppers = document.querySelectorAll("[data-radix-popper-content-wrapper]");
43
+ return Array.prototype.slice.call(radixPortals).some(function (portal) {
44
+ return portal.contains(activeElement);
45
+ }) || Array.prototype.slice.call(radixPoppers).some(function (popper) {
46
+ return popper.contains(activeElement);
47
+ });
48
+ };
49
+
50
+ /**
51
+ * Custom hook that returns an array of focusable elements inside a container.
52
+ * @param ref: React.MutableRefObject<HTMLDivElement>
53
+ * @returns
54
+ */
55
+ var useFocusableElements = function useFocusableElements(ref) {
56
+ var _useState = (0, _react.useState)(),
57
+ _useState2 = (0, _slicedToArray2["default"])(_useState, 2),
58
+ focusableElements = _useState2[0],
59
+ setFocusableElements = _useState2[1];
60
+ (0, _react.useEffect)(function () {
61
+ if (ref.current != null) {
62
+ setFocusableElements(getFocusableElements(ref.current));
63
+ var observer = new MutationObserver(function () {
64
+ setFocusableElements(getFocusableElements(ref.current));
65
+ });
66
+ observer.observe(ref.current, {
67
+ childList: true,
68
+ subtree: true,
69
+ attributes: true
70
+ });
71
+ return function () {
72
+ observer.disconnect();
73
+ };
74
+ }
75
+ }, []);
76
+ return focusableElements;
77
+ };
78
+
79
+ /**
80
+ * Traps the focus inside the children of the component. It will focus the first focusable element when the component is mounted.
81
+ * When the focus is on the last focusable element and the user tries to focus the next element, it will focus the first element.
82
+ * When the focus is on the first focusable element and the user tries to focus the previous element, it will focus the last element.
83
+ * The focus can't be moved outside the children unless the children are removed from the DOM (for example, a Dialog, a Modal, etc).
84
+ * @param children: React.ReactNode
85
+ * @returns
86
+ */
87
+ var FocusLock = function FocusLock(_ref) {
88
+ var children = _ref.children;
89
+ var childrenContainerRef = (0, _react.useRef)();
90
+ var focusableElements = useFocusableElements(childrenContainerRef);
91
+ var focusFirst = (0, _react.useCallback)(function () {
92
+ var _childrenContainerRef;
93
+ if ((focusableElements === null || focusableElements === void 0 ? void 0 : focusableElements.length) === 0) (_childrenContainerRef = childrenContainerRef.current) === null || _childrenContainerRef === void 0 ? void 0 : _childrenContainerRef.focus();else if ((focusableElements === null || focusableElements === void 0 ? void 0 : focusableElements.length) > 0) focusableElements.some(function (element) {
94
+ return attemptFocus(element);
95
+ });
96
+ }, [focusableElements]);
97
+ var focusLast = function focusLast() {
98
+ focusableElements.reverse().some(function (element) {
99
+ return attemptFocus(element);
100
+ });
101
+ };
102
+ var focusLock = function focusLock(event) {
103
+ if (event.key === "Tab") focusableElements.length === 0 && event.preventDefault();
104
+ };
105
+ (0, _react.useEffect)(function () {
106
+ var _childrenContainerRef2;
107
+ if (!((_childrenContainerRef2 = childrenContainerRef.current) !== null && _childrenContainerRef2 !== void 0 && _childrenContainerRef2.contains(document.activeElement)) && !radixPortalContains(document.activeElement)) focusFirst();
108
+ }, [focusFirst]);
109
+ return /*#__PURE__*/_react["default"].createElement(_react["default"].Fragment, null, /*#__PURE__*/_react["default"].createElement("div", {
110
+ onFocus: focusLast,
111
+ tabIndex: 0
112
+ }), /*#__PURE__*/_react["default"].createElement("div", {
113
+ onKeyDown: focusLock,
114
+ ref: childrenContainerRef,
115
+ tabIndex: (focusableElements === null || focusableElements === void 0 ? void 0 : focusableElements.length) === 0 ? 0 : -1,
116
+ style: {
117
+ outline: "none"
118
+ }
119
+ }, children), /*#__PURE__*/_react["default"].createElement("div", {
120
+ onFocus: focusFirst,
121
+ tabIndex: 0
122
+ }));
123
+ };
124
+ var _default = exports["default"] = FocusLock;
@@ -1,4 +1,4 @@
1
1
  /// <reference types="react" />
2
2
  import WizardPropsType from "./types";
3
- declare const DxcWizard: ({ mode, currentStep, onStepClick, steps, margin, tabIndex, }: WizardPropsType) => JSX.Element;
3
+ declare const DxcWizard: ({ mode, defaultCurrentStep, currentStep, onStepClick, steps, margin, tabIndex, }: WizardPropsType) => JSX.Element;
4
4
  export default DxcWizard;