@dxc-technology/halstack-react 0.0.0-9d82cb9 → 0.0.0-9e54008

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 (307) hide show
  1. package/BackgroundColorContext.d.ts +2 -2
  2. package/BackgroundColorContext.js +1 -1
  3. package/HalstackContext.d.ts +1336 -0
  4. package/HalstackContext.js +335 -0
  5. package/accordion/Accordion.d.ts +1 -1
  6. package/accordion/Accordion.js +110 -146
  7. package/accordion/Accordion.stories.tsx +108 -118
  8. package/accordion/Accordion.test.js +71 -0
  9. package/accordion/types.d.ts +7 -18
  10. package/accordion-group/AccordionGroup.d.ts +5 -4
  11. package/accordion-group/AccordionGroup.js +34 -76
  12. package/accordion-group/AccordionGroup.stories.tsx +94 -67
  13. package/accordion-group/AccordionGroup.test.js +116 -0
  14. package/accordion-group/AccordionGroupAccordion.d.ts +4 -0
  15. package/accordion-group/AccordionGroupAccordion.js +43 -0
  16. package/accordion-group/types.d.ts +13 -18
  17. package/alert/Alert.js +9 -10
  18. package/alert/Alert.stories.tsx +28 -0
  19. package/alert/Alert.test.js +92 -0
  20. package/badge/Badge.d.ts +4 -0
  21. package/badge/Badge.js +5 -3
  22. package/badge/types.d.ts +5 -0
  23. package/bleed/Bleed.d.ts +2 -2
  24. package/bleed/Bleed.js +1 -34
  25. package/bleed/Bleed.stories.tsx +95 -95
  26. package/bleed/types.d.ts +25 -1
  27. package/box/Box.d.ts +1 -1
  28. package/box/Box.js +19 -48
  29. package/box/Box.stories.tsx +38 -51
  30. package/box/Box.test.js +18 -0
  31. package/box/types.d.ts +0 -11
  32. package/bulleted-list/BulletedList.d.ts +7 -0
  33. package/bulleted-list/BulletedList.js +125 -0
  34. package/bulleted-list/BulletedList.stories.tsx +206 -0
  35. package/bulleted-list/types.d.ts +38 -0
  36. package/bulleted-list/types.js +5 -0
  37. package/button/Button.js +52 -70
  38. package/button/Button.stories.tsx +159 -8
  39. package/button/Button.test.js +35 -0
  40. package/button/types.d.ts +5 -5
  41. package/card/Card.d.ts +1 -1
  42. package/card/Card.js +37 -58
  43. package/card/Card.stories.tsx +12 -42
  44. package/card/Card.test.js +50 -0
  45. package/card/types.d.ts +1 -6
  46. package/checkbox/Checkbox.d.ts +2 -2
  47. package/checkbox/Checkbox.js +107 -110
  48. package/checkbox/Checkbox.stories.tsx +198 -130
  49. package/checkbox/Checkbox.test.js +155 -0
  50. package/checkbox/types.d.ts +11 -3
  51. package/chip/Chip.d.ts +1 -1
  52. package/chip/Chip.js +36 -95
  53. package/chip/Chip.stories.tsx +123 -30
  54. package/chip/Chip.test.js +54 -0
  55. package/chip/types.d.ts +5 -13
  56. package/common/OpenSans.css +68 -80
  57. package/common/coreTokens.d.ts +146 -0
  58. package/common/coreTokens.js +167 -0
  59. package/common/utils.d.ts +1 -0
  60. package/common/utils.js +4 -4
  61. package/common/variables.d.ts +1482 -0
  62. package/common/variables.js +1097 -1348
  63. package/date-input/Calendar.d.ts +4 -0
  64. package/date-input/Calendar.js +258 -0
  65. package/date-input/DateInput.js +169 -258
  66. package/date-input/DateInput.stories.tsx +199 -33
  67. package/date-input/DateInput.test.js +835 -0
  68. package/date-input/DatePicker.d.ts +4 -0
  69. package/date-input/DatePicker.js +146 -0
  70. package/date-input/Icons.d.ts +6 -0
  71. package/date-input/Icons.js +75 -0
  72. package/date-input/YearPicker.d.ts +4 -0
  73. package/date-input/YearPicker.js +126 -0
  74. package/date-input/types.d.ts +67 -9
  75. package/dialog/Dialog.d.ts +1 -1
  76. package/dialog/Dialog.js +68 -103
  77. package/dialog/Dialog.stories.tsx +154 -171
  78. package/dialog/Dialog.test.js +369 -0
  79. package/dialog/types.d.ts +0 -12
  80. package/dropdown/Dropdown.d.ts +1 -1
  81. package/dropdown/Dropdown.js +248 -277
  82. package/dropdown/Dropdown.stories.tsx +255 -64
  83. package/dropdown/Dropdown.test.js +586 -0
  84. package/dropdown/DropdownMenu.d.ts +4 -0
  85. package/dropdown/DropdownMenu.js +74 -0
  86. package/dropdown/DropdownMenuItem.d.ts +4 -0
  87. package/dropdown/DropdownMenuItem.js +79 -0
  88. package/dropdown/types.d.ts +27 -16
  89. package/file-input/FileInput.d.ts +2 -2
  90. package/file-input/FileInput.js +180 -223
  91. package/file-input/FileInput.stories.tsx +122 -11
  92. package/file-input/FileInput.test.js +457 -0
  93. package/file-input/FileItem.d.ts +4 -14
  94. package/file-input/FileItem.js +44 -66
  95. package/file-input/types.d.ts +18 -1
  96. package/flex/Flex.d.ts +4 -0
  97. package/flex/Flex.js +71 -0
  98. package/flex/Flex.stories.tsx +112 -0
  99. package/flex/types.d.ts +97 -0
  100. package/flex/types.js +5 -0
  101. package/footer/Footer.d.ts +1 -1
  102. package/footer/Footer.js +26 -116
  103. package/footer/Footer.stories.tsx +26 -16
  104. package/footer/Footer.test.js +97 -0
  105. package/footer/Icons.js +1 -1
  106. package/footer/types.d.ts +1 -6
  107. package/grid/Grid.d.ts +7 -0
  108. package/grid/Grid.js +91 -0
  109. package/grid/Grid.stories.tsx +219 -0
  110. package/grid/types.d.ts +115 -0
  111. package/grid/types.js +5 -0
  112. package/header/Header.d.ts +4 -3
  113. package/header/Header.js +102 -150
  114. package/header/Header.stories.tsx +152 -63
  115. package/header/Header.test.js +79 -0
  116. package/header/Icons.js +2 -2
  117. package/header/types.d.ts +0 -13
  118. package/heading/Heading.js +1 -1
  119. package/heading/Heading.test.js +186 -0
  120. package/inset/Inset.js +1 -34
  121. package/inset/Inset.stories.tsx +37 -36
  122. package/inset/types.d.ts +25 -1
  123. package/layout/ApplicationLayout.d.ts +16 -6
  124. package/layout/ApplicationLayout.js +72 -126
  125. package/layout/ApplicationLayout.stories.tsx +84 -93
  126. package/layout/Icons.d.ts +5 -0
  127. package/layout/Icons.js +13 -2
  128. package/layout/SidenavContext.d.ts +5 -0
  129. package/layout/SidenavContext.js +19 -0
  130. package/layout/types.d.ts +19 -35
  131. package/link/Link.d.ts +3 -2
  132. package/link/Link.js +63 -88
  133. package/link/Link.stories.tsx +159 -52
  134. package/link/Link.test.js +81 -0
  135. package/link/types.d.ts +7 -27
  136. package/main.d.ts +12 -15
  137. package/main.js +57 -75
  138. package/nav-tabs/NavTabs.d.ts +8 -0
  139. package/nav-tabs/NavTabs.js +122 -0
  140. package/nav-tabs/NavTabs.stories.tsx +274 -0
  141. package/nav-tabs/NavTabs.test.js +82 -0
  142. package/nav-tabs/Tab.d.ts +4 -0
  143. package/nav-tabs/Tab.js +146 -0
  144. package/nav-tabs/types.d.ts +52 -0
  145. package/nav-tabs/types.js +5 -0
  146. package/number-input/NumberInput.js +11 -18
  147. package/number-input/NumberInput.stories.tsx +5 -5
  148. package/number-input/NumberInput.test.js +542 -0
  149. package/number-input/types.d.ts +17 -10
  150. package/package.json +20 -23
  151. package/paginator/Icons.d.ts +5 -0
  152. package/paginator/Icons.js +16 -28
  153. package/paginator/Paginator.js +20 -49
  154. package/paginator/Paginator.stories.tsx +24 -0
  155. package/paginator/Paginator.test.js +318 -0
  156. package/paragraph/Paragraph.d.ts +5 -0
  157. package/paragraph/Paragraph.js +38 -0
  158. package/paragraph/Paragraph.stories.tsx +44 -0
  159. package/password-input/PasswordInput.js +7 -4
  160. package/password-input/PasswordInput.test.js +181 -0
  161. package/password-input/types.d.ts +14 -11
  162. package/progress-bar/ProgressBar.js +61 -55
  163. package/progress-bar/ProgressBar.stories.jsx +47 -12
  164. package/progress-bar/ProgressBar.test.js +110 -0
  165. package/quick-nav/QuickNav.d.ts +4 -0
  166. package/quick-nav/QuickNav.js +117 -0
  167. package/quick-nav/QuickNav.stories.tsx +356 -0
  168. package/quick-nav/types.d.ts +21 -0
  169. package/quick-nav/types.js +5 -0
  170. package/radio-group/Radio.d.ts +1 -1
  171. package/radio-group/Radio.js +60 -34
  172. package/radio-group/RadioGroup.js +81 -68
  173. package/radio-group/RadioGroup.stories.tsx +171 -36
  174. package/radio-group/RadioGroup.test.js +722 -0
  175. package/radio-group/types.d.ts +81 -3
  176. package/resultsetTable/Icons.d.ts +7 -0
  177. package/resultsetTable/Icons.js +51 -0
  178. package/resultsetTable/ResultsetTable.js +50 -106
  179. package/resultsetTable/ResultsetTable.stories.tsx +50 -25
  180. package/resultsetTable/ResultsetTable.test.js +325 -0
  181. package/resultsetTable/types.d.ts +1 -1
  182. package/select/Icons.d.ts +10 -0
  183. package/select/Icons.js +93 -0
  184. package/select/Listbox.d.ts +4 -0
  185. package/select/Listbox.js +169 -0
  186. package/select/Option.d.ts +4 -0
  187. package/select/Option.js +97 -0
  188. package/select/Select.js +189 -386
  189. package/select/Select.stories.tsx +600 -201
  190. package/select/Select.test.js +2228 -0
  191. package/select/types.d.ts +53 -13
  192. package/sidenav/Icons.d.ts +7 -0
  193. package/sidenav/Icons.js +51 -0
  194. package/sidenav/Sidenav.d.ts +6 -5
  195. package/sidenav/Sidenav.js +146 -44
  196. package/sidenav/Sidenav.stories.tsx +251 -151
  197. package/sidenav/Sidenav.test.js +44 -0
  198. package/sidenav/types.d.ts +52 -26
  199. package/slider/Slider.d.ts +2 -2
  200. package/slider/Slider.js +123 -98
  201. package/slider/Slider.stories.tsx +72 -9
  202. package/slider/Slider.test.js +250 -0
  203. package/slider/types.d.ts +8 -0
  204. package/spinner/Spinner.js +18 -24
  205. package/spinner/Spinner.stories.jsx +53 -27
  206. package/spinner/Spinner.test.js +64 -0
  207. package/switch/Switch.d.ts +2 -2
  208. package/switch/Switch.js +152 -69
  209. package/switch/Switch.stories.tsx +53 -42
  210. package/switch/Switch.test.js +225 -0
  211. package/switch/types.d.ts +10 -2
  212. package/table/Table.js +3 -3
  213. package/table/Table.stories.jsx +80 -1
  214. package/table/Table.test.js +26 -0
  215. package/tabs/Tab.d.ts +4 -0
  216. package/tabs/Tab.js +132 -0
  217. package/tabs/Tabs.d.ts +1 -1
  218. package/tabs/Tabs.js +362 -114
  219. package/tabs/Tabs.stories.tsx +122 -18
  220. package/tabs/Tabs.test.js +350 -0
  221. package/tabs/types.d.ts +37 -15
  222. package/tag/Tag.d.ts +1 -1
  223. package/tag/Tag.js +24 -36
  224. package/tag/Tag.stories.tsx +37 -27
  225. package/tag/Tag.test.js +60 -0
  226. package/tag/types.d.ts +23 -14
  227. package/text-input/Icons.d.ts +8 -0
  228. package/text-input/Icons.js +60 -0
  229. package/text-input/Suggestion.d.ts +4 -0
  230. package/text-input/Suggestion.js +84 -0
  231. package/text-input/Suggestions.d.ts +4 -0
  232. package/text-input/Suggestions.js +134 -0
  233. package/text-input/TextInput.js +225 -346
  234. package/text-input/TextInput.stories.tsx +310 -197
  235. package/text-input/TextInput.test.js +1723 -0
  236. package/text-input/types.d.ts +50 -12
  237. package/textarea/Textarea.js +22 -30
  238. package/textarea/Textarea.stories.jsx +93 -13
  239. package/textarea/Textarea.test.js +435 -0
  240. package/textarea/types.d.ts +18 -11
  241. package/toggle-group/ToggleGroup.d.ts +2 -2
  242. package/toggle-group/ToggleGroup.js +12 -8
  243. package/toggle-group/ToggleGroup.stories.tsx +46 -4
  244. package/toggle-group/ToggleGroup.test.js +156 -0
  245. package/toggle-group/types.d.ts +10 -2
  246. package/typography/Typography.d.ts +4 -0
  247. package/typography/Typography.js +32 -0
  248. package/typography/Typography.stories.tsx +198 -0
  249. package/typography/types.d.ts +18 -0
  250. package/typography/types.js +5 -0
  251. package/useTheme.d.ts +1234 -1
  252. package/useTheme.js +3 -3
  253. package/useTranslatedLabels.d.ts +85 -0
  254. package/useTranslatedLabels.js +20 -0
  255. package/utils/BaseTypography.d.ts +21 -0
  256. package/utils/BaseTypography.js +108 -0
  257. package/utils/FocusLock.d.ts +13 -0
  258. package/utils/FocusLock.js +138 -0
  259. package/wizard/Wizard.d.ts +1 -1
  260. package/wizard/Wizard.js +59 -55
  261. package/wizard/Wizard.stories.tsx +48 -19
  262. package/wizard/Wizard.test.js +141 -0
  263. package/wizard/types.d.ts +8 -4
  264. package/ThemeContext.d.ts +0 -15
  265. package/ThemeContext.js +0 -243
  266. package/V3Select/V3Select.js +0 -455
  267. package/V3Select/index.d.ts +0 -27
  268. package/V3Textarea/V3Textarea.js +0 -260
  269. package/V3Textarea/index.d.ts +0 -27
  270. package/card/ice-cream.jpg +0 -0
  271. package/common/RequiredComponent.js +0 -32
  272. package/date/Date.js +0 -373
  273. package/date/index.d.ts +0 -27
  274. package/input-text/Icons.js +0 -22
  275. package/input-text/InputText.js +0 -611
  276. package/input-text/index.d.ts +0 -36
  277. package/list/List.d.ts +0 -8
  278. package/list/List.js +0 -47
  279. package/list/List.stories.tsx +0 -95
  280. package/radio/Radio.d.ts +0 -4
  281. package/radio/Radio.js +0 -174
  282. package/radio/Radio.stories.tsx +0 -192
  283. package/radio/types.d.ts +0 -54
  284. package/row/Row.d.ts +0 -11
  285. package/row/Row.js +0 -127
  286. package/row/Row.stories.tsx +0 -239
  287. package/stack/Stack.d.ts +0 -10
  288. package/stack/Stack.js +0 -97
  289. package/stack/Stack.stories.tsx +0 -166
  290. package/text/Text.d.ts +0 -7
  291. package/text/Text.js +0 -30
  292. package/text/Text.stories.tsx +0 -19
  293. package/toggle/Toggle.js +0 -186
  294. package/toggle/index.d.ts +0 -21
  295. package/upload/Upload.js +0 -201
  296. package/upload/buttons-upload/ButtonsUpload.js +0 -111
  297. package/upload/buttons-upload/Icons.js +0 -40
  298. package/upload/dragAndDropArea/DragAndDropArea.js +0 -225
  299. package/upload/dragAndDropArea/Icons.js +0 -39
  300. package/upload/file-upload/FileToUpload.js +0 -115
  301. package/upload/file-upload/Icons.js +0 -66
  302. package/upload/files-upload/FilesToUpload.js +0 -109
  303. package/upload/index.d.ts +0 -15
  304. package/upload/transaction/Icons.js +0 -160
  305. package/upload/transaction/Transaction.js +0 -104
  306. package/upload/transactions/Transactions.js +0 -94
  307. /package/{radio → badge}/types.js +0 -0
