@dxc-technology/halstack-react 0.0.0-d3554d7 → 0.0.0-d3df47e

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 (331) hide show
  1. package/BackgroundColorContext.d.ts +1 -10
  2. package/BackgroundColorContext.js +5 -22
  3. package/HalstackContext.d.ts +1221 -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 +116 -181
  8. package/accordion/Accordion.stories.tsx +103 -127
  9. package/accordion/Accordion.test.js +32 -33
  10. package/accordion/types.d.ts +9 -16
  11. package/accordion-group/AccordionGroup.d.ts +5 -4
  12. package/accordion-group/AccordionGroup.js +38 -107
  13. package/accordion-group/AccordionGroup.stories.tsx +95 -68
  14. package/accordion-group/AccordionGroup.test.js +55 -90
  15. package/accordion-group/AccordionGroupAccordion.d.ts +4 -0
  16. package/accordion-group/AccordionGroupAccordion.js +31 -0
  17. package/accordion-group/types.d.ts +15 -16
  18. package/action-icon/ActionIcon.d.ts +4 -0
  19. package/action-icon/ActionIcon.js +47 -0
  20. package/action-icon/ActionIcon.stories.tsx +41 -0
  21. package/action-icon/ActionIcon.test.js +64 -0
  22. package/action-icon/types.d.ts +26 -0
  23. package/alert/Alert.js +23 -59
  24. package/alert/Alert.stories.tsx +28 -0
  25. package/alert/Alert.test.js +29 -46
  26. package/alert/types.d.ts +5 -5
  27. package/badge/Badge.d.ts +1 -1
  28. package/badge/Badge.js +142 -40
  29. package/badge/Badge.stories.tsx +210 -0
  30. package/badge/Badge.test.js +30 -0
  31. package/badge/types.d.ts +52 -2
  32. package/bleed/Bleed.js +14 -55
  33. package/bleed/Bleed.stories.tsx +95 -95
  34. package/bleed/types.d.ts +26 -2
  35. package/box/Box.d.ts +1 -1
  36. package/box/Box.js +30 -81
  37. package/box/Box.stories.tsx +38 -51
  38. package/box/Box.test.js +2 -7
  39. package/box/types.d.ts +3 -14
  40. package/bulleted-list/BulletedList.d.ts +7 -0
  41. package/bulleted-list/BulletedList.js +89 -0
  42. package/bulleted-list/BulletedList.stories.tsx +115 -0
  43. package/bulleted-list/types.d.ts +38 -0
  44. package/button/Button.d.ts +1 -1
  45. package/button/Button.js +62 -113
  46. package/button/Button.stories.tsx +160 -90
  47. package/button/Button.test.js +20 -17
  48. package/button/types.d.ts +12 -8
  49. package/card/Card.d.ts +1 -1
  50. package/card/Card.js +58 -102
  51. package/card/Card.stories.tsx +12 -42
  52. package/card/Card.test.js +11 -22
  53. package/card/types.d.ts +6 -11
  54. package/checkbox/Checkbox.d.ts +2 -2
  55. package/checkbox/Checkbox.js +144 -182
  56. package/checkbox/Checkbox.stories.tsx +166 -136
  57. package/checkbox/Checkbox.test.js +163 -29
  58. package/checkbox/types.d.ts +18 -6
  59. package/chip/Chip.js +39 -79
  60. package/chip/Chip.stories.tsx +121 -26
  61. package/chip/Chip.test.js +16 -31
  62. package/chip/types.d.ts +4 -4
  63. package/common/OpenSans.css +68 -80
  64. package/common/coreTokens.d.ts +237 -0
  65. package/common/coreTokens.js +184 -0
  66. package/common/utils.d.ts +1 -0
  67. package/common/utils.js +6 -12
  68. package/common/variables.d.ts +1367 -0
  69. package/common/variables.js +1002 -1136
  70. package/container/Container.d.ts +4 -0
  71. package/container/Container.js +194 -0
  72. package/container/Container.stories.tsx +214 -0
  73. package/container/types.d.ts +74 -0
  74. package/date-input/Calendar.d.ts +4 -0
  75. package/date-input/Calendar.js +214 -0
  76. package/date-input/DateInput.js +171 -306
  77. package/date-input/DateInput.stories.tsx +203 -56
  78. package/date-input/DateInput.test.js +708 -369
  79. package/date-input/DatePicker.d.ts +4 -0
  80. package/date-input/DatePicker.js +115 -0
  81. package/date-input/Icons.d.ts +6 -0
  82. package/date-input/Icons.js +58 -0
  83. package/date-input/YearPicker.d.ts +4 -0
  84. package/date-input/YearPicker.js +100 -0
  85. package/date-input/types.d.ts +86 -22
  86. package/dialog/Dialog.d.ts +1 -1
  87. package/dialog/Dialog.js +68 -130
  88. package/dialog/Dialog.stories.tsx +320 -167
  89. package/dialog/Dialog.test.js +287 -20
  90. package/dialog/types.d.ts +18 -25
  91. package/dropdown/Dropdown.d.ts +1 -1
  92. package/dropdown/Dropdown.js +243 -304
  93. package/dropdown/Dropdown.stories.tsx +245 -56
  94. package/dropdown/Dropdown.test.js +575 -165
  95. package/dropdown/DropdownMenu.d.ts +4 -0
  96. package/dropdown/DropdownMenu.js +63 -0
  97. package/dropdown/DropdownMenuItem.d.ts +4 -0
  98. package/dropdown/DropdownMenuItem.js +67 -0
  99. package/dropdown/types.d.ts +32 -14
  100. package/file-input/FileInput.d.ts +2 -2
  101. package/file-input/FileInput.js +246 -357
  102. package/file-input/FileInput.stories.tsx +123 -12
  103. package/file-input/FileInput.test.js +369 -367
  104. package/file-input/FileItem.d.ts +4 -14
  105. package/file-input/FileItem.js +50 -99
  106. package/file-input/types.d.ts +25 -8
  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/footer/Footer.d.ts +1 -1
  112. package/footer/Footer.js +70 -190
  113. package/footer/Footer.stories.tsx +60 -19
  114. package/footer/Footer.test.js +33 -57
  115. package/footer/Icons.d.ts +3 -2
  116. package/footer/Icons.js +67 -8
  117. package/footer/types.d.ts +25 -26
  118. package/grid/Grid.d.ts +7 -0
  119. package/grid/Grid.js +76 -0
  120. package/grid/Grid.stories.tsx +219 -0
  121. package/grid/types.d.ts +115 -0
  122. package/header/Header.d.ts +4 -3
  123. package/header/Header.js +99 -203
  124. package/header/Header.stories.tsx +152 -63
  125. package/header/Header.test.js +31 -28
  126. package/header/Icons.d.ts +2 -2
  127. package/header/Icons.js +4 -9
  128. package/header/types.d.ts +5 -19
  129. package/heading/Heading.js +10 -32
  130. package/heading/Heading.test.js +71 -88
  131. package/heading/types.d.ts +7 -7
  132. package/image/Image.d.ts +4 -0
  133. package/image/Image.js +70 -0
  134. package/image/Image.stories.tsx +127 -0
  135. package/image/types.d.ts +72 -0
  136. package/inset/Inset.js +14 -55
  137. package/inset/Inset.stories.tsx +37 -36
  138. package/inset/types.d.ts +26 -2
  139. package/layout/ApplicationLayout.d.ts +16 -6
  140. package/layout/ApplicationLayout.js +84 -181
  141. package/layout/ApplicationLayout.stories.tsx +85 -94
  142. package/layout/Icons.d.ts +8 -0
  143. package/layout/Icons.js +51 -48
  144. package/layout/SidenavContext.d.ts +5 -0
  145. package/layout/SidenavContext.js +13 -0
  146. package/layout/types.d.ts +19 -35
  147. package/link/Link.d.ts +3 -2
  148. package/link/Link.js +61 -99
  149. package/link/Link.stories.tsx +155 -53
  150. package/link/Link.test.js +25 -53
  151. package/link/types.d.ts +15 -31
  152. package/main.d.ts +14 -13
  153. package/main.js +65 -101
  154. package/nav-tabs/NavTabs.d.ts +8 -0
  155. package/nav-tabs/NavTabs.js +93 -0
  156. package/nav-tabs/NavTabs.stories.tsx +276 -0
  157. package/nav-tabs/NavTabs.test.js +76 -0
  158. package/nav-tabs/Tab.d.ts +4 -0
  159. package/nav-tabs/Tab.js +118 -0
  160. package/nav-tabs/types.d.ts +52 -0
  161. package/nav-tabs/types.js +5 -0
  162. package/number-input/NumberInput.d.ts +7 -0
  163. package/number-input/NumberInput.js +27 -43
  164. package/number-input/NumberInput.stories.tsx +44 -28
  165. package/number-input/NumberInput.test.js +703 -381
  166. package/number-input/types.d.ts +28 -15
  167. package/package.json +46 -47
  168. package/paginator/Icons.d.ts +5 -0
  169. package/paginator/Icons.js +21 -47
  170. package/paginator/Paginator.js +34 -91
  171. package/paginator/Paginator.stories.tsx +24 -0
  172. package/paginator/Paginator.test.js +280 -211
  173. package/paginator/types.d.ts +3 -3
  174. package/paragraph/Paragraph.d.ts +5 -0
  175. package/paragraph/Paragraph.js +22 -0
  176. package/paragraph/Paragraph.stories.tsx +27 -0
  177. package/password-input/Icons.d.ts +6 -0
  178. package/password-input/Icons.js +35 -0
  179. package/password-input/PasswordInput.js +57 -123
  180. package/password-input/PasswordInput.stories.tsx +1 -33
  181. package/password-input/PasswordInput.test.js +162 -147
  182. package/password-input/types.d.ts +21 -17
  183. package/progress-bar/ProgressBar.js +65 -91
  184. package/progress-bar/ProgressBar.stories.tsx +93 -0
  185. package/progress-bar/ProgressBar.test.js +72 -44
  186. package/progress-bar/types.d.ts +3 -3
  187. package/quick-nav/QuickNav.d.ts +4 -0
  188. package/quick-nav/QuickNav.js +94 -0
  189. package/quick-nav/QuickNav.stories.tsx +356 -0
  190. package/quick-nav/types.d.ts +21 -0
  191. package/quick-nav/types.js +5 -0
  192. package/radio-group/Radio.d.ts +1 -1
  193. package/radio-group/Radio.js +59 -76
  194. package/radio-group/RadioGroup.js +72 -116
  195. package/radio-group/RadioGroup.stories.tsx +135 -17
  196. package/radio-group/RadioGroup.test.js +529 -467
  197. package/radio-group/types.d.ts +86 -9
  198. package/resultset-table/Icons.d.ts +7 -0
  199. package/resultset-table/Icons.js +47 -0
  200. package/{resultsetTable → resultset-table}/ResultsetTable.d.ts +1 -1
  201. package/resultset-table/ResultsetTable.js +165 -0
  202. package/{resultsetTable → resultset-table}/ResultsetTable.stories.tsx +69 -25
  203. package/{resultsetTable → resultset-table}/ResultsetTable.test.js +117 -118
  204. package/{resultsetTable → resultset-table}/types.d.ts +13 -7
  205. package/resultset-table/types.js +5 -0
  206. package/select/Icons.d.ts +10 -0
  207. package/select/Icons.js +89 -0
  208. package/select/Listbox.d.ts +4 -0
  209. package/select/Listbox.js +143 -0
  210. package/select/Option.d.ts +4 -0
  211. package/select/Option.js +87 -0
  212. package/select/Select.js +223 -502
  213. package/select/Select.stories.tsx +534 -145
  214. package/select/Select.test.js +2009 -1539
  215. package/select/types.d.ts +64 -25
  216. package/sidenav/Icons.d.ts +7 -0
  217. package/sidenav/Icons.js +47 -0
  218. package/sidenav/Sidenav.d.ts +6 -5
  219. package/sidenav/Sidenav.js +131 -71
  220. package/sidenav/Sidenav.stories.tsx +251 -151
  221. package/sidenav/Sidenav.test.js +26 -45
  222. package/sidenav/types.d.ts +52 -26
  223. package/slider/Slider.d.ts +2 -2
  224. package/slider/Slider.js +148 -180
  225. package/slider/Slider.test.js +198 -73
  226. package/slider/types.d.ts +11 -3
  227. package/spinner/Spinner.js +31 -75
  228. package/spinner/{Spinner.stories.jsx → Spinner.stories.tsx} +53 -27
  229. package/spinner/Spinner.test.js +26 -35
  230. package/spinner/types.d.ts +3 -3
  231. package/status-light/StatusLight.d.ts +4 -0
  232. package/status-light/StatusLight.js +51 -0
  233. package/status-light/StatusLight.stories.tsx +74 -0
  234. package/status-light/StatusLight.test.js +25 -0
  235. package/status-light/types.d.ts +17 -0
  236. package/status-light/types.js +5 -0
  237. package/switch/Switch.d.ts +2 -2
  238. package/switch/Switch.js +149 -114
  239. package/switch/Switch.stories.tsx +44 -67
  240. package/switch/Switch.test.js +146 -39
  241. package/switch/types.d.ts +13 -5
  242. package/table/Table.d.ts +1 -1
  243. package/table/Table.js +25 -32
  244. package/table/{Table.stories.jsx → Table.stories.tsx} +178 -1
  245. package/table/Table.test.js +3 -8
  246. package/table/types.d.ts +12 -6
  247. package/tabs/Tab.d.ts +4 -0
  248. package/tabs/Tab.js +116 -0
  249. package/tabs/Tabs.d.ts +1 -1
  250. package/tabs/Tabs.js +316 -145
  251. package/tabs/Tabs.stories.tsx +120 -14
  252. package/tabs/Tabs.test.js +238 -67
  253. package/tabs/types.d.ts +29 -15
  254. package/tag/Tag.js +41 -78
  255. package/tag/Tag.stories.tsx +25 -8
  256. package/tag/Tag.test.js +20 -31
  257. package/tag/types.d.ts +7 -7
  258. package/text-input/Icons.d.ts +8 -0
  259. package/text-input/Icons.js +56 -0
  260. package/text-input/Suggestion.d.ts +4 -0
  261. package/text-input/Suggestion.js +67 -0
  262. package/text-input/Suggestions.d.ts +4 -0
  263. package/text-input/Suggestions.js +84 -0
  264. package/text-input/TextInput.js +324 -548
  265. package/text-input/TextInput.stories.tsx +272 -281
  266. package/text-input/TextInput.test.js +1425 -1377
  267. package/text-input/types.d.ts +70 -24
  268. package/textarea/Textarea.js +82 -134
  269. package/textarea/Textarea.stories.tsx +174 -0
  270. package/textarea/Textarea.test.js +168 -198
  271. package/textarea/types.d.ts +27 -16
  272. package/toggle-group/ToggleGroup.d.ts +2 -2
  273. package/toggle-group/ToggleGroup.js +92 -105
  274. package/toggle-group/ToggleGroup.stories.tsx +53 -8
  275. package/toggle-group/ToggleGroup.test.js +78 -66
  276. package/toggle-group/types.d.ts +34 -17
  277. package/typography/Typography.d.ts +4 -0
  278. package/typography/Typography.js +23 -0
  279. package/typography/Typography.stories.tsx +198 -0
  280. package/typography/types.d.ts +18 -0
  281. package/typography/types.js +5 -0
  282. package/useTheme.d.ts +1119 -1
  283. package/useTheme.js +4 -11
  284. package/useTranslatedLabels.d.ts +85 -0
  285. package/useTranslatedLabels.js +14 -0
  286. package/utils/BaseTypography.d.ts +21 -0
  287. package/utils/BaseTypography.js +94 -0
  288. package/utils/FocusLock.d.ts +13 -0
  289. package/utils/FocusLock.js +124 -0
  290. package/wizard/Wizard.d.ts +1 -1
  291. package/wizard/Wizard.js +70 -101
  292. package/wizard/Wizard.stories.tsx +48 -19
  293. package/wizard/Wizard.test.js +73 -87
  294. package/wizard/types.d.ts +12 -8
  295. package/ThemeContext.d.ts +0 -10
  296. package/ThemeContext.js +0 -243
  297. package/card/ice-cream.jpg +0 -0
  298. package/common/RequiredComponent.js +0 -32
  299. package/list/List.d.ts +0 -4
  300. package/list/List.js +0 -47
  301. package/list/List.stories.tsx +0 -95
  302. package/list/types.d.ts +0 -7
  303. package/number-input/NumberInputContext.d.ts +0 -4
  304. package/number-input/NumberInputContext.js +0 -19
  305. package/number-input/numberInputContextTypes.d.ts +0 -19
  306. package/progress-bar/ProgressBar.stories.jsx +0 -58
  307. package/radio/Radio.d.ts +0 -4
  308. package/radio/Radio.js +0 -174
  309. package/radio/Radio.stories.tsx +0 -192
  310. package/radio/Radio.test.js +0 -71
  311. package/radio/types.d.ts +0 -54
  312. package/resultsetTable/ResultsetTable.js +0 -254
  313. package/row/Row.d.ts +0 -3
  314. package/row/Row.js +0 -127
  315. package/row/Row.stories.tsx +0 -237
  316. package/row/types.d.ts +0 -10
  317. package/slider/Slider.stories.tsx +0 -177
  318. package/stack/Stack.d.ts +0 -3
  319. package/stack/Stack.js +0 -97
  320. package/stack/Stack.stories.tsx +0 -164
  321. package/stack/types.d.ts +0 -9
  322. package/text/Text.d.ts +0 -7
  323. package/text/Text.js +0 -30
  324. package/text/Text.stories.tsx +0 -19
  325. package/textarea/Textarea.stories.jsx +0 -157
  326. /package/{list → action-icon}/types.js +0 -0
  327. /package/{radio → bulleted-list}/types.js +0 -0
  328. /package/{resultsetTable → container}/types.js +0 -0
  329. /package/{row → flex}/types.js +0 -0
  330. /package/{stack → grid}/types.js +0 -0
  331. /package/{number-input/numberInputContextTypes.js → image/types.js} +0 -0
