@dxc-technology/halstack-react 0.0.0-c908d78 → 0.0.0-c9c1158

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 (355) hide show
  1. package/BackgroundColorContext.d.ts +10 -0
  2. package/BackgroundColorContext.js +7 -22
  3. package/HalstackContext.d.ts +1353 -0
  4. package/HalstackContext.js +310 -0
  5. package/README.md +47 -0
  6. package/accordion/Accordion.d.ts +1 -1
  7. package/accordion/Accordion.js +119 -192
  8. package/accordion/Accordion.stories.tsx +283 -0
  9. package/accordion/Accordion.test.js +56 -0
  10. package/accordion/types.d.ts +12 -23
  11. package/accordion-group/AccordionGroup.d.ts +5 -4
  12. package/accordion-group/AccordionGroup.js +39 -108
  13. package/accordion-group/AccordionGroup.stories.tsx +252 -0
  14. package/accordion-group/AccordionGroup.test.js +98 -0
  15. package/accordion-group/AccordionGroupAccordion.d.ts +4 -0
  16. package/accordion-group/AccordionGroupAccordion.js +31 -0
  17. package/accordion-group/types.d.ts +18 -23
  18. package/alert/Alert.js +24 -57
  19. package/alert/Alert.stories.tsx +198 -0
  20. package/alert/Alert.test.js +75 -0
  21. package/alert/types.d.ts +6 -6
  22. package/badge/Badge.d.ts +4 -0
  23. package/badge/Badge.js +9 -20
  24. package/badge/types.d.ts +5 -0
  25. package/bleed/Bleed.d.ts +3 -0
  26. package/bleed/Bleed.js +43 -0
  27. package/bleed/Bleed.stories.tsx +342 -0
  28. package/bleed/types.d.ts +37 -0
  29. package/bleed/types.js +5 -0
  30. package/box/Box.d.ts +1 -1
  31. package/box/Box.js +32 -83
  32. package/box/Box.stories.tsx +38 -51
  33. package/box/Box.test.js +13 -0
  34. package/box/types.d.ts +3 -18
  35. package/bulleted-list/BulletedList.d.ts +7 -0
  36. package/bulleted-list/BulletedList.js +99 -0
  37. package/bulleted-list/BulletedList.stories.tsx +116 -0
  38. package/bulleted-list/types.d.ts +38 -0
  39. package/bulleted-list/types.js +5 -0
  40. package/button/Button.d.ts +1 -1
  41. package/button/Button.js +64 -120
  42. package/button/Button.stories.tsx +328 -277
  43. package/button/Button.test.js +36 -0
  44. package/button/types.d.ts +14 -14
  45. package/card/Card.d.ts +1 -1
  46. package/card/Card.js +59 -104
  47. package/card/Card.stories.tsx +171 -0
  48. package/card/Card.test.js +39 -0
  49. package/card/types.d.ts +8 -15
  50. package/checkbox/Checkbox.d.ts +2 -2
  51. package/checkbox/Checkbox.js +147 -180
  52. package/checkbox/Checkbox.stories.tsx +166 -136
  53. package/checkbox/Checkbox.test.js +199 -0
  54. package/checkbox/types.d.ts +20 -8
  55. package/chip/Chip.d.ts +4 -0
  56. package/chip/Chip.js +48 -148
  57. package/chip/Chip.stories.tsx +214 -0
  58. package/chip/Chip.test.js +41 -0
  59. package/chip/types.d.ts +45 -0
  60. package/chip/types.js +5 -0
  61. package/common/OpenSans.css +68 -80
  62. package/common/coreTokens.d.ts +237 -0
  63. package/common/coreTokens.js +184 -0
  64. package/common/utils.d.ts +1 -0
  65. package/common/utils.js +6 -12
  66. package/common/variables.d.ts +1499 -0
  67. package/common/variables.js +1119 -1317
  68. package/container/Container.d.ts +4 -0
  69. package/container/Container.js +198 -0
  70. package/container/Container.stories.tsx +229 -0
  71. package/container/types.d.ts +74 -0
  72. package/container/types.js +5 -0
  73. package/date-input/Calendar.d.ts +4 -0
  74. package/date-input/Calendar.js +214 -0
  75. package/date-input/DateInput.js +175 -313
  76. package/date-input/DateInput.stories.tsx +285 -0
  77. package/date-input/DateInput.test.js +808 -0
  78. package/date-input/DatePicker.d.ts +4 -0
  79. package/date-input/DatePicker.js +115 -0
  80. package/date-input/Icons.d.ts +6 -0
  81. package/date-input/Icons.js +58 -0
  82. package/date-input/YearPicker.d.ts +4 -0
  83. package/date-input/YearPicker.js +100 -0
  84. package/date-input/types.d.ts +86 -22
  85. package/dialog/Dialog.d.ts +1 -1
  86. package/dialog/Dialog.js +72 -130
  87. package/dialog/Dialog.stories.tsx +195 -0
  88. package/dialog/Dialog.test.js +307 -0
  89. package/dialog/types.d.ts +18 -25
  90. package/dropdown/Dropdown.d.ts +1 -1
  91. package/dropdown/Dropdown.js +245 -328
  92. package/dropdown/Dropdown.stories.tsx +438 -0
  93. package/dropdown/Dropdown.test.js +599 -0
  94. package/dropdown/DropdownMenu.d.ts +4 -0
  95. package/dropdown/DropdownMenu.js +63 -0
  96. package/dropdown/DropdownMenuItem.d.ts +4 -0
  97. package/dropdown/DropdownMenuItem.js +67 -0
  98. package/dropdown/types.d.ts +37 -28
  99. package/file-input/FileInput.d.ts +4 -0
  100. package/file-input/FileInput.js +274 -327
  101. package/file-input/FileInput.stories.tsx +618 -0
  102. package/file-input/FileInput.test.js +459 -0
  103. package/file-input/FileItem.d.ts +4 -0
  104. package/file-input/FileItem.js +54 -112
  105. package/file-input/types.d.ts +129 -0
  106. package/file-input/types.js +5 -0
  107. package/flex/Flex.d.ts +4 -0
  108. package/flex/Flex.js +57 -0
  109. package/flex/Flex.stories.tsx +112 -0
  110. package/flex/types.d.ts +97 -0
  111. package/flex/types.js +5 -0
  112. package/footer/Footer.d.ts +1 -1
  113. package/footer/Footer.js +61 -192
  114. package/footer/{Footer.stories.jsx → Footer.stories.tsx} +38 -37
  115. package/footer/Footer.test.js +85 -0
  116. package/footer/Icons.d.ts +2 -0
  117. package/footer/Icons.js +4 -9
  118. package/footer/types.d.ts +36 -33
  119. package/grid/Grid.d.ts +7 -0
  120. package/grid/Grid.js +76 -0
  121. package/grid/Grid.stories.tsx +219 -0
  122. package/grid/types.d.ts +115 -0
  123. package/grid/types.js +5 -0
  124. package/header/Header.d.ts +4 -3
  125. package/header/Header.js +106 -199
  126. package/header/Header.stories.tsx +251 -0
  127. package/header/Header.test.js +66 -0
  128. package/header/Icons.d.ts +2 -0
  129. package/header/Icons.js +4 -9
  130. package/header/types.d.ts +4 -17
  131. package/heading/Heading.d.ts +4 -0
  132. package/heading/Heading.js +16 -55
  133. package/heading/Heading.stories.tsx +54 -0
  134. package/heading/Heading.test.js +169 -0
  135. package/heading/types.d.ts +33 -0
  136. package/heading/types.js +5 -0
  137. package/image/Image.d.ts +4 -0
  138. package/image/Image.js +70 -0
  139. package/image/Image.stories.tsx +127 -0
  140. package/image/types.d.ts +72 -0
  141. package/image/types.js +5 -0
  142. package/inset/Inset.d.ts +3 -0
  143. package/inset/Inset.js +43 -0
  144. package/inset/Inset.stories.tsx +230 -0
  145. package/inset/types.d.ts +37 -0
  146. package/inset/types.js +5 -0
  147. package/layout/ApplicationLayout.d.ts +20 -0
  148. package/layout/ApplicationLayout.js +83 -184
  149. package/layout/ApplicationLayout.stories.tsx +162 -0
  150. package/layout/Icons.d.ts +8 -0
  151. package/layout/Icons.js +51 -48
  152. package/layout/SidenavContext.d.ts +5 -0
  153. package/layout/SidenavContext.js +13 -0
  154. package/layout/types.d.ts +41 -0
  155. package/layout/types.js +5 -0
  156. package/link/Link.d.ts +3 -2
  157. package/link/Link.js +65 -111
  158. package/link/Link.stories.tsx +253 -0
  159. package/link/Link.test.js +63 -0
  160. package/link/types.d.ts +15 -35
  161. package/main.d.ts +16 -13
  162. package/main.js +71 -91
  163. package/nav-tabs/NavTabs.d.ts +8 -0
  164. package/nav-tabs/NavTabs.js +90 -0
  165. package/nav-tabs/NavTabs.stories.tsx +274 -0
  166. package/nav-tabs/NavTabs.test.js +75 -0
  167. package/nav-tabs/Tab.d.ts +4 -0
  168. package/nav-tabs/Tab.js +117 -0
  169. package/nav-tabs/types.d.ts +52 -0
  170. package/nav-tabs/types.js +5 -0
  171. package/number-input/NumberInput.d.ts +11 -0
  172. package/number-input/NumberInput.js +28 -89
  173. package/number-input/{NumberInput.stories.jsx → NumberInput.stories.tsx} +44 -28
  174. package/number-input/NumberInput.test.js +830 -0
  175. package/number-input/types.d.ts +130 -0
  176. package/number-input/types.js +5 -0
  177. package/package.json +46 -45
  178. package/paginator/Icons.d.ts +5 -0
  179. package/paginator/Icons.js +21 -47
  180. package/paginator/Paginator.js +35 -95
  181. package/paginator/Paginator.stories.tsx +24 -0
  182. package/paginator/Paginator.test.js +335 -0
  183. package/paginator/types.d.ts +3 -3
  184. package/paragraph/Paragraph.d.ts +5 -0
  185. package/paragraph/Paragraph.js +27 -0
  186. package/paragraph/Paragraph.stories.tsx +27 -0
  187. package/password-input/Icons.d.ts +6 -0
  188. package/password-input/Icons.js +35 -0
  189. package/password-input/PasswordInput.js +60 -125
  190. package/password-input/PasswordInput.stories.tsx +3 -34
  191. package/password-input/PasswordInput.test.js +198 -0
  192. package/password-input/types.d.ts +35 -24
  193. package/progress-bar/ProgressBar.js +69 -89
  194. package/progress-bar/ProgressBar.stories.tsx +93 -0
  195. package/progress-bar/ProgressBar.test.js +93 -0
  196. package/progress-bar/types.d.ts +3 -3
  197. package/quick-nav/QuickNav.d.ts +4 -0
  198. package/quick-nav/QuickNav.js +94 -0
  199. package/quick-nav/QuickNav.stories.tsx +356 -0
  200. package/quick-nav/types.d.ts +21 -0
  201. package/quick-nav/types.js +5 -0
  202. package/radio-group/Radio.d.ts +4 -0
  203. package/radio-group/Radio.js +124 -0
  204. package/radio-group/RadioGroup.d.ts +4 -0
  205. package/radio-group/RadioGroup.js +235 -0
  206. package/radio-group/RadioGroup.stories.tsx +214 -0
  207. package/radio-group/RadioGroup.test.js +756 -0
  208. package/radio-group/types.d.ts +114 -0
  209. package/radio-group/types.js +5 -0
  210. package/resultset-table/Icons.d.ts +7 -0
  211. package/resultset-table/Icons.js +47 -0
  212. package/resultset-table/ResultsetTable.d.ts +4 -0
  213. package/resultset-table/ResultsetTable.js +159 -0
  214. package/resultset-table/ResultsetTable.stories.tsx +300 -0
  215. package/resultset-table/ResultsetTable.test.js +305 -0
  216. package/resultset-table/types.d.ts +67 -0
  217. package/resultset-table/types.js +5 -0
  218. package/select/Icons.d.ts +10 -0
  219. package/select/Icons.js +89 -0
  220. package/select/Listbox.d.ts +4 -0
  221. package/select/Listbox.js +143 -0
  222. package/select/Option.d.ts +4 -0
  223. package/select/Option.js +80 -0
  224. package/select/Select.d.ts +4 -0
  225. package/select/Select.js +221 -504
  226. package/select/Select.stories.tsx +971 -0
  227. package/select/Select.test.js +2334 -0
  228. package/select/types.d.ts +209 -0
  229. package/select/types.js +5 -0
  230. package/sidenav/Icons.d.ts +7 -0
  231. package/sidenav/Icons.js +47 -0
  232. package/sidenav/Sidenav.d.ts +10 -0
  233. package/sidenav/Sidenav.js +135 -81
  234. package/sidenav/Sidenav.stories.tsx +282 -0
  235. package/sidenav/Sidenav.test.js +37 -0
  236. package/sidenav/types.d.ts +76 -0
  237. package/sidenav/types.js +5 -0
  238. package/slider/Slider.d.ts +2 -2
  239. package/slider/Slider.js +168 -180
  240. package/slider/Slider.test.js +254 -0
  241. package/slider/types.d.ts +13 -10
  242. package/spinner/Spinner.js +30 -66
  243. package/spinner/{Spinner.stories.jsx → Spinner.stories.tsx} +53 -26
  244. package/spinner/Spinner.test.js +55 -0
  245. package/spinner/types.d.ts +3 -3
  246. package/switch/Switch.d.ts +2 -2
  247. package/switch/Switch.js +154 -114
  248. package/switch/Switch.stories.tsx +45 -68
  249. package/switch/Switch.test.js +180 -0
  250. package/switch/types.d.ts +13 -5
  251. package/table/Table.js +10 -29
  252. package/table/{Table.stories.jsx → Table.stories.tsx} +81 -1
  253. package/table/Table.test.js +21 -0
  254. package/table/types.d.ts +8 -8
  255. package/tabs/Tab.d.ts +4 -0
  256. package/tabs/Tab.js +113 -0
  257. package/tabs/Tabs.d.ts +1 -1
  258. package/tabs/Tabs.js +319 -145
  259. package/tabs/Tabs.stories.tsx +226 -0
  260. package/tabs/Tabs.test.js +294 -0
  261. package/tabs/types.d.ts +48 -27
  262. package/tag/Tag.d.ts +1 -1
  263. package/tag/Tag.js +44 -86
  264. package/tag/Tag.stories.tsx +38 -28
  265. package/tag/Tag.test.js +49 -0
  266. package/tag/types.d.ts +25 -16
  267. package/text-input/Icons.d.ts +8 -0
  268. package/text-input/Icons.js +56 -0
  269. package/text-input/Suggestion.d.ts +4 -0
  270. package/text-input/Suggestion.js +67 -0
  271. package/text-input/Suggestions.d.ts +4 -0
  272. package/text-input/Suggestions.js +89 -0
  273. package/text-input/TextInput.d.ts +4 -0
  274. package/text-input/TextInput.js +310 -543
  275. package/text-input/TextInput.stories.tsx +465 -0
  276. package/text-input/TextInput.test.js +1739 -0
  277. package/text-input/types.d.ts +205 -0
  278. package/text-input/types.js +5 -0
  279. package/textarea/Textarea.d.ts +4 -0
  280. package/textarea/Textarea.js +94 -171
  281. package/textarea/Textarea.stories.tsx +175 -0
  282. package/textarea/Textarea.test.js +406 -0
  283. package/textarea/types.d.ts +141 -0
  284. package/textarea/types.js +5 -0
  285. package/toggle-group/ToggleGroup.d.ts +4 -0
  286. package/toggle-group/ToggleGroup.js +103 -142
  287. package/toggle-group/ToggleGroup.stories.tsx +218 -0
  288. package/toggle-group/ToggleGroup.test.js +137 -0
  289. package/toggle-group/types.d.ts +114 -0
  290. package/toggle-group/types.js +5 -0
  291. package/typography/Typography.d.ts +4 -0
  292. package/typography/Typography.js +23 -0
  293. package/typography/Typography.stories.tsx +198 -0
  294. package/typography/types.d.ts +18 -0
  295. package/typography/types.js +5 -0
  296. package/useTheme.d.ts +1252 -0
  297. package/useTheme.js +4 -11
  298. package/useTranslatedLabels.d.ts +85 -0
  299. package/useTranslatedLabels.js +14 -0
  300. package/utils/BaseTypography.d.ts +21 -0
  301. package/utils/BaseTypography.js +94 -0
  302. package/utils/FocusLock.d.ts +13 -0
  303. package/utils/FocusLock.js +114 -0
  304. package/wizard/Wizard.d.ts +4 -0
  305. package/wizard/Wizard.js +130 -151
  306. package/wizard/Wizard.stories.tsx +253 -0
  307. package/wizard/Wizard.test.js +114 -0
  308. package/wizard/types.d.ts +64 -0
  309. package/wizard/types.js +5 -0
  310. package/ThemeContext.js +0 -246
  311. package/V3Select/V3Select.js +0 -455
  312. package/V3Select/index.d.ts +0 -27
  313. package/V3Textarea/V3Textarea.js +0 -260
  314. package/V3Textarea/index.d.ts +0 -27
  315. package/chip/index.d.ts +0 -22
  316. package/common/RequiredComponent.js +0 -32
  317. package/date/Date.js +0 -373
  318. package/date/index.d.ts +0 -27
  319. package/file-input/index.d.ts +0 -81
  320. package/heading/index.d.ts +0 -17
  321. package/input-text/Icons.js +0 -22
  322. package/input-text/InputText.js +0 -611
  323. package/input-text/index.d.ts +0 -36
  324. package/number-input/NumberInputContext.js +0 -16
  325. package/number-input/index.d.ts +0 -113
  326. package/progress-bar/ProgressBar.stories.jsx +0 -58
  327. package/radio/Radio.d.ts +0 -4
  328. package/radio/Radio.js +0 -174
  329. package/radio/Radio.stories.tsx +0 -192
  330. package/radio/types.d.ts +0 -54
  331. package/resultsetTable/ResultsetTable.js +0 -274
  332. package/resultsetTable/index.d.ts +0 -19
  333. package/select/index.d.ts +0 -131
  334. package/sidenav/index.d.ts +0 -13
  335. package/text-input/index.d.ts +0 -135
  336. package/textarea/Textarea.stories.jsx +0 -135
  337. package/textarea/index.d.ts +0 -117
  338. package/toggle/Toggle.js +0 -186
  339. package/toggle/index.d.ts +0 -21
  340. package/toggle-group/index.d.ts +0 -21
  341. package/upload/Upload.js +0 -201
  342. package/upload/buttons-upload/ButtonsUpload.js +0 -111
  343. package/upload/buttons-upload/Icons.js +0 -40
  344. package/upload/dragAndDropArea/DragAndDropArea.js +0 -225
  345. package/upload/dragAndDropArea/Icons.js +0 -39
  346. package/upload/file-upload/FileToUpload.js +0 -115
  347. package/upload/file-upload/Icons.js +0 -66
  348. package/upload/files-upload/FilesToUpload.js +0 -109
  349. package/upload/index.d.ts +0 -15
  350. package/upload/transaction/Icons.js +0 -160
  351. package/upload/transaction/Transaction.js +0 -104
  352. package/upload/transactions/Transactions.js +0 -94
  353. package/wizard/Icons.js +0 -65
  354. package/wizard/index.d.ts +0 -18
  355. /package/{radio → badge}/types.js +0 -0
