@dxc-technology/halstack-react 0.0.0-e1a279c → 0.0.0-e201636

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 (281) hide show
  1. package/BackgroundColorContext.d.ts +10 -0
  2. package/BackgroundColorContext.js +1 -4
  3. package/HalstackContext.d.ts +12 -0
  4. package/HalstackContext.js +295 -0
  5. package/accordion/Accordion.d.ts +1 -1
  6. package/accordion/Accordion.js +15 -47
  7. package/accordion/Accordion.stories.tsx +307 -0
  8. package/accordion/Accordion.test.js +72 -0
  9. package/accordion/types.d.ts +8 -8
  10. package/accordion-group/AccordionGroup.d.ts +1 -1
  11. package/accordion-group/AccordionGroup.js +15 -17
  12. package/accordion-group/AccordionGroup.stories.tsx +225 -0
  13. package/accordion-group/AccordionGroup.test.js +151 -0
  14. package/accordion-group/types.d.ts +8 -8
  15. package/alert/Alert.js +6 -3
  16. package/alert/Alert.test.js +92 -0
  17. package/alert/types.d.ts +1 -1
  18. package/badge/Badge.d.ts +4 -0
  19. package/badge/Badge.js +6 -4
  20. package/badge/types.d.ts +5 -0
  21. package/{radio → badge}/types.js +0 -0
  22. package/bleed/Bleed.d.ts +3 -0
  23. package/bleed/Bleed.js +84 -0
  24. package/bleed/Bleed.stories.tsx +342 -0
  25. package/bleed/types.d.ts +37 -0
  26. package/bleed/types.js +5 -0
  27. package/box/Box.d.ts +1 -1
  28. package/box/Box.js +26 -39
  29. package/box/Box.test.js +18 -0
  30. package/box/types.d.ts +0 -4
  31. package/button/Button.d.ts +1 -1
  32. package/button/Button.js +24 -27
  33. package/button/Button.stories.tsx +6 -8
  34. package/button/Button.test.js +35 -0
  35. package/button/types.d.ts +5 -9
  36. package/card/Card.js +32 -34
  37. package/card/Card.stories.tsx +201 -0
  38. package/card/Card.test.js +50 -0
  39. package/card/ice-cream.jpg +0 -0
  40. package/card/types.d.ts +4 -6
  41. package/checkbox/Checkbox.d.ts +1 -1
  42. package/checkbox/Checkbox.js +45 -41
  43. package/checkbox/Checkbox.stories.tsx +124 -128
  44. package/checkbox/Checkbox.test.js +78 -0
  45. package/checkbox/types.d.ts +9 -5
  46. package/chip/Chip.d.ts +4 -0
  47. package/chip/Chip.js +16 -76
  48. package/chip/Chip.stories.tsx +6 -8
  49. package/chip/Chip.test.js +56 -0
  50. package/chip/types.d.ts +45 -0
  51. package/chip/types.js +5 -0
  52. package/common/variables.js +234 -341
  53. package/date-input/DateInput.js +63 -52
  54. package/date-input/DateInput.stories.tsx +7 -7
  55. package/date-input/DateInput.test.js +479 -0
  56. package/date-input/types.d.ts +16 -9
  57. package/dialog/Dialog.js +8 -35
  58. package/dialog/Dialog.test.js +40 -0
  59. package/dropdown/Dropdown.d.ts +1 -1
  60. package/dropdown/Dropdown.js +22 -48
  61. package/dropdown/Dropdown.stories.tsx +249 -0
  62. package/dropdown/Dropdown.test.js +189 -0
  63. package/dropdown/types.d.ts +6 -15
  64. package/file-input/FileInput.d.ts +4 -0
  65. package/file-input/FileInput.js +172 -111
  66. package/file-input/FileInput.stories.tsx +507 -0
  67. package/file-input/FileInput.test.js +457 -0
  68. package/file-input/FileItem.d.ts +14 -0
  69. package/file-input/FileItem.js +16 -23
  70. package/file-input/types.d.ts +112 -0
  71. package/file-input/types.js +5 -0
  72. package/footer/Footer.d.ts +1 -1
  73. package/footer/Footer.js +32 -113
  74. package/footer/{Footer.stories.jsx → Footer.stories.tsx} +1 -22
  75. package/footer/Footer.test.js +109 -0
  76. package/footer/Icons.d.ts +2 -0
  77. package/footer/Icons.js +3 -3
  78. package/footer/types.d.ts +22 -18
  79. package/header/Header.js +29 -50
  80. package/header/Header.stories.tsx +172 -0
  81. package/header/Header.test.js +79 -0
  82. package/header/Icons.d.ts +2 -0
  83. package/header/types.d.ts +4 -2
  84. package/heading/Heading.d.ts +4 -0
  85. package/heading/Heading.js +7 -24
  86. package/heading/Heading.stories.tsx +54 -0
  87. package/heading/Heading.test.js +186 -0
  88. package/heading/types.d.ts +33 -0
  89. package/heading/types.js +5 -0
  90. package/inset/Inset.d.ts +3 -0
  91. package/inset/Inset.js +84 -0
  92. package/inset/Inset.stories.tsx +229 -0
  93. package/inset/types.d.ts +37 -0
  94. package/inset/types.js +5 -0
  95. package/layout/ApplicationLayout.d.ts +11 -0
  96. package/layout/ApplicationLayout.js +84 -120
  97. package/layout/ApplicationLayout.stories.tsx +126 -0
  98. package/layout/Icons.d.ts +5 -0
  99. package/layout/Icons.js +13 -2
  100. package/layout/SidenavContext.d.ts +5 -0
  101. package/layout/SidenavContext.js +19 -0
  102. package/layout/types.d.ts +52 -0
  103. package/layout/types.js +5 -0
  104. package/link/Link.d.ts +3 -2
  105. package/link/Link.js +61 -86
  106. package/link/Link.stories.tsx +131 -15
  107. package/link/Link.test.js +83 -0
  108. package/link/types.d.ts +9 -29
  109. package/list/List.d.ts +4 -0
  110. package/list/List.js +47 -0
  111. package/list/List.stories.tsx +95 -0
  112. package/list/types.d.ts +7 -0
  113. package/list/types.js +5 -0
  114. package/main.d.ts +12 -9
  115. package/main.js +72 -42
  116. package/number-input/NumberInput.js +14 -24
  117. package/number-input/NumberInput.stories.tsx +5 -5
  118. package/number-input/NumberInput.test.js +506 -0
  119. package/number-input/NumberInputContext.d.ts +4 -0
  120. package/number-input/NumberInputContext.js +5 -2
  121. package/number-input/numberInputContextTypes.d.ts +19 -0
  122. package/number-input/numberInputContextTypes.js +5 -0
  123. package/number-input/types.d.ts +17 -10
  124. package/package.json +9 -6
  125. package/paginator/Paginator.js +19 -46
  126. package/paginator/Paginator.test.js +266 -0
  127. package/password-input/PasswordInput.js +23 -19
  128. package/password-input/PasswordInput.stories.tsx +3 -3
  129. package/password-input/PasswordInput.test.js +180 -0
  130. package/password-input/types.d.ts +29 -19
  131. package/progress-bar/ProgressBar.js +5 -5
  132. package/progress-bar/ProgressBar.stories.jsx +11 -11
  133. package/progress-bar/ProgressBar.test.js +65 -0
  134. package/quick-nav/QuickNav.d.ts +4 -0
  135. package/quick-nav/QuickNav.js +112 -0
  136. package/quick-nav/QuickNav.stories.tsx +237 -0
  137. package/quick-nav/types.d.ts +21 -0
  138. package/quick-nav/types.js +5 -0
  139. package/radio-group/Radio.d.ts +4 -0
  140. package/radio-group/Radio.js +141 -0
  141. package/radio-group/RadioGroup.d.ts +4 -0
  142. package/radio-group/RadioGroup.js +282 -0
  143. package/radio-group/RadioGroup.stories.tsx +100 -0
  144. package/radio-group/RadioGroup.test.js +695 -0
  145. package/radio-group/types.d.ts +114 -0
  146. package/radio-group/types.js +5 -0
  147. package/resultsetTable/ResultsetTable.d.ts +4 -0
  148. package/resultsetTable/ResultsetTable.js +9 -29
  149. package/resultsetTable/ResultsetTable.stories.tsx +275 -0
  150. package/resultsetTable/ResultsetTable.test.js +306 -0
  151. package/resultsetTable/types.d.ts +67 -0
  152. package/resultsetTable/types.js +5 -0
  153. package/row/Row.d.ts +3 -0
  154. package/row/Row.js +127 -0
  155. package/row/Row.stories.tsx +237 -0
  156. package/row/types.d.ts +28 -0
  157. package/row/types.js +5 -0
  158. package/select/Icons.d.ts +10 -0
  159. package/select/Icons.js +93 -0
  160. package/select/Listbox.d.ts +4 -0
  161. package/select/Listbox.js +152 -0
  162. package/select/Option.d.ts +4 -0
  163. package/select/Option.js +110 -0
  164. package/select/Select.d.ts +4 -0
  165. package/select/Select.js +122 -342
  166. package/select/Select.stories.tsx +103 -81
  167. package/select/Select.test.js +2120 -0
  168. package/select/types.d.ts +213 -0
  169. package/select/types.js +5 -0
  170. package/sidenav/Sidenav.d.ts +1 -1
  171. package/sidenav/Sidenav.js +22 -11
  172. package/sidenav/Sidenav.stories.tsx +182 -0
  173. package/sidenav/Sidenav.test.js +56 -0
  174. package/slider/Slider.d.ts +1 -1
  175. package/slider/Slider.js +6 -5
  176. package/slider/Slider.stories.tsx +8 -8
  177. package/slider/Slider.test.js +150 -0
  178. package/slider/types.d.ts +4 -0
  179. package/spinner/Spinner.js +3 -3
  180. package/spinner/Spinner.stories.jsx +1 -0
  181. package/spinner/Spinner.test.js +64 -0
  182. package/stack/Stack.d.ts +3 -0
  183. package/stack/Stack.js +97 -0
  184. package/stack/Stack.stories.tsx +164 -0
  185. package/stack/types.d.ts +24 -0
  186. package/stack/types.js +5 -0
  187. package/switch/Switch.d.ts +1 -1
  188. package/switch/Switch.js +37 -21
  189. package/switch/Switch.stories.tsx +15 -15
  190. package/switch/Switch.test.js +98 -0
  191. package/switch/types.d.ts +6 -2
  192. package/table/Table.js +3 -3
  193. package/table/Table.stories.jsx +2 -1
  194. package/table/Table.test.js +26 -0
  195. package/tabs/Tabs.d.ts +1 -1
  196. package/tabs/Tabs.js +20 -20
  197. package/tabs/Tabs.stories.tsx +112 -0
  198. package/tabs/Tabs.test.js +140 -0
  199. package/tabs/types.d.ts +29 -18
  200. package/tabs-nav/NavTabs.d.ts +8 -0
  201. package/tabs-nav/NavTabs.js +125 -0
  202. package/tabs-nav/NavTabs.stories.tsx +170 -0
  203. package/tabs-nav/NavTabs.test.js +82 -0
  204. package/tabs-nav/Tab.d.ts +4 -0
  205. package/tabs-nav/Tab.js +132 -0
  206. package/tabs-nav/types.d.ts +53 -0
  207. package/tabs-nav/types.js +5 -0
  208. package/tag/Tag.d.ts +1 -1
  209. package/tag/Tag.js +18 -28
  210. package/tag/Tag.stories.tsx +26 -29
  211. package/tag/Tag.test.js +60 -0
  212. package/tag/types.d.ts +23 -14
  213. package/text/Text.d.ts +7 -0
  214. package/text/Text.js +30 -0
  215. package/text/Text.stories.tsx +19 -0
  216. package/text-input/Suggestion.d.ts +4 -0
  217. package/text-input/Suggestion.js +55 -0
  218. package/text-input/TextInput.d.ts +4 -0
  219. package/text-input/TextInput.js +91 -146
  220. package/text-input/TextInput.stories.tsx +474 -0
  221. package/text-input/TextInput.test.js +1712 -0
  222. package/text-input/types.d.ts +178 -0
  223. package/text-input/types.js +5 -0
  224. package/textarea/Textarea.d.ts +4 -0
  225. package/textarea/Textarea.js +39 -79
  226. package/textarea/Textarea.stories.jsx +37 -15
  227. package/textarea/Textarea.test.js +437 -0
  228. package/textarea/types.d.ts +137 -0
  229. package/textarea/types.js +5 -0
  230. package/toggle-group/ToggleGroup.d.ts +4 -0
  231. package/toggle-group/ToggleGroup.js +18 -46
  232. package/toggle-group/ToggleGroup.stories.tsx +27 -32
  233. package/toggle-group/ToggleGroup.test.js +156 -0
  234. package/toggle-group/types.d.ts +105 -0
  235. package/toggle-group/types.js +5 -0
  236. package/useTheme.d.ts +2 -0
  237. package/useTheme.js +2 -2
  238. package/useTranslatedLabels.d.ts +2 -0
  239. package/useTranslatedLabels.js +20 -0
  240. package/wizard/Wizard.d.ts +1 -1
  241. package/wizard/Wizard.js +107 -46
  242. package/wizard/{Wizard.stories.jsx → Wizard.stories.tsx} +13 -23
  243. package/wizard/Wizard.test.js +141 -0
  244. package/wizard/types.d.ts +9 -9
  245. package/ThemeContext.js +0 -246
  246. package/V3Select/V3Select.js +0 -455
  247. package/V3Select/index.d.ts +0 -27
  248. package/V3Textarea/V3Textarea.js +0 -260
  249. package/V3Textarea/index.d.ts +0 -27
  250. package/chip/index.d.ts +0 -22
  251. package/date/Date.js +0 -373
  252. package/date/index.d.ts +0 -27
  253. package/file-input/index.d.ts +0 -81
  254. package/heading/index.d.ts +0 -17
  255. package/input-text/Icons.js +0 -22
  256. package/input-text/InputText.js +0 -611
  257. package/input-text/index.d.ts +0 -36
  258. package/radio/Radio.d.ts +0 -4
  259. package/radio/Radio.js +0 -174
  260. package/radio/Radio.stories.tsx +0 -192
  261. package/radio/types.d.ts +0 -54
  262. package/resultsetTable/index.d.ts +0 -19
  263. package/select/index.d.ts +0 -131
  264. package/text-input/index.d.ts +0 -135
  265. package/textarea/index.d.ts +0 -117
  266. package/toggle/Toggle.js +0 -186
  267. package/toggle/index.d.ts +0 -21
  268. package/toggle-group/index.d.ts +0 -21
  269. package/upload/Upload.js +0 -201
  270. package/upload/buttons-upload/ButtonsUpload.js +0 -111
  271. package/upload/buttons-upload/Icons.js +0 -40
  272. package/upload/dragAndDropArea/DragAndDropArea.js +0 -225
  273. package/upload/dragAndDropArea/Icons.js +0 -39
  274. package/upload/file-upload/FileToUpload.js +0 -115
  275. package/upload/file-upload/Icons.js +0 -66
  276. package/upload/files-upload/FilesToUpload.js +0 -109
  277. package/upload/index.d.ts +0 -15
  278. package/upload/transaction/Icons.js +0 -160
  279. package/upload/transaction/Transaction.js +0 -104
  280. package/upload/transactions/Transactions.js +0 -94
  281. package/wizard/Icons.js +0 -65