package/tag/Tag.js CHANGED
@@ -1,77 +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
9
  var _typeof2 = _interopRequireDefault(require("@babel/runtime/helpers/typeof"));
13
-
14
10
  var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
15
-
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
-
14
+ var _variables = require("../common/variables");
24
15
  var _useTheme = _interopRequireDefault(require("../useTheme"));
25
-
26
- var _utils = require("../common/utils.js");
27
-
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
- _ref$label = _ref.label,
39
- label = _ref$label === void 0 ? "" : _ref$label,
40
- linkHref = _ref.linkHref,
41
- onClick = _ref.onClick,
42
- _ref$iconBgColor = _ref.iconBgColor,
43
- iconBgColor = _ref$iconBgColor === void 0 ? "#5f249f" : _ref$iconBgColor,
44
- _ref$labelPosition = _ref.labelPosition,
45
- labelPosition = _ref$labelPosition === void 0 ? "after" : _ref$labelPosition,
46
- _ref$newWindow = _ref.newWindow,
47
- newWindow = _ref$newWindow === void 0 ? false : _ref$newWindow,
48
- margin = _ref.margin,
49
- _ref$size = _ref.size,
50
- size = _ref$size === void 0 ? "fitContent" : _ref$size,
51
- _ref$tabIndex = _ref.tabIndex,
52
- 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;
53
38
  var colorsTheme = (0, _useTheme["default"])();