package/tag/Tag.js CHANGED
@@ -1,78 +1,56 @@
1
1
  "use strict";
2
2
 
3
3
  var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
-
5
4
  var _typeof3 = require("@babel/runtime/helpers/typeof");
6
-
7
5
  Object.defineProperty(exports, "__esModule", {
8
6
  value: true
9
7
  });
10
8
  exports["default"] = void 0;
11
-
12
- var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
13
-
14
9
  var _typeof2 = _interopRequireDefault(require("@babel/runtime/helpers/typeof"));
15
-
10
+ var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
16
11
  var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
17
-
18
12
  var _react = _interopRequireWildcard(require("react"));
19
-
20
13
  var _styledComponents = _interopRequireWildcard(require("styled-components"));
21
-
22
- var _variables = require("../common/variables.js");
23
-
24
- var _useTheme = _interopRequireDefault(require("../useTheme.js"));
25
-
26
- var _utils = require("../common/utils.js");
27
-
14
+ var _variables = require("../common/variables");
15
+ var _useTheme = _interopRequireDefault(require("../useTheme"));
16
+ var _utils = require("../common/utils");
28
17
  var _Box = _interopRequireDefault(require("../box/Box"));
29
-
30
- var _templateObject, _templateObject2, _templateObject3, _templateObject4, _templateObject5, _templateObject6, _templateObject7, _templateObject8;
31
-
32
- 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); }
33
-
34
- function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof3(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; }
35
-
18
+ var _templateObject, _templateObject2, _templateObject3, _templateObject4, _templateObject5, _templateObject6, _templateObject7;
19
+ function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(e) { return e ? t : r; })(e); }
20
+ function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != _typeof3(e) && "function" != typeof e) return { "default": e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && Object.prototype.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n["default"] = e, t && t.set(e, n), n; }
36
21
  var DxcTag = function DxcTag(_ref) {
37
22
  var icon = _ref.icon,
38
- iconSrc = _ref.iconSrc,
39
- _ref$label = _ref.label,
40
- label = _ref$label === void 0 ? "" : _ref$label,
41
- linkHref = _ref.linkHref,
42
- onClick = _ref.onClick,
43
- _ref$iconBgColor = _ref.iconBgColor,
44
- iconBgColor = _ref$iconBgColor === void 0 ? "#5f249f" : _ref$iconBgColor,
45
- _ref$labelPosition = _ref.labelPosition,
46
- labelPosition = _ref$labelPosition === void 0 ? "after" : _ref$labelPosition,
47
- _ref$newWindow = _ref.newWindow,
48
- newWindow = _ref$newWindow === void 0 ? false : _ref$newWindow,
49
- margin = _ref.margin,
50
- _ref$size = _ref.size,
51
- size = _ref$size === void 0 ? "fitContent" : _ref$size,
52
- _ref$tabIndex = _ref.tabIndex,
53
- tabIndex = _ref$tabIndex === void 0 ? 0 : _ref$tabIndex;
23
+ _ref$label = _ref.label,
24
+ label = _ref$label === void 0 ? "" : _ref$label,
25
+ linkHref = _ref.linkHref,
26
+ onClick = _ref.onClick,
27
+ _ref$iconBgColor = _ref.iconBgColor,
28
+ iconBgColor = _ref$iconBgColor === void 0 ? "#5f249f" : _ref$iconBgColor,
29
+ _ref$labelPosition = _ref.labelPosition,
30
+ labelPosition = _ref$labelPosition === void 0 ? "after" : _ref$labelPosition,
31
+ _ref$newWindow = _ref.newWindow,
32
+ newWindow = _ref$newWindow === void 0 ? false : _ref$newWindow,
33
+ margin = _ref.margin,
34
+ _ref$size = _ref.size,
35
+ size = _ref$size === void 0 ? "fitContent" : _ref$size,
36
+ _ref$tabIndex = _ref.tabIndex,
37
+ tabIndex = _ref$tabIndex === void 0 ? 0 : _ref$tabIndex;
54
38
  var colorsTheme = (0, _useTheme["default"])();
55
-
56
39
  var _useState = (0, _react.useState)(false),
57
- _useState2 = (0, _slicedToArray2["default"])(_useState, 2),
58
- isHovered = _useState2[0],
59
- changeIsHovered = _useState2[1];
60
-
40
+ _useState2 = (0, _slicedToArray2["default"])(_useState, 2),
41
+ isHovered = _useState2[0],
42
+ changeIsHovered = _useState2[1];
61
43
  var clickHandler = function clickHandler() {
62
44
  onClick && onClick();
63
45
  };
64
-
65
46
  var tagContent = /*#__PURE__*/_react["default"].createElement(_Box["default"], {
66
47
  size: size,
67
48
  shadowDepth: isHovered && (onClick || linkHref) && 2 || 1
68
- }, /*#__PURE__*/_react["default"].createElement(TagContent, {
69
- labelPosition: labelPosition
70
- }, /*#__PURE__*/_react["default"].createElement(IconContainer, {
49
+ }, /*#__PURE__*/_react["default"].createElement(TagContent, null, labelPosition === "before" && size !== "small" && label && /*#__PURE__*/_react["default"].createElement(TagLabel, null, label), icon && /*#__PURE__*/_react["default"].createElement(IconContainer, {
71
50
  iconBgColor: iconBgColor
72
- }, icon ? /*#__PURE__*/_react["default"].createElement(TagIconContainer, null, (0, _typeof2["default"])(icon) === "object" ? icon : /*#__PURE__*/_react["default"].createElement(icon)) : /*#__PURE__*/_react["default"].createElement(TagIcon, {
73
- src: iconSrc
74
- })), size !== "small" && /*#__PURE__*/_react["default"].createElement(TagLabel, null, label)));
75
-
51
+ }, typeof icon === "string" ? /*#__PURE__*/_react["default"].createElement(TagIcon, {
52
+ src: icon
53
+ }) : icon), labelPosition === "after" && size !== "small" && label && /*#__PURE__*/_react["default"].createElement(TagLabel, null, label)));
76
54
  return /*#__PURE__*/_react["default"].createElement(_styledComponents.ThemeProvider, {
77
55
  theme: colorsTheme.tag
78
56
  }, /*#__PURE__*/_react["default"].createElement(StyledDxcTag, {
@@ -94,19 +72,16 @@ var DxcTag = function DxcTag(_ref) {
94
72
  target: newWindow ? "_blank" : "_self"
95
73
  }, tagContent) : tagContent));
96
74
  };
97
-
98
75
  var sizes = {
99
76
  small: "42px",
100
77
  medium: "240px",
101
78
  large: "480px",
102
79
  fillParent: "100%",
103
- fitContent: "unset"
80
+ fitContent: "fit-content"
104
81
  };
105
-
106
82
  var calculateWidth = function calculateWidth(margin, size) {
107
83
  return size === "fillParent" ? "calc(".concat(sizes[size], " - ").concat((0, _utils.getMargin)(margin, "left"), " - ").concat((0, _utils.getMargin)(margin, "right"), ")") : sizes[size];
108
84
  };
109
-
110
85
  var StyledDxcTag = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n display: inline-flex;\n cursor: ", ";\n margin: ", ";\n margin-top: ", ";\n margin-right: ", ";\n margin-bottom: ", ";\n margin-left: ", ";\n width: ", ";\n height: ", ";\n"])), function (_ref2) {
111
86
  var hasAction = _ref2.hasAction;
112
87
  return hasAction && "pointer" || "unset";
@@ -115,51 +90,32 @@ var StyledDxcTag = _styledComponents["default"].div(_templateObject || (_templat
115
90
  return margin && (0, _typeof2["default"])(margin) !== "object" ? _variables.spaces[margin] : "0px";
116
91
  }, function (_ref4) {
117
92
  var margin = _ref4.margin;
118
- return margin && margin.top ? _variables.spaces[margin.top] : "";
93
+ return margin && (0, _typeof2["default"])(margin) === "object" && margin.top ? _variables.spaces[margin.top] : "";
119
94
  }, function (_ref5) {
120
95
  var margin = _ref5.margin;
121
- return margin && margin.right ? _variables.spaces[margin.right] : "";
96
+ return margin && (0, _typeof2["default"])(margin) === "object" && margin.right ? _variables.spaces[margin.right] : "";
122
97
  }, function (_ref6) {
123
98
  var margin = _ref6.margin;
124
- return margin && margin.bottom ? _variables.spaces[margin.bottom] : "";
99
+ return margin && (0, _typeof2["default"])(margin) === "object" && margin.bottom ? _variables.spaces[margin.bottom] : "";
125
100
  }, function (_ref7) {
126
101
  var margin = _ref7.margin;
127
- return margin && margin.left ? _variables.spaces[margin.left] : "";
102
+ return margin && (0, _typeof2["default"])(margin) === "object" && margin.left ? _variables.spaces[margin.left] : "";
128
103
  }, function (props) {
129
104
  return calculateWidth(props.margin, props.size);
130
105
  }, function (props) {
131
106
  return props.theme.height;
132
107
  });
133
-
134
- var TagContent = _styledComponents["default"].div(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n display: inline-flex;\n align-items: center;\n flex-direction: ", ";\n width: 100%;\n height: ", ";\n"])), function (_ref8) {
135
- var labelPosition = _ref8.labelPosition;
136
- return labelPosition === "before" && "row-reverse" || "row";
137
- }, function (props) {
108
+ var TagContent = _styledComponents["default"].div(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n display: inline-flex;\n align-items: center;\n width: 100%;\n height: ", ";\n"])), function (props) {
138
109
  return props.theme.height;
139
110
  });
140
-
141
111
  var StyledLink = _styledComponents["default"].a(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n text-decoration: none;\n border-radius: 4px;\n width: 100%;\n :focus {\n outline: 2px solid ", ";\n outline-offset: 0px;\n }\n"])), function (props) {
142
112
  return props.theme.focusColor;
143
113
  });
144
-
145
114
  var StyledButton = _styledComponents["default"].button(_templateObject4 || (_templateObject4 = (0, _taggedTemplateLiteral2["default"])(["\n background: none;\n border-radius: 4px;\n border: none;\n padding: 0;\n cursor: pointer;\n font-family: inherit;\n width: 100%;\n :focus {\n outline: 2px solid ", ";\n }\n"])), function (props) {
146
115
  return props.theme.focusColor;
147
116
  });
148
-
149
- var TagIcon = _styledComponents["default"].img(_templateObject5 || (_templateObject5 = (0, _taggedTemplateLiteral2["default"])(["\n display: inline-flex;\n justify-content: center;\n align-items: center;\n overflow: hidden;\n width: ", ";\n height: ", ";\n"])), function (props) {
150
- return props.theme.iconWidth;
151
- }, function (props) {
152
- return props.theme.iconHeight;
153
- });
154
-
155
- var TagIconContainer = _styledComponents["default"].div(_templateObject6 || (_templateObject6 = (0, _taggedTemplateLiteral2["default"])(["\n display: inline-flex;\n justify-content: center;\n align-items: center;\n overflow: hidden;\n\n img,\n svg {\n width: ", ";\n height: ", ";\n }\n"])), function (props) {
156
- return props.theme.iconWidth;
157
- }, function (props) {
158
- return props.theme.iconHeight;
159
- });
160
-
161
- var IconContainer = _styledComponents["default"].div(_templateObject7 || (_templateObject7 = (0, _taggedTemplateLiteral2["default"])(["\n display: inline-flex;\n background: ", ";\n width: ", ";\n height: 100%;\n justify-content: center;\n align-items: center;\n color: ", ";\n min-width: ", ";\n"])), function (_ref9) {
162
- var iconBgColor = _ref9.iconBgColor;
117
+ var IconContainer = _styledComponents["default"].div(_templateObject5 || (_templateObject5 = (0, _taggedTemplateLiteral2["default"])(["\n display: inline-flex;\n background: ", ";\n width: ", ";\n height: 100%;\n justify-content: center;\n align-items: center;\n color: ", ";\n min-width: ", ";\n overflow: hidden;\n img,\n svg {\n width: ", ";\n height: ", ";\n }\n"])), function (_ref8) {
118
+ var iconBgColor = _ref8.iconBgColor;
163
119
  return iconBgColor;
164
120
  }, function (props) {
165
121
  return props.theme.iconSectionWidth;
@@ -167,9 +123,13 @@ var IconContainer = _styledComponents["default"].div(_templateObject7 || (_templ
167
123
  return props.theme.iconColor;
168
124
  }, function (props) {
169
125
  return props.theme.iconSectionWidth;
126
+ }, function (props) {
127
+ return props.theme.iconWidth;
128
+ }, function (props) {
129
+ return props.theme.iconHeight;
170
130
  });
171
-
172
- var TagLabel = _styledComponents["default"].div(_templateObject8 || (_templateObject8 = (0, _taggedTemplateLiteral2["default"])(["\n font-family: ", ";\n font-size: ", ";\n font-style: ", ";\n font-weight: ", ";\n color: ", ";\n padding-top: ", ";\n padding-bottom: ", ";\n padding-left: ", ";\n padding-right: ", ";\n flex-grow: 1;\n text-align: center;\n text-overflow: ellipsis;\n overflow: hidden;\n white-space: nowrap;\n"])), function (props) {
131
+ var TagIcon = _styledComponents["default"].img(_templateObject6 || (_templateObject6 = (0, _taggedTemplateLiteral2["default"])([""])));
132
+ var TagLabel = _styledComponents["default"].div(_templateObject7 || (_templateObject7 = (0, _taggedTemplateLiteral2["default"])(["\n font-family: ", ";\n font-size: ", ";\n font-style: ", ";\n font-weight: ", ";\n color: ", ";\n padding-top: ", ";\n padding-bottom: ", ";\n padding-left: ", ";\n padding-right: ", ";\n flex-grow: 1;\n text-align: center;\n text-overflow: ellipsis;\n overflow: hidden;\n white-space: nowrap;\n"])), function (props) {
173
133
  return props.theme.fontFamily;
174
134
  }, function (props) {
175
135
  return props.theme.fontSize;
@@ -188,6 +148,4 @@ var TagLabel = _styledComponents["default"].div(_templateObject8 || (_templateOb
188
148
  }, function (props) {
189
149
  return props.theme.labelPaddingRight;
190
150
  });
191
-
192
- var _default = DxcTag;
193
- exports["default"] = _default;
151
+ var _default = exports["default"] = DxcTag;
@@ -3,35 +3,36 @@ import { userEvent, within } from "@storybook/testing-library";
3
3
  import Title from "../../.storybook/components/Title";
4
4
  import ExampleContainer from "../../.storybook/components/ExampleContainer";
5
5
  import DxcTag from "./Tag";
6
+ import { HalstackProvider } from "../HalstackContext";
6
7
 
7
8
  export default {
8
9
  title: "Tag",
9
10
  component: DxcTag,
10
11
  };
11
12
 
12
- const icon = () => {
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
- };
20
- const largeIcon = () => {
21
- return (
22
- <svg xmlns="http://www.w3.org/2000/svg" height="48px" viewBox="0 0 24 24" width="48px" fill="currentColor">
23
- <path d="M0 0h24v24H0V0z" fill="none" />
24
- <path d="M11.99 2C6.47 2 2 6.48 2 12s4.47 10 9.99 10C17.52 22 22 17.52 22 12S17.52 2 11.99 2zM12 20c-4.42 0-8-3.58-8-8s3.58-8 8-8 8 3.58 8 8-3.58 8-8 8zm.5-13H11v6l5.25 3.15.75-1.23-4.5-2.67z" />
25
- </svg>
26
- );
13
+ const icon = (
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
+
20
+ const largeIcon = (
21
+ <svg xmlns="http://www.w3.org/2000/svg" height="48px" viewBox="0 0 24 24" width="48px" fill="currentColor">
22
+ <path d="M0 0h24v24H0V0z" fill="none" />
23
+ <path d="M11.99 2C6.47 2 2 6.48 2 12s4.47 10 9.99 10C17.52 22 22 17.52 22 12S17.52 2 11.99 2zM12 20c-4.42 0-8-3.58-8-8s3.58-8 8-8 8 3.58 8 8-3.58 8-8 8zm.5-13H11v6l5.25 3.15.75-1.23-4.5-2.67z" />
24
+ </svg>
25
+ );
26
+
27
+ const opinionatedTheme = {
28
+ tag: {
29
+ fontColor: "#000000",
30
+ iconColor: "#ffffff",
31
+ },
27
32
  };
28
33
 
29
34
  export const Chromatic = () => (
30
35
  <>
31
- <ExampleContainer>
32
- <Title title="Without label" theme="light" level={4} />
33
- <DxcTag />
34
- </ExampleContainer>
35
36
  <ExampleContainer>
36
37
  <Title title="With icon" theme="light" level={4} />
37
38
  <DxcTag icon={icon} />
@@ -46,7 +47,10 @@ export const Chromatic = () => (
46
47
  </ExampleContainer>
47
48
  <ExampleContainer>
48
49
  <Title title="With label and icon" theme="light" level={4} />
49
- <DxcTag label="Tag" icon={icon} />
50
+ <DxcTag
51
+ label="Tag"
52
+ icon="https://iconape.com/wp-content/files/yd/367773/svg/logo-linkedin-logo-icon-png-svg.png"
53
+ />
50
54
  </ExampleContainer>
51
55
  <ExampleContainer>
52
56
  <Title title="With right icon" theme="light" level={4} />
@@ -102,37 +106,43 @@ export const Chromatic = () => (
102
106
  <Title title="Sizes" theme="light" level={2} />
103
107
  <ExampleContainer>
104
108
  <Title title="Small size" theme="light" level={4} />
105
- <DxcTag label="Small" size="small" />
109
+ <DxcTag label="Small" size="small" icon={icon} />
106
110
  </ExampleContainer>
107
111
  <ExampleContainer>
108
112
  <Title title="Medium size" theme="light" level={4} />
109
- <DxcTag label="Medium size medium s" size="medium" />
113
+ <DxcTag label="Medium size medium s" size="medium" icon={icon} />
110
114
  </ExampleContainer>
111
115
  <ExampleContainer>
112
116
  <Title title="Medium size with ellipsis" theme="light" level={4} />
113
- <DxcTag label="Medium size medium si medium" size="medium" />
117
+ <DxcTag label="Medium size medium si medium" size="medium" icon={icon} />
114
118
  </ExampleContainer>
115
119
  <ExampleContainer>
116
120
  <Title title="Large size" theme="light" level={4} />
117
- <DxcTag label="Large size large size large size large size large size" size="large" />
121
+ <DxcTag label="Large size large size large size large size large size" size="large" icon={icon} />
118
122
  </ExampleContainer>
119
123
  <ExampleContainer>
120
124
  <Title title="Large size with ellipsis" theme="light" level={4} />
121
- <DxcTag label="Large size large size large size large size large size large size" size="large" />
125
+ <DxcTag label="Large size large size large size large size large size large size" size="large" icon={icon} />
122
126
  </ExampleContainer>
123
127
  <ExampleContainer>
124
128
  <Title title="FillParent size" theme="light" level={4} />
125
- <DxcTag label="FillParent" size="fillParent" />
129
+ <DxcTag label="FillParent" size="fillParent" icon={icon} />
126
130
  </ExampleContainer>
127
131
  <ExampleContainer>
128
132
  <Title title="FitContent size" theme="light" level={4} />
129
- <DxcTag label="FitContent" size="fitContent" />
133
+ <DxcTag label="FitContent" size="fitContent" icon={icon} />
134
+ </ExampleContainer>
135
+ <Title title="Opinionated theme" theme="light" level={2} />
136
+ <ExampleContainer>
137
+ <HalstackProvider theme={opinionatedTheme}>
138
+ <DxcTag label="Tag" icon={icon} />
139
+ </HalstackProvider>
130
140
  </ExampleContainer>
131
141
  </>
132
142
  );
133
143
 
134
144
  const LinkTag = () => (
135
- <ExampleContainer>
145
+ <ExampleContainer expanded>
136
146
  <Title title="Hover link tag" theme="light" level={4} />
137
147
  <DxcTag label="Tag" icon={icon} linkHref="https://www.dxc.com" />
138
148
  </ExampleContainer>
@@ -0,0 +1,49 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+ var _react = _interopRequireDefault(require("react"));
5
+ var _react2 = require("@testing-library/react");
6
+ var _Tag = _interopRequireDefault(require("./Tag.tsx"));
7
+ describe("Tag component tests", function () {
8
+ test("Tag renders with correct label", function () {
9
+ var _render = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Tag["default"], {
10
+ label: "tag-test"
11
+ })),
12
+ getByText = _render.getByText;
13
+ expect(getByText("tag-test")).toBeTruthy();
14
+ });
15
+ test("Tag renders with correct label before", function () {
16
+ var _render2 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Tag["default"], {
17
+ label: "tag-test",
18
+ labelPosition: "before"
19
+ })),
20
+ getByText = _render2.getByText;
21
+ expect(getByText("tag-test")).toBeTruthy();
22
+ });
23
+ test("Tag renders with correct icon", function () {
24
+ var _render3 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Tag["default"], {
25
+ label: "tag-test",
26
+ icon: "/test-icon.jpg"
27
+ })),
28
+ getByRole = _render3.getByRole;
29
+ expect(getByRole("img").getAttribute("src")).toBe("/test-icon.jpg");
30
+ });
31
+ test("Tag renders with link href", function () {
32
+ var _render4 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Tag["default"], {
33
+ label: "tag-test",
34
+ linkHref: "/test/page"
35
+ })),
36
+ getByRole = _render4.getByRole;
37
+ expect(getByRole("link").getAttribute("href")).toBe("/test/page");
38
+ });
39
+ test("Call correct function on click", function () {
40
+ var onClick = jest.fn();
41
+ var _render5 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Tag["default"], {
42
+ label: "tag-test",
43
+ onClick: onClick
44
+ })),
45
+ getByText = _render5.getByText;
46
+ _react2.fireEvent.click(getByText("tag-test"));
47
+ expect(onClick).toHaveBeenCalled();
48
+ });
49
+ });
package/tag/types.d.ts CHANGED
@@ -1,25 +1,13 @@
1
1
  /// <reference types="react" />
2
- declare type Space = "xxsmall" | "xsmall" | "small" | "medium" | "large" | "xlarge" | "xxlarge";
3
- declare type Margin = {
2
+ type Space = "xxsmall" | "xsmall" | "small" | "medium" | "large" | "xlarge" | "xxlarge";
3
+ 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 Props = {
11
- /**
12
- * Element used as the icon that will be placed next to the label.
13
- */
14
- icon?: SVG;
15
- /**
16
- * @deprecated URL of the icon.
17
- */
18
- iconSrc?: string;
19
- /**
20
- * Text to be placed next inside the tag.
21
- */
22
- label?: string;
9
+ type SVG = React.ReactNode & React.SVGProps<SVGSVGElement>;
10
+ type TagCommonProps = {
23
11
  /**
24
12
  * If defined, the tag will be displayed as an anchor, using this prop as "href".
25
13
  * Component will show some visual feedback on hover.
@@ -57,4 +45,25 @@ declare type Props = {
57
45
  */
58
46
  tabIndex?: number;
59
47
  };
48
+ type TagLabelProps = TagCommonProps & {
49
+ /**
50
+ * Element or path used as the icon that will be placed next to the label.
51
+ */
52
+ icon?: string | SVG;
53
+ /**
54
+ * Text to be placed next inside the tag.
55
+ */
56
+ label: string;
57
+ };
58
+ type TagIconProps = TagCommonProps & {
59
+ /**
60
+ * Element or path used as the icon that will be placed next to the label.
61
+ */
62
+ icon: string | SVG;
63
+ /**
64
+ * Text to be placed next inside the tag.
65
+ */
66
+ label?: string;
67
+ };
68
+ type Props = TagLabelProps | TagIconProps;
60
69
  export default Props;
@@ -0,0 +1,8 @@
1
+ import React from "react";
2
+ declare const icons: {
3
+ error: React.JSX.Element;
4
+ clear: React.JSX.Element;
5
+ increment: React.JSX.Element;
6
+ decrement: React.JSX.Element;
7
+ };
8
+ export default icons;
@@ -0,0 +1,56 @@
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 _react = _interopRequireDefault(require("react"));
9
+ var icons = {
10
+ error: /*#__PURE__*/_react["default"].createElement("svg", {
11
+ xmlns: "http://www.w3.org/2000/svg",
12
+ height: "24px",
13
+ viewBox: "0 0 24 24",
14
+ width: "24px",
15
+ fill: "currentColor"
16
+ }, /*#__PURE__*/_react["default"].createElement("path", {
17
+ d: "M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zm1 15h-2v-2h2v2zm0-4h-2V7h2v6z"
18
+ })),
19
+ clear: /*#__PURE__*/_react["default"].createElement("svg", {
20
+ xmlns: "http://www.w3.org/2000/svg",
21
+ width: "24",
22
+ height: "24",
23
+ viewBox: "0 0 24 24",
24
+ fill: "currentColor"
25
+ }, /*#__PURE__*/_react["default"].createElement("path", {
26
+ d: "M0 0h24v24H0V0z",
27
+ fill: "none"
28
+ }), /*#__PURE__*/_react["default"].createElement("path", {
29
+ d: "M19 6.41L17.59 5 12 10.59 6.41 5 5 6.41 10.59 12 5 17.59 6.41 19 12 13.41 17.59 19 19 17.59 13.41 12 19 6.41z"
30
+ })),
31
+ increment: /*#__PURE__*/_react["default"].createElement("svg", {
32
+ xmlns: "http://www.w3.org/2000/svg",
33
+ height: "24px",
34
+ viewBox: "0 0 24 24",
35
+ width: "24px",
36
+ fill: "currentColor"
37
+ }, /*#__PURE__*/_react["default"].createElement("path", {
38
+ d: "M0 0h24v24H0z",
39
+ fill: "none"
40
+ }), /*#__PURE__*/_react["default"].createElement("path", {
41
+ d: "M19 13h-6v6h-2v-6H5v-2h6V5h2v6h6v2z"
42
+ })),
43
+ decrement: /*#__PURE__*/_react["default"].createElement("svg", {
44
+ xmlns: "http://www.w3.org/2000/svg",
45
+ height: "24px",
46
+ viewBox: "0 0 24 24",
47
+ width: "24px",
48
+ fill: "currentColor"
49
+ }, /*#__PURE__*/_react["default"].createElement("path", {
50
+ d: "M0 0h24v24H0z",
51
+ fill: "none"
52
+ }), /*#__PURE__*/_react["default"].createElement("path", {
53
+ d: "M19 13H5v-2h14v2z"
54
+ }))
55
+ };
56
+ var _default = exports["default"] = icons;
@@ -0,0 +1,4 @@
1
+ import React from "react";
2
+ import { SuggestionProps } from "./types";
3
+ declare const _default: React.MemoExoticComponent<({ id, value, onClick, suggestion, isLast, visuallyFocused, highlighted, }: SuggestionProps) => JSX.Element>;
4
+ export default _default;
@@ -0,0 +1,67 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+ var _typeof = require("@babel/runtime/helpers/typeof");
5
+ Object.defineProperty(exports, "__esModule", {
6
+ value: true
7
+ });
8
+ exports["default"] = void 0;
9
+ var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
10
+ var _react = _interopRequireWildcard(require("react"));
11
+ var _styledComponents = _interopRequireDefault(require("styled-components"));
12
+ var _templateObject, _templateObject2;
13
+ function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(e) { return e ? t : r; })(e); }
14
+ function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != _typeof(e) && "function" != typeof e) return { "default": e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && Object.prototype.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n["default"] = e, t && t.set(e, n), n; }
15
+ var transformSpecialChars = function transformSpecialChars(str) {
16
+ var specialCharsRegex = /[\\*()\[\]{}+?/]/;
17
+ var value = str;
18
+ if (specialCharsRegex.test(value)) {
19
+ var regexAsString = specialCharsRegex.toString().split("");
20
+ var uniqueSpecialChars = regexAsString.filter(function (item, index) {
21
+ return regexAsString.indexOf(item) === index;
22
+ });
23
+ uniqueSpecialChars.forEach(function (specialChar) {
24
+ if (str.includes(specialChar)) value = value.replace(specialChar, "\\" + specialChar);
25
+ });
26
+ }
27
+ return value;
28
+ };
29
+ var Suggestion = function Suggestion(_ref) {
30
+ var id = _ref.id,
31
+ value = _ref.value,
32
+ _onClick = _ref.onClick,
33
+ suggestion = _ref.suggestion,
34
+ isLast = _ref.isLast,
35
+ visuallyFocused = _ref.visuallyFocused,
36
+ highlighted = _ref.highlighted;
37
+ var matchedSuggestion = (0, _react.useMemo)(function () {
38
+ var regEx = new RegExp(transformSpecialChars(value), "i");
39
+ return {
40
+ matchedWords: suggestion.match(regEx),
41
+ noMatchedWords: suggestion.replace(regEx, "")
42
+ };
43
+ }, [value, suggestion]);
44
+ return /*#__PURE__*/_react["default"].createElement(SuggestionContainer, {
45
+ id: id,
46
+ onClick: function onClick() {
47
+ _onClick(suggestion);
48
+ },
49
+ visuallyFocused: visuallyFocused,
50
+ role: "option",
51
+ "aria-selected": visuallyFocused ? true : undefined
52
+ }, /*#__PURE__*/_react["default"].createElement(StyledSuggestion, {
53
+ isLast: isLast,
54
+ visuallyFocused: visuallyFocused
55
+ }, highlighted ? /*#__PURE__*/_react["default"].createElement(_react["default"].Fragment, null, /*#__PURE__*/_react["default"].createElement("strong", null, matchedSuggestion.matchedWords), matchedSuggestion.noMatchedWords) : suggestion));
56
+ };
57
+ var SuggestionContainer = _styledComponents["default"].li(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n padding: 0 0.5rem;\n line-height: 1.715em;\n cursor: pointer;\n box-shadow: inset 0 0 0 2px\n ", ";\n\n &:hover {\n background-color: ", ";\n }\n &:active {\n background-color: ", ";\n }\n"])), function (props) {
58
+ return props.visuallyFocused ? props.theme.focusListOptionBorderColor : "transparent";
59
+ }, function (props) {
60
+ return props.theme.hoverListOptionBackgroundColor;
61
+ }, function (props) {
62
+ return props.theme.activeListOptionBackgroundColor;
63
+ });
64
+ var StyledSuggestion = _styledComponents["default"].span(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n width: 100%;\n overflow: hidden;\n text-overflow: ellipsis;\n white-space: nowrap;\n padding: 0.25rem 0.5rem 0.188rem 0.5rem;\n ", ";\n"])), function (props) {
65
+ return props.isLast || props.visuallyFocused ? "border-bottom: 1px solid transparent" : "border-bottom: 1px solid ".concat(props.theme.listOptionDividerColor);
66
+ });
67
+ var _default = exports["default"] = /*#__PURE__*/_react["default"].memo(Suggestion);
@@ -0,0 +1,4 @@
1
+ import React from "react";
2
+ import { SuggestionsProps } from "./types";
3
+ declare const _default: React.MemoExoticComponent<({ id, value, suggestions, visualFocusIndex, highlightedSuggestions, searchHasErrors, isSearching, suggestionOnClick, styles, }: SuggestionsProps) => JSX.Element>;
4
+ export default _default;