package/chip/Chip.js CHANGED
@@ -9,23 +9,19 @@ Object.defineProperty(exports, "__esModule", {
9
9
  });
10
10
  exports["default"] = void 0;
11
11
 
12
- var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray"));
12
+ var _typeof2 = _interopRequireDefault(require("@babel/runtime/helpers/typeof"));
13
13
 
14
14
  var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
15
15
 
16
- var _typeof2 = _interopRequireDefault(require("@babel/runtime/helpers/typeof"));
17
-
18
16
  var _react = _interopRequireDefault(require("react"));
19
17
 
20
18
  var _styledComponents = _interopRequireWildcard(require("styled-components"));
21
19
 
22
- var _propTypes = _interopRequireDefault(require("prop-types"));
23
-
24
20
  var _variables = require("../common/variables.js");
25
21
 
26
22
  var _utils = require("../common/utils.js");
27
23
 
28
- var _useTheme = _interopRequireDefault(require("../useTheme.js"));
24
+ var _useTheme = _interopRequireDefault(require("../useTheme"));
29
25
 
30
26
  var _templateObject, _templateObject2, _templateObject3, _templateObject4, _templateObject5;
31
27
 
@@ -37,9 +33,7 @@ var DxcChip = function DxcChip(_ref) {
37
33
  var label = _ref.label,
38
34
  suffixIcon = _ref.suffixIcon,
39
35
  prefixIcon = _ref.prefixIcon,
40
- suffixIconSrc = _ref.suffixIconSrc,
41
36
  onClickSuffix = _ref.onClickSuffix,
42
- prefixIconSrc = _ref.prefixIconSrc,
43
37
  onClickPrefix = _ref.onClickPrefix,
44
38
  disabled = _ref.disabled,
45
39
  margin = _ref.margin,
@@ -51,49 +45,33 @@ var DxcChip = function DxcChip(_ref) {
51
45
  }, /*#__PURE__*/_react["default"].createElement(StyledDxcChip, {
52
46
  disabled: disabled,
53
47
  margin: margin
54
- }, prefixIcon ? /*#__PURE__*/_react["default"].createElement(IconContainer, {
48
+ }, prefixIcon && /*#__PURE__*/_react["default"].createElement(IconContainer, {
55
49
  disabled: disabled,
56
50
  prefixIcon: true,
57
51
  label: label,
58
52
  mode: "prefix",
59
53
  tabIndex: typeof onClickPrefix === "function" && !disabled ? tabIndex : -1,
60
54
  onClick: function onClick() {
61
- return onClickPrefix && !disabled && onClickPrefix(label);
62
- },
63
- interactuable: typeof onClickPrefix === "function" && !disabled
64
- }, (0, _typeof2["default"])(prefixIcon) === "object" ? prefixIcon : /*#__PURE__*/_react["default"].createElement(prefixIcon)) : prefixIconSrc && /*#__PURE__*/_react["default"].createElement(PrefixIconContainer, {
65
- disabled: disabled,
66
- src: prefixIconSrc,
67
- label: label,
68
- tabIndex: typeof onClickPrefix === "function" && !disabled ? tabIndex : -1,
69
- onClick: function onClick() {
70
- return onClickPrefix && !disabled && onClickPrefix(label);
55
+ return onClickPrefix && !disabled && onClickPrefix();
71
56
  },
72
57
  interactuable: typeof onClickPrefix === "function" && !disabled
73
- }), label && /*#__PURE__*/_react["default"].createElement(ChipTextContainer, {
74
- disabled: disabled,
75
- prefixIconSrc: prefixIconSrc,
76
- suffixIconSrc: suffixIconSrc
77
- }, label), suffixIcon ? /*#__PURE__*/_react["default"].createElement(IconContainer, {
58
+ }, typeof prefixIcon === "string" ? /*#__PURE__*/_react["default"].createElement(PrefixIconContainer, {
59
+ src: prefixIcon
60
+ }) : prefixIcon), label && /*#__PURE__*/_react["default"].createElement(ChipTextContainer, {
61
+ disabled: disabled
62
+ }, label), suffixIcon && /*#__PURE__*/_react["default"].createElement(IconContainer, {
78
63
  disabled: disabled,
79
64
  suffixIcon: true,
80
65
  mode: "suffix",
81
66
  label: label,
82
67
  tabIndex: typeof onClickSuffix === "function" && !disabled ? tabIndex : -1,
83
68
  onClick: function onClick() {
84
- return onClickSuffix && !disabled && onClickSuffix(label);
69
+ return onClickSuffix && !disabled && onClickSuffix();
85
70
  },
86
71
  interactuable: typeof onClickSuffix === "function" && !disabled
87
- }, (0, _typeof2["default"])(suffixIcon) === "object" ? suffixIcon : /*#__PURE__*/_react["default"].createElement(suffixIcon)) : suffixIconSrc && /*#__PURE__*/_react["default"].createElement(SuffixIconContainer, {
88
- disabled: disabled,
89
- src: suffixIconSrc,
90
- label: label,
91
- tabIndex: typeof onClickSuffix === "function" && !disabled ? tabIndex : -1,
92
- onClick: function onClick() {
93
- return onClickSuffix && !disabled && onClickSuffix(label);
94
- },
95
- interactuable: typeof onClickSuffix === "function" && !disabled
96
- })));
72
+ }, typeof suffixIcon === "string" ? /*#__PURE__*/_react["default"].createElement(SuffixIconContainer, {
73
+ src: suffixIcon
74
+ }) : suffixIcon)));
97
75
  };