54
-
55
39
  var _useState = (0, _react.useState)(false),
56
- _useState2 = (0, _slicedToArray2["default"])(_useState, 2),
57
- isHovered = _useState2[0],
58
- changeIsHovered = _useState2[1];
59
-
40
+ _useState2 = (0, _slicedToArray2["default"])(_useState, 2),
41
+ isHovered = _useState2[0],
42
+ changeIsHovered = _useState2[1];
60
43
  var clickHandler = function clickHandler() {
61
44
  onClick && onClick();
62
45
  };
63
-
64
46
  var tagContent = /*#__PURE__*/_react["default"].createElement(_Box["default"], {
65
47
  size: size,
66
48
  shadowDepth: isHovered && (onClick || linkHref) && 2 || 1
67
- }, /*#__PURE__*/_react["default"].createElement(TagContent, {
68
- labelPosition: labelPosition
69
- }, /*#__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, {
70
50
  iconBgColor: iconBgColor
71
- }, icon && /*#__PURE__*/_react["default"].createElement(TagIconContainer, null, typeof icon === "string" ? /*#__PURE__*/_react["default"].createElement(TagIcon, {
51
+ }, typeof icon === "string" ? /*#__PURE__*/_react["default"].createElement(TagIcon, {
72
52
  src: icon
73
- }) : icon)), size !== "small" && /*#__PURE__*/_react["default"].createElement(TagLabel, null, label)));
74
-
53
+ }) : icon), labelPosition === "after" && size !== "small" && label && /*#__PURE__*/_react["default"].createElement(TagLabel, null, label)));
75
54
  return /*#__PURE__*/_react["default"].createElement(_styledComponents.ThemeProvider, {
76
55
  theme: colorsTheme.tag
77
56
  }, /*#__PURE__*/_react["default"].createElement(StyledDxcTag, {
@@ -93,19 +72,16 @@ var DxcTag = function DxcTag(_ref) {
93
72
  target: newWindow ? "_blank" : "_self"
94
73
  }, tagContent) : tagContent));
