@dxc-technology/halstack-react 0.0.0-b3e1a2f → 0.0.0-b41d935

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 (260) hide show
  1. package/HalstackContext.d.ts +12 -0
  2. package/HalstackContext.js +295 -0
  3. package/accordion/Accordion.d.ts +1 -1
  4. package/accordion/Accordion.js +122 -135
  5. package/accordion/Accordion.stories.tsx +13 -14
  6. package/accordion/Accordion.test.js +71 -0
  7. package/accordion/types.d.ts +11 -10
  8. package/accordion-group/AccordionGroup.d.ts +1 -1
  9. package/accordion-group/AccordionGroup.js +15 -36
  10. package/accordion-group/AccordionGroup.stories.tsx +28 -2
  11. package/accordion-group/AccordionGroup.test.js +126 -0
  12. package/accordion-group/types.d.ts +16 -9
  13. package/alert/Alert.js +5 -2
  14. package/alert/Alert.test.js +92 -0
  15. package/badge/Badge.d.ts +4 -0
  16. package/badge/Badge.js +5 -3
  17. package/badge/types.d.ts +5 -0
  18. package/{list → badge}/types.js +0 -0
  19. package/bleed/Bleed.js +1 -34
  20. package/bleed/Bleed.stories.tsx +94 -95
  21. package/bleed/types.d.ts +25 -1
  22. package/box/Box.js +23 -33
  23. package/box/Box.test.js +18 -0
  24. package/box/types.d.ts +1 -0
  25. package/bulleted-list/BulletedList.d.ts +7 -0
  26. package/bulleted-list/BulletedList.js +123 -0
  27. package/bulleted-list/BulletedList.stories.tsx +200 -0
  28. package/bulleted-list/types.d.ts +11 -0
  29. package/{radio → bulleted-list}/types.js +0 -0
  30. package/button/Button.js +53 -68
  31. package/button/Button.stories.tsx +9 -0
  32. package/button/Button.test.js +35 -0
  33. package/button/types.d.ts +7 -7
  34. package/card/Card.js +24 -27
  35. package/card/Card.test.js +50 -0
  36. package/card/types.d.ts +1 -0
  37. package/checkbox/Checkbox.d.ts +1 -1
  38. package/checkbox/Checkbox.js +104 -108
  39. package/checkbox/Checkbox.stories.tsx +146 -130
  40. package/checkbox/Checkbox.test.js +155 -0
  41. package/checkbox/types.d.ts +9 -5
  42. package/chip/Chip.d.ts +1 -1
  43. package/chip/Chip.js +14 -52
  44. package/chip/Chip.stories.tsx +6 -8
  45. package/chip/Chip.test.js +56 -0
  46. package/chip/types.d.ts +5 -13
  47. package/common/variables.js +236 -339
  48. package/date-input/DateInput.js +56 -42
  49. package/date-input/DateInput.stories.tsx +7 -7
  50. package/date-input/DateInput.test.js +479 -0
  51. package/date-input/types.d.ts +16 -9
  52. package/dialog/Dialog.js +46 -50
  53. package/dialog/Dialog.stories.tsx +57 -2
  54. package/dialog/Dialog.test.js +70 -0
  55. package/dialog/types.d.ts +3 -2
  56. package/dropdown/Dropdown.d.ts +1 -1
  57. package/dropdown/Dropdown.js +244 -273
  58. package/dropdown/Dropdown.stories.tsx +144 -79
  59. package/dropdown/Dropdown.test.js +590 -0
  60. package/dropdown/DropdownMenu.d.ts +4 -0
  61. package/dropdown/DropdownMenu.js +80 -0
  62. package/dropdown/DropdownMenuItem.d.ts +4 -0
  63. package/dropdown/DropdownMenuItem.js +92 -0
  64. package/dropdown/types.d.ts +29 -18
  65. package/file-input/FileInput.js +175 -217
  66. package/file-input/FileInput.stories.tsx +38 -10
  67. package/file-input/FileInput.test.js +498 -0
  68. package/file-input/FileItem.d.ts +4 -14
  69. package/file-input/FileItem.js +43 -66
  70. package/file-input/types.d.ts +13 -0
  71. package/flex/Flex.d.ts +4 -0
  72. package/flex/Flex.js +69 -0
  73. package/flex/Flex.stories.tsx +103 -0
  74. package/flex/types.d.ts +32 -0
  75. package/{row → flex}/types.js +0 -0
  76. package/footer/Footer.js +24 -99
  77. package/footer/Footer.stories.tsx +8 -1
  78. package/footer/Footer.test.js +109 -0
  79. package/footer/Icons.js +1 -1
  80. package/footer/types.d.ts +2 -1
  81. package/header/Header.js +95 -114
  82. package/header/Header.stories.tsx +46 -36
  83. package/header/Header.test.js +79 -0
  84. package/header/Icons.js +2 -2
  85. package/header/types.d.ts +3 -2
  86. package/heading/Heading.test.js +186 -0
  87. package/inset/Inset.js +1 -34
  88. package/inset/Inset.stories.tsx +36 -36
  89. package/inset/types.d.ts +25 -1
  90. package/layout/ApplicationLayout.d.ts +16 -6
  91. package/layout/ApplicationLayout.js +71 -125
  92. package/layout/ApplicationLayout.stories.tsx +84 -93
  93. package/layout/Icons.d.ts +5 -0
  94. package/layout/Icons.js +13 -2
  95. package/layout/SidenavContext.d.ts +5 -0
  96. package/layout/SidenavContext.js +19 -0
  97. package/layout/types.d.ts +18 -33
  98. package/link/Link.d.ts +3 -2
  99. package/link/Link.js +60 -85
  100. package/link/Link.stories.tsx +99 -52
  101. package/link/Link.test.js +83 -0
  102. package/link/types.d.ts +9 -29
  103. package/main.d.ts +11 -15
  104. package/main.js +53 -79
  105. package/number-input/NumberInput.js +11 -18
  106. package/number-input/NumberInput.stories.tsx +5 -5
  107. package/number-input/NumberInput.test.js +543 -0
  108. package/number-input/types.d.ts +17 -10
  109. package/package.json +14 -12
  110. package/paginator/Paginator.js +17 -38
  111. package/paginator/Paginator.test.js +308 -0
  112. package/paragraph/Paragraph.d.ts +6 -0
  113. package/paragraph/Paragraph.js +38 -0
  114. package/paragraph/Paragraph.stories.tsx +44 -0
  115. package/password-input/PasswordInput.js +7 -4
  116. package/password-input/PasswordInput.test.js +181 -0
  117. package/password-input/types.d.ts +14 -11
  118. package/progress-bar/ProgressBar.d.ts +2 -2
  119. package/progress-bar/ProgressBar.js +57 -51
  120. package/progress-bar/ProgressBar.stories.jsx +13 -11
  121. package/progress-bar/ProgressBar.test.js +110 -0
  122. package/progress-bar/types.d.ts +3 -4
  123. package/quick-nav/QuickNav.d.ts +4 -0
  124. package/quick-nav/QuickNav.js +117 -0
  125. package/quick-nav/QuickNav.stories.tsx +342 -0
  126. package/quick-nav/types.d.ts +21 -0
  127. package/{stack → quick-nav}/types.js +0 -0
  128. package/radio-group/Radio.d.ts +1 -1
  129. package/radio-group/Radio.js +57 -31
  130. package/radio-group/RadioGroup.js +75 -60
  131. package/radio-group/RadioGroup.stories.tsx +61 -39
  132. package/radio-group/RadioGroup.test.js +722 -0
  133. package/radio-group/types.d.ts +81 -3
  134. package/resultsetTable/ResultsetTable.js +6 -5
  135. package/resultsetTable/ResultsetTable.test.js +348 -0
  136. package/select/Icons.d.ts +10 -0
  137. package/select/Icons.js +93 -0
  138. package/select/Listbox.d.ts +4 -0
  139. package/select/Listbox.js +198 -0
  140. package/select/Option.d.ts +4 -0
  141. package/select/Option.js +110 -0
  142. package/select/Select.js +147 -365
  143. package/select/Select.stories.tsx +231 -176
  144. package/select/Select.test.js +2233 -0
  145. package/select/types.d.ts +52 -12
  146. package/sidenav/Sidenav.d.ts +6 -5
  147. package/sidenav/Sidenav.js +184 -52
  148. package/sidenav/Sidenav.stories.tsx +154 -156
  149. package/sidenav/Sidenav.test.js +44 -0
  150. package/sidenav/types.d.ts +50 -27
  151. package/slider/Slider.d.ts +1 -1
  152. package/slider/Slider.js +118 -93
  153. package/slider/Slider.stories.tsx +15 -9
  154. package/slider/Slider.test.js +250 -0
  155. package/slider/types.d.ts +6 -2
  156. package/spinner/Spinner.js +1 -1
  157. package/spinner/Spinner.test.js +64 -0
  158. package/switch/Switch.d.ts +2 -2
  159. package/switch/Switch.js +147 -65
  160. package/switch/Switch.stories.tsx +20 -42
  161. package/switch/Switch.test.js +225 -0
  162. package/switch/types.d.ts +9 -6
  163. package/table/Table.js +1 -1
  164. package/table/Table.test.js +26 -0
  165. package/tabs/Tab.d.ts +4 -0
  166. package/tabs/Tab.js +135 -0
  167. package/tabs/Tabs.d.ts +1 -1
  168. package/tabs/Tabs.js +362 -108
  169. package/tabs/Tabs.stories.tsx +74 -8
  170. package/tabs/Tabs.test.js +351 -0
  171. package/tabs/types.d.ts +19 -5
  172. package/tabs-nav/NavTabs.d.ts +8 -0
  173. package/tabs-nav/NavTabs.js +125 -0
  174. package/tabs-nav/NavTabs.stories.tsx +170 -0
  175. package/tabs-nav/NavTabs.test.js +82 -0
  176. package/tabs-nav/Tab.d.ts +4 -0
  177. package/tabs-nav/Tab.js +130 -0
  178. package/tabs-nav/types.d.ts +53 -0
  179. package/tabs-nav/types.js +5 -0
  180. package/tag/Tag.d.ts +1 -1
  181. package/tag/Tag.js +18 -28
  182. package/tag/Tag.stories.tsx +25 -28
  183. package/tag/Tag.test.js +60 -0
  184. package/tag/types.d.ts +23 -14
  185. package/text-input/Icons.d.ts +8 -0
  186. package/text-input/Icons.js +60 -0
  187. package/text-input/Suggestion.d.ts +4 -0
  188. package/text-input/Suggestion.js +57 -0
  189. package/text-input/Suggestions.d.ts +4 -0
  190. package/text-input/Suggestions.js +134 -0
  191. package/text-input/TextInput.js +217 -334
  192. package/text-input/TextInput.stories.tsx +219 -194
  193. package/text-input/TextInput.test.js +1771 -0
  194. package/text-input/types.d.ts +50 -12
  195. package/textarea/Textarea.js +20 -27
  196. package/textarea/Textarea.stories.jsx +33 -12
  197. package/textarea/Textarea.test.js +437 -0
  198. package/textarea/types.d.ts +18 -11
  199. package/toggle-group/ToggleGroup.d.ts +1 -1
  200. package/toggle-group/ToggleGroup.js +5 -4
  201. package/toggle-group/ToggleGroup.stories.tsx +4 -4
  202. package/toggle-group/ToggleGroup.test.js +156 -0
  203. package/toggle-group/types.d.ts +9 -1
  204. package/typography/Typography.d.ts +4 -0
  205. package/typography/Typography.js +131 -0
  206. package/typography/Typography.stories.tsx +198 -0
  207. package/typography/types.d.ts +18 -0
  208. package/typography/types.js +5 -0
  209. package/useTheme.js +2 -2
  210. package/useTranslatedLabels.d.ts +2 -0
  211. package/useTranslatedLabels.js +20 -0
  212. package/wizard/Wizard.d.ts +1 -1
  213. package/wizard/Wizard.js +58 -54
  214. package/wizard/Wizard.stories.tsx +33 -24
  215. package/wizard/Wizard.test.js +141 -0
  216. package/wizard/types.d.ts +10 -5
  217. package/ThemeContext.d.ts +0 -15
  218. package/ThemeContext.js +0 -243
  219. package/V3Select/V3Select.js +0 -455
  220. package/V3Select/index.d.ts +0 -27
  221. package/V3Textarea/V3Textarea.js +0 -260
  222. package/V3Textarea/index.d.ts +0 -27
  223. package/date/Date.js +0 -373
  224. package/date/index.d.ts +0 -27
  225. package/input-text/Icons.js +0 -22
  226. package/input-text/InputText.js +0 -611
  227. package/input-text/index.d.ts +0 -36
  228. package/list/List.d.ts +0 -4
  229. package/list/List.js +0 -47
  230. package/list/List.stories.tsx +0 -95
  231. package/list/types.d.ts +0 -7
  232. package/radio/Radio.d.ts +0 -4
  233. package/radio/Radio.js +0 -174
  234. package/radio/Radio.stories.tsx +0 -192
  235. package/radio/types.d.ts +0 -54
  236. package/row/Row.d.ts +0 -3
  237. package/row/Row.js +0 -127
  238. package/row/Row.stories.tsx +0 -237
  239. package/row/types.d.ts +0 -10
  240. package/stack/Stack.d.ts +0 -3
  241. package/stack/Stack.js +0 -97
  242. package/stack/Stack.stories.tsx +0 -164
  243. package/stack/types.d.ts +0 -9
  244. package/text/Text.d.ts +0 -7
  245. package/text/Text.js +0 -30
  246. package/text/Text.stories.tsx +0 -19
  247. package/toggle/Toggle.js +0 -186
  248. package/toggle/index.d.ts +0 -21
  249. package/upload/Upload.js +0 -201
  250. package/upload/buttons-upload/ButtonsUpload.js +0 -111
  251. package/upload/buttons-upload/Icons.js +0 -40
  252. package/upload/dragAndDropArea/DragAndDropArea.js +0 -225
  253. package/upload/dragAndDropArea/Icons.js +0 -39
  254. package/upload/file-upload/FileToUpload.js +0 -115
  255. package/upload/file-upload/Icons.js +0 -66
  256. package/upload/files-upload/FilesToUpload.js +0 -109
  257. package/upload/index.d.ts +0 -15
  258. package/upload/transaction/Icons.js +0 -160
  259. package/upload/transaction/Transaction.js +0 -104
  260. package/upload/transactions/Transactions.js +0 -94