98
76
 
99
77
  var getCursor = function getCursor(interactuable, disabled) {
@@ -159,34 +137,14 @@ var ChipTextContainer = _styledComponents["default"].span(_templateObject2 || (_
159
137
  return disabled && "not-allowed" || "default";
160
138
  });
161
139
 
162
- var SuffixIconContainer = _styledComponents["default"].img(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n color: ", ";\n ", "\n margin-left: ", ";\n width: ", ";\n height: ", ";\n"])), function (props) {
163
- return props.disabled ? props.theme.disabledIconColor : props.theme.iconColor;
164
- }, function (props) {
165
- return getCursor(props.interactuable, props.disabled);
166
- }, function (props) {
167
- return (props.label || props.suffixIconSrc) && props.theme.iconSpacing || props.prefixIconSrc && "5px";
168
- }, function (props) {
169
- return props.theme.iconSize;
170
- }, function (props) {
171
- return props.theme.iconSize;
172
- });
140
+ var SuffixIconContainer = _styledComponents["default"].img(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])([""])));
173
141
 
174
- var PrefixIconContainer = _styledComponents["default"].img(_templateObject4 || (_templateObject4 = (0, _taggedTemplateLiteral2["default"])(["\n color: ", ";\n ", "\n margin-right: ", ";\n width: ", ";\n height: ", ";\n"])), function (props) {
175
- return props.disabled ? props.theme.disabledIconColor : props.theme.iconColor;
176
- }, function (props) {
177
- return getCursor(props.interactuable, props.disabled);
178
- }, function (props) {
179
- return (props.label || props.suffixIconSrc) && props.theme.iconSpacing || props.prefixIconSrc && "5px";
180
- }, function (props) {
181
- return props.theme.iconSize;
182
- }, function (props) {
183
- return props.theme.iconSize;
184
- });
142
+ var PrefixIconContainer = _styledComponents["default"].img(_templateObject4 || (_templateObject4 = (0, _taggedTemplateLiteral2["default"])([""])));
185
143
 