95
74
  };
96
-
97
75
  var sizes = {
98
76
  small: "42px",
99
77
  medium: "240px",
100
78
  large: "480px",
101
79
  fillParent: "100%",
102
- fitContent: "unset"
80
+ fitContent: "fit-content"
103
81
  };
104
-
105
82
  var calculateWidth = function calculateWidth(margin, size) {
106
83
  return size === "fillParent" ? "calc(".concat(sizes[size], " - ").concat((0, _utils.getMargin)(margin, "left"), " - ").concat((0, _utils.getMargin)(margin, "right"), ")") : sizes[size];
107
84
  };
108
-
109
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) {
110
86
  var hasAction = _ref2.hasAction;
111
87
  return hasAction && "pointer" || "unset";
@@ -114,47 +90,32 @@ var StyledDxcTag = _styledComponents["default"].div(_templateObject || (_templat
114
90
  return margin && (0, _typeof2["default"])(margin) !== "object" ? _variables.spaces[margin] : "0px";
115
91
  }, function (_ref4) {
116
92
  var margin = _ref4.margin;
117
- return margin && margin.top ? _variables.spaces[margin.top] : "";
93
+ return margin && (0, _typeof2["default"])(margin) === "object" && margin.top ? _variables.spaces[margin.top] : "";
118
94
  }, function (_ref5) {
119
95
  var margin = _ref5.margin;
120
- return margin && margin.right ? _variables.spaces[margin.right] : "";
96
+ return margin && (0, _typeof2["default"])(margin) === "object" && margin.right ? _variables.spaces[margin.right] : "";
121
97
  }, function (_ref6) {
122
98
  var margin = _ref6.margin;
123
- return margin && margin.bottom ? _variables.spaces[margin.bottom] : "";
99
+ return margin && (0, _typeof2["default"])(margin) === "object" && margin.bottom ? _variables.spaces[margin.bottom] : "";
124
100
  }, function (_ref7) {
125
101
  var margin = _ref7.margin;
126
- return margin && margin.left ? _variables.spaces[margin.left] : "";
102
+ return margin && (0, _typeof2["default"])(margin) === "object" && margin.left ? _variables.spaces[margin.left] : "";
127
103
  }, function (props) {
128
104
  return calculateWidth(props.margin, props.size);
129
105
  }, function (props) {
130
106
  return props.theme.height;
131
107
  });
132
-
133
- 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) {
134
- var labelPosition = _ref8.labelPosition;
135
- return labelPosition === "before" && "row-reverse" || "row";
136
- }, 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) {
137
109
  return props.theme.height;
138
110
  });
