@dxc-technology/halstack-react 0.0.0-f4755a1 → 0.0.0-f53d80b

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 (301) hide show
  1. package/BackgroundColorContext.d.ts +2 -2
  2. package/BackgroundColorContext.js +1 -1
  3. package/HalstackContext.d.ts +1339 -0
  4. package/HalstackContext.js +335 -0
  5. package/accordion/Accordion.d.ts +1 -1
  6. package/accordion/Accordion.js +118 -142
  7. package/accordion/Accordion.stories.tsx +114 -19
  8. package/accordion/Accordion.test.js +71 -0
  9. package/accordion/types.d.ts +8 -7
  10. package/accordion-group/AccordionGroup.d.ts +1 -1
  11. package/accordion-group/AccordionGroup.js +17 -38
  12. package/accordion-group/AccordionGroup.stories.tsx +28 -2
  13. package/accordion-group/AccordionGroup.test.js +126 -0
  14. package/accordion-group/types.d.ts +14 -7
  15. package/alert/Alert.js +8 -7
  16. package/alert/Alert.stories.tsx +28 -0
  17. package/alert/Alert.test.js +92 -0
  18. package/badge/Badge.d.ts +4 -0
  19. package/badge/Badge.js +5 -3
  20. package/badge/types.d.ts +5 -0
  21. package/bleed/Bleed.d.ts +3 -0
  22. package/bleed/Bleed.js +51 -0
  23. package/bleed/Bleed.stories.tsx +341 -0
  24. package/bleed/types.d.ts +37 -0
  25. package/bleed/types.js +5 -0
  26. package/box/Box.js +25 -37
  27. package/box/Box.stories.tsx +15 -0
  28. package/box/Box.test.js +18 -0
  29. package/box/types.d.ts +1 -0
  30. package/bulleted-list/BulletedList.d.ts +7 -0
  31. package/bulleted-list/BulletedList.js +123 -0
  32. package/bulleted-list/BulletedList.stories.tsx +200 -0
  33. package/bulleted-list/types.d.ts +11 -0
  34. package/bulleted-list/types.js +5 -0
  35. package/button/Button.d.ts +1 -1
  36. package/button/Button.js +56 -81
  37. package/button/Button.stories.tsx +163 -14
  38. package/button/Button.test.js +35 -0
  39. package/button/types.d.ts +6 -10
  40. package/card/Card.js +33 -37
  41. package/card/Card.stories.tsx +13 -14
  42. package/card/Card.test.js +50 -0
  43. package/card/types.d.ts +1 -0
  44. package/checkbox/Checkbox.d.ts +2 -2
  45. package/checkbox/Checkbox.js +107 -110
  46. package/checkbox/Checkbox.stories.tsx +198 -130
  47. package/checkbox/Checkbox.test.js +155 -0
  48. package/checkbox/types.d.ts +11 -3
  49. package/chip/Chip.d.ts +1 -1
  50. package/chip/Chip.js +22 -68
  51. package/chip/Chip.stories.tsx +98 -13
  52. package/chip/Chip.test.js +54 -0
  53. package/chip/types.d.ts +5 -13
  54. package/common/utils.d.ts +1 -0
  55. package/common/utils.js +4 -4
  56. package/common/variables.d.ts +1625 -0
  57. package/common/variables.js +490 -591
  58. package/date-input/Calendar.d.ts +4 -0
  59. package/date-input/Calendar.js +258 -0
  60. package/date-input/DateInput.js +171 -260
  61. package/date-input/DateInput.stories.tsx +199 -33
  62. package/date-input/DateInput.test.js +835 -0
  63. package/date-input/DatePicker.d.ts +4 -0
  64. package/date-input/DatePicker.js +146 -0
  65. package/date-input/Icons.d.ts +6 -0
  66. package/date-input/Icons.js +75 -0
  67. package/date-input/YearPicker.d.ts +4 -0
  68. package/date-input/YearPicker.js +126 -0
  69. package/date-input/types.d.ts +67 -9
  70. package/dialog/Dialog.js +76 -93
  71. package/dialog/Dialog.stories.tsx +230 -123
  72. package/dialog/Dialog.test.js +369 -0
  73. package/dialog/types.d.ts +1 -0
  74. package/dropdown/Dropdown.d.ts +1 -1
  75. package/dropdown/Dropdown.js +248 -277
  76. package/dropdown/Dropdown.stories.tsx +255 -64
  77. package/dropdown/Dropdown.test.js +586 -0
  78. package/dropdown/DropdownMenu.d.ts +4 -0
  79. package/dropdown/DropdownMenu.js +70 -0
  80. package/dropdown/DropdownMenuItem.d.ts +4 -0
  81. package/dropdown/DropdownMenuItem.js +79 -0
  82. package/dropdown/types.d.ts +27 -16
  83. package/file-input/FileInput.d.ts +2 -2
  84. package/file-input/FileInput.js +180 -223
  85. package/file-input/FileInput.stories.tsx +122 -10
  86. package/file-input/FileInput.test.js +457 -0
  87. package/file-input/FileItem.d.ts +4 -14
  88. package/file-input/FileItem.js +44 -66
  89. package/file-input/types.d.ts +17 -0
  90. package/flex/Flex.d.ts +4 -0
  91. package/flex/Flex.js +69 -0
  92. package/flex/Flex.stories.tsx +103 -0
  93. package/flex/types.d.ts +32 -0
  94. package/flex/types.js +5 -0
  95. package/footer/Footer.js +26 -103
  96. package/footer/Footer.stories.tsx +99 -1
  97. package/footer/Footer.test.js +97 -0
  98. package/footer/Icons.js +1 -1
  99. package/footer/types.d.ts +2 -1
  100. package/grid/Grid.d.ts +7 -0
  101. package/grid/Grid.js +91 -0
  102. package/grid/Grid.stories.tsx +219 -0
  103. package/grid/types.d.ts +46 -0
  104. package/grid/types.js +5 -0
  105. package/header/Header.d.ts +3 -2
  106. package/header/Header.js +108 -129
  107. package/header/Header.stories.tsx +189 -36
  108. package/header/Header.test.js +79 -0
  109. package/header/Icons.js +2 -2
  110. package/header/types.d.ts +1 -0
  111. package/heading/Heading.js +1 -1
  112. package/heading/Heading.stories.tsx +3 -2
  113. package/heading/Heading.test.js +186 -0
  114. package/inset/Inset.d.ts +3 -0
  115. package/inset/Inset.js +51 -0
  116. package/inset/Inset.stories.tsx +229 -0
  117. package/inset/types.d.ts +37 -0
  118. package/inset/types.js +5 -0
  119. package/layout/ApplicationLayout.d.ts +16 -6
  120. package/layout/ApplicationLayout.js +72 -126
  121. package/layout/ApplicationLayout.stories.tsx +84 -93
  122. package/layout/Icons.d.ts +5 -0
  123. package/layout/Icons.js +13 -2
  124. package/layout/SidenavContext.d.ts +5 -0
  125. package/layout/SidenavContext.js +19 -0
  126. package/layout/types.d.ts +18 -33
  127. package/link/Link.d.ts +3 -2
  128. package/link/Link.js +62 -87
  129. package/link/Link.stories.tsx +159 -52
  130. package/link/Link.test.js +81 -0
  131. package/link/types.d.ts +7 -27
  132. package/main.d.ts +12 -15
  133. package/main.js +57 -75
  134. package/nav-tabs/NavTabs.d.ts +8 -0
  135. package/nav-tabs/NavTabs.js +125 -0
  136. package/nav-tabs/NavTabs.stories.tsx +260 -0
  137. package/nav-tabs/NavTabs.test.js +82 -0
  138. package/nav-tabs/Tab.d.ts +4 -0
  139. package/nav-tabs/Tab.js +150 -0
  140. package/nav-tabs/types.d.ts +53 -0
  141. package/nav-tabs/types.js +5 -0
  142. package/number-input/NumberInput.js +11 -18
  143. package/number-input/NumberInput.stories.tsx +5 -5
  144. package/number-input/NumberInput.test.js +542 -0
  145. package/number-input/types.d.ts +17 -10
  146. package/package.json +20 -23
  147. package/paginator/Icons.d.ts +5 -0
  148. package/paginator/Icons.js +16 -28
  149. package/paginator/Paginator.js +19 -48
  150. package/paginator/Paginator.stories.tsx +24 -0
  151. package/paginator/Paginator.test.js +305 -0
  152. package/paragraph/Paragraph.d.ts +5 -0
  153. package/paragraph/Paragraph.js +38 -0
  154. package/paragraph/Paragraph.stories.tsx +44 -0
  155. package/password-input/PasswordInput.js +7 -4
  156. package/password-input/PasswordInput.stories.tsx +3 -3
  157. package/password-input/PasswordInput.test.js +181 -0
  158. package/password-input/types.d.ts +14 -11
  159. package/progress-bar/ProgressBar.js +61 -55
  160. package/progress-bar/ProgressBar.stories.jsx +47 -12
  161. package/progress-bar/ProgressBar.test.js +110 -0
  162. package/quick-nav/QuickNav.d.ts +4 -0
  163. package/quick-nav/QuickNav.js +117 -0
  164. package/quick-nav/QuickNav.stories.tsx +356 -0
  165. package/quick-nav/types.d.ts +21 -0
  166. package/quick-nav/types.js +5 -0
  167. package/radio-group/Radio.d.ts +1 -1
  168. package/radio-group/Radio.js +79 -32
  169. package/radio-group/RadioGroup.js +153 -36
  170. package/radio-group/RadioGroup.stories.tsx +178 -20
  171. package/radio-group/RadioGroup.test.js +722 -0
  172. package/radio-group/types.d.ts +90 -13
  173. package/resultsetTable/Icons.d.ts +7 -0
  174. package/resultsetTable/Icons.js +51 -0
  175. package/resultsetTable/ResultsetTable.js +50 -106
  176. package/resultsetTable/ResultsetTable.stories.tsx +56 -32
  177. package/resultsetTable/ResultsetTable.test.js +325 -0
  178. package/resultsetTable/types.d.ts +1 -1
  179. package/select/Icons.d.ts +10 -0
  180. package/select/Icons.js +93 -0
  181. package/select/Listbox.d.ts +4 -0
  182. package/select/Listbox.js +169 -0
  183. package/select/Option.d.ts +4 -0
  184. package/select/Option.js +97 -0
  185. package/select/Select.js +189 -386
  186. package/select/Select.stories.tsx +600 -201
  187. package/select/Select.test.js +2228 -0
  188. package/select/types.d.ts +53 -13
  189. package/sidenav/Sidenav.d.ts +6 -5
  190. package/sidenav/Sidenav.js +183 -53
  191. package/sidenav/Sidenav.stories.tsx +249 -132
  192. package/sidenav/Sidenav.test.js +44 -0
  193. package/sidenav/types.d.ts +50 -27
  194. package/slider/Slider.d.ts +2 -2
  195. package/slider/Slider.js +123 -98
  196. package/slider/Slider.stories.tsx +72 -9
  197. package/slider/Slider.test.js +250 -0
  198. package/slider/types.d.ts +8 -0
  199. package/spinner/Spinner.js +18 -24
  200. package/spinner/Spinner.stories.jsx +53 -26
  201. package/spinner/Spinner.test.js +64 -0
  202. package/switch/Switch.d.ts +2 -2
  203. package/switch/Switch.js +152 -69
  204. package/switch/Switch.stories.tsx +54 -43
  205. package/switch/Switch.test.js +225 -0
  206. package/switch/types.d.ts +10 -2
  207. package/table/Table.js +3 -3
  208. package/table/Table.stories.jsx +81 -1
  209. package/table/Table.test.js +26 -0
  210. package/tabs/Tab.d.ts +4 -0
  211. package/tabs/Tab.js +133 -0
  212. package/tabs/Tabs.d.ts +1 -1
  213. package/tabs/Tabs.js +363 -111
  214. package/tabs/Tabs.stories.tsx +122 -17
  215. package/tabs/Tabs.test.js +350 -0
  216. package/tabs/types.d.ts +37 -15
  217. package/tag/Tag.d.ts +1 -1
  218. package/tag/Tag.js +24 -36
  219. package/tag/Tag.stories.tsx +38 -28
  220. package/tag/Tag.test.js +60 -0
  221. package/tag/types.d.ts +23 -14
  222. package/text-input/Icons.d.ts +8 -0
  223. package/text-input/Icons.js +60 -0
  224. package/text-input/Suggestion.d.ts +4 -0
  225. package/text-input/Suggestion.js +84 -0
  226. package/text-input/Suggestions.d.ts +4 -0
  227. package/text-input/Suggestions.js +134 -0
  228. package/text-input/TextInput.js +220 -333
  229. package/text-input/TextInput.stories.tsx +309 -196
  230. package/text-input/TextInput.test.js +1723 -0
  231. package/text-input/types.d.ts +51 -13
  232. package/textarea/Textarea.js +23 -30
  233. package/textarea/Textarea.stories.jsx +96 -15
  234. package/textarea/Textarea.test.js +437 -0
  235. package/textarea/types.d.ts +18 -11
  236. package/toggle-group/ToggleGroup.d.ts +1 -1
  237. package/toggle-group/ToggleGroup.js +12 -8
  238. package/toggle-group/ToggleGroup.stories.tsx +46 -4
  239. package/toggle-group/ToggleGroup.test.js +156 -0
  240. package/toggle-group/types.d.ts +10 -2
  241. package/typography/Typography.d.ts +4 -0
  242. package/typography/Typography.js +32 -0
  243. package/typography/Typography.stories.tsx +198 -0
  244. package/typography/types.d.ts +18 -0
  245. package/typography/types.js +5 -0
  246. package/useTheme.d.ts +1234 -1
  247. package/useTheme.js +3 -3
  248. package/useTranslatedLabels.d.ts +85 -0
  249. package/useTranslatedLabels.js +20 -0
  250. package/utils/BaseTypography.d.ts +21 -0
  251. package/utils/BaseTypography.js +108 -0
  252. package/utils/FocusLock.d.ts +13 -0
  253. package/utils/FocusLock.js +139 -0
  254. package/wizard/Wizard.d.ts +1 -1
  255. package/wizard/Wizard.js +59 -55
  256. package/wizard/Wizard.stories.tsx +48 -19
  257. package/wizard/Wizard.test.js +141 -0
  258. package/wizard/types.d.ts +8 -4
  259. package/ThemeContext.d.ts +0 -15
  260. package/ThemeContext.js +0 -243
  261. package/V3Select/V3Select.js +0 -455
  262. package/V3Select/index.d.ts +0 -27
  263. package/V3Textarea/V3Textarea.js +0 -260
  264. package/V3Textarea/index.d.ts +0 -27
  265. package/common/RequiredComponent.js +0 -32
  266. package/date/Date.js +0 -373
  267. package/date/index.d.ts +0 -27
  268. package/input-text/Icons.js +0 -22
  269. package/input-text/InputText.js +0 -611
  270. package/input-text/index.d.ts +0 -36
  271. package/list/List.d.ts +0 -8
  272. package/list/List.js +0 -47
  273. package/list/List.stories.tsx +0 -95
  274. package/radio/Radio.d.ts +0 -4
  275. package/radio/Radio.js +0 -174
  276. package/radio/Radio.stories.tsx +0 -192
  277. package/radio/types.d.ts +0 -54
  278. package/row/Row.d.ts +0 -11
  279. package/row/Row.js +0 -127
  280. package/row/Row.stories.tsx +0 -239
  281. package/stack/Stack.d.ts +0 -10
  282. package/stack/Stack.js +0 -97
  283. package/stack/Stack.stories.tsx +0 -166
  284. package/text/Text.d.ts +0 -7
  285. package/text/Text.js +0 -30
  286. package/text/Text.stories.tsx +0 -19
  287. package/toggle/Toggle.js +0 -186
  288. package/toggle/index.d.ts +0 -21
  289. package/upload/Upload.js +0 -201
  290. package/upload/buttons-upload/ButtonsUpload.js +0 -111
  291. package/upload/buttons-upload/Icons.js +0 -40
  292. package/upload/dragAndDropArea/DragAndDropArea.js +0 -225
  293. package/upload/dragAndDropArea/Icons.js +0 -39
  294. package/upload/file-upload/FileToUpload.js +0 -115
  295. package/upload/file-upload/Icons.js +0 -66
  296. package/upload/files-upload/FilesToUpload.js +0 -109
  297. package/upload/index.d.ts +0 -15
  298. package/upload/transaction/Icons.js +0 -160
  299. package/upload/transaction/Transaction.js +0 -104
  300. package/upload/transactions/Transactions.js +0 -94
  301. /package/{radio → badge}/types.js +0 -0