186
144
  var IconContainer = _styledComponents["default"].div(_templateObject5 || (_templateObject5 = (0, _taggedTemplateLiteral2["default"])(["\n color: ", ";\n ", "\n ", "\n width: ", ";\n height: ", ";\n overflow: hidden;\n\n img,\n svg {\n height: 100%;\n width: 100%;\n }\n &:focus {\n outline-color: ", ";\n outline-width: 2px;\n ", "\n }\n"])), function (props) {
187
145
  return props.disabled ? props.theme.disabledIconColor : props.theme.iconColor;
188
146
  }, function (props) {
189
- return props.prefixIcon ? "margin-right: ".concat((props.label || props.suffixIcon || props.suffixIconSrc) && props.theme.iconSpacing || (props.prefixIcon || props.prefixIconSrc) && "0", ";") : "margin-left: ".concat((props.label || props.prefixIcon || props.prefixIconSrc) && props.theme.iconSpacing || (props.prefixIcon || props.prefixIconSrc) && "0", ";");
147
+ return props.prefixIcon ? "margin-right: ".concat((props.label || props.suffixIcon) && props.theme.iconSpacing || props.prefixIcon && "0", ";") : "margin-left: ".concat((props.label || props.prefixIcon) && props.theme.iconSpacing || props.prefixIcon && "0", ";");
190
148
  }, function (props) {
191
149
  return getCursor(props.interactuable, props.disabled);
192
150
  }, function (props) {
@@ -199,23 +157,5 @@ var IconContainer = _styledComponents["default"].div(_templateObject5 || (_templ
199
157
  return props.disabled && "outline: none;";
200
158
  });
201
159
 
202
- DxcChip.propTypes = {
203
- label: _propTypes["default"].string,
204
- disabled: _propTypes["default"].bool,
205
- theme: _propTypes["default"].oneOf(["dark", "light"]),
206
- suffixIcon: _propTypes["default"].oneOfType([_propTypes["default"].element, _propTypes["default"].func]),
207
- prefixIcon: _propTypes["default"].oneOfType([_propTypes["default"].element, _propTypes["default"].func]),
208
- suffixIconSrc: _propTypes["default"].string,
209
- prefixIconSrc: _propTypes["default"].string,
210
- onClickSuffix: _propTypes["default"].func,
211
- onClickPrefix: _propTypes["default"].func,
212
- margin: _propTypes["default"].oneOfType([_propTypes["default"].shape({
213
- top: _propTypes["default"].oneOf(Object.keys(_variables.spaces)),
214
- bottom: _propTypes["default"].oneOf(Object.keys(_variables.spaces)),
215
- left: _propTypes["default"].oneOf(Object.keys(_variables.spaces)),
216
- right: _propTypes["default"].oneOf(Object.keys(_variables.spaces))
217
- }), _propTypes["default"].oneOf((0, _toConsumableArray2["default"])(Object.keys(_variables.spaces)))]),
218
- tabIndex: _propTypes["default"].number
219
- };
220
160
  var _default = DxcChip;
221
161
  exports["default"] = _default;
@@ -9,14 +9,12 @@ export default {
9
9
  component: DxcChip,
10
10
  };
11
11
 
12
- const iconSVG = () => {
13
- return (
14
- <svg viewBox="0 0 24 24" fill="currentColor">
15
- <path d="M0 0h24v24H0z" fill="none" />
16
- <path d="M12 21.35l-1.45-1.32C5.4 15.36 2 12.28 2 8.5 2 5.42 4.42 3 7.5 3c1.74 0 3.41.81 4.5 2.09C13.09 3.81 14.76 3 16.5 3 19.58 3 22 5.42 22 8.5c0 3.78-3.4 6.86-8.55 11.54L12 21.35z" />
17
- </svg>
18
- );
19
- };
12
+ const iconSVG = (
13
+ <svg viewBox="0 0 24 24" fill="currentColor">
14
+ <path d="M0 0h24v24H0z" fill="none" />
15
+ <path d="M12 21.35l-1.45-1.32C5.4 15.36 2 12.28 2 8.5 2 5.42 4.42 3 7.5 3c1.74 0 3.41.81 4.5 2.09C13.09 3.81 14.76 3 16.5 3 19.58 3 22 5.42 22 8.5c0 3.78-3.4 6.86-8.55 11.54L12 21.35z" />
16
+ </svg>
17
+ );
20
18
 
21
19
  export const Chromatic = () => (
22
20
  <>
@@ -0,0 +1,56 @@
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 _Chip = _interopRequireDefault(require("./Chip"));
10
+
11
+ var _invision = _interopRequireDefault(require("../../app/src/images/invision.svg"));
12
+
13
+ describe("Chip component tests", function () {
14
+ test("Chip renders with correct text", function () {
15
+ var _render = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Chip["default"], {
16
+ label: "Chip"
17
+ })),
18
+ getByText = _render.getByText;
19
+
20
+ expect(getByText("Chip")).toBeTruthy();
21
+ });
22
+ test("Calls correct function when clicking on prefix icon", function () {
23
+ var onClick = jest.fn();
24
+
25
+ var _render2 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Chip["default"], {
26
+ label: "Chip",
27
+ prefixIcon: _invision["default"],
28
+ onClickPrefix: onClick
29
+ })),
30
+ getByText = _render2.getByText,
31
+ getByRole = _render2.getByRole;
32
+
33
+ expect(getByText("Chip")).toBeTruthy();
34
+
35
+ _react2.fireEvent.click(getByRole("img"));
36
+
37
+ expect(onClick).toHaveBeenCalled();
38
+ });
39
+ test("Calls correct function when clicking on suffix icon", function () {
40
+ var onClick = jest.fn();
41
+
42
+ var _render3 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Chip["default"], {
43
+ label: "Chip",
44
+ suffixIcon: _invision["default"],
45
+ onClickSuffix: onClick
46
+ })),
47
+ getByText = _render3.getByText,
48
+ getByRole = _render3.getByRole;
49
+
50
+ expect(getByText("Chip")).toBeTruthy();
51
+
52
+ _react2.fireEvent.click(getByRole("img"));
53
+
54
+ expect(onClick).toHaveBeenCalled();
55
+ });
56
+ });
@@ -0,0 +1,45 @@
1
+ /// <reference types="react" />
2
+ declare type Space = "xxsmall" | "xsmall" | "small" | "medium" | "large" | "xlarge" | "xxlarge";
3
+ declare type Margin = {
4
+ top?: Space;
5
+ bottom?: Space;
6
+ left?: Space;
7
+ right?: Space;
8
+ };
9
+ declare type SVG = React.SVGProps<SVGSVGElement>;
10
+ declare type Props = {
11
+ /**
12
+ * Text to be placed on the chip.
13
+ */
14
+ label?: string;
15
+ /**
16
+ * Element or path used as icon to be placed after the chip label.
17
+ */
18
+ suffixIcon?: string | SVG;
19
+ /**
20
+ * Element or path used as icon to be placed before the chip label.
21
+ */
22
+ prefixIcon?: string | SVG;
23
+ /**
24
+ * This function will be called when the suffix is clicked.
25
+ */
26
+ onClickSuffix?: () => void;
27
+ /**
28
+ * This function will be called when the prefix is clicked.
29
+ */
30
+ onClickPrefix?: () => void;
31
+ /**
32
+ * If true, the component will be disabled.
33
+ */
34
+ disabled?: boolean;
35
+ /**
36
+ * Size of the margin to be applied to the component ('xxsmall' | 'xsmall' | 'small' | 'medium' | 'large' | 'xlarge' | 'xxlarge').
37
+ * You can pass an object with 'top', 'bottom', 'left' and 'right' properties in order to specify different margin sizes.
38
+ */
39
+ margin?: Space | Margin;
40
+ /**
41
+ * Value of the tabindex attribute.
42
+ */
43
+ tabIndex?: number;
44
+ };
45
+ export default Props;
package/chip/types.js ADDED
@@ -0,0 +1,5 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });