@dxc-technology/halstack-react 0.0.0-e1386cf → 0.0.0-e19ca5f

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 (385) hide show
  1. package/BackgroundColorContext.d.ts +1 -10
  2. package/BackgroundColorContext.js +5 -22
  3. package/HalstackContext.d.ts +1240 -6
  4. package/HalstackContext.js +122 -106
  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 +44 -118
  9. package/accordion/Accordion.stories.tsx +82 -147
  10. package/accordion/Accordion.test.js +19 -34
  11. package/accordion/types.d.ts +6 -18
  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 +29 -77
  15. package/accordion-group/AccordionGroup.stories.tsx +78 -77
  16. package/accordion-group/AccordionGroup.test.js +44 -72
  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 +7 -19
  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 +36 -126
  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 -42
  36. package/badge/Badge.stories.tsx +210 -0
  37. package/badge/Badge.test.js +30 -0
  38. package/badge/types.d.ts +52 -3
  39. package/bleed/Bleed.js +13 -21
  40. package/bleed/Bleed.stories.tsx +1 -0
  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 +18 -59
  45. package/box/Box.stories.tsx +38 -51
  46. package/box/Box.test.js +2 -7
  47. package/box/types.d.ts +3 -15
  48. package/breadcrumbs/Breadcrumbs.accessibility.test.d.ts +1 -0
  49. package/breadcrumbs/Breadcrumbs.accessibility.test.js +96 -0
  50. package/breadcrumbs/Breadcrumbs.d.ts +4 -0
  51. package/breadcrumbs/Breadcrumbs.js +79 -0
  52. package/breadcrumbs/Breadcrumbs.stories.tsx +194 -0
  53. package/breadcrumbs/Breadcrumbs.test.d.ts +1 -0
  54. package/breadcrumbs/Breadcrumbs.test.js +169 -0
  55. package/breadcrumbs/Item.d.ts +4 -0
  56. package/breadcrumbs/Item.js +52 -0
  57. package/breadcrumbs/dropdownTheme.d.ts +53 -0
  58. package/breadcrumbs/dropdownTheme.js +62 -0
  59. package/breadcrumbs/types.d.ts +16 -0
  60. package/bulleted-list/BulletedList.accessibility.test.js +119 -0
  61. package/bulleted-list/BulletedList.js +22 -53
  62. package/bulleted-list/BulletedList.stories.tsx +8 -93
  63. package/bulleted-list/types.d.ts +32 -5
  64. package/button/Button.accessibility.test.js +127 -0
  65. package/button/Button.d.ts +1 -1
  66. package/button/Button.js +71 -106
  67. package/button/Button.stories.tsx +143 -101
  68. package/button/Button.test.js +20 -17
  69. package/button/types.d.ts +9 -5
  70. package/card/Card.accessibility.test.js +36 -0
  71. package/card/Card.d.ts +1 -1
  72. package/card/Card.js +49 -89
  73. package/card/Card.stories.tsx +12 -42
  74. package/card/Card.test.js +11 -22
  75. package/card/types.d.ts +6 -12
  76. package/checkbox/Checkbox.accessibility.test.js +87 -0
  77. package/checkbox/Checkbox.js +90 -125
  78. package/checkbox/Checkbox.stories.tsx +68 -54
  79. package/checkbox/Checkbox.test.js +108 -64
  80. package/checkbox/types.d.ts +8 -4
  81. package/chip/Chip.accessibility.test.js +67 -0
  82. package/chip/Chip.js +45 -80
  83. package/chip/Chip.stories.tsx +107 -27
  84. package/chip/Chip.test.js +18 -33
  85. package/chip/types.d.ts +4 -4
  86. package/common/coreTokens.d.ts +237 -0
  87. package/common/coreTokens.js +184 -0
  88. package/common/utils.d.ts +1 -0
  89. package/common/utils.js +6 -12
  90. package/common/variables.d.ts +1392 -0
  91. package/common/variables.js +969 -1213
  92. package/container/Container.d.ts +4 -0
  93. package/container/Container.js +194 -0
  94. package/container/Container.stories.tsx +214 -0
  95. package/container/types.d.ts +74 -0
  96. package/contextual-menu/ContextualMenu.accessibility.test.js +97 -0
  97. package/contextual-menu/ContextualMenu.d.ts +5 -0
  98. package/contextual-menu/ContextualMenu.js +88 -0
  99. package/contextual-menu/ContextualMenu.stories.tsx +232 -0
  100. package/contextual-menu/ContextualMenu.test.js +205 -0
  101. package/contextual-menu/GroupItem.d.ts +4 -0
  102. package/contextual-menu/GroupItem.js +67 -0
  103. package/contextual-menu/ItemAction.d.ts +4 -0
  104. package/contextual-menu/ItemAction.js +51 -0
  105. package/contextual-menu/MenuItem.d.ts +4 -0
  106. package/contextual-menu/MenuItem.js +29 -0
  107. package/contextual-menu/SingleItem.d.ts +4 -0
  108. package/contextual-menu/SingleItem.js +38 -0
  109. package/contextual-menu/types.d.ts +58 -0
  110. package/contextual-menu/types.js +5 -0
  111. package/date-input/Calendar.d.ts +4 -0
  112. package/date-input/Calendar.js +214 -0
  113. package/date-input/DateInput.accessibility.test.js +228 -0
  114. package/date-input/DateInput.js +149 -299
  115. package/date-input/DateInput.stories.tsx +210 -56
  116. package/date-input/DateInput.test.js +694 -429
  117. package/date-input/DatePicker.d.ts +4 -0
  118. package/date-input/DatePicker.js +121 -0
  119. package/date-input/YearPicker.d.ts +4 -0
  120. package/date-input/YearPicker.js +100 -0
  121. package/date-input/types.d.ts +72 -15
  122. package/dialog/Dialog.accessibility.test.js +69 -0
  123. package/dialog/Dialog.d.ts +1 -1
  124. package/dialog/Dialog.js +51 -120
  125. package/dialog/Dialog.stories.tsx +316 -212
  126. package/dialog/Dialog.test.js +270 -33
  127. package/dialog/types.d.ts +18 -26
  128. package/divider/Divider.accessibility.test.js +33 -0
  129. package/divider/Divider.d.ts +4 -0
  130. package/divider/Divider.js +36 -0
  131. package/divider/Divider.stories.tsx +223 -0
  132. package/divider/Divider.test.js +38 -0
  133. package/divider/types.d.ts +21 -0
  134. package/divider/types.js +5 -0
  135. package/dropdown/Dropdown.accessibility.test.js +180 -0
  136. package/dropdown/Dropdown.js +66 -136
  137. package/dropdown/Dropdown.stories.tsx +209 -94
  138. package/dropdown/Dropdown.test.js +404 -390
  139. package/dropdown/DropdownMenu.js +23 -40
  140. package/dropdown/DropdownMenuItem.js +17 -38
  141. package/dropdown/types.d.ts +20 -24
  142. package/file-input/FileInput.accessibility.test.js +160 -0
  143. package/file-input/FileInput.js +184 -292
  144. package/file-input/FileInput.stories.tsx +86 -3
  145. package/file-input/FileInput.test.js +279 -395
  146. package/file-input/FileItem.js +31 -67
  147. package/file-input/types.d.ts +10 -10
  148. package/flex/Flex.js +27 -39
  149. package/flex/Flex.stories.tsx +35 -26
  150. package/flex/types.d.ts +74 -9
  151. package/footer/Footer.accessibility.test.js +125 -0
  152. package/footer/Footer.d.ts +1 -1
  153. package/footer/Footer.js +73 -118
  154. package/footer/Footer.stories.tsx +94 -23
  155. package/footer/Footer.test.js +33 -57
  156. package/footer/Icons.d.ts +3 -2
  157. package/footer/Icons.js +53 -22
  158. package/footer/types.d.ts +26 -28
  159. package/grid/Grid.d.ts +7 -0
  160. package/grid/Grid.js +76 -0
  161. package/grid/Grid.stories.tsx +219 -0
  162. package/grid/types.d.ts +115 -0
  163. package/grid/types.js +5 -0
  164. package/header/Header.accessibility.test.js +93 -0
  165. package/header/Header.d.ts +4 -3
  166. package/header/Header.js +55 -150
  167. package/header/Header.stories.tsx +130 -35
  168. package/header/Header.test.js +13 -26
  169. package/header/Icons.d.ts +2 -2
  170. package/header/Icons.js +3 -13
  171. package/header/types.d.ts +7 -22
  172. package/heading/Heading.accessibility.test.js +33 -0
  173. package/heading/Heading.js +10 -32
  174. package/heading/Heading.test.js +71 -88
  175. package/heading/types.d.ts +7 -7
  176. package/icon/Icon.accessibility.test.js +30 -0
  177. package/icon/Icon.d.ts +4 -0
  178. package/icon/Icon.js +33 -0
  179. package/icon/Icon.stories.tsx +28 -0
  180. package/icon/types.d.ts +4 -0
  181. package/icon/types.js +5 -0
  182. package/image/Image.accessibility.test.js +56 -0
  183. package/image/Image.d.ts +4 -0
  184. package/image/Image.js +70 -0
  185. package/image/Image.stories.tsx +129 -0
  186. package/image/types.d.ts +72 -0
  187. package/image/types.js +5 -0
  188. package/inset/Inset.js +13 -21
  189. package/inset/Inset.stories.tsx +2 -1
  190. package/inset/types.d.ts +2 -2
  191. package/layout/ApplicationLayout.d.ts +5 -5
  192. package/layout/ApplicationLayout.js +36 -70
  193. package/layout/ApplicationLayout.stories.tsx +1 -1
  194. package/layout/Icons.d.ts +7 -5
  195. package/layout/Icons.js +41 -59
  196. package/layout/types.d.ts +5 -6
  197. package/link/Link.accessibility.test.js +108 -0
  198. package/link/Link.js +31 -50
  199. package/link/Link.stories.tsx +64 -4
  200. package/link/Link.test.js +24 -44
  201. package/link/types.d.ts +14 -14
  202. package/main.d.ts +11 -5
  203. package/main.js +54 -59
  204. package/nav-tabs/NavTabs.accessibility.test.js +44 -0
  205. package/nav-tabs/NavTabs.d.ts +7 -0
  206. package/{tabs-nav → nav-tabs}/NavTabs.js +25 -57
  207. package/nav-tabs/NavTabs.stories.tsx +279 -0
  208. package/nav-tabs/NavTabs.test.js +77 -0
  209. package/nav-tabs/NavTabsContext.d.ts +3 -0
  210. package/nav-tabs/NavTabsContext.js +8 -0
  211. package/nav-tabs/Tab.js +117 -0
  212. package/{tabs-nav → nav-tabs}/types.d.ts +15 -16
  213. package/nav-tabs/types.js +5 -0
  214. package/number-input/NumberInput.accessibility.test.js +228 -0
  215. package/number-input/NumberInput.js +46 -36
  216. package/number-input/NumberInput.stories.tsx +42 -26
  217. package/number-input/NumberInput.test.js +860 -413
  218. package/number-input/NumberInputContext.d.ts +3 -4
  219. package/number-input/NumberInputContext.js +3 -14
  220. package/number-input/types.d.ts +17 -5
  221. package/package.json +43 -46
  222. package/paginator/Paginator.accessibility.test.js +79 -0
  223. package/paginator/Paginator.js +34 -67
  224. package/paginator/Paginator.stories.tsx +24 -0
  225. package/paginator/Paginator.test.js +252 -225
  226. package/paginator/types.d.ts +3 -3
  227. package/paragraph/Paragraph.accessibility.test.js +28 -0
  228. package/paragraph/Paragraph.d.ts +3 -4
  229. package/paragraph/Paragraph.js +6 -22
  230. package/paragraph/Paragraph.stories.tsx +0 -17
  231. package/password-input/PasswordInput.accessibility.test.js +153 -0
  232. package/password-input/PasswordInput.js +58 -127
  233. package/password-input/PasswordInput.stories.tsx +1 -33
  234. package/password-input/PasswordInput.test.js +158 -141
  235. package/password-input/types.d.ts +8 -7
  236. package/progress-bar/ProgressBar.accessibility.test.js +35 -0
  237. package/progress-bar/ProgressBar.d.ts +2 -2
  238. package/progress-bar/ProgressBar.js +28 -58
  239. package/progress-bar/{ProgressBar.stories.jsx → ProgressBar.stories.tsx} +36 -3
  240. package/progress-bar/ProgressBar.test.js +36 -53
  241. package/progress-bar/types.d.ts +4 -3
  242. package/quick-nav/QuickNav.accessibility.test.js +57 -0
  243. package/quick-nav/QuickNav.js +4 -27
  244. package/quick-nav/QuickNav.stories.tsx +15 -1
  245. package/quick-nav/types.d.ts +10 -10
  246. package/radio-group/Radio.d.ts +1 -1
  247. package/radio-group/Radio.js +31 -63
  248. package/radio-group/RadioGroup.accessibility.test.js +97 -0
  249. package/radio-group/RadioGroup.js +46 -93
  250. package/radio-group/RadioGroup.stories.tsx +131 -18
  251. package/radio-group/RadioGroup.test.js +505 -471
  252. package/radio-group/types.d.ts +8 -8
  253. package/resultset-table/Icons.d.ts +7 -0
  254. package/{text-input → resultset-table}/Icons.js +13 -26
  255. package/resultset-table/ResultsetTable.accessibility.test.js +285 -0
  256. package/resultset-table/ResultsetTable.d.ts +7 -0
  257. package/resultset-table/ResultsetTable.js +171 -0
  258. package/{resultsetTable → resultset-table}/ResultsetTable.stories.tsx +168 -30
  259. package/resultset-table/ResultsetTable.test.js +381 -0
  260. package/{resultsetTable → resultset-table}/types.d.ts +44 -11
  261. package/resultset-table/types.js +5 -0
  262. package/select/Listbox.d.ts +1 -1
  263. package/select/Listbox.js +43 -86
  264. package/select/Option.js +35 -56
  265. package/select/Select.accessibility.test.js +228 -0
  266. package/select/Select.js +140 -183
  267. package/select/Select.stories.tsx +496 -204
  268. package/select/Select.test.js +1949 -1917
  269. package/select/types.d.ts +17 -18
  270. package/sidenav/Sidenav.accessibility.test.js +59 -0
  271. package/sidenav/Sidenav.d.ts +2 -2
  272. package/sidenav/Sidenav.js +90 -157
  273. package/sidenav/Sidenav.stories.tsx +160 -63
  274. package/sidenav/Sidenav.test.js +3 -10
  275. package/{layout → sidenav}/SidenavContext.d.ts +1 -1
  276. package/{layout → sidenav}/SidenavContext.js +3 -9
  277. package/sidenav/types.d.ts +33 -30
  278. package/slider/Slider.accessibility.test.js +104 -0
  279. package/slider/Slider.js +75 -132
  280. package/slider/Slider.test.js +108 -104
  281. package/slider/types.d.ts +4 -4
  282. package/spinner/Spinner.accessibility.test.js +96 -0
  283. package/spinner/Spinner.js +34 -74
  284. package/spinner/{Spinner.stories.jsx → Spinner.stories.tsx} +53 -27
  285. package/spinner/Spinner.test.js +26 -35
  286. package/spinner/types.d.ts +3 -3
  287. package/status-light/StatusLight.accessibility.test.js +157 -0
  288. package/status-light/StatusLight.d.ts +4 -0
  289. package/status-light/StatusLight.js +51 -0
  290. package/status-light/StatusLight.stories.tsx +74 -0
  291. package/status-light/StatusLight.test.js +25 -0
  292. package/status-light/types.d.ts +17 -0
  293. package/status-light/types.js +5 -0
  294. package/switch/Switch.accessibility.test.js +98 -0
  295. package/switch/Switch.js +52 -100
  296. package/switch/Switch.stories.tsx +45 -34
  297. package/switch/Switch.test.js +52 -97
  298. package/switch/types.d.ts +4 -4
  299. package/table/DropdownTheme.js +62 -0
  300. package/table/Table.accessibility.test.js +93 -0
  301. package/table/Table.d.ts +6 -2
  302. package/table/Table.js +78 -35
  303. package/table/Table.stories.tsx +663 -0
  304. package/table/Table.test.js +94 -7
  305. package/table/types.d.ts +34 -6
  306. package/tabs/Tab.js +28 -46
  307. package/tabs/Tabs.accessibility.test.js +56 -0
  308. package/tabs/Tabs.js +69 -163
  309. package/tabs/Tabs.stories.tsx +50 -6
  310. package/tabs/Tabs.test.js +61 -136
  311. package/tabs/types.d.ts +21 -21
  312. package/tag/Tag.accessibility.test.js +69 -0
  313. package/tag/Tag.js +34 -66
  314. package/tag/Tag.stories.tsx +18 -8
  315. package/tag/Tag.test.js +18 -37
  316. package/tag/types.d.ts +9 -9
  317. package/text-input/Suggestion.js +35 -25
  318. package/text-input/Suggestions.d.ts +1 -1
  319. package/text-input/Suggestions.js +30 -70
  320. package/text-input/TextInput.accessibility.test.js +321 -0
  321. package/text-input/TextInput.js +229 -335
  322. package/text-input/TextInput.stories.tsx +155 -162
  323. package/text-input/TextInput.test.js +1289 -1157
  324. package/text-input/types.d.ts +25 -17
  325. package/textarea/Textarea.accessibility.test.js +155 -0
  326. package/textarea/Textarea.js +71 -113
  327. package/textarea/Textarea.stories.tsx +174 -0
  328. package/textarea/Textarea.test.js +152 -183
  329. package/textarea/types.d.ts +9 -5
  330. package/toggle-group/ToggleGroup.accessibility.test.js +107 -0
  331. package/toggle-group/ToggleGroup.d.ts +2 -2
  332. package/toggle-group/ToggleGroup.js +94 -107
  333. package/toggle-group/ToggleGroup.stories.tsx +52 -7
  334. package/toggle-group/ToggleGroup.test.js +69 -88
  335. package/toggle-group/types.d.ts +28 -19
  336. package/typography/Typography.accessibility.test.js +339 -0
  337. package/typography/Typography.d.ts +2 -2
  338. package/typography/Typography.js +15 -123
  339. package/typography/Typography.stories.tsx +1 -1
  340. package/typography/types.d.ts +1 -1
  341. package/useTheme.d.ts +1144 -1
  342. package/useTheme.js +2 -9
  343. package/useTranslatedLabels.d.ts +84 -1
  344. package/useTranslatedLabels.js +1 -7
  345. package/utils/BaseTypography.d.ts +21 -0
  346. package/utils/BaseTypography.js +94 -0
  347. package/utils/FocusLock.d.ts +13 -0
  348. package/utils/FocusLock.js +124 -0
  349. package/wizard/Wizard.accessibility.test.js +55 -0
  350. package/wizard/Wizard.js +29 -75
  351. package/wizard/Wizard.stories.tsx +39 -0
  352. package/wizard/Wizard.test.js +54 -81
  353. package/wizard/types.d.ts +10 -11
  354. package/card/ice-cream.jpg +0 -0
  355. package/common/OpenSans.css +0 -81
  356. package/common/RequiredComponent.js +0 -32
  357. package/common/fonts/OpenSans-Bold.ttf +0 -0
  358. package/common/fonts/OpenSans-BoldItalic.ttf +0 -0
  359. package/common/fonts/OpenSans-ExtraBold.ttf +0 -0
  360. package/common/fonts/OpenSans-ExtraBoldItalic.ttf +0 -0
  361. package/common/fonts/OpenSans-Italic.ttf +0 -0
  362. package/common/fonts/OpenSans-Light.ttf +0 -0
  363. package/common/fonts/OpenSans-LightItalic.ttf +0 -0
  364. package/common/fonts/OpenSans-Regular.ttf +0 -0
  365. package/common/fonts/OpenSans-SemiBold.ttf +0 -0
  366. package/common/fonts/OpenSans-SemiBoldItalic.ttf +0 -0
  367. package/number-input/numberInputContextTypes.d.ts +0 -19
  368. package/paginator/Icons.js +0 -66
  369. package/resultsetTable/ResultsetTable.d.ts +0 -4
  370. package/resultsetTable/ResultsetTable.js +0 -252
  371. package/resultsetTable/ResultsetTable.test.js +0 -348
  372. package/select/Icons.d.ts +0 -10
  373. package/select/Icons.js +0 -93
  374. package/slider/Slider.stories.tsx +0 -183
  375. package/table/Table.stories.jsx +0 -277
  376. package/tabs-nav/NavTabs.d.ts +0 -8
  377. package/tabs-nav/NavTabs.stories.tsx +0 -170
  378. package/tabs-nav/NavTabs.test.js +0 -82
  379. package/tabs-nav/Tab.js +0 -130
  380. package/text-input/Icons.d.ts +0 -8
  381. package/textarea/Textarea.stories.jsx +0 -157
  382. /package/{resultsetTable → action-icon}/types.js +0 -0
  383. /package/{tabs-nav → breadcrumbs}/types.js +0 -0
  384. /package/{number-input/numberInputContextTypes.js → container/types.js} +0 -0
  385. /package/{tabs-nav → nav-tabs}/Tab.d.ts +0 -0