139
-
140
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) {
141
112
  return props.theme.focusColor;
142
113
  });
143
-
144
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) {
145
115
  return props.theme.focusColor;
146
116
  });
147
-
148
- var TagIcon = _styledComponents["default"].img(_templateObject5 || (_templateObject5 = (0, _taggedTemplateLiteral2["default"])([""])));
149
-
150
- 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) {
151
- return props.theme.iconWidth;
152
- }, function (props) {
153
- return props.theme.iconHeight;
154
- });
155
-
156
- 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) {
157
- 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;
158
119
  return iconBgColor;
159
120
  }, function (props) {
160
121
  return props.theme.iconSectionWidth;
@@ -162,9 +123,13 @@ var IconContainer = _styledComponents["default"].div(_templateObject7 || (_templ
162
123
  return props.theme.iconColor;
163
124
  }, function (props) {
164
125
  return props.theme.iconSectionWidth;
126
+ }, function (props) {
127
+ return props.theme.iconWidth;
128
+ }, function (props) {
129
+ return props.theme.iconHeight;
165
130
  });
166
-
167
- 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) {
168
133
  return props.theme.fontFamily;
169
134
  }, function (props) {
170
135
  return props.theme.fontSize;
@@ -183,6 +148,4 @@ var TagLabel = _styledComponents["default"].div(_templateObject8 || (_templateOb
183
148
  }, function (props) {
184
149
  return props.theme.labelPaddingRight;
185
150
  });
186
-
187
- var _default = DxcTag;
188
- exports["default"] = _default;
151
+ var _default = exports["default"] = DxcTag;
@@ -3,6 +3,7 @@ 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",
@@ -23,6 +24,13 @@ const largeIcon = (
23
24
  </svg>
24
25
  );
25
26
 
27
+ const opinionatedTheme = {
28
+ tag: {
29
+ fontColor: "#000000",
30
+ iconColor: "#ffffff",
31
+ },
32
+ };
33
+
26
34
  export const Chromatic = () => (
27
35
  <>
28
36
  <ExampleContainer>
@@ -39,7 +47,10 @@ export const Chromatic = () => (
39
47
  </ExampleContainer>
40
48
  <ExampleContainer>
41
49
  <Title title="With label and icon" theme="light" level={4} />
42
- <DxcTag label="Tag" icon="https://iconape.com/wp-content/files/yd/367773/svg/logo-linkedin-logo-icon-png-svg.png" />
50
+ <DxcTag
51
+ label="Tag"
52
+ icon="https://iconape.com/wp-content/files/yd/367773/svg/logo-linkedin-logo-icon-png-svg.png"
53
+ />
43
54
  </ExampleContainer>
44
55
  <ExampleContainer>
45
56
  <Title title="With right icon" theme="light" level={4} />
@@ -95,31 +106,37 @@ export const Chromatic = () => (
95
106
  <Title title="Sizes" theme="light" level={2} />
96
107
  <ExampleContainer>
97
108
  <Title title="Small size" theme="light" level={4} />
98
- <DxcTag label="Small" size="small" />
109
+ <DxcTag label="Small" size="small" icon={icon} />
99
110
  </ExampleContainer>
100
111
  <ExampleContainer>
101
112
  <Title title="Medium size" theme="light" level={4} />
102
- <DxcTag label="Medium size medium s" size="medium" />
113
+ <DxcTag label="Medium size medium s" size="medium" icon={icon} />
103
114
  </ExampleContainer>
104
115
  <ExampleContainer>
105
116
  <Title title="Medium size with ellipsis" theme="light" level={4} />
106
- <DxcTag label="Medium size medium si medium" size="medium" />
117
+ <DxcTag label="Medium size medium si medium" size="medium" icon={icon} />
107
118
  </ExampleContainer>
108
119
  <ExampleContainer>
109
120
  <Title title="Large size" theme="light" level={4} />
110
- <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} />
111
122
  </ExampleContainer>
112
123
  <ExampleContainer>
113
124
  <Title title="Large size with ellipsis" theme="light" level={4} />
114
- <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} />
115
126
  </ExampleContainer>
116
127
  <ExampleContainer>
117
128
  <Title title="FillParent size" theme="light" level={4} />
118
- <DxcTag label="FillParent" size="fillParent" />
129
+ <DxcTag label="FillParent" size="fillParent" icon={icon} />
119
130
  </ExampleContainer>
120
131
  <ExampleContainer>
121
132
  <Title title="FitContent size" theme="light" level={4} />
122
- <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>
123
140
  </ExampleContainer>
124
141
  </>
125
142
  );
package/tag/Tag.test.js CHANGED
@@ -1,60 +1,49 @@
1
1
  "use strict";
2
2
 
3
3
  var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
-
5
4
  var _react = _interopRequireDefault(require("react"));
6
-
7
5
  var _react2 = require("@testing-library/react");
8
-
9
- var _Tag = _interopRequireDefault(require("./Tag"));
10
-
6
+ var _Tag = _interopRequireDefault(require("./Tag.tsx"));
11
7
  describe("Tag component tests", function () {
12
8
  test("Tag renders with correct label", function () {
13
9
  var _render = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Tag["default"], {
14
- label: "tag-test"
15
- })),
16
- getByText = _render.getByText;
17
-
10
+ label: "tag-test"
11
+ })),
12
+ getByText = _render.getByText;
18
13
  expect(getByText("tag-test")).toBeTruthy();
19
14
  });
20
15
  test("Tag renders with correct label before", function () {
21
16
  var _render2 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Tag["default"], {
22
- label: "tag-test",
23
- labelPosition: "before"
24
- })),
25
- getByText = _render2.getByText;
26
-
17
+ label: "tag-test",
18
+ labelPosition: "before"
19
+ })),
20
+ getByText = _render2.getByText;
27
21
  expect(getByText("tag-test")).toBeTruthy();
28
22
  });
29
23
  test("Tag renders with correct icon", function () {
30
24
  var _render3 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Tag["default"], {
31
- label: "tag-test",
32
- icon: "/test-icon.jpg"
33
- })),
34
- getByRole = _render3.getByRole;
35
-
25
+ label: "tag-test",
26
+ icon: "/test-icon.jpg"
27
+ })),
28
+ getByRole = _render3.getByRole;
36
29
  expect(getByRole("img").getAttribute("src")).toBe("/test-icon.jpg");
37
30
  });
38
31
  test("Tag renders with link href", function () {
39
32
  var _render4 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Tag["default"], {
40
- label: "tag-test",
41
- linkHref: "/test/page"
42
- })),
43
- getByRole = _render4.getByRole;
44
-
33
+ label: "tag-test",
34
+ linkHref: "/test/page"
35
+ })),
36
+ getByRole = _render4.getByRole;
45
37
  expect(getByRole("link").getAttribute("href")).toBe("/test/page");
46
38
  });
47
39
  test("Call correct function on click", function () {
48
40
  var onClick = jest.fn();
49
-
50
41
  var _render5 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Tag["default"], {
51
- label: "tag-test",
52
- onClick: onClick
53
- })),
54
- getByText = _render5.getByText;
55
-
42
+ label: "tag-test",
43
+ onClick: onClick
44
+ })),
45
+ getByText = _render5.getByText;
56
46
  _react2.fireEvent.click(getByText("tag-test"));
57
-
58
47
  expect(onClick).toHaveBeenCalled();
59
48
  });
60
49
  });
package/tag/types.d.ts CHANGED
@@ -1,13 +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>;
10
- declare type TagCommonProps = {
9
+ type SVG = React.ReactNode & React.SVGProps<SVGSVGElement>;
10
+ type TagCommonProps = {
11
11
  /**
12
12
  * If defined, the tag will be displayed as an anchor, using this prop as "href".
13
13
  * Component will show some visual feedback on hover.
@@ -45,7 +45,7 @@ declare type TagCommonProps = {
45
45
  */
46
46
  tabIndex?: number;
47
47
  };
48
- declare type TagLabelProps = TagCommonProps & {
48
+ type TagLabelProps = TagCommonProps & {
49
49
  /**
50
50
  * Element or path used as the icon that will be placed next to the label.
51
51
  */
@@ -55,7 +55,7 @@ declare type TagLabelProps = TagCommonProps & {
55
55
  */
56
56
  label: string;
57
57
  };
58
- declare type TagIconProps = TagCommonProps & {
58
+ type TagIconProps = TagCommonProps & {
59
59
  /**
60
60
  * Element or path used as the icon that will be placed next to the label.
61
61
  */
@@ -65,5 +65,5 @@ declare type TagIconProps = TagCommonProps & {
65
65
  */
66
66
  label?: string;
67
67
  };
68
- declare type Props = TagLabelProps | TagIconProps;
68
+ type Props = TagLabelProps | TagIconProps;
69
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;
@@ -0,0 +1,84 @@
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 _useTranslatedLabels = _interopRequireDefault(require("../useTranslatedLabels"));
13
+ var _Suggestion = _interopRequireDefault(require("./Suggestion"));
14
+ var _Icons = _interopRequireDefault(require("./Icons"));
15
+ var _templateObject, _templateObject2, _templateObject3, _templateObject4;
16
+ 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); }
17
+ 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; }
18
+ var Suggestions = function Suggestions(_ref) {
19
+ var id = _ref.id,
20
+ value = _ref.value,
21
+ suggestions = _ref.suggestions,
22
+ visualFocusIndex = _ref.visualFocusIndex,
23
+ highlightedSuggestions = _ref.highlightedSuggestions,
24
+ searchHasErrors = _ref.searchHasErrors,
25
+ isSearching = _ref.isSearching,
26
+ suggestionOnClick = _ref.suggestionOnClick,
27
+ styles = _ref.styles;
28
+ var translatedLabels = (0, _useTranslatedLabels["default"])();
29
+ var listboxRef = (0, _react.useRef)(null);
30
+ (0, _react.useEffect)(function () {
31
+ var _listboxRef$current, _visualFocusedOptionE;
32
+ var visualFocusedOptionEl = listboxRef === null || listboxRef === void 0 ? void 0 : (_listboxRef$current = listboxRef.current) === null || _listboxRef$current === void 0 ? void 0 : _listboxRef$current.querySelectorAll("[role='option']")[visualFocusIndex];
33
+ visualFocusedOptionEl === null || visualFocusedOptionEl === void 0 ? void 0 : (_visualFocusedOptionE = visualFocusedOptionEl.scrollIntoView) === null || _visualFocusedOptionE === void 0 ? void 0 : _visualFocusedOptionE.call(visualFocusedOptionEl, {
34
+ block: "nearest",
35
+ inline: "start"
36
+ });
37
+ }, [visualFocusIndex]);
38
+ return /*#__PURE__*/_react["default"].createElement(SuggestionsContainer, {
39
+ id: id,
40
+ error: searchHasErrors ? true : false,
41
+ onMouseDown: function onMouseDown(event) {
42
+ event.preventDefault();
43
+ },
44
+ ref: listboxRef,
45
+ role: "listbox",
46
+ style: styles
47
+ }, !isSearching && !searchHasErrors && suggestions.length > 0 && suggestions.map(function (suggestion, index) {
48
+ return /*#__PURE__*/_react["default"].createElement(_Suggestion["default"], {
49
+ key: "suggestion-".concat(index),
50
+ id: "suggestion-".concat(index),
51
+ value: value,
52
+ onClick: suggestionOnClick,
53
+ suggestion: suggestion,
54
+ isLast: index === suggestions.length - 1,
55
+ visuallyFocused: visualFocusIndex === index,
56
+ highlighted: highlightedSuggestions
57
+ });
58
+ }), isSearching && /*#__PURE__*/_react["default"].createElement(SuggestionsSystemMessage, null, translatedLabels.textInput.searchingMessage), searchHasErrors && /*#__PURE__*/_react["default"].createElement(SuggestionsError, null, /*#__PURE__*/_react["default"].createElement(SuggestionsErrorIcon, null, _Icons["default"].error), translatedLabels.textInput.fetchingDataErrorMessage));
59
+ };
60
+ var SuggestionsContainer = _styledComponents["default"].ul(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n box-sizing: border-box;\n max-height: 304px;\n overflow-y: auto;\n margin: 0;\n padding: 0.25rem 0;\n background-color: ", ";\n border: 1px solid\n ", ";\n\n border-radius: 0.25rem;\n box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1);\n color: ", ";\n font-family: ", ";\n font-size: ", ";\n font-style: ", ";\n font-weight: ", ";\n"])), function (props) {
61
+ return props.error ? props.theme.errorListDialogBackgroundColor : props.theme.listDialogBackgroundColor;
62
+ }, function (props) {
63
+ return props.error ? props.theme.errorListDialogBorderColor : props.theme.listDialogBorderColor;
64
+ }, function (props) {
65
+ return props.theme.listOptionFontColor;
66
+ }, function (props) {
67
+ return props.theme.fontFamily;
68
+ }, function (props) {
69
+ return props.theme.listOptionFontSize;
70
+ }, function (props) {
71
+ return props.theme.listOptionFontStyle;
72
+ }, function (props) {
73
+ return props.theme.listOptionFontWeight;
74
+ });
75
+ var SuggestionsSystemMessage = _styledComponents["default"].span(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n padding: 0.25rem 1rem;\n color: ", ";\n line-height: 1.715em;\n"])), function (props) {
76
+ return props.theme.systemMessageFontColor;
77
+ });
78
+ var SuggestionsErrorIcon = _styledComponents["default"].span(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n flex-wrap: wrap;\n align-content: center;\n margin-right: 0.5rem;\n height: 18px;\n width: 18px;\n color: ", ";\n"])), function (props) {
79
+ return props.theme.errorIconColor;
80
+ });
81
+ var SuggestionsError = _styledComponents["default"].span(_templateObject4 || (_templateObject4 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n padding: 0.25rem 1rem;\n align-items: center;\n line-height: 1.715em;\n color: ", ";\n"])), function (props) {
82
+ return props.theme.errorListDialogFontColor;
83
+ });
84
+ var _default = exports["default"] = /*#__PURE__*/_react["default"].memo(Suggestions);