@@ -2,109 +2,88 @@ import React from "react";
2
2
  import Title from "../../.storybook/components/Title";
3
3
  import ExampleContainer from "../../.storybook/components/ExampleContainer";
4
4
  import DxcBox from "./Box";
5
+ import DxcInset from "../inset/Inset";
6
+ import { HalstackProvider } from "../HalstackContext";
5
7
 
6
8
  export default {
7
9
  title: "Box ",
8
10
  component: DxcBox,
9
11
  };
10
12
 
13
+ const opinionatedTheme = {
14
+ box: {
15
+ baseColor: "#ffffff",
16
+ },
17
+ };
18
+
11
19
  export const Chromatic = () => (
12
20
  <>
13
21
  <Title title="Display flex" theme="light" level={2} />
14
22
  <ExampleContainer>
15
- <DxcBox display="flex" padding="medium">
16
- Box
23
+ <DxcBox display="flex">
24
+ <DxcInset space="2rem">Box</DxcInset>
17
25
  </DxcBox>
18
26
  </ExampleContainer>
19
27
  <Title title="ShadowDepth" theme="light" level={2} />
20
28
  <ExampleContainer>
21
29
  <Title title="ShadowDepth 0" theme="light" level={4} />
22
- <DxcBox shadowDepth={0} margin="medium" padding="medium">
23
- Box
30
+ <DxcBox shadowDepth={0} margin="medium">
31
+ <DxcInset space="2rem">Box</DxcInset>
24
32
  </DxcBox>
25
33
  </ExampleContainer>
26
34
  <ExampleContainer>
27
35
  <Title title="ShadowDepth 1" theme="light" level={4} />
28
- <DxcBox shadowDepth={1} margin="medium" padding="medium">
29
- Box
36
+ <DxcBox shadowDepth={1} margin="medium">
37
+ <DxcInset space="2rem">Box</DxcInset>
30
38
  </DxcBox>
31
39
  </ExampleContainer>
32
40
  <ExampleContainer>
33
41
  <Title title="ShadowDepth 2" theme="light" level={4} />
34
- <DxcBox shadowDepth={2} margin="medium" padding="medium">
35
- Box
42
+ <DxcBox shadowDepth={2} margin="medium">
43
+ <DxcInset space="2rem">Box</DxcInset>
36
44
  </DxcBox>
37
45
  </ExampleContainer>
38
- <Title title="Paddings" theme="light" level={2} />
39
- <ExampleContainer>
40
- <Title title="Xxsmall padding" theme="light" level={4} />
41
- <DxcBox padding="xxsmall">Box</DxcBox>
42
- </ExampleContainer>
43
- <ExampleContainer>
44
- <Title title="Xsmall padding" theme="light" level={4} />
45
- <DxcBox padding="xsmall">Box</DxcBox>
46
- </ExampleContainer>
47
- <ExampleContainer>
48
- <Title title="Small padding" theme="light" level={4} />
49
- <DxcBox padding="small">Box</DxcBox>
50
- </ExampleContainer>
51
- <ExampleContainer>
52
- <Title title="Medium padding" theme="light" level={4} />
53
- <DxcBox padding="medium">Box</DxcBox>
54
- </ExampleContainer>
55
- <ExampleContainer>
56
- <Title title="Large padding" theme="light" level={4} />
57
- <DxcBox padding="large">Box</DxcBox>
58
- </ExampleContainer>
59
- <ExampleContainer>
60
- <Title title="Xlarge padding" theme="light" level={4} />
61
- <DxcBox padding="xlarge">Box</DxcBox>
62
- </ExampleContainer>
63
- <ExampleContainer>
64
- <Title title="Xxlarge padding" theme="light" level={4} />
65
- <DxcBox padding="xxlarge">Box</DxcBox>
66
- </ExampleContainer>
67
46
  <Title title="Margins" theme="light" level={2} />
68
47
  <ExampleContainer>
69
48
  <Title title="Xxsmall margin" theme="light" level={4} />
70
- <DxcBox margin="xxsmall" padding="medium">
71
- Box
49
+ <DxcBox margin="xxsmall">
50
+ <DxcInset space="2rem">Box</DxcInset>
72
51
  </DxcBox>
73
52
  </ExampleContainer>
74
53
  <ExampleContainer>
75
54
  <Title title="Xsmall margin" theme="light" level={4} />
76
- <DxcBox margin="xsmall" padding="medium">
77
- Box
55
+ <DxcBox margin="xsmall">
56
+ <DxcInset space="2rem">Box</DxcInset>
78
57
  </DxcBox>
79
58
  </ExampleContainer>
80
59
  <ExampleContainer>
81
60
  <Title title="Small margin" theme="light" level={4} />
82
- <DxcBox margin="small" padding="medium">
83
- Box
61
+ <DxcBox margin="small">
62
+ <DxcInset space="2rem">Box</DxcInset>
84
63
  </DxcBox>
85
64
  </ExampleContainer>
86
65
  <ExampleContainer>
87
66
  <Title title="Medium margin" theme="light" level={4} />
88
- <DxcBox margin="medium" padding="medium">
89
- Box
67
+ <DxcBox margin="medium">
68
+ <DxcInset space="2rem">Box</DxcInset>
90
69
  </DxcBox>
91
70
  </ExampleContainer>
92
71
  <ExampleContainer>
93
72
  <Title title="Large margin" theme="light" level={4} />
94
- <DxcBox margin="large" padding="medium">
95
- Box
73
+ <DxcBox margin="large">
74
+ <DxcInset space="2rem">Box</DxcInset>
96
75
  </DxcBox>
97
76
  </ExampleContainer>
98
77
  <ExampleContainer>
99
78
  <Title title="Xlarge margin" theme="light" level={4} />
100
- <DxcBox margin="xlarge" padding="medium">
101
- Box
79
+ <DxcBox margin="xlarge">
80
+ <DxcInset space="2rem">Box</DxcInset>
102
81
  </DxcBox>
103
82
  </ExampleContainer>
104
83
  <ExampleContainer>
105
84
  <Title title="Xxlarge margin" theme="light" level={4} />
106
- <DxcBox margin="xxlarge" padding="medium">
107
- Box
85
+ <DxcBox margin="xxlarge">
86
+ <DxcInset space="2rem">Box</DxcInset>
108
87
  </DxcBox>
109
88
  </ExampleContainer>
110
89
  <Title title="Sizes" theme="light" level={2} />
@@ -128,5 +107,13 @@ export const Chromatic = () => (
128
107
  <Title title="FitContent" theme="light" level={4} />
129
108
  <DxcBox size="fitContent">Box</DxcBox>
130
109
  </ExampleContainer>
110
+ <Title title="Opinionated theme" theme="light" level={2} />
111
+ <ExampleContainer>
112
+ <HalstackProvider theme={opinionatedTheme}>
113
+ <DxcBox display="flex">
114
+ <DxcInset space="2rem">Box</DxcInset>
115
+ </DxcBox>
116
+ </HalstackProvider>
117
+ </ExampleContainer>
131
118
  </>
132
119
  );
@@ -0,0 +1,18 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+
5
+ var _react = _interopRequireDefault(require("react"));
6
+
7
+ var _react2 = require("@testing-library/react");
8
+
9
+ var _Card = _interopRequireDefault(require("../card/Card.tsx"));
10
+
11
+ describe("Box component tests", function () {
12
+ test("Box renders with correct text", function () {
13
+ var _render = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Card["default"], null, "test-box")),
14
+ getByText = _render.getByText;
15
+
16
+ expect(getByText("test-box")).toBeTruthy();
17
+ });
18
+ });
package/box/types.d.ts CHANGED
@@ -6,12 +6,6 @@ declare type Margin = {
6
6
  left?: Space;
7
7
  right?: Space;
8
8
  };
