@dxc-technology/halstack-react 0.0.0-c2834c3 → 0.0.0-c293b72

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 (397) hide show
  1. package/BackgroundColorContext.d.ts +1 -10
  2. package/BackgroundColorContext.js +5 -22
  3. package/HalstackContext.d.ts +1243 -6
  4. package/HalstackContext.js +126 -114
  5. package/README.md +47 -0
  6. package/accordion/Accordion.accessibility.test.js +71 -0
  7. package/accordion/Accordion.d.ts +1 -1
  8. package/accordion/Accordion.js +104 -161
  9. package/accordion/Accordion.stories.tsx +84 -140
  10. package/accordion/Accordion.test.js +25 -41
  11. package/accordion/types.d.ts +6 -17
  12. package/accordion-group/AccordionGroup.accessibility.test.js +88 -0
  13. package/accordion-group/AccordionGroup.d.ts +2 -2
  14. package/accordion-group/AccordionGroup.js +31 -98
  15. package/accordion-group/AccordionGroup.stories.tsx +94 -67
  16. package/accordion-group/AccordionGroup.test.js +52 -105
  17. package/accordion-group/AccordionGroupAccordion.d.ts +4 -0
  18. package/accordion-group/AccordionGroupAccordion.js +31 -0
  19. package/accordion-group/AccordionGroupContext.d.ts +3 -0
  20. package/accordion-group/AccordionGroupContext.js +8 -0
  21. package/accordion-group/types.d.ts +12 -17
  22. package/action-icon/ActionIcon.accessibility.test.js +63 -0
  23. package/action-icon/ActionIcon.d.ts +4 -0
  24. package/action-icon/ActionIcon.js +48 -0
  25. package/action-icon/ActionIcon.stories.tsx +41 -0
  26. package/action-icon/ActionIcon.test.js +64 -0
  27. package/action-icon/types.d.ts +26 -0
  28. package/alert/Alert.accessibility.test.js +95 -0
  29. package/alert/Alert.js +32 -125
  30. package/alert/Alert.stories.tsx +28 -0
  31. package/alert/Alert.test.js +29 -46
  32. package/alert/types.d.ts +5 -5
  33. package/badge/Badge.accessibility.test.js +129 -0
  34. package/badge/Badge.d.ts +1 -1
  35. package/badge/Badge.js +142 -40
  36. package/badge/Badge.stories.tsx +210 -0
  37. package/badge/Badge.test.js +30 -0
  38. package/badge/types.d.ts +52 -2
  39. package/bleed/Bleed.js +14 -55
  40. package/bleed/Bleed.stories.tsx +95 -95
  41. package/bleed/types.d.ts +2 -2
  42. package/box/Box.accessibility.test.js +33 -0
  43. package/box/Box.d.ts +1 -1
  44. package/box/Box.js +30 -81
  45. package/box/Box.stories.tsx +38 -51
  46. package/box/Box.test.js +2 -7
  47. package/box/types.d.ts +3 -14
  48. package/bulleted-list/BulletedList.accessibility.test.js +107 -0
  49. package/bulleted-list/BulletedList.d.ts +7 -0
  50. package/bulleted-list/BulletedList.js +92 -0
  51. package/bulleted-list/BulletedList.stories.tsx +115 -0
  52. package/bulleted-list/types.d.ts +38 -0
  53. package/button/Button.accessibility.test.js +127 -0
  54. package/button/Button.d.ts +1 -1
  55. package/button/Button.js +64 -117
  56. package/button/Button.stories.tsx +151 -100
  57. package/button/Button.test.js +20 -17
  58. package/button/types.d.ts +12 -8
  59. package/card/Card.accessibility.test.js +36 -0
  60. package/card/Card.d.ts +1 -1
  61. package/card/Card.js +64 -107
  62. package/card/Card.stories.tsx +12 -42
  63. package/card/Card.test.js +11 -22
  64. package/card/types.d.ts +6 -11
  65. package/checkbox/Checkbox.accessibility.test.js +87 -0
  66. package/checkbox/Checkbox.d.ts +2 -2
  67. package/checkbox/Checkbox.js +140 -182
  68. package/checkbox/Checkbox.stories.tsx +128 -94
  69. package/checkbox/Checkbox.test.js +160 -39
  70. package/checkbox/types.d.ts +11 -3
  71. package/chip/Chip.accessibility.test.js +67 -0
  72. package/chip/Chip.js +43 -80
  73. package/chip/Chip.stories.tsx +102 -26
  74. package/chip/Chip.test.js +18 -33
  75. package/chip/types.d.ts +4 -4
  76. package/common/coreTokens.d.ts +237 -0
  77. package/common/coreTokens.js +184 -0
  78. package/common/utils.d.ts +1 -0
  79. package/common/utils.js +6 -12
  80. package/common/variables.d.ts +1395 -0
  81. package/common/variables.js +942 -1159
  82. package/container/Container.d.ts +4 -0
  83. package/container/Container.js +194 -0
  84. package/container/Container.stories.tsx +214 -0
  85. package/container/types.d.ts +74 -0
  86. package/contextual-menu/ContextualMenu.accessibility.test.js +86 -0
  87. package/contextual-menu/ContextualMenu.d.ts +7 -0
  88. package/contextual-menu/ContextualMenu.js +71 -0
  89. package/contextual-menu/ContextualMenu.stories.tsx +182 -0
  90. package/contextual-menu/ContextualMenu.test.js +71 -0
  91. package/contextual-menu/MenuItemAction.d.ts +4 -0
  92. package/contextual-menu/MenuItemAction.js +46 -0
  93. package/contextual-menu/types.d.ts +22 -0
  94. package/date-input/Calendar.d.ts +4 -0
  95. package/date-input/Calendar.js +214 -0
  96. package/date-input/DateInput.accessibility.test.js +216 -0
  97. package/date-input/DateInput.js +149 -299
  98. package/date-input/DateInput.stories.tsx +203 -56
  99. package/date-input/DateInput.test.js +700 -371
  100. package/date-input/DatePicker.d.ts +4 -0
  101. package/date-input/DatePicker.js +121 -0
  102. package/date-input/YearPicker.d.ts +4 -0
  103. package/date-input/YearPicker.js +100 -0
  104. package/date-input/types.d.ts +72 -15
  105. package/dialog/Dialog.accessibility.test.js +69 -0
  106. package/dialog/Dialog.d.ts +1 -1
  107. package/dialog/Dialog.js +73 -107
  108. package/dialog/Dialog.stories.tsx +320 -167
  109. package/dialog/Dialog.test.js +287 -20
  110. package/dialog/types.d.ts +18 -25
  111. package/divider/Divider.accessibility.test.js +33 -0
  112. package/divider/Divider.d.ts +4 -0
  113. package/divider/Divider.js +36 -0
  114. package/divider/Divider.stories.tsx +223 -0
  115. package/divider/Divider.test.js +38 -0
  116. package/divider/types.d.ts +21 -0
  117. package/dropdown/Dropdown.accessibility.test.js +180 -0
  118. package/dropdown/Dropdown.d.ts +1 -1
  119. package/dropdown/Dropdown.js +231 -303
  120. package/dropdown/Dropdown.stories.tsx +235 -57
  121. package/dropdown/Dropdown.test.js +575 -165
  122. package/dropdown/DropdownMenu.d.ts +4 -0
  123. package/dropdown/DropdownMenu.js +63 -0
  124. package/dropdown/DropdownMenuItem.d.ts +4 -0
  125. package/dropdown/DropdownMenuItem.js +70 -0
  126. package/dropdown/types.d.ts +35 -19
  127. package/file-input/FileInput.accessibility.test.js +160 -0
  128. package/file-input/FileInput.d.ts +2 -2
  129. package/file-input/FileInput.js +241 -391
  130. package/file-input/FileInput.stories.tsx +123 -12
  131. package/file-input/FileInput.test.js +292 -367
  132. package/file-input/FileItem.d.ts +4 -14
  133. package/file-input/FileItem.js +52 -117
  134. package/file-input/types.d.ts +25 -8
  135. package/flex/Flex.d.ts +4 -0
  136. package/flex/Flex.js +57 -0
  137. package/flex/Flex.stories.tsx +112 -0
  138. package/flex/types.d.ts +97 -0
  139. package/footer/Footer.accessibility.test.js +117 -0
  140. package/footer/Footer.d.ts +1 -1
  141. package/footer/Footer.js +73 -118
  142. package/footer/Footer.stories.tsx +87 -21
  143. package/footer/Footer.test.js +33 -57
  144. package/footer/Icons.d.ts +3 -2
  145. package/footer/Icons.js +67 -8
  146. package/footer/types.d.ts +26 -27
  147. package/grid/Grid.d.ts +7 -0
  148. package/grid/Grid.js +76 -0
  149. package/grid/Grid.stories.tsx +219 -0
  150. package/grid/types.d.ts +115 -0
  151. package/grid/types.js +5 -0
  152. package/header/Header.accessibility.test.js +84 -0
  153. package/header/Header.d.ts +4 -3
  154. package/header/Header.js +88 -182
  155. package/header/Header.stories.tsx +118 -39
  156. package/header/Header.test.js +13 -26
  157. package/header/Icons.d.ts +2 -2
  158. package/header/Icons.js +4 -9
  159. package/header/types.d.ts +7 -21
  160. package/heading/Heading.accessibility.test.js +33 -0
  161. package/heading/Heading.js +10 -32
  162. package/heading/Heading.test.js +71 -88
  163. package/heading/types.d.ts +7 -7
  164. package/icon/Icon.accessibility.test.js +30 -0
  165. package/icon/Icon.d.ts +4 -0
  166. package/icon/Icon.js +33 -0
  167. package/icon/Icon.stories.tsx +28 -0
  168. package/icon/types.d.ts +4 -0
  169. package/icon/types.js +5 -0
  170. package/image/Image.accessibility.test.js +56 -0
  171. package/image/Image.d.ts +4 -0
  172. package/image/Image.js +70 -0
  173. package/image/Image.stories.tsx +129 -0
  174. package/image/types.d.ts +72 -0
  175. package/image/types.js +5 -0
  176. package/inset/Inset.js +14 -55
  177. package/inset/Inset.stories.tsx +37 -36
  178. package/inset/types.d.ts +2 -2
  179. package/layout/ApplicationLayout.d.ts +16 -6
  180. package/layout/ApplicationLayout.js +82 -166
  181. package/layout/ApplicationLayout.stories.tsx +85 -94
  182. package/layout/Icons.d.ts +8 -0
  183. package/layout/Icons.js +49 -48
  184. package/layout/types.d.ts +19 -35
  185. package/link/Link.accessibility.test.js +112 -0
  186. package/link/Link.d.ts +2 -2
  187. package/link/Link.js +46 -91
  188. package/link/Link.stories.tsx +74 -7
  189. package/link/Link.test.js +24 -44
  190. package/link/types.d.ts +14 -15
  191. package/main.d.ts +14 -12
  192. package/main.js +65 -101
  193. package/nav-tabs/NavTabs.accessibility.test.js +44 -0
  194. package/nav-tabs/NavTabs.d.ts +7 -0
  195. package/nav-tabs/NavTabs.js +93 -0
  196. package/nav-tabs/NavTabs.stories.tsx +279 -0
  197. package/nav-tabs/NavTabs.test.js +75 -0
  198. package/nav-tabs/NavTabsContext.d.ts +3 -0
  199. package/nav-tabs/NavTabsContext.js +8 -0
  200. package/nav-tabs/Tab.d.ts +4 -0
  201. package/nav-tabs/Tab.js +117 -0
  202. package/nav-tabs/types.d.ts +52 -0
  203. package/nav-tabs/types.js +5 -0
  204. package/number-input/NumberInput.accessibility.test.js +228 -0
  205. package/number-input/NumberInput.js +46 -36
  206. package/number-input/NumberInput.stories.tsx +42 -26
  207. package/number-input/NumberInput.test.js +860 -377
  208. package/number-input/NumberInputContext.d.ts +3 -4
  209. package/number-input/NumberInputContext.js +3 -14
  210. package/number-input/types.d.ts +17 -5
  211. package/package.json +49 -51
  212. package/paginator/Icons.d.ts +5 -0
  213. package/paginator/Icons.js +21 -47
  214. package/paginator/Paginator.accessibility.test.js +79 -0
  215. package/paginator/Paginator.js +23 -59
  216. package/paginator/Paginator.stories.tsx +24 -0
  217. package/paginator/Paginator.test.js +280 -211
  218. package/paginator/types.d.ts +3 -3
  219. package/paragraph/Paragraph.accessibility.test.js +28 -0
  220. package/paragraph/Paragraph.d.ts +5 -0
  221. package/paragraph/Paragraph.js +22 -0
  222. package/paragraph/Paragraph.stories.tsx +27 -0
  223. package/password-input/PasswordInput.accessibility.test.js +153 -0
  224. package/password-input/PasswordInput.js +56 -126
  225. package/password-input/PasswordInput.stories.tsx +1 -33
  226. package/password-input/PasswordInput.test.js +160 -142
  227. package/password-input/types.d.ts +8 -7
  228. package/progress-bar/ProgressBar.accessibility.test.js +35 -0
  229. package/progress-bar/ProgressBar.js +65 -91
  230. package/progress-bar/ProgressBar.stories.tsx +93 -0
  231. package/progress-bar/ProgressBar.test.js +72 -44
  232. package/progress-bar/types.d.ts +3 -3
  233. package/quick-nav/QuickNav.accessibility.test.js +57 -0
  234. package/quick-nav/QuickNav.js +34 -56
  235. package/quick-nav/QuickNav.stories.tsx +146 -27
  236. package/quick-nav/types.d.ts +10 -10
  237. package/radio-group/Radio.d.ts +1 -1
  238. package/radio-group/Radio.js +59 -76
  239. package/radio-group/RadioGroup.accessibility.test.js +97 -0
  240. package/radio-group/RadioGroup.js +67 -114
  241. package/radio-group/RadioGroup.stories.tsx +132 -18
  242. package/radio-group/RadioGroup.test.js +518 -457
  243. package/radio-group/types.d.ts +10 -10
  244. package/resultset-table/Icons.d.ts +7 -0
  245. package/resultset-table/Icons.js +47 -0
  246. package/resultset-table/ResultsetTable.accessibility.test.js +274 -0
  247. package/resultset-table/ResultsetTable.d.ts +7 -0
  248. package/resultset-table/ResultsetTable.js +170 -0
  249. package/{resultsetTable → resultset-table}/ResultsetTable.stories.tsx +156 -30
  250. package/resultset-table/ResultsetTable.test.js +381 -0
  251. package/{resultsetTable → resultset-table}/types.d.ts +44 -11
  252. package/resultset-table/types.js +5 -0
  253. package/select/Listbox.d.ts +1 -1
  254. package/select/Listbox.js +47 -54
  255. package/select/Option.js +33 -55
  256. package/select/Select.accessibility.test.js +217 -0
  257. package/select/Select.js +186 -242
  258. package/select/Select.stories.tsx +503 -190
  259. package/select/Select.test.js +1962 -1743
  260. package/select/types.d.ts +17 -21
  261. package/sidenav/Sidenav.accessibility.test.js +59 -0
  262. package/sidenav/Sidenav.d.ts +6 -5
  263. package/sidenav/Sidenav.js +136 -71
  264. package/sidenav/Sidenav.stories.tsx +246 -151
  265. package/sidenav/Sidenav.test.js +26 -45
  266. package/sidenav/SidenavContext.d.ts +5 -0
  267. package/sidenav/SidenavContext.js +13 -0
  268. package/sidenav/types.d.ts +52 -26
  269. package/slider/Slider.accessibility.test.js +104 -0
  270. package/slider/Slider.d.ts +2 -2
  271. package/slider/Slider.js +148 -181
  272. package/slider/Slider.test.js +185 -81
  273. package/slider/types.d.ts +7 -3
  274. package/spinner/Spinner.accessibility.test.js +96 -0
  275. package/spinner/Spinner.js +31 -75
  276. package/spinner/{Spinner.stories.jsx → Spinner.stories.tsx} +53 -27
  277. package/spinner/Spinner.test.js +26 -35
  278. package/spinner/types.d.ts +3 -3
  279. package/status-light/StatusLight.accessibility.test.js +157 -0
  280. package/status-light/StatusLight.d.ts +4 -0
  281. package/status-light/StatusLight.js +51 -0
  282. package/status-light/StatusLight.stories.tsx +74 -0
  283. package/status-light/StatusLight.test.js +25 -0
  284. package/status-light/types.d.ts +17 -0
  285. package/status-light/types.js +5 -0
  286. package/switch/Switch.accessibility.test.js +89 -0
  287. package/switch/Switch.d.ts +2 -2
  288. package/switch/Switch.js +145 -126
  289. package/switch/Switch.stories.tsx +37 -60
  290. package/switch/Switch.test.js +138 -56
  291. package/switch/types.d.ts +7 -3
  292. package/table/DropdownTheme.js +62 -0
  293. package/table/Table.accessibility.test.js +82 -0
  294. package/table/Table.d.ts +6 -2
  295. package/table/Table.js +78 -35
  296. package/table/Table.stories.tsx +651 -0
  297. package/table/Table.test.js +95 -8
  298. package/table/types.d.ts +34 -6
  299. package/tabs/Tab.d.ts +4 -0
  300. package/tabs/Tab.js +117 -0
  301. package/tabs/Tabs.accessibility.test.js +56 -0
  302. package/tabs/Tabs.js +303 -141
  303. package/tabs/Tabs.stories.tsx +118 -6
  304. package/tabs/Tabs.test.js +213 -77
  305. package/tabs/types.d.ts +30 -20
  306. package/tag/Tag.accessibility.test.js +69 -0
  307. package/tag/Tag.js +35 -67
  308. package/tag/Tag.stories.tsx +18 -8
  309. package/tag/Tag.test.js +18 -37
  310. package/tag/types.d.ts +9 -9
  311. package/text-input/Suggestion.js +40 -28
  312. package/text-input/Suggestions.d.ts +4 -0
  313. package/text-input/Suggestions.js +86 -0
  314. package/text-input/TextInput.accessibility.test.js +321 -0
  315. package/text-input/TextInput.js +311 -514
  316. package/text-input/TextInput.stories.tsx +266 -275
  317. package/text-input/TextInput.test.js +1419 -1375
  318. package/text-input/types.d.ts +43 -16
  319. package/textarea/Textarea.accessibility.test.js +155 -0
  320. package/textarea/Textarea.js +70 -113
  321. package/textarea/Textarea.stories.tsx +174 -0
  322. package/textarea/Textarea.test.js +152 -183
  323. package/textarea/types.d.ts +9 -5
  324. package/toggle-group/ToggleGroup.accessibility.test.js +107 -0
  325. package/toggle-group/ToggleGroup.d.ts +2 -2
  326. package/toggle-group/ToggleGroup.js +94 -107
  327. package/toggle-group/ToggleGroup.stories.tsx +52 -7
  328. package/toggle-group/ToggleGroup.test.js +69 -88
  329. package/toggle-group/types.d.ts +28 -19
  330. package/typography/Typography.accessibility.test.js +339 -0
  331. package/typography/Typography.d.ts +4 -0
  332. package/typography/Typography.js +23 -0
  333. package/typography/Typography.stories.tsx +198 -0
  334. package/typography/types.d.ts +18 -0
  335. package/typography/types.js +5 -0
  336. package/useTheme.d.ts +1147 -1
  337. package/useTheme.js +2 -9
  338. package/useTranslatedLabels.d.ts +84 -1
  339. package/useTranslatedLabels.js +1 -7
  340. package/utils/BaseTypography.d.ts +21 -0
  341. package/utils/BaseTypography.js +94 -0
  342. package/utils/FocusLock.d.ts +13 -0
  343. package/utils/FocusLock.js +124 -0
  344. package/wizard/Wizard.accessibility.test.js +55 -0
  345. package/wizard/Wizard.js +34 -79
  346. package/wizard/Wizard.stories.tsx +59 -1
  347. package/wizard/Wizard.test.js +54 -81
  348. package/wizard/types.d.ts +9 -9
  349. package/card/ice-cream.jpg +0 -0
  350. package/common/OpenSans.css +0 -81
  351. package/common/RequiredComponent.js +0 -32
  352. package/common/fonts/OpenSans-Bold.ttf +0 -0
  353. package/common/fonts/OpenSans-BoldItalic.ttf +0 -0
  354. package/common/fonts/OpenSans-ExtraBold.ttf +0 -0
  355. package/common/fonts/OpenSans-ExtraBoldItalic.ttf +0 -0
  356. package/common/fonts/OpenSans-Italic.ttf +0 -0
  357. package/common/fonts/OpenSans-Light.ttf +0 -0
  358. package/common/fonts/OpenSans-LightItalic.ttf +0 -0
  359. package/common/fonts/OpenSans-Regular.ttf +0 -0
  360. package/common/fonts/OpenSans-SemiBold.ttf +0 -0
  361. package/common/fonts/OpenSans-SemiBoldItalic.ttf +0 -0
  362. package/list/List.d.ts +0 -4
  363. package/list/List.js +0 -47
  364. package/list/List.stories.tsx +0 -95
  365. package/list/types.d.ts +0 -7
  366. package/number-input/numberInputContextTypes.d.ts +0 -19
  367. package/progress-bar/ProgressBar.stories.jsx +0 -58
  368. package/radio/Radio.d.ts +0 -4
  369. package/radio/Radio.js +0 -173
  370. package/radio/Radio.stories.tsx +0 -192
  371. package/radio/Radio.test.js +0 -71
  372. package/radio/types.d.ts +0 -54
  373. package/resultsetTable/ResultsetTable.d.ts +0 -4
  374. package/resultsetTable/ResultsetTable.js +0 -254
  375. package/resultsetTable/ResultsetTable.test.js +0 -306
  376. package/row/Row.d.ts +0 -3
  377. package/row/Row.js +0 -127
  378. package/row/Row.stories.tsx +0 -237
  379. package/row/types.d.ts +0 -28
  380. package/select/Icons.d.ts +0 -10
  381. package/select/Icons.js +0 -93
  382. package/slider/Slider.stories.tsx +0 -177
  383. package/stack/Stack.d.ts +0 -3
  384. package/stack/Stack.js +0 -97
  385. package/stack/Stack.stories.tsx +0 -164
  386. package/stack/types.d.ts +0 -24
  387. package/table/Table.stories.jsx +0 -277
  388. package/text/Text.d.ts +0 -7
  389. package/text/Text.js +0 -30
  390. package/text/Text.stories.tsx +0 -19
  391. package/textarea/Textarea.stories.jsx +0 -157
  392. /package/{list → action-icon}/types.js +0 -0
  393. /package/{radio → bulleted-list}/types.js +0 -0
  394. /package/{resultsetTable → container}/types.js +0 -0
  395. /package/{row → contextual-menu}/types.js +0 -0
  396. /package/{stack → divider}/types.js +0 -0
  397. /package/{number-input/numberInputContextTypes.js → flex/types.js} +0 -0
package/layout/Icons.js CHANGED
@@ -1,55 +1,56 @@
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
- exports.twitterLogo = exports.linkedinLogo = exports.facebookLogo = void 0;
9
-
7
+ exports["default"] = void 0;
10
8
  var _react = _interopRequireDefault(require("react"));
11
-
12
- var facebookLogo = /*#__PURE__*/_react["default"].createElement("svg", {
13
- version: "1.1",
14
- id: "Capa_1",
15
- x: "0px",
16
- y: "0px",
17
- width: "438.536px",
18
- height: "438.536px",
19
- viewBox: "0 0 438.536 438.536",
20
- fill: "#FFFFFF"
21
- }, /*#__PURE__*/_react["default"].createElement("g", null, /*#__PURE__*/_react["default"].createElement("path", {
22
- d: "M414.41,24.123C398.333,8.042,378.963,0,356.315,0H82.228C59.58,0,40.21,8.042,24.126,24.123 C8.045,40.207,0.003,59.576,0.003,82.225v274.084c0,22.647,8.042,42.018,24.123,58.102c16.084,16.084,35.454,24.126,58.102,24.126 h274.084c22.648,0,42.018-8.042,58.095-24.126c16.084-16.084,24.126-35.454,24.126-58.102V82.225 C438.532,59.576,430.49,40.204,414.41,24.123z M373.155,225.548h-49.963V406.84h-74.802V225.548H210.99V163.02h37.401v-37.402 c0-26.838,6.283-47.107,18.843-60.813c12.559-13.706,33.304-20.555,62.242-20.555h49.963v62.526h-31.401 c-10.663,0-17.467,1.853-20.417,5.568c-2.949,3.711-4.428,10.23-4.428,19.558v31.119h56.534L373.155,225.548z"
23
- })));
24
-
25
- exports.facebookLogo = facebookLogo;
26
-
27
- var twitterLogo = /*#__PURE__*/_react["default"].createElement("svg", {
28
- version: "1.1",
29
- id: "Capa_1",
30
- x: "0px",
31
- y: "0px",
32
- width: "438.536px",
33
- height: "438.536px",
34
- viewBox: "0 0 438.536 438.536",
35
- fill: "#FFFFFF"
36
- }, /*#__PURE__*/_react["default"].createElement("g", null, /*#__PURE__*/_react["default"].createElement("path", {
37
- d: "M414.41,24.123C398.333,8.042,378.963,0,356.315,0H82.228C59.58,0,40.21,8.042,24.126,24.123 C8.045,40.207,0.003,59.576,0.003,82.225v274.084c0,22.647,8.042,42.018,24.123,58.102c16.084,16.084,35.454,24.126,58.102,24.126 h274.084c22.648,0,42.018-8.042,58.095-24.126c16.084-16.084,24.126-35.454,24.126-58.102V82.225 C438.532,59.576,430.49,40.204,414.41,24.123z M335.471,168.735c0.191,1.713,0.288,4.278,0.288,7.71 c0,15.989-2.334,32.025-6.995,48.104c-4.661,16.087-11.8,31.504-21.416,46.254c-9.606,14.749-21.074,27.791-34.396,39.115 c-13.325,11.32-29.311,20.365-47.968,27.117c-18.648,6.762-38.637,10.143-59.953,10.143c-33.116,0-63.76-8.952-91.931-26.836 c4.568,0.568,9.329,0.855,14.275,0.855c27.6,0,52.439-8.565,74.519-25.7c-12.941-0.185-24.506-4.179-34.688-11.991 c-10.185-7.803-17.273-17.699-21.271-29.691c4.947,0.76,8.658,1.137,11.132,1.137c4.187,0,9.042-0.76,14.56-2.279 c-13.894-2.669-25.598-9.562-35.115-20.697c-9.519-11.136-14.277-23.84-14.277-38.114v-0.571 c10.085,4.755,19.602,7.229,28.549,7.422c-17.321-11.613-25.981-28.265-25.981-49.963c0-10.66,2.758-20.747,8.278-30.264 c15.035,18.464,33.311,33.213,54.816,44.252c21.507,11.038,44.54,17.227,69.092,18.558c-0.95-3.616-1.427-8.186-1.427-13.704 c0-16.562,5.853-30.692,17.56-42.399c11.703-11.706,25.837-17.561,42.394-17.561c17.515,0,32.079,6.283,43.688,18.846 c13.134-2.474,25.892-7.33,38.26-14.56c-4.757,14.652-13.613,25.788-26.55,33.402c12.368-1.716,23.88-4.95,34.537-9.708 C357.458,149.793,347.462,160.166,335.471,168.735z"
38
- })));
39
-
40
- exports.twitterLogo = twitterLogo;
41
-
42
- var linkedinLogo = /*#__PURE__*/_react["default"].createElement("svg", {
43
- version: "1.1",
44
- id: "Capa_1",
45
- x: "0px",
46
- y: "0px",
47
- width: "438.536px",
48
- height: "438.536px",
49
- viewBox: "0 0 438.536 438.536",
50
- fill: "#FFFFFF"
51
- }, /*#__PURE__*/_react["default"].createElement("g", null, /*#__PURE__*/_react["default"].createElement("path", {
52
- d: "M414.41,24.123C398.333,8.042,378.963,0,356.315,0H82.228C59.58,0,40.21,8.042,24.126,24.123 C8.045,40.207,0.003,59.576,0.003,82.225v274.084c0,22.647,8.042,42.018,24.123,58.102c16.084,16.084,35.454,24.126,58.102,24.126 h274.084c22.648,0,42.018-8.042,58.095-24.126c16.084-16.084,24.126-35.454,24.126-58.102V82.225 C438.532,59.576,430.49,40.204,414.41,24.123z M133.618,367.157H67.666V169.016h65.952V367.157z M127.626,132.332 c-6.851,6.567-15.893,9.851-27.124,9.851h-0.288c-10.848,0-19.648-3.284-26.407-9.851c-6.76-6.567-10.138-14.703-10.138-24.41 c0-9.897,3.476-18.083,10.421-24.556c6.95-6.471,15.942-9.708,26.98-9.708c11.039,0,19.89,3.237,26.553,9.708 c6.661,6.473,10.088,14.659,10.277,24.556C137.899,117.625,134.477,125.761,127.626,132.332z M370.873,367.157h-65.952v-105.92 c0-29.879-11.036-44.823-33.116-44.823c-8.374,0-15.42,2.331-21.128,6.995c-5.715,4.661-9.996,10.324-12.847,16.991 c-1.335,3.422-1.999,8.75-1.999,15.981v110.775h-65.952c0.571-119.529,0.571-185.579,0-198.142h65.952v27.974 c13.867-21.681,33.558-32.544,59.101-32.544c22.84,0,41.21,7.52,55.104,22.554c13.895,15.037,20.841,37.214,20.841,66.519v113.64 H370.873z"
53
- })));
54
-
55
- exports.linkedinLogo = linkedinLogo;
9
+ var layoutIcons = {
10
+ facebookLogo: /*#__PURE__*/_react["default"].createElement("svg", {
11
+ version: "1.1",
12
+ x: "0px",
13
+ y: "0px",
14
+ width: "438.536px",
15
+ height: "438.536px",
16
+ viewBox: "0 0 438.536 438.536",
17
+ fill: "#FFFFFF"
18
+ }, /*#__PURE__*/_react["default"].createElement("g", null, /*#__PURE__*/_react["default"].createElement("path", {
19
+ d: "M414.41,24.123C398.333,8.042,378.963,0,356.315,0H82.228C59.58,0,40.21,8.042,24.126,24.123 C8.045,40.207,0.003,59.576,0.003,82.225v274.084c0,22.647,8.042,42.018,24.123,58.102c16.084,16.084,35.454,24.126,58.102,24.126 h274.084c22.648,0,42.018-8.042,58.095-24.126c16.084-16.084,24.126-35.454,24.126-58.102V82.225 C438.532,59.576,430.49,40.204,414.41,24.123z M373.155,225.548h-49.963V406.84h-74.802V225.548H210.99V163.02h37.401v-37.402 c0-26.838,6.283-47.107,18.843-60.813c12.559-13.706,33.304-20.555,62.242-20.555h49.963v62.526h-31.401 c-10.663,0-17.467,1.853-20.417,5.568c-2.949,3.711-4.428,10.23-4.428,19.558v31.119h56.534L373.155,225.548z"
20
+ }))),
21
+ xLogo: /*#__PURE__*/_react["default"].createElement("svg", {
22
+ width: "256",
23
+ height: "256",
24
+ viewBox: "0 0 256 256",
25
+ fill: "none",
26
+ xmlns: "http://www.w3.org/2000/svg"
27
+ }, /*#__PURE__*/_react["default"].createElement("rect", {
28
+ width: "256",
29
+ height: "256",
30
+ rx: "40",
31
+ fill: "white"
32
+ }), /*#__PURE__*/_react["default"].createElement("path", {
33
+ d: "M140.192 118.205L187.848 64H176.556L135.158 111.056L102.117 64H64L113.975 135.163L64 192H75.2914L118.982 142.296L153.883 192H192L140.192 118.205ZM124.722 135.787L119.65 128.697L79.3634 72.3294H96.7094L129.232 117.837L134.282 124.927L176.551 184.076H159.205L124.722 135.787Z",
34
+ fill: "#0F1419"
35
+ })),
36
+ linkedinLogo: /*#__PURE__*/_react["default"].createElement("svg", {
37
+ version: "1.1",
38
+ x: "0px",
39
+ y: "0px",
40
+ width: "438.536px",
41
+ height: "438.536px",
42
+ viewBox: "0 0 438.536 438.536",
43
+ fill: "#FFFFFF"
44
+ }, /*#__PURE__*/_react["default"].createElement("g", null, /*#__PURE__*/_react["default"].createElement("path", {
45
+ d: "M414.41,24.123C398.333,8.042,378.963,0,356.315,0H82.228C59.58,0,40.21,8.042,24.126,24.123 C8.045,40.207,0.003,59.576,0.003,82.225v274.084c0,22.647,8.042,42.018,24.123,58.102c16.084,16.084,35.454,24.126,58.102,24.126 h274.084c22.648,0,42.018-8.042,58.095-24.126c16.084-16.084,24.126-35.454,24.126-58.102V82.225 C438.532,59.576,430.49,40.204,414.41,24.123z M133.618,367.157H67.666V169.016h65.952V367.157z M127.626,132.332 c-6.851,6.567-15.893,9.851-27.124,9.851h-0.288c-10.848,0-19.648-3.284-26.407-9.851c-6.76-6.567-10.138-14.703-10.138-24.41 c0-9.897,3.476-18.083,10.421-24.556c6.95-6.471,15.942-9.708,26.98-9.708c11.039,0,19.89,3.237,26.553,9.708 c6.661,6.473,10.088,14.659,10.277,24.556C137.899,117.625,134.477,125.761,127.626,132.332z M370.873,367.157h-65.952v-105.92 c0-29.879-11.036-44.823-33.116-44.823c-8.374,0-15.42,2.331-21.128,6.995c-5.715,4.661-9.996,10.324-12.847,16.991 c-1.335,3.422-1.999,8.75-1.999,15.981v110.775h-65.952c0.571-119.529,0.571-185.579,0-198.142h65.952v27.974 c13.867-21.681,33.558-32.544,59.101-32.544c22.84,0,41.21,7.52,55.104,22.554c13.895,15.037,20.841,37.214,20.841,66.519v113.64 H370.873z"
46
+ }))),
47
+ hamburgerIcon: /*#__PURE__*/_react["default"].createElement("svg", {
48
+ xmlns: "http://www.w3.org/2000/svg",
49
+ height: "24",
50
+ width: "24",
51
+ viewBox: "0 0 24 24"
52
+ }, /*#__PURE__*/_react["default"].createElement("path", {
53
+ d: "M3 18V16H21V18ZM3 13V11H21V13ZM3 8V6H21V8Z"
54
+ }))
55
+ };
56
+ var _default = exports["default"] = layoutIcons;
package/layout/types.d.ts CHANGED
@@ -1,57 +1,41 @@
1
1
  /// <reference types="react" />