@@ -3,6 +3,7 @@ import { userEvent, within } from "@storybook/testing-library";
3
3
  import DxcChip from "./Chip";
4
4
  import Title from "../../.storybook/components/Title";
5
5
  import ExampleContainer from "../../.storybook/components/ExampleContainer";
6
+ import { HalstackProvider } from "../HalstackContext";
6
7
 
7
8
  export default {
8
9
  title: "Chip",
@@ -10,12 +11,42 @@ export default {
10
11
  };
11
12
 
12
13
  const iconSVG = (
13
- <svg viewBox="0 0 24 24" fill="currentColor">
14
- <path d="M0 0h24v24H0z" fill="none" />
15
- <path d="M12 21.35l-1.45-1.32C5.4 15.36 2 12.28 2 8.5 2 5.42 4.42 3 7.5 3c1.74 0 3.41.81 4.5 2.09C13.09 3.81 14.76 3 16.5 3 19.58 3 22 5.42 22 8.5c0 3.78-3.4 6.86-8.55 11.54L12 21.35z" />
14
+ <svg
15
+ version="1.1"
16
+ x="0px"
17
+ y="0px"
18
+ width="438.536px"
19
+ height="438.536px"
20
+ viewBox="0 0 438.536 438.536"
21
+ fill="currentColor"
22
+ >
23
+ <g>
24
+ <path
25
+ 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
26
+ 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
27
+ h274.084c22.648,0,42.018-8.042,58.095-24.126c16.084-16.084,24.126-35.454,24.126-58.102V82.225
28
+ 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
29
+ 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
30
+ 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"
31
+ />
32
+ </g>
33
+ </svg>
34
+ );
35
+
36
+ const smallIconSVG = (
37
+ <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 20 20" height="20" width="20">
38
+ <path d="m10 17-1.042-.938q-2.083-1.854-3.437-3.177-1.354-1.323-2.136-2.354Q2.604 9.5 2.302 8.646 2 7.792 2 6.896q0-1.854 1.271-3.125T6.396 2.5q1.021 0 1.979.438.958.437 1.625 1.229.667-.792 1.625-1.229.958-.438 1.979-.438 1.854 0 3.125 1.271T18 6.896q0 .896-.292 1.729-.291.833-1.073 1.854-.781 1.021-2.145 2.365-1.365 1.344-3.49 3.26Zm0-2.021q1.938-1.729 3.188-2.948 1.25-1.219 1.989-2.125.74-.906 1.031-1.614.292-.709.292-1.396 0-1.229-.833-2.063Q14.833 4 13.604 4q-.729 0-1.364.302-.636.302-1.094.844L10.417 6h-.834l-.729-.854q-.458-.542-1.114-.844Q7.083 4 6.396 4q-1.229 0-2.063.833-.833.834-.833 2.063 0 .687.271 1.364.271.678.989 1.573.719.896 1.98 2.125Q8 13.188 10 14.979Zm0-5.5Z" />
16
39
  </svg>
17
40
  );
18
41
 
42
+ const opinionatedTheme = {
43
+ chip: {
44
+ baseColor: "#e6e6e6",
45
+ fontColor: "#000000",
46
+ iconColor: "#4d4d4d",
47
+ },
48
+ };
49
+
19
50
  export const Chromatic = () => (
20
51
  <>
21
52
  <ExampleContainer>
@@ -23,46 +54,54 @@ export const Chromatic = () => (
23
54
  <DxcChip label="Default Chip" />
24
55
  </ExampleContainer>
25
56
  <ExampleContainer>
26
- <Title title="Chip with prefix" theme="light" level={4} />
27
- <DxcChip label="Chip with prefix" prefixIcon={iconSVG} />
57
+ <Title title="Chip with prefix SVG (small icon)" theme="light" level={4} />
58
+ <DxcChip label="Chip with prefix" prefixIcon={smallIconSVG} />
28
59
  </ExampleContainer>
29
60
  <ExampleContainer>
30
- <Title title="Chip with suffix" theme="light" level={4} />
61
+ <Title title="Chip with suffix SVG (large icon)" theme="light" level={4} />
31
62
  <DxcChip label="Chip with suffix" suffixIcon={iconSVG} />
32
63
  </ExampleContainer>
33
64
  <ExampleContainer>
34
- <Title title="Chip with prefix and suffix" theme="light" level={4} />
35
- <DxcChip label="Chip with prefix and suffix" prefixIcon={iconSVG} suffixIcon={iconSVG} />
65
+ <Title title="Chip with prefix (SVG) and suffix (URL)" theme="light" level={4} />
66
+ <DxcChip label="Chip with prefix and suffix" prefixIcon={iconSVG} suffixIcon="filled_check_circle" />
36
67
  </ExampleContainer>
37
68
  <ExampleContainer>
38
69
  <Title title="Disabled chip" theme="light" level={4} />
39
- <DxcChip label="Disabled" disabled prefixIcon={iconSVG} suffixIcon={iconSVG} />
70
+ <DxcChip label="Disabled" disabled prefixIcon={iconSVG} suffixIcon="filled_check_circle" />
40
71
  </ExampleContainer>
41
72
  <ExampleContainer>
42
73
  <Title title="Chip with ellipsis" theme="light" level={4} />
43
- <DxcChip label="With ellipsis asdfasdf asdf asdfasdf asdf asdfasdf asdfasdf asdf asdf adfasrfasf afsdg afgasfg asdf asdf asdf asdf asdf asdf asdf afdg asfg asdfg asdf asdf asdf asdfasdf asd fas df asd asdf asdf asdfasd fg ssssssssssss ssss" />
74
+ <div style={{ width: "200px" }}>
75
+ <DxcChip label="With ellipsis asdfasdf asdf asdfasdf asdf asdfasdf asdfasdf asdf asdf adfasrfasf afsdg afgasfg asdf asdf asdf asdf asdf asdf asdf afdg asfg asdfg asdf asdf asdf asdfasdf asd fas df asd asdf asdf asdfasd fg ssssssssssss ssss" />
76
+ </div>
44
77
  </ExampleContainer>
45
78
  <ExampleContainer>
46
79
  <Title title="Chip with ellipsis and suffix" theme="light" level={4} />
47
- <DxcChip
48
- suffixIcon={iconSVG}
49
- label="With ellipsis asdfasdf asdf asdfasdf asdf asdfasdf asdfasdf asdf asdf adfasrfasf afsdg afgasfg asdf asdf asdf asdf asdf asdf asdf afdg asfg asdfg asdf asdf asdf asdfasdf asd fas df asd asdf asdf asdfasd fgsss"
50
- />
80
+ <div style={{ width: "200px" }}>
81
+ <DxcChip
82
+ suffixIcon={iconSVG}
83
+ label="With ellipsis asdfasdf asdf asdfasdf asdf asdfasdf asdfasdf asdf asdf adfasrfasf afsdg afgasfg asdf asdf asdf asdf asdf asdf asdf afdg asfg asdfg asdf asdf asdf asdfasdf asd fas df asd asdf asdf asdfasd fgsss"
84
+ />
85
+ </div>
51
86
  </ExampleContainer>
52
87
  <ExampleContainer>
53
88
  <Title title="Chip with ellipsis and prefix" theme="light" level={4} />
54
- <DxcChip
55
- prefixIcon={iconSVG}
56
- label="With ellipsis asdfasdf asdf asdfasdf asdf asdfasdf asdfasdf asdf asdf adfasrfasf afsdg afgasfg asdf asdf asdf asdf asdf asdf asdf afdg asfg asdfg asdf asdf asdf asdfasdf asd fas df asd asdf asdf asdfasd fgsss"
57
- />
89
+ <div style={{ width: "200px" }}>
90
+ <DxcChip
91
+ prefixIcon={iconSVG}
92
+ label="With ellipsis asdfasdf asdf asdfasdf asdf asdfasdf asdfasdf asdf asdf adfasrfasf afsdg afgasfg asdf asdf asdf asdf asdf asdf asdf afdg asfg asdfg asdf asdf asdf asdfasdf asd fas df asd asdf asdf asdfasd fgsss"
93
+ />
94
+ </div>
58
95
  </ExampleContainer>
59
96
  <ExampleContainer>
60
97
  <Title title="Chip with ellipsis, suffix and prefix" theme="light" level={4} />
61
- <DxcChip
62
- prefixIcon={iconSVG}
63
- suffixIcon={iconSVG}
64
- label="With ellipsis asdfasdf asdf asdfasdf asdf asdfasdf asdfasdf asdf asdf adfasrfasf afsdg afgasfg asdf asdf asdf asdf asdf asdf asdf afdg asfg asdfg asdf asdf asdf asdfasdf asd fas df asd asdf asdf asdfasdf"
65
- />
98
+ <div style={{ width: "200px" }}>
99
+ <DxcChip
100
+ prefixIcon={iconSVG}
101
+ suffixIcon={iconSVG}
102
+ label="With ellipsis asdfasdf asdf asdfasdf asdf asdfasdf asdfasdf asdf asdf adfasrfasf afsdg afgasfg asdf asdf asdf asdf asdf asdf asdf afdg asfg asdfg asdf asdf asdf asdfasdf asd fas df asd asdf asdf asdfasdf"
103
+ />
104
+ </div>
66
105
  </ExampleContainer>
67
106
  <Title title="Margins" theme="light" level={2} />
68
107
  <ExampleContainer>
@@ -93,27 +132,68 @@ export const Chromatic = () => (
93
132
  <Title title="Xxlarge margin" theme="light" level={4} />
94
133
  <DxcChip label="xxlarge" margin="xxlarge" />
95
134
  </ExampleContainer>
135
+ <Title title="Opinionated theme" theme="light" level={2} />
136
+ <ExampleContainer>
137
+ <Title title="Chip with prefix and suffix" theme="light" level={4} />
138
+ <HalstackProvider theme={opinionatedTheme}>
139
+ <DxcChip label="Chip" prefixIcon={iconSVG} suffixIcon="filled_check_circle" />
140
+ </HalstackProvider>
141
+ </ExampleContainer>
142
+ <ExampleContainer>
143
+ <Title title="Chip with prefix and suffix" theme="light" level={4} />
144
+ <HalstackProvider theme={opinionatedTheme}>
145
+ <DxcChip label="Chip" disabled prefixIcon={iconSVG} suffixIcon="filled_check_circle" />
146
+ </HalstackProvider>
147
+ </ExampleContainer>
148
+ <ExampleContainer pseudoState="pseudo-hover">
149
+ <Title title="Hovered" theme="light" level={4} />
150
+ <HalstackProvider theme={opinionatedTheme}>
151
+ <DxcChip
152
+ label="Chip"
153
+ prefixIcon={iconSVG}
154
+ suffixIcon={iconSVG}
155
+ onClickPrefix={() => {}}
156
+ onClickSuffix={() => {}}
157
+ />
158
+ </HalstackProvider>
159
+ </ExampleContainer>
160
+ <ExampleContainer pseudoState="pseudo-active">
161
+ <Title title="Actived" theme="light" level={4} />
162
+ <HalstackProvider theme={opinionatedTheme}>
163
+ <DxcChip
164
+ label="Chip"
165
+ prefixIcon={iconSVG}
166
+ suffixIcon={iconSVG}
167
+ onClickPrefix={() => {}}
168
+ onClickSuffix={() => {}}
169
+ />
170
+ </HalstackProvider>
171
+ </ExampleContainer>
96
172
  </>
97
173
  );
98
174
  const ChipPrefixFocused = () => (
99
175
  <ExampleContainer>
100
176
  <Title title="Chip with prefix" theme="light" level={4} />
101
- <DxcChip label="Chip with prefix" prefixIcon={iconSVG} onClickPrefix={() => {}} />
177
+ <DxcChip
178
+ label="Chip with prefix"
179
+ prefixIcon={iconSVG}
180
+ onClickPrefix={() => {}}
181
+ />
102
182
  </ExampleContainer>
103
183
  );
104
184
  const ChipSuffixFocused = () => (
105
185
  <ExampleContainer>
106
186
  <Title title="Chip with suffix" theme="light" level={4} />
107
- <DxcChip label="Chip with suffix" suffixIcon={iconSVG} onClickSuffix={() => {}} />
187
+ <DxcChip label="Chip with suffix" suffixIcon="filled_delete" onClickSuffix={() => {}} />
108
188
  </ExampleContainer>
109
189
  );
110
190
 
111
191
  export const PrefixFocused = ChipPrefixFocused.bind({});
112
- PrefixFocused.play = async ({ canvasElement }) => {
192
+ PrefixFocused.play = async () => {
113
193
  await userEvent.tab();
114
194
  };
115
195
 
116
196
  export const SuffixFocused = ChipSuffixFocused.bind({});
117
- SuffixFocused.play = async ({ canvasElement }) => {
197
+ SuffixFocused.play = async () => {
118
198
  await userEvent.tab();
119
199
  };
package/chip/Chip.test.js CHANGED
@@ -1,56 +1,41 @@
1
1
  "use strict";
2
2
 
3
3
  var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
-
5
4
  var _react = _interopRequireDefault(require("react"));
6
-
7
5
  var _react2 = require("@testing-library/react");
8
-
9
- var _Chip = _interopRequireDefault(require("./Chip"));
10
-
11
- var _invision = _interopRequireDefault(require("../../app/src/images/invision.svg"));
12
-
6
+ var _Chip = _interopRequireDefault(require("./Chip.tsx"));
13
7
  describe("Chip component tests", function () {
14
8
  test("Chip renders with correct text", function () {
15
9
  var _render = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Chip["default"], {
16
- label: "Chip"
17
- })),
18
- getByText = _render.getByText;
19
-
10
+ label: "Chip"
11
+ })),
12
+ getByText = _render.getByText;
20
13
  expect(getByText("Chip")).toBeTruthy();
21
14
  });
22
15
  test("Calls correct function when clicking on prefix icon", function () {
23
16
  var onClick = jest.fn();
24
-
25
17
  var _render2 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Chip["default"], {
26
- label: "Chip",
27
- prefixIcon: _invision["default"],
28
- onClickPrefix: onClick
29
- })),
30
- getByText = _render2.getByText,
31
- getByRole = _render2.getByRole;
32
-
18
+ label: "Chip",
19
+ prefixIcon: "nutrition",
20
+ onClickPrefix: onClick
21
+ })),
22
+ getByText = _render2.getByText,
23
+ getByRole = _render2.getByRole;
33
24
  expect(getByText("Chip")).toBeTruthy();
34
-
35
- _react2.fireEvent.click(getByRole("img"));
36
-
25
+ _react2.fireEvent.click(getByRole("button"));
37
26
  expect(onClick).toHaveBeenCalled();
38
27
  });
39
28
  test("Calls correct function when clicking on suffix icon", function () {
40
29
  var onClick = jest.fn();
41
-
42
30
  var _render3 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Chip["default"], {
43
- label: "Chip",
44
- suffixIcon: _invision["default"],
45
- onClickSuffix: onClick
46
- })),
47
- getByText = _render3.getByText,
48
- getByRole = _render3.getByRole;
49
-
31
+ label: "Chip",
32
+ suffixIcon: "nutrition",
33
+ onClickSuffix: onClick
34
+ })),
35
+ getByText = _render3.getByText,
36
+ getByRole = _render3.getByRole;
50
37
  expect(getByText("Chip")).toBeTruthy();
51
-
52
- _react2.fireEvent.click(getByRole("img"));
53
-
38
+ _react2.fireEvent.click(getByRole("button"));
54
39
  expect(onClick).toHaveBeenCalled();
55
40
  });
56
41
  });
package/chip/types.d.ts CHANGED
@@ -1,13 +1,13 @@
1
1
  /// <reference types="react" />
2
- declare type Space = "xxsmall" | "xsmall" | "small" | "medium" | "large" | "xlarge" | "xxlarge";
3
- declare type Margin = {
2
+ type Space = "xxsmall" | "xsmall" | "small" | "medium" | "large" | "xlarge" | "xxlarge";
3
+ type Margin = {
4
4
  top?: Space;
5
5
  bottom?: Space;
6
6
  left?: Space;
7
7
  right?: Space;
8
8
  };
9
- declare type SVG = React.ReactNode & React.SVGProps<SVGSVGElement>;
10
- declare type Props = {
9
+ type SVG = React.ReactNode & React.SVGProps<SVGSVGElement>;
10
+ type Props = {
11
11
  /**
12
12
  * Text to be placed on the chip.
13
13
  */
@@ -0,0 +1,237 @@
1
+ /**
2
+ * Halstack Color Palette
3
+ * @link https://developer.dxc.com/halstack/next/principles/color/#color-tokens-core-color-tokens
4
+ */
5
+ declare const CoreColorTokens: {
6
+ color_black: string;
7
+ color_white: string;
8
+ color_transparent: string;
9
+ color_grey_50: string;
10
+ color_grey_100: string;
11
+ color_grey_200: string;
12
+ color_grey_300: string;
13
+ color_grey_400: string;
14
+ color_grey_500: string;
15
+ color_grey_600: string;
16
+ color_grey_700: string;
17
+ color_grey_800: string;
18
+ color_grey_900: string;
19
+ color_grey_50_a: string;
20
+ color_grey_100_a: string;
21
+ color_grey_200_a: string;
22
+ color_grey_300_a: string;
23
+ color_grey_400_a: string;
24
+ color_grey_500_a: string;
25
+ color_grey_600_a: string;
26
+ color_grey_700_a: string;
27
+ color_grey_800_a: string;
28
+ color_grey_900_a: string;
29
+ color_purple_50: string;
30
+ color_purple_100: string;
31
+ color_purple_200: string;
32
+ color_purple_300: string;
33
+ color_purple_400: string;
34
+ color_purple_500: string;
35
+ color_purple_600: string;
36
+ color_purple_700: string;
37
+ color_purple_800: string;
38
+ color_purple_900: string;
39
+ color_blue_50: string;
40
+ color_blue_100: string;
41
+ color_blue_200: string;
42
+ color_blue_300: string;
43
+ color_blue_400: string;
44
+ color_blue_500: string;
45
+ color_blue_600: string;
46
+ color_blue_700: string;
47
+ color_blue_800: string;
48
+ color_blue_900: string;
49
+ color_red_50: string;
50
+ color_red_100: string;
51
+ color_red_200: string;
52
+ color_red_300: string;
53
+ color_red_400: string;
54
+ color_red_500: string;
55
+ color_red_600: string;
56
+ color_red_700: string;
57
+ color_red_800: string;
58
+ color_red_900: string;
59
+ color_green_50: string;
60
+ color_green_100: string;
61
+ color_green_200: string;
62
+ color_green_300: string;
63
+ color_green_400: string;
64
+ color_green_500: string;
65
+ color_green_600: string;
66
+ color_green_700: string;
67
+ color_green_800: string;
68
+ color_green_900: string;
69
+ color_yellow_50: string;
70
+ color_yellow_100: string;
71
+ color_yellow_200: string;
72
+ color_yellow_300: string;
73
+ color_yellow_400: string;
74
+ color_yellow_500: string;
75
+ color_yellow_600: string;
76
+ color_yellow_700: string;
77
+ color_yellow_800: string;
78
+ color_yellow_900: string;
79
+ color_orange_50: string;
80
+ color_orange_100: string;
81
+ color_orange_200: string;
82
+ color_orange_300: string;
83
+ color_orange_400: string;
84
+ color_orange_500: string;
85
+ color_orange_600: string;
86
+ color_orange_700: string;
87
+ color_orange_800: string;
88
+ color_orange_900: string;
89
+ };
90
+ export declare const getCoreColorToken: (key: CoreColorTokens) => string;
91
+ export type CoreColorTokens = keyof typeof CoreColorTokens;
92
+ declare const CoreTokens: {
93
+ inherit: string;
94
+ type_sans: string;
95
+ type_scale_root: string;
96
+ type_scale_08: string;
97
+ type_scale_07: string;
98
+ type_scale_06: string;
99
+ type_scale_05: string;
100
+ type_scale_04: string;
101
+ type_scale_03: string;
102
+ type_scale_02: string;
103
+ type_scale_01: string;
104
+ type_light: string;
105
+ type_regular: string;
106
+ type_semibold: string;
107
+ type_bold: string;
108
+ type_italic: string;
109
+ type_normal: string;
110
+ type_spacing_tight_02: string;
111
+ type_spacing_tight_01: string;
112
+ type_spacing_normal: string;
113
+ type_spacing_wide_01: string;
114
+ type_spacing_wide_02: string;
115
+ type_spacing_wide_03: string;
116
+ type_initial: string;
117
+ type_uppercase: string;
118
+ type_no_line: string;
119
+ type_underline: string;
120
+ type_line_through: string;
121
+ type_leading_compact_03: string;
122
+ type_leading_compact_02: string;
123
+ type_leading_compact_01: string;
124
+ type_leading_normal: string;
125
+ type_leading_loose_01: string;
126
+ type_leading_loose_02: string;
127
+ border_width_0: string;
128
+ border_width_1: string;
129
+ border_width_2: string;
130
+ border_width_4: string;
131
+ border_radius_none: string;
132
+ border_radius_small: string;
133
+ border_radius_medium: string;
134
+ border_radius_large: string;
135
+ border_solid: string;
136
+ border_dashed: string;
137
+ border_none: string;
138
+ spacing_0: string;
139
+ spacing_2: string;
140
+ spacing_4: string;
141
+ spacing_8: string;
142
+ spacing_12: string;
143
+ spacing_16: string;
144
+ spacing_24: string;
145
+ spacing_32: string;
146
+ spacing_40: string;
147
+ spacing_48: string;
148
+ spacing_56: string;
149
+ spacing_64: string;
150
+ spacing_80: string;
151
+ spacing_96: string;
152
+ spacing_112: string;
153
+ color_black: string;
154
+ color_white: string;
155
+ color_transparent: string;
156
+ color_grey_50: string;
157
+ color_grey_100: string;
158
+ color_grey_200: string;
159
+ color_grey_300: string;
160
+ color_grey_400: string;
161
+ color_grey_500: string;
162
+ color_grey_600: string;
163
+ color_grey_700: string;
164
+ color_grey_800: string;
165
+ color_grey_900: string;
166
+ color_grey_50_a: string;
167
+ color_grey_100_a: string;
168
+ color_grey_200_a: string;
169
+ color_grey_300_a: string;
170
+ color_grey_400_a: string;
171
+ color_grey_500_a: string;
172
+ color_grey_600_a: string;
173
+ color_grey_700_a: string;
174
+ color_grey_800_a: string;
175
+ color_grey_900_a: string;
176
+ color_purple_50: string;
177
+ color_purple_100: string;
178
+ color_purple_200: string;
179
+ color_purple_300: string;
180
+ color_purple_400: string;
181
+ color_purple_500: string;
182
+ color_purple_600: string;
183
+ color_purple_700: string;
184
+ color_purple_800: string;
185
+ color_purple_900: string;
186
+ color_blue_50: string;
187
+ color_blue_100: string;
188
+ color_blue_200: string;
189
+ color_blue_300: string;
190
+ color_blue_400: string;
191
+ color_blue_500: string;
192
+ color_blue_600: string;
193
+ color_blue_700: string;
194
+ color_blue_800: string;
195
+ color_blue_900: string;
196
+ color_red_50: string;
197
+ color_red_100: string;
198
+ color_red_200: string;
199
+ color_red_300: string;
200
+ color_red_400: string;
201
+ color_red_500: string;
202
+ color_red_600: string;
203
+ color_red_700: string;
204
+ color_red_800: string;
205
+ color_red_900: string;
206
+ color_green_50: string;
207
+ color_green_100: string;
208
+ color_green_200: string;
209
+ color_green_300: string;
210
+ color_green_400: string;
211
+ color_green_500: string;
212
+ color_green_600: string;
213
+ color_green_700: string;
214
+ color_green_800: string;
215
+ color_green_900: string;
216
+ color_yellow_50: string;
217
+ color_yellow_100: string;
218
+ color_yellow_200: string;
219
+ color_yellow_300: string;
220
+ color_yellow_400: string;
221
+ color_yellow_500: string;
222
+ color_yellow_600: string;
223
+ color_yellow_700: string;
224
+ color_yellow_800: string;
225
+ color_yellow_900: string;
226
+ color_orange_50: string;
227
+ color_orange_100: string;
228
+ color_orange_200: string;
229
+ color_orange_300: string;
230
+ color_orange_400: string;
231
+ color_orange_500: string;
232
+ color_orange_600: string;
233
+ color_orange_700: string;
234
+ color_orange_800: string;
235
+ color_orange_900: string;
236
+ };
237
+ export default CoreTokens;