9
- declare type Padding = {
10
- top?: Space;
11
- bottom?: Space;
12
- left?: Space;
13
- right?: Space;
14
- };
15
9
  declare type Props = {
16
10
  /**
17
11
  * The size of the shadow to be displayed around the box.
@@ -30,11 +24,6 @@ declare type Props = {
30
24
  * You can pass an object with 'top', 'bottom', 'left' and 'right' properties in order to specify different margin sizes.
31
25
  */
32
26
  margin?: Space | Margin;
33
- /**
34
- * Size of the padding to be applied to the custom area ('xxsmall' | 'xsmall' | 'small' | 'medium' | 'large' | 'xlarge' | 'xxlarge').
35
- * You can pass an object with 'top', 'bottom', 'left' and 'right' properties in order to specify different padding sizes.
36
- */
37
- padding?: Space | Padding;
38
27
  /**
39
28
  * Size of the component.
40
29
  */
@@ -0,0 +1,7 @@
1
+ /// <reference types="react" />
2
+ import BulletedListPropsType, { BulletedListItemPropsType } from "./types";
3
+ declare const DxcBulletedList: {
4
+ ({ children, type, icon }: BulletedListPropsType): JSX.Element;
5
+ Item: ({ children }: BulletedListItemPropsType) => JSX.Element;
6
+ };
7
+ export default DxcBulletedList;
@@ -0,0 +1,125 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+
5
+ var _typeof = require("@babel/runtime/helpers/typeof");
6
+
7
+ Object.defineProperty(exports, "__esModule", {
8
+ value: true
9
+ });
10
+ exports["default"] = void 0;
11
+
12
+ var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
13
+
14
+ var _react = _interopRequireWildcard(require("react"));
15
+
16
+ var _styledComponents = _interopRequireWildcard(require("styled-components"));
17
+
18
+ var _Flex = _interopRequireDefault(require("../flex/Flex"));
19
+
20
+ var _Typography = _interopRequireDefault(require("../typography/Typography"));
21
+
22
+ var _useTheme = _interopRequireDefault(require("../useTheme"));
23
+
24
+ var _BackgroundColorContext = _interopRequireDefault(require("../BackgroundColorContext"));
25
+
26
+ var _templateObject, _templateObject2, _templateObject3, _templateObject4, _templateObject5, _templateObject6, _templateObject7, _templateObject8, _templateObject9;
27
+
28
+ 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); }
29
+
30
+ function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(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; }
31
+
32
+ var BulletedListItem = function BulletedListItem(_ref) {
33
+ var children = _ref.children;
34
+ return /*#__PURE__*/_react["default"].createElement(_react["default"].Fragment, null, children);
35
+ };
36
+
37
+ var DxcBulletedList = function DxcBulletedList(_ref2) {
38
+ var children = _ref2.children,
39
+ _ref2$type = _ref2.type,
40
+ type = _ref2$type === void 0 ? "disc" : _ref2$type,
41
+ _ref2$icon = _ref2.icon,
42
+ icon = _ref2$icon === void 0 ? "" : _ref2$icon;
43
+ var colorsTheme = (0, _useTheme["default"])();
44
+ var backgroundType = (0, _react.useContext)(_BackgroundColorContext["default"]);
45
+ return /*#__PURE__*/_react["default"].createElement(_styledComponents.ThemeProvider, {
46
+ theme: colorsTheme.bulletedList
47
+ }, /*#__PURE__*/_react["default"].createElement(ListContainer, null, /*#__PURE__*/_react["default"].createElement(_Flex["default"], {
48
+ direction: "column",
49
+ as: type === "number" ? "ol" : "ul",
50
+ gap: "0.125rem"
51
+ }, _react["default"].Children.map(children, function (child, index) {
52
+ return /*#__PURE__*/_react["default"].createElement(ListItem, null, /*#__PURE__*/_react["default"].createElement(GeneralContent, null, type === "number" ? /*#__PURE__*/_react["default"].createElement(Number, null, /*#__PURE__*/_react["default"].createElement(_Typography["default"], {
53
+ color: backgroundType && backgroundType === "dark" ? colorsTheme.bulletedList.fontColorOnDark : colorsTheme.bulletedList.fontColor
54
+ }, index + 1, ".")) : type === "square" ? /*#__PURE__*/_react["default"].createElement(Bullet, null, /*#__PURE__*/_react["default"].createElement(Square, {
55
+ backgroundType: backgroundType
56
+ })) : type === "circle" ? /*#__PURE__*/_react["default"].createElement(Bullet, null, /*#__PURE__*/_react["default"].createElement(Circle, {
57
+ backgroundType: backgroundType
58
+ })) : type === "icon" ? /*#__PURE__*/_react["default"].createElement(Bullet, null, /*#__PURE__*/_react["default"].createElement(Icon, {
59
+ backgroundType: backgroundType
60
+ }, typeof icon === "string" ? /*#__PURE__*/_react["default"].createElement("img", {
61
+ src: icon
62
+ }) : icon)) : /*#__PURE__*/_react["default"].createElement(Bullet, null, /*#__PURE__*/_react["default"].createElement(Disc, {
63
+ backgroundType: backgroundType
64
+ })), /*#__PURE__*/_react["default"].createElement(_Typography["default"], {
65
+ color: backgroundType && backgroundType === "dark" ? colorsTheme.bulletedList.fontColorOnDark : colorsTheme.bulletedList.fontColor
66
+ }, child)));
67
+ }))));
68
+ };
69
+
70
+ DxcBulletedList.Item = BulletedListItem;
71
+
72
+ var ListContainer = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n ul,\n ol {\n padding: 0;\n margin: 0;\n }\n"])));
73
+
74
+ var Bullet = _styledComponents["default"].div(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n align-self: flex-start;\n align-items: center;\n height: 1.5rem;\n"])));
75
+
76
+ var GeneralContent = _styledComponents["default"].div(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n display: grid;\n grid-template-columns: auto 1fr;\n align-items: center;\n"])));
77
+
78
+ var Icon = _styledComponents["default"].div(_templateObject4 || (_templateObject4 = (0, _taggedTemplateLiteral2["default"])(["\n height: 1.5rem;\n width: auto;\n margin-right: ", ";\n align-content: center;\n color: ", ";\n svg,\n img {\n height: ", ";\n width: ", ";\n }\n"])), function (props) {
79
+ return props.theme.bulletMarginRight;
80
+ }, function (props) {
81
+ return props.backgroundType && props.backgroundType === "dark" ? props.theme.fontColorOnDark : props.theme.fontColor;
82
+ }, function (props) {
83
+ return props.theme.bulletIconHeight;
84
+ }, function (props) {
85
+ return props.theme.bulletIconWidth;
86
+ });
87
+
88
+ var Number = _styledComponents["default"].div(_templateObject5 || (_templateObject5 = (0, _taggedTemplateLiteral2["default"])(["\n user-select: none;\n margin-right: ", ";\n display: flex;\n box-sizing: border-box;\n align-self: flex-start;\n min-width: 0;\n"])), function (props) {
89
+ return props.theme.bulletMarginRight;
90
+ });
91
+
92
+ var Square = _styledComponents["default"].div(_templateObject6 || (_templateObject6 = (0, _taggedTemplateLiteral2["default"])(["\n background-color: ", ";\n height: ", ";\n width: ", ";\n margin-right: ", ";\n"])), function (props) {
93
+ return props.backgroundType && props.backgroundType === "dark" ? props.theme.fontColorOnDark : props.theme.fontColor;
94
+ }, function (props) {
95
+ return props.theme.bulletHeight;
96
+ }, function (props) {
97
+ return props.theme.bulletWidth;
98
+ }, function (props) {
99
+ return props.theme.bulletMarginRight;
100
+ });
101
+
102
+ var Circle = _styledComponents["default"].div(_templateObject7 || (_templateObject7 = (0, _taggedTemplateLiteral2["default"])(["\n height: ", ";\n width: ", ";\n border-radius: 50%;\n border: 1px solid;\n border-color: ", ";\n margin-right: ", ";\n"])), function (props) {
103
+ return props.theme.bulletHeight;
104
+ }, function (props) {
105
+ return props.theme.bulletWidth;
106
+ }, function (props) {
107
+ return props.backgroundType && props.backgroundType === "dark" ? props.theme.fontColorOnDark : props.theme.fontColor;
108
+ }, function (props) {
109
+ return props.theme.bulletMarginRight;
110
+ });
111
+
112
+ var Disc = _styledComponents["default"].div(_templateObject8 || (_templateObject8 = (0, _taggedTemplateLiteral2["default"])(["\n background-color: ", ";\n height: ", ";\n width: ", ";\n border-radius: 50%;\n margin-right: ", ";\n"])), function (props) {
113
+ return props.backgroundType && props.backgroundType === "dark" ? props.theme.fontColorOnDark : props.theme.fontColor;
114
+ }, function (props) {
115
+ return props.theme.bulletHeight;
116
+ }, function (props) {
117
+ return props.theme.bulletWidth;
118
+ }, function (props) {
119
+ return props.theme.bulletMarginRight;
120
+ });
121
+
122
+ var ListItem = _styledComponents["default"].li(_templateObject9 || (_templateObject9 = (0, _taggedTemplateLiteral2["default"])(["\n margin: 0px;\n padding: 0px;\n list-style: none;\n display: flex;\n font-size: 1em;\n"])));
123
+
124
+ var _default = DxcBulletedList;
125
+ exports["default"] = _default;
@@ -0,0 +1,206 @@
1
+ import React from "react";
2
+ import styled from "styled-components";
3
+ import Title from "../../.storybook/components/Title";
4
+ import { BackgroundColorProvider } from "../BackgroundColorContext";
5
+ import ExampleContainer from "../../.storybook/components/ExampleContainer";
6
+ import DxcBulletedList from "./BulletedList";
7
+
8
+ export default {
9
+ title: "BulletedList",
10
+ component: DxcBulletedList,
11
+ };
12
+
13
+ const icon = (
14
+ <svg xmlns="http://www.w3.org/2000/svg" height="24px" viewBox="0 0 24 24" width="24px" fill="currentColor">
15
+ <path d="M0 0h24v24H0V0z" fill="none" />
16
+ <path d="M16 1H4c-1.1 0-2 .9-2 2v14h2V3h12V1zm3 4H8c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h11c1.1 0 2-.9 2-2V7c0-1.1-.9-2-2-2zm0 16H8V7h11v14z" />
17
+ </svg>
18
+ );
19
+
20
+ export const Chromatic = () => (
21
+ <>
22
+ <ExampleContainer>
23
+ <Title title="Icon list (SVG)" level={4} />
24
+ <DxcBulletedList type="icon" icon={icon}>
25
+ <DxcBulletedList.Item>Code</DxcBulletedList.Item>
26
+ <DxcBulletedList.Item>Usage</DxcBulletedList.Item>
27
+ <DxcBulletedList.Item>Specifications</DxcBulletedList.Item>
28
+ </DxcBulletedList>
29
+ <Title title="Icon list (path)" level={4} />
30
+ <DxcBulletedList type="icon" icon="https://upload.wikimedia.org/wikipedia/commons/e/e0/Check_green_icon.svg">
31
+ <DxcBulletedList.Item>Code</DxcBulletedList.Item>
32
+ <DxcBulletedList.Item>Usage</DxcBulletedList.Item>
33
+ <DxcBulletedList.Item>Specifications</DxcBulletedList.Item>
34
+ </DxcBulletedList>
35
+ <Title title="Number list" level={4} />
36
+ <DxcBulletedList type="number">
37
+ <DxcBulletedList.Item>Code</DxcBulletedList.Item>
38
+ <DxcBulletedList.Item>Usage</DxcBulletedList.Item>
39
+ <DxcBulletedList.Item>Specifications</DxcBulletedList.Item>
40
+ </DxcBulletedList>
41
+ <Title title="Square" level={4} />
42
+ <DxcBulletedList type="square">
43
+ <DxcBulletedList.Item>Code</DxcBulletedList.Item>
44
+ <DxcBulletedList.Item>Usage</DxcBulletedList.Item>
45
+ <DxcBulletedList.Item>Specifications</DxcBulletedList.Item>
46
+ </DxcBulletedList>
47
+ <Title title="Circle" level={4} />
48
+ <DxcBulletedList type="circle">
49
+ <DxcBulletedList.Item>Code</DxcBulletedList.Item>
50
+ <DxcBulletedList.Item>Usage</DxcBulletedList.Item>
51
+ <DxcBulletedList.Item>Specifications</DxcBulletedList.Item>
52
+ </DxcBulletedList>
53
+ <Title title="Disc" level={4} />
54
+ <DxcBulletedList>
55
+ <DxcBulletedList.Item>Code</DxcBulletedList.Item>
56
+ <DxcBulletedList.Item>Usage</DxcBulletedList.Item>
57
+ <DxcBulletedList.Item>Specifications</DxcBulletedList.Item>
58
+ </DxcBulletedList>
59
+ <Title title="Multiple lines" level={4} />
60
+ <Container>
61
+ <Title title="Number" level={4} />
62
+ <DxcBulletedList type="number">
63
+ <DxcBulletedList.Item>
64
+ Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et
65
+ dolore magna aliqua.
66
+ </DxcBulletedList.Item>
67
+ <DxcBulletedList.Item>Text 2.</DxcBulletedList.Item>
68
+ </DxcBulletedList>
69
+ </Container>
70
+ <Container>
71
+ <Title title="Square" level={4} />
72
+ <DxcBulletedList type="square">
73
+ <DxcBulletedList.Item>
74
+ Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et
75
+ dolore magna aliqua.
76
+ </DxcBulletedList.Item>
77
+ <DxcBulletedList.Item>Text 2.</DxcBulletedList.Item>
78
+ </DxcBulletedList>
79
+ </Container>
80
+ <Container>
81
+ <Title title="Circle" level={4} />
82
+ <DxcBulletedList type="circle">
83
+ <DxcBulletedList.Item>
84
+ Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et
85
+ dolore magna aliqua.
86
+ </DxcBulletedList.Item>
87
+ <DxcBulletedList.Item>Text 2.</DxcBulletedList.Item>
88
+ </DxcBulletedList>
89
+ </Container>
90
+ <Title title="Disc" level={4} />
91
+ <Container>
92
+ <DxcBulletedList>
93
+ <DxcBulletedList.Item>
94
+ Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et
95
+ dolore magna aliqua.
96
+ </DxcBulletedList.Item>
97
+ <DxcBulletedList.Item>Text 2.</DxcBulletedList.Item>
98
+ </DxcBulletedList>
99
+ </Container>
100
+ <Container>
101
+ <Title title="Icon" level={4} />
102
+ <DxcBulletedList type="icon" icon={icon}>
103
+ <DxcBulletedList.Item>
104
+ Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et
105
+ dolore magna aliqua.
106
+ </DxcBulletedList.Item>
107
+ <DxcBulletedList.Item>Text 2.</DxcBulletedList.Item>
108
+ </DxcBulletedList>
109
+ </Container>
110
+ </ExampleContainer>
111
+ <BackgroundColorProvider color="#333333">
112
+ <DarkContainerForBulletedList>
113
+ <Title title="Icon list" theme="dark" level={4} />
114
+ <DxcBulletedList type="icon" icon={icon}>
115
+ <DxcBulletedList.Item>Code</DxcBulletedList.Item>
116
+ <DxcBulletedList.Item>Usage</DxcBulletedList.Item>
117
+ <DxcBulletedList.Item>Specifications</DxcBulletedList.Item>
118
+ </DxcBulletedList>
119
+ <Title title="Number list" theme="dark" level={4} />
120
+ <DxcBulletedList type="number">
121
+ <DxcBulletedList.Item>Code</DxcBulletedList.Item>
122
+ <DxcBulletedList.Item>Usage</DxcBulletedList.Item>
123
+ <DxcBulletedList.Item>Specifications</DxcBulletedList.Item>
124
+ </DxcBulletedList>
125
+ <Title title="Square" theme="dark" level={4} />
126
+ <DxcBulletedList type="square">
127
+ <DxcBulletedList.Item>Code</DxcBulletedList.Item>
128
+ <DxcBulletedList.Item>Usage</DxcBulletedList.Item>
129
+ <DxcBulletedList.Item>Specifications</DxcBulletedList.Item>
130
+ </DxcBulletedList>
131
+ <Title title="Circle" theme="dark" level={4} />
132
+ <DxcBulletedList type="circle">
133
+ <DxcBulletedList.Item>Code</DxcBulletedList.Item>
134
+ <DxcBulletedList.Item>Usage</DxcBulletedList.Item>
135
+ <DxcBulletedList.Item>Specifications</DxcBulletedList.Item>
136
+ </DxcBulletedList>
137
+ <Title title="Disc" theme="dark" level={4} />
138
+ <DxcBulletedList>
139
+ <DxcBulletedList.Item>Code</DxcBulletedList.Item>
140
+ <DxcBulletedList.Item>Usage</DxcBulletedList.Item>
141
+ <DxcBulletedList.Item>Specifications</DxcBulletedList.Item>
142
+ </DxcBulletedList>
143
+ <Title title="Multiple lines" theme="dark" level={4} />
144
+ <Container>
145
+ <Title title="Number" theme="dark" level={4} />
146
+ <DxcBulletedList type="number">
147
+ <DxcBulletedList.Item>
148
+ Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et
149
+ dolore magna aliqua.
150
+ </DxcBulletedList.Item>
151
+ <DxcBulletedList.Item>Text 2.</DxcBulletedList.Item>
152
+ </DxcBulletedList>
153
+ </Container>
154
+ <Container>
155
+ <Title title="Square" theme="dark" level={4} />
156
+ <DxcBulletedList type="square">
157
+ <DxcBulletedList.Item>
158
+ Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et
159
+ dolore magna aliqua.
160
+ </DxcBulletedList.Item>
161
+ <DxcBulletedList.Item>Text 2.</DxcBulletedList.Item>
162
+ </DxcBulletedList>
163
+ </Container>
164
+ <Container>
165
+ <Title title="Circle" theme="dark" level={4} />
166
+ <DxcBulletedList type="circle">
167
+ <DxcBulletedList.Item>
168
+ Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et
169
+ dolore magna aliqua.
170
+ </DxcBulletedList.Item>
171
+ <DxcBulletedList.Item>Text 2.</DxcBulletedList.Item>
172
+ </DxcBulletedList>
173
+ </Container>
174
+ <Title title="Disc" theme="dark" level={4} />
175
+ <Container>
176
+ <DxcBulletedList>
177
+ <DxcBulletedList.Item>
178
+ Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et
179
+ dolore magna aliqua.
180
+ </DxcBulletedList.Item>
181
+ <DxcBulletedList.Item>Text 2.</DxcBulletedList.Item>
182
+ </DxcBulletedList>
183
+ </Container>
184
+ <Container>
185
+ <Title title="Icon" theme="dark" level={4} />
186
+ <DxcBulletedList type="icon" icon={icon}>
187
+ <DxcBulletedList.Item>
188
+ Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et
189
+ dolore magna aliqua.
190
+ </DxcBulletedList.Item>
191
+ <DxcBulletedList.Item>Text 2.</DxcBulletedList.Item>
192
+ </DxcBulletedList>
193
+ </Container>
194
+ </DarkContainerForBulletedList>
195
+ </BackgroundColorProvider>
196
+ </>
197
+ );
198
+
199
+ const Container = styled.div`
200
+ width: 400px;
201
+ `;
202
+
203
+ const DarkContainerForBulletedList = styled.div`
204
+ background-color: #333333;
205
+ padding: 5px;
206
+ `;
@@ -0,0 +1,38 @@
1
+ /// <reference types="react" />
2
+ declare type SVG = React.ReactNode & React.SVGProps<SVGSVGElement>;
3
+ declare type IconProps = {
4
+ /**
5
+ * Defines the style of the bullet point in the list.
6
+ */
7
+ type: "icon";
8
+ /**
9
+ * Icon to display as bullet.
10
+ */
11
+ icon: string | SVG;
12
+ /**
13
+ * Text to be shown in the list.
14
+ */
15
+ children: React.ReactNode;
16
+ };
17
+ declare type OtherProps = {
18
+ /**
19
+ * Defines the style of the bullet point in the list.
20
+ */
21
+ type?: "disc" | "circle" | "square" | "number";
22
+ /**
23
+ * Icon to display as bullet.
24
+ */
25
+ icon?: never;
26
+ /**
27
+ * Text to be shown in the list.
28
+ */
29
+ children: React.ReactNode;
30
+ };
31
+ declare type Props = IconProps | OtherProps;
32
+ export default Props;
33
+ export declare type BulletedListItemPropsType = {
34
+ /**
35
+ * Text to be shown in the list.
36
+ */
37
+ children?: React.ReactNode;
38
+ };
@@ -0,0 +1,5 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });