@dxc-technology/halstack-react 0.0.0-da4b2be → 0.0.0-da9270d

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 (236) hide show
  1. package/BackgroundColorContext.d.ts +1 -10
  2. package/BackgroundColorContext.js +4 -21
  3. package/HalstackContext.d.ts +23 -124
  4. package/HalstackContext.js +10 -35
  5. package/README.md +47 -0
  6. package/accordion/Accordion.d.ts +1 -1
  7. package/accordion/Accordion.js +24 -76
  8. package/accordion/Accordion.stories.tsx +1 -113
  9. package/accordion/Accordion.test.js +18 -33
  10. package/accordion/types.d.ts +5 -17
  11. package/accordion-group/AccordionGroup.js +15 -42
  12. package/accordion-group/AccordionGroup.stories.tsx +78 -77
  13. package/accordion-group/AccordionGroup.test.js +43 -71
  14. package/accordion-group/AccordionGroupAccordion.js +9 -21
  15. package/accordion-group/types.d.ts +6 -18
  16. package/alert/Alert.js +15 -50
  17. package/alert/Alert.test.js +28 -45
  18. package/alert/types.d.ts +5 -5
  19. package/badge/Badge.js +4 -17
  20. package/badge/types.d.ts +1 -1
  21. package/bleed/Bleed.js +13 -21
  22. package/bleed/types.d.ts +2 -2
  23. package/box/Box.js +11 -33
  24. package/box/Box.test.js +1 -6
  25. package/box/types.d.ts +3 -3
  26. package/bulleted-list/BulletedList.js +18 -54
  27. package/bulleted-list/BulletedList.stories.tsx +1 -92
  28. package/bulleted-list/types.d.ts +5 -5
  29. package/button/Button.d.ts +1 -1
  30. package/button/Button.js +66 -99
  31. package/button/Button.stories.tsx +6 -87
  32. package/button/Button.test.js +17 -16
  33. package/button/types.d.ts +8 -4
  34. package/card/Card.d.ts +1 -1
  35. package/card/Card.js +39 -79
  36. package/card/Card.stories.tsx +0 -29
  37. package/card/Card.test.js +10 -21
  38. package/card/types.d.ts +6 -12
  39. package/checkbox/Checkbox.js +85 -120
  40. package/checkbox/Checkbox.stories.tsx +16 -54
  41. package/checkbox/Checkbox.test.js +107 -63
  42. package/checkbox/types.d.ts +8 -4
  43. package/chip/Chip.js +12 -31
  44. package/chip/Chip.stories.tsx +1 -1
  45. package/chip/Chip.test.js +15 -28
  46. package/chip/types.d.ts +4 -4
  47. package/common/coreTokens.d.ts +105 -14
  48. package/common/coreTokens.js +41 -24
  49. package/common/utils.js +2 -8
  50. package/common/variables.d.ts +23 -124
  51. package/common/variables.js +27 -135
  52. package/container/Container.d.ts +4 -0
  53. package/container/Container.js +194 -0
  54. package/container/Container.stories.tsx +214 -0
  55. package/container/types.d.ts +74 -0
  56. package/date-input/Calendar.js +15 -59
  57. package/date-input/DateInput.js +50 -96
  58. package/date-input/DateInput.stories.tsx +11 -30
  59. package/date-input/DateInput.test.js +674 -701
  60. package/date-input/DatePicker.js +11 -42
  61. package/date-input/Icons.d.ts +6 -6
  62. package/date-input/Icons.js +6 -23
  63. package/date-input/YearPicker.js +8 -34
  64. package/date-input/types.d.ts +27 -21
  65. package/dialog/Dialog.js +13 -40
  66. package/dialog/Dialog.stories.tsx +170 -0
  67. package/dialog/Dialog.test.js +125 -187
  68. package/dialog/types.d.ts +18 -13
  69. package/dropdown/Dropdown.js +39 -93
  70. package/dropdown/Dropdown.test.js +391 -378
  71. package/dropdown/DropdownMenu.js +8 -19
  72. package/dropdown/DropdownMenuItem.js +5 -17
  73. package/dropdown/types.d.ts +17 -19
  74. package/file-input/FileInput.js +180 -248
  75. package/file-input/FileInput.stories.tsx +1 -1
  76. package/file-input/FileInput.test.js +356 -354
  77. package/file-input/FileItem.js +14 -41
  78. package/file-input/types.d.ts +10 -10
  79. package/flex/Flex.js +25 -39
  80. package/flex/types.d.ts +6 -6
  81. package/footer/Footer.d.ts +1 -1
  82. package/footer/Footer.js +54 -112
  83. package/footer/Footer.stories.tsx +19 -95
  84. package/footer/Footer.test.js +21 -33
  85. package/footer/Icons.d.ts +2 -2
  86. package/footer/Icons.js +2 -7
  87. package/footer/types.d.ts +21 -29
  88. package/grid/Grid.d.ts +1 -1
  89. package/grid/Grid.js +2 -17
  90. package/grid/Grid.stories.tsx +38 -38
  91. package/grid/types.d.ts +10 -10
  92. package/header/Header.d.ts +2 -2
  93. package/header/Header.js +31 -114
  94. package/header/Header.stories.tsx +7 -71
  95. package/header/Header.test.js +12 -25
  96. package/header/Icons.d.ts +2 -2
  97. package/header/Icons.js +2 -7
  98. package/header/types.d.ts +5 -20
  99. package/heading/Heading.js +9 -31
  100. package/heading/Heading.test.js +70 -87
  101. package/heading/types.d.ts +7 -7
  102. package/image/Image.d.ts +4 -0
  103. package/image/Image.js +70 -0
  104. package/image/Image.stories.tsx +127 -0
  105. package/image/types.d.ts +72 -0
  106. package/inset/Inset.js +13 -21
  107. package/inset/types.d.ts +2 -2
  108. package/layout/ApplicationLayout.d.ts +3 -3
  109. package/layout/ApplicationLayout.js +28 -65
  110. package/layout/ApplicationLayout.stories.tsx +1 -1
  111. package/layout/Icons.d.ts +8 -5
  112. package/layout/Icons.js +51 -59
  113. package/layout/SidenavContext.d.ts +1 -1
  114. package/layout/SidenavContext.js +3 -9
  115. package/layout/types.d.ts +3 -3
  116. package/link/Link.js +21 -42
  117. package/link/Link.test.js +23 -41
  118. package/link/types.d.ts +14 -14
  119. package/main.d.ts +4 -3
  120. package/main.js +17 -58
  121. package/nav-tabs/NavTabs.js +11 -43
  122. package/nav-tabs/NavTabs.stories.tsx +1 -1
  123. package/nav-tabs/NavTabs.test.js +36 -43
  124. package/nav-tabs/Tab.js +16 -45
  125. package/nav-tabs/types.d.ts +9 -9
  126. package/number-input/NumberInput.d.ts +7 -0
  127. package/number-input/NumberInput.js +26 -35
  128. package/number-input/NumberInput.stories.tsx +42 -26
  129. package/number-input/NumberInput.test.js +700 -412
  130. package/number-input/types.d.ts +11 -5
  131. package/package.json +30 -28
  132. package/paginator/Icons.d.ts +5 -5
  133. package/paginator/Icons.js +5 -19
  134. package/paginator/Paginator.js +15 -43
  135. package/paginator/Paginator.test.js +224 -207
  136. package/paginator/types.d.ts +3 -3
  137. package/paragraph/Paragraph.js +3 -19
  138. package/paragraph/Paragraph.stories.tsx +0 -17
  139. package/password-input/Icons.d.ts +6 -0
  140. package/password-input/Icons.js +35 -0
  141. package/password-input/PasswordInput.js +57 -126
  142. package/password-input/PasswordInput.stories.tsx +1 -33
  143. package/password-input/PasswordInput.test.js +157 -140
  144. package/password-input/types.d.ts +8 -7
  145. package/progress-bar/ProgressBar.js +21 -53
  146. package/progress-bar/{ProgressBar.stories.jsx → ProgressBar.stories.tsx} +1 -1
  147. package/progress-bar/ProgressBar.test.js +35 -52
  148. package/progress-bar/types.d.ts +3 -3
  149. package/quick-nav/QuickNav.js +4 -27
  150. package/quick-nav/QuickNav.stories.tsx +1 -1
  151. package/quick-nav/types.d.ts +10 -10
  152. package/radio-group/Radio.d.ts +1 -1
  153. package/radio-group/Radio.js +22 -54
  154. package/radio-group/RadioGroup.js +37 -83
  155. package/radio-group/RadioGroup.stories.tsx +10 -10
  156. package/radio-group/RadioGroup.test.js +504 -470
  157. package/radio-group/types.d.ts +8 -8
  158. package/resultset-table/Icons.d.ts +7 -0
  159. package/{resultsetTable → resultset-table}/Icons.js +1 -5
  160. package/{resultsetTable → resultset-table}/ResultsetTable.js +23 -59
  161. package/{resultsetTable → resultset-table}/ResultsetTable.test.js +72 -92
  162. package/{resultsetTable → resultset-table}/types.d.ts +7 -7
  163. package/resultset-table/types.js +5 -0
  164. package/select/Icons.d.ts +7 -7
  165. package/select/Icons.js +1 -5
  166. package/select/Listbox.js +13 -39
  167. package/select/Option.js +9 -26
  168. package/select/Select.js +70 -155
  169. package/select/Select.stories.tsx +3 -3
  170. package/select/Select.test.js +1946 -1804
  171. package/select/types.d.ts +14 -15
  172. package/sidenav/Icons.d.ts +4 -4
  173. package/sidenav/Icons.js +1 -5
  174. package/sidenav/Sidenav.js +26 -68
  175. package/sidenav/Sidenav.test.js +3 -10
  176. package/sidenav/types.d.ts +18 -18
  177. package/slider/Slider.js +68 -125
  178. package/slider/Slider.test.js +107 -103
  179. package/slider/types.d.ts +4 -4
  180. package/spinner/Spinner.js +16 -54
  181. package/spinner/Spinner.test.js +25 -34
  182. package/spinner/types.d.ts +3 -3
  183. package/switch/Switch.js +49 -97
  184. package/switch/Switch.stories.tsx +0 -34
  185. package/switch/Switch.test.js +51 -96
  186. package/switch/types.d.ts +4 -4
  187. package/table/Table.js +5 -27
  188. package/table/Table.test.js +1 -6
  189. package/table/types.d.ts +8 -8
  190. package/tabs/Tab.js +10 -29
  191. package/tabs/Tabs.js +52 -129
  192. package/tabs/Tabs.test.js +62 -118
  193. package/tabs/types.d.ts +19 -19
  194. package/tag/Tag.js +21 -51
  195. package/tag/Tag.test.js +19 -30
  196. package/tag/types.d.ts +7 -7
  197. package/text-input/Icons.d.ts +5 -5
  198. package/text-input/Icons.js +1 -5
  199. package/text-input/Suggestion.js +9 -26
  200. package/text-input/Suggestions.d.ts +1 -1
  201. package/text-input/Suggestions.js +15 -65
  202. package/text-input/TextInput.js +204 -284
  203. package/text-input/TextInput.stories.tsx +48 -152
  204. package/text-input/TextInput.test.js +1210 -1194
  205. package/text-input/types.d.ts +25 -17
  206. package/textarea/Textarea.js +67 -109
  207. package/textarea/{Textarea.stories.jsx → Textarea.stories.tsx} +58 -100
  208. package/textarea/Textarea.test.js +150 -179
  209. package/textarea/types.d.ts +9 -5
  210. package/toggle-group/ToggleGroup.js +90 -107
  211. package/toggle-group/ToggleGroup.stories.tsx +7 -4
  212. package/toggle-group/ToggleGroup.test.js +68 -87
  213. package/toggle-group/types.d.ts +26 -17
  214. package/typography/Typography.js +4 -13
  215. package/typography/types.d.ts +1 -1
  216. package/useTheme.d.ts +20 -121
  217. package/useTheme.js +1 -8
  218. package/useTranslatedLabels.js +1 -7
  219. package/utils/BaseTypography.d.ts +2 -2
  220. package/utils/BaseTypography.js +16 -30
  221. package/utils/FocusLock.js +22 -39
  222. package/wizard/Wizard.js +14 -49
  223. package/wizard/Wizard.test.js +53 -80
  224. package/wizard/types.d.ts +6 -6
  225. package/card/ice-cream.jpg +0 -0
  226. package/number-input/NumberInputContext.d.ts +0 -4
  227. package/number-input/NumberInputContext.js +0 -19
  228. package/number-input/numberInputContextTypes.d.ts +0 -19
  229. package/resultsetTable/Icons.d.ts +0 -7
  230. package/slider/Slider.stories.tsx +0 -240
  231. /package/{resultsetTable → container}/types.js +0 -0
  232. /package/{number-input/numberInputContextTypes.js → image/types.js} +0 -0
  233. /package/{resultsetTable → resultset-table}/ResultsetTable.d.ts +0 -0
  234. /package/{resultsetTable → resultset-table}/ResultsetTable.stories.tsx +0 -0
  235. /package/spinner/{Spinner.stories.jsx → Spinner.stories.tsx} +0 -0
  236. /package/table/{Table.stories.jsx → Table.stories.tsx} +0 -0
@@ -0,0 +1,194 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+ Object.defineProperty(exports, "__esModule", {
5
+ value: true
6
+ });
7
+ exports["default"] = void 0;
8
+ var _typeof2 = _interopRequireDefault(require("@babel/runtime/helpers/typeof"));
9
+ var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
10
+ var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
11
+ var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties"));
12
+ var _react = _interopRequireDefault(require("react"));
13
+ var _styledComponents = _interopRequireDefault(require("styled-components"));
14
+ var _coreTokens = require("../common/coreTokens");
15
+ var _templateObject;
16
+ var _excluded = ["display", "width", "height", "overflow"];
17
+ /**
18
+ * This values correspond to the spaces defined in the design system
19
+ * https://developer.dxc.com/halstack/next/principles/spacing/#component-spacing-tokens
20
+ */
21
+ var spaces = {
22
+ xxsmall: "4px",
23
+ xsmall: "8px",
24
+ small: "12px",
25
+ medium: "16px",
26
+ large: "24px",
27
+ xlarge: "32px",
28
+ xxlarge: "48px"
29
+ };
30
+ var DxcContainer = function DxcContainer(_ref) {
31
+ var display = _ref.display,
32
+ width = _ref.width,
33
+ height = _ref.height,
34
+ overflow = _ref.overflow,
35
+ props = (0, _objectWithoutProperties2["default"])(_ref, _excluded);
36
+ return /*#__PURE__*/_react["default"].createElement(Container, (0, _extends2["default"])({
37
+ $display: display,
38
+ $width: width,
39
+ $height: height,
40
+ $overflow: overflow
41
+ }, props));
42
+ };
43
+ var getBorderStyles = function getBorderStyles(direction, borderProperties) {
44
+ var _borderProperties$wid, _borderProperties$sty, _getCoreColorToken;
45
+ return "border-".concat(direction, ": ").concat((_borderProperties$wid = borderProperties === null || borderProperties === void 0 ? void 0 : borderProperties.width) !== null && _borderProperties$wid !== void 0 ? _borderProperties$wid : "", " ").concat((_borderProperties$sty = borderProperties === null || borderProperties === void 0 ? void 0 : borderProperties.style) !== null && _borderProperties$sty !== void 0 ? _borderProperties$sty : "", " ").concat((_getCoreColorToken = (0, _coreTokens.getCoreColorToken)(borderProperties === null || borderProperties === void 0 ? void 0 : borderProperties.color)) !== null && _getCoreColorToken !== void 0 ? _getCoreColorToken : "", ";");
46
+ };
47
+ var Container = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n box-sizing: ", ";\n display: ", ";\n width: ", ";\n height: ", ";\n max-width: ", ";\n max-height: ", ";\n min-width: ", ";\n min-height: ", ";\n position: ", ";\n top: ", ";\n right: ", ";\n bottom: ", ";\n left: ", ";\n float: ", ";\n z-index: ", ";\n box-shadow: ", ";\n\n background-attachment: ", ";\n background-clip: ", ";\n background-color: ", ";\n background-image: ", ";\n background-origin: ", ";\n background-position: ", ";\n background-repeat: ", ";\n background-size: ", ";\n\n border-radius: ", ";\n border-width: ", ";\n border-style: ", ";\n border-width: ", ";\n\n ", ";\n\n margin: ", ";\n margin-top: ", ";\n margin-right: ", ";\n margin-bottom: ", ";\n margin-left: ", ";\n\n outline: ", ";\n outline-offset: ", ";\n\n overflow: ", ";\n overflow-x: ", ";\n overflow-y: ", ";\n\n padding: ", ";\n padding-top: ", ";\n padding-right: ", ";\n padding-bottom: ", ";\n padding-left: ", ";\n"])), function (_ref2) {
48
+ var boxSizing = _ref2.boxSizing;
49
+ return boxSizing;
50
+ }, function (_ref3) {
51
+ var $display = _ref3.$display;
52
+ return $display;
53
+ }, function (_ref4) {
54
+ var $width = _ref4.$width;
55
+ return $width;
56
+ }, function (_ref5) {
57
+ var $height = _ref5.$height;
58
+ return $height;
59
+ }, function (_ref6) {
60
+ var maxWidth = _ref6.maxWidth;
61
+ return maxWidth;
62
+ }, function (_ref7) {
63
+ var maxHeight = _ref7.maxHeight;
64
+ return maxHeight;
65
+ }, function (_ref8) {
66
+ var minWidth = _ref8.minWidth;
67
+ return minWidth;
68
+ }, function (_ref9) {
69
+ var minHeight = _ref9.minHeight;
70
+ return minHeight;
71
+ }, function (_ref10) {
72
+ var position = _ref10.position;
73
+ return position;
74
+ }, function (_ref11) {
75
+ var inset = _ref11.inset;
76
+ return inset === null || inset === void 0 ? void 0 : inset.top;
77
+ }, function (_ref12) {
78
+ var inset = _ref12.inset;
79
+ return inset === null || inset === void 0 ? void 0 : inset.right;
80
+ }, function (_ref13) {
81
+ var inset = _ref13.inset;
82
+ return inset === null || inset === void 0 ? void 0 : inset.bottom;
83
+ }, function (_ref14) {
84
+ var inset = _ref14.inset;
85
+ return inset === null || inset === void 0 ? void 0 : inset.left;
86
+ }, function (_ref15) {
87
+ var _float = _ref15["float"];
88
+ return _float;
89
+ }, function (_ref16) {
90
+ var zIndex = _ref16.zIndex;
91
+ return zIndex;
92
+ }, function (_ref17) {
93
+ var boxShadow = _ref17.boxShadow;
94
+ return boxShadow;
95
+ }, function (_ref18) {
96
+ var background = _ref18.background;
97
+ return background === null || background === void 0 ? void 0 : background.attachment;
98
+ }, function (_ref19) {
99
+ var background = _ref19.background;
100
+ return background === null || background === void 0 ? void 0 : background.clip;
101
+ }, function (_ref20) {
102
+ var background = _ref20.background;
103
+ return (0, _coreTokens.getCoreColorToken)(background === null || background === void 0 ? void 0 : background.color);
104
+ }, function (_ref21) {
105
+ var background = _ref21.background;
106
+ return background === null || background === void 0 ? void 0 : background.image;
107
+ }, function (_ref22) {
108
+ var background = _ref22.background;
109
+ return background === null || background === void 0 ? void 0 : background.origin;
110
+ }, function (_ref23) {
111
+ var background = _ref23.background;
112
+ return background === null || background === void 0 ? void 0 : background.position;
113
+ }, function (_ref24) {
114
+ var background = _ref24.background;
115
+ return background === null || background === void 0 ? void 0 : background.repeat;
116
+ }, function (_ref25) {
117
+ var background = _ref25.background;
118
+ return background === null || background === void 0 ? void 0 : background.size;
119
+ }, function (_ref26) {
120
+ var borderRadius = _ref26.borderRadius;
121
+ return borderRadius;
122
+ }, function (_ref27) {
123
+ var border = _ref27.border;
124
+ return border && "width" in border ? "".concat(border === null || border === void 0 ? void 0 : border.width) : "";
125
+ }, function (_ref28) {
126
+ var border = _ref28.border;
127
+ return border && "style" in border ? "".concat(border === null || border === void 0 ? void 0 : border.style) : "";
128
+ }, function (_ref29) {
129
+ var border = _ref29.border;
130
+ return border && "color" in border ? "".concat((0, _coreTokens.getCoreColorToken)(border === null || border === void 0 ? void 0 : border.color)) : "";
131
+ }, function (_ref30) {
132
+ var border = _ref30.border;
133
+ if (border != null) {
134
+ var styles = "";
135
+ switch (true) {
136
+ case "top" in border:
137
+ styles += getBorderStyles("top", border.top);
138
+ case "right" in border:
139
+ styles += getBorderStyles("right", border.right);
140
+ case "left" in border:
141
+ styles += getBorderStyles("left", border.left);
142
+ case "bottom" in border:
143
+ styles += getBorderStyles("bottom", border.bottom);
144
+ }
145
+ return styles;
146
+ }
147
+ }, function (_ref31) {
148
+ var margin = _ref31.margin;
149
+ return typeof margin === "string" ? spaces[margin] : "";
150
+ }, function (_ref32) {
151
+ var margin = _ref32.margin;
152
+ return (0, _typeof2["default"])(margin) === "object" ? spaces[margin.top] : "";
153
+ }, function (_ref33) {
154
+ var margin = _ref33.margin;
155
+ return (0, _typeof2["default"])(margin) === "object" ? spaces[margin.right] : "";
156
+ }, function (_ref34) {
157
+ var margin = _ref34.margin;
158
+ return (0, _typeof2["default"])(margin) === "object" ? spaces[margin.bottom] : "";
159
+ }, function (_ref35) {
160
+ var margin = _ref35.margin;
161
+ return (0, _typeof2["default"])(margin) === "object" ? spaces[margin.left] : "";
162
+ }, function (_ref36) {
163
+ var _outline$width, _outline$style, _getCoreColorToken2;
164
+ var outline = _ref36.outline;
165
+ return "".concat((_outline$width = outline === null || outline === void 0 ? void 0 : outline.width) !== null && _outline$width !== void 0 ? _outline$width : "", " ").concat((_outline$style = outline === null || outline === void 0 ? void 0 : outline.style) !== null && _outline$style !== void 0 ? _outline$style : "", " ").concat((_getCoreColorToken2 = (0, _coreTokens.getCoreColorToken)(outline === null || outline === void 0 ? void 0 : outline.color)) !== null && _getCoreColorToken2 !== void 0 ? _getCoreColorToken2 : "");
166
+ }, function (_ref37) {
167
+ var outline = _ref37.outline;
168
+ return outline === null || outline === void 0 ? void 0 : outline.offset;
169
+ }, function (_ref38) {
170
+ var $overflow = _ref38.$overflow;
171
+ return typeof $overflow === "string" ? $overflow : "";
172
+ }, function (_ref39) {
173
+ var $overflow = _ref39.$overflow;
174
+ return (0, _typeof2["default"])($overflow) === "object" ? "".concat($overflow === null || $overflow === void 0 ? void 0 : $overflow.x) : "";
175
+ }, function (_ref40) {
176
+ var $overflow = _ref40.$overflow;
177
+ return (0, _typeof2["default"])($overflow) === "object" ? "".concat($overflow === null || $overflow === void 0 ? void 0 : $overflow.y) : "";
178
+ }, function (_ref41) {
179
+ var padding = _ref41.padding;
180
+ return typeof padding === "string" ? spaces[padding] : "";
181
+ }, function (_ref42) {
182
+ var padding = _ref42.padding;
183
+ return (0, _typeof2["default"])(padding) === "object" ? spaces[padding.top] : "";
184
+ }, function (_ref43) {
185
+ var padding = _ref43.padding;
186
+ return (0, _typeof2["default"])(padding) === "object" ? spaces[padding.right] : "";
187
+ }, function (_ref44) {
188
+ var padding = _ref44.padding;
189
+ return (0, _typeof2["default"])(padding) === "object" ? spaces[padding.bottom] : "";
190
+ }, function (_ref45) {
191
+ var padding = _ref45.padding;
192
+ return (0, _typeof2["default"])(padding) === "object" ? spaces[padding.left] : "";
193
+ });
194
+ var _default = exports["default"] = DxcContainer;
@@ -0,0 +1,214 @@
1
+ import React from "react";
2
+ import Title from "../../.storybook/components/Title";
3
+ import ExampleContainer from "../../.storybook/components/ExampleContainer";
4
+ import DxcContainer from "./Container";
5
+ import DxcParagraph from "../paragraph/Paragraph";
6
+ import DxcTypography from "../typography/Typography";
7
+
8
+ export default {
9
+ title: "Container",
10
+ component: DxcContainer,
11
+ };
12
+
13
+ export const Chromatic = () => (
14
+ <>
15
+ <Title title="Box sizing border box" level={4} />
16
+ <ExampleContainer>
17
+ <DxcContainer
18
+ boxSizing="border-box"
19
+ width="200px"
20
+ height="200px"
21
+ background={{ color: "color_purple_400" }}
22
+ border={{
23
+ top: {
24
+ width: "2px",
25
+ color: "color_blue_600",
26
+ style: "solid",
27
+ },
28
+ bottom: {
29
+ width: "thick",
30
+ color: "color_purple_600",
31
+ style: "solid",
32
+ },
33
+ }}
34
+ borderRadius="0 0 0.25rem 0.25rem"
35
+ padding="medium"
36
+ margin="large"
37
+ >
38
+ <b>Example text</b>
39
+ </DxcContainer>
40
+ </ExampleContainer>
41
+ <Title title="Background image" level={4} />
42
+ <ExampleContainer>
43
+ <DxcContainer
44
+ background={{
45
+ image: "url(https://www.laecuaciondigital.com/wp-content/uploads/2023/10/DXC-Technology.png)",
46
+ position: "50%",
47
+ }}
48
+ width="500px"
49
+ height="500px"
50
+ >
51
+ <p>Example text</p>
52
+ </DxcContainer>
53
+ </ExampleContainer>
54
+ <Title title="Positioning of boxes" level={4} />
55
+ <ExampleContainer>
56
+ <DxcContainer
57
+ position="relative"
58
+ width="fit-content"
59
+ border={{ color: "color_purple_400", width: "2px", style: "dashed" }}
60
+ borderRadius="0.25rem"
61
+ margin={{ bottom: "xxlarge" }}
62
+ >
63
+ <DxcContainer display="inline-block" background={{ color: "color_purple_400" }} width="50px" height="50px">
64
+ <b>1</b>
65
+ </DxcContainer>
66
+ <DxcContainer display="inline-block" background={{ color: "color_purple_400" }} width="50px" height="50px">
67
+ <b>2</b>
68
+ </DxcContainer>
69
+ <DxcContainer
70
+ display="inline-block"
71
+ position="absolute"
72
+ inset={{ top: "25px", left: "0" }}
73
+ background={{ color: "color_blue_500" }}
74
+ width="50px"
75
+ height="50px"
76
+ zIndex={1}
77
+ >
78
+ <b>3</b>
79
+ </DxcContainer>
80
+ </DxcContainer>
81
+ </ExampleContainer>
82
+ <Title title="Margin collapse" level={4} />
83
+ <ExampleContainer>
84
+ <DxcContainer
85
+ width="fit-content"
86
+ border={{ color: "color_purple_400", width: "2px", style: "dashed" }}
87
+ borderRadius="0.25rem"
88
+ >
89
+ <DxcContainer
90
+ background={{ color: "color_purple_400" }}
91
+ width="50px"
92
+ height="50px"
93
+ margin={{ bottom: "medium" }}
94
+ >
95
+ <b>1</b>
96
+ </DxcContainer>
97
+ <DxcContainer background={{ color: "color_purple_400" }} width="50px" height="50px" margin={{ top: "large" }}>
98
+ <b>2</b>
99
+ </DxcContainer>
100
+ </DxcContainer>
101
+ </ExampleContainer>
102
+ <Title title="Overflow" level={4} />
103
+ <ExampleContainer>
104
+ <DxcContainer overflow={{ x: "auto" }} maxHeight="100px" width="fit-content">
105
+ <DxcContainer
106
+ border={{ width: "1px", style: "solid", color: "color_black" }}
107
+ background={{ color: "color_purple_400" }}
108
+ width="50px"
109
+ height="50px"
110
+ >
111
+ <b>1</b>
112
+ </DxcContainer>
113
+ <DxcContainer
114
+ border={{ width: "1px", style: "solid", color: "color_black" }}
115
+ background={{ color: "color_purple_400" }}
116
+ width="50px"
117
+ height="50px"
118
+ >
119
+ <b>2</b>
120
+ </DxcContainer>
121
+ <DxcContainer
122
+ border={{ width: "1px", style: "solid", color: "color_black" }}
123
+ background={{ color: "color_purple_400" }}
124
+ width="50px"
125
+ height="50px"
126
+ >
127
+ <b>3</b>
128
+ </DxcContainer>
129
+ </DxcContainer>
130
+ </ExampleContainer>
131
+ <Title title="Float" level={4} />
132
+ <ExampleContainer>
133
+ <DxcContainer padding="medium" border={{ width: "1px", style: "solid", color: "color_black" }}>
134
+ <DxcContainer float="right" background={{ color: "color_purple_400" }} width="100px" height="100px">
135
+ <b>Floating text</b>
136
+ </DxcContainer>
137
+ <p style={{ margin: 0 }}>
138
+ Lorem ipsum dolor sit amet, consectetur adipiscing elit. Nulla facilisis, sapien vitae aliquam lacinia, nisl
139
+ quam tincidunt ligula, eget aliquam eros quam quis nunc. Donec euismod, nisl eget ultricies aliquam, nisl
140
+ velit aliquam nunc, quis aliquam nisl nunc vel nisl. Donec euismod, nisl eget ultricies aliquam, nisl velit
141
+ aliquam nunc, quis aliquam nisl nunc vel nisl. Donec euismod, nisl eget ultricies aliquam, nisl velit aliquam
142
+ nunc, quis aliquam nisl nunc vel nisl. Donec euismod, nisl eget ultricies aliquam, nisl velit aliquam nunc,
143
+ quis aliquam nisl nunc vel nisl. Donec euismod, nisl eget ultricies aliquam, nisl velit aliquam nunc, quis
144
+ aliquam nisl nunc vel nisl. Donec euismod, nisl eget ultricies aliquam, nisl velit aliquam nunc, quis aliquam
145
+ nisl nunc vel nisl. Donec euismod, nisl eget ultricies aliquam, nisl velit aliquam nunc, quis aliquam nisl.
146
+ </p>
147
+ </DxcContainer>
148
+ </ExampleContainer>
149
+ <Title title="Box shadow and opacity" level={4} />
150
+ <ExampleContainer>
151
+ <DxcContainer
152
+ padding="medium"
153
+ outline={{ width: "1px", style: "solid", color: "color_black" }}
154
+ boxShadow="10px 5px 5px #fe0123"
155
+ >
156
+ <p style={{ margin: 0 }}>
157
+ Lorem ipsum dolor sit amet, consectetur adipiscing elit. Nulla facilisis, sapien vitae aliquam lacinia, nisl
158
+ quam tincidunt ligula, eget aliquam eros quam quis nunc. Donec euismod, nisl eget ultricies aliquam, nisl
159
+ velit aliquam nunc, quis aliquam nisl nunc vel nisl. Donec euismod, nisl eget ultricies aliquam, nisl velit
160
+ aliquam nunc, quis aliquam nisl nunc vel nisl. Donec euismod, nisl eget ultricies aliquam, nisl velit aliquam
161
+ nunc, quis aliquam nisl nunc vel nisl. Donec euismod, nisl eget ultricies aliquam, nisl velit aliquam nunc,
162
+ quis aliquam nisl nunc vel nisl. Donec euismod, nisl eget ultricies aliquam, nisl velit aliquam nunc, quis
163
+ aliquam nisl nunc vel nisl. Donec euismod, nisl eget ultricies aliquam, nisl velit aliquam nunc, quis aliquam
164
+ nisl.
165
+ </p>
166
+ </DxcContainer>
167
+ </ExampleContainer>
168
+ <Title title="Building a listbox component" level={4} />
169
+ <ExampleContainer>
170
+ <Listbox suggestions={["Option 1", "Option 2", "Option 3", "Option 4", "Option 5"]} />
171
+ </ExampleContainer>
172
+ <Title title="Border and outline" level={4} />
173
+ <ExampleContainer>
174
+ <DxcContainer
175
+ outline={{ color: "color_blue_400", style: "solid", offset: "2px" }}
176
+ border={{ top: { style: "solid" } }}
177
+ >
178
+ Example text
179
+ </DxcContainer>
180
+ </ExampleContainer>
181
+ </>
182
+ );
183
+
184
+ const Listbox = ({ suggestions = [] }: { suggestions: string[] }): JSX.Element => (
185
+ <DxcContainer
186
+ boxSizing="border-box"
187
+ boxShadow="0 4px 6px -1px rgba(0, 0, 0, 0.1)"
188
+ border={{ width: "1px", style: "solid", color: "color_grey_400" }}
189
+ borderRadius="0.25rem"
190
+ background={{ color: "color_white" }}
191
+ padding={{ top: "xxsmall", bottom: "xxsmall" }}
192
+ maxHeight="304px"
193
+ width="250px"
194
+ overflow={{ x: "hidden", y: "auto" }}
195
+ >
196
+ {suggestions.map((suggestion, index) => (
197
+ <DxcContainer padding={{ left: "xsmall", right: "xsmall" }}>
198
+ <DxcContainer
199
+ border={
200
+ index !== suggestions.length - 1
201
+ ? { bottom: { width: "1px", style: "solid", color: "color_grey_200" } }
202
+ : undefined
203
+ }
204
+ padding={{ top: "xxsmall", bottom: "xxsmall", left: "xxsmall", right: "xxsmall" }}
205
+ overflow="hidden"
206
+ >
207
+ <DxcTypography whiteSpace="nowrap" textOverflow="ellipsis" lineHeight="1.715em">
208
+ {suggestion}
209
+ </DxcTypography>
210
+ </DxcContainer>
211
+ </DxcContainer>
212
+ ))}
213
+ </DxcContainer>
214
+ );
@@ -0,0 +1,74 @@
1
+ /// <reference types="react" />
2
+ import { CoreColorTokens } from "../common/coreTokens";
3
+ type SpacingValues = "xxsmall" | "xsmall" | "small" | "medium" | "large" | "xlarge" | "xxlarge";
4
+ type Space = SpacingValues | {
5
+ top?: SpacingValues;
6
+ right?: SpacingValues;
7
+ bottom?: SpacingValues;
8
+ left?: SpacingValues;
9
+ };
10
+ type Inset = {
11
+ top?: string;
12
+ right?: string;
13
+ bottom?: string;
14
+ left?: string;
15
+ };
16
+ type Background = {
17
+ attachment?: string;
18
+ clip?: string;
19
+ color?: CoreColorTokens;
20
+ image?: string;
21
+ origin?: string;
22
+ position?: string;
23
+ repeat?: string;
24
+ size?: string;
25
+ };
26
+ export type BorderProperties = {
27
+ width?: string;
28
+ style?: "none" | "dotted" | "dashed" | "solid" | "double" | "groove" | "ridge" | "inset" | "outset";
29
+ color?: CoreColorTokens;
30
+ };
31
+ type Border = BorderProperties | {
32
+ top?: BorderProperties;
33
+ right?: BorderProperties;
34
+ bottom?: BorderProperties;
35
+ left?: BorderProperties;
36
+ };
37
+ type Outline = BorderProperties & {
38
+ offset?: string;
39
+ };
40
+ type OverflowValues = "visible" | "hidden" | "clip" | "scroll" | "auto";
41
+ type Overflow = OverflowValues | {
42
+ x?: OverflowValues;
43
+ y?: OverflowValues;
44
+ };
45
+ type Props = {
46
+ boxSizing?: "border-box" | "content-box";
47
+ display?: "block" | "inline-block" | "inline" | "none";
48
+ width?: string;
49
+ height?: string;
50
+ maxWidth?: string;
51
+ maxHeight?: string;
52
+ minWidth?: string;
53
+ minHeight?: string;
54
+ padding?: Space;
55
+ border?: Border;
56
+ borderRadius?: string;
57
+ margin?: Space;
58
+ overflow?: Overflow;
59
+ position?: "static" | "relative" | "absolute" | "fixed" | "sticky";
60
+ inset?: Inset;
61
+ float?: "left" | "right" | "none";
62
+ zIndex?: "auto" | number;
63
+ background?: Background;
64
+ boxShadow?: string;
65
+ outline?: Outline;
66
+ children: React.ReactNode;
67
+ };
68
+ export type StyledProps = Omit<Props, "display" | "width" | "height" | "opacity" | "overflow"> & {
69
+ $display?: "block" | "inline-block" | "inline" | "none";
70
+ $width?: string;
71
+ $height?: string;
72
+ $overflow?: Overflow;
73
+ };
74
+ export default Props;