@@ -0,0 +1,79 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+
5
+ Object.defineProperty(exports, "__esModule", {
6
+ value: true
7
+ });
8
+ exports["default"] = void 0;
9
+
10
+ var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
11
+
12
+ var _react = _interopRequireDefault(require("react"));
13
+
14
+ var _styledComponents = _interopRequireDefault(require("styled-components"));
15
+
16
+ var _templateObject, _templateObject2, _templateObject3;
17
+
18
+ var DropdownMenuItem = function DropdownMenuItem(_ref) {
19
+ var id = _ref.id,
20
+ visuallyFocused = _ref.visuallyFocused,
21
+ iconPosition = _ref.iconPosition,
22
+ _onClick = _ref.onClick,
23
+ option = _ref.option;
24
+ return /*#__PURE__*/_react["default"].createElement(DropdownMenuItemContainer, {
25
+ visuallyFocused: visuallyFocused,
26
+ onClick: function onClick() {
27
+ _onClick(option.value);
28
+ },
29
+ id: id,
30
+ role: "menuitem",
31
+ tabIndex: -1
32
+ }, iconPosition === "after" && /*#__PURE__*/_react["default"].createElement(DropdownMenuItemLabel, null, option.label), option.icon && /*#__PURE__*/_react["default"].createElement(DropdownMenuItemIcon, {
33
+ role: typeof option.icon === "string" ? undefined : "img"
34
+ }, typeof option.icon === "string" ? /*#__PURE__*/_react["default"].createElement("img", {
35
+ src: option.icon
36
+ }) : option.icon), iconPosition === "before" && /*#__PURE__*/_react["default"].createElement(DropdownMenuItemLabel, null, option.label));
37
+ };
38
+
39
+ var DropdownMenuItemContainer = _styledComponents["default"].li(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n box-sizing: border-box;\n display: flex;\n align-items: center;\n gap: ", ";\n min-height: 36px;\n padding-top: ", ";\n padding-bottom: ", ";\n padding-left: ", ";\n padding-right: ", ";\n cursor: pointer;\n\n ", "\n &:hover {\n background-color: ", ";\n }\n &:active {\n background-color: ", ";\n }\n"])), function (props) {
40
+ return props.theme.optionIconSpacing;
41
+ }, function (props) {
42
+ return props.theme.optionPaddingTop;
43
+ }, function (props) {
44
+ return props.theme.optionPaddingBottom;
45
+ }, function (props) {
46
+ return props.theme.optionPaddingLeft;
47
+ }, function (props) {
48
+ return props.theme.optionPaddingRight;
49
+ }, function (props) {
50
+ return props.visuallyFocused && "outline: ".concat(props.theme.focusColor, " solid 2px; outline-offset: -2px;");
51
+ }, function (props) {
52
+ return props.theme.hoverOptionBackgroundColor;
53
+ }, function (props) {
54
+ return props.theme.activeOptionBackgroundColor;
55
+ });
56
+
57
+ var DropdownMenuItemLabel = _styledComponents["default"].span(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n font-family: ", ";\n font-size: ", ";\n font-style: ", ";\n font-weight: ", ";\n line-height: 1.5rem;\n color: ", ";\n white-space: nowrap;\n"])), function (props) {
58
+ return props.theme.optionFontFamily;
59
+ }, function (props) {
60
+ return props.theme.optionFontSize;
61
+ }, function (props) {
62
+ return props.theme.optionFontStyle;
63
+ }, function (props) {
64
+ return props.theme.optionFontWeight;
65
+ }, function (props) {
66
+ return props.theme.optionFontColor;
67
+ });
68
+
69
+ var DropdownMenuItemIcon = _styledComponents["default"].div(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n color: ", ";\n\n img,\n svg {\n width: ", ";\n height: ", ";\n }\n"])), function (props) {
70
+ return props.theme.optionIconColor;
71
+ }, function (props) {
72
+ return props.theme.optionIconSize;
73
+ }, function (props) {
74
+ return props.theme.optionIconSize;
75
+ });
76
+
77
+ var _default = /*#__PURE__*/_react["default"].memo(DropdownMenuItem);
78
+
79
+ exports["default"] = _default;
@@ -6,21 +6,18 @@ declare type Margin = {
6
6
  left?: Space;
7
7
  right?: Space;
8
8
  };