2
- declare type Space = "xxsmall" | "xsmall" | "small" | "medium" | "large" | "xlarge" | "xxlarge";
3
- declare type Padding = {
4
- top?: Space;
5
- bottom?: Space;
6
- left?: Space;
7
- right?: Space;
8
- };
9
- declare type ChildrenType = AppLayoutHeaderPropsType | AppLayoutMainPropsType | AppLayoutFooterPropsType | AppLayoutSidenavPropsType;
10
- export declare type AppLayoutHeaderPropsType = {
2
+ export type AppLayoutMainPropsType = {
11
3
  /**
12
- * Everything between this tags will be displayed as a header, at the top of the screen.
13
- * This is optional and if it is not specified, the DxcHeader will be shown by default.
4
+ * Everything between the tags will be displayed as the content of the main part of the application.
14
5
  */
15
- children?: React.ReactNode;
6
+ children: React.ReactNode;
16
7
  };
17
- export declare type AppLayoutMainPropsType = {
8
+ export type AppLayoutSidenavPropsType = {
18
9
  /**
19
- * Everything between the tags will be displayed as the content of the main part of the application.
10
+ * The area inside the sidenav. This area can be used to render the content inside the sidenav.
20
11
  */
21
12
  children: React.ReactNode;
22
- };
23
- export declare type AppLayoutFooterPropsType = {
24
13
  /**
25
- * Everything between the tags will be displayed as a footer, at the bottom of the screen.
26
- * This is optional and if it is not specified, the DxcFooter will be shown by default.
14
+ * The area assigned to render the sidenav title. It is highly recommended to use the sidenav title.
27
15
  */
28
- children?: React.ReactNode;
16
+ title?: React.ReactNode;
29
17
  };
30
- export declare type AppLayoutSidenavPropsType = {
18
+ type AppLayoutPropsType = {
31
19
  /**
32
- * Size of the padding to be applied to the custom area ('xxsmall' | 'xsmall' | 'small' | 'medium' | 'large' | 'xlarge' | 'xxlarge').
33
- * You can pass an object with 'top', 'bottom', 'left' and 'right' properties in order to specify different padding sizes.
20
+ * Text to be placed next to the hamburger button that toggles the
21
+ * visibility of the sidenav.
34
22
  */
35
- padding?: Space | Padding;
23
+ visibilityToggleLabel?: string;
36
24
  /**
37
- * The area inside the sidenav. This area can be used to render custom content.
25
+ * Header content.
38
26
  */
39
- children: React.ReactNode;
27
+ header?: React.ReactNode;
40
28
  /**
41
- * If false, the arrow button is hidden.
42
- * In lower resolutions the arrow will be always displayed.
29
+ * Sidenav content
43
30
  */
44
- displayArrow?: boolean;
31
+ sidenav?: React.ReactNode;
45
32
  /**
46
- * Default action over the content of the page, overlay the content or push to the right ('push' | 'overlay').
47
- * In lower resolutions the mode will always be overlay.
33
+ * Footer content
48
34
  */
49
- mode: "push" | "overlay";
50
- };
51
- declare type AppLayoutPropsType = {
35
+ footer?: React.ReactNode;
52
36
  /**
53
- * The area inside the sidenav. This area can be used to render custom content.
37
+ * Use the DxcApplicationLayout.Main provided to render main content.
54
38
  */
55
- children: React.ReactElement<ChildrenType> | React.ReactElement<ChildrenType>[];
39
+ children: React.ReactElement<AppLayoutMainPropsType>;
56
40
  };
57
41
  export default AppLayoutPropsType;
@@ -0,0 +1,112 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+ var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator"));
5
+ var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator"));
6
+ var _react = _interopRequireDefault(require("react"));
7
+ var _react2 = require("@testing-library/react");
8
+ var _jestAxe = require("jest-axe");
9
+ var _Link = _interopRequireDefault(require("./Link.tsx"));
10
+ var _Flex = _interopRequireDefault(require("../flex/Flex.tsx"));
11
+ var icon = /*#__PURE__*/_react["default"].createElement("svg", {
12
+ viewBox: "0 0 24 24",
13
+ enableBackground: "new 0 0 24 24",
14
+ fill: "currentColor"
15
+ }, /*#__PURE__*/_react["default"].createElement("g", {
16
+ id: "Bounding_Box"
17
+ }, /*#__PURE__*/_react["default"].createElement("rect", {
18
+ fill: "none",
19
+ width: "24",
20
+ height: "24"
21
+ })), /*#__PURE__*/_react["default"].createElement("g", {
22
+ id: "Master"
23
+ }, /*#__PURE__*/_react["default"].createElement("path", {
24
+ d: "M19,9.3V4h-3v2.6L12,3L2,12h3v8h5v-6h4v6h5v-8h3L19,9.3z M10,10c0-1.1,0.9-2,2-2s2,0.9,2,2H10z"
25
+ })));
26
+ describe("Link component accessibility tests", function () {
27
+ it("Should not have basic accessibility issues", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee() {
28
+ var _render, container, results;
29
+ return _regenerator["default"].wrap(function _callee$(_context) {
30
+ while (1) switch (_context.prev = _context.next) {
31
+ case 0:
32
+ _render = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Flex["default"], null, /*#__PURE__*/_react["default"].createElement(_Link["default"], {
33
+ href: "https://www.google.com",
34
+ icon: icon,
35
+ iconPosition: "before",
36
+ margin: "medium"
37
+ }, "Link"), /*#__PURE__*/_react["default"].createElement(_Link["default"], {
38
+ href: "https://www.google.com",
39
+ icon: icon,
40
+ iconPosition: "after",
41
+ margin: "medium"
42
+ }, "Link"))), container = _render.container;
43
+ _context.next = 3;
44
+ return (0, _jestAxe.axe)(container);
45
+ case 3:
46
+ results = _context.sent;
47
+ expect(results).toHaveNoViolations();
48
+ case 5:
49
+ case "end":
50
+ return _context.stop();
51
+ }
52
+ }, _callee);
53
+ })));
54
+ it("Should not have basic accessibility issues for disabled mode", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee2() {
55
+ var _render2, container, results;
56
+ return _regenerator["default"].wrap(function _callee2$(_context2) {
57
+ while (1) switch (_context2.prev = _context2.next) {
58
+ case 0:
59
+ _render2 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Flex["default"], null, /*#__PURE__*/_react["default"].createElement(_Link["default"], {
60
+ href: "https://www.google.com",
61
+ icon: icon,
62
+ iconPosition: "before",
63
+ margin: "medium",
64
+ disabled: true
65
+ }, "Link"), /*#__PURE__*/_react["default"].createElement(_Link["default"], {
66
+ href: "https://www.google.com",
67
+ icon: icon,
68
+ iconPosition: "after",
69
+ margin: "medium",
70
+ disabled: true
71
+ }, "Link"))), container = _render2.container;
72
+ _context2.next = 3;
73
+ return (0, _jestAxe.axe)(container);
74
+ case 3:
75
+ results = _context2.sent;
76
+ expect(results).toHaveNoViolations();
77
+ case 5:
78
+ case "end":
79
+ return _context2.stop();
80
+ }
81
+ }, _callee2);
82
+ })));
83
+ it("Should not have basic accessibility issues for new-window mode", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee3() {
84
+ var _render3, container, results;
85
+ return _regenerator["default"].wrap(function _callee3$(_context3) {
86
+ while (1) switch (_context3.prev = _context3.next) {
87
+ case 0:
88
+ _render3 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Flex["default"], null, /*#__PURE__*/_react["default"].createElement(_Link["default"], {
89
+ href: "https://www.google.com",
90
+ icon: icon,
91
+ iconPosition: "before",
92
+ margin: "medium",
93
+ newWindow: true
94
+ }, "Link"), /*#__PURE__*/_react["default"].createElement(_Link["default"], {
95
+ href: "https://www.google.com",
96
+ icon: icon,
97
+ iconPosition: "after",
98
+ margin: "medium",
99
+ newWindow: true
100
+ }, "Link"))), container = _render3.container;
101
+ _context3.next = 3;
102
+ return (0, _jestAxe.axe)(container);
103
+ case 3:
104
+ results = _context3.sent;
105
+ expect(results).toHaveNoViolations();
106
+ case 5:
107
+ case "end":
108
+ return _context3.stop();
109
+ }
110
+ }, _callee3);
111
+ })));
112
+ });
package/link/Link.d.ts CHANGED
@@ -1,4 +1,4 @@
1
- /// <reference types="react" />
1
+ import React from "react";
2
2
  import { LinkProps } from "./types";
3
- declare const DxcLink: ({ inheritColor, disabled, icon, iconPosition, href, newWindow, onClick, margin, tabIndex, children, }: LinkProps) => JSX.Element;
3
+ declare const DxcLink: React.ForwardRefExoticComponent<LinkProps & React.RefAttributes<HTMLAnchorElement>>;
4
4
  export default DxcLink;
package/link/Link.js CHANGED
@@ -1,88 +1,72 @@
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
- var _react = _interopRequireDefault(require("react"));
17
-
11
+ var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
12
+ var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties"));
13
+ var _react = _interopRequireWildcard(require("react"));
18
14
  var _styledComponents = _interopRequireWildcard(require("styled-components"));
19
-
20
- var _variables = require("../common/variables.js");
21
-
15
+ var _variables = require("../common/variables");
22
16
  var _useTheme = _interopRequireDefault(require("../useTheme"));
23
-
24
- var _templateObject, _templateObject2, _templateObject3, _templateObject4, _templateObject5, _templateObject6;
25
-
26
- 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); }
27
-
28
- 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; }
29
-
17
+ var _Icon = _interopRequireDefault(require("../icon/Icon"));
18
+ var _templateObject, _templateObject2;
19
+ var _excluded = ["inheritColor", "disabled", "icon", "iconPosition", "href", "newWindow", "onClick", "margin", "tabIndex", "children"];
20
+ 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); }
21
+ 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; }
30
22
  var LinkContent = /*#__PURE__*/_react["default"].memo(function (_ref) {
31
23
  var iconPosition = _ref.iconPosition,
32
- icon = _ref.icon,
33
- children = _ref.children;
34
- return /*#__PURE__*/_react["default"].createElement(LinkText, null, iconPosition === "after" && children, icon && /*#__PURE__*/_react["default"].createElement(LinkIconContainer, {
24
+ icon = _ref.icon,
25
+ children = _ref.children;
26
+ return /*#__PURE__*/_react["default"].createElement(_react["default"].Fragment, null, iconPosition === "after" && children, icon && /*#__PURE__*/_react["default"].createElement(LinkIconContainer, {
35
27
  iconPosition: iconPosition
36
- }, typeof icon === "string" ? /*#__PURE__*/_react["default"].createElement(LinkIcon, {
37
- src: icon
28
+ }, typeof icon === "string" ? /*#__PURE__*/_react["default"].createElement(_Icon["default"], {
29
+ icon: icon
38
30
  }) : icon), iconPosition === "before" && children);
39
31
  });
40
-
41
- var DxcLink = function DxcLink(_ref2) {
32
+ var DxcLink = /*#__PURE__*/(0, _react.forwardRef)(function (_ref2, ref) {
42
33
  var _ref2$inheritColor = _ref2.inheritColor,
43
- inheritColor = _ref2$inheritColor === void 0 ? false : _ref2$inheritColor,
44
- _ref2$disabled = _ref2.disabled,
45
- disabled = _ref2$disabled === void 0 ? false : _ref2$disabled,
46
- icon = _ref2.icon,
47
- _ref2$iconPosition = _ref2.iconPosition,
48
- iconPosition = _ref2$iconPosition === void 0 ? "before" : _ref2$iconPosition,
49
- _ref2$href = _ref2.href,
50
- href = _ref2$href === void 0 ? "" : _ref2$href,
51
- _ref2$newWindow = _ref2.newWindow,
52
- newWindow = _ref2$newWindow === void 0 ? false : _ref2$newWindow,
53
- onClick = _ref2.onClick,
54
- margin = _ref2.margin,
55
- _ref2$tabIndex = _ref2.tabIndex,
56
- tabIndex = _ref2$tabIndex === void 0 ? 0 : _ref2$tabIndex,
57
- children = _ref2.children;
34
+ inheritColor = _ref2$inheritColor === void 0 ? false : _ref2$inheritColor,
35
+ _ref2$disabled = _ref2.disabled,
36
+ disabled = _ref2$disabled === void 0 ? false : _ref2$disabled,
37
+ icon = _ref2.icon,
38
+ _ref2$iconPosition = _ref2.iconPosition,
39
+ iconPosition = _ref2$iconPosition === void 0 ? "before" : _ref2$iconPosition,
40
+ _ref2$href = _ref2.href,
41
+ href = _ref2$href === void 0 ? "" : _ref2$href,
42
+ _ref2$newWindow = _ref2.newWindow,
43
+ newWindow = _ref2$newWindow === void 0 ? false : _ref2$newWindow,
44
+ onClick = _ref2.onClick,
45
+ margin = _ref2.margin,
46
+ _ref2$tabIndex = _ref2.tabIndex,
47
+ tabIndex = _ref2$tabIndex === void 0 ? 0 : _ref2$tabIndex,
48
+ children = _ref2.children,
49
+ otherProps = (0, _objectWithoutProperties2["default"])(_ref2, _excluded);
58
50
  var colorsTheme = (0, _useTheme["default"])();
59
51
  return /*#__PURE__*/_react["default"].createElement(_styledComponents.ThemeProvider, {
60
52
  theme: colorsTheme.link
61
- }, /*#__PURE__*/_react["default"].createElement(LinkContainer, {
62
- margin: margin
63
- }, typeof children === "string" && (href || onClick) ? /*#__PURE__*/_react["default"].createElement(StyledLink, {
53
+ }, /*#__PURE__*/_react["default"].createElement(StyledLink, (0, _extends2["default"])({
64
54
  as: href ? "a" : "button",
65
55
  tabIndex: tabIndex,
66
- onClick: !disabled && onClick,
56
+ onClick: !disabled ? onClick : undefined,
67
57
  href: !disabled && href ? href : undefined,
68
58
  target: href ? newWindow ? "_blank" : "_self" : undefined,
69
59
  disabled: disabled,
70
- inheritColor: inheritColor
71
- }, /*#__PURE__*/_react["default"].createElement(LinkContent, {
72
- iconPosition: iconPosition,
73
- icon: icon,
74
- children: children
75
- })) : /*#__PURE__*/_react["default"].createElement(CustomLinkContainer, {
76
- disabled: disabled,
77
- inheritColor: inheritColor
78
- }, /*#__PURE__*/_react["default"].createElement(LinkContent, {
60
+ inheritColor: inheritColor,
61
+ margin: margin,
62
+ ref: ref
63
+ }, otherProps), /*#__PURE__*/_react["default"].createElement(LinkContent, {
79
64
  iconPosition: iconPosition,
80
65
  icon: icon,
81
66
  children: children
82
- }))));
83
- };
84
-
85
- var LinkContainer = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n display: inline-flex;\n margin: ", ";\n margin-top: ", ";\n margin-right: ", ";\n margin-bottom: ", ";\n margin-left: ", ";\n\n * {\n background: none;\n border: none;\n padding: 0;\n cursor: pointer;\n font-size: ", ";\n font-weight: ", ";\n font-style: ", ";\n font-family: ", ";\n text-decoration-color: transparent;\n }\n"])), function (props) {
67
+ })));
68
+ });
69
+ var StyledLink = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n display: inline-flex;\n align-items: baseline;\n margin: ", ";\n margin-top: ", ";\n margin-right: ", ";\n margin-bottom: ", ";\n margin-left: ", ";\n background: none;\n border: none;\n padding: 0;\n cursor: pointer;\n font-size: ", ";\n font-weight: ", ";\n font-style: ", ";\n font-family: ", ";\n text-decoration-color: transparent;\n width: fit-content;\n ", "\n ", "\n color: ", ";\n ", "\n &:visited {\n color: ", ";\n &:hover {\n ", "\n }\n }\n &:hover {\n ", "\n }\n &:focus {\n border-radius: 2px;\n outline: 2px solid ", ";\n ", "\n }\n &:active {\n ", "\n }\n"])), function (props) {
86
70
  return props.margin && (0, _typeof2["default"])(props.margin) !== "object" ? _variables.spaces[props.margin] : "0px";
87
71
  }, function (props) {
88
72
  return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.top ? _variables.spaces[props.margin.top] : "";
@@ -100,14 +84,12 @@ var LinkContainer = _styledComponents["default"].div(_templateObject || (_templa
100
84
  return props.theme.fontStyle;
101
85
  }, function (props) {
102
86
  return props.theme.fontFamily;
103
- });
104
-
105
- var StyledLink = _styledComponents["default"].div(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n ", "\n ", "\n color: ", ";\n ", "\n\n &:visited {\n color: ", ";\n &:hover {\n ", "\n }\n }\n &:hover {\n ", "\n }\n &:focus {\n border-radius: 2px;\n outline: 2px solid ", ";\n ", "\n }\n &:active {\n ", "\n }\n"])), function (props) {
87
+ }, function (props) {
106
88
  return "padding-bottom: ".concat(props.theme.underlineSpacing, ";\n border-bottom: ").concat(props.theme.underlineThickness, " ").concat(props.theme.underlineStyle, " transparent;");
107
89
  }, function (props) {
108
90
  return props.disabled && "cursor: default;";
109
91
  }, function (props) {
110
- return props.inheritColor ? "inherit" : !props.disabled ? props.theme.fontColor : props.theme.disabledColor;
92
+ return props.inheritColor ? "inherit" : !props.disabled ? props.theme.fontColor : props.theme.disabledFontColor;
111
93
  }, function (props) {
112
94
  return props.disabled ? "pointer-events: none;" : "";
113
95
  }, function (props) {
@@ -123,40 +105,13 @@ var StyledLink = _styledComponents["default"].div(_templateObject2 || (_template
123
105
  }, function (props) {
124
106
  return "color: ".concat(props.theme.activeFontColor, " !important;\n border-bottom-color: ").concat(props.theme.activeUnderlineColor, " !important;");
125
107
  });
126
-
127
- var CustomLinkContainer = _styledComponents["default"].div(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n ", "\n ", "\n ", "\n\n * {\n color: ", ";\n }\n\n &:hover {\n * {\n color: ", ";\n }\n ", "\n }\n &:focus-within {\n * {\n outline: none;\n }\n border-radius: 2px;\n outline: 2px solid ", ";\n ", "\n }\n &:active {\n * {\n color: ", " !important;\n }\n ", "\n }\n"])), function (props) {
128
- return "padding-bottom: ".concat(props.theme.underlineSpacing, ";\n border-bottom: ").concat(props.theme.underlineThickness, " ").concat(props.theme.underlineStyle, " transparent;");
129
- }, function (props) {
130
- return props.disabled && "cursor: default;";
131
- }, function (props) {
132
- return props.disabled ? "pointer-events: none;" : "";
133
- }, function (props) {
134
- return props.inheritColor ? "inherit" : !props.disabled ? props.theme.fontColor : props.theme.disabledColor;
135
- }, function (props) {
136
- return props.theme.hoverFontColor;
137
- }, function (props) {
138
- return "border-bottom-color: ".concat(props.theme.hoverUnderlineColor, ";\n cursor: pointer;");
139
- }, function (props) {
140
- return props.theme.focusColor;
141
- }, function (props) {
142
- return props.disabled && "outline: none";
143
- }, function (props) {
144
- return props.theme.activeFontColor;
145
- }, function (props) {
146
- return "border-bottom-color: ".concat(props.theme.activeUnderlineColor, " !important;");
147
- });
148
-
149
- var LinkText = _styledComponents["default"].div(_templateObject4 || (_templateObject4 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n align-items: baseline;\n max-width: 100%;\n"])));
150
-
151
- var LinkIcon = _styledComponents["default"].img(_templateObject5 || (_templateObject5 = (0, _taggedTemplateLiteral2["default"])([""])));
152
-
153
- var LinkIconContainer = _styledComponents["default"].div(_templateObject6 || (_templateObject6 = (0, _taggedTemplateLiteral2["default"])(["\n width: ", ";\n height: ", ";\n ", ";\n overflow: hidden;\n align-self: center;\n\n img,\n svg {\n height: 100%;\n width: 100%;\n }\n"])), function (props) {
108
+ var LinkIconContainer = _styledComponents["default"].div(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n width: ", ";\n height: ", ";\n ", ";\n overflow: hidden;\n align-self: center;\n\n font-size: ", ";\n svg {\n height: 100%;\n width: 100%;\n }\n"])), function (props) {
154
109
  return props.theme.iconSize;
155
110
  }, function (props) {
156
111
  return props.theme.iconSize;
157
112
  }, function (props) {
158
113
  return "".concat(props.iconPosition === "before" ? "margin-right" : "margin-left", ": ").concat(props.theme.iconSpacing);
114
+ }, function (props) {
115
+ return props.theme.iconSize;
159
116
  });
160
-
161
- var _default = DxcLink;
162
- exports["default"] = _default;
117
+ var _default = exports["default"] = DxcLink;
@@ -2,6 +2,7 @@ import React from "react";
2
2
  import DxcLink from "./Link";
3
3
  import Title from "../../.storybook/components/Title";
4
4
  import ExampleContainer from "../../.storybook/components/ExampleContainer";
5
+ import { HalstackProvider } from "../HalstackContext";
5
6
 
6
7
  export default {
7
8
  title: "Link",
@@ -9,7 +10,7 @@ export default {
9
10
  };
10
11
 
11
12
  const icon = (
12
- <svg viewBox="0 0 24 24" enable-background="new 0 0 24 24" fill="currentColor">
13
+ <svg viewBox="0 0 24 24" enableBackground="new 0 0 24 24" fill="currentColor">
13
14
  <g id="Bounding_Box">
14
15
  <rect fill="none" width="24" height="24" />
15
16
  </g>
@@ -19,6 +20,12 @@ const icon = (
19
20
  </svg>
20
21
  );
21
22
 
23
+ const opinionatedTheme = {
24
+ link: {
25
+ baseColor: "#5f249f",
26
+ },
27
+ };
28
+
22
29
  export const Chromatic = () => (
23
30
  <>
24
31
  <Title title="With anchor" theme="light" level={2} />
@@ -26,7 +33,7 @@ export const Chromatic = () => (
26
33
  <Title title="Disabled" theme="light" level={4} />
27
34
  <DxcLink disabled>Test</DxcLink>
28
35
  <Title title="Icon before" theme="light" level={4} />
29
- <DxcLink href="https://www.google.com" icon={icon} iconPosition="before">
36
+ <DxcLink href="https://www.google.com" icon="lock" iconPosition="before">
30
37
  Test
31
38
  </DxcLink>
32
39
  <Title title="Icon after" theme="light" level={4} />
@@ -68,11 +75,18 @@ export const Chromatic = () => (
68
75
  </ExampleContainer>
69
76
  <ExampleContainer pseudoState="pseudo-hover">
70
77
  <Title title="Long text with hover" theme="light" level={4} />
71
- Lorem <DxcLink href="https://www.google.com">Test</DxcLink> ipsum dolor sit amet, consectetur adipiscing elit, sed
72
- do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation
73
- ullamco laboris nisi ut aliquip ex ea commodo consequat. Duis aute irure dolor in reprehenderit in voluptate velit
74
- esse cillum dolore eu fugiat nulla pariatur. Excepteur sint occaecat cupidatat non proident, sunt in culpa qui
75
- officia deserunt mollit anim id est laborum.
78
+ Lorem{" "}
79
+ <DxcLink href="https://www.google.com" icon="filled_home">
80
+ Test
81
+ </DxcLink>{" "}
82
+ ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna
83
+ aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo
84
+ consequat. Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur.
85
+ Excepteur sint occaecat cupidatat non proident, sunt in culpa qui officia deserunt mollit{" "}
86
+ <DxcLink href="https://www.google.com" icon={icon} iconPosition="after">
87
+ Test
88
+ </DxcLink>{" "}
89
+ anim id est laborum.
76
90
  </ExampleContainer>
77
91
  <ExampleContainer pseudoState="pseudo-focus">
78
92
  <Title title="Long text with focus" theme="light" level={4} />
@@ -182,5 +196,58 @@ export const Chromatic = () => (
182
196
  Test
183
197
  </DxcLink>
184
198
  </ExampleContainer>
199
+ <Title title="Opinionated theme" theme="light" level={2} />
200
+ <ExampleContainer>
201
+ <Title title="Disabled" theme="light" level={4} />
202
+ <HalstackProvider theme={opinionatedTheme}>
203
+ <DxcLink disabled>Test</DxcLink>
204
+ </HalstackProvider>
205
+ </ExampleContainer>
206
+ <ExampleContainer>
207
+ <Title title="Icon before" theme="light" level={4} />
208
+ <HalstackProvider theme={opinionatedTheme}>
209
+ <DxcLink href="https://www.google.com" icon={icon} iconPosition="before">
210
+ Test
211
+ </DxcLink>
212
+ </HalstackProvider>
213
+ </ExampleContainer>
214
+ <ExampleContainer>
215
+ <Title title="Disabled" theme="light" level={4} />
216
+ <HalstackProvider theme={opinionatedTheme}>
217
+ <DxcLink disabled>Test</DxcLink>
218
+ </HalstackProvider>
219
+ </ExampleContainer>
220
+ <ExampleContainer>
221
+ <Title title="Icon after" theme="light" level={4} />{" "}
222
+ <HalstackProvider theme={opinionatedTheme}>
223
+ <DxcLink onClick={() => {}} icon={icon} iconPosition="after">
224
+ Test
225
+ </DxcLink>
226
+ </HalstackProvider>
227
+ </ExampleContainer>
228
+ <ExampleContainer pseudoState="pseudo-hover">
229
+ <Title title="With link hovered" theme="light" level={4} />
230
+ <HalstackProvider theme={opinionatedTheme}>
231
+ <DxcLink onClick={() => {}}>Test</DxcLink>
232
+ </HalstackProvider>
233
+ </ExampleContainer>
234
+ <ExampleContainer pseudoState="pseudo-focus">
235
+ <Title title="With link focused" theme="light" level={4} />
236
+ <HalstackProvider theme={opinionatedTheme}>
237
+ <DxcLink onClick={() => {}}>Test</DxcLink>
238
+ </HalstackProvider>
239
+ </ExampleContainer>
240
+ <ExampleContainer pseudoState="pseudo-active">
241
+ <Title title="With link active" theme="light" level={4} />
242
+ <HalstackProvider theme={opinionatedTheme}>
243
+ <DxcLink onClick={() => {}}>Test</DxcLink>
244
+ </HalstackProvider>
245
+ </ExampleContainer>
246
+ <ExampleContainer pseudoState="pseudo-visited">
247
+ <HalstackProvider theme={opinionatedTheme}>
248
+ <Title title="With link visited" theme="light" level={4} />
249
+ <DxcLink href="https://www.google.com">Test</DxcLink>
250
+ </HalstackProvider>
251
+ </ExampleContainer>
185
252
  </>
186
253
  );