@@ -0,0 +1,92 @@
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 = _interopRequireDefault(require("react"));
15
+
16
+ var _styledComponents = _interopRequireWildcard(require("styled-components"));
17
+
18
+ var _useTheme = _interopRequireDefault(require("../useTheme"));
19
+
20
+ var _templateObject, _templateObject2, _templateObject3;
21
+
22
+ 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); }
23
+
24
+ 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; }
25
+
26
+ var DropdownMenuItem = function DropdownMenuItem(_ref) {
27
+ var id = _ref.id,
28
+ visuallyFocused = _ref.visuallyFocused,
29
+ iconPosition = _ref.iconPosition,
30
+ _onClick = _ref.onClick,
31
+ option = _ref.option;
32
+ var colorsTheme = (0, _useTheme["default"])();
33
+ return /*#__PURE__*/_react["default"].createElement(_styledComponents.ThemeProvider, {
34
+ theme: colorsTheme.dropdown
35
+ }, /*#__PURE__*/_react["default"].createElement(DropdownMenuItemContainer, {
36
+ visuallyFocused: visuallyFocused,
37
+ onClick: function onClick() {
38
+ _onClick(option.value);
39
+ },
40
+ id: id,
41
+ role: "menuitem",
42
+ tabIndex: -1
43
+ }, iconPosition === "after" && /*#__PURE__*/_react["default"].createElement(DropdownMenuItemLabel, null, option.label), option.icon && /*#__PURE__*/_react["default"].createElement(DropdownMenuItemIcon, {
44
+ iconPosition: iconPosition,
45
+ label: option.label,
46
+ role: typeof option.icon === "string" ? undefined : "img"
47
+ }, typeof option.icon === "string" ? /*#__PURE__*/_react["default"].createElement("img", {
48
+ src: option.icon
49
+ }) : option.icon), iconPosition === "before" && /*#__PURE__*/_react["default"].createElement(DropdownMenuItemLabel, null, option.label)));
50
+ };
51
+
52
+ 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) {
53
+ return props.theme.optionIconSpacing;
54
+ }, function (props) {
55
+ return props.theme.optionPaddingTop;
56
+ }, function (props) {
57
+ return props.theme.optionPaddingBottom;
58
+ }, function (props) {
59
+ return props.theme.optionPaddingLeft;
60
+ }, function (props) {
61
+ return props.theme.optionPaddingRight;
62
+ }, function (props) {
63
+ return props.visuallyFocused && "outline: ".concat(props.theme.focusColor, " solid 2px; outline-offset: -2px;");
64
+ }, function (props) {
65
+ return props.theme.hoverOptionBackgroundColor;
66
+ }, function (props) {
67
+ return props.theme.activeOptionBackgroundColor;
68
+ });
69
+
70
+ 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"])), function (props) {
71
+ return props.theme.optionFontFamily;
72
+ }, function (props) {
73
+ return props.theme.optionFontSize;
74
+ }, function (props) {
75
+ return props.theme.optionFontStyle;
76
+ }, function (props) {
77
+ return props.theme.optionFontWeight;
78
+ }, function (props) {
79
+ return props.theme.optionFontColor;
80
+ });
81
+
82
+ 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) {
83
+ return props.theme.optionIconColor;
84
+ }, function (props) {
85
+ return props.theme.optionIconSize;
86
+ }, function (props) {
87
+ return props.theme.optionIconSize;
88
+ });
89
+
90
+ var _default = /*#__PURE__*/_react["default"].memo(DropdownMenuItem);
91
+
92
+ exports["default"] = _default;
@@ -1,26 +1,23 @@
1
1
  /// <reference types="react" />
2
- declare type Space = "xxsmall" | "xsmall" | "small" | "medium" | "large" | "xlarge" | "xxlarge";
3
- declare type Margin = {
2
+ export declare type Space = "xxsmall" | "xsmall" | "small" | "medium" | "large" | "xlarge" | "xxlarge";
3
+ export declare type Margin = {
4
4
  top?: Space;
5
5
  bottom?: Space;
6
6
  left?: Space;
7
7
  right?: Space;
8
8
  };
9
- declare type SVG = React.SVGProps<SVGSVGElement> | React.FunctionComponent<React.SVGProps<SVGSVGElement>>;
10
- declare type Option = {
9
+ export 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;