9
- declare type SVG = React.SVGProps<SVGSVGElement> | React.FunctionComponent<React.SVGProps<SVGSVGElement>>;
10
- declare type Option = {
9
+ declare type Size = "small" | "medium" | "large" | "fillParent" | "fitContent";
10
+ declare type SVG = React.ReactNode & React.SVGProps<SVGSVGElement>;
11
+ export declare type Option = {
11
12
  /**
12
13
  * Option display value.
13
14
  */
14
15
  label?: string;
15
16
  /**
16
- * Element used as the icon that will be placed next to the
17
+ * Element or path used as the icon that will be placed next to the
17
18
  * option label.
18
19
  */
19
- icon?: SVG;
20
- /**
21
- * @deprecated URL of the icon that will be placed next to the option label.
22
- */
23
- iconSrc?: string;
20
+ icon?: string | SVG;
24
21
  /**
25
22
  * Option inner value.
26
23
  */
@@ -37,15 +34,10 @@ declare type Props = {
37
34
  */
38
35
  optionsIconPosition?: "before" | "after";
39
36
  /**
40
- * Element used as the icon that will be placed next to the
41
- * dropdown label.
42
- */
43
- icon?: SVG;
44
- /**
45
- * @deprecated URL of the icon that will be placed next to the
37
+ * Element or path used as the icon that will be placed next to the
46
38
  * dropdown label.
47
39
  */
48
- iconSrc?: string;
40
+ icon?: string | SVG;
49
41
  /**
50
42
  * Whether the icon should appear after or before the label.
51
43
  */
@@ -76,7 +68,7 @@ declare type Props = {
76
68
  /**
77
69
  * Size of the component.
78
70
  */
79
- size?: "small" | "medium" | "large" | "fillParent" | "fitContent";
71
+ size?: Size;
80
72
  /**
81
73
  * Value of the tabindex.
82
74
  */
@@ -86,4 +78,23 @@ declare type Props = {
86
78
  */
87
79
  disabled?: boolean;
88
80
  };
81
+ export declare type DropdownMenuProps = {
82
+ id: string;
83
+ dropdownTriggerId: string;
84
+ iconsPosition: "before" | "after";
85
+ visualFocusIndex: number;
86
+ menuItemOnClick: (value: string) => void;
87
+ onKeyDown: (event: React.KeyboardEvent<HTMLUListElement>) => void;
88
+ options: Option[];
89
+ styles: {
90
+ width: number;
91
+ };
92
+ };
93
+ export declare type DropdownMenuItemProps = {
94
+ id: string;
95
+ visuallyFocused: boolean;
96
+ iconPosition: "before" | "after";
97
+ onClick: (value: string) => void;
98
+ option: Option;
99
+ };
89
100
  export default Props;
@@ -1,4 +1,4 @@
1
- /// <reference types="react" />
1
+ import React from "react";
2
2
  import FileInputPropsType from "./types";
3
- declare const DxcFileInput: ({ name, mode, label, buttonLabel, dropAreaLabel, helperText, accept, minSize, maxSize, showPreview, multiple, disabled, callbackFile, value, margin, tabIndex, }: FileInputPropsType) => JSX.Element;
3
+ declare const DxcFileInput: React.ForwardRefExoticComponent<FileInputPropsType & React.RefAttributes<HTMLDivElement>>;
4
4
  export default DxcFileInput;